dcicutils 8.14.0.1b21__tar.gz → 8.14.0.1b23__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/PKG-INFO +1 -1
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/scripts/update_portal_object.py +12 -6
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/scripts/view_portal_object.py +34 -6
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/pyproject.toml +1 -1
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/LICENSE.txt +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/README.rst +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/__init__.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/base.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/beanstalk_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/bundle_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/captured_output.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/cloudformation_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/codebuild_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/command_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/common.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/contribution_scripts.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/contribution_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/creds_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/data_readers.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/data_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/datetime_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/deployment_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/diff_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/docker_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/ecr_scripts.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/ecr_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/ecs_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/env_base.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/env_manager.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/env_scripts.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/env_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/env_utils_legacy.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/es_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/exceptions.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/ff_mocks.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/ff_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/file_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/function_cache_decorator.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/glacier_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/hack_for_elasticsearch_numpy_usage.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/http_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/jh_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/kibana/dashboards.json +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/kibana/readme.md +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/lang_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/c4-infrastructure.jsonc +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/c4-python-infrastructure.jsonc +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/park-lab-common-server.jsonc +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/park-lab-common.jsonc +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/park-lab-gpl-pipeline.jsonc +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/park-lab-pipeline.jsonc +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/log_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/misc_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/obfuscation_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/opensearch_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/portal_object_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/portal_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/progress_bar.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/project_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/qa_checkers.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/qa_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/redis_tools.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/redis_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/s3_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/schema_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/scripts/publish_to_pypi.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/scripts/run_license_checker.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/secrets_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/sheet_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/snapshot_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/ssl_certificate_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/structured_data.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/submitr/progress_constants.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/submitr/ref_lookup_strategy.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/task_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/tmpfile_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/trace_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/validation_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/variant_utils.py +0 -0
- {dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/zip_utils.py +0 -0
@@ -2,9 +2,16 @@
|
|
2
2
|
# Command-line utility to update (post, patch, upsert) portal objects for SMaHT/CGAP/Fourfront.
|
3
3
|
# ------------------------------------------------------------------------------------------------------
|
4
4
|
# Example commands:
|
5
|
-
#
|
6
|
-
# update-portal-object --
|
7
|
-
# update-portal-object --
|
5
|
+
#
|
6
|
+
# update-portal-object --load {json-file | directory-with-json-files}
|
7
|
+
# update-portal-object --post {json-file | directory-with-json-files}
|
8
|
+
# update-portal-object --upsert {json-file | directory-with-json-files}
|
9
|
+
# update-portal-object --patch {json-file | directory-with-json-files}
|
10
|
+
#
|
11
|
+
# The specified json-file or file withing directory-with-jaon-files must be JSON containing either
|
12
|
+
# a list of objects, which which case the file name for the target schema name, or if not, then
|
13
|
+
# the --schema option must be used to specified the target schema; or the JSON must be a dictionary
|
14
|
+
# of schema names, where the value of each is a list of objects for that schema.
|
8
15
|
# --------------------------------------------------------------------------------------------------
|
9
16
|
|
10
17
|
import argparse
|
@@ -464,8 +471,7 @@ def _load_data(portal: Portal, load: str, ini_file: str, explicit_schema_name: O
|
|
464
471
|
# view_name: \\\'22813a02-906b-4b60-b2b2-4afaea24aa28\\\', subpath: (), traversed: (), root:
|
465
472
|
# <encoded.root.SMAHTRoot object at 0x136d41460>, vroot: <encoded.root.SMAHTRoot object at 0x136d41460>, vroot_path: ()"}\' # noqa
|
466
473
|
#
|
467
|
-
if (
|
468
|
-
(len(item_type.groups()) == 1)): # noqa
|
474
|
+
if (item_type := re.search(r"https?://.*/(.*)\?skip_indexing=.*", item)) and (len(item_type.groups()) == 1): # noqa
|
469
475
|
item_type = to_snake_case(item_type.group(1))
|
470
476
|
identifying_value = f"/{to_camel_case(item_type)}{identifying_value}"
|
471
477
|
unresolved_link_error_message_prefix = "Unable to resolve link:"
|
@@ -628,7 +634,7 @@ def _load_data(portal: Portal, load: str, ini_file: str, explicit_schema_name: O
|
|
628
634
|
_print(f"Total items loaded: {loadxl_total_item_count // 2}" # TODO: straightend out this arithmetic
|
629
635
|
f"{f' (errors: {loadxl_total_error_count})' if loadxl_total_error_count else ''}")
|
630
636
|
for item in sorted(loadxl_summary.keys()):
|
631
|
-
_print(f"▷ {to_camel_case(item)}: {loadxl_summary[item]}")
|
637
|
+
_print(f"▷ {to_camel_case(item)}: {loadxl_summary[item] // 2}") # TODO: straightend out this arithmetic
|
632
638
|
if loadxl_unresolved:
|
633
639
|
_print("✗ Unresolved references:")
|
634
640
|
for item in loadxl_unresolved:
|
@@ -290,6 +290,23 @@ def _get_portal_object(portal: Portal, uuid: str,
|
|
290
290
|
_print()
|
291
291
|
return None
|
292
292
|
|
293
|
+
def get_metadata_types(path: str) -> Optional[dict]:
|
294
|
+
nonlocal portal, debug
|
295
|
+
metadata_types = {}
|
296
|
+
try:
|
297
|
+
if verbose:
|
298
|
+
_print(f"Executing separted query to get actual metadata types for raw/inserts query.")
|
299
|
+
if ((response := portal.get(path)) and (response.status_code in [200, 307]) and
|
300
|
+
(response := response.json()) and (results := response.get("@graph"))): # noqa
|
301
|
+
for result in results:
|
302
|
+
if (result_type := result.get("@type")) and (result_uuid := result.get("uuid")):
|
303
|
+
if ((isinstance(result_type, list) and (result_type := result_type[0])) or
|
304
|
+
isinstance(result_type, str)): # noqa
|
305
|
+
metadata_types[result_uuid] = result_type
|
306
|
+
except Exception:
|
307
|
+
return None
|
308
|
+
return metadata_types
|
309
|
+
|
293
310
|
response = None
|
294
311
|
try:
|
295
312
|
if not uuid.startswith("/"):
|
@@ -312,6 +329,7 @@ def _get_portal_object(portal: Portal, uuid: str,
|
|
312
329
|
if not response.json:
|
313
330
|
_exit(f"Invalid JSON getting Portal object: {uuid}")
|
314
331
|
response = response.json()
|
332
|
+
response_types = {}
|
315
333
|
if inserts:
|
316
334
|
# Format results as suitable for inserts (e.g. via update-portal-object).
|
317
335
|
response.pop("schema_version", None)
|
@@ -319,10 +337,12 @@ def _get_portal_object(portal: Portal, uuid: str,
|
|
319
337
|
(isinstance(results_type := response.get("@type"), list) and results_type) and
|
320
338
|
(isinstance(results_type := results_type[0], str) and results_type.endswith("SearchResults")) and
|
321
339
|
(results_type := results_type[0:-len("SearchResults")])): # noqa
|
322
|
-
# For search results, the type (from XyzSearchResults, above) may not be precisely correct
|
323
|
-
# each of the results; it may be the supertype (e.g. QualityMetric vs QualityMetricWorkflowRun);
|
340
|
+
# For (raw frame) search results, the type (from XyzSearchResults, above) may not be precisely correct
|
341
|
+
# for each of the results; it may be the supertype (e.g. QualityMetric vs QualityMetricWorkflowRun);
|
324
342
|
# so for types which are supertypes (gotten via Portal.get_schemas_super_type_map) we actually
|
325
|
-
# lookup each result individually to determine its actual precise type.
|
343
|
+
# lookup each result individually to determine its actual precise type. Although, if we have
|
344
|
+
# more than (say) 5 results to do this for, then do a separate query (get_metadata_types)
|
345
|
+
# to get the result types all at once.
|
326
346
|
if not ((supertypes := portal.get_schemas_super_type_map()) and (subtypes := supertypes.get(results_type))):
|
327
347
|
subtypes = None
|
328
348
|
response = {}
|
@@ -335,9 +355,17 @@ def _get_portal_object(portal: Portal, uuid: str,
|
|
335
355
|
result.pop("schema_version", None)
|
336
356
|
result = prune_data(result)
|
337
357
|
if (subtypes and one_or_more_objects_of_types_exists(portal, subtypes, debug=debug) and
|
338
|
-
(result_uuid := result.get("uuid"))
|
339
|
-
|
340
|
-
|
358
|
+
(result_uuid := result.get("uuid"))): # noqa
|
359
|
+
import pdb ; pdb.set_trace() # noqa
|
360
|
+
# If we have more than (say) 5 results for which we need to determine that actual result type,
|
361
|
+
# then get them all at once via separate query (get_metadata_types)) which is not the raw frame.
|
362
|
+
if (results_total > 5) and (not response_types):
|
363
|
+
response_types = get_metadata_types(path)
|
364
|
+
if not (response_types and (result_type := response_types.get(result_uuid))):
|
365
|
+
if individual_result_type := get_metadata_for_individual_result_type(result_uuid):
|
366
|
+
result_type = individual_result_type
|
367
|
+
else:
|
368
|
+
result_type = results_type
|
341
369
|
else:
|
342
370
|
result_type = results_type
|
343
371
|
if response.get(result_type):
|
@@ -1,6 +1,6 @@
|
|
1
1
|
[tool.poetry]
|
2
2
|
name = "dcicutils"
|
3
|
-
version = "8.14.0.
|
3
|
+
version = "8.14.0.1b23" # TODO: To become 8.14.1
|
4
4
|
description = "Utility package for interacting with the 4DN Data Portal and other 4DN resources"
|
5
5
|
authors = ["4DN-DCIC Team <support@4dnucleome.org>"]
|
6
6
|
license = "MIT"
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/hack_for_elasticsearch_numpy_usage.py
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
{dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/c4-infrastructure.jsonc
RENAMED
File without changes
|
File without changes
|
File without changes
|
{dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/park-lab-common.jsonc
RENAMED
File without changes
|
File without changes
|
{dcicutils-8.14.0.1b21 → dcicutils-8.14.0.1b23}/dcicutils/license_policies/park-lab-pipeline.jsonc
RENAMED
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|