dcicutils 8.16.2.1b2__tar.gz → 8.16.2.1b4__tar.gz
Sign up to get free protection for your applications and to get access to all the features.
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/PKG-INFO +1 -1
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/portal_utils.py +24 -2
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/pyproject.toml +1 -1
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/LICENSE.txt +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/README.rst +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/__init__.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/base.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/beanstalk_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/bundle_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/captured_output.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/cloudformation_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/codebuild_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/command_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/common.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/contribution_scripts.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/contribution_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/creds_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/data_readers.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/data_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/datetime_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/deployment_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/diff_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/docker_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/ecr_scripts.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/ecr_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/ecs_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/env_base.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/env_manager.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/env_scripts.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/env_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/env_utils_legacy.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/es_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/exceptions.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/ff_mocks.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/ff_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/file_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/function_cache_decorator.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/glacier_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/hack_for_elasticsearch_numpy_usage.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/http_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/jh_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/kibana/dashboards.json +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/kibana/readme.md +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/lang_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/c4-infrastructure.jsonc +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/c4-python-infrastructure.jsonc +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/park-lab-common-server.jsonc +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/park-lab-common.jsonc +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/park-lab-gpl-pipeline.jsonc +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/park-lab-pipeline.jsonc +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/log_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/misc_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/obfuscation_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/opensearch_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/portal_object_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/progress_bar.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/project_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/qa_checkers.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/qa_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/redis_tools.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/redis_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/s3_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/schema_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/scripts/publish_to_pypi.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/scripts/run_license_checker.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/scripts/update_portal_object.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/scripts/view_portal_object.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/secrets_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/sheet_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/snapshot_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/ssl_certificate_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/structured_data.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/submitr/progress_constants.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/submitr/ref_lookup_strategy.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/task_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/tmpfile_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/trace_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/validation_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/variant_utils.py +0 -0
- {dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/zip_utils.py +0 -0
@@ -13,6 +13,7 @@ import requests
|
|
13
13
|
from requests.models import Response
|
14
14
|
from threading import Thread
|
15
15
|
from typing import Callable, Dict, List, Optional, Tuple, Type, Union
|
16
|
+
# from urllib.parse import parse_qs as parse_url_query_string
|
16
17
|
from uuid import uuid4 as uuid
|
17
18
|
from webtest.app import TestApp, TestResponse
|
18
19
|
from wsgiref.simple_server import make_server as wsgi_make_server
|
@@ -210,7 +211,8 @@ class Portal:
|
|
210
211
|
|
211
212
|
def get(self, url: str, follow: bool = True,
|
212
213
|
raw: bool = False, database: bool = False,
|
213
|
-
limit: Optional[int] = None, offset: Optional[int] = None,
|
214
|
+
limit: Optional[int] = None, offset: Optional[int] = None,
|
215
|
+
field: Optional[str] = None, deleted: bool = False,
|
214
216
|
raise_for_status: bool = False, **kwargs) -> OptionalResponse:
|
215
217
|
url = self.url(url, raw, database)
|
216
218
|
if isinstance(limit, int) and (limit >= 0):
|
@@ -228,6 +230,11 @@ class Portal:
|
|
228
230
|
url += f"&field={field}"
|
229
231
|
else:
|
230
232
|
url += f"?field={field}"
|
233
|
+
if deleted is True:
|
234
|
+
if "?" in url:
|
235
|
+
url += "&status=deleted"
|
236
|
+
else:
|
237
|
+
url += "?status=deleted"
|
231
238
|
if not self.vapp:
|
232
239
|
response = requests.get(url, allow_redirects=follow, **self._kwargs(**kwargs))
|
233
240
|
else:
|
@@ -270,8 +277,11 @@ class Portal:
|
|
270
277
|
return response
|
271
278
|
|
272
279
|
def get_metadata(self, object_id: str, raw: bool = False, database: bool = False,
|
273
|
-
limit: Optional[int] = None, offset: Optional[int] = None,
|
280
|
+
limit: Optional[int] = None, offset: Optional[int] = None,
|
281
|
+
field: Optional[str] = None, deleted: bool = False,
|
274
282
|
raise_exception: bool = True) -> Optional[dict]:
|
283
|
+
if not isinstance(object_id, str):
|
284
|
+
return None
|
275
285
|
if isinstance(raw, bool) and raw:
|
276
286
|
add_on = "frame=raw" + ("&datastore=database" if isinstance(database, bool) and database else "")
|
277
287
|
elif database:
|
@@ -293,6 +303,18 @@ class Portal:
|
|
293
303
|
add_on += f"&field={field}"
|
294
304
|
else:
|
295
305
|
add_on += f"field={field}"
|
306
|
+
if deleted is True:
|
307
|
+
if add_on:
|
308
|
+
add_on += "&status=deleted"
|
309
|
+
else:
|
310
|
+
add_on += "status=deleted"
|
311
|
+
if (question_mark := object_id.find("?")) > 0:
|
312
|
+
query_string = object_id[question_mark + 1:]
|
313
|
+
object_id = object_id[:question_mark]
|
314
|
+
if add_on:
|
315
|
+
add_on += f"&{query_string}"
|
316
|
+
else:
|
317
|
+
add_on += query_string
|
296
318
|
if raise_exception:
|
297
319
|
return get_metadata(obj_id=object_id, vapp=self.vapp, key=self.key, add_on=add_on)
|
298
320
|
else:
|
@@ -1,6 +1,6 @@
|
|
1
1
|
[tool.poetry]
|
2
2
|
name = "dcicutils"
|
3
|
-
version = "8.16.2.
|
3
|
+
version = "8.16.2.1b4" # TOOD: To become 8.16.3
|
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.16.2.1b2 → dcicutils-8.16.2.1b4}/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.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/c4-infrastructure.jsonc
RENAMED
File without changes
|
File without changes
|
File without changes
|
{dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/park-lab-common.jsonc
RENAMED
File without changes
|
{dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/dcicutils/license_policies/park-lab-gpl-pipeline.jsonc
RENAMED
File without changes
|
{dcicutils-8.16.2.1b2 → dcicutils-8.16.2.1b4}/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
|
File without changes
|