label-studio-sdk 1.0.20__py3-none-any.whl → 2.0.1__py3-none-any.whl
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 label-studio-sdk might be problematic. Click here for more details.
- label_studio_sdk/__init__.py +345 -180
- label_studio_sdk/actions/__init__.py +4 -0
- label_studio_sdk/actions/client.py +46 -10
- label_studio_sdk/actions/types/__init__.py +4 -0
- label_studio_sdk/actions/types/actions_create_request_filters.py +2 -2
- label_studio_sdk/actions/types/actions_create_request_filters_items_item.py +2 -2
- label_studio_sdk/actions/types/actions_create_request_id.py +7 -7
- label_studio_sdk/actions/types/actions_create_request_selected_items_excluded.py +2 -2
- label_studio_sdk/actions/types/actions_create_request_selected_items_included.py +2 -2
- label_studio_sdk/actions/types/actions_list_response_item.py +25 -0
- label_studio_sdk/actions/types/actions_list_response_item_dialog.py +22 -0
- label_studio_sdk/annotations/__init__.py +2 -2
- label_studio_sdk/annotations/client.py +379 -243
- label_studio_sdk/annotations/types/__init__.py +4 -2
- label_studio_sdk/annotations/types/annotation_bulk_serializer_with_selected_items_request_last_action.py +7 -0
- label_studio_sdk/annotations/types/annotations_create_bulk_response_item.py +8 -5
- label_studio_sdk/base_client.py +32 -24
- label_studio_sdk/billing/__init__.py +2 -0
- label_studio_sdk/billing/client.py +112 -0
- label_studio_sdk/comments/client.py +378 -140
- label_studio_sdk/converter/README.md +207 -0
- label_studio_sdk/converter/imports/coco.py +132 -23
- label_studio_sdk/core/__init__.py +4 -0
- label_studio_sdk/core/unchecked_base_model.py +305 -0
- label_studio_sdk/environment.py +1 -1
- label_studio_sdk/errors/__init__.py +10 -1
- label_studio_sdk/errors/forbidden_error.py +9 -0
- label_studio_sdk/errors/method_not_allowed_error.py +9 -0
- label_studio_sdk/export_storage/__init__.py +1 -24
- label_studio_sdk/export_storage/azure/__init__.py +0 -3
- label_studio_sdk/export_storage/azure/client.py +231 -273
- label_studio_sdk/export_storage/client.py +5 -5
- label_studio_sdk/export_storage/gcs/__init__.py +0 -3
- label_studio_sdk/export_storage/gcs/client.py +231 -273
- label_studio_sdk/export_storage/local/__init__.py +0 -3
- label_studio_sdk/export_storage/local/client.py +211 -253
- label_studio_sdk/export_storage/redis/__init__.py +0 -3
- label_studio_sdk/export_storage/redis/client.py +239 -281
- label_studio_sdk/export_storage/s3/__init__.py +0 -3
- label_studio_sdk/export_storage/s3/client.py +254 -296
- label_studio_sdk/export_storage/s3s/client.py +694 -210
- label_studio_sdk/export_storage/types/export_storage_list_types_response_item.py +2 -2
- label_studio_sdk/files/client.py +52 -71
- label_studio_sdk/import_storage/__init__.py +1 -24
- label_studio_sdk/import_storage/azure/__init__.py +0 -3
- label_studio_sdk/import_storage/azure/client.py +249 -299
- label_studio_sdk/import_storage/client.py +5 -5
- label_studio_sdk/import_storage/gcs/__init__.py +0 -3
- label_studio_sdk/import_storage/gcs/client.py +249 -299
- label_studio_sdk/import_storage/local/__init__.py +0 -3
- label_studio_sdk/import_storage/local/client.py +211 -257
- label_studio_sdk/import_storage/redis/__init__.py +0 -3
- label_studio_sdk/import_storage/redis/client.py +239 -285
- label_studio_sdk/import_storage/s3/__init__.py +0 -3
- label_studio_sdk/import_storage/s3/client.py +274 -324
- label_studio_sdk/import_storage/s3s/client.py +728 -434
- label_studio_sdk/import_storage/types/import_storage_list_types_response_item.py +2 -2
- label_studio_sdk/jwt_settings/client.py +56 -58
- label_studio_sdk/label_interface/control_tags.py +48 -8
- label_studio_sdk/label_interface/interface.py +261 -56
- label_studio_sdk/ml/__init__.py +2 -16
- label_studio_sdk/ml/client.py +196 -179
- label_studio_sdk/ml/types/__init__.py +2 -12
- label_studio_sdk/ml/types/ml_list_model_versions_response.py +20 -0
- label_studio_sdk/model_providers/__init__.py +3 -0
- label_studio_sdk/model_providers/client.py +280 -228
- label_studio_sdk/model_providers/types/__init__.py +5 -0
- label_studio_sdk/{prompts/types/prompts_batch_predictions_response.py → model_providers/types/model_providers_list_model_provider_choices_response.py} +3 -3
- label_studio_sdk/organizations/__init__.py +5 -0
- label_studio_sdk/organizations/client.py +331 -0
- label_studio_sdk/organizations/members/__init__.py +2 -0
- label_studio_sdk/organizations/members/client.py +636 -0
- label_studio_sdk/predictions/client.py +29 -77
- label_studio_sdk/projects/__init__.py +18 -9
- label_studio_sdk/projects/client.py +905 -414
- label_studio_sdk/projects/exports/__init__.py +2 -2
- label_studio_sdk/projects/exports/client.py +336 -396
- label_studio_sdk/projects/exports/client_ext.py +30 -30
- label_studio_sdk/projects/exports/types/__init__.py +1 -2
- label_studio_sdk/projects/exports/types/exports_convert_response.py +5 -9
- label_studio_sdk/projects/pauses/client.py +114 -105
- label_studio_sdk/projects/stats/__init__.py +5 -0
- label_studio_sdk/projects/stats/client.py +175 -0
- label_studio_sdk/projects/stats/types/__init__.py +8 -0
- label_studio_sdk/projects/stats/types/stats_iaa_response.py +44 -0
- label_studio_sdk/projects/stats/types/stats_iaa_response_common_tasks.py +7 -0
- label_studio_sdk/projects/stats/types/stats_iaa_response_iaa.py +5 -0
- label_studio_sdk/{types/base_task_file_upload.py → projects/stats/types/stats_iaa_response_std.py} +1 -1
- label_studio_sdk/projects/types/__init__.py +10 -6
- label_studio_sdk/projects/types/lse_project_create_request_sampling.py +7 -0
- label_studio_sdk/projects/types/lse_project_create_request_skip_queue.py +7 -0
- label_studio_sdk/projects/types/patched_lse_project_update_request_sampling.py +7 -0
- label_studio_sdk/projects/types/patched_lse_project_update_request_skip_queue.py +7 -0
- label_studio_sdk/{prompts/types/prompts_batch_failed_predictions_response.py → projects/types/projects_duplicate_response.py} +8 -5
- label_studio_sdk/projects/types/projects_import_tasks_response.py +2 -2
- label_studio_sdk/projects/types/projects_list_request_filter.py +1 -1
- label_studio_sdk/prompts/__init__.py +4 -10
- label_studio_sdk/prompts/client.py +511 -442
- label_studio_sdk/prompts/indicators/__init__.py +3 -0
- label_studio_sdk/prompts/indicators/client.py +47 -49
- label_studio_sdk/prompts/indicators/types/__init__.py +5 -0
- label_studio_sdk/{types/key_indicator_value.py → prompts/indicators/types/indicators_list_response_item.py} +3 -3
- label_studio_sdk/prompts/runs/client.py +113 -135
- label_studio_sdk/prompts/types/__init__.py +2 -12
- label_studio_sdk/prompts/types/prompts_compatible_projects_request_project_type.py +7 -0
- label_studio_sdk/prompts/versions/client.py +372 -312
- label_studio_sdk/tasks/__init__.py +2 -2
- label_studio_sdk/tasks/client.py +514 -213
- label_studio_sdk/tasks/types/__init__.py +1 -2
- label_studio_sdk/tokens/client.py +160 -152
- label_studio_sdk/tokens/client_ext.py +3 -3
- label_studio_sdk/types/__init__.py +276 -142
- label_studio_sdk/{webhooks/types/webhooks_update_request_actions_item.py → types/actions_enum.py} +4 -1
- label_studio_sdk/types/all_roles_project_list.py +197 -0
- label_studio_sdk/types/all_roles_project_list_sampling.py +7 -0
- label_studio_sdk/types/all_roles_project_list_skip_queue.py +7 -0
- label_studio_sdk/types/annotated_enum.py +5 -0
- label_studio_sdk/types/annotation.py +24 -10
- label_studio_sdk/types/annotation_last_action.py +3 -15
- label_studio_sdk/types/{annotations_dm_field.py → annotation_request.py} +21 -30
- label_studio_sdk/types/annotation_request_last_action.py +7 -0
- label_studio_sdk/types/assignment_settings.py +31 -0
- label_studio_sdk/types/assignment_settings_label_stream_task_distribution.py +7 -0
- label_studio_sdk/types/assignment_settings_request.py +32 -0
- label_studio_sdk/types/assignment_settings_request_label_stream_task_distribution.py +7 -0
- label_studio_sdk/types/associated_project.py +30 -0
- label_studio_sdk/types/auth_method_enum.py +5 -0
- label_studio_sdk/types/azure_blob_export_storage.py +8 -12
- label_studio_sdk/types/azure_blob_import_storage.py +8 -12
- label_studio_sdk/types/{prompt_associated_projects_item_id.py → batch_failed_predictions.py} +4 -4
- label_studio_sdk/types/{access_token_response.py → batch_predictions.py} +6 -8
- label_studio_sdk/types/billing_checks.py +39 -0
- label_studio_sdk/types/billing_flags.py +44 -0
- label_studio_sdk/types/billing_info_response.py +22 -0
- label_studio_sdk/types/blank_enum.py +5 -0
- label_studio_sdk/types/{key_indicators_item_extra_kpis_item.py → blueprint_list.py} +12 -6
- label_studio_sdk/types/budget_reset_period_enum.py +5 -0
- label_studio_sdk/types/child_filter.py +44 -0
- label_studio_sdk/types/comment.py +39 -14
- label_studio_sdk/types/comment_request.py +32 -0
- label_studio_sdk/types/comment_serializer_with_expanded_user.py +53 -0
- label_studio_sdk/types/converted_format.py +5 -5
- label_studio_sdk/types/{api_token_response.py → converted_format_request.py} +8 -15
- label_studio_sdk/types/count_limit.py +22 -0
- label_studio_sdk/types/custom_scripts_editable_by_enum.py +5 -0
- label_studio_sdk/types/default_role_enum.py +5 -0
- label_studio_sdk/types/edition_enum.py +5 -0
- label_studio_sdk/types/export.py +7 -7
- label_studio_sdk/types/file_upload.py +5 -5
- label_studio_sdk/types/filter.py +9 -6
- label_studio_sdk/types/filter_group.py +3 -3
- label_studio_sdk/types/finished_enum.py +5 -0
- label_studio_sdk/types/gcs_export_storage.py +8 -12
- label_studio_sdk/types/gcs_import_storage.py +8 -12
- label_studio_sdk/types/{rotate_token_response.py → hotkeys.py} +5 -8
- label_studio_sdk/types/{base_task.py → import_api_request.py} +11 -34
- label_studio_sdk/types/inference_run_cost_estimate.py +2 -2
- label_studio_sdk/types/label_stream_task_distribution_enum.py +5 -0
- label_studio_sdk/types/{annotations_dm_field_last_action.py → last_action_enum.py} +1 -1
- label_studio_sdk/types/local_files_export_storage.py +8 -12
- label_studio_sdk/types/local_files_import_storage.py +8 -12
- label_studio_sdk/types/{annotation_filter_options.py → lse_annotation_filter_options.py} +12 -2
- label_studio_sdk/types/lse_annotation_filter_options_request.py +42 -0
- label_studio_sdk/types/lse_annotation_filter_options_request_reviewed.py +7 -0
- label_studio_sdk/types/lse_annotation_filter_options_reviewed.py +7 -0
- label_studio_sdk/types/{export_snapshot.py → lse_export_create.py} +11 -11
- label_studio_sdk/types/lse_fields.py +49 -0
- label_studio_sdk/types/lse_fields_onboarding_state.py +8 -0
- label_studio_sdk/types/lse_fields_trial_role.py +8 -0
- label_studio_sdk/types/lse_key_indicator_value.py +35 -0
- label_studio_sdk/types/lse_organization.py +57 -0
- label_studio_sdk/types/lse_organization_custom_scripts_editable_by.py +7 -0
- label_studio_sdk/types/{key_indicators_item_additional_kpis_item.py → lse_organization_member_list.py} +12 -7
- label_studio_sdk/types/lse_project_create.py +196 -0
- label_studio_sdk/types/lse_project_create_sampling.py +7 -0
- label_studio_sdk/types/lse_project_create_skip_queue.py +7 -0
- label_studio_sdk/types/lse_project_update.py +215 -0
- label_studio_sdk/types/lse_project_update_sampling.py +7 -0
- label_studio_sdk/types/lse_project_update_skip_queue.py +7 -0
- label_studio_sdk/types/lse_s3export_storage.py +134 -0
- label_studio_sdk/{import_storage/s3/types/s3create_response.py → types/lse_s3export_storage_request.py} +47 -21
- label_studio_sdk/{import_storage/s3/types/s3update_response.py → types/lse_s3import_storage.py} +60 -21
- label_studio_sdk/types/{s3s_import_storage.py → lse_s3import_storage_request.py} +32 -21
- label_studio_sdk/types/lse_task.py +117 -0
- label_studio_sdk/types/{data_manager_task_serializer_drafts_item.py → lse_task_drafts_item.py} +2 -2
- label_studio_sdk/types/lse_task_filter_options.py +63 -0
- label_studio_sdk/types/lse_task_filter_options_annotated.py +7 -0
- label_studio_sdk/types/lse_task_filter_options_finished.py +7 -0
- label_studio_sdk/types/lse_task_filter_options_request.py +63 -0
- label_studio_sdk/types/lse_task_filter_options_request_annotated.py +7 -0
- label_studio_sdk/types/lse_task_filter_options_request_finished.py +7 -0
- label_studio_sdk/types/lse_task_filter_options_request_reviewed.py +7 -0
- label_studio_sdk/types/lse_task_filter_options_request_skipped.py +7 -0
- label_studio_sdk/types/lse_task_filter_options_reviewed.py +7 -0
- label_studio_sdk/types/lse_task_filter_options_skipped.py +7 -0
- label_studio_sdk/types/{data_manager_task_serializer_predictions_item.py → lse_task_predictions_item.py} +4 -5
- label_studio_sdk/types/lse_task_serializer_for_annotators.py +54 -0
- label_studio_sdk/types/lse_task_serializer_for_annotators_drafts_item.py +22 -0
- label_studio_sdk/types/lse_task_serializer_for_annotators_predictions_item.py +28 -0
- label_studio_sdk/types/lse_task_serializer_for_reviewers.py +117 -0
- label_studio_sdk/types/lse_task_serializer_for_reviewers_drafts_item.py +22 -0
- label_studio_sdk/types/lse_task_serializer_for_reviewers_predictions_item.py +28 -0
- label_studio_sdk/types/lse_user.py +49 -0
- label_studio_sdk/types/{base_user.py → lse_user_api.py} +17 -6
- label_studio_sdk/types/lse_user_organization_member_list.py +48 -0
- label_studio_sdk/types/lseapi_token_create.py +21 -0
- label_studio_sdk/types/lseapi_token_list.py +21 -0
- label_studio_sdk/types/lsejwt_settings.py +32 -0
- label_studio_sdk/types/maybe_expanded_comment.py +7 -0
- label_studio_sdk/types/ml_backend.py +16 -17
- label_studio_sdk/types/mode_enum.py +5 -0
- label_studio_sdk/types/model_interface.py +44 -0
- label_studio_sdk/types/model_interface_request.py +40 -0
- label_studio_sdk/types/model_interface_serializer_get.py +45 -0
- label_studio_sdk/types/model_provider_connection.py +48 -17
- label_studio_sdk/types/model_provider_connection_budget_reset_period.py +3 -1
- label_studio_sdk/types/model_provider_connection_request.py +71 -0
- label_studio_sdk/types/model_run.py +40 -0
- label_studio_sdk/types/{inference_run_status.py → model_run_status_enum.py} +1 -1
- label_studio_sdk/types/null_enum.py +3 -0
- label_studio_sdk/types/onboarding_state_enum.py +7 -0
- label_studio_sdk/types/organization_billing.py +20 -0
- label_studio_sdk/types/organization_id.py +28 -0
- label_studio_sdk/types/organization_invite.py +20 -0
- label_studio_sdk/types/organization_member.py +37 -0
- label_studio_sdk/types/organization_membership.py +24 -0
- label_studio_sdk/{projects/types/projects_list_response.py → types/paginated_all_roles_project_list_list.py} +5 -5
- label_studio_sdk/types/paginated_lse_organization_member_list_list.py +23 -0
- label_studio_sdk/types/{jwt_settings_response.py → paginated_role_based_task_list.py} +11 -9
- label_studio_sdk/types/pause.py +55 -14
- label_studio_sdk/types/pause_request.py +41 -0
- label_studio_sdk/types/prediction.py +7 -11
- label_studio_sdk/types/prediction_request.py +56 -0
- label_studio_sdk/types/project.py +32 -39
- label_studio_sdk/types/project_import.py +12 -13
- label_studio_sdk/types/project_label_config.py +2 -2
- label_studio_sdk/types/project_label_config_request.py +22 -0
- label_studio_sdk/types/project_sampling.py +3 -3
- label_studio_sdk/types/project_skip_queue.py +3 -1
- label_studio_sdk/types/project_subset_enum.py +5 -0
- label_studio_sdk/types/prompts_status_enum.py +16 -0
- label_studio_sdk/types/{prompt_version_provider.py → provider_enum.py} +1 -1
- label_studio_sdk/types/reason_enum.py +7 -0
- label_studio_sdk/types/redis_export_storage.py +8 -12
- label_studio_sdk/types/redis_import_storage.py +8 -12
- label_studio_sdk/types/refined_prompt_response.py +5 -6
- label_studio_sdk/types/requeue_rejected_tasks_mode_enum.py +5 -0
- label_studio_sdk/types/review_criteria_enum.py +5 -0
- label_studio_sdk/types/review_settings.py +80 -0
- label_studio_sdk/types/review_settings_request.py +80 -0
- label_studio_sdk/types/review_settings_request_requeue_rejected_tasks_mode.py +8 -0
- label_studio_sdk/types/review_settings_request_review_criteria.py +7 -0
- label_studio_sdk/types/review_settings_requeue_rejected_tasks_mode.py +8 -0
- label_studio_sdk/types/review_settings_review_criteria.py +7 -0
- label_studio_sdk/types/reviewed_enum.py +5 -0
- label_studio_sdk/types/role9e7enum.py +5 -0
- label_studio_sdk/types/role_based_task.py +8 -0
- label_studio_sdk/types/s3export_storage.py +8 -12
- label_studio_sdk/types/s3import_storage.py +8 -12
- label_studio_sdk/types/sampling_enum.py +7 -0
- label_studio_sdk/types/scope_enum.py +5 -0
- label_studio_sdk/types/selected_items_request.py +23 -0
- label_studio_sdk/types/serialization_option.py +2 -6
- label_studio_sdk/types/serialization_option_request.py +22 -0
- label_studio_sdk/types/serialization_options.py +17 -5
- label_studio_sdk/types/serialization_options_request.py +47 -0
- label_studio_sdk/types/skill_name_enum.py +5 -0
- label_studio_sdk/types/skip_queue_enum.py +5 -0
- label_studio_sdk/types/skipped_enum.py +5 -0
- label_studio_sdk/types/state_enum.py +5 -0
- label_studio_sdk/types/status7bf_enum.py +5 -0
- label_studio_sdk/types/{azure_blob_import_storage_status.py → status_c5a_enum.py} +2 -2
- label_studio_sdk/types/third_party_model_version.py +65 -0
- label_studio_sdk/types/third_party_model_version_request.py +54 -0
- label_studio_sdk/types/token_refresh_response.py +19 -0
- label_studio_sdk/types/token_rotate_response.py +19 -0
- label_studio_sdk/types/trial_role_enum.py +16 -0
- label_studio_sdk/types/user_simple.py +8 -5
- label_studio_sdk/types/user_simple_request.py +28 -0
- label_studio_sdk/types/version_response.py +49 -0
- label_studio_sdk/types/view.py +8 -15
- label_studio_sdk/types/webhook.py +9 -13
- label_studio_sdk/types/webhook_serializer_for_update.py +15 -13
- label_studio_sdk/types/workspace.py +14 -34
- label_studio_sdk/types/workspace_member_create.py +27 -0
- label_studio_sdk/types/workspace_member_list.py +24 -0
- label_studio_sdk/users/client.py +604 -87
- label_studio_sdk/users/types/users_get_token_response.py +4 -11
- label_studio_sdk/users/types/users_reset_token_response.py +4 -11
- label_studio_sdk/versions/__init__.py +0 -3
- label_studio_sdk/versions/client.py +14 -14
- label_studio_sdk/views/client.py +227 -141
- label_studio_sdk/views/types/views_create_request_data.py +2 -2
- label_studio_sdk/views/types/views_create_request_data_filters.py +2 -2
- label_studio_sdk/views/types/views_create_request_data_filters_items_item.py +2 -2
- label_studio_sdk/views/types/views_update_request_data.py +2 -2
- label_studio_sdk/views/types/views_update_request_data_filters.py +2 -2
- label_studio_sdk/views/types/views_update_request_data_filters_items_item.py +2 -2
- label_studio_sdk/webhooks/__init__.py +36 -2
- label_studio_sdk/webhooks/client.py +173 -367
- label_studio_sdk/webhooks/types/__init__.py +34 -2
- label_studio_sdk/webhooks/types/webhooks_info_response.py +80 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_annotation_created.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_annotation_updated.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_annotations_created.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_annotations_deleted.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_label_link_created.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_label_link_deleted.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_label_link_updated.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_project_created.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_project_deleted.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_project_updated.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_review_created.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_review_updated.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_reviews_deleted.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_tasks_created.py +24 -0
- label_studio_sdk/webhooks/types/webhooks_info_response_tasks_deleted.py +24 -0
- label_studio_sdk/workspaces/__init__.py +1 -2
- label_studio_sdk/workspaces/client.py +97 -117
- label_studio_sdk/workspaces/members/__init__.py +0 -3
- label_studio_sdk/workspaces/members/client.py +65 -81
- {label_studio_sdk-1.0.20.dist-info → label_studio_sdk-2.0.1.dist-info}/METADATA +73 -25
- label_studio_sdk-2.0.1.dist-info/RECORD +435 -0
- {label_studio_sdk-1.0.20.dist-info → label_studio_sdk-2.0.1.dist-info}/WHEEL +1 -1
- label_studio_sdk/annotations/types/annotations_create_bulk_request_selected_items.py +0 -34
- label_studio_sdk/export_storage/azure/types/__init__.py +0 -6
- label_studio_sdk/export_storage/azure/types/azure_create_response.py +0 -57
- label_studio_sdk/export_storage/azure/types/azure_update_response.py +0 -57
- label_studio_sdk/export_storage/gcs/types/__init__.py +0 -6
- label_studio_sdk/export_storage/gcs/types/gcs_create_response.py +0 -57
- label_studio_sdk/export_storage/gcs/types/gcs_update_response.py +0 -57
- label_studio_sdk/export_storage/local/types/__init__.py +0 -6
- label_studio_sdk/export_storage/local/types/local_create_response.py +0 -47
- label_studio_sdk/export_storage/local/types/local_update_response.py +0 -47
- label_studio_sdk/export_storage/redis/types/__init__.py +0 -6
- label_studio_sdk/export_storage/redis/types/redis_create_response.py +0 -62
- label_studio_sdk/export_storage/redis/types/redis_update_response.py +0 -62
- label_studio_sdk/export_storage/s3/types/__init__.py +0 -6
- label_studio_sdk/export_storage/s3/types/s3create_response.py +0 -81
- label_studio_sdk/export_storage/s3/types/s3update_response.py +0 -81
- label_studio_sdk/import_storage/azure/types/__init__.py +0 -6
- label_studio_sdk/import_storage/azure/types/azure_create_response.py +0 -72
- label_studio_sdk/import_storage/azure/types/azure_update_response.py +0 -72
- label_studio_sdk/import_storage/gcs/types/__init__.py +0 -6
- label_studio_sdk/import_storage/gcs/types/gcs_create_response.py +0 -72
- label_studio_sdk/import_storage/gcs/types/gcs_update_response.py +0 -72
- label_studio_sdk/import_storage/local/types/__init__.py +0 -6
- label_studio_sdk/import_storage/local/types/local_create_response.py +0 -47
- label_studio_sdk/import_storage/local/types/local_update_response.py +0 -47
- label_studio_sdk/import_storage/redis/types/__init__.py +0 -6
- label_studio_sdk/import_storage/redis/types/redis_create_response.py +0 -62
- label_studio_sdk/import_storage/redis/types/redis_update_response.py +0 -62
- label_studio_sdk/import_storage/s3/types/__init__.py +0 -6
- label_studio_sdk/ml/types/ml_create_response.py +0 -68
- label_studio_sdk/ml/types/ml_create_response_auth_method.py +0 -5
- label_studio_sdk/ml/types/ml_update_response.py +0 -68
- label_studio_sdk/ml/types/ml_update_response_auth_method.py +0 -5
- label_studio_sdk/projects/exports/types/exports_list_formats_response_item.py +0 -44
- label_studio_sdk/projects/types/projects_create_response.py +0 -91
- label_studio_sdk/projects/types/projects_update_response.py +0 -96
- label_studio_sdk/prompts/types/prompts_batch_failed_predictions_request_failed_predictions_item.py +0 -32
- label_studio_sdk/prompts/types/prompts_batch_predictions_request_results_item.py +0 -59
- label_studio_sdk/tasks/types/tasks_list_response.py +0 -38
- label_studio_sdk/types/annotation_completed_by.py +0 -6
- label_studio_sdk/types/azure_blob_export_storage_status.py +0 -7
- label_studio_sdk/types/base_task_updated_by.py +0 -7
- label_studio_sdk/types/comment_created_by.py +0 -5
- label_studio_sdk/types/converted_format_status.py +0 -5
- label_studio_sdk/types/data_manager_task_serializer.py +0 -118
- label_studio_sdk/types/data_manager_task_serializer_annotators_item.py +0 -5
- label_studio_sdk/types/data_manager_task_serializer_comment_authors_item.py +0 -5
- label_studio_sdk/types/data_manager_task_serializer_predictions_item_model_run.py +0 -5
- label_studio_sdk/types/export_format.py +0 -25
- label_studio_sdk/types/export_snapshot_status.py +0 -5
- label_studio_sdk/types/export_status.py +0 -5
- label_studio_sdk/types/gcs_export_storage_status.py +0 -7
- label_studio_sdk/types/gcs_import_storage_status.py +0 -7
- label_studio_sdk/types/inference_run.py +0 -34
- label_studio_sdk/types/inference_run_created_by.py +0 -5
- label_studio_sdk/types/inference_run_organization.py +0 -5
- label_studio_sdk/types/inference_run_project_subset.py +0 -5
- label_studio_sdk/types/key_indicators.py +0 -6
- label_studio_sdk/types/key_indicators_item.py +0 -41
- label_studio_sdk/types/local_files_export_storage_status.py +0 -7
- label_studio_sdk/types/local_files_import_storage_status.py +0 -7
- label_studio_sdk/types/ml_backend_auth_method.py +0 -5
- label_studio_sdk/types/ml_backend_state.py +0 -5
- label_studio_sdk/types/model_provider_connection_created_by.py +0 -5
- label_studio_sdk/types/model_provider_connection_organization.py +0 -5
- label_studio_sdk/types/model_provider_connection_provider.py +0 -7
- label_studio_sdk/types/model_provider_connection_scope.py +0 -5
- label_studio_sdk/types/pause_paused_by.py +0 -5
- label_studio_sdk/types/project_import_status.py +0 -5
- label_studio_sdk/types/prompt.py +0 -71
- label_studio_sdk/types/prompt_associated_projects_item.py +0 -6
- label_studio_sdk/types/prompt_created_by.py +0 -5
- label_studio_sdk/types/prompt_organization.py +0 -5
- label_studio_sdk/types/prompt_version.py +0 -32
- label_studio_sdk/types/prompt_version_created_by.py +0 -5
- label_studio_sdk/types/prompt_version_organization.py +0 -5
- label_studio_sdk/types/redis_export_storage_status.py +0 -7
- label_studio_sdk/types/redis_import_storage_status.py +0 -7
- label_studio_sdk/types/refined_prompt_response_refinement_status.py +0 -7
- label_studio_sdk/types/s3export_storage_status.py +0 -7
- label_studio_sdk/types/s3import_storage_status.py +0 -7
- label_studio_sdk/types/s3s_export_storage.py +0 -73
- label_studio_sdk/types/s3s_import_storage_status.py +0 -7
- label_studio_sdk/types/task.py +0 -156
- label_studio_sdk/types/task_annotators_item.py +0 -5
- label_studio_sdk/types/task_comment_authors_item.py +0 -5
- label_studio_sdk/types/task_filter_options.py +0 -39
- label_studio_sdk/types/webhook_actions_item.py +0 -21
- label_studio_sdk/types/webhook_serializer_for_update_actions_item.py +0 -21
- label_studio_sdk/versions/types/__init__.py +0 -6
- label_studio_sdk/versions/types/versions_get_response.py +0 -73
- label_studio_sdk/versions/types/versions_get_response_edition.py +0 -5
- label_studio_sdk/workspaces/members/types/__init__.py +0 -6
- label_studio_sdk/workspaces/members/types/members_create_response.py +0 -22
- label_studio_sdk/workspaces/members/types/members_list_response_item.py +0 -22
- label_studio_sdk-1.0.20.dist-info/RECORD +0 -374
- {label_studio_sdk-1.0.20.dist-info → label_studio_sdk-2.0.1.dist-info}/LICENSE +0 -0
|
@@ -0,0 +1,305 @@
|
|
|
1
|
+
# This file was auto-generated by Fern from our API Definition.
|
|
2
|
+
|
|
3
|
+
import datetime as dt
|
|
4
|
+
import inspect
|
|
5
|
+
import typing
|
|
6
|
+
import uuid
|
|
7
|
+
|
|
8
|
+
import typing_extensions
|
|
9
|
+
from pydantic_core import PydanticUndefined
|
|
10
|
+
|
|
11
|
+
import pydantic
|
|
12
|
+
|
|
13
|
+
from .pydantic_utilities import (
|
|
14
|
+
IS_PYDANTIC_V2,
|
|
15
|
+
ModelField,
|
|
16
|
+
UniversalBaseModel,
|
|
17
|
+
get_args,
|
|
18
|
+
get_origin,
|
|
19
|
+
is_literal_type,
|
|
20
|
+
is_union,
|
|
21
|
+
parse_date,
|
|
22
|
+
parse_datetime,
|
|
23
|
+
parse_obj_as,
|
|
24
|
+
)
|
|
25
|
+
from .serialization import get_field_to_alias_mapping
|
|
26
|
+
|
|
27
|
+
|
|
28
|
+
class UnionMetadata:
|
|
29
|
+
discriminant: str
|
|
30
|
+
|
|
31
|
+
def __init__(self, *, discriminant: str) -> None:
|
|
32
|
+
self.discriminant = discriminant
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
Model = typing.TypeVar("Model", bound=pydantic.BaseModel)
|
|
36
|
+
|
|
37
|
+
|
|
38
|
+
class UncheckedBaseModel(UniversalBaseModel):
|
|
39
|
+
if IS_PYDANTIC_V2:
|
|
40
|
+
model_config: typing.ClassVar[pydantic.ConfigDict] = pydantic.ConfigDict(extra="allow") # type: ignore # Pydantic v2
|
|
41
|
+
else:
|
|
42
|
+
|
|
43
|
+
class Config:
|
|
44
|
+
extra = pydantic.Extra.allow
|
|
45
|
+
|
|
46
|
+
@classmethod
|
|
47
|
+
def model_construct(
|
|
48
|
+
cls: typing.Type["Model"],
|
|
49
|
+
_fields_set: typing.Optional[typing.Set[str]] = None,
|
|
50
|
+
**values: typing.Any,
|
|
51
|
+
) -> "Model":
|
|
52
|
+
# Fallback construct function to the specified override below.
|
|
53
|
+
return cls.construct(_fields_set=_fields_set, **values)
|
|
54
|
+
|
|
55
|
+
# Allow construct to not validate model
|
|
56
|
+
# Implementation taken from: https://github.com/pydantic/pydantic/issues/1168#issuecomment-817742836
|
|
57
|
+
@classmethod
|
|
58
|
+
def construct(
|
|
59
|
+
cls: typing.Type["Model"],
|
|
60
|
+
_fields_set: typing.Optional[typing.Set[str]] = None,
|
|
61
|
+
**values: typing.Any,
|
|
62
|
+
) -> "Model":
|
|
63
|
+
m = cls.__new__(cls)
|
|
64
|
+
fields_values = {}
|
|
65
|
+
|
|
66
|
+
if _fields_set is None:
|
|
67
|
+
_fields_set = set(values.keys())
|
|
68
|
+
|
|
69
|
+
fields = _get_model_fields(cls)
|
|
70
|
+
populate_by_name = _get_is_populate_by_name(cls)
|
|
71
|
+
field_aliases = get_field_to_alias_mapping(cls)
|
|
72
|
+
|
|
73
|
+
for name, field in fields.items():
|
|
74
|
+
# Key here is only used to pull data from the values dict
|
|
75
|
+
# you should always use the NAME of the field to for field_values, etc.
|
|
76
|
+
# because that's how the object is constructed from a pydantic perspective
|
|
77
|
+
key = field.alias
|
|
78
|
+
if (key is None or field.alias == name) and name in field_aliases:
|
|
79
|
+
key = field_aliases[name]
|
|
80
|
+
|
|
81
|
+
if key is None or (key not in values and populate_by_name): # Added this to allow population by field name
|
|
82
|
+
key = name
|
|
83
|
+
|
|
84
|
+
if key in values:
|
|
85
|
+
if IS_PYDANTIC_V2:
|
|
86
|
+
type_ = field.annotation # type: ignore # Pydantic v2
|
|
87
|
+
else:
|
|
88
|
+
type_ = typing.cast(typing.Type, field.outer_type_) # type: ignore # Pydantic < v1.10.15
|
|
89
|
+
|
|
90
|
+
fields_values[name] = (
|
|
91
|
+
construct_type(object_=values[key], type_=type_) if type_ is not None else values[key]
|
|
92
|
+
)
|
|
93
|
+
_fields_set.add(name)
|
|
94
|
+
else:
|
|
95
|
+
default = _get_field_default(field)
|
|
96
|
+
fields_values[name] = default
|
|
97
|
+
|
|
98
|
+
# If the default values are non-null act like they've been set
|
|
99
|
+
# This effectively allows exclude_unset to work like exclude_none where
|
|
100
|
+
# the latter passes through intentionally set none values.
|
|
101
|
+
if default != None and default != PydanticUndefined:
|
|
102
|
+
_fields_set.add(name)
|
|
103
|
+
|
|
104
|
+
# Add extras back in
|
|
105
|
+
extras = {}
|
|
106
|
+
pydantic_alias_fields = [field.alias for field in fields.values()]
|
|
107
|
+
internal_alias_fields = list(field_aliases.values())
|
|
108
|
+
for key, value in values.items():
|
|
109
|
+
# If the key is not a field by name, nor an alias to a field, then it's extra
|
|
110
|
+
if (key not in pydantic_alias_fields and key not in internal_alias_fields) and key not in fields:
|
|
111
|
+
if IS_PYDANTIC_V2:
|
|
112
|
+
extras[key] = value
|
|
113
|
+
else:
|
|
114
|
+
_fields_set.add(key)
|
|
115
|
+
fields_values[key] = value
|
|
116
|
+
|
|
117
|
+
object.__setattr__(m, "__dict__", fields_values)
|
|
118
|
+
|
|
119
|
+
if IS_PYDANTIC_V2:
|
|
120
|
+
object.__setattr__(m, "__pydantic_private__", None)
|
|
121
|
+
object.__setattr__(m, "__pydantic_extra__", extras)
|
|
122
|
+
object.__setattr__(m, "__pydantic_fields_set__", _fields_set)
|
|
123
|
+
else:
|
|
124
|
+
object.__setattr__(m, "__fields_set__", _fields_set)
|
|
125
|
+
m._init_private_attributes() # type: ignore # Pydantic v1
|
|
126
|
+
return m
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
def _convert_undiscriminated_union_type(union_type: typing.Type[typing.Any], object_: typing.Any) -> typing.Any:
|
|
130
|
+
inner_types = get_args(union_type)
|
|
131
|
+
if typing.Any in inner_types:
|
|
132
|
+
return object_
|
|
133
|
+
|
|
134
|
+
for inner_type in inner_types:
|
|
135
|
+
try:
|
|
136
|
+
if inspect.isclass(inner_type) and issubclass(inner_type, pydantic.BaseModel):
|
|
137
|
+
# Attempt a validated parse until one works
|
|
138
|
+
return parse_obj_as(inner_type, object_)
|
|
139
|
+
except Exception:
|
|
140
|
+
continue
|
|
141
|
+
|
|
142
|
+
# If none of the types work, just return the first successful cast
|
|
143
|
+
for inner_type in inner_types:
|
|
144
|
+
try:
|
|
145
|
+
return construct_type(object_=object_, type_=inner_type)
|
|
146
|
+
except Exception:
|
|
147
|
+
continue
|
|
148
|
+
|
|
149
|
+
|
|
150
|
+
def _convert_union_type(type_: typing.Type[typing.Any], object_: typing.Any) -> typing.Any:
|
|
151
|
+
base_type = get_origin(type_) or type_
|
|
152
|
+
union_type = type_
|
|
153
|
+
if base_type == typing_extensions.Annotated:
|
|
154
|
+
union_type = get_args(type_)[0]
|
|
155
|
+
annotated_metadata = get_args(type_)[1:]
|
|
156
|
+
for metadata in annotated_metadata:
|
|
157
|
+
if isinstance(metadata, UnionMetadata):
|
|
158
|
+
try:
|
|
159
|
+
# Cast to the correct type, based on the discriminant
|
|
160
|
+
for inner_type in get_args(union_type):
|
|
161
|
+
try:
|
|
162
|
+
objects_discriminant = getattr(object_, metadata.discriminant)
|
|
163
|
+
except:
|
|
164
|
+
objects_discriminant = object_[metadata.discriminant]
|
|
165
|
+
if inner_type.__fields__[metadata.discriminant].default == objects_discriminant:
|
|
166
|
+
return construct_type(object_=object_, type_=inner_type)
|
|
167
|
+
except Exception:
|
|
168
|
+
# Allow to fall through to our regular union handling
|
|
169
|
+
pass
|
|
170
|
+
return _convert_undiscriminated_union_type(union_type, object_)
|
|
171
|
+
|
|
172
|
+
|
|
173
|
+
def construct_type(*, type_: typing.Type[typing.Any], object_: typing.Any) -> typing.Any:
|
|
174
|
+
"""
|
|
175
|
+
Here we are essentially creating the same `construct` method in spirit as the above, but for all types, not just
|
|
176
|
+
Pydantic models.
|
|
177
|
+
The idea is to essentially attempt to coerce object_ to type_ (recursively)
|
|
178
|
+
"""
|
|
179
|
+
# Short circuit when dealing with optionals, don't try to coerces None to a type
|
|
180
|
+
if object_ is None:
|
|
181
|
+
return None
|
|
182
|
+
|
|
183
|
+
base_type = get_origin(type_) or type_
|
|
184
|
+
is_annotated = base_type == typing_extensions.Annotated
|
|
185
|
+
maybe_annotation_members = get_args(type_)
|
|
186
|
+
is_annotated_union = is_annotated and is_union(get_origin(maybe_annotation_members[0]))
|
|
187
|
+
|
|
188
|
+
if base_type == typing.Any:
|
|
189
|
+
return object_
|
|
190
|
+
|
|
191
|
+
if base_type == dict:
|
|
192
|
+
if not isinstance(object_, typing.Mapping):
|
|
193
|
+
return object_
|
|
194
|
+
|
|
195
|
+
key_type, items_type = get_args(type_)
|
|
196
|
+
d = {
|
|
197
|
+
construct_type(object_=key, type_=key_type): construct_type(object_=item, type_=items_type)
|
|
198
|
+
for key, item in object_.items()
|
|
199
|
+
}
|
|
200
|
+
return d
|
|
201
|
+
|
|
202
|
+
if base_type == list:
|
|
203
|
+
if not isinstance(object_, list):
|
|
204
|
+
return object_
|
|
205
|
+
|
|
206
|
+
inner_type = get_args(type_)[0]
|
|
207
|
+
return [construct_type(object_=entry, type_=inner_type) for entry in object_]
|
|
208
|
+
|
|
209
|
+
if base_type == set:
|
|
210
|
+
if not isinstance(object_, set) and not isinstance(object_, list):
|
|
211
|
+
return object_
|
|
212
|
+
|
|
213
|
+
inner_type = get_args(type_)[0]
|
|
214
|
+
return {construct_type(object_=entry, type_=inner_type) for entry in object_}
|
|
215
|
+
|
|
216
|
+
if is_union(base_type) or is_annotated_union:
|
|
217
|
+
return _convert_union_type(type_, object_)
|
|
218
|
+
|
|
219
|
+
# Cannot do an `issubclass` with a literal type, let's also just confirm we have a class before this call
|
|
220
|
+
if (
|
|
221
|
+
object_ is not None
|
|
222
|
+
and not is_literal_type(type_)
|
|
223
|
+
and (
|
|
224
|
+
(inspect.isclass(base_type) and issubclass(base_type, pydantic.BaseModel))
|
|
225
|
+
or (
|
|
226
|
+
is_annotated
|
|
227
|
+
and inspect.isclass(maybe_annotation_members[0])
|
|
228
|
+
and issubclass(maybe_annotation_members[0], pydantic.BaseModel)
|
|
229
|
+
)
|
|
230
|
+
)
|
|
231
|
+
):
|
|
232
|
+
if IS_PYDANTIC_V2:
|
|
233
|
+
return type_.model_construct(**object_)
|
|
234
|
+
else:
|
|
235
|
+
return type_.construct(**object_)
|
|
236
|
+
|
|
237
|
+
if base_type == dt.datetime:
|
|
238
|
+
try:
|
|
239
|
+
return parse_datetime(object_)
|
|
240
|
+
except Exception:
|
|
241
|
+
return object_
|
|
242
|
+
|
|
243
|
+
if base_type == dt.date:
|
|
244
|
+
try:
|
|
245
|
+
return parse_date(object_)
|
|
246
|
+
except Exception:
|
|
247
|
+
return object_
|
|
248
|
+
|
|
249
|
+
if base_type == uuid.UUID:
|
|
250
|
+
try:
|
|
251
|
+
return uuid.UUID(object_)
|
|
252
|
+
except Exception:
|
|
253
|
+
return object_
|
|
254
|
+
|
|
255
|
+
if base_type == int:
|
|
256
|
+
try:
|
|
257
|
+
return int(object_)
|
|
258
|
+
except Exception:
|
|
259
|
+
return object_
|
|
260
|
+
|
|
261
|
+
if base_type == bool:
|
|
262
|
+
try:
|
|
263
|
+
if isinstance(object_, str):
|
|
264
|
+
stringified_object = object_.lower()
|
|
265
|
+
return stringified_object == "true" or stringified_object == "1"
|
|
266
|
+
|
|
267
|
+
return bool(object_)
|
|
268
|
+
except Exception:
|
|
269
|
+
return object_
|
|
270
|
+
|
|
271
|
+
return object_
|
|
272
|
+
|
|
273
|
+
|
|
274
|
+
def _get_is_populate_by_name(model: typing.Type["Model"]) -> bool:
|
|
275
|
+
if IS_PYDANTIC_V2:
|
|
276
|
+
return model.model_config.get("populate_by_name", False) # type: ignore # Pydantic v2
|
|
277
|
+
return model.__config__.allow_population_by_field_name # type: ignore # Pydantic v1
|
|
278
|
+
|
|
279
|
+
|
|
280
|
+
PydanticField = typing.Union[ModelField, pydantic.fields.FieldInfo]
|
|
281
|
+
|
|
282
|
+
|
|
283
|
+
# Pydantic V1 swapped the typing of __fields__'s values from ModelField to FieldInfo
|
|
284
|
+
# And so we try to handle both V1 cases, as well as V2 (FieldInfo from model.model_fields)
|
|
285
|
+
def _get_model_fields(
|
|
286
|
+
model: typing.Type["Model"],
|
|
287
|
+
) -> typing.Mapping[str, PydanticField]:
|
|
288
|
+
if IS_PYDANTIC_V2:
|
|
289
|
+
return model.model_fields # type: ignore # Pydantic v2
|
|
290
|
+
else:
|
|
291
|
+
return model.__fields__ # type: ignore # Pydantic v1
|
|
292
|
+
|
|
293
|
+
|
|
294
|
+
def _get_field_default(field: PydanticField) -> typing.Any:
|
|
295
|
+
try:
|
|
296
|
+
value = field.get_default() # type: ignore # Pydantic < v1.10.15
|
|
297
|
+
except:
|
|
298
|
+
value = field.default
|
|
299
|
+
if IS_PYDANTIC_V2:
|
|
300
|
+
from pydantic_core import PydanticUndefined
|
|
301
|
+
|
|
302
|
+
if value == PydanticUndefined:
|
|
303
|
+
return None
|
|
304
|
+
return value
|
|
305
|
+
return value
|
label_studio_sdk/environment.py
CHANGED
|
@@ -1,8 +1,17 @@
|
|
|
1
1
|
# This file was auto-generated by Fern from our API Definition.
|
|
2
2
|
|
|
3
3
|
from .bad_request_error import BadRequestError
|
|
4
|
+
from .forbidden_error import ForbiddenError
|
|
4
5
|
from .internal_server_error import InternalServerError
|
|
6
|
+
from .method_not_allowed_error import MethodNotAllowedError
|
|
5
7
|
from .not_found_error import NotFoundError
|
|
6
8
|
from .unauthorized_error import UnauthorizedError
|
|
7
9
|
|
|
8
|
-
__all__ = [
|
|
10
|
+
__all__ = [
|
|
11
|
+
"BadRequestError",
|
|
12
|
+
"ForbiddenError",
|
|
13
|
+
"InternalServerError",
|
|
14
|
+
"MethodNotAllowedError",
|
|
15
|
+
"NotFoundError",
|
|
16
|
+
"UnauthorizedError",
|
|
17
|
+
]
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
# This file was auto-generated by Fern from our API Definition.
|
|
2
|
+
|
|
3
|
+
from ..core.api_error import ApiError
|
|
4
|
+
import typing
|
|
5
|
+
|
|
6
|
+
|
|
7
|
+
class MethodNotAllowedError(ApiError):
|
|
8
|
+
def __init__(self, body: typing.Optional[typing.Any]):
|
|
9
|
+
super().__init__(status_code=405, body=body)
|
|
@@ -2,28 +2,5 @@
|
|
|
2
2
|
|
|
3
3
|
from .types import ExportStorageListTypesResponseItem
|
|
4
4
|
from . import azure, gcs, local, redis, s3, s3s
|
|
5
|
-
from .azure import AzureCreateResponse, AzureUpdateResponse
|
|
6
|
-
from .gcs import GcsCreateResponse, GcsUpdateResponse
|
|
7
|
-
from .local import LocalCreateResponse, LocalUpdateResponse
|
|
8
|
-
from .redis import RedisCreateResponse, RedisUpdateResponse
|
|
9
|
-
from .s3 import S3CreateResponse, S3UpdateResponse
|
|
10
5
|
|
|
11
|
-
__all__ = [
|
|
12
|
-
"AzureCreateResponse",
|
|
13
|
-
"AzureUpdateResponse",
|
|
14
|
-
"ExportStorageListTypesResponseItem",
|
|
15
|
-
"GcsCreateResponse",
|
|
16
|
-
"GcsUpdateResponse",
|
|
17
|
-
"LocalCreateResponse",
|
|
18
|
-
"LocalUpdateResponse",
|
|
19
|
-
"RedisCreateResponse",
|
|
20
|
-
"RedisUpdateResponse",
|
|
21
|
-
"S3CreateResponse",
|
|
22
|
-
"S3UpdateResponse",
|
|
23
|
-
"azure",
|
|
24
|
-
"gcs",
|
|
25
|
-
"local",
|
|
26
|
-
"redis",
|
|
27
|
-
"s3",
|
|
28
|
-
"s3s",
|
|
29
|
-
]
|
|
6
|
+
__all__ = ["ExportStorageListTypesResponseItem", "azure", "gcs", "local", "redis", "s3", "s3s"]
|