hatchet-sdk 0.47.0__py3-none-any.whl → 1.0.0__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.
- hatchet_sdk/__init__.py +25 -16
- hatchet_sdk/client.py +14 -39
- hatchet_sdk/clients/admin.py +203 -362
- hatchet_sdk/clients/dispatcher/action_listener.py +106 -84
- hatchet_sdk/clients/dispatcher/dispatcher.py +21 -21
- hatchet_sdk/clients/event_ts.py +23 -10
- hatchet_sdk/clients/events.py +96 -99
- hatchet_sdk/clients/rest/__init__.py +24 -0
- hatchet_sdk/clients/rest/api/__init__.py +2 -0
- hatchet_sdk/clients/rest/api/task_api.py +2174 -0
- hatchet_sdk/clients/rest/api/workflow_runs_api.py +638 -106
- hatchet_sdk/clients/rest/api_client.py +1 -1
- hatchet_sdk/clients/rest/configuration.py +8 -1
- hatchet_sdk/clients/rest/exceptions.py +21 -0
- hatchet_sdk/clients/rest/models/__init__.py +22 -0
- hatchet_sdk/clients/rest/models/tenant.py +4 -0
- hatchet_sdk/clients/rest/models/tenant_version.py +37 -0
- hatchet_sdk/clients/rest/models/update_tenant_request.py +7 -0
- hatchet_sdk/clients/rest/models/v1_cancel_task_request.py +104 -0
- hatchet_sdk/clients/rest/models/v1_dag_children.py +102 -0
- hatchet_sdk/clients/rest/models/v1_replay_task_request.py +104 -0
- hatchet_sdk/clients/rest/models/v1_task.py +174 -0
- hatchet_sdk/clients/rest/models/v1_task_event.py +118 -0
- hatchet_sdk/clients/rest/models/v1_task_event_list.py +110 -0
- hatchet_sdk/clients/rest/models/v1_task_event_type.py +55 -0
- hatchet_sdk/clients/rest/models/v1_task_filter.py +106 -0
- hatchet_sdk/clients/rest/models/v1_task_point_metric.py +92 -0
- hatchet_sdk/clients/rest/models/v1_task_point_metrics.py +100 -0
- hatchet_sdk/clients/rest/models/v1_task_run_metric.py +88 -0
- hatchet_sdk/clients/rest/models/v1_task_run_status.py +40 -0
- hatchet_sdk/clients/rest/models/v1_task_status.py +40 -0
- hatchet_sdk/clients/rest/models/v1_task_summary.py +212 -0
- hatchet_sdk/clients/rest/models/v1_task_summary_list.py +110 -0
- hatchet_sdk/clients/rest/models/v1_workflow_run.py +171 -0
- hatchet_sdk/clients/rest/models/v1_workflow_run_details.py +145 -0
- hatchet_sdk/clients/rest/models/v1_workflow_type.py +37 -0
- hatchet_sdk/clients/rest/models/workflow_run_shape_item_for_workflow_run_details.py +99 -0
- hatchet_sdk/clients/rest/rest.py +37 -26
- hatchet_sdk/clients/rest/tenacity_utils.py +1 -1
- hatchet_sdk/clients/rest_client.py +141 -116
- hatchet_sdk/clients/run_event_listener.py +66 -60
- hatchet_sdk/clients/workflow_listener.py +75 -66
- hatchet_sdk/config.py +117 -0
- hatchet_sdk/connection.py +27 -13
- hatchet_sdk/context/__init__.py +0 -1
- hatchet_sdk/context/context.py +118 -218
- hatchet_sdk/features/cron.py +43 -57
- hatchet_sdk/features/scheduled.py +60 -74
- hatchet_sdk/hatchet.py +192 -195
- hatchet_sdk/labels.py +4 -6
- hatchet_sdk/metadata.py +1 -1
- hatchet_sdk/opentelemetry/instrumentor.py +9 -5
- hatchet_sdk/rate_limit.py +9 -18
- hatchet_sdk/token.py +13 -9
- hatchet_sdk/utils/aio_utils.py +0 -40
- hatchet_sdk/utils/proto_enums.py +54 -0
- hatchet_sdk/utils/typing.py +9 -1
- hatchet_sdk/v0/__init__.py +251 -0
- hatchet_sdk/v0/client.py +119 -0
- hatchet_sdk/v0/clients/admin.py +541 -0
- hatchet_sdk/v0/clients/dispatcher/action_listener.py +422 -0
- hatchet_sdk/v0/clients/dispatcher/dispatcher.py +204 -0
- hatchet_sdk/v0/clients/event_ts.py +28 -0
- hatchet_sdk/v0/clients/events.py +182 -0
- hatchet_sdk/v0/clients/rest/__init__.py +307 -0
- hatchet_sdk/v0/clients/rest/api/__init__.py +19 -0
- hatchet_sdk/v0/clients/rest/api/api_token_api.py +858 -0
- hatchet_sdk/v0/clients/rest/api/default_api.py +2259 -0
- hatchet_sdk/v0/clients/rest/api/event_api.py +2548 -0
- hatchet_sdk/v0/clients/rest/api/github_api.py +331 -0
- hatchet_sdk/v0/clients/rest/api/healthcheck_api.py +483 -0
- hatchet_sdk/v0/clients/rest/api/log_api.py +449 -0
- hatchet_sdk/v0/clients/rest/api/metadata_api.py +728 -0
- hatchet_sdk/v0/clients/rest/api/rate_limits_api.py +423 -0
- hatchet_sdk/v0/clients/rest/api/slack_api.py +577 -0
- hatchet_sdk/v0/clients/rest/api/sns_api.py +872 -0
- hatchet_sdk/v0/clients/rest/api/step_run_api.py +2202 -0
- hatchet_sdk/v0/clients/rest/api/tenant_api.py +4430 -0
- hatchet_sdk/v0/clients/rest/api/user_api.py +2888 -0
- hatchet_sdk/v0/clients/rest/api/worker_api.py +858 -0
- hatchet_sdk/v0/clients/rest/api/workflow_api.py +6312 -0
- hatchet_sdk/v0/clients/rest/api/workflow_run_api.py +1932 -0
- hatchet_sdk/v0/clients/rest/api/workflow_runs_api.py +610 -0
- hatchet_sdk/v0/clients/rest/api_client.py +759 -0
- hatchet_sdk/v0/clients/rest/api_response.py +22 -0
- hatchet_sdk/v0/clients/rest/configuration.py +611 -0
- hatchet_sdk/v0/clients/rest/exceptions.py +200 -0
- hatchet_sdk/v0/clients/rest/models/__init__.py +274 -0
- hatchet_sdk/v0/clients/rest/models/accept_invite_request.py +83 -0
- hatchet_sdk/v0/clients/rest/models/api_error.py +102 -0
- hatchet_sdk/v0/clients/rest/models/api_errors.py +100 -0
- hatchet_sdk/v0/clients/rest/models/api_meta.py +144 -0
- hatchet_sdk/v0/clients/rest/models/api_meta_auth.py +85 -0
- hatchet_sdk/v0/clients/rest/models/api_meta_integration.py +88 -0
- hatchet_sdk/v0/clients/rest/models/api_meta_posthog.py +90 -0
- hatchet_sdk/v0/clients/rest/models/api_resource_meta.py +98 -0
- hatchet_sdk/v0/clients/rest/models/api_token.py +105 -0
- hatchet_sdk/v0/clients/rest/models/bulk_create_event_request.py +100 -0
- hatchet_sdk/v0/clients/rest/models/bulk_create_event_response.py +110 -0
- hatchet_sdk/v0/clients/rest/models/cancel_event_request.py +85 -0
- hatchet_sdk/v0/clients/rest/models/cancel_step_run_request.py +83 -0
- hatchet_sdk/v0/clients/rest/models/concurrency_limit_strategy.py +39 -0
- hatchet_sdk/v0/clients/rest/models/create_api_token_request.py +92 -0
- hatchet_sdk/v0/clients/rest/models/create_api_token_response.py +83 -0
- hatchet_sdk/v0/clients/rest/models/create_cron_workflow_trigger_request.py +98 -0
- hatchet_sdk/v0/clients/rest/models/create_event_request.py +95 -0
- hatchet_sdk/v0/clients/rest/models/create_pull_request_from_step_run.py +83 -0
- hatchet_sdk/v0/clients/rest/models/create_sns_integration_request.py +85 -0
- hatchet_sdk/v0/clients/rest/models/create_tenant_alert_email_group_request.py +83 -0
- hatchet_sdk/v0/clients/rest/models/create_tenant_invite_request.py +86 -0
- hatchet_sdk/v0/clients/rest/models/create_tenant_request.py +84 -0
- hatchet_sdk/v0/clients/rest/models/cron_workflows.py +131 -0
- hatchet_sdk/v0/clients/rest/models/cron_workflows_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/cron_workflows_method.py +37 -0
- hatchet_sdk/v0/clients/rest/models/cron_workflows_order_by_field.py +37 -0
- hatchet_sdk/v0/clients/rest/models/event.py +143 -0
- hatchet_sdk/v0/clients/rest/models/event_data.py +83 -0
- hatchet_sdk/v0/clients/rest/models/event_key_list.py +98 -0
- hatchet_sdk/v0/clients/rest/models/event_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/event_order_by_direction.py +37 -0
- hatchet_sdk/v0/clients/rest/models/event_order_by_field.py +36 -0
- hatchet_sdk/v0/clients/rest/models/event_update_cancel200_response.py +85 -0
- hatchet_sdk/v0/clients/rest/models/event_workflow_run_summary.py +116 -0
- hatchet_sdk/v0/clients/rest/models/events.py +110 -0
- hatchet_sdk/v0/clients/rest/models/get_step_run_diff_response.py +100 -0
- hatchet_sdk/v0/clients/rest/models/github_app_installation.py +107 -0
- hatchet_sdk/v0/clients/rest/models/github_branch.py +86 -0
- hatchet_sdk/v0/clients/rest/models/github_repo.py +86 -0
- hatchet_sdk/v0/clients/rest/models/info_get_version200_response.py +83 -0
- hatchet_sdk/v0/clients/rest/models/job.py +132 -0
- hatchet_sdk/v0/clients/rest/models/job_run.py +176 -0
- hatchet_sdk/v0/clients/rest/models/job_run_status.py +41 -0
- hatchet_sdk/v0/clients/rest/models/link_github_repository_request.py +106 -0
- hatchet_sdk/v0/clients/rest/models/list_api_tokens_response.py +110 -0
- hatchet_sdk/v0/clients/rest/models/list_github_app_installations_response.py +112 -0
- hatchet_sdk/v0/clients/rest/models/list_pull_requests_response.py +100 -0
- hatchet_sdk/v0/clients/rest/models/list_slack_webhooks.py +110 -0
- hatchet_sdk/v0/clients/rest/models/list_sns_integrations.py +110 -0
- hatchet_sdk/v0/clients/rest/models/log_line.py +94 -0
- hatchet_sdk/v0/clients/rest/models/log_line_level.py +39 -0
- hatchet_sdk/v0/clients/rest/models/log_line_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/log_line_order_by_direction.py +37 -0
- hatchet_sdk/v0/clients/rest/models/log_line_order_by_field.py +36 -0
- hatchet_sdk/v0/clients/rest/models/pagination_response.py +95 -0
- hatchet_sdk/v0/clients/rest/models/pull_request.py +112 -0
- hatchet_sdk/v0/clients/rest/models/pull_request_state.py +37 -0
- hatchet_sdk/v0/clients/rest/models/queue_metrics.py +97 -0
- hatchet_sdk/v0/clients/rest/models/rate_limit.py +117 -0
- hatchet_sdk/v0/clients/rest/models/rate_limit_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/rate_limit_order_by_direction.py +37 -0
- hatchet_sdk/v0/clients/rest/models/rate_limit_order_by_field.py +38 -0
- hatchet_sdk/v0/clients/rest/models/recent_step_runs.py +118 -0
- hatchet_sdk/v0/clients/rest/models/reject_invite_request.py +83 -0
- hatchet_sdk/v0/clients/rest/models/replay_event_request.py +85 -0
- hatchet_sdk/v0/clients/rest/models/replay_workflow_runs_request.py +85 -0
- hatchet_sdk/v0/clients/rest/models/replay_workflow_runs_response.py +100 -0
- hatchet_sdk/v0/clients/rest/models/rerun_step_run_request.py +83 -0
- hatchet_sdk/v0/clients/rest/models/schedule_workflow_run_request.py +92 -0
- hatchet_sdk/v0/clients/rest/models/scheduled_run_status.py +42 -0
- hatchet_sdk/v0/clients/rest/models/scheduled_workflows.py +149 -0
- hatchet_sdk/v0/clients/rest/models/scheduled_workflows_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/scheduled_workflows_method.py +37 -0
- hatchet_sdk/v0/clients/rest/models/scheduled_workflows_order_by_field.py +37 -0
- hatchet_sdk/v0/clients/rest/models/semaphore_slots.py +113 -0
- hatchet_sdk/v0/clients/rest/models/slack_webhook.py +127 -0
- hatchet_sdk/v0/clients/rest/models/sns_integration.py +114 -0
- hatchet_sdk/v0/clients/rest/models/step.py +123 -0
- hatchet_sdk/v0/clients/rest/models/step_run.py +202 -0
- hatchet_sdk/v0/clients/rest/models/step_run_archive.py +142 -0
- hatchet_sdk/v0/clients/rest/models/step_run_archive_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/step_run_diff.py +91 -0
- hatchet_sdk/v0/clients/rest/models/step_run_event.py +122 -0
- hatchet_sdk/v0/clients/rest/models/step_run_event_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/step_run_event_reason.py +52 -0
- hatchet_sdk/v0/clients/rest/models/step_run_event_severity.py +38 -0
- hatchet_sdk/v0/clients/rest/models/step_run_status.py +44 -0
- hatchet_sdk/v0/clients/rest/models/tenant.py +118 -0
- hatchet_sdk/v0/clients/rest/models/tenant_alert_email_group.py +98 -0
- hatchet_sdk/v0/clients/rest/models/tenant_alert_email_group_list.py +112 -0
- hatchet_sdk/v0/clients/rest/models/tenant_alerting_settings.py +143 -0
- hatchet_sdk/v0/clients/rest/models/tenant_invite.py +120 -0
- hatchet_sdk/v0/clients/rest/models/tenant_invite_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/tenant_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/tenant_member.py +123 -0
- hatchet_sdk/v0/clients/rest/models/tenant_member_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/tenant_member_role.py +38 -0
- hatchet_sdk/v0/clients/rest/models/tenant_queue_metrics.py +116 -0
- hatchet_sdk/v0/clients/rest/models/tenant_resource.py +40 -0
- hatchet_sdk/v0/clients/rest/models/tenant_resource_limit.py +135 -0
- hatchet_sdk/v0/clients/rest/models/tenant_resource_policy.py +102 -0
- hatchet_sdk/v0/clients/rest/models/tenant_step_run_queue_metrics.py +83 -0
- hatchet_sdk/v0/clients/rest/models/trigger_workflow_run_request.py +91 -0
- hatchet_sdk/v0/clients/rest/models/update_tenant_alert_email_group_request.py +83 -0
- hatchet_sdk/v0/clients/rest/models/update_tenant_invite_request.py +85 -0
- hatchet_sdk/v0/clients/rest/models/update_tenant_request.py +137 -0
- hatchet_sdk/v0/clients/rest/models/update_worker_request.py +87 -0
- hatchet_sdk/v0/clients/rest/models/user.py +126 -0
- hatchet_sdk/v0/clients/rest/models/user_change_password_request.py +88 -0
- hatchet_sdk/v0/clients/rest/models/user_login_request.py +86 -0
- hatchet_sdk/v0/clients/rest/models/user_register_request.py +91 -0
- hatchet_sdk/v0/clients/rest/models/user_tenant_memberships_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/user_tenant_public.py +86 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker.py +100 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker_create_request.py +94 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker_create_response.py +98 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker_created.py +102 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker_list_response.py +110 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker_request.py +102 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker_request_list_response.py +104 -0
- hatchet_sdk/v0/clients/rest/models/webhook_worker_request_method.py +38 -0
- hatchet_sdk/v0/clients/rest/models/worker.py +239 -0
- hatchet_sdk/v0/clients/rest/models/worker_label.py +102 -0
- hatchet_sdk/v0/clients/rest/models/worker_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/worker_runtime_info.py +103 -0
- hatchet_sdk/v0/clients/rest/models/worker_runtime_sdks.py +38 -0
- hatchet_sdk/v0/clients/rest/models/worker_type.py +38 -0
- hatchet_sdk/v0/clients/rest/models/workflow.py +165 -0
- hatchet_sdk/v0/clients/rest/models/workflow_concurrency.py +107 -0
- hatchet_sdk/v0/clients/rest/models/workflow_deployment_config.py +136 -0
- hatchet_sdk/v0/clients/rest/models/workflow_kind.py +38 -0
- hatchet_sdk/v0/clients/rest/models/workflow_list.py +120 -0
- hatchet_sdk/v0/clients/rest/models/workflow_metrics.py +97 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run.py +188 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run_cancel200_response.py +85 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run_list.py +110 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run_order_by_direction.py +37 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run_order_by_field.py +39 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run_shape.py +186 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run_status.py +42 -0
- hatchet_sdk/v0/clients/rest/models/workflow_run_triggered_by.py +112 -0
- hatchet_sdk/v0/clients/rest/models/workflow_runs_cancel_request.py +85 -0
- hatchet_sdk/v0/clients/rest/models/workflow_runs_metrics.py +94 -0
- hatchet_sdk/v0/clients/rest/models/workflow_runs_metrics_counts.py +104 -0
- hatchet_sdk/v0/clients/rest/models/workflow_tag.py +84 -0
- hatchet_sdk/v0/clients/rest/models/workflow_trigger_cron_ref.py +86 -0
- hatchet_sdk/v0/clients/rest/models/workflow_trigger_event_ref.py +86 -0
- hatchet_sdk/v0/clients/rest/models/workflow_triggers.py +141 -0
- hatchet_sdk/v0/clients/rest/models/workflow_update_request.py +85 -0
- hatchet_sdk/v0/clients/rest/models/workflow_version.py +170 -0
- hatchet_sdk/v0/clients/rest/models/workflow_version_concurrency.py +114 -0
- hatchet_sdk/v0/clients/rest/models/workflow_version_definition.py +85 -0
- hatchet_sdk/v0/clients/rest/models/workflow_version_meta.py +123 -0
- hatchet_sdk/v0/clients/rest/models/workflow_workers_count.py +95 -0
- hatchet_sdk/v0/clients/rest/rest.py +187 -0
- hatchet_sdk/v0/clients/rest/tenacity_utils.py +39 -0
- hatchet_sdk/v0/clients/rest_client.py +613 -0
- hatchet_sdk/v0/clients/run_event_listener.py +260 -0
- hatchet_sdk/v0/clients/workflow_listener.py +277 -0
- hatchet_sdk/v0/connection.py +63 -0
- hatchet_sdk/v0/context/__init__.py +1 -0
- hatchet_sdk/v0/context/context.py +446 -0
- hatchet_sdk/v0/context/worker_context.py +28 -0
- hatchet_sdk/v0/contracts/dispatcher_pb2.py +102 -0
- hatchet_sdk/v0/contracts/dispatcher_pb2.pyi +387 -0
- hatchet_sdk/v0/contracts/dispatcher_pb2_grpc.py +621 -0
- hatchet_sdk/v0/contracts/events_pb2.py +46 -0
- hatchet_sdk/v0/contracts/events_pb2.pyi +87 -0
- hatchet_sdk/v0/contracts/events_pb2_grpc.py +274 -0
- hatchet_sdk/v0/contracts/workflows_pb2.py +80 -0
- hatchet_sdk/v0/contracts/workflows_pb2.pyi +312 -0
- hatchet_sdk/v0/contracts/workflows_pb2_grpc.py +277 -0
- hatchet_sdk/v0/features/cron.py +286 -0
- hatchet_sdk/v0/features/scheduled.py +248 -0
- hatchet_sdk/v0/hatchet.py +310 -0
- hatchet_sdk/v0/labels.py +10 -0
- hatchet_sdk/v0/logger.py +13 -0
- hatchet_sdk/v0/metadata.py +2 -0
- hatchet_sdk/v0/opentelemetry/instrumentor.py +396 -0
- hatchet_sdk/v0/rate_limit.py +126 -0
- hatchet_sdk/v0/semver.py +30 -0
- hatchet_sdk/v0/token.py +27 -0
- hatchet_sdk/v0/utils/aio_utils.py +137 -0
- hatchet_sdk/v0/utils/backoff.py +9 -0
- hatchet_sdk/v0/utils/typing.py +12 -0
- hatchet_sdk/{v2 → v0/v2}/callable.py +8 -8
- hatchet_sdk/{v2 → v0/v2}/concurrency.py +2 -2
- hatchet_sdk/{v2 → v0/v2}/hatchet.py +10 -10
- hatchet_sdk/v0/worker/__init__.py +1 -0
- hatchet_sdk/v0/worker/action_listener_process.py +278 -0
- hatchet_sdk/v0/worker/runner/run_loop_manager.py +112 -0
- hatchet_sdk/v0/worker/runner/runner.py +460 -0
- hatchet_sdk/v0/worker/runner/utils/capture_logs.py +81 -0
- hatchet_sdk/v0/worker/runner/utils/error_with_traceback.py +6 -0
- hatchet_sdk/v0/worker/worker.py +391 -0
- hatchet_sdk/v0/workflow.py +261 -0
- hatchet_sdk/v0/workflow_run.py +59 -0
- hatchet_sdk/worker/__init__.py +0 -1
- hatchet_sdk/worker/action_listener_process.py +36 -33
- hatchet_sdk/worker/runner/run_loop_manager.py +18 -16
- hatchet_sdk/worker/runner/runner.py +32 -60
- hatchet_sdk/worker/runner/utils/capture_logs.py +25 -14
- hatchet_sdk/worker/runner/utils/error_with_traceback.py +1 -1
- hatchet_sdk/worker/worker.py +61 -75
- hatchet_sdk/workflow.py +473 -207
- hatchet_sdk/workflow_run.py +5 -18
- {hatchet_sdk-0.47.0.dist-info → hatchet_sdk-1.0.0.dist-info}/METADATA +2 -1
- hatchet_sdk-1.0.0.dist-info/RECORD +485 -0
- hatchet_sdk/utils/serialization.py +0 -18
- hatchet_sdk-0.47.0.dist-info/RECORD +0 -237
- /hatchet_sdk/{loader.py → v0/loader.py} +0 -0
- /hatchet_sdk/{utils → v0/utils}/types.py +0 -0
- {hatchet_sdk-0.47.0.dist-info → hatchet_sdk-1.0.0.dist-info}/WHEEL +0 -0
- {hatchet_sdk-0.47.0.dist-info → hatchet_sdk-1.0.0.dist-info}/entry_points.txt +0 -0
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
# coding: utf-8
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
Hatchet API
|
|
5
|
+
|
|
6
|
+
The Hatchet API
|
|
7
|
+
|
|
8
|
+
The version of the OpenAPI document: 1.0.0
|
|
9
|
+
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
|
10
|
+
|
|
11
|
+
Do not edit the class manually.
|
|
12
|
+
""" # noqa: E501
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
from __future__ import annotations
|
|
16
|
+
|
|
17
|
+
import json
|
|
18
|
+
import pprint
|
|
19
|
+
import re # noqa: F401
|
|
20
|
+
from datetime import datetime
|
|
21
|
+
from typing import Any, ClassVar, Dict, List, Optional, Set
|
|
22
|
+
|
|
23
|
+
from pydantic import BaseModel, ConfigDict, Field, StrictInt, StrictStr
|
|
24
|
+
from typing_extensions import Annotated, Self
|
|
25
|
+
|
|
26
|
+
from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta
|
|
27
|
+
from hatchet_sdk.clients.rest.models.v1_task_status import V1TaskStatus
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
class V1WorkflowRun(BaseModel):
|
|
31
|
+
"""
|
|
32
|
+
V1WorkflowRun
|
|
33
|
+
""" # noqa: E501
|
|
34
|
+
|
|
35
|
+
metadata: APIResourceMeta
|
|
36
|
+
status: V1TaskStatus
|
|
37
|
+
started_at: Optional[datetime] = Field(
|
|
38
|
+
default=None,
|
|
39
|
+
description="The timestamp the task run started.",
|
|
40
|
+
alias="startedAt",
|
|
41
|
+
)
|
|
42
|
+
finished_at: Optional[datetime] = Field(
|
|
43
|
+
default=None,
|
|
44
|
+
description="The timestamp the task run finished.",
|
|
45
|
+
alias="finishedAt",
|
|
46
|
+
)
|
|
47
|
+
duration: Optional[StrictInt] = Field(
|
|
48
|
+
default=None, description="The duration of the task run, in milliseconds."
|
|
49
|
+
)
|
|
50
|
+
tenant_id: Annotated[str, Field(min_length=36, strict=True, max_length=36)] = Field(
|
|
51
|
+
description="The ID of the tenant.", alias="tenantId"
|
|
52
|
+
)
|
|
53
|
+
additional_metadata: Optional[Dict[str, Any]] = Field(
|
|
54
|
+
default=None,
|
|
55
|
+
description="Additional metadata for the task run.",
|
|
56
|
+
alias="additionalMetadata",
|
|
57
|
+
)
|
|
58
|
+
display_name: StrictStr = Field(
|
|
59
|
+
description="The display name of the task run.", alias="displayName"
|
|
60
|
+
)
|
|
61
|
+
workflow_id: StrictStr = Field(alias="workflowId")
|
|
62
|
+
output: Dict[str, Any] = Field(
|
|
63
|
+
description="The output of the task run (for the latest run)"
|
|
64
|
+
)
|
|
65
|
+
error_message: Optional[StrictStr] = Field(
|
|
66
|
+
default=None,
|
|
67
|
+
description="The error message of the task run (for the latest run)",
|
|
68
|
+
alias="errorMessage",
|
|
69
|
+
)
|
|
70
|
+
workflow_version_id: Optional[StrictStr] = Field(
|
|
71
|
+
default=None,
|
|
72
|
+
description="The ID of the workflow version.",
|
|
73
|
+
alias="workflowVersionId",
|
|
74
|
+
)
|
|
75
|
+
input: Dict[str, Any] = Field(description="The input of the task run.")
|
|
76
|
+
created_at: Optional[datetime] = Field(
|
|
77
|
+
default=None,
|
|
78
|
+
description="The timestamp the task run was created.",
|
|
79
|
+
alias="createdAt",
|
|
80
|
+
)
|
|
81
|
+
__properties: ClassVar[List[str]] = [
|
|
82
|
+
"metadata",
|
|
83
|
+
"status",
|
|
84
|
+
"startedAt",
|
|
85
|
+
"finishedAt",
|
|
86
|
+
"duration",
|
|
87
|
+
"tenantId",
|
|
88
|
+
"additionalMetadata",
|
|
89
|
+
"displayName",
|
|
90
|
+
"workflowId",
|
|
91
|
+
"output",
|
|
92
|
+
"errorMessage",
|
|
93
|
+
"workflowVersionId",
|
|
94
|
+
"input",
|
|
95
|
+
"createdAt",
|
|
96
|
+
]
|
|
97
|
+
|
|
98
|
+
model_config = ConfigDict(
|
|
99
|
+
populate_by_name=True,
|
|
100
|
+
validate_assignment=True,
|
|
101
|
+
protected_namespaces=(),
|
|
102
|
+
)
|
|
103
|
+
|
|
104
|
+
def to_str(self) -> str:
|
|
105
|
+
"""Returns the string representation of the model using alias"""
|
|
106
|
+
return pprint.pformat(self.model_dump(by_alias=True))
|
|
107
|
+
|
|
108
|
+
def to_json(self) -> str:
|
|
109
|
+
"""Returns the JSON representation of the model using alias"""
|
|
110
|
+
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
|
|
111
|
+
return json.dumps(self.to_dict())
|
|
112
|
+
|
|
113
|
+
@classmethod
|
|
114
|
+
def from_json(cls, json_str: str) -> Optional[Self]:
|
|
115
|
+
"""Create an instance of V1WorkflowRun from a JSON string"""
|
|
116
|
+
return cls.from_dict(json.loads(json_str))
|
|
117
|
+
|
|
118
|
+
def to_dict(self) -> Dict[str, Any]:
|
|
119
|
+
"""Return the dictionary representation of the model using alias.
|
|
120
|
+
|
|
121
|
+
This has the following differences from calling pydantic's
|
|
122
|
+
`self.model_dump(by_alias=True)`:
|
|
123
|
+
|
|
124
|
+
* `None` is only added to the output dict for nullable fields that
|
|
125
|
+
were set at model initialization. Other fields with value `None`
|
|
126
|
+
are ignored.
|
|
127
|
+
"""
|
|
128
|
+
excluded_fields: Set[str] = set([])
|
|
129
|
+
|
|
130
|
+
_dict = self.model_dump(
|
|
131
|
+
by_alias=True,
|
|
132
|
+
exclude=excluded_fields,
|
|
133
|
+
exclude_none=True,
|
|
134
|
+
)
|
|
135
|
+
# override the default output from pydantic by calling `to_dict()` of metadata
|
|
136
|
+
if self.metadata:
|
|
137
|
+
_dict["metadata"] = self.metadata.to_dict()
|
|
138
|
+
return _dict
|
|
139
|
+
|
|
140
|
+
@classmethod
|
|
141
|
+
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
|
|
142
|
+
"""Create an instance of V1WorkflowRun from a dict"""
|
|
143
|
+
if obj is None:
|
|
144
|
+
return None
|
|
145
|
+
|
|
146
|
+
if not isinstance(obj, dict):
|
|
147
|
+
return cls.model_validate(obj)
|
|
148
|
+
|
|
149
|
+
_obj = cls.model_validate(
|
|
150
|
+
{
|
|
151
|
+
"metadata": (
|
|
152
|
+
APIResourceMeta.from_dict(obj["metadata"])
|
|
153
|
+
if obj.get("metadata") is not None
|
|
154
|
+
else None
|
|
155
|
+
),
|
|
156
|
+
"status": obj.get("status"),
|
|
157
|
+
"startedAt": obj.get("startedAt"),
|
|
158
|
+
"finishedAt": obj.get("finishedAt"),
|
|
159
|
+
"duration": obj.get("duration"),
|
|
160
|
+
"tenantId": obj.get("tenantId"),
|
|
161
|
+
"additionalMetadata": obj.get("additionalMetadata"),
|
|
162
|
+
"displayName": obj.get("displayName"),
|
|
163
|
+
"workflowId": obj.get("workflowId"),
|
|
164
|
+
"output": obj.get("output"),
|
|
165
|
+
"errorMessage": obj.get("errorMessage"),
|
|
166
|
+
"workflowVersionId": obj.get("workflowVersionId"),
|
|
167
|
+
"input": obj.get("input"),
|
|
168
|
+
"createdAt": obj.get("createdAt"),
|
|
169
|
+
}
|
|
170
|
+
)
|
|
171
|
+
return _obj
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
# coding: utf-8
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
Hatchet API
|
|
5
|
+
|
|
6
|
+
The Hatchet API
|
|
7
|
+
|
|
8
|
+
The version of the OpenAPI document: 1.0.0
|
|
9
|
+
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
|
10
|
+
|
|
11
|
+
Do not edit the class manually.
|
|
12
|
+
""" # noqa: E501
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
from __future__ import annotations
|
|
16
|
+
|
|
17
|
+
import json
|
|
18
|
+
import pprint
|
|
19
|
+
import re # noqa: F401
|
|
20
|
+
from typing import Any, ClassVar, Dict, List, Optional, Set
|
|
21
|
+
|
|
22
|
+
from pydantic import BaseModel, ConfigDict, Field
|
|
23
|
+
from typing_extensions import Self
|
|
24
|
+
|
|
25
|
+
from hatchet_sdk.clients.rest.models.v1_task_event import V1TaskEvent
|
|
26
|
+
from hatchet_sdk.clients.rest.models.v1_task_summary import V1TaskSummary
|
|
27
|
+
from hatchet_sdk.clients.rest.models.v1_workflow_run import V1WorkflowRun
|
|
28
|
+
from hatchet_sdk.clients.rest.models.workflow_run_shape_item_for_workflow_run_details import (
|
|
29
|
+
WorkflowRunShapeItemForWorkflowRunDetails,
|
|
30
|
+
)
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
class V1WorkflowRunDetails(BaseModel):
|
|
34
|
+
"""
|
|
35
|
+
V1WorkflowRunDetails
|
|
36
|
+
""" # noqa: E501
|
|
37
|
+
|
|
38
|
+
run: V1WorkflowRun
|
|
39
|
+
task_events: List[V1TaskEvent] = Field(
|
|
40
|
+
description="The list of task events for the workflow run", alias="taskEvents"
|
|
41
|
+
)
|
|
42
|
+
shape: List[WorkflowRunShapeItemForWorkflowRunDetails]
|
|
43
|
+
tasks: List[V1TaskSummary]
|
|
44
|
+
__properties: ClassVar[List[str]] = ["run", "taskEvents", "shape", "tasks"]
|
|
45
|
+
|
|
46
|
+
model_config = ConfigDict(
|
|
47
|
+
populate_by_name=True,
|
|
48
|
+
validate_assignment=True,
|
|
49
|
+
protected_namespaces=(),
|
|
50
|
+
)
|
|
51
|
+
|
|
52
|
+
def to_str(self) -> str:
|
|
53
|
+
"""Returns the string representation of the model using alias"""
|
|
54
|
+
return pprint.pformat(self.model_dump(by_alias=True))
|
|
55
|
+
|
|
56
|
+
def to_json(self) -> str:
|
|
57
|
+
"""Returns the JSON representation of the model using alias"""
|
|
58
|
+
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
|
|
59
|
+
return json.dumps(self.to_dict())
|
|
60
|
+
|
|
61
|
+
@classmethod
|
|
62
|
+
def from_json(cls, json_str: str) -> Optional[Self]:
|
|
63
|
+
"""Create an instance of V1WorkflowRunDetails from a JSON string"""
|
|
64
|
+
return cls.from_dict(json.loads(json_str))
|
|
65
|
+
|
|
66
|
+
def to_dict(self) -> Dict[str, Any]:
|
|
67
|
+
"""Return the dictionary representation of the model using alias.
|
|
68
|
+
|
|
69
|
+
This has the following differences from calling pydantic's
|
|
70
|
+
`self.model_dump(by_alias=True)`:
|
|
71
|
+
|
|
72
|
+
* `None` is only added to the output dict for nullable fields that
|
|
73
|
+
were set at model initialization. Other fields with value `None`
|
|
74
|
+
are ignored.
|
|
75
|
+
"""
|
|
76
|
+
excluded_fields: Set[str] = set([])
|
|
77
|
+
|
|
78
|
+
_dict = self.model_dump(
|
|
79
|
+
by_alias=True,
|
|
80
|
+
exclude=excluded_fields,
|
|
81
|
+
exclude_none=True,
|
|
82
|
+
)
|
|
83
|
+
# override the default output from pydantic by calling `to_dict()` of run
|
|
84
|
+
if self.run:
|
|
85
|
+
_dict["run"] = self.run.to_dict()
|
|
86
|
+
# override the default output from pydantic by calling `to_dict()` of each item in task_events (list)
|
|
87
|
+
_items = []
|
|
88
|
+
if self.task_events:
|
|
89
|
+
for _item_task_events in self.task_events:
|
|
90
|
+
if _item_task_events:
|
|
91
|
+
_items.append(_item_task_events.to_dict())
|
|
92
|
+
_dict["taskEvents"] = _items
|
|
93
|
+
# override the default output from pydantic by calling `to_dict()` of each item in shape (list)
|
|
94
|
+
_items = []
|
|
95
|
+
if self.shape:
|
|
96
|
+
for _item_shape in self.shape:
|
|
97
|
+
if _item_shape:
|
|
98
|
+
_items.append(_item_shape.to_dict())
|
|
99
|
+
_dict["shape"] = _items
|
|
100
|
+
# override the default output from pydantic by calling `to_dict()` of each item in tasks (list)
|
|
101
|
+
_items = []
|
|
102
|
+
if self.tasks:
|
|
103
|
+
for _item_tasks in self.tasks:
|
|
104
|
+
if _item_tasks:
|
|
105
|
+
_items.append(_item_tasks.to_dict())
|
|
106
|
+
_dict["tasks"] = _items
|
|
107
|
+
return _dict
|
|
108
|
+
|
|
109
|
+
@classmethod
|
|
110
|
+
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
|
|
111
|
+
"""Create an instance of V1WorkflowRunDetails from a dict"""
|
|
112
|
+
if obj is None:
|
|
113
|
+
return None
|
|
114
|
+
|
|
115
|
+
if not isinstance(obj, dict):
|
|
116
|
+
return cls.model_validate(obj)
|
|
117
|
+
|
|
118
|
+
_obj = cls.model_validate(
|
|
119
|
+
{
|
|
120
|
+
"run": (
|
|
121
|
+
V1WorkflowRun.from_dict(obj["run"])
|
|
122
|
+
if obj.get("run") is not None
|
|
123
|
+
else None
|
|
124
|
+
),
|
|
125
|
+
"taskEvents": (
|
|
126
|
+
[V1TaskEvent.from_dict(_item) for _item in obj["taskEvents"]]
|
|
127
|
+
if obj.get("taskEvents") is not None
|
|
128
|
+
else None
|
|
129
|
+
),
|
|
130
|
+
"shape": (
|
|
131
|
+
[
|
|
132
|
+
WorkflowRunShapeItemForWorkflowRunDetails.from_dict(_item)
|
|
133
|
+
for _item in obj["shape"]
|
|
134
|
+
]
|
|
135
|
+
if obj.get("shape") is not None
|
|
136
|
+
else None
|
|
137
|
+
),
|
|
138
|
+
"tasks": (
|
|
139
|
+
[V1TaskSummary.from_dict(_item) for _item in obj["tasks"]]
|
|
140
|
+
if obj.get("tasks") is not None
|
|
141
|
+
else None
|
|
142
|
+
),
|
|
143
|
+
}
|
|
144
|
+
)
|
|
145
|
+
return _obj
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
# coding: utf-8
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
Hatchet API
|
|
5
|
+
|
|
6
|
+
The Hatchet API
|
|
7
|
+
|
|
8
|
+
The version of the OpenAPI document: 1.0.0
|
|
9
|
+
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
|
10
|
+
|
|
11
|
+
Do not edit the class manually.
|
|
12
|
+
""" # noqa: E501
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
from __future__ import annotations
|
|
16
|
+
|
|
17
|
+
import json
|
|
18
|
+
from enum import Enum
|
|
19
|
+
|
|
20
|
+
from typing_extensions import Self
|
|
21
|
+
|
|
22
|
+
|
|
23
|
+
class V1WorkflowType(str, Enum):
|
|
24
|
+
"""
|
|
25
|
+
V1WorkflowType
|
|
26
|
+
"""
|
|
27
|
+
|
|
28
|
+
"""
|
|
29
|
+
allowed enum values
|
|
30
|
+
"""
|
|
31
|
+
DAG = "DAG"
|
|
32
|
+
TASK = "TASK"
|
|
33
|
+
|
|
34
|
+
@classmethod
|
|
35
|
+
def from_json(cls, json_str: str) -> Self:
|
|
36
|
+
"""Create an instance of V1WorkflowType from a JSON string"""
|
|
37
|
+
return cls(json.loads(json_str))
|
|
@@ -0,0 +1,99 @@
|
|
|
1
|
+
# coding: utf-8
|
|
2
|
+
|
|
3
|
+
"""
|
|
4
|
+
Hatchet API
|
|
5
|
+
|
|
6
|
+
The Hatchet API
|
|
7
|
+
|
|
8
|
+
The version of the OpenAPI document: 1.0.0
|
|
9
|
+
Generated by OpenAPI Generator (https://openapi-generator.tech)
|
|
10
|
+
|
|
11
|
+
Do not edit the class manually.
|
|
12
|
+
""" # noqa: E501
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+
from __future__ import annotations
|
|
16
|
+
|
|
17
|
+
import json
|
|
18
|
+
import pprint
|
|
19
|
+
import re # noqa: F401
|
|
20
|
+
from typing import Any, ClassVar, Dict, List, Optional, Set
|
|
21
|
+
|
|
22
|
+
from pydantic import BaseModel, ConfigDict, Field, StrictStr
|
|
23
|
+
from typing_extensions import Annotated, Self
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
class WorkflowRunShapeItemForWorkflowRunDetails(BaseModel):
|
|
27
|
+
"""
|
|
28
|
+
WorkflowRunShapeItemForWorkflowRunDetails
|
|
29
|
+
""" # noqa: E501
|
|
30
|
+
|
|
31
|
+
task_external_id: Annotated[
|
|
32
|
+
str, Field(min_length=36, strict=True, max_length=36)
|
|
33
|
+
] = Field(alias="taskExternalId")
|
|
34
|
+
children_external_ids: List[
|
|
35
|
+
Annotated[str, Field(min_length=36, strict=True, max_length=36)]
|
|
36
|
+
] = Field(alias="childrenExternalIds")
|
|
37
|
+
task_name: StrictStr = Field(alias="taskName")
|
|
38
|
+
__properties: ClassVar[List[str]] = [
|
|
39
|
+
"taskExternalId",
|
|
40
|
+
"childrenExternalIds",
|
|
41
|
+
"taskName",
|
|
42
|
+
]
|
|
43
|
+
|
|
44
|
+
model_config = ConfigDict(
|
|
45
|
+
populate_by_name=True,
|
|
46
|
+
validate_assignment=True,
|
|
47
|
+
protected_namespaces=(),
|
|
48
|
+
)
|
|
49
|
+
|
|
50
|
+
def to_str(self) -> str:
|
|
51
|
+
"""Returns the string representation of the model using alias"""
|
|
52
|
+
return pprint.pformat(self.model_dump(by_alias=True))
|
|
53
|
+
|
|
54
|
+
def to_json(self) -> str:
|
|
55
|
+
"""Returns the JSON representation of the model using alias"""
|
|
56
|
+
# TODO: pydantic v2: use .model_dump_json(by_alias=True, exclude_unset=True) instead
|
|
57
|
+
return json.dumps(self.to_dict())
|
|
58
|
+
|
|
59
|
+
@classmethod
|
|
60
|
+
def from_json(cls, json_str: str) -> Optional[Self]:
|
|
61
|
+
"""Create an instance of WorkflowRunShapeItemForWorkflowRunDetails from a JSON string"""
|
|
62
|
+
return cls.from_dict(json.loads(json_str))
|
|
63
|
+
|
|
64
|
+
def to_dict(self) -> Dict[str, Any]:
|
|
65
|
+
"""Return the dictionary representation of the model using alias.
|
|
66
|
+
|
|
67
|
+
This has the following differences from calling pydantic's
|
|
68
|
+
`self.model_dump(by_alias=True)`:
|
|
69
|
+
|
|
70
|
+
* `None` is only added to the output dict for nullable fields that
|
|
71
|
+
were set at model initialization. Other fields with value `None`
|
|
72
|
+
are ignored.
|
|
73
|
+
"""
|
|
74
|
+
excluded_fields: Set[str] = set([])
|
|
75
|
+
|
|
76
|
+
_dict = self.model_dump(
|
|
77
|
+
by_alias=True,
|
|
78
|
+
exclude=excluded_fields,
|
|
79
|
+
exclude_none=True,
|
|
80
|
+
)
|
|
81
|
+
return _dict
|
|
82
|
+
|
|
83
|
+
@classmethod
|
|
84
|
+
def from_dict(cls, obj: Optional[Dict[str, Any]]) -> Optional[Self]:
|
|
85
|
+
"""Create an instance of WorkflowRunShapeItemForWorkflowRunDetails from a dict"""
|
|
86
|
+
if obj is None:
|
|
87
|
+
return None
|
|
88
|
+
|
|
89
|
+
if not isinstance(obj, dict):
|
|
90
|
+
return cls.model_validate(obj)
|
|
91
|
+
|
|
92
|
+
_obj = cls.model_validate(
|
|
93
|
+
{
|
|
94
|
+
"taskExternalId": obj.get("taskExternalId"),
|
|
95
|
+
"childrenExternalIds": obj.get("childrenExternalIds"),
|
|
96
|
+
"taskName": obj.get("taskName"),
|
|
97
|
+
}
|
|
98
|
+
)
|
|
99
|
+
return _obj
|
hatchet_sdk/clients/rest/rest.py
CHANGED
|
@@ -55,40 +55,32 @@ class RESTClientObject:
|
|
|
55
55
|
def __init__(self, configuration) -> None:
|
|
56
56
|
|
|
57
57
|
# maxsize is number of requests to host that are allowed in parallel
|
|
58
|
-
maxsize = configuration.connection_pool_maxsize
|
|
58
|
+
self.maxsize = configuration.connection_pool_maxsize
|
|
59
59
|
|
|
60
|
-
ssl_context = ssl.create_default_context(
|
|
60
|
+
self.ssl_context = ssl.create_default_context(
|
|
61
|
+
cafile=configuration.ssl_ca_cert,
|
|
62
|
+
cadata=configuration.ca_cert_data,
|
|
63
|
+
)
|
|
61
64
|
if configuration.cert_file:
|
|
62
|
-
ssl_context.load_cert_chain(
|
|
65
|
+
self.ssl_context.load_cert_chain(
|
|
63
66
|
configuration.cert_file, keyfile=configuration.key_file
|
|
64
67
|
)
|
|
65
68
|
|
|
66
69
|
if not configuration.verify_ssl:
|
|
67
|
-
ssl_context.check_hostname = False
|
|
68
|
-
ssl_context.verify_mode = ssl.CERT_NONE
|
|
69
|
-
|
|
70
|
-
connector = aiohttp.TCPConnector(limit=maxsize, ssl=ssl_context)
|
|
70
|
+
self.ssl_context.check_hostname = False
|
|
71
|
+
self.ssl_context.verify_mode = ssl.CERT_NONE
|
|
71
72
|
|
|
72
73
|
self.proxy = configuration.proxy
|
|
73
74
|
self.proxy_headers = configuration.proxy_headers
|
|
74
75
|
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
self.retry_client: Optional[aiohttp_retry.RetryClient]
|
|
80
|
-
if retries is not None:
|
|
81
|
-
self.retry_client = aiohttp_retry.RetryClient(
|
|
82
|
-
client_session=self.pool_manager,
|
|
83
|
-
retry_options=aiohttp_retry.ExponentialRetry(
|
|
84
|
-
attempts=retries, factor=2.0, start_timeout=0.1, max_timeout=120.0
|
|
85
|
-
),
|
|
86
|
-
)
|
|
87
|
-
else:
|
|
88
|
-
self.retry_client = None
|
|
76
|
+
self.retries = configuration.retries
|
|
77
|
+
|
|
78
|
+
self.pool_manager: Optional[aiohttp.ClientSession] = None
|
|
79
|
+
self.retry_client: Optional[aiohttp_retry.RetryClient] = None
|
|
89
80
|
|
|
90
|
-
async def close(self):
|
|
91
|
-
|
|
81
|
+
async def close(self) -> None:
|
|
82
|
+
if self.pool_manager:
|
|
83
|
+
await self.pool_manager.close()
|
|
92
84
|
if self.retry_client is not None:
|
|
93
85
|
await self.retry_client.close()
|
|
94
86
|
|
|
@@ -177,10 +169,29 @@ class RESTClientObject:
|
|
|
177
169
|
raise ApiException(status=0, reason=msg)
|
|
178
170
|
|
|
179
171
|
pool_manager: Union[aiohttp.ClientSession, aiohttp_retry.RetryClient]
|
|
180
|
-
|
|
172
|
+
|
|
173
|
+
# https pool manager
|
|
174
|
+
if self.pool_manager is None:
|
|
175
|
+
self.pool_manager = aiohttp.ClientSession(
|
|
176
|
+
connector=aiohttp.TCPConnector(
|
|
177
|
+
limit=self.maxsize, ssl=self.ssl_context
|
|
178
|
+
),
|
|
179
|
+
trust_env=True,
|
|
180
|
+
)
|
|
181
|
+
pool_manager = self.pool_manager
|
|
182
|
+
|
|
183
|
+
if self.retries is not None and method in ALLOW_RETRY_METHODS:
|
|
184
|
+
if self.retry_client is None:
|
|
185
|
+
self.retry_client = aiohttp_retry.RetryClient(
|
|
186
|
+
client_session=self.pool_manager,
|
|
187
|
+
retry_options=aiohttp_retry.ExponentialRetry(
|
|
188
|
+
attempts=self.retries,
|
|
189
|
+
factor=2.0,
|
|
190
|
+
start_timeout=0.1,
|
|
191
|
+
max_timeout=120.0,
|
|
192
|
+
),
|
|
193
|
+
)
|
|
181
194
|
pool_manager = self.retry_client
|
|
182
|
-
else:
|
|
183
|
-
pool_manager = self.pool_manager
|
|
184
195
|
|
|
185
196
|
r = await pool_manager.request(**args)
|
|
186
197
|
|
|
@@ -27,7 +27,7 @@ def tenacity_alert_retry(retry_state: tenacity.RetryCallState) -> None:
|
|
|
27
27
|
)
|
|
28
28
|
|
|
29
29
|
|
|
30
|
-
def tenacity_should_retry(ex:
|
|
30
|
+
def tenacity_should_retry(ex: BaseException) -> bool:
|
|
31
31
|
if isinstance(ex, (grpc.aio.AioRpcError, grpc.RpcError)):
|
|
32
32
|
if ex.code() in [
|
|
33
33
|
grpc.StatusCode.UNIMPLEMENTED,
|