dcicutils 8.5.0.1b3__py3-none-any.whl → 8.5.0.1b4__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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
         |