|
5 | 5 | from collections.abc import Iterable |
6 | 6 | import time |
7 | 7 | import ndjson |
8 | | -from itertools import islice |
| 8 | +from itertools import islice, chain |
9 | 9 |
|
10 | 10 | from concurrent.futures import ThreadPoolExecutor, as_completed |
11 | 11 | from io import StringIO |
@@ -256,6 +256,18 @@ def validate_attachments(item): |
256 | 256 | ) |
257 | 257 | return attachments |
258 | 258 |
|
| 259 | + def parse_metadata_fields(item): |
| 260 | + metadata_fields = item.get('metadata_fields') |
| 261 | + if metadata_fields: |
| 262 | + mdo = self.client.get_data_row_metadata_ontology() |
| 263 | + metadata = list( |
| 264 | + chain.from_iterable( |
| 265 | + mdo.parse_upsert(m) for m in metadata_fields)) |
| 266 | + metadata_fields = [ |
| 267 | + md.dict(by_alias=True) for md in metadata |
| 268 | + ] |
| 269 | + item['metadata_fields'] = metadata_fields |
| 270 | + |
259 | 271 | def format_row(item): |
260 | 272 | # Formats user input into a consistent dict structure |
261 | 273 | if isinstance(item, dict): |
@@ -289,13 +301,16 @@ def convert_item(item): |
289 | 301 | # Don't make any changes to tms data |
290 | 302 | if "tileLayerUrl" in item: |
291 | 303 | validate_attachments(item) |
292 | | - return item |
| 304 | + return item |
293 | 305 | # Convert all payload variations into the same dict format |
294 | 306 | item = format_row(item) |
295 | 307 | # Make sure required keys exist (and there are no extra keys) |
296 | 308 | validate_keys(item) |
297 | 309 | # Make sure attachments are valid |
298 | 310 | validate_attachments(item) |
| 311 | + print(f"!! Before parsing metadata field: {item}") |
| 312 | + parse_metadata_fields(item) |
| 313 | + print(f"!! After parsing metadata field: {item}") |
299 | 314 | # Upload any local file paths |
300 | 315 | item = upload_if_necessary(item) |
301 | 316 |
|
|
0 commit comments