dcicutils 8.8.6.1b6__py3-none-any.whl → 8.8.6.1b8__py3-none-any.whl

Sign up to get free protection for your applications and to get access to all the features.
@@ -145,15 +145,12 @@ class PortalObject:
145
145
  return diffs
146
146
 
147
147
  @lru_cache(maxsize=1)
148
- def _get_identifying_paths(self, all: bool = True,
149
- ref_lookup_strategy: Optional[Callable] = None) -> Optional[List[str]]:
148
+ def _get_identifying_paths(self, ref_lookup_strategy: Optional[Callable] = None) -> Optional[List[str]]:
150
149
  if not self._portal and (uuid := self.uuid):
151
- if all is True and (type := self.type):
152
- return [f"/{type}/{uuid}", f"/{uuid}"]
153
150
  return [f"/{uuid}"]
154
151
  # Migrating to and unifying this in portal_utils.Portal.get_identifying_paths (2024-05-26).
155
152
  return self._portal.get_identifying_paths(self._data,
156
- portal_type=self.schema, all=all,
153
+ portal_type=self.schema,
157
154
  lookup_strategy=ref_lookup_strategy) if self._portal else None
158
155
 
159
156
  def _normalized_refs(self, refs: List[dict]) -> Tuple[PortalObject, int]:
dcicutils/portal_utils.py CHANGED
@@ -407,7 +407,7 @@ class Portal:
407
407
 
408
408
  @function_cache(maxsize=100, serialize_key=True)
409
409
  def get_identifying_paths(self, portal_object: dict, portal_type: Optional[Union[str, dict]] = None,
410
- all: bool = True, lookup_strategy: Optional[Union[Callable, bool]] = None) -> List[str]:
410
+ lookup_strategy: Optional[Union[Callable, bool]] = None) -> List[str]:
411
411
  """
412
412
  Returns the list of the identifying Portal (URL) paths for the given Portal object. Favors any uuid
413
413
  and identifier based paths and defavors aliases based paths (ala self.get_identifying_property_names);
@@ -467,20 +467,16 @@ class Portal:
467
467
  # And note the disction of just using /{uuid} here rather than /{type}/{uuid} as in the else
468
468
  # statement below is not really necessary; just here for emphasis that this is all that's needed.
469
469
  #
470
- if all is True:
471
- results.append(f"/{portal_type}/{identifying_value}")
472
470
  results.append(f"/{identifying_value}")
473
471
  elif isinstance(identifying_value, list):
474
472
  for identifying_value_item in identifying_value:
475
473
  if identifying_value_item:
476
474
  results.append(f"/{portal_type}/{identifying_value_item}")
477
- if all is True:
478
- results.append(f"/{identifying_value_item}")
479
475
  else:
480
476
  lookup_options = Portal.LOOKUP_UNDEFINED
481
477
  if schema := self.get_schema(portal_type):
482
478
  if callable(lookup_strategy):
483
- lookup_options, validator = lookup_strategy(self, self.type, schema, identifying_value)
479
+ lookup_options, validator = lookup_strategy(self, portal_type, schema, identifying_value)
484
480
  if callable(validator):
485
481
  if validator(schema, identifying_property, identifying_value) is False:
486
482
  continue
@@ -494,12 +490,12 @@ class Portal:
494
490
  lookup_options = Portal.LOOKUP_DEFAULT
495
491
  if is_lookup_root_first(lookup_options):
496
492
  results.append(f"/{identifying_value}")
497
- if is_lookup_specified_type(lookup_options) and self.type:
498
- results.append(f"/{self.type}/{identifying_value}")
493
+ if is_lookup_specified_type(lookup_options) and portal_type:
494
+ results.append(f"/{portal_type}/{identifying_value}")
499
495
  if is_lookup_root(lookup_options) and not is_lookup_root_first(lookup_options):
500
496
  results.append(f"/{identifying_value}")
501
497
  if is_lookup_subtypes(lookup_options):
502
- for subtype_name in self.get_schema_subtype_names(self.type):
498
+ for subtype_name in self.get_schema_subtype_names(portal_type):
503
499
  results.append(f"/{subtype_name}/{identifying_value}")
504
500
  return results
505
501
 
@@ -542,7 +538,7 @@ class Portal:
542
538
  @staticmethod
543
539
  def _lookup_strategy(portal: Portal, type_name: str, schema: dict, value: str) -> (int, Optional[str]):
544
540
  #
545
- # Note this slight odd situation WRT object lookups by submitted_id and accession:
541
+ # Note this slightly odd situation WRT object lookups by submitted_id and accession:
546
542
  # -----------------------------+-----------------------------------------------+---------------+
547
543
  # PATH | EXAMPLE | LOOKUP RESULT |
548
544
  # -----------------------------+-----------------------------------------------+---------------+
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: dcicutils
3
- Version: 8.8.6.1b6
3
+ Version: 8.8.6.1b8
4
4
  Summary: Utility package for interacting with the 4DN Data Portal and other 4DN resources
5
5
  Home-page: https://github.com/4dn-dcic/utils
6
6
  License: MIT
@@ -47,8 +47,8 @@ dcicutils/log_utils.py,sha256=7pWMc6vyrorUZQf-V-M3YC6zrPgNhuV_fzm9xqTPph0,10883
47
47
  dcicutils/misc_utils.py,sha256=zHwsxxEn24muLBP7mDvMa8I9VdMejwW8HMuCL5xbhhw,107690
48
48
  dcicutils/obfuscation_utils.py,sha256=fo2jOmDRC6xWpYX49u80bVNisqRRoPskFNX3ymFAmjw,5963
49
49
  dcicutils/opensearch_utils.py,sha256=V2exmFYW8Xl2_pGFixF4I2Cc549Opwe4PhFi5twC0M8,1017
50
- dcicutils/portal_object_utils.py,sha256=ryNoSFKEdaj4Y5MPryVanK2Hg32-Kg6r0BwvOPf2Ov0,11227
51
- dcicutils/portal_utils.py,sha256=J1Ir-DeBu8JzueLZ3NjnP3lQeUzQMlbx99hoiKaWsVY,44054
50
+ dcicutils/portal_object_utils.py,sha256=Az3n1aL-PQkN5gOFE6ZqC2XkYsqiwKlq7-tZggs1QN4,11062
51
+ dcicutils/portal_utils.py,sha256=lsS_Pvjr0ecUpyHu3R_QcnjrwUHApr2qo8Wmp9COwks,43827
52
52
  dcicutils/progress_bar.py,sha256=UT7lxb-rVF_gp4yjY2Tg4eun1naaH__hB4_v3O85bcE,19468
53
53
  dcicutils/project_utils.py,sha256=qPdCaFmWUVBJw4rw342iUytwdQC0P-XKpK4mhyIulMM,31250
54
54
  dcicutils/qa_checkers.py,sha256=cdXjeL0jCDFDLT8VR8Px78aS10hwNISOO5G_Zv2TZ6M,20534
@@ -73,8 +73,8 @@ dcicutils/trace_utils.py,sha256=g8kwV4ebEy5kXW6oOrEAUsurBcCROvwtZqz9fczsGRE,1769
73
73
  dcicutils/validation_utils.py,sha256=cMZIU2cY98FYtzK52z5WUYck7urH6JcqOuz9jkXpqzg,14797
74
74
  dcicutils/variant_utils.py,sha256=2H9azNx3xAj-MySg-uZ2SFqbWs4kZvf61JnK6b-h4Qw,4343
75
75
  dcicutils/zip_utils.py,sha256=_Y9EmL3D2dUZhxucxHvrtmmlbZmK4FpSsHEb7rGSJLU,3265
76
- dcicutils-8.8.6.1b6.dist-info/LICENSE.txt,sha256=qnwSmfnEWMl5l78VPDEzAmEbLVrRqQvfUQiHT0ehrOo,1102
77
- dcicutils-8.8.6.1b6.dist-info/METADATA,sha256=g3y6skHiac16VTTk89IWTnrZYIyp55vpG0l0xT7Z6tw,3439
78
- dcicutils-8.8.6.1b6.dist-info/WHEEL,sha256=7Z8_27uaHI_UZAc4Uox4PpBhQ9Y5_modZXWMxtUi4NU,88
79
- dcicutils-8.8.6.1b6.dist-info/entry_points.txt,sha256=51Q4F_2V10L0282W7HFjP4jdzW4K8lnWDARJQVFy_hw,270
80
- dcicutils-8.8.6.1b6.dist-info/RECORD,,
76
+ dcicutils-8.8.6.1b8.dist-info/LICENSE.txt,sha256=qnwSmfnEWMl5l78VPDEzAmEbLVrRqQvfUQiHT0ehrOo,1102
77
+ dcicutils-8.8.6.1b8.dist-info/METADATA,sha256=f5e7Y4rOGWnLReByHQbOEKbpTPLMLTjzs9pzhHUM_jA,3439
78
+ dcicutils-8.8.6.1b8.dist-info/WHEEL,sha256=7Z8_27uaHI_UZAc4Uox4PpBhQ9Y5_modZXWMxtUi4NU,88
79
+ dcicutils-8.8.6.1b8.dist-info/entry_points.txt,sha256=51Q4F_2V10L0282W7HFjP4jdzW4K8lnWDARJQVFy_hw,270
80
+ dcicutils-8.8.6.1b8.dist-info/RECORD,,