-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathconverter.py
More file actions
69 lines (56 loc) · 2.47 KB
/
converter.py
File metadata and controls
69 lines (56 loc) · 2.47 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# Main validation engine
import exception_messages
from conversion_layout import ConversionLayout, ConversionField
from extractor import Extractor
from common.mappings import ActionFlag
class Converter:
def __init__(self, fhir_data, action_flag = ActionFlag.UPDATE, report_unexpected_exception=True):
self.converted = {}
self.error_records = []
self.action_flag = action_flag
self.report_unexpected_exception = report_unexpected_exception
try:
if not fhir_data:
raise ValueError("FHIR data is required for initialization.")
self.extractor = Extractor(fhir_data, self.report_unexpected_exception)
self.conversion_layout = ConversionLayout(self.extractor)
except Exception as e:
if report_unexpected_exception:
self._log_error(None, None, f"Initialization failed: [{e.__class__.__name__}] {e}")
raise
def run_conversion(self):
conversions = self.conversion_layout.get_conversion_layout()
for conversion in conversions:
self._convert_data(conversion)
self.error_records.extend(self.extractor.get_error_records())
# Add CONVERSION_ERRORS as the 35th field
self.converted["CONVERSION_ERRORS"] = self.error_records
return self.converted
def _convert_data(self, conversion: ConversionField):
flat_field = conversion.field_name_flat
try:
if flat_field == "ACTION_FLAG":
self.converted[flat_field] = self.action_flag
else:
converted = conversion.expression_rule()
if converted is not None:
self.converted[flat_field] = converted
except Exception as e:
self._log_error(
flat_field,
None,
f"Conversion error [{e.__class__.__name__}]: {e}",
code=exception_messages.PARSING_ERROR
)
self.converted[flat_field] = ""
def _log_error(self, field_name, field_value, e, code=exception_messages.UNEXPECTED_EXCEPTION):
error_obj = {
"code": code,
"field": field_name,
"value": field_value,
"message": str(e)
}
if self.report_unexpected_exception:
self.error_records.append(error_obj)
def get_error_records(self):
return self.error_records