UncountablePythonSDK 0.0.46__tar.gz → 0.0.48__tar.gz
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of UncountablePythonSDK might be problematic. Click here for more details.
- {uncountablepythonsdk-0.0.46/UncountablePythonSDK.egg-info → uncountablepythonsdk-0.0.48}/PKG-INFO +2 -1
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48/UncountablePythonSDK.egg-info}/PKG-INFO +2 -1
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/UncountablePythonSDK.egg-info/SOURCES.txt +1 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/UncountablePythonSDK.egg-info/requires.txt +1 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/examples/edit_recipe_inputs.py +3 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/examples/invoke_uploader.py +4 -4
- uncountablepythonsdk-0.0.48/pkgs/filesystem_utils/_s3_session.py +116 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/file_type_utils.py +10 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pyproject.toml +2 -1
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/executors/generic_upload_executor.py +5 -14
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/create_entities.py +1 -1
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/create_entity.py +1 -1
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/edit_recipe_inputs.py +14 -1
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/uploader/invoke_uploader.py +2 -2
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/async_batch_processor.py +5 -5
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/client_base.py +7 -7
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/generic_upload_t.py +0 -1
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/.github/workflows/documentation.yml +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/.github/workflows/publish.yml +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/.gitignore +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/README.md +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/UncountablePythonSDK.egg-info/dependency_links.txt +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/UncountablePythonSDK.egg-info/top_level.txt +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/.gitignore +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/conf.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/index.md +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/justfile +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/quickstart.md +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/requirements.txt +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/android-chrome-192x192.png +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/android-chrome-512x512.png +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/apple-touch-icon.png +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/browserconfig.xml +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/favicon-16x16.png +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/favicon-32x32.png +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/manifest.json +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/mstile-150x150.png +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/safari-pinned-tab.svg +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/logo_blue.png +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/examples/async_batch.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/examples/create_entity.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/examples/upload_files.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/_is_enum.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/_is_namedtuple.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/argument_parser.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/case_convert.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/_gdrive_session.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/_local_session.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/_sftp_session.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/filesystem_session.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/missing_sentry.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/opaque_key.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/serial_class.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/serial_union.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/yaml.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization_util/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization_util/_get_type_for_serialization.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization_util/convert_to_snakecase.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization_util/serialization_helpers.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/strenum_compat/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/strenum_compat/strenum_compat.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/__main__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/actions_registry/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/actions_registry/__main__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/actions_registry/emit_typescript.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/builder.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/config.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_io_ts.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_open_api.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_open_api_util.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_python.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_typescript.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_typescript_util.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/load_types.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/open_api_util.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/parts/base.py.prepart +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/parts/base.ts.prepart +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/test.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/type_info/__main__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/type_info/emit_type_info.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/util.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/__main__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/convert_type.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/emit_python.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/types.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/setup.cfg +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/core/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/core/async_batch.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/core/client.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/core/file_upload.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/core/types.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/construct_client.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/cron.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/db/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/db/connect.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/entrypoint.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/executors/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/executors/executors.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/executors/script_executor.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/job.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/secret_retrieval/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/secret_retrieval/retrieve_secret.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/integration/server.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/py.typed +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/batch/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/batch/execute_batch.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/batch/execute_batch_load_async.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/chemical/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/chemical/convert_chemical_formats.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/get_entities_data.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/list_entities.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/lock_entity.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/resolve_entity_ids.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/set_values.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/transition_entity_phase.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/entity/unlock_entity.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/equipment/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/equipment/associate_equipment_input.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/field_options/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/field_options/upsert_field_options.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/id_source/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/id_source/list_id_source.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/id_source/match_id_source.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/input_groups/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/input_groups/get_input_group_names.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/create_inputs.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/get_input_data.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/get_input_names.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/get_inputs_data.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/set_input_attribute_values.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/set_input_category.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/set_input_subcategories.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/inputs/set_intermediate_type.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/material_families/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/material_families/update_entity_material_families.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/outputs/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/outputs/get_output_data.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/outputs/get_output_names.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/outputs/resolve_output_conditions.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/permissions/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/permissions/set_core_permissions.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/project/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/project/get_projects.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/project/get_projects_data.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipe_links/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipe_links/create_recipe_link.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipe_links/remove_recipe_link.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipe_metadata/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipe_metadata/get_recipe_metadata_data.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/add_recipe_to_project.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/archive_recipes.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/associate_recipe_as_input.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/associate_recipe_as_lot.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/create_recipe.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/create_recipes.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/disassociate_recipe_as_input.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/get_curve.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/get_recipe_calculations.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/get_recipe_links.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/get_recipe_names.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/get_recipe_output_metadata.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/get_recipes_data.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/lock_recipes.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/remove_recipe_from_project.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/set_recipe_inputs.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/set_recipe_metadata.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/set_recipe_output_annotations.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/set_recipe_outputs.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/set_recipe_tags.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/unarchive_recipes.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/recipes/unlock_recipes.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/triggers/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/triggers/run_trigger.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/api/uploader/__init__.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/async_batch.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/async_batch_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/base.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/base_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/calculations.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/calculations_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/chemical_structure.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/chemical_structure_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/client_config.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/client_config_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/curves.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/curves_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/entity.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/entity_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/experiment_groups.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/experiment_groups_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/field_values.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/field_values_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/fields.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/fields_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/generic_upload.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/id_source.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/id_source_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/identifier.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/identifier_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/input_attributes.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/input_attributes_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/inputs.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/inputs_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/job_definition.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/job_definition_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/outputs.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/outputs_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/permissions.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/permissions_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/phases.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/phases_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/post_base.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/post_base_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_identifiers.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_identifiers_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_inputs.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_inputs_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_links.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_links_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_metadata.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_metadata_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_output_metadata.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_output_metadata_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_tags.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_tags_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_workflow_steps.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipe_workflow_steps_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipes.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/recipes_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/response.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/response_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/secret_retrieval.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/secret_retrieval_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/units.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/units_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/users.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/users_t.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/workflows.py +0 -0
- {uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/workflows_t.py +0 -0
{uncountablepythonsdk-0.0.46/UncountablePythonSDK.egg-info → uncountablepythonsdk-0.0.48}/PKG-INFO
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: UncountablePythonSDK
|
|
3
|
-
Version: 0.0.
|
|
3
|
+
Version: 0.0.48
|
|
4
4
|
Summary: Uncountable SDK
|
|
5
5
|
Project-URL: Homepage, https://github.com/uncountableinc/uncountable-python-sdk
|
|
6
6
|
Project-URL: Repository, https://github.com/uncountableinc/uncountable-python-sdk.git
|
|
@@ -28,6 +28,7 @@ Requires-Dist: google-api-python-client==2.*
|
|
|
28
28
|
Requires-Dist: tqdm==4.*
|
|
29
29
|
Requires-Dist: pysftp==0.*
|
|
30
30
|
Requires-Dist: paramiko==3.*
|
|
31
|
+
Requires-Dist: boto3==1.*
|
|
31
32
|
Provides-Extra: test
|
|
32
33
|
Requires-Dist: mypy==1.*; extra == "test"
|
|
33
34
|
Requires-Dist: ruff==0.*; extra == "test"
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48/UncountablePythonSDK.egg-info}/PKG-INFO
RENAMED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
Metadata-Version: 2.1
|
|
2
2
|
Name: UncountablePythonSDK
|
|
3
|
-
Version: 0.0.
|
|
3
|
+
Version: 0.0.48
|
|
4
4
|
Summary: Uncountable SDK
|
|
5
5
|
Project-URL: Homepage, https://github.com/uncountableinc/uncountable-python-sdk
|
|
6
6
|
Project-URL: Repository, https://github.com/uncountableinc/uncountable-python-sdk.git
|
|
@@ -28,6 +28,7 @@ Requires-Dist: google-api-python-client==2.*
|
|
|
28
28
|
Requires-Dist: tqdm==4.*
|
|
29
29
|
Requires-Dist: pysftp==0.*
|
|
30
30
|
Requires-Dist: paramiko==3.*
|
|
31
|
+
Requires-Dist: boto3==1.*
|
|
31
32
|
Provides-Extra: test
|
|
32
33
|
Requires-Dist: mypy==1.*; extra == "test"
|
|
33
34
|
Requires-Dist: ruff==0.*; extra == "test"
|
|
@@ -38,6 +38,7 @@ pkgs/argument_parser/case_convert.py
|
|
|
38
38
|
pkgs/filesystem_utils/__init__.py
|
|
39
39
|
pkgs/filesystem_utils/_gdrive_session.py
|
|
40
40
|
pkgs/filesystem_utils/_local_session.py
|
|
41
|
+
pkgs/filesystem_utils/_s3_session.py
|
|
41
42
|
pkgs/filesystem_utils/_sftp_session.py
|
|
42
43
|
pkgs/filesystem_utils/file_type_utils.py
|
|
43
44
|
pkgs/filesystem_utils/filesystem_session.py
|
|
@@ -37,6 +37,9 @@ edits.append(
|
|
|
37
37
|
quantity_basis=QuantityBasis.VOLUME, ingredient_key=IdentifierKeyId(id=1)
|
|
38
38
|
)
|
|
39
39
|
)
|
|
40
|
+
edits.append(
|
|
41
|
+
edit_recipe_inputs_t.RecipeInputEditAddInstructions(instructions="Mix for 3 minutes")
|
|
42
|
+
)
|
|
40
43
|
batch_loader.edit_recipe_inputs(
|
|
41
44
|
recipe_key=IdentifierKeyBatchReference(reference=created_recipe_reference),
|
|
42
45
|
edits=edits,
|
|
@@ -10,14 +10,14 @@ client = Client(
|
|
|
10
10
|
api_secret_key=os.environ["UNC_API_SECRET_KEY"],
|
|
11
11
|
),
|
|
12
12
|
)
|
|
13
|
-
|
|
13
|
+
uploaded_file = client.upload_files(
|
|
14
14
|
file_uploads=[
|
|
15
15
|
MediaFileUpload(path="~/Downloads/my_file_to_upload.csv"),
|
|
16
16
|
]
|
|
17
|
-
)
|
|
17
|
+
)[0]
|
|
18
18
|
|
|
19
19
|
client.invoke_uploader(
|
|
20
|
-
|
|
20
|
+
file_id=uploaded_file.file_id,
|
|
21
21
|
uploader_key=IdentifierKeyId(id=48),
|
|
22
|
-
|
|
22
|
+
material_family_key=IdentifierKeyId(id=1),
|
|
23
23
|
)
|
|
@@ -0,0 +1,116 @@
|
|
|
1
|
+
from io import BytesIO
|
|
2
|
+
|
|
3
|
+
from boto3.session import Session
|
|
4
|
+
|
|
5
|
+
from pkgs.filesystem_utils.file_type_utils import (
|
|
6
|
+
FileObjectData,
|
|
7
|
+
FileSystemFileReference,
|
|
8
|
+
FileSystemObject,
|
|
9
|
+
FileSystemS3Config,
|
|
10
|
+
FileTransfer,
|
|
11
|
+
IncompatibleFileReference,
|
|
12
|
+
)
|
|
13
|
+
|
|
14
|
+
from .filesystem_session import FileSystemSession
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
def _add_slash(prefix: str) -> str:
|
|
18
|
+
if len(prefix) > 0 and prefix[-1] != "/":
|
|
19
|
+
prefix = prefix + "/"
|
|
20
|
+
return prefix
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
class S3Session(FileSystemSession):
|
|
24
|
+
config: FileSystemS3Config
|
|
25
|
+
|
|
26
|
+
def __init__(self, s3_config: FileSystemS3Config) -> None:
|
|
27
|
+
super().__init__()
|
|
28
|
+
self.config = s3_config
|
|
29
|
+
|
|
30
|
+
def start(self) -> None:
|
|
31
|
+
session = Session(region_name=self.config.region_name)
|
|
32
|
+
s3_resource = session.resource(
|
|
33
|
+
service_name="s3",
|
|
34
|
+
endpoint_url=self.config.endpoint_url,
|
|
35
|
+
aws_access_key_id=self.config.access_key_id,
|
|
36
|
+
aws_secret_access_key=self.config.secret_access_key,
|
|
37
|
+
aws_session_token=self.config.session_token,
|
|
38
|
+
)
|
|
39
|
+
|
|
40
|
+
self.bucket = s3_resource.Bucket(self.config.bucket_name)
|
|
41
|
+
|
|
42
|
+
def __enter__(self) -> "S3Session":
|
|
43
|
+
self.start()
|
|
44
|
+
return self
|
|
45
|
+
|
|
46
|
+
def __exit__(self, exc_type: object, exc_val: object, exc_tb: object) -> None:
|
|
47
|
+
self.bucket = None
|
|
48
|
+
|
|
49
|
+
def list_files(
|
|
50
|
+
self,
|
|
51
|
+
dir_path: FileSystemObject,
|
|
52
|
+
*,
|
|
53
|
+
recursive: bool = False,
|
|
54
|
+
valid_extensions: list[str] | None = None,
|
|
55
|
+
) -> list[FileSystemObject]:
|
|
56
|
+
if recursive:
|
|
57
|
+
raise NotImplementedError("recursive file listings not implemented for s3")
|
|
58
|
+
|
|
59
|
+
if not isinstance(dir_path, FileSystemFileReference):
|
|
60
|
+
raise IncompatibleFileReference()
|
|
61
|
+
|
|
62
|
+
assert self.bucket is not None, "call to list_files on uninitialized s3 session"
|
|
63
|
+
|
|
64
|
+
filesystem_references: list[FileSystemObject] = []
|
|
65
|
+
for obj in self.bucket.objects.filter(Prefix=dir_path.filepath):
|
|
66
|
+
if valid_extensions is None or any(
|
|
67
|
+
obj.key.endswith(valid_extension) for valid_extension in valid_extensions
|
|
68
|
+
):
|
|
69
|
+
filesystem_references.append(FileSystemFileReference(obj.key))
|
|
70
|
+
|
|
71
|
+
return filesystem_references
|
|
72
|
+
|
|
73
|
+
def download_files(
|
|
74
|
+
self,
|
|
75
|
+
filepaths: list[FileSystemObject],
|
|
76
|
+
) -> list[FileObjectData]:
|
|
77
|
+
downloaded_files: list[FileObjectData] = []
|
|
78
|
+
assert (
|
|
79
|
+
self.bucket is not None
|
|
80
|
+
), "call to download_files on uninitialized s3 session"
|
|
81
|
+
|
|
82
|
+
for file_object in filepaths:
|
|
83
|
+
if (
|
|
84
|
+
not isinstance(file_object, FileSystemFileReference)
|
|
85
|
+
or file_object.filename is None
|
|
86
|
+
):
|
|
87
|
+
raise IncompatibleFileReference()
|
|
88
|
+
s3_file_obj = self.bucket.Object(_add_slash(file_object.filepath))
|
|
89
|
+
response = s3_file_obj.get()
|
|
90
|
+
file_obj_bytes = response["Body"].read()
|
|
91
|
+
downloaded_files.append(
|
|
92
|
+
FileObjectData(
|
|
93
|
+
file_data=file_obj_bytes,
|
|
94
|
+
file_IO=BytesIO(file_obj_bytes),
|
|
95
|
+
filename=file_object.filename,
|
|
96
|
+
filepath=file_object.filepath,
|
|
97
|
+
)
|
|
98
|
+
)
|
|
99
|
+
|
|
100
|
+
return downloaded_files
|
|
101
|
+
|
|
102
|
+
def move_files(self, file_mappings: list[FileTransfer]) -> None:
|
|
103
|
+
assert self.bucket is not None, "call to move_files on uninitialized s3 session"
|
|
104
|
+
|
|
105
|
+
for src_file, dest_file in file_mappings:
|
|
106
|
+
if not isinstance(src_file, FileSystemFileReference) or not isinstance(
|
|
107
|
+
dest_file, FileSystemFileReference
|
|
108
|
+
):
|
|
109
|
+
raise IncompatibleFileReference()
|
|
110
|
+
self.bucket.Object(_add_slash(dest_file.filepath)).copy_from(
|
|
111
|
+
CopySource={
|
|
112
|
+
"Bucket": self.bucket.name,
|
|
113
|
+
"Key": _add_slash(src_file.filepath),
|
|
114
|
+
}
|
|
115
|
+
)
|
|
116
|
+
self.bucket.Object(_add_slash(src_file.filepath)).delete()
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/file_type_utils.py
RENAMED
|
@@ -59,3 +59,13 @@ class FileSystemSFTPConfig:
|
|
|
59
59
|
password: str | None = None
|
|
60
60
|
valid_extensions: Optional[tuple[str]] = None
|
|
61
61
|
recursive: bool = True
|
|
62
|
+
|
|
63
|
+
|
|
64
|
+
@dataclass(kw_only=True)
|
|
65
|
+
class FileSystemS3Config:
|
|
66
|
+
endpoint_url: str
|
|
67
|
+
bucket_name: str
|
|
68
|
+
region_name: Optional[str]
|
|
69
|
+
access_key_id: Optional[str]
|
|
70
|
+
secret_access_key: Optional[str]
|
|
71
|
+
session_token: Optional[str]
|
|
@@ -14,7 +14,6 @@ from pkgs.filesystem_utils import (
|
|
|
14
14
|
SFTPSession,
|
|
15
15
|
)
|
|
16
16
|
from pkgs.filesystem_utils.filesystem_session import FileSystemSession
|
|
17
|
-
from uncountable.core.async_batch import AsyncBatchProcessor
|
|
18
17
|
from uncountable.core.file_upload import DataFileUpload, FileUpload
|
|
19
18
|
from uncountable.integration.job import Job, JobArguments, JobLogger
|
|
20
19
|
from uncountable.integration.secret_retrieval import retrieve_secret
|
|
@@ -189,9 +188,9 @@ class GenericUploadJob(Job):
|
|
|
189
188
|
|
|
190
189
|
def run(self, args: JobArguments) -> JobResult:
|
|
191
190
|
client = args.client
|
|
191
|
+
batch_processor = args.batch_processor
|
|
192
192
|
logger = args.logger
|
|
193
193
|
|
|
194
|
-
batch_executor = AsyncBatchProcessor(client=client)
|
|
195
194
|
with self._construct_filesystem_session(args) as filesystem_session:
|
|
196
195
|
files_to_upload: list[FileUpload] = []
|
|
197
196
|
for remote_directory in self.remote_directories:
|
|
@@ -227,20 +226,12 @@ class GenericUploadJob(Job):
|
|
|
227
226
|
|
|
228
227
|
file_ids = [file.file_id for file in uploaded_files]
|
|
229
228
|
|
|
230
|
-
|
|
229
|
+
for material_family_key in self.upload_strategy.material_family_keys:
|
|
231
230
|
for file_id in file_ids:
|
|
232
|
-
|
|
233
|
-
|
|
231
|
+
batch_processor.invoke_uploader(
|
|
232
|
+
file_id=file_id,
|
|
234
233
|
uploader_key=self.upload_strategy.uploader_key,
|
|
235
|
-
|
|
234
|
+
material_family_key=material_family_key,
|
|
236
235
|
)
|
|
237
|
-
else:
|
|
238
|
-
batch_executor.invoke_uploader(
|
|
239
|
-
file_ids=file_ids,
|
|
240
|
-
uploader_key=self.upload_strategy.uploader_key,
|
|
241
|
-
material_family_keys=self.upload_strategy.material_family_keys,
|
|
242
|
-
)
|
|
243
|
-
|
|
244
|
-
batch_executor.send()
|
|
245
236
|
|
|
246
237
|
return JobResult(success=True)
|
|
@@ -34,7 +34,7 @@ class EntityToCreate:
|
|
|
34
34
|
@dataclasses.dataclass(kw_only=True)
|
|
35
35
|
class Arguments:
|
|
36
36
|
definition_id: base_t.ObjectId
|
|
37
|
-
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK]]
|
|
37
|
+
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK], typing.Literal[entity_t.EntityType.SPECS]]
|
|
38
38
|
entities_to_create: list[EntityToCreate]
|
|
39
39
|
|
|
40
40
|
|
|
@@ -40,7 +40,7 @@ class EntityFieldInitialValue:
|
|
|
40
40
|
@dataclasses.dataclass(kw_only=True)
|
|
41
41
|
class Arguments:
|
|
42
42
|
definition_id: base_t.ObjectId
|
|
43
|
-
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK]]
|
|
43
|
+
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK], typing.Literal[entity_t.EntityType.SPECS]]
|
|
44
44
|
field_values: typing.Optional[typing.Optional[list[field_values_t.FieldRefNameValue]]] = None
|
|
45
45
|
|
|
46
46
|
|
|
@@ -23,6 +23,7 @@ __all__: list[str] = [
|
|
|
23
23
|
"ENDPOINT_PATH",
|
|
24
24
|
"RecipeInputEdit",
|
|
25
25
|
"RecipeInputEditAddInput",
|
|
26
|
+
"RecipeInputEditAddInstructions",
|
|
26
27
|
"RecipeInputEditBase",
|
|
27
28
|
"RecipeInputEditChangeBasisViewed",
|
|
28
29
|
"RecipeInputEditClearInputs",
|
|
@@ -45,6 +46,7 @@ class RecipeInputEditType(StrEnum):
|
|
|
45
46
|
UPDATE_ANNOTATIONS = "update_annotations"
|
|
46
47
|
SET_LOT = "set_lot"
|
|
47
48
|
CHANGE_BASIS = "change_basis"
|
|
49
|
+
ADD_INSTRUCTIONS = "add_instructions"
|
|
48
50
|
|
|
49
51
|
|
|
50
52
|
# DO NOT MODIFY -- This file is generated by type_spec
|
|
@@ -115,6 +117,16 @@ class RecipeInputEditSetLot(RecipeInputEditBase):
|
|
|
115
117
|
ingredient_lot_recipe_key: identifier_t.IdentifierKey
|
|
116
118
|
|
|
117
119
|
|
|
120
|
+
# DO NOT MODIFY -- This file is generated by type_spec
|
|
121
|
+
@serial_class(
|
|
122
|
+
parse_require={"type"},
|
|
123
|
+
)
|
|
124
|
+
@dataclasses.dataclass(kw_only=True)
|
|
125
|
+
class RecipeInputEditAddInstructions(RecipeInputEditBase):
|
|
126
|
+
type: typing.Literal[RecipeInputEditType.ADD_INSTRUCTIONS] = RecipeInputEditType.ADD_INSTRUCTIONS
|
|
127
|
+
instructions: str
|
|
128
|
+
|
|
129
|
+
|
|
118
130
|
# DO NOT MODIFY -- This file is generated by type_spec
|
|
119
131
|
@serial_class(
|
|
120
132
|
to_string_values={"lower_value", "upper_value"},
|
|
@@ -140,7 +152,7 @@ class RecipeInputEditUpdateAnnotations(RecipeInputEditInputBase):
|
|
|
140
152
|
|
|
141
153
|
# DO NOT MODIFY -- This file is generated by type_spec
|
|
142
154
|
RecipeInputEdit = typing.Annotated[
|
|
143
|
-
typing.Union[RecipeInputEditClearInputs, RecipeInputEditUpsertInput, RecipeInputEditAddInput, RecipeInputEditUpdateAnnotations, RecipeInputEditSetLot, RecipeInputEditChangeBasisViewed],
|
|
155
|
+
typing.Union[RecipeInputEditClearInputs, RecipeInputEditUpsertInput, RecipeInputEditAddInput, RecipeInputEditUpdateAnnotations, RecipeInputEditSetLot, RecipeInputEditChangeBasisViewed, RecipeInputEditAddInstructions],
|
|
144
156
|
serial_union_annotation(
|
|
145
157
|
discriminator="type",
|
|
146
158
|
discriminator_map={
|
|
@@ -150,6 +162,7 @@ RecipeInputEdit = typing.Annotated[
|
|
|
150
162
|
"update_annotations": RecipeInputEditUpdateAnnotations,
|
|
151
163
|
"set_lot": RecipeInputEditSetLot,
|
|
152
164
|
"change_basis": RecipeInputEditChangeBasisViewed,
|
|
165
|
+
"add_instructions": RecipeInputEditAddInstructions,
|
|
153
166
|
},
|
|
154
167
|
),
|
|
155
168
|
]
|
|
@@ -26,9 +26,9 @@ ENDPOINT_PATH = "api/external/uploader/invoke_uploader"
|
|
|
26
26
|
# DO NOT MODIFY -- This file is generated by type_spec
|
|
27
27
|
@dataclasses.dataclass(kw_only=True)
|
|
28
28
|
class Arguments:
|
|
29
|
-
|
|
29
|
+
file_id: base_t.ObjectId
|
|
30
30
|
uploader_key: identifier_t.IdentifierKey
|
|
31
|
-
|
|
31
|
+
material_family_key: identifier_t.IdentifierKey
|
|
32
32
|
|
|
33
33
|
|
|
34
34
|
# DO NOT MODIFY -- This file is generated by type_spec
|
|
@@ -160,19 +160,19 @@ class AsyncBatchProcessorBase(ABC):
|
|
|
160
160
|
def invoke_uploader(
|
|
161
161
|
self,
|
|
162
162
|
*,
|
|
163
|
-
|
|
163
|
+
file_id: base_t.ObjectId,
|
|
164
164
|
uploader_key: identifier_t.IdentifierKey,
|
|
165
|
-
|
|
165
|
+
material_family_key: identifier_t.IdentifierKey,
|
|
166
166
|
depends_on: typing.Optional[list[str]] = None,
|
|
167
167
|
) -> async_batch_t.QueuedAsyncBatchRequest:
|
|
168
|
-
"""Runs
|
|
168
|
+
"""Runs a file through an uploader.
|
|
169
169
|
|
|
170
170
|
:param depends_on: A list of batch reference keys to process before processing this request
|
|
171
171
|
"""
|
|
172
172
|
args = invoke_uploader_t.Arguments(
|
|
173
|
-
|
|
173
|
+
file_id=file_id,
|
|
174
174
|
uploader_key=uploader_key,
|
|
175
|
-
|
|
175
|
+
material_family_key=material_family_key,
|
|
176
176
|
)
|
|
177
177
|
json_data = serialize_for_api(args)
|
|
178
178
|
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/client_base.py
RENAMED
|
@@ -235,7 +235,7 @@ class ClientMethods(ABC):
|
|
|
235
235
|
self,
|
|
236
236
|
*,
|
|
237
237
|
definition_id: base_t.ObjectId,
|
|
238
|
-
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK]],
|
|
238
|
+
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK], typing.Literal[entity_t.EntityType.SPECS]],
|
|
239
239
|
entities_to_create: list[create_entities_t.EntityToCreate],
|
|
240
240
|
) -> create_entities_t.Data:
|
|
241
241
|
"""Creates new Uncountable entities
|
|
@@ -260,7 +260,7 @@ class ClientMethods(ABC):
|
|
|
260
260
|
self,
|
|
261
261
|
*,
|
|
262
262
|
definition_id: base_t.ObjectId,
|
|
263
|
-
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK]],
|
|
263
|
+
entity_type: typing.Union[typing.Literal[entity_t.EntityType.LAB_REQUEST], typing.Literal[entity_t.EntityType.APPROVAL], typing.Literal[entity_t.EntityType.CUSTOM_ENTITY], typing.Literal[entity_t.EntityType.INVENTORY_AMOUNT], typing.Literal[entity_t.EntityType.TASK], typing.Literal[entity_t.EntityType.PROJECT], typing.Literal[entity_t.EntityType.EQUIPMENT], typing.Literal[entity_t.EntityType.INV_LOCAL_LOCATIONS], typing.Literal[entity_t.EntityType.FIELD_OPTION_SET], typing.Literal[entity_t.EntityType.WEBHOOK], typing.Literal[entity_t.EntityType.SPECS]],
|
|
264
264
|
field_values: typing.Optional[typing.Optional[list[field_values_t.FieldRefNameValue]]] = None,
|
|
265
265
|
) -> create_entity_t.Data:
|
|
266
266
|
"""Creates a new Uncountable entity
|
|
@@ -854,17 +854,17 @@ class ClientMethods(ABC):
|
|
|
854
854
|
def invoke_uploader(
|
|
855
855
|
self,
|
|
856
856
|
*,
|
|
857
|
-
|
|
857
|
+
file_id: base_t.ObjectId,
|
|
858
858
|
uploader_key: identifier_t.IdentifierKey,
|
|
859
|
-
|
|
859
|
+
material_family_key: identifier_t.IdentifierKey,
|
|
860
860
|
) -> invoke_uploader_t.Data:
|
|
861
|
-
"""Runs
|
|
861
|
+
"""Runs a file through an uploader.
|
|
862
862
|
|
|
863
863
|
"""
|
|
864
864
|
args = invoke_uploader_t.Arguments(
|
|
865
|
-
|
|
865
|
+
file_id=file_id,
|
|
866
866
|
uploader_key=uploader_key,
|
|
867
|
-
|
|
867
|
+
material_family_key=material_family_key,
|
|
868
868
|
)
|
|
869
869
|
api_request = APIRequest(
|
|
870
870
|
method=invoke_uploader_t.ENDPOINT_METHOD,
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/uncountable/types/generic_upload_t.py
RENAMED
|
@@ -36,6 +36,5 @@ class GenericRemoteDirectoryScope:
|
|
|
36
36
|
class GenericUploadStrategy:
|
|
37
37
|
uploader_key: identifier_t.IdentifierKey
|
|
38
38
|
material_family_keys: list[identifier_t.IdentifierKey]
|
|
39
|
-
parse_files_individually: bool
|
|
40
39
|
skip_moving_files: bool = False
|
|
41
40
|
# DO NOT MODIFY -- This file is generated by type_spec
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/.github/workflows/documentation.yml
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
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/browserconfig.xml
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/favicon-16x16.png
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/favicon-32x32.png
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/manifest.json
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/docs/static/favicons/mstile-150x150.png
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/__init__.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/_is_enum.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/_is_namedtuple.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/argument_parser.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/argument_parser/case_convert.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/__init__.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/_gdrive_session.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/_local_session.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/filesystem_utils/_sftp_session.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/missing_sentry.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/opaque_key.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/serial_class.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization/serial_union.py
RENAMED
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/serialization_util/__init__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/strenum_compat/strenum_compat.py
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
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_open_api_util.py
RENAMED
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_typescript.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/emit_typescript_util.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/parts/base.py.prepart
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/parts/base.ts.prepart
RENAMED
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/type_info/__main__.py
RENAMED
|
File without changes
|
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/__init__.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/__main__.py
RENAMED
|
File without changes
|
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/emit_python.py
RENAMED
|
File without changes
|
{uncountablepythonsdk-0.0.46 → uncountablepythonsdk-0.0.48}/pkgs/type_spec/value_spec/types.py
RENAMED
|
File without changes
|
|
File without changes
|