dcicutils 8.13.3__tar.gz → 8.13.3.1b2__tar.gz

Sign up to get free protection for your applications and to get access to all the features.
Files changed (81) hide show
  1. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/PKG-INFO +4 -4
  2. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/common.py +1 -2
  3. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/qa_checkers.py +1 -2
  4. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/qa_utils.py +1 -2
  5. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/s3_utils.py +1 -2
  6. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/scripts/view_portal_object.py +41 -29
  7. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/pyproject.toml +6 -6
  8. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/LICENSE.txt +0 -0
  9. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/README.rst +0 -0
  10. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/__init__.py +0 -0
  11. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/base.py +0 -0
  12. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/beanstalk_utils.py +0 -0
  13. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/bundle_utils.py +0 -0
  14. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/captured_output.py +0 -0
  15. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/cloudformation_utils.py +0 -0
  16. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/codebuild_utils.py +0 -0
  17. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/command_utils.py +0 -0
  18. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/contribution_scripts.py +0 -0
  19. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/contribution_utils.py +0 -0
  20. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/creds_utils.py +0 -0
  21. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/data_readers.py +0 -0
  22. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/data_utils.py +0 -0
  23. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/datetime_utils.py +0 -0
  24. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/deployment_utils.py +0 -0
  25. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/diff_utils.py +0 -0
  26. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/docker_utils.py +0 -0
  27. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/ecr_scripts.py +0 -0
  28. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/ecr_utils.py +0 -0
  29. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/ecs_utils.py +0 -0
  30. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/env_base.py +0 -0
  31. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/env_manager.py +0 -0
  32. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/env_scripts.py +0 -0
  33. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/env_utils.py +0 -0
  34. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/env_utils_legacy.py +0 -0
  35. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/es_utils.py +0 -0
  36. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/exceptions.py +0 -0
  37. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/ff_mocks.py +0 -0
  38. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/ff_utils.py +0 -0
  39. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/file_utils.py +0 -0
  40. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/function_cache_decorator.py +0 -0
  41. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/glacier_utils.py +0 -0
  42. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/hack_for_elasticsearch_numpy_usage.py +0 -0
  43. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/http_utils.py +0 -0
  44. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/jh_utils.py +0 -0
  45. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/kibana/dashboards.json +0 -0
  46. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/kibana/readme.md +0 -0
  47. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/lang_utils.py +0 -0
  48. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/license_policies/c4-infrastructure.jsonc +0 -0
  49. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/license_policies/c4-python-infrastructure.jsonc +0 -0
  50. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/license_policies/park-lab-common-server.jsonc +0 -0
  51. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/license_policies/park-lab-common.jsonc +0 -0
  52. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/license_policies/park-lab-gpl-pipeline.jsonc +0 -0
  53. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/license_policies/park-lab-pipeline.jsonc +0 -0
  54. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/license_utils.py +0 -0
  55. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/log_utils.py +0 -0
  56. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/misc_utils.py +0 -0
  57. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/obfuscation_utils.py +0 -0
  58. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/opensearch_utils.py +0 -0
  59. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/portal_object_utils.py +0 -0
  60. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/portal_utils.py +0 -0
  61. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/progress_bar.py +0 -0
  62. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/project_utils.py +0 -0
  63. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/redis_tools.py +0 -0
  64. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/redis_utils.py +0 -0
  65. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/schema_utils.py +0 -0
  66. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/scripts/publish_to_pypi.py +0 -0
  67. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/scripts/run_license_checker.py +0 -0
  68. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/scripts/update_portal_object.py +0 -0
  69. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/secrets_utils.py +0 -0
  70. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/sheet_utils.py +0 -0
  71. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/snapshot_utils.py +0 -0
  72. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/ssl_certificate_utils.py +0 -0
  73. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/structured_data.py +0 -0
  74. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/submitr/progress_constants.py +0 -0
  75. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/submitr/ref_lookup_strategy.py +0 -0
  76. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/task_utils.py +0 -0
  77. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/tmpfile_utils.py +0 -0
  78. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/trace_utils.py +0 -0
  79. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/validation_utils.py +0 -0
  80. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/variant_utils.py +0 -0
  81. {dcicutils-8.13.3 → dcicutils-8.13.3.1b2}/dcicutils/zip_utils.py +0 -0
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: dcicutils
3
- Version: 8.13.3
3
+ Version: 8.13.3.1b2
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
@@ -26,8 +26,8 @@ Requires-Dist: PyJWT (>=2.6.0,<3.0.0)
26
26
  Requires-Dist: PyYAML (>=6.0.1,<7.0.0)
27
27
  Requires-Dist: appdirs (>=1.4.4,<2.0.0)
28
28
  Requires-Dist: aws-requests-auth (>=0.4.2,<1)
29
- Requires-Dist: boto3 (>=1.34.136,<2.0.0)
30
- Requires-Dist: botocore (>=1.34.136,<2.0.0)
29
+ Requires-Dist: boto3 (>=1.34.147,<2.0.0)
30
+ Requires-Dist: botocore (>=1.34.147,<2.0.0)
31
31
  Requires-Dist: chardet (>=5.2.0,<6.0.0)
32
32
  Requires-Dist: docker (>=4.4.4,<5.0.0)
33
33
  Requires-Dist: elasticsearch (==7.13.4)
@@ -41,7 +41,7 @@ Requires-Dist: pyperclip (>=1.8.2,<2.0.0)
41
41
  Requires-Dist: pyramid (==1.10.8)
42
42
  Requires-Dist: pytz (>=2020.4)
43
43
  Requires-Dist: redis (>=4.5.1,<5.0.0)
44
- Requires-Dist: requests (>=2.21.0,<3.0.0)
44
+ Requires-Dist: requests (==2.31.0)
45
45
  Requires-Dist: rfc3986 (>=1.4.0,<2.0.0)
46
46
  Requires-Dist: shortuuid (>=1.0.13,<2.0.0)
47
47
  Requires-Dist: structlog (>=19.2.0,<20.0.0)
@@ -3,8 +3,7 @@ import os
3
3
  import re
4
4
 
5
5
  from tempfile import TemporaryFile
6
- from typing import Dict, Union, Tuple, List, Any
7
- from typing_extensions import Literal
6
+ from typing import Dict, Union, Tuple, List, Any, Literal
8
7
 
9
8
 
10
9
  # ===== Useful constants =====
@@ -6,8 +6,7 @@ import toml
6
6
  import warnings
7
7
 
8
8
  from collections import defaultdict
9
- from typing import Optional, List, Dict, Type
10
- from typing_extensions import Literal
9
+ from typing import Optional, List, Dict, Type, Literal
11
10
  from .contribution_utils import Contributions
12
11
  from .lang_utils import conjoined_list, n_of, there_are
13
12
  from .misc_utils import PRINT, remove_prefix, remove_suffix, getattr_customized, CustomizableProperty
@@ -25,8 +25,7 @@ from botocore.credentials import Credentials as Boto3Credentials
25
25
  from botocore.exceptions import ClientError
26
26
  from collections import defaultdict
27
27
  from json import dumps as json_dumps, loads as json_loads
28
- from typing import Any, Optional, List, DefaultDict, Union, Type, Dict
29
- from typing_extensions import Literal
28
+ from typing import Any, Optional, List, DefaultDict, Union, Type, Dict, Literal
30
29
  from unittest import mock
31
30
  from . import misc_utils as misc_utils_module, command_utils as command_utils_module
32
31
  from .common import S3StorageClass
@@ -5,8 +5,7 @@ import mimetypes
5
5
  import os
6
6
 
7
7
  from io import BytesIO
8
- from typing import Optional, Any, Union
9
- from typing_extensions import Literal
8
+ from typing import Optional, Any, Union, Literal
10
9
  from zipfile import ZipFile
11
10
  from .base import get_beanstalk_real_url
12
11
  from .common import (
@@ -114,16 +114,13 @@ def main():
114
114
  help="Copy object data to clipboard.")
115
115
  parser.add_argument("--output", required=False, help="Output file.", type=str)
116
116
  parser.add_argument("--indent", required=False, default=False, help="Indent output.", type=int)
117
- parser.add_argument("--details", action="store_true", required=False, default=False, help="Detailed output.")
118
- parser.add_argument("--more-details", action="store_true", required=False, default=False,
119
- help="More detailed output.")
117
+ parser.add_argument("--summary", action="store_true", required=False, default=False,
118
+ help="Summary output (for schema only).")
119
+ parser.add_argument("--terse", action="store_true", required=False, default=False, help="Terse output.")
120
120
  parser.add_argument("--verbose", action="store_true", required=False, default=False, help="Verbose output.")
121
121
  parser.add_argument("--debug", action="store_true", required=False, default=False, help="Debugging output.")
122
122
  args = parser.parse_args()
123
123
 
124
- if args.more_details:
125
- args.details = True
126
-
127
124
  portal = _create_portal(ini=args.ini, env=args.env or os.environ.get("SMAHT_ENV"),
128
125
  server=args.server, app=args.app, verbose=args.verbose, debug=args.debug)
129
126
 
@@ -143,9 +140,8 @@ def main():
143
140
  _output_file = io.open(args.output, "w")
144
141
 
145
142
  if args.uuid and ((args.uuid.lower() == "schemas") or (args.uuid.lower() == "schema")):
146
- _print_all_schema_names(portal=portal, details=args.details,
147
- more_details=args.more_details, all=args.all,
148
- tree=args.tree, raw=args.raw, raw_yaml=args.yaml)
143
+ _print_all_schema_names(portal=portal, terse=args.terse, all=args.all,
144
+ tree=args.tree, summary=args.summary, yaml=args.yaml)
149
145
  return
150
146
  elif args.uuid and (args.uuid.lower() == "info"):
151
147
  if consortia := portal.get_metadata("/consortia?limit=1000"):
@@ -182,7 +178,7 @@ def main():
182
178
  if schema:
183
179
  if args.copy:
184
180
  pyperclip.copy(json.dumps(schema, indent=4))
185
- if not args.raw:
181
+ if args.summary:
186
182
  if parent_schema_name := _get_parent_schema_name(schema):
187
183
  if schema.get("isAbstract") is True:
188
184
  _print_output(f"{schema_name} | parent: {parent_schema_name} | abstract")
@@ -190,8 +186,8 @@ def main():
190
186
  _print_output(f"{schema_name} | parent: {parent_schema_name}")
191
187
  else:
192
188
  _print_output(schema_name)
193
- _print_schema(schema, details=args.details, more_details=args.details,
194
- all=args.all, raw=args.raw, raw_yaml=args.yaml)
189
+ _print_schema(schema, terse=args.terse,
190
+ all=args.all, summary=args.summary, yaml=args.yaml)
195
191
  return
196
192
 
197
193
  data = _get_portal_object(portal=portal, uuid=args.uuid, raw=args.raw, inserts=args.inserts,
@@ -276,9 +272,26 @@ def _get_portal_object(portal: Portal, uuid: str,
276
272
  (isinstance(results_type := response.get("@type"), list) and results_type) and
277
273
  (isinstance(results_type := results_type[0], str) and results_type.endswith("SearchResults")) and
278
274
  (results_type := results_type[0:-len("SearchResults")])): # noqa
275
+ # For search results, the type (from XyzSearchResults, above) may not be precisely correct for
276
+ # each of the results; it may be the supertype (e.g. QualityMetric vs QualityMetricWorkflowRun);
277
+ # so for types which are supertypes (gotten via Portal.get_schemas_super_type_map) we actually
278
+ # lookup each result individually to determine its actual precise type.
279
+ if not ((supertypes := portal.get_schemas_super_type_map()) and (subtypes := supertypes.get(results_type))):
280
+ subtypes = None
281
+ response = {}
279
282
  for result in results:
280
283
  result.pop("schema_version", None)
281
- response = {f"{results_type}": results}
284
+ if (subtypes and
285
+ (result_uuid := result.get("uuid")) and
286
+ (individual_result := portal.get_metadata(result_uuid, raise_exception=False)) and
287
+ isinstance(result_type:= individual_result.get("@type"), list) and result_type and result_type[0]): # noqa
288
+ result_type = result_type[0]
289
+ else:
290
+ result_type = results_type
291
+ if response.get(result_type):
292
+ response[result_type].append(result)
293
+ else:
294
+ response[result_type] = [result]
282
295
  # Get the result as non-raw so we can get its type.
283
296
  elif ((response_cooked := portal.get(path, database=database)) and
284
297
  (isinstance(response_type := response_cooked.json().get("@type"), list) and response_type)):
@@ -332,19 +345,19 @@ def _get_schema_name_from_schema_named_json_file_name(portal: Portal, value: str
332
345
  return False
333
346
 
334
347
 
335
- def _print_schema(schema: dict, details: bool = False, more_details: bool = False, all: bool = False,
336
- raw: bool = False, raw_yaml: bool = False) -> None:
337
- if raw:
338
- if raw_yaml:
348
+ def _print_schema(schema: dict, terse: bool = False, all: bool = False,
349
+ summary: bool = False, yaml: bool = False) -> None:
350
+ if summary is not True:
351
+ if yaml:
339
352
  _print_output(yaml.dump(schema))
340
353
  else:
341
354
  _print_output(json.dumps(schema, indent=4))
342
355
  return
343
- _print_schema_info(schema, details=details, more_details=more_details, all=all)
356
+ _print_schema_info(schema, terse=terse, all=all)
344
357
 
345
358
 
346
359
  def _print_schema_info(schema: dict, level: int = 0,
347
- details: bool = False, more_details: bool = False, all: bool = False,
360
+ terse: bool = False, all: bool = False,
348
361
  required: Optional[List[str]] = None) -> None:
349
362
  if not schema or not isinstance(schema, dict):
350
363
  return
@@ -396,7 +409,7 @@ def _print_schema_info(schema: dict, level: int = 0,
396
409
  _print_output(f" - {reference_property['name']}: {reference_property['ref']}")
397
410
  if schema.get("additionalProperties") is True:
398
411
  _print_output(f" - additional properties are allowed")
399
- if not more_details:
412
+ if terse:
400
413
  return
401
414
  if properties := (schema.get("properties") if level == 0 else schema):
402
415
  if level == 0:
@@ -422,8 +435,7 @@ def _print_schema_info(schema: dict, level: int = 0,
422
435
  if property.get("calculatedProperty"):
423
436
  suffix += f" | calculated"
424
437
  _print_output(f"{spaces}- {property_name}: {property_type}{suffix}")
425
- _print_schema_info(object_properties, level=level + 1,
426
- details=details, more_details=more_details, all=all,
438
+ _print_schema_info(object_properties, level=level + 1, terse=terse, all=all,
427
439
  required=property.get("required"))
428
440
  elif property_type == "array":
429
441
  suffix = ""
@@ -447,7 +459,7 @@ def _print_schema_info(schema: dict, level: int = 0,
447
459
  suffix = ""
448
460
  _print_output(f"{spaces}- {property_name}: array of object{suffix}")
449
461
  _print_schema_info(property_items.get("properties"), level=level + 1,
450
- details=details, more_details=more_details, all=all,
462
+ terse=terse, all=all,
451
463
  required=property_items.get("required"))
452
464
  elif property_type == "array":
453
465
  # This (array-of-array) never happens to occur at this time (February 2024).
@@ -523,13 +535,13 @@ def _print_schema_info(schema: dict, level: int = 0,
523
535
 
524
536
 
525
537
  def _print_all_schema_names(portal: Portal,
526
- details: bool = False, more_details: bool = False, all: bool = False,
527
- tree: bool = False, raw: bool = False, raw_yaml: bool = False) -> None:
538
+ terse: bool = False, all: bool = False,
539
+ tree: bool = False, summary: bool = False, yaml: bool = False) -> None:
528
540
  if not (schemas := _get_schemas(portal)):
529
541
  return
530
542
 
531
- if raw:
532
- if raw_yaml:
543
+ if summary is not True:
544
+ if yaml:
533
545
  _print_output(yaml.dump(schemas))
534
546
  else:
535
547
  _print_output(json.dumps(schemas, indent=4))
@@ -550,8 +562,8 @@ def _print_all_schema_names(portal: Portal,
550
562
  _print_output(f"{schema_name} | abstract")
551
563
  else:
552
564
  _print_output(schema_name)
553
- if details:
554
- _print_schema(schemas[schema_name], details=details, more_details=more_details, all=all)
565
+ if not terse:
566
+ _print_schema(schemas[schema_name], terse=terse, all=all)
555
567
 
556
568
 
557
569
  def _get_parent_schema_name(schema: dict) -> Optional[str]:
@@ -1,6 +1,6 @@
1
1
  [tool.poetry]
2
2
  name = "dcicutils"
3
- version = "8.13.3"
3
+ version = "8.13.3.1b2" # TODO: To become 8.13.4
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"
@@ -39,8 +39,8 @@ classifiers = [
39
39
 
40
40
  [tool.poetry.dependencies]
41
41
  python = ">=3.8.1,<3.13"
42
- boto3 = "^1.34.136"
43
- botocore = "^1.34.136"
42
+ boto3 = "^1.34.147"
43
+ botocore = "^1.34.147"
44
44
  # The DCIC portals (cgap-portal and fourfront) are very particular about which ElasticSearch version.
45
45
  # This value is intentionally pinned and must not be changed casually.
46
46
  elasticsearch = "7.13.4"
@@ -63,7 +63,7 @@ pyperclip = "^1.8.2"
63
63
  PyYAML = "^6.0.1"
64
64
  # N.B. 2024-06-30: Updating (via poetry update) from requests 2.31.0 (2023-05-22)
65
65
  # to 2.32.3 (2024-05-29) causes utils GA/CI to fail (on test_ecr_utils_workflow) for some reason.
66
- requests = "^2.21.0"
66
+ requests = "2.31.0"
67
67
  rfc3986 = "^1.4.0"
68
68
  shortuuid = "^1.0.13"
69
69
  structlog = "^19.2.0"
@@ -75,8 +75,8 @@ webtest = "^2.0.34"
75
75
 
76
76
 
77
77
  [tool.poetry.dev-dependencies]
78
- boto3-stubs = "^1.34.136"
79
- botocore-stubs = "^1.34.136"
78
+ boto3-stubs = "^1.34.147"
79
+ botocore-stubs = "^1.34.147"
80
80
  coverage = "^7.5.4"
81
81
  # Loaded manually in GA workflow for coverage because a dependency on 2to3
82
82
  # in its docopts dependency makes a problem for laoding it here in poetry. -kmp 7-Apr-2023
File without changes
File without changes