dcicutils 8.5.0.1b3__py3-none-any.whl → 8.5.0.1b4__py3-none-any.whl
Sign up to get free protection for your applications and to get access to all the features.
- dcicutils/portal_utils.py +6 -7
- dcicutils/structured_data.py +12 -4
- {dcicutils-8.5.0.1b3.dist-info → dcicutils-8.5.0.1b4.dist-info}/METADATA +1 -1
- {dcicutils-8.5.0.1b3.dist-info → dcicutils-8.5.0.1b4.dist-info}/RECORD +7 -7
- {dcicutils-8.5.0.1b3.dist-info → dcicutils-8.5.0.1b4.dist-info}/LICENSE.txt +0 -0
- {dcicutils-8.5.0.1b3.dist-info → dcicutils-8.5.0.1b4.dist-info}/WHEEL +0 -0
- {dcicutils-8.5.0.1b3.dist-info → dcicutils-8.5.0.1b4.dist-info}/entry_points.txt +0 -0
dcicutils/portal_utils.py
CHANGED
@@ -23,15 +23,14 @@ class Portal:
|
|
23
23
|
2. From a key dictionary, containing "key" and "secret" property values.
|
24
24
|
3. From a key tuple, containing (in order) a key and secret values.
|
25
25
|
4. From a keys file assumed to reside in ~/.{app}-keys.json where the given "app" value is either "smaht", "cgap",
|
26
|
-
or "fourfront";
|
27
|
-
|
28
|
-
an "app" value is not specified but the given "env" value begins with one of the app values then that value
|
29
|
-
will be used, i.e. e.g. if env is "smaht-
|
26
|
+
or "fourfront"; where is assumed to contain a dictionary with a key for the given "env" value, e.g. smaht-local;
|
27
|
+
and with a dictionary value containing "key" and "secret" property values, and an optional "server" property;
|
28
|
+
if an "app" value is not specified but the given "env" value begins with one of the app values then that value
|
29
|
+
will be used, i.e. e.g. if "env" is "smaht-local" and app is unspecified than it is assumed to be "smaht".
|
30
30
|
5. From a keys file as described above (#4) but rather than be identified by the given "env" value it
|
31
|
-
is looked up
|
31
|
+
is looked up via the given "server" name and the "server" key dictionary value in the key file.
|
32
32
|
6. From a given "vapp" value (which is assumed to be a TestApp or VirtualApp).
|
33
|
-
7. From another Portal object.
|
34
|
-
8. From a a pyramid Router object.
|
33
|
+
7. From another Portal object; or from a a pyramid Router object.
|
35
34
|
"""
|
36
35
|
def __init__(self,
|
37
36
|
arg: Optional[Union[VirtualApp, TestApp, Router, Portal, dict, tuple, str]] = None,
|
dcicutils/structured_data.py
CHANGED
@@ -42,8 +42,8 @@ StructuredDataSet = Type["StructuredDataSet"]
|
|
42
42
|
class StructuredDataSet:
|
43
43
|
|
44
44
|
def __init__(self, file: Optional[str] = None, portal: Optional[Union[VirtualApp, TestApp, Portal]] = None,
|
45
|
-
schemas: Optional[List[dict]] = None,
|
46
|
-
order: Optional[List[str]] = None, prune: bool = True) -> None:
|
45
|
+
schemas: Optional[List[dict]] = None, autoadd: Optional[dict] = None,
|
46
|
+
data: Optional[List[dict]] = None, order: Optional[List[str]] = None, prune: bool = True) -> None:
|
47
47
|
self.data = {} if not data else data # If portal is None then no schemas nor refs.
|
48
48
|
self._portal = Portal(portal, data=self.data, schemas=schemas) if portal else None
|
49
49
|
self._order = order
|
@@ -52,13 +52,14 @@ class StructuredDataSet:
|
|
52
52
|
self._errors = {}
|
53
53
|
self._resolved_refs = set()
|
54
54
|
self._validated = False
|
55
|
+
self._autoadd_properties = autoadd if isinstance(autoadd, dict) and autoadd else None
|
55
56
|
self._load_file(file) if file else None
|
56
57
|
|
57
58
|
@staticmethod
|
58
59
|
def load(file: str, portal: Optional[Union[VirtualApp, TestApp, Portal]] = None,
|
59
|
-
schemas: Optional[List[dict]] = None,
|
60
|
+
schemas: Optional[List[dict]] = None, autoadd: Optional[dict] = None,
|
60
61
|
order: Optional[List[str]] = None, prune: bool = True) -> StructuredDataSet:
|
61
|
-
return StructuredDataSet(file=file, portal=portal, schemas=schemas, order=order, prune=prune)
|
62
|
+
return StructuredDataSet(file=file, portal=portal, schemas=schemas, autoadd=autoadd, order=order, prune=prune)
|
62
63
|
|
63
64
|
def validate(self, force: bool = False) -> None:
|
64
65
|
if self._validated and not force:
|
@@ -163,6 +164,8 @@ class StructuredDataSet:
|
|
163
164
|
structured_row = structured_row_template.create_row()
|
164
165
|
for column_name, value in row.items():
|
165
166
|
structured_row_template.set_value(structured_row, column_name, value, reader.file, reader.row_number)
|
167
|
+
if self._autoadd_properties:
|
168
|
+
self._add_properties(structured_row, self._autoadd_properties, schema)
|
166
169
|
self._add(type_name, structured_row)
|
167
170
|
self._note_warning(reader.warnings, "reader")
|
168
171
|
if schema:
|
@@ -177,6 +180,11 @@ class StructuredDataSet:
|
|
177
180
|
else:
|
178
181
|
self.data[type_name] = [data] if isinstance(data, dict) else data
|
179
182
|
|
183
|
+
def _add_properties(self, structured_row: dict, properties: dict, schema: Optional[dict] = None) -> None:
|
184
|
+
for name in properties:
|
185
|
+
if name not in structured_row and (not schema or schema.data.get("properties", {}).get(name)):
|
186
|
+
structured_row[name] = properties[name]
|
187
|
+
|
180
188
|
def _note_warning(self, item: Optional[Union[dict, List[dict]]], group: str) -> None:
|
181
189
|
self._note_issue(self._warnings, item, group)
|
182
190
|
|
@@ -43,7 +43,7 @@ dcicutils/log_utils.py,sha256=7pWMc6vyrorUZQf-V-M3YC6zrPgNhuV_fzm9xqTPph0,10883
|
|
43
43
|
dcicutils/misc_utils.py,sha256=nRjLEORY35YmJwTjO0fnauBPznaI_bkVasIW8PccDYM,100179
|
44
44
|
dcicutils/obfuscation_utils.py,sha256=fo2jOmDRC6xWpYX49u80bVNisqRRoPskFNX3ymFAmjw,5963
|
45
45
|
dcicutils/opensearch_utils.py,sha256=V2exmFYW8Xl2_pGFixF4I2Cc549Opwe4PhFi5twC0M8,1017
|
46
|
-
dcicutils/portal_utils.py,sha256=
|
46
|
+
dcicutils/portal_utils.py,sha256=Wh918ZKpUJFbt7w6Bn5G7v-0k6ImOUWMFmE9Oxt1ZN4,14560
|
47
47
|
dcicutils/project_utils.py,sha256=qPdCaFmWUVBJw4rw342iUytwdQC0P-XKpK4mhyIulMM,31250
|
48
48
|
dcicutils/qa_checkers.py,sha256=cdXjeL0jCDFDLT8VR8Px78aS10hwNISOO5G_Zv2TZ6M,20534
|
49
49
|
dcicutils/qa_utils.py,sha256=TT0SiJWiuxYvbsIyhK9VO4uV_suxhB6CpuC4qPacCzQ,160208
|
@@ -56,14 +56,14 @@ dcicutils/secrets_utils.py,sha256=8dppXAsiHhJzI6NmOcvJV5ldvKkQZzh3Fl-cb8Wm7MI,19
|
|
56
56
|
dcicutils/sheet_utils.py,sha256=VlmzteONW5VF_Q4vo0yA5vesz1ViUah1MZ_yA1rwZ0M,33629
|
57
57
|
dcicutils/snapshot_utils.py,sha256=ymP7PXH6-yEiXAt75w0ldQFciGNqWBClNxC5gfX2FnY,22961
|
58
58
|
dcicutils/ssl_certificate_utils.py,sha256=F0ifz_wnRRN9dfrfsz7aCp4UDLgHEY8LaK7PjnNvrAQ,9707
|
59
|
-
dcicutils/structured_data.py,sha256=
|
59
|
+
dcicutils/structured_data.py,sha256=tMKBhq6OuM2t6iDxIPBFcxV66MiwmOHTBeACxhvkbiQ,33307
|
60
60
|
dcicutils/task_utils.py,sha256=MF8ujmTD6-O2AC2gRGPHyGdUrVKgtr8epT5XU8WtNjk,8082
|
61
61
|
dcicutils/trace_utils.py,sha256=g8kwV4ebEy5kXW6oOrEAUsurBcCROvwtZqz9fczsGRE,1769
|
62
62
|
dcicutils/validation_utils.py,sha256=cMZIU2cY98FYtzK52z5WUYck7urH6JcqOuz9jkXpqzg,14797
|
63
63
|
dcicutils/variant_utils.py,sha256=2H9azNx3xAj-MySg-uZ2SFqbWs4kZvf61JnK6b-h4Qw,4343
|
64
64
|
dcicutils/zip_utils.py,sha256=0OXR0aLNwyLIZOzIFTM_5DOun7dxIv6TIZbFiithkO0,3276
|
65
|
-
dcicutils-8.5.0.
|
66
|
-
dcicutils-8.5.0.
|
67
|
-
dcicutils-8.5.0.
|
68
|
-
dcicutils-8.5.0.
|
69
|
-
dcicutils-8.5.0.
|
65
|
+
dcicutils-8.5.0.1b4.dist-info/LICENSE.txt,sha256=t0_-jIjqxNnymZoNJe-OltRIuuF8qfhN0ATlHyrUJPk,1102
|
66
|
+
dcicutils-8.5.0.1b4.dist-info/METADATA,sha256=Zpf8fTsgsuRfo8WDGkONHxtcf4SPWOFK_4iCNVAhB78,3314
|
67
|
+
dcicutils-8.5.0.1b4.dist-info/WHEEL,sha256=7Z8_27uaHI_UZAc4Uox4PpBhQ9Y5_modZXWMxtUi4NU,88
|
68
|
+
dcicutils-8.5.0.1b4.dist-info/entry_points.txt,sha256=8wbw5csMIgBXhkwfgsgJeuFcoUc0WsucUxmOyml2aoA,209
|
69
|
+
dcicutils-8.5.0.1b4.dist-info/RECORD,,
|
File without changes
|
File without changes
|
File without changes
|