From c8a79aabf3edb4cec03fcc529fb42100a951abc4 Mon Sep 17 00:00:00 2001 From: Abhiuday Gupta <77210185+aeswibon@users.noreply.github.com> Date: Tue, 16 Apr 2024 23:49:21 +0530 Subject: [PATCH] chore(format): added pre-commit hooks and formatted files (#294) Co-authored-by: steebchen --- .github/workflows/app.yml | 4 +- .github/workflows/docs.yml | 4 +- .github/workflows/lint.yml | 6 +- .github/workflows/pre-release.yaml | 10 +- .github/workflows/publish-python-sdk.yaml | 2 +- .github/workflows/test.yml | 26 +- .pre-commit-config.yaml | 36 +- CONTRIBUTING.md | 2 +- Caddyfile | 2 +- Taskfile.yaml | 29 +- api/v1/server/oas/gen/codegen.yaml | 2 +- build/package/nginx.conf | 2 +- frontend/app/components.json | 2 +- frontend/app/src/index.css | 2 +- frontend/app/tailwind.config.js | 2 +- frontend/docs/pages/_meta.json | 2 +- frontend/docs/pages/blog/_alice.json | 2 +- frontend/docs/pages/blog/_fairness.json | 2 +- frontend/docs/pages/blog/_meta.json | 2 +- frontend/docs/pages/blog/_multi.json | 2 +- frontend/docs/pages/contributing/_meta.json | 2 +- .../home/features/concurrency/_meta.json | 2 +- .../docs/pages/home/quickstart/_meta.json | 2 +- frontend/docs/pages/launches/_meta.json | 2 +- frontend/docs/pages/sdks/_meta.json | 2 +- .../sdks/python-sdk/_api/_types/APIError.md | 2 - .../sdks/python-sdk/_api/_types/APIErrors.md | 2 - .../sdks/python-sdk/_api/_types/APIMeta.md | 2 - .../python-sdk/_api/_types/APIMetaAuth.md | 2 - .../_api/_types/APIMetaIntegration.md | 2 - .../python-sdk/_api/_types/APIResourceMeta.md | 2 - .../_api/_types/PaginationResponse.md | 2 - .../sdks/python-sdk/_api/_types/Workflow.md | 2 - .../python-sdk/_api/_types/WorkflowApi.md | 1 - .../_api/_types/WorkflowDeploymentConfig.md | 2 - .../python-sdk/_api/_types/WorkflowList.md | 2 - .../python-sdk/_api/_types/WorkflowRun.md | 2 - .../python-sdk/_api/_types/WorkflowRunApi.md | 1 - .../python-sdk/_api/_types/WorkflowRunList.md | 2 - .../_api/_types/WorkflowRunStatus.md | 2 - .../_api/_types/WorkflowRunTriggeredBy.md | 2 - .../python-sdk/_api/_types/WorkflowTag.md | 2 - .../_api/_types/WorkflowTriggerCronRef.md | 2 - .../_api/_types/WorkflowTriggerEventRef.md | 2 - .../_api/_types/WorkflowTriggers.md | 2 - .../python-sdk/_api/_types/WorkflowVersion.md | 2 - .../_api/_types/WorkflowVersionDefinition.md | 2 - .../_api/_types/WorkflowVersionMeta.md | 2 - .../docs/pages/sdks/python-sdk/_meta.json | 2 +- .../docs/pages/sdks/typescript-sdk/_meta.json | 2 +- .../pages/sdks/typescript-sdk/api/_meta.json | 2 +- frontend/docs/pages/self-hosting/_meta.json | 2 +- frontend/docs/postcss.config.js | 2 +- frontend/docs/styles/global.css | 2 +- frontend/docs/tailwind.config.js | 2 +- hack/dev/generate-dev-api-token.sh | 2 +- hack/dev/generate-local-encryption-keys.sh | 1 - hack/oas/generate-clients.sh | 2 +- nodemon.api.json | 2 +- nodemon.engine.json | 2 +- prisma/migrations/migration_lock.toml | 2 +- python-sdk/.gitignore | 2 +- python-sdk/examples/api/api.py | 5 +- python-sdk/examples/async/event_test.py | 10 +- python-sdk/examples/async/worker.py | 20 +- python-sdk/examples/cancellation/worker.py | 14 +- .../concurrency-limit-rr/event_test.py | 10 +- .../examples/concurrency-limit-rr/worker.py | 19 +- .../examples/concurrency-limit/event_test.py | 10 +- .../examples/concurrency-limit/worker.py | 11 +- python-sdk/examples/dag/event_test.py | 11 +- python-sdk/examples/dag/worker.py | 50 +- python-sdk/examples/delayed/event_test.py | 10 +- python-sdk/examples/delayed/worker.py | 23 +- python-sdk/examples/fanout/worker.py | 13 +- python-sdk/examples/logger/worker.py | 16 +- python-sdk/examples/manual_trigger/stream.py | 25 +- python-sdk/examples/manual_trigger/worker.py | 25 +- python-sdk/examples/rate_limit/event_test.py | 22 +- python-sdk/examples/rate_limit/worker.py | 13 +- python-sdk/examples/simple/event_test.py | 10 +- python-sdk/examples/simple/worker.py | 14 +- python-sdk/examples/timeout/event_test.py | 10 +- python-sdk/examples/timeout/worker.py | 11 +- python-sdk/hatchet_sdk/__init__.py | 103 +- python-sdk/hatchet_sdk/client.py | 45 +- python-sdk/hatchet_sdk/clients/admin.py | 86 +- python-sdk/hatchet_sdk/clients/dispatcher.py | 149 +- python-sdk/hatchet_sdk/clients/events.py | 28 +- python-sdk/hatchet_sdk/clients/listener.py | 76 +- .../hatchet_sdk/clients/rest/__init__.py | 112 +- .../hatchet_sdk/clients/rest/api/__init__.py | 3 +- .../clients/rest/api/api_token_api.py | 343 ++-- .../clients/rest/api/default_api.py | 295 +-- .../hatchet_sdk/clients/rest/api/event_api.py | 617 +++--- .../clients/rest/api/github_api.py | 668 ++++--- .../clients/rest/api/healthcheck_api.py | 142 +- .../hatchet_sdk/clients/rest/api/log_api.py | 230 ++- .../clients/rest/api/metadata_api.py | 158 +- .../hatchet_sdk/clients/rest/api/sns_api.py | 366 ++-- .../clients/rest/api/step_run_api.py | 555 +++--- .../clients/rest/api/tenant_api.py | 725 ++++--- .../hatchet_sdk/clients/rest/api/user_api.py | 946 ++++------ .../clients/rest/api/worker_api.py | 218 +-- .../clients/rest/api/workflow_api.py | 1680 +++++++++-------- .../clients/rest/api/workflow_run_api.py | 175 +- .../hatchet_sdk/clients/rest/api_client.py | 245 +-- .../hatchet_sdk/clients/rest/api_response.py | 11 +- .../hatchet_sdk/clients/rest/configuration.py | 202 +- .../hatchet_sdk/clients/rest/exceptions.py | 31 +- .../clients/rest/models/__init__.py | 95 +- .../rest/models/accept_invite_request.py | 23 +- .../clients/rest/models/api_error.py | 44 +- .../clients/rest/models/api_errors.py | 33 +- .../clients/rest/models/api_meta.py | 33 +- .../clients/rest/models/api_meta_auth.py | 24 +- .../rest/models/api_meta_integration.py | 27 +- .../clients/rest/models/api_resource_meta.py | 45 +- .../clients/rest/models/api_token.py | 48 +- .../rest/models/cancel_step_run_request.py | 20 +- .../rest/models/create_api_token_request.py | 27 +- .../rest/models/create_api_token_response.py | 20 +- .../create_pull_request_from_step_run.py | 20 +- .../models/create_sns_integration_request.py | 24 +- .../models/create_tenant_invite_request.py | 24 +- .../rest/models/create_tenant_request.py | 21 +- .../hatchet_sdk/clients/rest/models/event.py | 81 +- .../clients/rest/models/event_data.py | 20 +- .../clients/rest/models/event_key_list.py | 35 +- .../clients/rest/models/event_list.py | 41 +- .../rest/models/event_order_by_direction.py | 8 +- .../rest/models/event_order_by_field.py | 6 +- .../rest/models/event_workflow_run_summary.py | 60 +- .../rest/models/get_step_run_diff_response.py | 33 +- .../rest/models/github_app_installation.py | 46 +- .../clients/rest/models/github_branch.py | 23 +- .../clients/rest/models/github_repo.py | 23 +- .../hatchet_sdk/clients/rest/models/job.py | 69 +- .../clients/rest/models/job_run.py | 101 +- .../clients/rest/models/job_run_status.py | 14 +- .../models/link_github_repository_request.py | 56 +- .../rest/models/list_api_tokens_response.py | 41 +- .../list_github_app_installations_response.py | 45 +- .../models/list_pull_requests_response.py | 33 +- .../rest/models/list_sns_integrations.py | 41 +- .../clients/rest/models/log_line.py | 34 +- .../clients/rest/models/log_line_level.py | 12 +- .../clients/rest/models/log_line_list.py | 41 +- .../models/log_line_order_by_direction.py | 8 +- .../rest/models/log_line_order_by_field.py | 6 +- .../rest/models/pagination_response.py | 36 +- .../clients/rest/models/pull_request.py | 52 +- .../clients/rest/models/pull_request_state.py | 8 +- .../rest/models/reject_invite_request.py | 23 +- .../rest/models/replay_event_request.py | 27 +- .../rest/models/rerun_step_run_request.py | 20 +- .../clients/rest/models/sns_integration.py | 59 +- .../hatchet_sdk/clients/rest/models/step.py | 66 +- .../clients/rest/models/step_run.py | 137 +- .../clients/rest/models/step_run_diff.py | 28 +- .../clients/rest/models/step_run_status.py | 18 +- .../hatchet_sdk/clients/rest/models/tenant.py | 37 +- .../clients/rest/models/tenant_invite.py | 63 +- .../clients/rest/models/tenant_invite_list.py | 41 +- .../clients/rest/models/tenant_list.py | 41 +- .../clients/rest/models/tenant_member.py | 59 +- .../clients/rest/models/tenant_member_list.py | 41 +- .../clients/rest/models/tenant_member_role.py | 10 +- .../models/trigger_workflow_run_request.py | 20 +- .../models/update_tenant_invite_request.py | 23 +- .../hatchet_sdk/clients/rest/models/user.py | 64 +- .../models/user_change_password_request.py | 27 +- .../clients/rest/models/user_login_request.py | 23 +- .../rest/models/user_register_request.py | 28 +- .../models/user_tenant_memberships_list.py | 41 +- .../clients/rest/models/user_tenant_public.py | 25 +- .../hatchet_sdk/clients/rest/models/worker.py | 73 +- .../clients/rest/models/worker_list.py | 41 +- .../clients/rest/models/workflow.py | 105 +- .../rest/models/workflow_concurrency.py | 58 +- .../rest/models/workflow_deployment_config.py | 85 +- .../clients/rest/models/workflow_list.py | 49 +- .../clients/rest/models/workflow_metrics.py | 38 +- .../clients/rest/models/workflow_run.py | 114 +- .../clients/rest/models/workflow_run_list.py | 41 +- .../rest/models/workflow_run_status.py | 16 +- .../rest/models/workflow_run_triggered_by.py | 58 +- .../clients/rest/models/workflow_tag.py | 21 +- .../rest/models/workflow_trigger_cron_ref.py | 23 +- .../rest/models/workflow_trigger_event_ref.py | 23 +- .../clients/rest/models/workflow_triggers.py | 72 +- .../clients/rest/models/workflow_version.py | 83 +- .../models/workflow_version_concurrency.py | 58 +- .../models/workflow_version_definition.py | 24 +- .../rest/models/workflow_version_meta.py | 56 +- python-sdk/hatchet_sdk/clients/rest/rest.py | 64 +- python-sdk/hatchet_sdk/clients/rest_client.py | 28 +- python-sdk/hatchet_sdk/connection.py | 17 +- python-sdk/hatchet_sdk/context.py | 91 +- python-sdk/hatchet_sdk/hatchet.py | 71 +- python-sdk/hatchet_sdk/loader.py | 104 +- python-sdk/hatchet_sdk/logger.py | 1 + python-sdk/hatchet_sdk/metadata.py | 2 +- python-sdk/hatchet_sdk/rate_limit.py | 7 +- python-sdk/hatchet_sdk/semver.py | 6 +- python-sdk/hatchet_sdk/token.py | 15 +- python-sdk/hatchet_sdk/worker.py | 130 +- python-sdk/hatchet_sdk/workflow.py | 69 +- python-sdk/publish.sh | 2 +- python-sdk/pyproject.toml | 14 + 210 files changed, 6871 insertions(+), 5993 deletions(-) diff --git a/.github/workflows/app.yml b/.github/workflows/app.yml index 3ef4b8044..ba6c43e82 100644 --- a/.github/workflows/app.yml +++ b/.github/workflows/app.yml @@ -7,7 +7,7 @@ jobs: - name: Clone repository uses: actions/checkout@v4 - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false @@ -29,7 +29,7 @@ jobs: - name: Clone repository uses: actions/checkout@v4 - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false diff --git a/.github/workflows/docs.yml b/.github/workflows/docs.yml index 1381b5887..8c4f8feb6 100644 --- a/.github/workflows/docs.yml +++ b/.github/workflows/docs.yml @@ -7,7 +7,7 @@ jobs: - name: Clone repository uses: actions/checkout@v4 - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false @@ -29,7 +29,7 @@ jobs: - name: Clone repository uses: actions/checkout@v4 - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index e49470eea..63a92aa1a 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -14,7 +14,7 @@ jobs: with: go-version: "1.21" - - uses: actions/cache@v3 + - uses: actions/cache@v4 with: path: | ~/go/pkg/mod @@ -29,9 +29,9 @@ jobs: run: go run github.com/steebchen/prisma-client-go generate - name: golangci-lint - uses: golangci/golangci-lint-action@v3.2.0 + uses: golangci/golangci-lint-action@v4 with: - version: v1.55.0 + version: v1.57.1 args: --config .golangci.yml --timeout 5m --max-issues-per-linter 0 --max-same-issues 0 only-new-issues: true skip-cache: true diff --git a/.github/workflows/pre-release.yaml b/.github/workflows/pre-release.yaml index 43c4146f9..00ec66529 100644 --- a/.github/workflows/pre-release.yaml +++ b/.github/workflows/pre-release.yaml @@ -14,7 +14,7 @@ jobs: env: GITHUB_TAG: ${{ github.ref }} - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Login to GHCR id: login-ghcr run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin @@ -38,7 +38,7 @@ jobs: env: GITHUB_TAG: ${{ github.ref }} - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Login to GHCR id: login-ghcr run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin @@ -62,7 +62,7 @@ jobs: env: GITHUB_TAG: ${{ github.ref }} - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Login to GHCR id: login-ghcr run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin @@ -86,7 +86,7 @@ jobs: env: GITHUB_TAG: ${{ github.ref }} - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Login to GHCR id: login-ghcr run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin @@ -108,7 +108,7 @@ jobs: env: GITHUB_TAG: ${{ github.ref }} - name: Checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: Login to GHCR id: login-ghcr run: echo "${{ secrets.GITHUB_TOKEN }}" | docker login ghcr.io -u ${{ github.actor }} --password-stdin diff --git a/.github/workflows/publish-python-sdk.yaml b/.github/workflows/publish-python-sdk.yaml index 26ff7fa85..781c96a5f 100644 --- a/.github/workflows/publish-python-sdk.yaml +++ b/.github/workflows/publish-python-sdk.yaml @@ -11,7 +11,7 @@ jobs: uses: actions/checkout@v2 - name: Set up Python - uses: actions/setup-python@v2 + uses: actions/setup-python@v3 with: python-version: "3.x" diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 3f33f933f..11a5fad29 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml @@ -10,12 +10,12 @@ jobs: - uses: actions/checkout@v4 - name: Install Protoc - uses: arduino/setup-protoc@v2 + uses: arduino/setup-protoc@v3 with: version: "25.2" - name: Install Task - uses: arduino/setup-task@v1 + uses: arduino/setup-task@v2 - name: Setup Go uses: actions/setup-go@v5 @@ -23,7 +23,7 @@ jobs: go-version: "1.21" - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false @@ -54,7 +54,7 @@ jobs: - uses: actions/checkout@v4 - name: Install Protoc - uses: arduino/setup-protoc@v2 + uses: arduino/setup-protoc@v3 with: version: "25.1" @@ -81,12 +81,12 @@ jobs: - uses: actions/checkout@v4 - name: Install Protoc - uses: arduino/setup-protoc@v2 + uses: arduino/setup-protoc@v3 with: version: "25.1" - name: Install Task - uses: arduino/setup-task@v1 + uses: arduino/setup-task@v2 - name: Setup Go uses: actions/setup-go@v5 @@ -94,7 +94,7 @@ jobs: go-version: "1.21" - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false @@ -134,10 +134,10 @@ jobs: - uses: actions/checkout@v4 - name: Install Task - uses: arduino/setup-task@v1 + uses: arduino/setup-task@v2 - name: Install Protoc - uses: arduino/setup-protoc@v2 + uses: arduino/setup-protoc@v3 with: version: "25.1" @@ -147,7 +147,7 @@ jobs: go-version: "1.21" - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false @@ -223,10 +223,10 @@ jobs: - uses: actions/checkout@v4 - name: Install Task - uses: arduino/setup-task@v1 + uses: arduino/setup-task@v2 - name: Install Protoc - uses: arduino/setup-protoc@v2 + uses: arduino/setup-protoc@v3 with: version: "25.1" @@ -236,7 +236,7 @@ jobs: go-version: "1.21" - name: Setup pnpm - uses: pnpm/action-setup@v2 + uses: pnpm/action-setup@v3 with: version: 8 run_install: false diff --git a/.pre-commit-config.yaml b/.pre-commit-config.yaml index f120e642e..026fffda9 100644 --- a/.pre-commit-config.yaml +++ b/.pre-commit-config.yaml @@ -1,7 +1,33 @@ repos: - - repo: https://github.com/gitguardian/ggshield - rev: v1.23.0 + - repo: https://github.com/pre-commit/pre-commit-hooks + rev: v4.5.0 hooks: - - id: ggshield - language_version: python3 - stages: [commit] + - id: no-commit-to-branch + args: ["--branch=main"] + - id: check-merge-conflict + - id: mixed-line-ending + args: ["--fix=lf"] + - id: end-of-file-fixer + exclude: \.sql + - id: check-yaml + - repo: https://github.com/PyCQA/isort + rev: 5.13.2 + hooks: + - id: isort + additional_dependencies: ["isort[pyproject]"] + exclude: _pb2(_grpc)?\.py + types: + - python + - repo: https://github.com/psf/black + rev: 24.3.0 + hooks: + - id: black + args: ["--config=python-sdk/pyproject.toml"] + exclude: _pb2(_grpc)?\.py + types: + - python + - repo: https://github.com/golangci/golangci-lint + rev: v1.57.1 + hooks: + - id: golangci-lint + args: ["--config=.golangci.yml"] diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 0c30d089b..f66378ce8 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -110,4 +110,4 @@ export HATCHET_CLIENT_TOKEN="$(go run ./cmd/hatchet-admin token create --tenant- 2. Create or modify the required SQL queries in `./internal/repository/prisma/dbsqlc` 3. Add new queries files to `./internal/repository/prisma/dbsqlc/sqlc.yaml` 4. Create a new migration file with `task prisma-migrate` -5. Generate Go with `task generate-all` \ No newline at end of file +5. Generate Go with `task generate-all` diff --git a/Caddyfile b/Caddyfile index d4481cd7b..239af32fb 100644 --- a/Caddyfile +++ b/Caddyfile @@ -14,4 +14,4 @@ grpc.dev.hatchet-tools.com { tls internal reverse_proxy h2c://127.0.0.1:7070 -} \ No newline at end of file +} diff --git a/Taskfile.yaml b/Taskfile.yaml index 054d39555..38059cc48 100644 --- a/Taskfile.yaml +++ b/Taskfile.yaml @@ -3,16 +3,15 @@ version: "3" tasks: setup: cmds: - - | - task install-dependencies && - task generate-certs && - task set-env-db && - task prisma-migrate && - task generate-all && - task generate-local-encryption-keys && - task set-env-all && - task seed-dev && - task copy-ca-to-sdks + - task: install-dependencies + - task: generate-certs + - task: set-env-db + - task: prisma-migrate + - task: generate-all + - task: generate-local-encryption-key + - task: set-env-all + - task: seed-dev + - task: copy-ca-to-sdks set-env-db: cmds: - | @@ -88,6 +87,7 @@ tasks: - task: generate-go - task: generate-proto - task: generate-sqlc + - task: pre-commit-run install-dependencies: cmds: - go mod download @@ -157,3 +157,12 @@ tasks: copy-ca-to-sdks: cmds: - mkdir -p ./python-sdk/certs/ && cp ./hack/dev/certs/ca.cert ./python-sdk/certs/ + pre-commit-install: + cmds: + - pip install pre-commit + - pre-commit install + pre-commit-run: + deps: + - pre-commit-install + cmds: + - pre-commit run --all-files || pre-commit run --all-files diff --git a/api/v1/server/oas/gen/codegen.yaml b/api/v1/server/oas/gen/codegen.yaml index 40e182f03..cbccb604e 100644 --- a/api/v1/server/oas/gen/codegen.yaml +++ b/api/v1/server/oas/gen/codegen.yaml @@ -232,4 +232,4 @@ output-options: } return nil } - {{end}} \ No newline at end of file + {{end}} diff --git a/build/package/nginx.conf b/build/package/nginx.conf index 246fc3a3a..8ab39967f 100644 --- a/build/package/nginx.conf +++ b/build/package/nginx.conf @@ -13,4 +13,4 @@ http { try_files $uri /index.html; } } -} \ No newline at end of file +} diff --git a/frontend/app/components.json b/frontend/app/components.json index 88a9a6e0e..1cd599c2c 100644 --- a/frontend/app/components.json +++ b/frontend/app/components.json @@ -13,4 +13,4 @@ "components": "@/components", "utils": "@/lib/utils" } -} \ No newline at end of file +} diff --git a/frontend/app/src/index.css b/frontend/app/src/index.css index 6a80f292d..c53208f10 100644 --- a/frontend/app/src/index.css +++ b/frontend/app/src/index.css @@ -235,4 +235,4 @@ body { .rjsf textarea{ @apply flex h-20 w-full rounded-md border border-input bg-transparent px-3 py-2 text-sm ring-offset-background file:border-0 file:bg-transparent file:text-sm file:font-medium placeholder:text-muted-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:cursor-not-allowed disabled:opacity-50; } -/* END rjsf JSON Schema Form style hack */ \ No newline at end of file +/* END rjsf JSON Schema Form style hack */ diff --git a/frontend/app/tailwind.config.js b/frontend/app/tailwind.config.js index cf7fe02de..dee62e25a 100644 --- a/frontend/app/tailwind.config.js +++ b/frontend/app/tailwind.config.js @@ -136,4 +136,4 @@ module.exports = { }, }, plugins: [require("tailwindcss-animate")], -} \ No newline at end of file +} diff --git a/frontend/docs/pages/_meta.json b/frontend/docs/pages/_meta.json index 00de5c1f5..3235d8dd0 100644 --- a/frontend/docs/pages/_meta.json +++ b/frontend/docs/pages/_meta.json @@ -25,4 +25,4 @@ "display": "hidden", "type": "page" } -} \ No newline at end of file +} diff --git a/frontend/docs/pages/blog/_alice.json b/frontend/docs/pages/blog/_alice.json index e08937e00..c9f3c6279 100644 --- a/frontend/docs/pages/blog/_alice.json +++ b/frontend/docs/pages/blog/_alice.json @@ -1 +1 @@ -{"assets":[{"id":"FcRGxR1DAk6L5FB4ij6KO","layers":[{"ddd":0,"ind":2,"ty":4,"nm":"","ln":"va6HDrHI5HXXzypIhy3yW2","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[2,24]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"Bu9lAGfZul51C34BG8pFv","layers":[{"ddd":0,"ind":6,"ty":4,"nm":"","ln":"RTZ1hCGQ7G5N06kk7HS-k6","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50009.01,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.89,0.18],[4.89,0.18],[2.71,-0.38],[1.31,-1.95],[0.82,-4.3],[0.82,-4.3],[1.31,-6.66],[2.68,-8.26],[4.75,-8.84],[4.75,-8.84],[6.1,-8.61],[7.31,-7.88],[8.18,-6.53],[8.5,-4.48],[8.5,-4.48],[8.5,-3.91],[1.77,-3.91],[1.77,-5.07],[7.14,-5.07],[6.84,-6.39],[6.01,-7.3],[4.75,-7.64],[4.75,-7.64],[3.37,-7.24],[2.47,-6.22],[2.16,-4.86],[2.16,-4.86],[2.16,-4.09],[2.5,-2.42],[3.46,-1.38],[4.89,-1.02],[4.89,-1.02],[5.84,-1.17],[6.59,-1.63],[7.07,-2.39],[7.07,-2.39],[8.36,-2.02],[7.68,-0.87],[6.48,-0.09],[4.89,0.18]],"i":[[0,0],[0,0],[0.61,0.37],[0.33,0.67],[0,0.9],[0,0],[-0.33,0.68],[-0.59,0.38],[-0.79,0],[0,0],[-0.45,-0.15],[-0.37,-0.34],[-0.22,-0.56],[0,-0.81],[0,0],[0,0],[0,0],[0,0],[0,0],[0.2,0.39],[0.36,0.22],[0.49,0],[0,0],[0.39,-0.27],[0.21,-0.42],[0,-0.49],[0,0],[0,0],[-0.23,-0.45],[-0.41,-0.23],[-0.55,0],[0,0],[-0.29,0.1],[-0.21,0.21],[-0.11,0.31],[0,0],[0,0],[0.32,-0.33],[0.47,-0.19],[0.59,0]],"o":[[0,0],[-0.84,0],[-0.61,-0.37],[-0.33,-0.67],[0,0],[0,-0.89],[0.33,-0.69],[0.59,-0.39],[0,0],[0.45,0],[0.44,0.15],[0.36,0.34],[0.21,0.55],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.49],[-0.19,-0.39],[-0.35,-0.23],[0,0],[-0.53,0],[-0.39,0.26],[-0.21,0.42],[0,0],[0,0],[0,0.66],[0.23,0.46],[0.41,0.24],[0,0],[0.35,0],[0.29,-0.1],[0.21,-0.2],[0,0],[0,0],[-0.13,0.44],[-0.33,0.33],[-0.47,0.18],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":7,"ty":4,"nm":"","ln":"1IVtWDl9h6BXi0p-ZynCi7","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000.08,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.77,0.18],[4.77,0.18],[2.66,-0.4],[1.3,-1.99],[0.82,-4.32],[0.82,-4.32],[1.31,-6.67],[2.68,-8.26],[4.75,-8.84],[4.75,-8.84],[6.41,-8.5],[7.62,-7.55],[8.2,-6.11],[8.2,-6.11],[6.86,-6.11],[6.18,-7.17],[4.77,-7.64],[4.77,-7.64],[3.4,-7.23],[2.49,-6.09],[2.16,-4.36],[2.16,-4.36],[2.48,-2.6],[3.39,-1.44],[4.77,-1.02],[4.77,-1.02],[5.72,-1.2],[6.44,-1.73],[6.86,-2.55],[6.86,-2.55],[8.2,-2.55],[7.64,-1.16],[6.47,-0.18],[4.77,0.18]],"i":[[0,0],[0,0],[0.59,0.39],[0.31,0.67],[0,0.87],[0,0],[-0.33,0.68],[-0.59,0.38],[-0.79,0],[0,0],[-0.49,-0.23],[-0.31,-0.41],[-0.07,-0.55],[0,0],[0,0],[0.35,0.31],[0.59,0],[0,0],[0.39,-0.27],[0.21,-0.49],[0,-0.66],[0,0],[-0.21,-0.5],[-0.39,-0.27],[-0.53,0],[0,0],[-0.28,0.12],[-0.19,0.23],[-0.08,0.32],[0,0],[0,0],[0.3,-0.41],[0.49,-0.24],[0.65,0]],"o":[[0,0],[-0.81,0],[-0.59,-0.39],[-0.32,-0.68],[0,0],[0,-0.89],[0.33,-0.68],[0.59,-0.39],[0,0],[0.61,0],[0.49,0.23],[0.31,0.41],[0,0],[0,0],[-0.1,-0.4],[-0.35,-0.31],[0,0],[-0.52,0],[-0.39,0.27],[-0.22,0.49],[0,0],[0,0.67],[0.21,0.5],[0.39,0.28],[0,0],[0.35,0],[0.29,-0.13],[0.2,-0.23],[0,0],[0,0],[-0.07,0.52],[-0.29,0.41],[-0.49,0.24],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":8,"ty":4,"nm":"","ln":"c04wlcjZMJmNcq3aZ2kcn8","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49996.28,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.57,0],[1.23,0],[1.23,-8.73],[2.57,-8.73],[2.57,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[1.91,-10.18],[1.91,-10.18],[1.24,-10.45],[0.95,-11.09],[0.95,-11.09],[1.24,-11.73],[1.91,-12],[1.91,-12],[2.58,-11.73],[2.86,-11.09],[2.86,-11.09],[2.58,-10.45],[1.91,-10.18]],"i":[[0,0],[0,0],[0.19,0.18],[0,0.25],[0,0],[-0.19,0.17],[-0.26,0],[0,0],[-0.19,-0.18],[0,-0.25],[0,0],[0.19,-0.18],[0.26,0]],"o":[[0,0],[-0.26,0],[-0.19,-0.18],[0,0],[0,-0.25],[0.19,-0.18],[0,0],[0.26,0],[0.19,0.17],[0,0],[0,0.25],[-0.19,0.18],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":9,"ty":4,"nm":"","ln":"VWQy3OFIVV6tU8XAsssDA9","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49992.49,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[1.23,-11.64],[2.57,-11.64],[2.57,0],[1.23,0],[1.23,-11.64]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":10,"ty":4,"nm":"","ln":"VVDhN1Y2oOY06IS43W9ED10","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49981.67,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.36,-9.8],[1.89,0],[0.41,0],[4.68,-11.64],[6.14,-11.64],[10.41,0],[8.93,0],[5.45,-9.8],[5.36,-9.8]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[2.43,-3.3],[2.43,-4.55],[8.39,-4.55],[8.39,-3.3],[2.43,-3.3]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"DxhxD9PQHBnUe3yoljZPB","layers":[{"ddd":0,"ind":5,"ty":0,"nm":"","ln":"precomp_igACupoF-ncuD69aX-Gmf5","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Bu9lAGfZul51C34BG8pFv"}]},{"id":"LngS0iiQ16cdJYvpEDGzR","layers":[{"ddd":0,"ind":4,"ty":0,"nm":"","ln":"precomp_KayBkv_NAJSAKvocgXYlt4","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DxhxD9PQHBnUe3yoljZPB"}]},{"id":"9eqIldDJSpsMHinmcH1Pz","layers":[]},{"h":45,"id":"ABpWvxb3H4Ah0xEJxFeMZ","p":"","u":"","w":45,"e":1},{"id":"IM_KzPMd7XTh1TMf4koUv","layers":[{"ddd":0,"ind":15,"ty":2,"nm":"","ln":"ABpWvxb3H4Ah0xEJxFeMZ15","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"ABpWvxb3H4Ah0xEJxFeMZ"}]},{"id":"dlkreuHch_bNNpzQXYsKr","layers":[{"ddd":0,"ind":17,"ty":4,"nm":"","ln":"i7rCLxzkJeppFw9OqE-zb17","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"PMbVCO64q3dokM8KGG2BQ","layers":[{"ddd":0,"ind":16,"ty":0,"nm":"","td":1,"ln":"precomp_61rWE5SDlBxclhXRjf4J616","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"dlkreuHch_bNNpzQXYsKr"},{"ddd":0,"ind":14,"ty":0,"nm":"","tt":1,"ln":"precomp_GZDYzgBhFiSSgyj-IFTiB14","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"IM_KzPMd7XTh1TMf4koUv"}]},{"id":"itDYL43jT4MTF3JS5ZB1_","layers":[]},{"id":"WDm-Z1SWjUBbfPFilqnNZ","layers":[]},{"id":"1NdNgVBQJQuQHk4FTmSTr","layers":[{"ddd":0,"ind":12,"ty":0,"nm":"","ln":"precomp_OpoNZv1uQe8hjon3sIL_S12","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"9eqIldDJSpsMHinmcH1Pz"},{"ddd":0,"ind":13,"ty":0,"nm":"","ln":"precomp_GZDYzgBhFiSSgyj-IFTiB13","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"PMbVCO64q3dokM8KGG2BQ"},{"ddd":0,"ind":18,"ty":0,"nm":"","ln":"precomp_8JDwyVAXZ8W1R6yYV2hJk18","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"itDYL43jT4MTF3JS5ZB1_"},{"ddd":0,"ind":19,"ty":0,"nm":"","ln":"precomp_uTDVCr4PEs5OYebnU5lKj19","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WDm-Z1SWjUBbfPFilqnNZ"}]},{"id":"DU7g2yhUE0PpExuIDbBGI","layers":[]},{"h":45,"id":"9UZ8UmY8_mtSeJrrLuPDI","p":"","u":"","w":45,"e":1},{"id":"QXE7P3588rInsXO0v43l3","layers":[{"ddd":0,"ind":24,"ty":2,"nm":"","ln":"9UZ8UmY8_mtSeJrrLuPDI24","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"9UZ8UmY8_mtSeJrrLuPDI"}]},{"id":"q0Dz2qVgGfYqrpQzXg68w","layers":[{"ddd":0,"ind":26,"ty":4,"nm":"","ln":"c-gyEaIpekO9DNJk0b6x426","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"1ztGx24jm6NzN7qcjtA2A","layers":[{"ddd":0,"ind":25,"ty":0,"nm":"","td":1,"ln":"precomp_Fy1bdQP0yhcTpAylo05Jj25","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"q0Dz2qVgGfYqrpQzXg68w"},{"ddd":0,"ind":23,"ty":0,"nm":"","tt":1,"ln":"precomp_MrlxTbD66le6pjI4SHAmg23","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"QXE7P3588rInsXO0v43l3"}]},{"id":"ifAWb0ku1lefJhMUTh9-J","layers":[]},{"id":"yh2KibH-KypKEaG41uC6c","layers":[]},{"id":"m9dH0F5MwXsLDDQSBUxbN","layers":[{"ddd":0,"ind":21,"ty":0,"nm":"","ln":"precomp_l2QfvfP6S1ZzRmXtfgmwq21","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DU7g2yhUE0PpExuIDbBGI"},{"ddd":0,"ind":22,"ty":0,"nm":"","ln":"precomp_MrlxTbD66le6pjI4SHAmg22","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1ztGx24jm6NzN7qcjtA2A"},{"ddd":0,"ind":27,"ty":0,"nm":"","ln":"precomp_-eQs8MTFpV0a_h1KSbX0627","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"ifAWb0ku1lefJhMUTh9-J"},{"ddd":0,"ind":28,"ty":0,"nm":"","ln":"precomp_Pudi5DjjmGbRsMXVSeS3S28","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"yh2KibH-KypKEaG41uC6c"}]},{"id":"W45MbEl9H7jLwD9mU0X6_","layers":[]},{"h":45,"id":"Jm735z3alknEn5lntdxS6","p":"","u":"","w":45,"e":1},{"id":"Xv41nvJCPKiIrCctfzEBs","layers":[{"ddd":0,"ind":33,"ty":2,"nm":"","ln":"Jm735z3alknEn5lntdxS633","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"Jm735z3alknEn5lntdxS6"}]},{"id":"-FPjwkQSa5OpMd0VlPg8W","layers":[{"ddd":0,"ind":35,"ty":4,"nm":"","ln":"CoGm9Wqkt3sRZPpRBQ5Oq35","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"cLXNodzVkXSsDlSixYOOH","layers":[{"ddd":0,"ind":34,"ty":0,"nm":"","td":1,"ln":"precomp_aQTseLvBk1qnwKeQ5hGjN34","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"-FPjwkQSa5OpMd0VlPg8W"},{"ddd":0,"ind":32,"ty":0,"nm":"","tt":1,"ln":"precomp_t95vO0oTmMDKkJyuIbdre32","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Xv41nvJCPKiIrCctfzEBs"}]},{"id":"WGAc3unn49i1X_sP6DJzb","layers":[]},{"id":"hOcBg6WrhGWjvLQ2hfSPP","layers":[]},{"id":"0gYS5jhAGIs7crB8QrUz2","layers":[{"ddd":0,"ind":30,"ty":0,"nm":"","ln":"precomp_gdbOBvvViMAY0saAr9BZp30","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"W45MbEl9H7jLwD9mU0X6_"},{"ddd":0,"ind":31,"ty":0,"nm":"","ln":"precomp_t95vO0oTmMDKkJyuIbdre31","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"cLXNodzVkXSsDlSixYOOH"},{"ddd":0,"ind":36,"ty":0,"nm":"","ln":"precomp_RfDd4rmVgmJyxj0mb5wEN36","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WGAc3unn49i1X_sP6DJzb"},{"ddd":0,"ind":37,"ty":0,"nm":"","ln":"precomp_1l5U5Xi9kUS3sWCtzTudP37","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"hOcBg6WrhGWjvLQ2hfSPP"}]},{"id":"Y3OtUUAm82LRhIBtdFQ2e","layers":[]},{"h":45,"id":"dC55gwtCj2mDruyZNTnJp","p":"","u":"","w":45,"e":1},{"id":"7tf_EB3oA-gN0bEJIcz6k","layers":[{"ddd":0,"ind":42,"ty":2,"nm":"","ln":"dC55gwtCj2mDruyZNTnJp42","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"dC55gwtCj2mDruyZNTnJp"}]},{"id":"tjX1Ci0HNdCrdAAWwxlpR","layers":[{"ddd":0,"ind":44,"ty":4,"nm":"","ln":"vMODVCBbSPqYKc1Xky-2A44","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"_4pY2FZwsa3bNGETt9MdU","layers":[{"ddd":0,"ind":43,"ty":0,"nm":"","td":1,"ln":"precomp_aZOWBUUvSoGWrH0Ctf9wG43","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"tjX1Ci0HNdCrdAAWwxlpR"},{"ddd":0,"ind":41,"ty":0,"nm":"","tt":1,"ln":"precomp_sFNc3UEW21KwfCa2cHoLd41","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7tf_EB3oA-gN0bEJIcz6k"}]},{"id":"pPBlv5PmDw7NlYGuONgpx","layers":[]},{"id":"tDsioldGoBkvTQ4PKAVLL","layers":[]},{"id":"J1B0qVspRM_3bvXSjoLp0","layers":[{"ddd":0,"ind":39,"ty":0,"nm":"","ln":"precomp_aG01j4T59Lowhabf28VI439","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Y3OtUUAm82LRhIBtdFQ2e"},{"ddd":0,"ind":40,"ty":0,"nm":"","ln":"precomp_sFNc3UEW21KwfCa2cHoLd40","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_4pY2FZwsa3bNGETt9MdU"},{"ddd":0,"ind":45,"ty":0,"nm":"","ln":"precomp_kI8LfSm5UV9rVR2-3jK_u45","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"pPBlv5PmDw7NlYGuONgpx"},{"ddd":0,"ind":46,"ty":0,"nm":"","ln":"precomp_qA5Czaceu-xnZ6nZZeB5_46","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"tDsioldGoBkvTQ4PKAVLL"}]},{"id":"0jidQ1Pf1dzayoEQS9Tj6","layers":[]},{"h":45,"id":"YzbrT6xb53YGIN4wK60XH","p":"","u":"","w":45,"e":1},{"id":"Vp-UaGN-O-UoLlEjkHRIA","layers":[{"ddd":0,"ind":51,"ty":2,"nm":"","ln":"YzbrT6xb53YGIN4wK60XH51","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"YzbrT6xb53YGIN4wK60XH"}]},{"id":"o2QQYShkbWSG_G2DJ_KZg","layers":[{"ddd":0,"ind":53,"ty":4,"nm":"","ln":"VgDrIgD6hS-huxHTezpep53","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"gwp_wmRVfWlDDQxd1MRcb","layers":[{"ddd":0,"ind":52,"ty":0,"nm":"","td":1,"ln":"precomp_TGhzUSPLQFbajKqksVQt952","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"o2QQYShkbWSG_G2DJ_KZg"},{"ddd":0,"ind":50,"ty":0,"nm":"","tt":1,"ln":"precomp_fvWkWuqsI-lKC9kYt3GJq50","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Vp-UaGN-O-UoLlEjkHRIA"}]},{"id":"f7LcMMGmkX4wUrKOuBt0x","layers":[]},{"id":"xChQfUdYh69G7igoU8G3t","layers":[]},{"id":"qrJiCHr7n5E_Ea20SXw_6","layers":[{"ddd":0,"ind":48,"ty":0,"nm":"","ln":"precomp_sprtaq4DHHne_f_0m_Xco48","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"0jidQ1Pf1dzayoEQS9Tj6"},{"ddd":0,"ind":49,"ty":0,"nm":"","ln":"precomp_fvWkWuqsI-lKC9kYt3GJq49","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"gwp_wmRVfWlDDQxd1MRcb"},{"ddd":0,"ind":54,"ty":0,"nm":"","ln":"precomp_gl-SeSF4acJPrUTGE1Q0x54","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"f7LcMMGmkX4wUrKOuBt0x"},{"ddd":0,"ind":55,"ty":0,"nm":"","ln":"precomp_2fTtbdZkGTIMfy4xp7XhH55","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"xChQfUdYh69G7igoU8G3t"}]},{"id":"t7xx1Hf5FWy-MjgSMJBuf","layers":[]},{"h":45,"id":"fqcpsaNvzHM_SxaUy1aLe","p":"","u":"","w":45,"e":1},{"id":"vm51j4-ITYhMwNfDG0dFB","layers":[{"ddd":0,"ind":60,"ty":2,"nm":"","ln":"fqcpsaNvzHM_SxaUy1aLe60","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"fqcpsaNvzHM_SxaUy1aLe"}]},{"id":"jdGJrUrXy_5VKDgrLIdSu","layers":[{"ddd":0,"ind":62,"ty":4,"nm":"","ln":"cQaSqYxxn9xH5PeejEVnt62","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"OPIKbLgNONyCrlTRzcshu","layers":[{"ddd":0,"ind":61,"ty":0,"nm":"","td":1,"ln":"precomp_oHvD3iIf53AeKY3rTRsrz61","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"jdGJrUrXy_5VKDgrLIdSu"},{"ddd":0,"ind":59,"ty":0,"nm":"","tt":1,"ln":"precomp_Q-HkteGRQnbReZE2Xikpn59","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"vm51j4-ITYhMwNfDG0dFB"}]},{"id":"wQVI65kJQ20PPPqTaP0uu","layers":[]},{"id":"6cEnfUtIt4WDUt09BUofz","layers":[]},{"id":"h5L-p3LNkHprJpPK0qqug","layers":[{"ddd":0,"ind":57,"ty":0,"nm":"","ln":"precomp_wU9yIr_BCB9GU0Tonnxy857","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"t7xx1Hf5FWy-MjgSMJBuf"},{"ddd":0,"ind":58,"ty":0,"nm":"","ln":"precomp_Q-HkteGRQnbReZE2Xikpn58","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"OPIKbLgNONyCrlTRzcshu"},{"ddd":0,"ind":63,"ty":0,"nm":"","ln":"precomp_8oShG4NrmzH8s_lDetPvp63","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"wQVI65kJQ20PPPqTaP0uu"},{"ddd":0,"ind":64,"ty":0,"nm":"","ln":"precomp_r7v5nvcPo33_5eMaLa6De64","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"6cEnfUtIt4WDUt09BUofz"}]},{"id":"7tFvfT0MS3hFFgFTuhPHd","layers":[]},{"h":45,"id":"KlJNPoQ58F7Wo7mcGMItH","p":"","u":"","w":45,"e":1},{"id":"CmLQifVYEJDu2-iVUi1_u","layers":[{"ddd":0,"ind":69,"ty":2,"nm":"","ln":"KlJNPoQ58F7Wo7mcGMItH69","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"KlJNPoQ58F7Wo7mcGMItH"}]},{"id":"WGOk_tUA_MPsW_qVKhgHN","layers":[{"ddd":0,"ind":71,"ty":4,"nm":"","ln":"7n5aBggFWXcU5vLZnatOG71","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"3BjwZ_8FKzno7R_KYXsyZ","layers":[{"ddd":0,"ind":70,"ty":0,"nm":"","td":1,"ln":"precomp_JKtaq9ekMsEHppNMxgT3r70","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WGOk_tUA_MPsW_qVKhgHN"},{"ddd":0,"ind":68,"ty":0,"nm":"","tt":1,"ln":"precomp_hgNGEIN_FrZau1maWS0fe68","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"CmLQifVYEJDu2-iVUi1_u"}]},{"id":"CSOBB3P2mmX2Qk6PgJDhP","layers":[]},{"id":"_AZgJbxPjMn98N9ieYDHP","layers":[]},{"id":"oDfxAfxXh38-S9jmq5wia","layers":[{"ddd":0,"ind":66,"ty":0,"nm":"","ln":"precomp_RRC1Hrf0XwTBjpR-VlJth66","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7tFvfT0MS3hFFgFTuhPHd"},{"ddd":0,"ind":67,"ty":0,"nm":"","ln":"precomp_hgNGEIN_FrZau1maWS0fe67","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"3BjwZ_8FKzno7R_KYXsyZ"},{"ddd":0,"ind":72,"ty":0,"nm":"","ln":"precomp_0sH0rlMC2ggl_qqTrhOp072","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"CSOBB3P2mmX2Qk6PgJDhP"},{"ddd":0,"ind":73,"ty":0,"nm":"","ln":"precomp_UXT-dP3Wz-KVlpS_I-EoG73","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_AZgJbxPjMn98N9ieYDHP"}]},{"id":"PMKgimJDrF8d9y87-WkbI","layers":[]},{"h":45,"id":"cViK9O9AHboQ1BfqUYZbT","p":"","u":"","w":45,"e":1},{"id":"XFtM0cPMJduDpcUKDr9jb","layers":[{"ddd":0,"ind":78,"ty":2,"nm":"","ln":"cViK9O9AHboQ1BfqUYZbT78","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"cViK9O9AHboQ1BfqUYZbT"}]},{"id":"2Qz62AbVbwj5PTBDWUEmK","layers":[{"ddd":0,"ind":80,"ty":4,"nm":"","ln":"1aiEP35AUtJblW0GiAwrp80","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"KAkyfeXLoDfsNaCOz-h8r","layers":[{"ddd":0,"ind":79,"ty":0,"nm":"","td":1,"ln":"precomp_lDeAsJx2DG-I9lcoSv7iE79","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"2Qz62AbVbwj5PTBDWUEmK"},{"ddd":0,"ind":77,"ty":0,"nm":"","tt":1,"ln":"precomp_ajdR7D5gGuBWAlDO-fjL077","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"XFtM0cPMJduDpcUKDr9jb"}]},{"id":"VEGivJ-PDkPqBP7SncFm3","layers":[]},{"id":"D_SaaHHlJmTMqxlAmFJ9U","layers":[]},{"id":"5-RxkO4CxIh7glDn4PoL7","layers":[{"ddd":0,"ind":75,"ty":0,"nm":"","ln":"precomp_YKH9EuCB6wxk49Fz2HY2V75","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"PMKgimJDrF8d9y87-WkbI"},{"ddd":0,"ind":76,"ty":0,"nm":"","ln":"precomp_ajdR7D5gGuBWAlDO-fjL076","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"KAkyfeXLoDfsNaCOz-h8r"},{"ddd":0,"ind":81,"ty":0,"nm":"","ln":"precomp__YUWdV5VSM7t1bzePz2ho81","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"VEGivJ-PDkPqBP7SncFm3"},{"ddd":0,"ind":82,"ty":0,"nm":"","ln":"precomp_6fwgiJqena1z2UqemcAHL82","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"D_SaaHHlJmTMqxlAmFJ9U"}]},{"id":"ZRlIQL7d4eS2xBrvVMouH","layers":[]},{"h":45,"id":"tYa4S4YKwhi7Jp7sMuhZb","p":"","u":"","w":45,"e":1},{"id":"4F3u9bCmjej6tBzy5-IGg","layers":[{"ddd":0,"ind":87,"ty":2,"nm":"","ln":"tYa4S4YKwhi7Jp7sMuhZb87","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"tYa4S4YKwhi7Jp7sMuhZb"}]},{"id":"7SJ2-EqyY1qyMrifgj_EE","layers":[{"ddd":0,"ind":89,"ty":4,"nm":"","ln":"iHKtduHJCxWagsBhplphy89","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"nGqHSg6Ftu6HE3TDIpSbU","layers":[{"ddd":0,"ind":88,"ty":0,"nm":"","td":1,"ln":"precomp_CCqmsV0_UpPD6Y5LSywja88","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7SJ2-EqyY1qyMrifgj_EE"},{"ddd":0,"ind":86,"ty":0,"nm":"","tt":1,"ln":"precomp_vInkXFc16m773dIZxW0T486","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"4F3u9bCmjej6tBzy5-IGg"}]},{"id":"DTMJFY00QLo6jabxCR_Ma","layers":[]},{"id":"gwX8Ym-Rv0VftkUicPn87","layers":[]},{"id":"5Uo0TfeEtoqlVjJqqYTxD","layers":[{"ddd":0,"ind":84,"ty":0,"nm":"","ln":"precomp_gGq49n4pSUaxPv-pohD2G84","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"ZRlIQL7d4eS2xBrvVMouH"},{"ddd":0,"ind":85,"ty":0,"nm":"","ln":"precomp_vInkXFc16m773dIZxW0T485","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"nGqHSg6Ftu6HE3TDIpSbU"},{"ddd":0,"ind":90,"ty":0,"nm":"","ln":"precomp_fK8W-CAfhHYmhXh0BGX_O90","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DTMJFY00QLo6jabxCR_Ma"},{"ddd":0,"ind":91,"ty":0,"nm":"","ln":"precomp_qTJVk0VZ7m2dElbE0Mywb91","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"gwX8Ym-Rv0VftkUicPn87"}]},{"id":"BcoNf6Y_RIhNZgJaEjnIt","layers":[]},{"h":45,"id":"DsjVleWpgzrBoxGjhaksk","p":"","u":"","w":45,"e":1},{"id":"QmkZO3sTxfFF7jnSD_TX-","layers":[{"ddd":0,"ind":96,"ty":2,"nm":"","ln":"DsjVleWpgzrBoxGjhaksk96","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"DsjVleWpgzrBoxGjhaksk"}]},{"id":"L6YH5CPda1HWf3enGY6hA","layers":[{"ddd":0,"ind":98,"ty":4,"nm":"","ln":"Jic2KHlWLtghzvzF_tQVH98","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"DqGTVzbvRLsDm0T1qriQb","layers":[{"ddd":0,"ind":97,"ty":0,"nm":"","td":1,"ln":"precomp_WqJF8Kk99VYevX46AovFE97","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"L6YH5CPda1HWf3enGY6hA"},{"ddd":0,"ind":95,"ty":0,"nm":"","tt":1,"ln":"precomp_5Bg4Mf1zEPy9aqgje1rpG95","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"QmkZO3sTxfFF7jnSD_TX-"}]},{"id":"WiE9OwVSFoqVwU1EY-kJy","layers":[]},{"id":"YCwAp7ab_Ud-hfwGAEM8-","layers":[]},{"id":"CpQ1ZpGf4gTkX2T1IUN8H","layers":[{"ddd":0,"ind":93,"ty":0,"nm":"","ln":"precomp_9sBBt5Xbv3Inl99acBOnq93","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"BcoNf6Y_RIhNZgJaEjnIt"},{"ddd":0,"ind":94,"ty":0,"nm":"","ln":"precomp_5Bg4Mf1zEPy9aqgje1rpG94","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DqGTVzbvRLsDm0T1qriQb"},{"ddd":0,"ind":99,"ty":0,"nm":"","ln":"precomp_vmUHWpkhDWsQOou4NiSA599","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WiE9OwVSFoqVwU1EY-kJy"},{"ddd":0,"ind":100,"ty":0,"nm":"","ln":"precomp_QkW_SmjrVLfZX3dZF9IE_100","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"YCwAp7ab_Ud-hfwGAEM8-"}]},{"id":"1K-kp2YUW1BD-x4l_ShCV","layers":[]},{"h":45,"id":"F1QRPA2dfkw3YPj-Cbmu9","p":"","u":"","w":45,"e":1},{"id":"9ptuOhLV2jDupLu5dUXIN","layers":[{"ddd":0,"ind":105,"ty":2,"nm":"","ln":"F1QRPA2dfkw3YPj-Cbmu9105","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"F1QRPA2dfkw3YPj-Cbmu9"}]},{"id":"WadhOAcrUye2NeuuSzezY","layers":[{"ddd":0,"ind":107,"ty":4,"nm":"","ln":"vrlSu1wf7UwySTxBtKBW2107","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"68UgXz-rgXE3a1aMmuVTg","layers":[{"ddd":0,"ind":106,"ty":0,"nm":"","td":1,"ln":"precomp_BSUYYXXCkttTGfdxVymJM106","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WadhOAcrUye2NeuuSzezY"},{"ddd":0,"ind":104,"ty":0,"nm":"","tt":1,"ln":"precomp_VaRqxJvTSrdGzLe0vvUHw104","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"9ptuOhLV2jDupLu5dUXIN"}]},{"id":"1QD8cZs5OuekLdm5wOdWU","layers":[]},{"id":"LKTI3FDCmeVuXUV_mFRUC","layers":[]},{"id":"xl6s-Qge6NvJxaxQCcb23","layers":[{"ddd":0,"ind":102,"ty":0,"nm":"","ln":"precomp_4WIRC_itvjJr8qxQxBUPa102","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1K-kp2YUW1BD-x4l_ShCV"},{"ddd":0,"ind":103,"ty":0,"nm":"","ln":"precomp_VaRqxJvTSrdGzLe0vvUHw103","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"68UgXz-rgXE3a1aMmuVTg"},{"ddd":0,"ind":108,"ty":0,"nm":"","ln":"precomp_J3FSFeT5NHGP2DAdzdEg6108","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1QD8cZs5OuekLdm5wOdWU"},{"ddd":0,"ind":109,"ty":0,"nm":"","ln":"precomp_o9JOkwCMvgntLdIhnIHP8109","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"LKTI3FDCmeVuXUV_mFRUC"}]},{"id":"audEMVOnb9eAA_36XJgj6","layers":[]},{"h":45,"id":"yMAiH_0ij8NPCgYFt_C03","p":"","u":"","w":45,"e":1},{"id":"jaxZMuWTn5qj9bIWUXoIx","layers":[{"ddd":0,"ind":114,"ty":2,"nm":"","ln":"yMAiH_0ij8NPCgYFt_C03114","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"yMAiH_0ij8NPCgYFt_C03"}]},{"id":"fRW_MYHKStky_onCNdGmK","layers":[{"ddd":0,"ind":116,"ty":4,"nm":"","ln":"Okz61lW_B0UD3lq4R6jWl116","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"w9WEd0QCCBY3n4pGBuSzq","layers":[{"ddd":0,"ind":115,"ty":0,"nm":"","td":1,"ln":"precomp_32jUcvb7qJfoU4YvspvhM115","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"fRW_MYHKStky_onCNdGmK"},{"ddd":0,"ind":113,"ty":0,"nm":"","tt":1,"ln":"precomp_FVN8Bn_zqeVo5FHHL50GQ113","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"jaxZMuWTn5qj9bIWUXoIx"}]},{"id":"jIpTwVf17EBGRQOXdAEwT","layers":[]},{"id":"QLDB12Q-AQDcRpLlu8_6z","layers":[]},{"id":"TOgqut4P1xneEbaIjqpMf","layers":[{"ddd":0,"ind":111,"ty":0,"nm":"","ln":"precomp_f5yE1bVb2F98xgv9GbEd3111","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"audEMVOnb9eAA_36XJgj6"},{"ddd":0,"ind":112,"ty":0,"nm":"","ln":"precomp_FVN8Bn_zqeVo5FHHL50GQ112","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"w9WEd0QCCBY3n4pGBuSzq"},{"ddd":0,"ind":117,"ty":0,"nm":"","ln":"precomp_DPz5QuIBbh3HQXA4NLmd_117","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"jIpTwVf17EBGRQOXdAEwT"},{"ddd":0,"ind":118,"ty":0,"nm":"","ln":"precomp_g55VHJ8UcwoUaf_QZcyGS118","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"QLDB12Q-AQDcRpLlu8_6z"}]},{"id":"TNyOqEhDvKeOdy8mthy-R","layers":[]},{"h":45,"id":"dbRx-LBMtj1eg4CrjVmaE","p":"","u":"","w":45,"e":1},{"id":"_NWgnUuTUDJDEjqG_fUCY","layers":[{"ddd":0,"ind":123,"ty":2,"nm":"","ln":"dbRx-LBMtj1eg4CrjVmaE123","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"dbRx-LBMtj1eg4CrjVmaE"}]},{"id":"AhZKbO_rThVn25U1YR8ZI","layers":[{"ddd":0,"ind":125,"ty":4,"nm":"","ln":"BTUobg95a8Gcjhb3mW9gK125","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"L-RIwYHKoSF4VepnNgVTf","layers":[{"ddd":0,"ind":124,"ty":0,"nm":"","td":1,"ln":"precomp_vX4YnUd6McN9BzTyaC6sX124","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"AhZKbO_rThVn25U1YR8ZI"},{"ddd":0,"ind":122,"ty":0,"nm":"","tt":1,"ln":"precomp_ujVmB6h-peELkNal61x2d122","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_NWgnUuTUDJDEjqG_fUCY"}]},{"id":"_8WmDsJxdtEQXwREpaDNa","layers":[]},{"id":"V5JBvz-e7OTwk_aqG4Ip_","layers":[]},{"id":"PrdF5u-8Fw0h_KbqbYfJG","layers":[{"ddd":0,"ind":120,"ty":0,"nm":"","ln":"precomp_pFM9KIiGhKm3krnexNwEc120","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"TNyOqEhDvKeOdy8mthy-R"},{"ddd":0,"ind":121,"ty":0,"nm":"","ln":"precomp_ujVmB6h-peELkNal61x2d121","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"L-RIwYHKoSF4VepnNgVTf"},{"ddd":0,"ind":126,"ty":0,"nm":"","ln":"precomp_PJgxEEO_2R3gHbWB3b79z126","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_8WmDsJxdtEQXwREpaDNa"},{"ddd":0,"ind":127,"ty":0,"nm":"","ln":"precomp_0pbqn6reFmlLvMjIDBquj127","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"V5JBvz-e7OTwk_aqG4Ip_"}]},{"id":"A7SAQDGyVoMMpKGbN9Lu8","layers":[]},{"h":45,"id":"QdbfzXBcdT5-zstdySSeh","p":"","u":"","w":45,"e":1},{"id":"4TMtDGwGyKYTvUWHNrUyw","layers":[{"ddd":0,"ind":132,"ty":2,"nm":"","ln":"QdbfzXBcdT5-zstdySSeh132","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"QdbfzXBcdT5-zstdySSeh"}]},{"id":"bT_za47g-WZT9rog4k49Q","layers":[{"ddd":0,"ind":134,"ty":4,"nm":"","ln":"Iz42PypTYkq7YWpc27xS9134","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"0pTZrvushEc5ffEe2ZL-c","layers":[{"ddd":0,"ind":133,"ty":0,"nm":"","td":1,"ln":"precomp_dL7yp9kd2WaLG6Sx3_8oH133","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"bT_za47g-WZT9rog4k49Q"},{"ddd":0,"ind":131,"ty":0,"nm":"","tt":1,"ln":"precomp_tdkcCs1pf9285tcsB_8KR131","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"4TMtDGwGyKYTvUWHNrUyw"}]},{"id":"gA-17tVpvBg4FWlq0_UPD","layers":[]},{"id":"WdlkXqcANpGSLJ8ZlKBnM","layers":[]},{"id":"8t0xGXsZM9SkB_w3QfZR7","layers":[{"ddd":0,"ind":129,"ty":0,"nm":"","ln":"precomp_-byrD89H-SGf8zPzZpivN129","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"A7SAQDGyVoMMpKGbN9Lu8"},{"ddd":0,"ind":130,"ty":0,"nm":"","ln":"precomp_tdkcCs1pf9285tcsB_8KR130","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"0pTZrvushEc5ffEe2ZL-c"},{"ddd":0,"ind":135,"ty":0,"nm":"","ln":"precomp_gx2lCEIyhQWirf91cE302135","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"gA-17tVpvBg4FWlq0_UPD"},{"ddd":0,"ind":136,"ty":0,"nm":"","ln":"precomp_jUzdUmmxNjk0-_eH7Eage136","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WdlkXqcANpGSLJ8ZlKBnM"}]},{"id":"NXdD84xzNm_5IlR9lF6x6","layers":[]},{"h":45,"id":"bGs5YM-yayqDfS4JSY2Us","p":"","u":"","w":45,"e":1},{"id":"AdDHZaxutCXCAyH8iMdks","layers":[{"ddd":0,"ind":141,"ty":2,"nm":"","ln":"bGs5YM-yayqDfS4JSY2Us141","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"bGs5YM-yayqDfS4JSY2Us"}]},{"id":"v6gw2RF7VZTFdYsGk1arX","layers":[{"ddd":0,"ind":143,"ty":4,"nm":"","ln":"nkG6i9mtERWLLCr0btA8-143","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"rvQvc-0gZ5-1subbV35ko","layers":[{"ddd":0,"ind":142,"ty":0,"nm":"","td":1,"ln":"precomp_QrQPJ2Mw7fOdJbXAN7fFc142","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"v6gw2RF7VZTFdYsGk1arX"},{"ddd":0,"ind":140,"ty":0,"nm":"","tt":1,"ln":"precomp_V6QZbHZt9WpZ36I07gYIN140","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"AdDHZaxutCXCAyH8iMdks"}]},{"id":"-ED6KVlwjEBIljTZh_MHA","layers":[]},{"id":"edGA8TI-3GMoaWSUpeJpx","layers":[]},{"id":"eDhrm1tYtPflD9uGIIHf0","layers":[{"ddd":0,"ind":138,"ty":0,"nm":"","ln":"precomp_prnlqPKw89Q6lmTxSqZ0U138","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"NXdD84xzNm_5IlR9lF6x6"},{"ddd":0,"ind":139,"ty":0,"nm":"","ln":"precomp_V6QZbHZt9WpZ36I07gYIN139","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"rvQvc-0gZ5-1subbV35ko"},{"ddd":0,"ind":144,"ty":0,"nm":"","ln":"precomp_Ag0pRzFLCZFh1hXRqLose144","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"-ED6KVlwjEBIljTZh_MHA"},{"ddd":0,"ind":145,"ty":0,"nm":"","ln":"precomp_Hscx4WWZyXFdTa65zZ_o4145","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"edGA8TI-3GMoaWSUpeJpx"}]},{"id":"IBkGZTMIAbw0myFQ2KTnd","layers":[]},{"h":184,"id":"1QxmZoRYrZLI0vocQMryy","p":"","u":"","w":218,"e":1},{"id":"-c9slQ58f4tDUwFfHgPia","layers":[{"ddd":0,"ind":150,"ty":2,"nm":"","ln":"1QxmZoRYrZLI0vocQMryy150","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49891,49908]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"1QxmZoRYrZLI0vocQMryy"}]},{"id":"7CcuiSOKf92D4GeDR_crK","layers":[{"ddd":0,"ind":152,"ty":4,"nm":"","ln":"pspzJhHQqDW4DXWbbCLGj152","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[218,184]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"p-IPk1pV80qaVqHMbxR8c","layers":[{"ddd":0,"ind":151,"ty":0,"nm":"","td":1,"ln":"precomp_0Hoch-YvqUTuJ4S3uR8_4151","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7CcuiSOKf92D4GeDR_crK"},{"ddd":0,"ind":149,"ty":0,"nm":"","tt":1,"ln":"precomp_btzyL_rTQWvZnZ2dxn5Hp149","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"-c9slQ58f4tDUwFfHgPia"}]},{"id":"tFBMdpuqXJr3Ovlf2PRdh","layers":[]},{"id":"_p3Wu-oHCgy_YfDg2IeB6","layers":[]},{"id":"r4zUNTw-LgX_hVpVRUSrO","layers":[{"ddd":0,"ind":147,"ty":0,"nm":"","ln":"precomp_iYeHMCl-MVatHKl84o1aL147","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"IBkGZTMIAbw0myFQ2KTnd"},{"ddd":0,"ind":148,"ty":0,"nm":"","ln":"precomp_btzyL_rTQWvZnZ2dxn5Hp148","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"p-IPk1pV80qaVqHMbxR8c"},{"ddd":0,"ind":153,"ty":0,"nm":"","ln":"precomp_mr9ZZnPlzmVFoCI4Ccfu4153","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"tFBMdpuqXJr3Ovlf2PRdh"},{"ddd":0,"ind":154,"ty":0,"nm":"","ln":"precomp_qVu1Wt-YHmceFfSJE97jC154","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_p3Wu-oHCgy_YfDg2IeB6"}]},{"id":"sNVXS2BGTCHwZKXmYY7lV","layers":[]},{"id":"s84XEl4j37T9YupJrsBTP","layers":[{"ddd":0,"ind":157,"ty":4,"nm":"","ln":"A82bSnYkMtw1q-s5GWvDu157","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[1074,300]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.01,0.03,0.09]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"wrkEviRNVA6uf3S-T7YLI","layers":[{"ddd":0,"ind":1,"ty":0,"nm":"","ln":"precomp__yKsry3HDasKSgULzl3-Y1","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49586.5,50034.5],"h":1},{"t":0,"s":[49586.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49636.5,50034.5],"h":1},{"t":24,"s":[49636.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49686.5,50034.5],"h":1},{"t":48,"s":[49686.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49736.5,50034.5],"h":1},{"t":72,"s":[49736.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49786.5,50034.5],"h":1},{"t":96,"s":[49786.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49836.5,50034.5],"h":1},{"t":120,"s":[49836.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49886.5,50034.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"FcRGxR1DAk6L5FB4ij6KO"},{"ddd":0,"ind":3,"ty":0,"nm":"","ln":"precomp_SF0yrQrX06RcGzPjLAChd3","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49585.5,50066],"h":1},{"t":0,"s":[49585.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49635.5,50066],"h":1},{"t":24,"s":[49635.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49685.5,50066],"h":1},{"t":48,"s":[49685.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49735.5,50066],"h":1},{"t":72,"s":[49735.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49785.5,50066],"h":1},{"t":96,"s":[49785.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49835.5,50066],"h":1},{"t":120,"s":[49835.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49885.5,50066],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"LngS0iiQ16cdJYvpEDGzR"},{"ddd":0,"ind":11,"ty":0,"nm":"","ln":"precomp_P-HiwuAFBTT62TLTZqZll11","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49635.5,50000],"h":1},{"t":0,"s":[49635.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49685.5,50000],"h":1},{"t":24,"s":[49685.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49735.5,50000],"h":1},{"t":48,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49785.5,50000],"h":1},{"t":72,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49835.5,50000],"h":1},{"t":96,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49885.5,50000],"h":1},{"t":120,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49935.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1NdNgVBQJQuQHk4FTmSTr"},{"ddd":0,"ind":20,"ty":0,"nm":"","ln":"precomp_OHRvkPTSXZSH1FGWcuMBz20","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49685.5,50000],"h":1},{"t":0,"s":[49685.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49735.5,50000],"h":1},{"t":24,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49785.5,50000],"h":1},{"t":48,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49835.5,50000],"h":1},{"t":72,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49885.5,50000],"h":1},{"t":96,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49935.5,50000],"h":1},{"t":120,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49985.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"m9dH0F5MwXsLDDQSBUxbN"},{"ddd":0,"ind":29,"ty":0,"nm":"","ln":"precomp_CO6d-RYRT9HfAASTjepwL29","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49735.5,50000],"h":1},{"t":0,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49785.5,50000],"h":1},{"t":24,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49835.5,50000],"h":1},{"t":48,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49885.5,50000],"h":1},{"t":72,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49935.5,50000],"h":1},{"t":96,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49985.5,50000],"h":1},{"t":120,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50035.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"0gYS5jhAGIs7crB8QrUz2"},{"ddd":0,"ind":38,"ty":0,"nm":"","ln":"precomp_uXclUMI0uHzhsIjwO6aA638","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49785.5,50000],"h":1},{"t":0,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49835.5,50000],"h":1},{"t":24,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49885.5,50000],"h":1},{"t":48,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49935.5,50000],"h":1},{"t":72,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49985.5,50000],"h":1},{"t":96,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50035.5,50000],"h":1},{"t":120,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50085.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"J1B0qVspRM_3bvXSjoLp0"},{"ddd":0,"ind":47,"ty":0,"nm":"","ln":"precomp_MZ9z5Idn8oQWHiLUjqjMX47","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49835.5,50000],"h":1},{"t":0,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49885.5,50000],"h":1},{"t":24,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49935.5,50000],"h":1},{"t":48,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49985.5,50000],"h":1},{"t":72,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50035.5,50000],"h":1},{"t":96,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50085.5,50000],"h":1},{"t":120,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50135.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"qrJiCHr7n5E_Ea20SXw_6"},{"ddd":0,"ind":56,"ty":0,"nm":"","ln":"precomp_gVNnp2cRIYK9pXE8eQEcs56","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49885.5,50000],"h":1},{"t":0,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49935.5,50000],"h":1},{"t":24,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49985.5,50000],"h":1},{"t":48,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50035.5,50000],"h":1},{"t":72,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50085.5,50000],"h":1},{"t":96,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50135.5,50000],"h":1},{"t":120,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50185.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"h5L-p3LNkHprJpPK0qqug"},{"ddd":0,"ind":65,"ty":0,"nm":"","ln":"precomp_ypWVWU7MDUZTi6l_tnw7N65","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49935.5,50000],"h":1},{"t":0,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49985.5,50000],"h":1},{"t":24,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50035.5,50000],"h":1},{"t":48,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50085.5,50000],"h":1},{"t":72,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50135.5,50000],"h":1},{"t":96,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50185.5,50000],"h":1},{"t":120,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50235.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"oDfxAfxXh38-S9jmq5wia"},{"ddd":0,"ind":74,"ty":0,"nm":"","ln":"precomp_zyOsbRZBsqLj4MBO26Uvn74","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49985.5,50000],"h":1},{"t":0,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50035.5,50000],"h":1},{"t":24,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50085.5,50000],"h":1},{"t":48,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50135.5,50000],"h":1},{"t":72,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50185.5,50000],"h":1},{"t":96,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50235.5,50000],"h":1},{"t":120,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50285.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"5-RxkO4CxIh7glDn4PoL7"},{"ddd":0,"ind":83,"ty":0,"nm":"","ln":"precomp_vCeUwru4p6fSgpN3XlLUI83","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[50035.5,50000],"h":1},{"t":0,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50085.5,50000],"h":1},{"t":24,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50135.5,50000],"h":1},{"t":48,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50185.5,50000],"h":1},{"t":72,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50235.5,50000],"h":1},{"t":96,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50285.5,50000],"h":1},{"t":120,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50428,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"5Uo0TfeEtoqlVjJqqYTxD"},{"ddd":0,"ind":92,"ty":0,"nm":"","ln":"precomp_SCTeRrcs5fvVcyq2ueJzp92","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":120,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":144,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50085.5,50000],"h":1},{"t":0,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50135.5,50000],"h":1},{"t":24,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50185.5,50000],"h":1},{"t":48,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50235.5,50000],"h":1},{"t":72,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50285.5,50000],"h":1},{"t":96,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50428,50000],"h":1},{"t":120,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"CpQ1ZpGf4gTkX2T1IUN8H"},{"ddd":0,"ind":101,"ty":0,"nm":"","ln":"precomp_3XehBm15W8gj9OGcWDBI6101","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":96,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":120,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50135.5,50000],"h":1},{"t":0,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50185.5,50000],"h":1},{"t":24,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50235.5,50000],"h":1},{"t":48,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50285.5,50000],"h":1},{"t":72,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50428,50000],"h":1},{"t":96,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"xl6s-Qge6NvJxaxQCcb23"},{"ddd":0,"ind":110,"ty":0,"nm":"","ln":"precomp_SQGQ1DMuRkTyuxSnDukfv110","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":72,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":96,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50185.5,50000],"h":1},{"t":0,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50235.5,50000],"h":1},{"t":24,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50285.5,50000],"h":1},{"t":48,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50428,50000],"h":1},{"t":72,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"TOgqut4P1xneEbaIjqpMf"},{"ddd":0,"ind":119,"ty":0,"nm":"","ln":"precomp_Ngqnv5u7c78bv1kKml-JZ119","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":48,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":72,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50235.5,50000],"h":1},{"t":0,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50285.5,50000],"h":1},{"t":24,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50428,50000],"h":1},{"t":48,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"PrdF5u-8Fw0h_KbqbYfJG"},{"ddd":0,"ind":128,"ty":0,"nm":"","ln":"precomp_7SfQxvberzjgAVfhsi9pe128","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49585.5,50000],"h":1},{"t":0,"s":[49585.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49635.5,50000],"h":1},{"t":24,"s":[49635.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49685.5,50000],"h":1},{"t":48,"s":[49685.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49735.5,50000],"h":1},{"t":72,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49785.5,50000],"h":1},{"t":96,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49835.5,50000],"h":1},{"t":120,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49885.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"8t0xGXsZM9SkB_w3QfZR7"},{"ddd":0,"ind":137,"ty":0,"nm":"","ln":"precomp_SSbPtfB45NY2wk8qYEhVs137","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":24,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":48,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50285.5,50000],"h":1},{"t":0,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50428,50000],"h":1},{"t":24,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"eDhrm1tYtPflD9uGIIHf0"},{"ddd":0,"ind":146,"ty":0,"nm":"","ln":"precomp_MprMPTSLYQOXKH26z-kdy146","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50428,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"r4zUNTw-LgX_hVpVRUSrO"},{"ddd":0,"ind":155,"ty":0,"nm":"","ln":"precomp_gVQzIfkE2xkBlH7BKG3UV155","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"sNVXS2BGTCHwZKXmYY7lV"},{"ddd":0,"ind":156,"ty":0,"nm":"","ln":"precomp_XMJpyhoVl-fimMTztA3rw156","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"s84XEl4j37T9YupJrsBTP"}]}],"ddd":0,"fr":60,"h":300,"ip":0,"layers":[{"ddd":0,"ind":0,"ty":0,"nm":"","ln":"precomp_RhoI5eMdh0y036MGIYl__0","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[537,150]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"wrkEviRNVA6uf3S-T7YLI"}],"meta":{"g":"https://jitter.video"},"nm":"Basic-Task-Queue-[copy]","op":192,"v":"5.7.4","w":1074} \ No newline at end of file +{"assets":[{"id":"FcRGxR1DAk6L5FB4ij6KO","layers":[{"ddd":0,"ind":2,"ty":4,"nm":"","ln":"va6HDrHI5HXXzypIhy3yW2","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[2,24]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"Bu9lAGfZul51C34BG8pFv","layers":[{"ddd":0,"ind":6,"ty":4,"nm":"","ln":"RTZ1hCGQ7G5N06kk7HS-k6","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50009.01,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.89,0.18],[4.89,0.18],[2.71,-0.38],[1.31,-1.95],[0.82,-4.3],[0.82,-4.3],[1.31,-6.66],[2.68,-8.26],[4.75,-8.84],[4.75,-8.84],[6.1,-8.61],[7.31,-7.88],[8.18,-6.53],[8.5,-4.48],[8.5,-4.48],[8.5,-3.91],[1.77,-3.91],[1.77,-5.07],[7.14,-5.07],[6.84,-6.39],[6.01,-7.3],[4.75,-7.64],[4.75,-7.64],[3.37,-7.24],[2.47,-6.22],[2.16,-4.86],[2.16,-4.86],[2.16,-4.09],[2.5,-2.42],[3.46,-1.38],[4.89,-1.02],[4.89,-1.02],[5.84,-1.17],[6.59,-1.63],[7.07,-2.39],[7.07,-2.39],[8.36,-2.02],[7.68,-0.87],[6.48,-0.09],[4.89,0.18]],"i":[[0,0],[0,0],[0.61,0.37],[0.33,0.67],[0,0.9],[0,0],[-0.33,0.68],[-0.59,0.38],[-0.79,0],[0,0],[-0.45,-0.15],[-0.37,-0.34],[-0.22,-0.56],[0,-0.81],[0,0],[0,0],[0,0],[0,0],[0,0],[0.2,0.39],[0.36,0.22],[0.49,0],[0,0],[0.39,-0.27],[0.21,-0.42],[0,-0.49],[0,0],[0,0],[-0.23,-0.45],[-0.41,-0.23],[-0.55,0],[0,0],[-0.29,0.1],[-0.21,0.21],[-0.11,0.31],[0,0],[0,0],[0.32,-0.33],[0.47,-0.19],[0.59,0]],"o":[[0,0],[-0.84,0],[-0.61,-0.37],[-0.33,-0.67],[0,0],[0,-0.89],[0.33,-0.69],[0.59,-0.39],[0,0],[0.45,0],[0.44,0.15],[0.36,0.34],[0.21,0.55],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.49],[-0.19,-0.39],[-0.35,-0.23],[0,0],[-0.53,0],[-0.39,0.26],[-0.21,0.42],[0,0],[0,0],[0,0.66],[0.23,0.46],[0.41,0.24],[0,0],[0.35,0],[0.29,-0.1],[0.21,-0.2],[0,0],[0,0],[-0.13,0.44],[-0.33,0.33],[-0.47,0.18],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":7,"ty":4,"nm":"","ln":"1IVtWDl9h6BXi0p-ZynCi7","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000.08,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.77,0.18],[4.77,0.18],[2.66,-0.4],[1.3,-1.99],[0.82,-4.32],[0.82,-4.32],[1.31,-6.67],[2.68,-8.26],[4.75,-8.84],[4.75,-8.84],[6.41,-8.5],[7.62,-7.55],[8.2,-6.11],[8.2,-6.11],[6.86,-6.11],[6.18,-7.17],[4.77,-7.64],[4.77,-7.64],[3.4,-7.23],[2.49,-6.09],[2.16,-4.36],[2.16,-4.36],[2.48,-2.6],[3.39,-1.44],[4.77,-1.02],[4.77,-1.02],[5.72,-1.2],[6.44,-1.73],[6.86,-2.55],[6.86,-2.55],[8.2,-2.55],[7.64,-1.16],[6.47,-0.18],[4.77,0.18]],"i":[[0,0],[0,0],[0.59,0.39],[0.31,0.67],[0,0.87],[0,0],[-0.33,0.68],[-0.59,0.38],[-0.79,0],[0,0],[-0.49,-0.23],[-0.31,-0.41],[-0.07,-0.55],[0,0],[0,0],[0.35,0.31],[0.59,0],[0,0],[0.39,-0.27],[0.21,-0.49],[0,-0.66],[0,0],[-0.21,-0.5],[-0.39,-0.27],[-0.53,0],[0,0],[-0.28,0.12],[-0.19,0.23],[-0.08,0.32],[0,0],[0,0],[0.3,-0.41],[0.49,-0.24],[0.65,0]],"o":[[0,0],[-0.81,0],[-0.59,-0.39],[-0.32,-0.68],[0,0],[0,-0.89],[0.33,-0.68],[0.59,-0.39],[0,0],[0.61,0],[0.49,0.23],[0.31,0.41],[0,0],[0,0],[-0.1,-0.4],[-0.35,-0.31],[0,0],[-0.52,0],[-0.39,0.27],[-0.22,0.49],[0,0],[0,0.67],[0.21,0.5],[0.39,0.28],[0,0],[0.35,0],[0.29,-0.13],[0.2,-0.23],[0,0],[0,0],[-0.07,0.52],[-0.29,0.41],[-0.49,0.24],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":8,"ty":4,"nm":"","ln":"c04wlcjZMJmNcq3aZ2kcn8","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49996.28,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.57,0],[1.23,0],[1.23,-8.73],[2.57,-8.73],[2.57,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[1.91,-10.18],[1.91,-10.18],[1.24,-10.45],[0.95,-11.09],[0.95,-11.09],[1.24,-11.73],[1.91,-12],[1.91,-12],[2.58,-11.73],[2.86,-11.09],[2.86,-11.09],[2.58,-10.45],[1.91,-10.18]],"i":[[0,0],[0,0],[0.19,0.18],[0,0.25],[0,0],[-0.19,0.17],[-0.26,0],[0,0],[-0.19,-0.18],[0,-0.25],[0,0],[0.19,-0.18],[0.26,0]],"o":[[0,0],[-0.26,0],[-0.19,-0.18],[0,0],[0,-0.25],[0.19,-0.18],[0,0],[0.26,0],[0.19,0.17],[0,0],[0,0.25],[-0.19,0.18],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":9,"ty":4,"nm":"","ln":"VWQy3OFIVV6tU8XAsssDA9","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49992.49,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[1.23,-11.64],[2.57,-11.64],[2.57,0],[1.23,0],[1.23,-11.64]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":10,"ty":4,"nm":"","ln":"VVDhN1Y2oOY06IS43W9ED10","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49981.67,50005.82]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.36,-9.8],[1.89,0],[0.41,0],[4.68,-11.64],[6.14,-11.64],[10.41,0],[8.93,0],[5.45,-9.8],[5.36,-9.8]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[2.43,-3.3],[2.43,-4.55],[8.39,-4.55],[8.39,-3.3],[2.43,-3.3]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"DxhxD9PQHBnUe3yoljZPB","layers":[{"ddd":0,"ind":5,"ty":0,"nm":"","ln":"precomp_igACupoF-ncuD69aX-Gmf5","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Bu9lAGfZul51C34BG8pFv"}]},{"id":"LngS0iiQ16cdJYvpEDGzR","layers":[{"ddd":0,"ind":4,"ty":0,"nm":"","ln":"precomp_KayBkv_NAJSAKvocgXYlt4","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DxhxD9PQHBnUe3yoljZPB"}]},{"id":"9eqIldDJSpsMHinmcH1Pz","layers":[]},{"h":45,"id":"ABpWvxb3H4Ah0xEJxFeMZ","p":"","u":"","w":45,"e":1},{"id":"IM_KzPMd7XTh1TMf4koUv","layers":[{"ddd":0,"ind":15,"ty":2,"nm":"","ln":"ABpWvxb3H4Ah0xEJxFeMZ15","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"ABpWvxb3H4Ah0xEJxFeMZ"}]},{"id":"dlkreuHch_bNNpzQXYsKr","layers":[{"ddd":0,"ind":17,"ty":4,"nm":"","ln":"i7rCLxzkJeppFw9OqE-zb17","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"PMbVCO64q3dokM8KGG2BQ","layers":[{"ddd":0,"ind":16,"ty":0,"nm":"","td":1,"ln":"precomp_61rWE5SDlBxclhXRjf4J616","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"dlkreuHch_bNNpzQXYsKr"},{"ddd":0,"ind":14,"ty":0,"nm":"","tt":1,"ln":"precomp_GZDYzgBhFiSSgyj-IFTiB14","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"IM_KzPMd7XTh1TMf4koUv"}]},{"id":"itDYL43jT4MTF3JS5ZB1_","layers":[]},{"id":"WDm-Z1SWjUBbfPFilqnNZ","layers":[]},{"id":"1NdNgVBQJQuQHk4FTmSTr","layers":[{"ddd":0,"ind":12,"ty":0,"nm":"","ln":"precomp_OpoNZv1uQe8hjon3sIL_S12","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"9eqIldDJSpsMHinmcH1Pz"},{"ddd":0,"ind":13,"ty":0,"nm":"","ln":"precomp_GZDYzgBhFiSSgyj-IFTiB13","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"PMbVCO64q3dokM8KGG2BQ"},{"ddd":0,"ind":18,"ty":0,"nm":"","ln":"precomp_8JDwyVAXZ8W1R6yYV2hJk18","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"itDYL43jT4MTF3JS5ZB1_"},{"ddd":0,"ind":19,"ty":0,"nm":"","ln":"precomp_uTDVCr4PEs5OYebnU5lKj19","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WDm-Z1SWjUBbfPFilqnNZ"}]},{"id":"DU7g2yhUE0PpExuIDbBGI","layers":[]},{"h":45,"id":"9UZ8UmY8_mtSeJrrLuPDI","p":"","u":"","w":45,"e":1},{"id":"QXE7P3588rInsXO0v43l3","layers":[{"ddd":0,"ind":24,"ty":2,"nm":"","ln":"9UZ8UmY8_mtSeJrrLuPDI24","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"9UZ8UmY8_mtSeJrrLuPDI"}]},{"id":"q0Dz2qVgGfYqrpQzXg68w","layers":[{"ddd":0,"ind":26,"ty":4,"nm":"","ln":"c-gyEaIpekO9DNJk0b6x426","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"1ztGx24jm6NzN7qcjtA2A","layers":[{"ddd":0,"ind":25,"ty":0,"nm":"","td":1,"ln":"precomp_Fy1bdQP0yhcTpAylo05Jj25","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"q0Dz2qVgGfYqrpQzXg68w"},{"ddd":0,"ind":23,"ty":0,"nm":"","tt":1,"ln":"precomp_MrlxTbD66le6pjI4SHAmg23","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"QXE7P3588rInsXO0v43l3"}]},{"id":"ifAWb0ku1lefJhMUTh9-J","layers":[]},{"id":"yh2KibH-KypKEaG41uC6c","layers":[]},{"id":"m9dH0F5MwXsLDDQSBUxbN","layers":[{"ddd":0,"ind":21,"ty":0,"nm":"","ln":"precomp_l2QfvfP6S1ZzRmXtfgmwq21","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DU7g2yhUE0PpExuIDbBGI"},{"ddd":0,"ind":22,"ty":0,"nm":"","ln":"precomp_MrlxTbD66le6pjI4SHAmg22","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1ztGx24jm6NzN7qcjtA2A"},{"ddd":0,"ind":27,"ty":0,"nm":"","ln":"precomp_-eQs8MTFpV0a_h1KSbX0627","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"ifAWb0ku1lefJhMUTh9-J"},{"ddd":0,"ind":28,"ty":0,"nm":"","ln":"precomp_Pudi5DjjmGbRsMXVSeS3S28","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"yh2KibH-KypKEaG41uC6c"}]},{"id":"W45MbEl9H7jLwD9mU0X6_","layers":[]},{"h":45,"id":"Jm735z3alknEn5lntdxS6","p":"","u":"","w":45,"e":1},{"id":"Xv41nvJCPKiIrCctfzEBs","layers":[{"ddd":0,"ind":33,"ty":2,"nm":"","ln":"Jm735z3alknEn5lntdxS633","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"Jm735z3alknEn5lntdxS6"}]},{"id":"-FPjwkQSa5OpMd0VlPg8W","layers":[{"ddd":0,"ind":35,"ty":4,"nm":"","ln":"CoGm9Wqkt3sRZPpRBQ5Oq35","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"cLXNodzVkXSsDlSixYOOH","layers":[{"ddd":0,"ind":34,"ty":0,"nm":"","td":1,"ln":"precomp_aQTseLvBk1qnwKeQ5hGjN34","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"-FPjwkQSa5OpMd0VlPg8W"},{"ddd":0,"ind":32,"ty":0,"nm":"","tt":1,"ln":"precomp_t95vO0oTmMDKkJyuIbdre32","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Xv41nvJCPKiIrCctfzEBs"}]},{"id":"WGAc3unn49i1X_sP6DJzb","layers":[]},{"id":"hOcBg6WrhGWjvLQ2hfSPP","layers":[]},{"id":"0gYS5jhAGIs7crB8QrUz2","layers":[{"ddd":0,"ind":30,"ty":0,"nm":"","ln":"precomp_gdbOBvvViMAY0saAr9BZp30","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"W45MbEl9H7jLwD9mU0X6_"},{"ddd":0,"ind":31,"ty":0,"nm":"","ln":"precomp_t95vO0oTmMDKkJyuIbdre31","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"cLXNodzVkXSsDlSixYOOH"},{"ddd":0,"ind":36,"ty":0,"nm":"","ln":"precomp_RfDd4rmVgmJyxj0mb5wEN36","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WGAc3unn49i1X_sP6DJzb"},{"ddd":0,"ind":37,"ty":0,"nm":"","ln":"precomp_1l5U5Xi9kUS3sWCtzTudP37","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"hOcBg6WrhGWjvLQ2hfSPP"}]},{"id":"Y3OtUUAm82LRhIBtdFQ2e","layers":[]},{"h":45,"id":"dC55gwtCj2mDruyZNTnJp","p":"","u":"","w":45,"e":1},{"id":"7tf_EB3oA-gN0bEJIcz6k","layers":[{"ddd":0,"ind":42,"ty":2,"nm":"","ln":"dC55gwtCj2mDruyZNTnJp42","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"dC55gwtCj2mDruyZNTnJp"}]},{"id":"tjX1Ci0HNdCrdAAWwxlpR","layers":[{"ddd":0,"ind":44,"ty":4,"nm":"","ln":"vMODVCBbSPqYKc1Xky-2A44","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"_4pY2FZwsa3bNGETt9MdU","layers":[{"ddd":0,"ind":43,"ty":0,"nm":"","td":1,"ln":"precomp_aZOWBUUvSoGWrH0Ctf9wG43","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"tjX1Ci0HNdCrdAAWwxlpR"},{"ddd":0,"ind":41,"ty":0,"nm":"","tt":1,"ln":"precomp_sFNc3UEW21KwfCa2cHoLd41","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7tf_EB3oA-gN0bEJIcz6k"}]},{"id":"pPBlv5PmDw7NlYGuONgpx","layers":[]},{"id":"tDsioldGoBkvTQ4PKAVLL","layers":[]},{"id":"J1B0qVspRM_3bvXSjoLp0","layers":[{"ddd":0,"ind":39,"ty":0,"nm":"","ln":"precomp_aG01j4T59Lowhabf28VI439","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Y3OtUUAm82LRhIBtdFQ2e"},{"ddd":0,"ind":40,"ty":0,"nm":"","ln":"precomp_sFNc3UEW21KwfCa2cHoLd40","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_4pY2FZwsa3bNGETt9MdU"},{"ddd":0,"ind":45,"ty":0,"nm":"","ln":"precomp_kI8LfSm5UV9rVR2-3jK_u45","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"pPBlv5PmDw7NlYGuONgpx"},{"ddd":0,"ind":46,"ty":0,"nm":"","ln":"precomp_qA5Czaceu-xnZ6nZZeB5_46","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"tDsioldGoBkvTQ4PKAVLL"}]},{"id":"0jidQ1Pf1dzayoEQS9Tj6","layers":[]},{"h":45,"id":"YzbrT6xb53YGIN4wK60XH","p":"","u":"","w":45,"e":1},{"id":"Vp-UaGN-O-UoLlEjkHRIA","layers":[{"ddd":0,"ind":51,"ty":2,"nm":"","ln":"YzbrT6xb53YGIN4wK60XH51","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"YzbrT6xb53YGIN4wK60XH"}]},{"id":"o2QQYShkbWSG_G2DJ_KZg","layers":[{"ddd":0,"ind":53,"ty":4,"nm":"","ln":"VgDrIgD6hS-huxHTezpep53","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"gwp_wmRVfWlDDQxd1MRcb","layers":[{"ddd":0,"ind":52,"ty":0,"nm":"","td":1,"ln":"precomp_TGhzUSPLQFbajKqksVQt952","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"o2QQYShkbWSG_G2DJ_KZg"},{"ddd":0,"ind":50,"ty":0,"nm":"","tt":1,"ln":"precomp_fvWkWuqsI-lKC9kYt3GJq50","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"Vp-UaGN-O-UoLlEjkHRIA"}]},{"id":"f7LcMMGmkX4wUrKOuBt0x","layers":[]},{"id":"xChQfUdYh69G7igoU8G3t","layers":[]},{"id":"qrJiCHr7n5E_Ea20SXw_6","layers":[{"ddd":0,"ind":48,"ty":0,"nm":"","ln":"precomp_sprtaq4DHHne_f_0m_Xco48","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"0jidQ1Pf1dzayoEQS9Tj6"},{"ddd":0,"ind":49,"ty":0,"nm":"","ln":"precomp_fvWkWuqsI-lKC9kYt3GJq49","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"gwp_wmRVfWlDDQxd1MRcb"},{"ddd":0,"ind":54,"ty":0,"nm":"","ln":"precomp_gl-SeSF4acJPrUTGE1Q0x54","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"f7LcMMGmkX4wUrKOuBt0x"},{"ddd":0,"ind":55,"ty":0,"nm":"","ln":"precomp_2fTtbdZkGTIMfy4xp7XhH55","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"xChQfUdYh69G7igoU8G3t"}]},{"id":"t7xx1Hf5FWy-MjgSMJBuf","layers":[]},{"h":45,"id":"fqcpsaNvzHM_SxaUy1aLe","p":"","u":"","w":45,"e":1},{"id":"vm51j4-ITYhMwNfDG0dFB","layers":[{"ddd":0,"ind":60,"ty":2,"nm":"","ln":"fqcpsaNvzHM_SxaUy1aLe60","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"fqcpsaNvzHM_SxaUy1aLe"}]},{"id":"jdGJrUrXy_5VKDgrLIdSu","layers":[{"ddd":0,"ind":62,"ty":4,"nm":"","ln":"cQaSqYxxn9xH5PeejEVnt62","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"OPIKbLgNONyCrlTRzcshu","layers":[{"ddd":0,"ind":61,"ty":0,"nm":"","td":1,"ln":"precomp_oHvD3iIf53AeKY3rTRsrz61","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"jdGJrUrXy_5VKDgrLIdSu"},{"ddd":0,"ind":59,"ty":0,"nm":"","tt":1,"ln":"precomp_Q-HkteGRQnbReZE2Xikpn59","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"vm51j4-ITYhMwNfDG0dFB"}]},{"id":"wQVI65kJQ20PPPqTaP0uu","layers":[]},{"id":"6cEnfUtIt4WDUt09BUofz","layers":[]},{"id":"h5L-p3LNkHprJpPK0qqug","layers":[{"ddd":0,"ind":57,"ty":0,"nm":"","ln":"precomp_wU9yIr_BCB9GU0Tonnxy857","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"t7xx1Hf5FWy-MjgSMJBuf"},{"ddd":0,"ind":58,"ty":0,"nm":"","ln":"precomp_Q-HkteGRQnbReZE2Xikpn58","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"OPIKbLgNONyCrlTRzcshu"},{"ddd":0,"ind":63,"ty":0,"nm":"","ln":"precomp_8oShG4NrmzH8s_lDetPvp63","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"wQVI65kJQ20PPPqTaP0uu"},{"ddd":0,"ind":64,"ty":0,"nm":"","ln":"precomp_r7v5nvcPo33_5eMaLa6De64","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"6cEnfUtIt4WDUt09BUofz"}]},{"id":"7tFvfT0MS3hFFgFTuhPHd","layers":[]},{"h":45,"id":"KlJNPoQ58F7Wo7mcGMItH","p":"","u":"","w":45,"e":1},{"id":"CmLQifVYEJDu2-iVUi1_u","layers":[{"ddd":0,"ind":69,"ty":2,"nm":"","ln":"KlJNPoQ58F7Wo7mcGMItH69","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"KlJNPoQ58F7Wo7mcGMItH"}]},{"id":"WGOk_tUA_MPsW_qVKhgHN","layers":[{"ddd":0,"ind":71,"ty":4,"nm":"","ln":"7n5aBggFWXcU5vLZnatOG71","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"3BjwZ_8FKzno7R_KYXsyZ","layers":[{"ddd":0,"ind":70,"ty":0,"nm":"","td":1,"ln":"precomp_JKtaq9ekMsEHppNMxgT3r70","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WGOk_tUA_MPsW_qVKhgHN"},{"ddd":0,"ind":68,"ty":0,"nm":"","tt":1,"ln":"precomp_hgNGEIN_FrZau1maWS0fe68","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"CmLQifVYEJDu2-iVUi1_u"}]},{"id":"CSOBB3P2mmX2Qk6PgJDhP","layers":[]},{"id":"_AZgJbxPjMn98N9ieYDHP","layers":[]},{"id":"oDfxAfxXh38-S9jmq5wia","layers":[{"ddd":0,"ind":66,"ty":0,"nm":"","ln":"precomp_RRC1Hrf0XwTBjpR-VlJth66","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7tFvfT0MS3hFFgFTuhPHd"},{"ddd":0,"ind":67,"ty":0,"nm":"","ln":"precomp_hgNGEIN_FrZau1maWS0fe67","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"3BjwZ_8FKzno7R_KYXsyZ"},{"ddd":0,"ind":72,"ty":0,"nm":"","ln":"precomp_0sH0rlMC2ggl_qqTrhOp072","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"CSOBB3P2mmX2Qk6PgJDhP"},{"ddd":0,"ind":73,"ty":0,"nm":"","ln":"precomp_UXT-dP3Wz-KVlpS_I-EoG73","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_AZgJbxPjMn98N9ieYDHP"}]},{"id":"PMKgimJDrF8d9y87-WkbI","layers":[]},{"h":45,"id":"cViK9O9AHboQ1BfqUYZbT","p":"","u":"","w":45,"e":1},{"id":"XFtM0cPMJduDpcUKDr9jb","layers":[{"ddd":0,"ind":78,"ty":2,"nm":"","ln":"cViK9O9AHboQ1BfqUYZbT78","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"cViK9O9AHboQ1BfqUYZbT"}]},{"id":"2Qz62AbVbwj5PTBDWUEmK","layers":[{"ddd":0,"ind":80,"ty":4,"nm":"","ln":"1aiEP35AUtJblW0GiAwrp80","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"KAkyfeXLoDfsNaCOz-h8r","layers":[{"ddd":0,"ind":79,"ty":0,"nm":"","td":1,"ln":"precomp_lDeAsJx2DG-I9lcoSv7iE79","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"2Qz62AbVbwj5PTBDWUEmK"},{"ddd":0,"ind":77,"ty":0,"nm":"","tt":1,"ln":"precomp_ajdR7D5gGuBWAlDO-fjL077","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"XFtM0cPMJduDpcUKDr9jb"}]},{"id":"VEGivJ-PDkPqBP7SncFm3","layers":[]},{"id":"D_SaaHHlJmTMqxlAmFJ9U","layers":[]},{"id":"5-RxkO4CxIh7glDn4PoL7","layers":[{"ddd":0,"ind":75,"ty":0,"nm":"","ln":"precomp_YKH9EuCB6wxk49Fz2HY2V75","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"PMKgimJDrF8d9y87-WkbI"},{"ddd":0,"ind":76,"ty":0,"nm":"","ln":"precomp_ajdR7D5gGuBWAlDO-fjL076","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"KAkyfeXLoDfsNaCOz-h8r"},{"ddd":0,"ind":81,"ty":0,"nm":"","ln":"precomp__YUWdV5VSM7t1bzePz2ho81","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"VEGivJ-PDkPqBP7SncFm3"},{"ddd":0,"ind":82,"ty":0,"nm":"","ln":"precomp_6fwgiJqena1z2UqemcAHL82","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"D_SaaHHlJmTMqxlAmFJ9U"}]},{"id":"ZRlIQL7d4eS2xBrvVMouH","layers":[]},{"h":45,"id":"tYa4S4YKwhi7Jp7sMuhZb","p":"","u":"","w":45,"e":1},{"id":"4F3u9bCmjej6tBzy5-IGg","layers":[{"ddd":0,"ind":87,"ty":2,"nm":"","ln":"tYa4S4YKwhi7Jp7sMuhZb87","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"tYa4S4YKwhi7Jp7sMuhZb"}]},{"id":"7SJ2-EqyY1qyMrifgj_EE","layers":[{"ddd":0,"ind":89,"ty":4,"nm":"","ln":"iHKtduHJCxWagsBhplphy89","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"nGqHSg6Ftu6HE3TDIpSbU","layers":[{"ddd":0,"ind":88,"ty":0,"nm":"","td":1,"ln":"precomp_CCqmsV0_UpPD6Y5LSywja88","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7SJ2-EqyY1qyMrifgj_EE"},{"ddd":0,"ind":86,"ty":0,"nm":"","tt":1,"ln":"precomp_vInkXFc16m773dIZxW0T486","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"4F3u9bCmjej6tBzy5-IGg"}]},{"id":"DTMJFY00QLo6jabxCR_Ma","layers":[]},{"id":"gwX8Ym-Rv0VftkUicPn87","layers":[]},{"id":"5Uo0TfeEtoqlVjJqqYTxD","layers":[{"ddd":0,"ind":84,"ty":0,"nm":"","ln":"precomp_gGq49n4pSUaxPv-pohD2G84","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"ZRlIQL7d4eS2xBrvVMouH"},{"ddd":0,"ind":85,"ty":0,"nm":"","ln":"precomp_vInkXFc16m773dIZxW0T485","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"nGqHSg6Ftu6HE3TDIpSbU"},{"ddd":0,"ind":90,"ty":0,"nm":"","ln":"precomp_fK8W-CAfhHYmhXh0BGX_O90","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DTMJFY00QLo6jabxCR_Ma"},{"ddd":0,"ind":91,"ty":0,"nm":"","ln":"precomp_qTJVk0VZ7m2dElbE0Mywb91","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"gwX8Ym-Rv0VftkUicPn87"}]},{"id":"BcoNf6Y_RIhNZgJaEjnIt","layers":[]},{"h":45,"id":"DsjVleWpgzrBoxGjhaksk","p":"","u":"","w":45,"e":1},{"id":"QmkZO3sTxfFF7jnSD_TX-","layers":[{"ddd":0,"ind":96,"ty":2,"nm":"","ln":"DsjVleWpgzrBoxGjhaksk96","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"DsjVleWpgzrBoxGjhaksk"}]},{"id":"L6YH5CPda1HWf3enGY6hA","layers":[{"ddd":0,"ind":98,"ty":4,"nm":"","ln":"Jic2KHlWLtghzvzF_tQVH98","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"DqGTVzbvRLsDm0T1qriQb","layers":[{"ddd":0,"ind":97,"ty":0,"nm":"","td":1,"ln":"precomp_WqJF8Kk99VYevX46AovFE97","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"L6YH5CPda1HWf3enGY6hA"},{"ddd":0,"ind":95,"ty":0,"nm":"","tt":1,"ln":"precomp_5Bg4Mf1zEPy9aqgje1rpG95","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"QmkZO3sTxfFF7jnSD_TX-"}]},{"id":"WiE9OwVSFoqVwU1EY-kJy","layers":[]},{"id":"YCwAp7ab_Ud-hfwGAEM8-","layers":[]},{"id":"CpQ1ZpGf4gTkX2T1IUN8H","layers":[{"ddd":0,"ind":93,"ty":0,"nm":"","ln":"precomp_9sBBt5Xbv3Inl99acBOnq93","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"BcoNf6Y_RIhNZgJaEjnIt"},{"ddd":0,"ind":94,"ty":0,"nm":"","ln":"precomp_5Bg4Mf1zEPy9aqgje1rpG94","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"DqGTVzbvRLsDm0T1qriQb"},{"ddd":0,"ind":99,"ty":0,"nm":"","ln":"precomp_vmUHWpkhDWsQOou4NiSA599","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WiE9OwVSFoqVwU1EY-kJy"},{"ddd":0,"ind":100,"ty":0,"nm":"","ln":"precomp_QkW_SmjrVLfZX3dZF9IE_100","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"YCwAp7ab_Ud-hfwGAEM8-"}]},{"id":"1K-kp2YUW1BD-x4l_ShCV","layers":[]},{"h":45,"id":"F1QRPA2dfkw3YPj-Cbmu9","p":"","u":"","w":45,"e":1},{"id":"9ptuOhLV2jDupLu5dUXIN","layers":[{"ddd":0,"ind":105,"ty":2,"nm":"","ln":"F1QRPA2dfkw3YPj-Cbmu9105","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"F1QRPA2dfkw3YPj-Cbmu9"}]},{"id":"WadhOAcrUye2NeuuSzezY","layers":[{"ddd":0,"ind":107,"ty":4,"nm":"","ln":"vrlSu1wf7UwySTxBtKBW2107","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"68UgXz-rgXE3a1aMmuVTg","layers":[{"ddd":0,"ind":106,"ty":0,"nm":"","td":1,"ln":"precomp_BSUYYXXCkttTGfdxVymJM106","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WadhOAcrUye2NeuuSzezY"},{"ddd":0,"ind":104,"ty":0,"nm":"","tt":1,"ln":"precomp_VaRqxJvTSrdGzLe0vvUHw104","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"9ptuOhLV2jDupLu5dUXIN"}]},{"id":"1QD8cZs5OuekLdm5wOdWU","layers":[]},{"id":"LKTI3FDCmeVuXUV_mFRUC","layers":[]},{"id":"xl6s-Qge6NvJxaxQCcb23","layers":[{"ddd":0,"ind":102,"ty":0,"nm":"","ln":"precomp_4WIRC_itvjJr8qxQxBUPa102","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1K-kp2YUW1BD-x4l_ShCV"},{"ddd":0,"ind":103,"ty":0,"nm":"","ln":"precomp_VaRqxJvTSrdGzLe0vvUHw103","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"68UgXz-rgXE3a1aMmuVTg"},{"ddd":0,"ind":108,"ty":0,"nm":"","ln":"precomp_J3FSFeT5NHGP2DAdzdEg6108","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1QD8cZs5OuekLdm5wOdWU"},{"ddd":0,"ind":109,"ty":0,"nm":"","ln":"precomp_o9JOkwCMvgntLdIhnIHP8109","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"LKTI3FDCmeVuXUV_mFRUC"}]},{"id":"audEMVOnb9eAA_36XJgj6","layers":[]},{"h":45,"id":"yMAiH_0ij8NPCgYFt_C03","p":"","u":"","w":45,"e":1},{"id":"jaxZMuWTn5qj9bIWUXoIx","layers":[{"ddd":0,"ind":114,"ty":2,"nm":"","ln":"yMAiH_0ij8NPCgYFt_C03114","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"yMAiH_0ij8NPCgYFt_C03"}]},{"id":"fRW_MYHKStky_onCNdGmK","layers":[{"ddd":0,"ind":116,"ty":4,"nm":"","ln":"Okz61lW_B0UD3lq4R6jWl116","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"w9WEd0QCCBY3n4pGBuSzq","layers":[{"ddd":0,"ind":115,"ty":0,"nm":"","td":1,"ln":"precomp_32jUcvb7qJfoU4YvspvhM115","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"fRW_MYHKStky_onCNdGmK"},{"ddd":0,"ind":113,"ty":0,"nm":"","tt":1,"ln":"precomp_FVN8Bn_zqeVo5FHHL50GQ113","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"jaxZMuWTn5qj9bIWUXoIx"}]},{"id":"jIpTwVf17EBGRQOXdAEwT","layers":[]},{"id":"QLDB12Q-AQDcRpLlu8_6z","layers":[]},{"id":"TOgqut4P1xneEbaIjqpMf","layers":[{"ddd":0,"ind":111,"ty":0,"nm":"","ln":"precomp_f5yE1bVb2F98xgv9GbEd3111","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"audEMVOnb9eAA_36XJgj6"},{"ddd":0,"ind":112,"ty":0,"nm":"","ln":"precomp_FVN8Bn_zqeVo5FHHL50GQ112","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"w9WEd0QCCBY3n4pGBuSzq"},{"ddd":0,"ind":117,"ty":0,"nm":"","ln":"precomp_DPz5QuIBbh3HQXA4NLmd_117","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"jIpTwVf17EBGRQOXdAEwT"},{"ddd":0,"ind":118,"ty":0,"nm":"","ln":"precomp_g55VHJ8UcwoUaf_QZcyGS118","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"QLDB12Q-AQDcRpLlu8_6z"}]},{"id":"TNyOqEhDvKeOdy8mthy-R","layers":[]},{"h":45,"id":"dbRx-LBMtj1eg4CrjVmaE","p":"","u":"","w":45,"e":1},{"id":"_NWgnUuTUDJDEjqG_fUCY","layers":[{"ddd":0,"ind":123,"ty":2,"nm":"","ln":"dbRx-LBMtj1eg4CrjVmaE123","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"dbRx-LBMtj1eg4CrjVmaE"}]},{"id":"AhZKbO_rThVn25U1YR8ZI","layers":[{"ddd":0,"ind":125,"ty":4,"nm":"","ln":"BTUobg95a8Gcjhb3mW9gK125","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"L-RIwYHKoSF4VepnNgVTf","layers":[{"ddd":0,"ind":124,"ty":0,"nm":"","td":1,"ln":"precomp_vX4YnUd6McN9BzTyaC6sX124","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"AhZKbO_rThVn25U1YR8ZI"},{"ddd":0,"ind":122,"ty":0,"nm":"","tt":1,"ln":"precomp_ujVmB6h-peELkNal61x2d122","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_NWgnUuTUDJDEjqG_fUCY"}]},{"id":"_8WmDsJxdtEQXwREpaDNa","layers":[]},{"id":"V5JBvz-e7OTwk_aqG4Ip_","layers":[]},{"id":"PrdF5u-8Fw0h_KbqbYfJG","layers":[{"ddd":0,"ind":120,"ty":0,"nm":"","ln":"precomp_pFM9KIiGhKm3krnexNwEc120","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"TNyOqEhDvKeOdy8mthy-R"},{"ddd":0,"ind":121,"ty":0,"nm":"","ln":"precomp_ujVmB6h-peELkNal61x2d121","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"L-RIwYHKoSF4VepnNgVTf"},{"ddd":0,"ind":126,"ty":0,"nm":"","ln":"precomp_PJgxEEO_2R3gHbWB3b79z126","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_8WmDsJxdtEQXwREpaDNa"},{"ddd":0,"ind":127,"ty":0,"nm":"","ln":"precomp_0pbqn6reFmlLvMjIDBquj127","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"V5JBvz-e7OTwk_aqG4Ip_"}]},{"id":"A7SAQDGyVoMMpKGbN9Lu8","layers":[]},{"h":45,"id":"QdbfzXBcdT5-zstdySSeh","p":"","u":"","w":45,"e":1},{"id":"4TMtDGwGyKYTvUWHNrUyw","layers":[{"ddd":0,"ind":132,"ty":2,"nm":"","ln":"QdbfzXBcdT5-zstdySSeh132","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"QdbfzXBcdT5-zstdySSeh"}]},{"id":"bT_za47g-WZT9rog4k49Q","layers":[{"ddd":0,"ind":134,"ty":4,"nm":"","ln":"Iz42PypTYkq7YWpc27xS9134","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"0pTZrvushEc5ffEe2ZL-c","layers":[{"ddd":0,"ind":133,"ty":0,"nm":"","td":1,"ln":"precomp_dL7yp9kd2WaLG6Sx3_8oH133","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"bT_za47g-WZT9rog4k49Q"},{"ddd":0,"ind":131,"ty":0,"nm":"","tt":1,"ln":"precomp_tdkcCs1pf9285tcsB_8KR131","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"4TMtDGwGyKYTvUWHNrUyw"}]},{"id":"gA-17tVpvBg4FWlq0_UPD","layers":[]},{"id":"WdlkXqcANpGSLJ8ZlKBnM","layers":[]},{"id":"8t0xGXsZM9SkB_w3QfZR7","layers":[{"ddd":0,"ind":129,"ty":0,"nm":"","ln":"precomp_-byrD89H-SGf8zPzZpivN129","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"A7SAQDGyVoMMpKGbN9Lu8"},{"ddd":0,"ind":130,"ty":0,"nm":"","ln":"precomp_tdkcCs1pf9285tcsB_8KR130","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"0pTZrvushEc5ffEe2ZL-c"},{"ddd":0,"ind":135,"ty":0,"nm":"","ln":"precomp_gx2lCEIyhQWirf91cE302135","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"gA-17tVpvBg4FWlq0_UPD"},{"ddd":0,"ind":136,"ty":0,"nm":"","ln":"precomp_jUzdUmmxNjk0-_eH7Eage136","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"WdlkXqcANpGSLJ8ZlKBnM"}]},{"id":"NXdD84xzNm_5IlR9lF6x6","layers":[]},{"h":45,"id":"bGs5YM-yayqDfS4JSY2Us","p":"","u":"","w":45,"e":1},{"id":"AdDHZaxutCXCAyH8iMdks","layers":[{"ddd":0,"ind":141,"ty":2,"nm":"","ln":"bGs5YM-yayqDfS4JSY2Us141","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"bGs5YM-yayqDfS4JSY2Us"}]},{"id":"v6gw2RF7VZTFdYsGk1arX","layers":[{"ddd":0,"ind":143,"ty":4,"nm":"","ln":"nkG6i9mtERWLLCr0btA8-143","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"rvQvc-0gZ5-1subbV35ko","layers":[{"ddd":0,"ind":142,"ty":0,"nm":"","td":1,"ln":"precomp_QrQPJ2Mw7fOdJbXAN7fFc142","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"v6gw2RF7VZTFdYsGk1arX"},{"ddd":0,"ind":140,"ty":0,"nm":"","tt":1,"ln":"precomp_V6QZbHZt9WpZ36I07gYIN140","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"AdDHZaxutCXCAyH8iMdks"}]},{"id":"-ED6KVlwjEBIljTZh_MHA","layers":[]},{"id":"edGA8TI-3GMoaWSUpeJpx","layers":[]},{"id":"eDhrm1tYtPflD9uGIIHf0","layers":[{"ddd":0,"ind":138,"ty":0,"nm":"","ln":"precomp_prnlqPKw89Q6lmTxSqZ0U138","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"NXdD84xzNm_5IlR9lF6x6"},{"ddd":0,"ind":139,"ty":0,"nm":"","ln":"precomp_V6QZbHZt9WpZ36I07gYIN139","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"rvQvc-0gZ5-1subbV35ko"},{"ddd":0,"ind":144,"ty":0,"nm":"","ln":"precomp_Ag0pRzFLCZFh1hXRqLose144","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"-ED6KVlwjEBIljTZh_MHA"},{"ddd":0,"ind":145,"ty":0,"nm":"","ln":"precomp_Hscx4WWZyXFdTa65zZ_o4145","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"edGA8TI-3GMoaWSUpeJpx"}]},{"id":"IBkGZTMIAbw0myFQ2KTnd","layers":[]},{"h":184,"id":"1QxmZoRYrZLI0vocQMryy","p":"","u":"","w":218,"e":1},{"id":"-c9slQ58f4tDUwFfHgPia","layers":[{"ddd":0,"ind":150,"ty":2,"nm":"","ln":"1QxmZoRYrZLI0vocQMryy150","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49891,49908]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"refId":"1QxmZoRYrZLI0vocQMryy"}]},{"id":"7CcuiSOKf92D4GeDR_crK","layers":[{"ddd":0,"ind":152,"ty":4,"nm":"","ln":"pspzJhHQqDW4DXWbbCLGj152","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[218,184]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"p-IPk1pV80qaVqHMbxR8c","layers":[{"ddd":0,"ind":151,"ty":0,"nm":"","td":1,"ln":"precomp_0Hoch-YvqUTuJ4S3uR8_4151","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"7CcuiSOKf92D4GeDR_crK"},{"ddd":0,"ind":149,"ty":0,"nm":"","tt":1,"ln":"precomp_btzyL_rTQWvZnZ2dxn5Hp149","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"-c9slQ58f4tDUwFfHgPia"}]},{"id":"tFBMdpuqXJr3Ovlf2PRdh","layers":[]},{"id":"_p3Wu-oHCgy_YfDg2IeB6","layers":[]},{"id":"r4zUNTw-LgX_hVpVRUSrO","layers":[{"ddd":0,"ind":147,"ty":0,"nm":"","ln":"precomp_iYeHMCl-MVatHKl84o1aL147","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"IBkGZTMIAbw0myFQ2KTnd"},{"ddd":0,"ind":148,"ty":0,"nm":"","ln":"precomp_btzyL_rTQWvZnZ2dxn5Hp148","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"p-IPk1pV80qaVqHMbxR8c"},{"ddd":0,"ind":153,"ty":0,"nm":"","ln":"precomp_mr9ZZnPlzmVFoCI4Ccfu4153","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"tFBMdpuqXJr3Ovlf2PRdh"},{"ddd":0,"ind":154,"ty":0,"nm":"","ln":"precomp_qVu1Wt-YHmceFfSJE97jC154","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"_p3Wu-oHCgy_YfDg2IeB6"}]},{"id":"sNVXS2BGTCHwZKXmYY7lV","layers":[]},{"id":"s84XEl4j37T9YupJrsBTP","layers":[{"ddd":0,"ind":157,"ty":4,"nm":"","ln":"A82bSnYkMtw1q-s5GWvDu157","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":193,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[1074,300]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.01,0.03,0.09]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"wrkEviRNVA6uf3S-T7YLI","layers":[{"ddd":0,"ind":1,"ty":0,"nm":"","ln":"precomp__yKsry3HDasKSgULzl3-Y1","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49586.5,50034.5],"h":1},{"t":0,"s":[49586.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49636.5,50034.5],"h":1},{"t":24,"s":[49636.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49686.5,50034.5],"h":1},{"t":48,"s":[49686.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49736.5,50034.5],"h":1},{"t":72,"s":[49736.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49786.5,50034.5],"h":1},{"t":96,"s":[49786.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49836.5,50034.5],"h":1},{"t":120,"s":[49836.5,50034.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49886.5,50034.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"FcRGxR1DAk6L5FB4ij6KO"},{"ddd":0,"ind":3,"ty":0,"nm":"","ln":"precomp_SF0yrQrX06RcGzPjLAChd3","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49585.5,50066],"h":1},{"t":0,"s":[49585.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49635.5,50066],"h":1},{"t":24,"s":[49635.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49685.5,50066],"h":1},{"t":48,"s":[49685.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49735.5,50066],"h":1},{"t":72,"s":[49735.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49785.5,50066],"h":1},{"t":96,"s":[49785.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49835.5,50066],"h":1},{"t":120,"s":[49835.5,50066],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49885.5,50066],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"LngS0iiQ16cdJYvpEDGzR"},{"ddd":0,"ind":11,"ty":0,"nm":"","ln":"precomp_P-HiwuAFBTT62TLTZqZll11","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49635.5,50000],"h":1},{"t":0,"s":[49635.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49685.5,50000],"h":1},{"t":24,"s":[49685.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49735.5,50000],"h":1},{"t":48,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49785.5,50000],"h":1},{"t":72,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49835.5,50000],"h":1},{"t":96,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49885.5,50000],"h":1},{"t":120,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49935.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"1NdNgVBQJQuQHk4FTmSTr"},{"ddd":0,"ind":20,"ty":0,"nm":"","ln":"precomp_OHRvkPTSXZSH1FGWcuMBz20","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49685.5,50000],"h":1},{"t":0,"s":[49685.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49735.5,50000],"h":1},{"t":24,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49785.5,50000],"h":1},{"t":48,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49835.5,50000],"h":1},{"t":72,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49885.5,50000],"h":1},{"t":96,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49935.5,50000],"h":1},{"t":120,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49985.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"m9dH0F5MwXsLDDQSBUxbN"},{"ddd":0,"ind":29,"ty":0,"nm":"","ln":"precomp_CO6d-RYRT9HfAASTjepwL29","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49735.5,50000],"h":1},{"t":0,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49785.5,50000],"h":1},{"t":24,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49835.5,50000],"h":1},{"t":48,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49885.5,50000],"h":1},{"t":72,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49935.5,50000],"h":1},{"t":96,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49985.5,50000],"h":1},{"t":120,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50035.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"0gYS5jhAGIs7crB8QrUz2"},{"ddd":0,"ind":38,"ty":0,"nm":"","ln":"precomp_uXclUMI0uHzhsIjwO6aA638","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49785.5,50000],"h":1},{"t":0,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49835.5,50000],"h":1},{"t":24,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49885.5,50000],"h":1},{"t":48,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49935.5,50000],"h":1},{"t":72,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49985.5,50000],"h":1},{"t":96,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50035.5,50000],"h":1},{"t":120,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50085.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"J1B0qVspRM_3bvXSjoLp0"},{"ddd":0,"ind":47,"ty":0,"nm":"","ln":"precomp_MZ9z5Idn8oQWHiLUjqjMX47","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49835.5,50000],"h":1},{"t":0,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49885.5,50000],"h":1},{"t":24,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49935.5,50000],"h":1},{"t":48,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49985.5,50000],"h":1},{"t":72,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50035.5,50000],"h":1},{"t":96,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50085.5,50000],"h":1},{"t":120,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50135.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"qrJiCHr7n5E_Ea20SXw_6"},{"ddd":0,"ind":56,"ty":0,"nm":"","ln":"precomp_gVNnp2cRIYK9pXE8eQEcs56","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49885.5,50000],"h":1},{"t":0,"s":[49885.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49935.5,50000],"h":1},{"t":24,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49985.5,50000],"h":1},{"t":48,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50035.5,50000],"h":1},{"t":72,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50085.5,50000],"h":1},{"t":96,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50135.5,50000],"h":1},{"t":120,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50185.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"h5L-p3LNkHprJpPK0qqug"},{"ddd":0,"ind":65,"ty":0,"nm":"","ln":"precomp_ypWVWU7MDUZTi6l_tnw7N65","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49935.5,50000],"h":1},{"t":0,"s":[49935.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49985.5,50000],"h":1},{"t":24,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50035.5,50000],"h":1},{"t":48,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50085.5,50000],"h":1},{"t":72,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50135.5,50000],"h":1},{"t":96,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50185.5,50000],"h":1},{"t":120,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50235.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"oDfxAfxXh38-S9jmq5wia"},{"ddd":0,"ind":74,"ty":0,"nm":"","ln":"precomp_zyOsbRZBsqLj4MBO26Uvn74","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49985.5,50000],"h":1},{"t":0,"s":[49985.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50035.5,50000],"h":1},{"t":24,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50085.5,50000],"h":1},{"t":48,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50135.5,50000],"h":1},{"t":72,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50185.5,50000],"h":1},{"t":96,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50235.5,50000],"h":1},{"t":120,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50285.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"5-RxkO4CxIh7glDn4PoL7"},{"ddd":0,"ind":83,"ty":0,"nm":"","ln":"precomp_vCeUwru4p6fSgpN3XlLUI83","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[50035.5,50000],"h":1},{"t":0,"s":[50035.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50085.5,50000],"h":1},{"t":24,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50135.5,50000],"h":1},{"t":48,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50185.5,50000],"h":1},{"t":72,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50235.5,50000],"h":1},{"t":96,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50285.5,50000],"h":1},{"t":120,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50428,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"5Uo0TfeEtoqlVjJqqYTxD"},{"ddd":0,"ind":92,"ty":0,"nm":"","ln":"precomp_SCTeRrcs5fvVcyq2ueJzp92","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":120,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":144,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50085.5,50000],"h":1},{"t":0,"s":[50085.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50135.5,50000],"h":1},{"t":24,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50185.5,50000],"h":1},{"t":48,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50235.5,50000],"h":1},{"t":72,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50285.5,50000],"h":1},{"t":96,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50428,50000],"h":1},{"t":120,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"CpQ1ZpGf4gTkX2T1IUN8H"},{"ddd":0,"ind":101,"ty":0,"nm":"","ln":"precomp_3XehBm15W8gj9OGcWDBI6101","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":96,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":120,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50135.5,50000],"h":1},{"t":0,"s":[50135.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50185.5,50000],"h":1},{"t":24,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50235.5,50000],"h":1},{"t":48,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50285.5,50000],"h":1},{"t":72,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50428,50000],"h":1},{"t":96,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"xl6s-Qge6NvJxaxQCcb23"},{"ddd":0,"ind":110,"ty":0,"nm":"","ln":"precomp_SQGQ1DMuRkTyuxSnDukfv110","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":72,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":96,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50185.5,50000],"h":1},{"t":0,"s":[50185.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50235.5,50000],"h":1},{"t":24,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50285.5,50000],"h":1},{"t":48,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50428,50000],"h":1},{"t":72,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"TOgqut4P1xneEbaIjqpMf"},{"ddd":0,"ind":119,"ty":0,"nm":"","ln":"precomp_Ngqnv5u7c78bv1kKml-JZ119","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":48,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":72,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50235.5,50000],"h":1},{"t":0,"s":[50235.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50285.5,50000],"h":1},{"t":24,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50428,50000],"h":1},{"t":48,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"PrdF5u-8Fw0h_KbqbYfJG"},{"ddd":0,"ind":128,"ty":0,"nm":"","ln":"precomp_7SfQxvberzjgAVfhsi9pe128","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":1,"k":[{"t":0,"s":[49585.5,50000],"h":1},{"t":0,"s":[49585.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49635.5,50000],"h":1},{"t":24,"s":[49635.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49685.5,50000],"h":1},{"t":48,"s":[49685.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49735.5,50000],"h":1},{"t":72,"s":[49735.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49785.5,50000],"h":1},{"t":96,"s":[49785.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49835.5,50000],"h":1},{"t":120,"s":[49835.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49885.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"8t0xGXsZM9SkB_w3QfZR7"},{"ddd":0,"ind":137,"ty":0,"nm":"","ln":"precomp_SSbPtfB45NY2wk8qYEhVs137","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":24,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":48,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50285.5,50000],"h":1},{"t":0,"s":[50285.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50428,50000],"h":1},{"t":24,"s":[50428,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50478,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"eDhrm1tYtPflD9uGIIHf0"},{"ddd":0,"ind":146,"ty":0,"nm":"","ln":"precomp_MprMPTSLYQOXKH26z-kdy146","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50428,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"r4zUNTw-LgX_hVpVRUSrO"},{"ddd":0,"ind":155,"ty":0,"nm":"","ln":"precomp_gVQzIfkE2xkBlH7BKG3UV155","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"sNVXS2BGTCHwZKXmYY7lV"},{"ddd":0,"ind":156,"ty":0,"nm":"","ln":"precomp_XMJpyhoVl-fimMTztA3rw156","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"s84XEl4j37T9YupJrsBTP"}]}],"ddd":0,"fr":60,"h":300,"ip":0,"layers":[{"ddd":0,"ind":0,"ty":0,"nm":"","ln":"precomp_RhoI5eMdh0y036MGIYl__0","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[537,150]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":193,"st":0,"bm":0,"refId":"wrkEviRNVA6uf3S-T7YLI"}],"meta":{"g":"https://jitter.video"},"nm":"Basic-Task-Queue-[copy]","op":192,"v":"5.7.4","w":1074} diff --git a/frontend/docs/pages/blog/_fairness.json b/frontend/docs/pages/blog/_fairness.json index 9f57405a0..12927cff0 100644 --- a/frontend/docs/pages/blog/_fairness.json +++ b/frontend/docs/pages/blog/_fairness.json @@ -1 +1 @@ -{"assets":[{"id":"yulU8vWqKbRjf848fsLyv","layers":[]},{"h":45,"id":"9SBWCMPXgTML2euv-iBgA","p":"","u":"","w":45,"e":1},{"id":"UqSDkE0XTQUqModho1Nqi","layers":[{"ddd":0,"ind":5,"ty":2,"nm":"","ln":"9SBWCMPXgTML2euv-iBgA5","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"9SBWCMPXgTML2euv-iBgA"}]},{"id":"5mxpUCoqrlncqk7veyp6W","layers":[{"ddd":0,"ind":7,"ty":4,"nm":"","ln":"KtlaIh72UXZZKGZ7QBVey7","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"A1JemffokXxnP_lmyzRdG","layers":[{"ddd":0,"ind":6,"ty":0,"nm":"","td":1,"ln":"precomp_zzQpnEUsSYfK2gPHzxdUd6","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5mxpUCoqrlncqk7veyp6W"},{"ddd":0,"ind":4,"ty":0,"nm":"","tt":1,"ln":"precomp_OksBrZrYbv5y5uxxF9rDm4","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"UqSDkE0XTQUqModho1Nqi"}]},{"id":"6Q0uGMngSy8xbZRlgN2ZL","layers":[]},{"id":"T-fZio3s69dhBl8Tb3SkB","layers":[]},{"id":"KBnueAc3Jde2Y8D1VS1FK","layers":[{"ddd":0,"ind":2,"ty":0,"nm":"","ln":"precomp_lN5UJu9z1X5Iy4W_46ZMe2","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"yulU8vWqKbRjf848fsLyv"},{"ddd":0,"ind":3,"ty":0,"nm":"","ln":"precomp_OksBrZrYbv5y5uxxF9rDm3","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"A1JemffokXxnP_lmyzRdG"},{"ddd":0,"ind":8,"ty":0,"nm":"","ln":"precomp_zNjTgH-WJLhAC_GEcHSIZ8","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"6Q0uGMngSy8xbZRlgN2ZL"},{"ddd":0,"ind":9,"ty":0,"nm":"","ln":"precomp_1NTBbVkz6t7VZk29rg-I59","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"T-fZio3s69dhBl8Tb3SkB"}]},{"id":"5Z4NLo4VNrF65f8NQQaCz","layers":[]},{"h":45,"id":"54wIpGQO0hT4zPjKD5YML","p":"","u":"","w":45,"e":1},{"id":"w6pcpqFmHRgCi2N7Ce2Dr","layers":[{"ddd":0,"ind":14,"ty":2,"nm":"","ln":"54wIpGQO0hT4zPjKD5YML14","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"54wIpGQO0hT4zPjKD5YML"}]},{"id":"zI8F9r_1CNk8j4qDdGX9f","layers":[{"ddd":0,"ind":16,"ty":4,"nm":"","ln":"dgEplkXxtxt9PgzVCgOSd16","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"4xm9euMKW55qWh0wVXHNu","layers":[{"ddd":0,"ind":15,"ty":0,"nm":"","td":1,"ln":"precomp_gzbEYo-2zrAVvntLm82_X15","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"zI8F9r_1CNk8j4qDdGX9f"},{"ddd":0,"ind":13,"ty":0,"nm":"","tt":1,"ln":"precomp_LEyj12QSgOn2o35eiA6W513","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"w6pcpqFmHRgCi2N7Ce2Dr"}]},{"id":"eG4P1X90WGMjoNkCo5MIj","layers":[]},{"id":"XuZQhg1Zsbyl5STKQV1eg","layers":[]},{"id":"BLV0J7Lt7DnDPzvyTVtqn","layers":[{"ddd":0,"ind":11,"ty":0,"nm":"","ln":"precomp_1x6hBWKBWx23XY4Y871SG11","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5Z4NLo4VNrF65f8NQQaCz"},{"ddd":0,"ind":12,"ty":0,"nm":"","ln":"precomp_LEyj12QSgOn2o35eiA6W512","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"4xm9euMKW55qWh0wVXHNu"},{"ddd":0,"ind":17,"ty":0,"nm":"","ln":"precomp_sgCBn7zyaR9WNCY-0RQ2t17","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"eG4P1X90WGMjoNkCo5MIj"},{"ddd":0,"ind":18,"ty":0,"nm":"","ln":"precomp_lD1t3v2d1bBx2Vdjs7CxZ18","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"XuZQhg1Zsbyl5STKQV1eg"}]},{"id":"mrmbN9qnXIChot6qcjXUW","layers":[]},{"h":45,"id":"k8X9p_GQOpVtl_eFUE6BM","p":"","u":"","w":45,"e":1},{"id":"E4tejf1KL9G5aJMyCPDgn","layers":[{"ddd":0,"ind":23,"ty":2,"nm":"","ln":"k8X9p_GQOpVtl_eFUE6BM23","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"k8X9p_GQOpVtl_eFUE6BM"}]},{"id":"oChC2zUv8lIhWzD8WHDCT","layers":[{"ddd":0,"ind":25,"ty":4,"nm":"","ln":"lzIWCpc2IDnheKhtHZwCd25","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"s4JNvszG0Rocrs7luabF7","layers":[{"ddd":0,"ind":24,"ty":0,"nm":"","td":1,"ln":"precomp_1i1_DcRk-ljM8MsMLAAYI24","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"oChC2zUv8lIhWzD8WHDCT"},{"ddd":0,"ind":22,"ty":0,"nm":"","tt":1,"ln":"precomp_h4XDyNbqp2e2rcXAOQOvf22","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"E4tejf1KL9G5aJMyCPDgn"}]},{"id":"n_Bhwor14FwJouk92i9MG","layers":[]},{"id":"PCHJMoluuzRsH5QsuLPPX","layers":[]},{"id":"QaRXUJAbfNvzOK_o16lsL","layers":[{"ddd":0,"ind":20,"ty":0,"nm":"","ln":"precomp_Be-HG2PfKdgwnioT_8DYz20","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"mrmbN9qnXIChot6qcjXUW"},{"ddd":0,"ind":21,"ty":0,"nm":"","ln":"precomp_h4XDyNbqp2e2rcXAOQOvf21","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"s4JNvszG0Rocrs7luabF7"},{"ddd":0,"ind":26,"ty":0,"nm":"","ln":"precomp_r4yE1nKUPwjr2yombW0K726","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"n_Bhwor14FwJouk92i9MG"},{"ddd":0,"ind":27,"ty":0,"nm":"","ln":"precomp_L3sOXlZOeHoE_Kax8q_2Q27","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"PCHJMoluuzRsH5QsuLPPX"}]},{"id":"8vKxO1-bJikEpnUKbL2_b","layers":[]},{"h":45,"id":"GqiaBhF9SBurEPyxZSvm0","p":"","u":"","w":45,"e":1},{"id":"BXUACfPjKr6SZzJcORZoC","layers":[{"ddd":0,"ind":32,"ty":2,"nm":"","ln":"GqiaBhF9SBurEPyxZSvm032","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"GqiaBhF9SBurEPyxZSvm0"}]},{"id":"PtWDMFAMSGGRrKRxAqi2N","layers":[{"ddd":0,"ind":34,"ty":4,"nm":"","ln":"aDxZcAI8Y0LTd7_Clb_rF34","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"HocXy8XdhplJRJ0ad1aFy","layers":[{"ddd":0,"ind":33,"ty":0,"nm":"","td":1,"ln":"precomp_RvOWM-s-Pr0mC31NxAvyI33","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"PtWDMFAMSGGRrKRxAqi2N"},{"ddd":0,"ind":31,"ty":0,"nm":"","tt":1,"ln":"precomp_3L2NkHDXOfHRno3ho6tjN31","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"BXUACfPjKr6SZzJcORZoC"}]},{"id":"80Bg2LzytEwvf0wxY-DDr","layers":[]},{"id":"5inTWv2rSKvB-edhwbU-o","layers":[]},{"id":"Ck9MjVfGMNXBrK40rFMUG","layers":[{"ddd":0,"ind":29,"ty":0,"nm":"","ln":"precomp_-AEjgST_VTbF_ZfxfJXi429","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"8vKxO1-bJikEpnUKbL2_b"},{"ddd":0,"ind":30,"ty":0,"nm":"","ln":"precomp_3L2NkHDXOfHRno3ho6tjN30","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"HocXy8XdhplJRJ0ad1aFy"},{"ddd":0,"ind":35,"ty":0,"nm":"","ln":"precomp_ZXAcBzj7tpP__2gLJHixw35","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"80Bg2LzytEwvf0wxY-DDr"},{"ddd":0,"ind":36,"ty":0,"nm":"","ln":"precomp_U4ABa_Xf3hqlqKmjIoQR936","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5inTWv2rSKvB-edhwbU-o"}]},{"id":"oJrXBDzoBzuCS76SkUbZf","layers":[]},{"h":45,"id":"ZlnoUXgB-wjZUhxWJ1Xd2","p":"","u":"","w":45,"e":1},{"id":"9QDbIKRvMnpybiwDD-7PL","layers":[{"ddd":0,"ind":41,"ty":2,"nm":"","ln":"ZlnoUXgB-wjZUhxWJ1Xd241","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"ZlnoUXgB-wjZUhxWJ1Xd2"}]},{"id":"_EhuSBExkVk6Ro-Gd73vQ","layers":[{"ddd":0,"ind":43,"ty":4,"nm":"","ln":"6cmiZn0k_TX_CLEdz8O7o43","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"C5y6qIyb18jthHZnGhAT-","layers":[{"ddd":0,"ind":42,"ty":0,"nm":"","td":1,"ln":"precomp_VDVQAIlpbLFssyrXf6qJr42","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"_EhuSBExkVk6Ro-Gd73vQ"},{"ddd":0,"ind":40,"ty":0,"nm":"","tt":1,"ln":"precomp_pNm7M3lzfubMDkOVA9DiO40","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"9QDbIKRvMnpybiwDD-7PL"}]},{"id":"PMMyrEKZAuZ42y_y6Pere","layers":[]},{"id":"IWnwN26V2QiMSyKBRCBC2","layers":[]},{"id":"rp0ZHOpavceJcJHS_aO8n","layers":[{"ddd":0,"ind":38,"ty":0,"nm":"","ln":"precomp_Wjq69e6ApjX4rJeJzclfZ38","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"oJrXBDzoBzuCS76SkUbZf"},{"ddd":0,"ind":39,"ty":0,"nm":"","ln":"precomp_pNm7M3lzfubMDkOVA9DiO39","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"C5y6qIyb18jthHZnGhAT-"},{"ddd":0,"ind":44,"ty":0,"nm":"","ln":"precomp_Mtrziyf-MIpTDthKiw6cy44","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"PMMyrEKZAuZ42y_y6Pere"},{"ddd":0,"ind":45,"ty":0,"nm":"","ln":"precomp_qPcFPc8Y3WoCxLm6eCWjO45","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"IWnwN26V2QiMSyKBRCBC2"}]},{"id":"l_wZZpSzdTgCvEGLdUwry","layers":[]},{"h":45,"id":"sn24u7PbyWcud3MsI1WkY","p":"","u":"","w":45,"e":1},{"id":"dSeviyOqoF5NF9bI9B3ro","layers":[{"ddd":0,"ind":50,"ty":2,"nm":"","ln":"sn24u7PbyWcud3MsI1WkY50","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"sn24u7PbyWcud3MsI1WkY"}]},{"id":"w1-zLKK6qBsX0dU5RBkdd","layers":[{"ddd":0,"ind":52,"ty":4,"nm":"","ln":"KFoTmW8PjrTDSe_ekFKXw52","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"k6366sjR3D5SBF4ry-oAr","layers":[{"ddd":0,"ind":51,"ty":0,"nm":"","td":1,"ln":"precomp_H1_5vN07hSycKK-iiRPo651","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"w1-zLKK6qBsX0dU5RBkdd"},{"ddd":0,"ind":49,"ty":0,"nm":"","tt":1,"ln":"precomp_Y3RhhwTpsC5CnW98wHGMK49","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"dSeviyOqoF5NF9bI9B3ro"}]},{"id":"4XpcHh8IeANWZnQt58Etl","layers":[]},{"id":"6Z68thyJQcA7VPUxY4MHV","layers":[]},{"id":"ocTdvqp8qP0CBJN5AFzRL","layers":[{"ddd":0,"ind":47,"ty":0,"nm":"","ln":"precomp_mBNEgZ8lh_NKbVJwi-XkF47","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"l_wZZpSzdTgCvEGLdUwry"},{"ddd":0,"ind":48,"ty":0,"nm":"","ln":"precomp_Y3RhhwTpsC5CnW98wHGMK48","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"k6366sjR3D5SBF4ry-oAr"},{"ddd":0,"ind":53,"ty":0,"nm":"","ln":"precomp_uaRWdpGb-rApaovhxTTfu53","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"4XpcHh8IeANWZnQt58Etl"},{"ddd":0,"ind":54,"ty":0,"nm":"","ln":"precomp_A1M4DyDOpIUvT0zNYDLUX54","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"6Z68thyJQcA7VPUxY4MHV"}]},{"id":"OtDBv3qz5lWV9vuhoJ5Xx","layers":[]},{"h":45,"id":"fh4qoqFE-pFMiu5OB-T9z","p":"","u":"","w":45,"e":1},{"id":"Ld4LfTqtcd8e3kgTxWWk0","layers":[{"ddd":0,"ind":59,"ty":2,"nm":"","ln":"fh4qoqFE-pFMiu5OB-T9z59","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"fh4qoqFE-pFMiu5OB-T9z"}]},{"id":"gxbdMIWuVtNOJy10T1CSx","layers":[{"ddd":0,"ind":61,"ty":4,"nm":"","ln":"8CQ10jkMXuDCJQGq11pJr61","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"LA-4TDWxYyZftnSKBautr","layers":[{"ddd":0,"ind":60,"ty":0,"nm":"","td":1,"ln":"precomp_4Sc372Dh_ls7zu66xMM7_60","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"gxbdMIWuVtNOJy10T1CSx"},{"ddd":0,"ind":58,"ty":0,"nm":"","tt":1,"ln":"precomp_etwpsSqWxqp1UZLPqybjW58","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"Ld4LfTqtcd8e3kgTxWWk0"}]},{"id":"J0K5VwRB3vhxC4ypCBg2v","layers":[]},{"id":"VvYdnwXSrXmg-mh-Rcn1o","layers":[]},{"id":"tO9ekoSfn0rsYia7DQqMF","layers":[{"ddd":0,"ind":56,"ty":0,"nm":"","ln":"precomp_cMZ_cSCC-_GVm_xLHrO2r56","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"OtDBv3qz5lWV9vuhoJ5Xx"},{"ddd":0,"ind":57,"ty":0,"nm":"","ln":"precomp_etwpsSqWxqp1UZLPqybjW57","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"LA-4TDWxYyZftnSKBautr"},{"ddd":0,"ind":62,"ty":0,"nm":"","ln":"precomp_BW4xqaLZHIgopkFr_PrHl62","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"J0K5VwRB3vhxC4ypCBg2v"},{"ddd":0,"ind":63,"ty":0,"nm":"","ln":"precomp_brVAifg0TKDIdZko_UrBY63","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"VvYdnwXSrXmg-mh-Rcn1o"}]},{"id":"5dRGfW-f-5EC06AxyPclJ","layers":[]},{"h":45,"id":"sjIpqZkA4Ah4UwbGy7-nv","p":"","u":"","w":45,"e":1},{"id":"WrqKVORAq5UGZFPJ8jX4b","layers":[{"ddd":0,"ind":68,"ty":2,"nm":"","ln":"sjIpqZkA4Ah4UwbGy7-nv68","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"sjIpqZkA4Ah4UwbGy7-nv"}]},{"id":"TfOsHu3dRL4pTcy4HEu2F","layers":[{"ddd":0,"ind":70,"ty":4,"nm":"","ln":"Q92rB0fQYcd6nZhwdwpVm70","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"DtYqzM4JyNa6j8AgrgvOA","layers":[{"ddd":0,"ind":69,"ty":0,"nm":"","td":1,"ln":"precomp_MLkkvcvjtHxkESfK4oKUf69","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"TfOsHu3dRL4pTcy4HEu2F"},{"ddd":0,"ind":67,"ty":0,"nm":"","tt":1,"ln":"precomp_xSH5V-zS0FMVrSW8byLwi67","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"WrqKVORAq5UGZFPJ8jX4b"}]},{"id":"Nbk2sPWPM1g9WpAWh3Mcl","layers":[]},{"id":"tIQ9h3JTZiBjJ9r72AVRS","layers":[]},{"id":"bjR9IuwZvxpB0XMoiJmtV","layers":[{"ddd":0,"ind":65,"ty":0,"nm":"","ln":"precomp_tDxLuFR3zc8fqpt5aP7WT65","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5dRGfW-f-5EC06AxyPclJ"},{"ddd":0,"ind":66,"ty":0,"nm":"","ln":"precomp_xSH5V-zS0FMVrSW8byLwi66","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"DtYqzM4JyNa6j8AgrgvOA"},{"ddd":0,"ind":71,"ty":0,"nm":"","ln":"precomp_c-Nq8wr2SlKwLF2G8fmUt71","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"Nbk2sPWPM1g9WpAWh3Mcl"},{"ddd":0,"ind":72,"ty":0,"nm":"","ln":"precomp_ioKh6_MDOovIfO9NUvy5x72","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"tIQ9h3JTZiBjJ9r72AVRS"}]},{"id":"HmbclP1LJACiRndIX7hVz","layers":[]},{"h":45,"id":"7KDX9nkEyVmSWQWpl4xj-","p":"","u":"","w":45,"e":1},{"id":"7awDR8wCG1kZZSxHArQ3y","layers":[{"ddd":0,"ind":77,"ty":2,"nm":"","ln":"7KDX9nkEyVmSWQWpl4xj-77","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"7KDX9nkEyVmSWQWpl4xj-"}]},{"id":"utbAE5MXEuhXqx7Rxi1f_","layers":[{"ddd":0,"ind":79,"ty":4,"nm":"","ln":"RP0Lq8Bx8APZM1jcFACo779","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"iLKyxfTSxQ3xRidR417TK","layers":[{"ddd":0,"ind":78,"ty":0,"nm":"","td":1,"ln":"precomp_XNarjz5p95hxEybeBOgBb78","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"utbAE5MXEuhXqx7Rxi1f_"},{"ddd":0,"ind":76,"ty":0,"nm":"","tt":1,"ln":"precomp_7TjlyqvzYHDikN8w0K03A76","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"7awDR8wCG1kZZSxHArQ3y"}]},{"id":"f6CR7tlG6G-P-i5IZCAZz","layers":[]},{"id":"3lPvucaiw6HePIPG9XhMf","layers":[]},{"id":"8S8gY5V7-sb-zgTzcr1VR","layers":[{"ddd":0,"ind":74,"ty":0,"nm":"","ln":"precomp_coYxXELe3uuors_D-s6Gp74","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"HmbclP1LJACiRndIX7hVz"},{"ddd":0,"ind":75,"ty":0,"nm":"","ln":"precomp_7TjlyqvzYHDikN8w0K03A75","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"iLKyxfTSxQ3xRidR417TK"},{"ddd":0,"ind":80,"ty":0,"nm":"","ln":"precomp_1YXqL106t5D9JtgqX77or80","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"f6CR7tlG6G-P-i5IZCAZz"},{"ddd":0,"ind":81,"ty":0,"nm":"","ln":"precomp_9OoqAITkjQzrKvtmdOE8y81","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"3lPvucaiw6HePIPG9XhMf"}]},{"id":"JlWmvFHY-QYi6Z9xFeR3m","layers":[]},{"h":184,"id":"qGqNC2ISdXJ2B11-YbxOc","p":"","u":"","w":218,"e":1},{"id":"clsBKQnyb3iEQAlt-LfBE","layers":[{"ddd":0,"ind":86,"ty":2,"nm":"","ln":"qGqNC2ISdXJ2B11-YbxOc86","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49891,49908]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"qGqNC2ISdXJ2B11-YbxOc"}]},{"id":"F-4f8Kf89lxL8Ww8mqWb1","layers":[{"ddd":0,"ind":88,"ty":4,"nm":"","ln":"Nbn1N2R7bF6aygNvMDCgx88","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[218,184]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"LJudKacBKw9jtQ6ofZoq6","layers":[{"ddd":0,"ind":87,"ty":0,"nm":"","td":1,"ln":"precomp_-fFQU5AbMqm2fJV22QrgZ87","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"F-4f8Kf89lxL8Ww8mqWb1"},{"ddd":0,"ind":85,"ty":0,"nm":"","tt":1,"ln":"precomp_f722-X4dbyBeBuqvM3KBJ85","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"clsBKQnyb3iEQAlt-LfBE"}]},{"id":"JFrHn6XK6uZwyGGcm3iKT","layers":[]},{"id":"KTZnxLE5CMVvuo_JEWyXK","layers":[]},{"id":"ok4gWC1zBtArH8tpnq8He","layers":[{"ddd":0,"ind":83,"ty":0,"nm":"","ln":"precomp_-Omp8_Vr55cGNJsf_ukjf83","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"JlWmvFHY-QYi6Z9xFeR3m"},{"ddd":0,"ind":84,"ty":0,"nm":"","ln":"precomp_f722-X4dbyBeBuqvM3KBJ84","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"LJudKacBKw9jtQ6ofZoq6"},{"ddd":0,"ind":89,"ty":0,"nm":"","ln":"precomp_CPFiH1io7GFKoy0XeOKzr89","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"JFrHn6XK6uZwyGGcm3iKT"},{"ddd":0,"ind":90,"ty":0,"nm":"","ln":"precomp_5L0EmZ5Zh-qIwbDS68Wka90","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"KTZnxLE5CMVvuo_JEWyXK"}]},{"id":"JTOZEzgSQEY43sv4n2tlA","layers":[]},{"id":"lXCZhTwN9hkFjo5_fz7bP","layers":[{"ddd":0,"ind":93,"ty":4,"nm":"","ln":"FCVcMJ8iumjdJd8v7tMxl93","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[733,300]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.01,0.03,0.09]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"zmQJnYlGdks32zF2cOJsi","layers":[{"ddd":0,"ind":1,"ty":0,"nm":"","ln":"precomp_mY0TBhY2Ik_JpkJeEDX-b1","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":216,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":240,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49706,50000],"h":1},{"t":0,"s":[49706,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49756,50000],"h":1},{"t":24,"s":[49756,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49806,50000],"h":1},{"t":48,"s":[49806,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49856,50000],"h":1},{"t":72,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49906,50000],"h":1},{"t":96,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49956,50000],"h":1},{"t":120,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50006,50000],"h":1},{"t":144,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50056,50000],"h":1},{"t":168,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50106,50000],"h":1},{"t":192,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":216,"s":[50236.75,50000],"h":1},{"t":216,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"KBnueAc3Jde2Y8D1VS1FK"},{"ddd":0,"ind":10,"ty":0,"nm":"","ln":"precomp_9TpNu-V1DIEvuf1cfLX8-10","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":192,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":216,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49756,50000],"h":1},{"t":0,"s":[49756,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49806,50000],"h":1},{"t":24,"s":[49806,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49856,50000],"h":1},{"t":48,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49906,50000],"h":1},{"t":72,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49956,50000],"h":1},{"t":96,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50006,50000],"h":1},{"t":120,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50056,50000],"h":1},{"t":144,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50106,50000],"h":1},{"t":168,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50236.75,50000],"h":1},{"t":192,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":216,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"BLV0J7Lt7DnDPzvyTVtqn"},{"ddd":0,"ind":19,"ty":0,"nm":"","ln":"precomp_SQGQ1DMuRkTyuxSnDukfv19","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":168,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":192,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49806,50000],"h":1},{"t":0,"s":[49806,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49856,50000],"h":1},{"t":24,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49906,50000],"h":1},{"t":48,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49956,50000],"h":1},{"t":72,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50006,50000],"h":1},{"t":96,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50056,50000],"h":1},{"t":120,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50106,50000],"h":1},{"t":144,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50236.75,50000],"h":1},{"t":168,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"QaRXUJAbfNvzOK_o16lsL"},{"ddd":0,"ind":28,"ty":0,"nm":"","ln":"precomp_sQWvef6aRtX68nsqQAjm028","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":144,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":168,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49856,50000],"h":1},{"t":0,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49906,50000],"h":1},{"t":24,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49956,50000],"h":1},{"t":48,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50006,50000],"h":1},{"t":72,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50056,50000],"h":1},{"t":96,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50106,50000],"h":1},{"t":120,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50236.75,50000],"h":1},{"t":144,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"Ck9MjVfGMNXBrK40rFMUG"},{"ddd":0,"ind":37,"ty":0,"nm":"","ln":"precomp_nzWrUD5tRSgUI4iOAahJm37","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":120,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":144,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49906,50000],"h":1},{"t":0,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49956,50000],"h":1},{"t":24,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50006,50000],"h":1},{"t":48,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50056,50000],"h":1},{"t":72,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50106,50000],"h":1},{"t":96,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50236.75,50000],"h":1},{"t":120,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"rp0ZHOpavceJcJHS_aO8n"},{"ddd":0,"ind":46,"ty":0,"nm":"","ln":"precomp_Ngqnv5u7c78bv1kKml-JZ46","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":96,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":120,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49956,50000],"h":1},{"t":0,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50006,50000],"h":1},{"t":24,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50056,50000],"h":1},{"t":48,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50106,50000],"h":1},{"t":72,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50236.75,50000],"h":1},{"t":96,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"ocTdvqp8qP0CBJN5AFzRL"},{"ddd":0,"ind":55,"ty":0,"nm":"","ln":"precomp_d7LGjssn6jk_BAI4iTpbu55","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":72,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":96,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50006,50000],"h":1},{"t":0,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50056,50000],"h":1},{"t":24,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50106,50000],"h":1},{"t":48,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50236.75,50000],"h":1},{"t":72,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"tO9ekoSfn0rsYia7DQqMF"},{"ddd":0,"ind":64,"ty":0,"nm":"","ln":"precomp_7SfQxvberzjgAVfhsi9pe64","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":48,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":72,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50056,50000],"h":1},{"t":0,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50106,50000],"h":1},{"t":24,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50232.5,50000],"h":1},{"t":48,"s":[50232.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50282.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"bjR9IuwZvxpB0XMoiJmtV"},{"ddd":0,"ind":73,"ty":0,"nm":"","ln":"precomp_SSbPtfB45NY2wk8qYEhVs73","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":24,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":48,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50106,50000],"h":1},{"t":0,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50237.5,50000],"h":1},{"t":24,"s":[50237.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50287.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"8S8gY5V7-sb-zgTzcr1VR"},{"ddd":0,"ind":82,"ty":0,"nm":"","ln":"precomp_MprMPTSLYQOXKH26z-kdy82","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50236.75,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"ok4gWC1zBtArH8tpnq8He"},{"ddd":0,"ind":91,"ty":0,"nm":"","ln":"precomp_RjDJcDe8E-T7mQsdaC0e-91","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"JTOZEzgSQEY43sv4n2tlA"},{"ddd":0,"ind":92,"ty":0,"nm":"","ln":"precomp_xi_ExXz2tn_cz61rfykgG92","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"lXCZhTwN9hkFjo5_fz7bP"}]}],"ddd":0,"fr":60,"h":300,"ip":0,"layers":[{"ddd":0,"ind":0,"ty":0,"nm":"","ln":"precomp_RhoI5eMdh0y036MGIYl__0","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[366.5,150]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"zmQJnYlGdks32zF2cOJsi"}],"meta":{"g":"https://jitter.video"},"nm":"Fairness-[copy]","op":270,"v":"5.7.4","w":733} \ No newline at end of file +{"assets":[{"id":"yulU8vWqKbRjf848fsLyv","layers":[]},{"h":45,"id":"9SBWCMPXgTML2euv-iBgA","p":"","u":"","w":45,"e":1},{"id":"UqSDkE0XTQUqModho1Nqi","layers":[{"ddd":0,"ind":5,"ty":2,"nm":"","ln":"9SBWCMPXgTML2euv-iBgA5","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"9SBWCMPXgTML2euv-iBgA"}]},{"id":"5mxpUCoqrlncqk7veyp6W","layers":[{"ddd":0,"ind":7,"ty":4,"nm":"","ln":"KtlaIh72UXZZKGZ7QBVey7","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"A1JemffokXxnP_lmyzRdG","layers":[{"ddd":0,"ind":6,"ty":0,"nm":"","td":1,"ln":"precomp_zzQpnEUsSYfK2gPHzxdUd6","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5mxpUCoqrlncqk7veyp6W"},{"ddd":0,"ind":4,"ty":0,"nm":"","tt":1,"ln":"precomp_OksBrZrYbv5y5uxxF9rDm4","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"UqSDkE0XTQUqModho1Nqi"}]},{"id":"6Q0uGMngSy8xbZRlgN2ZL","layers":[]},{"id":"T-fZio3s69dhBl8Tb3SkB","layers":[]},{"id":"KBnueAc3Jde2Y8D1VS1FK","layers":[{"ddd":0,"ind":2,"ty":0,"nm":"","ln":"precomp_lN5UJu9z1X5Iy4W_46ZMe2","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"yulU8vWqKbRjf848fsLyv"},{"ddd":0,"ind":3,"ty":0,"nm":"","ln":"precomp_OksBrZrYbv5y5uxxF9rDm3","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"A1JemffokXxnP_lmyzRdG"},{"ddd":0,"ind":8,"ty":0,"nm":"","ln":"precomp_zNjTgH-WJLhAC_GEcHSIZ8","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"6Q0uGMngSy8xbZRlgN2ZL"},{"ddd":0,"ind":9,"ty":0,"nm":"","ln":"precomp_1NTBbVkz6t7VZk29rg-I59","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"T-fZio3s69dhBl8Tb3SkB"}]},{"id":"5Z4NLo4VNrF65f8NQQaCz","layers":[]},{"h":45,"id":"54wIpGQO0hT4zPjKD5YML","p":"","u":"","w":45,"e":1},{"id":"w6pcpqFmHRgCi2N7Ce2Dr","layers":[{"ddd":0,"ind":14,"ty":2,"nm":"","ln":"54wIpGQO0hT4zPjKD5YML14","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"54wIpGQO0hT4zPjKD5YML"}]},{"id":"zI8F9r_1CNk8j4qDdGX9f","layers":[{"ddd":0,"ind":16,"ty":4,"nm":"","ln":"dgEplkXxtxt9PgzVCgOSd16","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"4xm9euMKW55qWh0wVXHNu","layers":[{"ddd":0,"ind":15,"ty":0,"nm":"","td":1,"ln":"precomp_gzbEYo-2zrAVvntLm82_X15","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"zI8F9r_1CNk8j4qDdGX9f"},{"ddd":0,"ind":13,"ty":0,"nm":"","tt":1,"ln":"precomp_LEyj12QSgOn2o35eiA6W513","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"w6pcpqFmHRgCi2N7Ce2Dr"}]},{"id":"eG4P1X90WGMjoNkCo5MIj","layers":[]},{"id":"XuZQhg1Zsbyl5STKQV1eg","layers":[]},{"id":"BLV0J7Lt7DnDPzvyTVtqn","layers":[{"ddd":0,"ind":11,"ty":0,"nm":"","ln":"precomp_1x6hBWKBWx23XY4Y871SG11","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5Z4NLo4VNrF65f8NQQaCz"},{"ddd":0,"ind":12,"ty":0,"nm":"","ln":"precomp_LEyj12QSgOn2o35eiA6W512","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"4xm9euMKW55qWh0wVXHNu"},{"ddd":0,"ind":17,"ty":0,"nm":"","ln":"precomp_sgCBn7zyaR9WNCY-0RQ2t17","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"eG4P1X90WGMjoNkCo5MIj"},{"ddd":0,"ind":18,"ty":0,"nm":"","ln":"precomp_lD1t3v2d1bBx2Vdjs7CxZ18","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"XuZQhg1Zsbyl5STKQV1eg"}]},{"id":"mrmbN9qnXIChot6qcjXUW","layers":[]},{"h":45,"id":"k8X9p_GQOpVtl_eFUE6BM","p":"","u":"","w":45,"e":1},{"id":"E4tejf1KL9G5aJMyCPDgn","layers":[{"ddd":0,"ind":23,"ty":2,"nm":"","ln":"k8X9p_GQOpVtl_eFUE6BM23","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"k8X9p_GQOpVtl_eFUE6BM"}]},{"id":"oChC2zUv8lIhWzD8WHDCT","layers":[{"ddd":0,"ind":25,"ty":4,"nm":"","ln":"lzIWCpc2IDnheKhtHZwCd25","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"s4JNvszG0Rocrs7luabF7","layers":[{"ddd":0,"ind":24,"ty":0,"nm":"","td":1,"ln":"precomp_1i1_DcRk-ljM8MsMLAAYI24","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"oChC2zUv8lIhWzD8WHDCT"},{"ddd":0,"ind":22,"ty":0,"nm":"","tt":1,"ln":"precomp_h4XDyNbqp2e2rcXAOQOvf22","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"E4tejf1KL9G5aJMyCPDgn"}]},{"id":"n_Bhwor14FwJouk92i9MG","layers":[]},{"id":"PCHJMoluuzRsH5QsuLPPX","layers":[]},{"id":"QaRXUJAbfNvzOK_o16lsL","layers":[{"ddd":0,"ind":20,"ty":0,"nm":"","ln":"precomp_Be-HG2PfKdgwnioT_8DYz20","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"mrmbN9qnXIChot6qcjXUW"},{"ddd":0,"ind":21,"ty":0,"nm":"","ln":"precomp_h4XDyNbqp2e2rcXAOQOvf21","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"s4JNvszG0Rocrs7luabF7"},{"ddd":0,"ind":26,"ty":0,"nm":"","ln":"precomp_r4yE1nKUPwjr2yombW0K726","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"n_Bhwor14FwJouk92i9MG"},{"ddd":0,"ind":27,"ty":0,"nm":"","ln":"precomp_L3sOXlZOeHoE_Kax8q_2Q27","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"PCHJMoluuzRsH5QsuLPPX"}]},{"id":"8vKxO1-bJikEpnUKbL2_b","layers":[]},{"h":45,"id":"GqiaBhF9SBurEPyxZSvm0","p":"","u":"","w":45,"e":1},{"id":"BXUACfPjKr6SZzJcORZoC","layers":[{"ddd":0,"ind":32,"ty":2,"nm":"","ln":"GqiaBhF9SBurEPyxZSvm032","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"GqiaBhF9SBurEPyxZSvm0"}]},{"id":"PtWDMFAMSGGRrKRxAqi2N","layers":[{"ddd":0,"ind":34,"ty":4,"nm":"","ln":"aDxZcAI8Y0LTd7_Clb_rF34","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"HocXy8XdhplJRJ0ad1aFy","layers":[{"ddd":0,"ind":33,"ty":0,"nm":"","td":1,"ln":"precomp_RvOWM-s-Pr0mC31NxAvyI33","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"PtWDMFAMSGGRrKRxAqi2N"},{"ddd":0,"ind":31,"ty":0,"nm":"","tt":1,"ln":"precomp_3L2NkHDXOfHRno3ho6tjN31","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"BXUACfPjKr6SZzJcORZoC"}]},{"id":"80Bg2LzytEwvf0wxY-DDr","layers":[]},{"id":"5inTWv2rSKvB-edhwbU-o","layers":[]},{"id":"Ck9MjVfGMNXBrK40rFMUG","layers":[{"ddd":0,"ind":29,"ty":0,"nm":"","ln":"precomp_-AEjgST_VTbF_ZfxfJXi429","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"8vKxO1-bJikEpnUKbL2_b"},{"ddd":0,"ind":30,"ty":0,"nm":"","ln":"precomp_3L2NkHDXOfHRno3ho6tjN30","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"HocXy8XdhplJRJ0ad1aFy"},{"ddd":0,"ind":35,"ty":0,"nm":"","ln":"precomp_ZXAcBzj7tpP__2gLJHixw35","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"80Bg2LzytEwvf0wxY-DDr"},{"ddd":0,"ind":36,"ty":0,"nm":"","ln":"precomp_U4ABa_Xf3hqlqKmjIoQR936","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5inTWv2rSKvB-edhwbU-o"}]},{"id":"oJrXBDzoBzuCS76SkUbZf","layers":[]},{"h":45,"id":"ZlnoUXgB-wjZUhxWJ1Xd2","p":"","u":"","w":45,"e":1},{"id":"9QDbIKRvMnpybiwDD-7PL","layers":[{"ddd":0,"ind":41,"ty":2,"nm":"","ln":"ZlnoUXgB-wjZUhxWJ1Xd241","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"ZlnoUXgB-wjZUhxWJ1Xd2"}]},{"id":"_EhuSBExkVk6Ro-Gd73vQ","layers":[{"ddd":0,"ind":43,"ty":4,"nm":"","ln":"6cmiZn0k_TX_CLEdz8O7o43","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"C5y6qIyb18jthHZnGhAT-","layers":[{"ddd":0,"ind":42,"ty":0,"nm":"","td":1,"ln":"precomp_VDVQAIlpbLFssyrXf6qJr42","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"_EhuSBExkVk6Ro-Gd73vQ"},{"ddd":0,"ind":40,"ty":0,"nm":"","tt":1,"ln":"precomp_pNm7M3lzfubMDkOVA9DiO40","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"9QDbIKRvMnpybiwDD-7PL"}]},{"id":"PMMyrEKZAuZ42y_y6Pere","layers":[]},{"id":"IWnwN26V2QiMSyKBRCBC2","layers":[]},{"id":"rp0ZHOpavceJcJHS_aO8n","layers":[{"ddd":0,"ind":38,"ty":0,"nm":"","ln":"precomp_Wjq69e6ApjX4rJeJzclfZ38","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"oJrXBDzoBzuCS76SkUbZf"},{"ddd":0,"ind":39,"ty":0,"nm":"","ln":"precomp_pNm7M3lzfubMDkOVA9DiO39","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"C5y6qIyb18jthHZnGhAT-"},{"ddd":0,"ind":44,"ty":0,"nm":"","ln":"precomp_Mtrziyf-MIpTDthKiw6cy44","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"PMMyrEKZAuZ42y_y6Pere"},{"ddd":0,"ind":45,"ty":0,"nm":"","ln":"precomp_qPcFPc8Y3WoCxLm6eCWjO45","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"IWnwN26V2QiMSyKBRCBC2"}]},{"id":"l_wZZpSzdTgCvEGLdUwry","layers":[]},{"h":45,"id":"sn24u7PbyWcud3MsI1WkY","p":"","u":"","w":45,"e":1},{"id":"dSeviyOqoF5NF9bI9B3ro","layers":[{"ddd":0,"ind":50,"ty":2,"nm":"","ln":"sn24u7PbyWcud3MsI1WkY50","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"sn24u7PbyWcud3MsI1WkY"}]},{"id":"w1-zLKK6qBsX0dU5RBkdd","layers":[{"ddd":0,"ind":52,"ty":4,"nm":"","ln":"KFoTmW8PjrTDSe_ekFKXw52","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"k6366sjR3D5SBF4ry-oAr","layers":[{"ddd":0,"ind":51,"ty":0,"nm":"","td":1,"ln":"precomp_H1_5vN07hSycKK-iiRPo651","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"w1-zLKK6qBsX0dU5RBkdd"},{"ddd":0,"ind":49,"ty":0,"nm":"","tt":1,"ln":"precomp_Y3RhhwTpsC5CnW98wHGMK49","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"dSeviyOqoF5NF9bI9B3ro"}]},{"id":"4XpcHh8IeANWZnQt58Etl","layers":[]},{"id":"6Z68thyJQcA7VPUxY4MHV","layers":[]},{"id":"ocTdvqp8qP0CBJN5AFzRL","layers":[{"ddd":0,"ind":47,"ty":0,"nm":"","ln":"precomp_mBNEgZ8lh_NKbVJwi-XkF47","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"l_wZZpSzdTgCvEGLdUwry"},{"ddd":0,"ind":48,"ty":0,"nm":"","ln":"precomp_Y3RhhwTpsC5CnW98wHGMK48","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"k6366sjR3D5SBF4ry-oAr"},{"ddd":0,"ind":53,"ty":0,"nm":"","ln":"precomp_uaRWdpGb-rApaovhxTTfu53","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"4XpcHh8IeANWZnQt58Etl"},{"ddd":0,"ind":54,"ty":0,"nm":"","ln":"precomp_A1M4DyDOpIUvT0zNYDLUX54","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"6Z68thyJQcA7VPUxY4MHV"}]},{"id":"OtDBv3qz5lWV9vuhoJ5Xx","layers":[]},{"h":45,"id":"fh4qoqFE-pFMiu5OB-T9z","p":"","u":"","w":45,"e":1},{"id":"Ld4LfTqtcd8e3kgTxWWk0","layers":[{"ddd":0,"ind":59,"ty":2,"nm":"","ln":"fh4qoqFE-pFMiu5OB-T9z59","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"fh4qoqFE-pFMiu5OB-T9z"}]},{"id":"gxbdMIWuVtNOJy10T1CSx","layers":[{"ddd":0,"ind":61,"ty":4,"nm":"","ln":"8CQ10jkMXuDCJQGq11pJr61","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"LA-4TDWxYyZftnSKBautr","layers":[{"ddd":0,"ind":60,"ty":0,"nm":"","td":1,"ln":"precomp_4Sc372Dh_ls7zu66xMM7_60","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"gxbdMIWuVtNOJy10T1CSx"},{"ddd":0,"ind":58,"ty":0,"nm":"","tt":1,"ln":"precomp_etwpsSqWxqp1UZLPqybjW58","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"Ld4LfTqtcd8e3kgTxWWk0"}]},{"id":"J0K5VwRB3vhxC4ypCBg2v","layers":[]},{"id":"VvYdnwXSrXmg-mh-Rcn1o","layers":[]},{"id":"tO9ekoSfn0rsYia7DQqMF","layers":[{"ddd":0,"ind":56,"ty":0,"nm":"","ln":"precomp_cMZ_cSCC-_GVm_xLHrO2r56","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"OtDBv3qz5lWV9vuhoJ5Xx"},{"ddd":0,"ind":57,"ty":0,"nm":"","ln":"precomp_etwpsSqWxqp1UZLPqybjW57","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"LA-4TDWxYyZftnSKBautr"},{"ddd":0,"ind":62,"ty":0,"nm":"","ln":"precomp_BW4xqaLZHIgopkFr_PrHl62","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"J0K5VwRB3vhxC4ypCBg2v"},{"ddd":0,"ind":63,"ty":0,"nm":"","ln":"precomp_brVAifg0TKDIdZko_UrBY63","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"VvYdnwXSrXmg-mh-Rcn1o"}]},{"id":"5dRGfW-f-5EC06AxyPclJ","layers":[]},{"h":45,"id":"sjIpqZkA4Ah4UwbGy7-nv","p":"","u":"","w":45,"e":1},{"id":"WrqKVORAq5UGZFPJ8jX4b","layers":[{"ddd":0,"ind":68,"ty":2,"nm":"","ln":"sjIpqZkA4Ah4UwbGy7-nv68","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"sjIpqZkA4Ah4UwbGy7-nv"}]},{"id":"TfOsHu3dRL4pTcy4HEu2F","layers":[{"ddd":0,"ind":70,"ty":4,"nm":"","ln":"Q92rB0fQYcd6nZhwdwpVm70","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"DtYqzM4JyNa6j8AgrgvOA","layers":[{"ddd":0,"ind":69,"ty":0,"nm":"","td":1,"ln":"precomp_MLkkvcvjtHxkESfK4oKUf69","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"TfOsHu3dRL4pTcy4HEu2F"},{"ddd":0,"ind":67,"ty":0,"nm":"","tt":1,"ln":"precomp_xSH5V-zS0FMVrSW8byLwi67","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"WrqKVORAq5UGZFPJ8jX4b"}]},{"id":"Nbk2sPWPM1g9WpAWh3Mcl","layers":[]},{"id":"tIQ9h3JTZiBjJ9r72AVRS","layers":[]},{"id":"bjR9IuwZvxpB0XMoiJmtV","layers":[{"ddd":0,"ind":65,"ty":0,"nm":"","ln":"precomp_tDxLuFR3zc8fqpt5aP7WT65","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"5dRGfW-f-5EC06AxyPclJ"},{"ddd":0,"ind":66,"ty":0,"nm":"","ln":"precomp_xSH5V-zS0FMVrSW8byLwi66","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"DtYqzM4JyNa6j8AgrgvOA"},{"ddd":0,"ind":71,"ty":0,"nm":"","ln":"precomp_c-Nq8wr2SlKwLF2G8fmUt71","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"Nbk2sPWPM1g9WpAWh3Mcl"},{"ddd":0,"ind":72,"ty":0,"nm":"","ln":"precomp_ioKh6_MDOovIfO9NUvy5x72","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"tIQ9h3JTZiBjJ9r72AVRS"}]},{"id":"HmbclP1LJACiRndIX7hVz","layers":[]},{"h":45,"id":"7KDX9nkEyVmSWQWpl4xj-","p":"","u":"","w":45,"e":1},{"id":"7awDR8wCG1kZZSxHArQ3y","layers":[{"ddd":0,"ind":77,"ty":2,"nm":"","ln":"7KDX9nkEyVmSWQWpl4xj-77","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"7KDX9nkEyVmSWQWpl4xj-"}]},{"id":"utbAE5MXEuhXqx7Rxi1f_","layers":[{"ddd":0,"ind":79,"ty":4,"nm":"","ln":"RP0Lq8Bx8APZM1jcFACo779","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"iLKyxfTSxQ3xRidR417TK","layers":[{"ddd":0,"ind":78,"ty":0,"nm":"","td":1,"ln":"precomp_XNarjz5p95hxEybeBOgBb78","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"utbAE5MXEuhXqx7Rxi1f_"},{"ddd":0,"ind":76,"ty":0,"nm":"","tt":1,"ln":"precomp_7TjlyqvzYHDikN8w0K03A76","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"7awDR8wCG1kZZSxHArQ3y"}]},{"id":"f6CR7tlG6G-P-i5IZCAZz","layers":[]},{"id":"3lPvucaiw6HePIPG9XhMf","layers":[]},{"id":"8S8gY5V7-sb-zgTzcr1VR","layers":[{"ddd":0,"ind":74,"ty":0,"nm":"","ln":"precomp_coYxXELe3uuors_D-s6Gp74","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"HmbclP1LJACiRndIX7hVz"},{"ddd":0,"ind":75,"ty":0,"nm":"","ln":"precomp_7TjlyqvzYHDikN8w0K03A75","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"iLKyxfTSxQ3xRidR417TK"},{"ddd":0,"ind":80,"ty":0,"nm":"","ln":"precomp_1YXqL106t5D9JtgqX77or80","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"f6CR7tlG6G-P-i5IZCAZz"},{"ddd":0,"ind":81,"ty":0,"nm":"","ln":"precomp_9OoqAITkjQzrKvtmdOE8y81","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"3lPvucaiw6HePIPG9XhMf"}]},{"id":"JlWmvFHY-QYi6Z9xFeR3m","layers":[]},{"h":184,"id":"qGqNC2ISdXJ2B11-YbxOc","p":"","u":"","w":218,"e":1},{"id":"clsBKQnyb3iEQAlt-LfBE","layers":[{"ddd":0,"ind":86,"ty":2,"nm":"","ln":"qGqNC2ISdXJ2B11-YbxOc86","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49891,49908]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"refId":"qGqNC2ISdXJ2B11-YbxOc"}]},{"id":"F-4f8Kf89lxL8Ww8mqWb1","layers":[{"ddd":0,"ind":88,"ty":4,"nm":"","ln":"Nbn1N2R7bF6aygNvMDCgx88","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[218,184]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"LJudKacBKw9jtQ6ofZoq6","layers":[{"ddd":0,"ind":87,"ty":0,"nm":"","td":1,"ln":"precomp_-fFQU5AbMqm2fJV22QrgZ87","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"F-4f8Kf89lxL8Ww8mqWb1"},{"ddd":0,"ind":85,"ty":0,"nm":"","tt":1,"ln":"precomp_f722-X4dbyBeBuqvM3KBJ85","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"clsBKQnyb3iEQAlt-LfBE"}]},{"id":"JFrHn6XK6uZwyGGcm3iKT","layers":[]},{"id":"KTZnxLE5CMVvuo_JEWyXK","layers":[]},{"id":"ok4gWC1zBtArH8tpnq8He","layers":[{"ddd":0,"ind":83,"ty":0,"nm":"","ln":"precomp_-Omp8_Vr55cGNJsf_ukjf83","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"JlWmvFHY-QYi6Z9xFeR3m"},{"ddd":0,"ind":84,"ty":0,"nm":"","ln":"precomp_f722-X4dbyBeBuqvM3KBJ84","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"LJudKacBKw9jtQ6ofZoq6"},{"ddd":0,"ind":89,"ty":0,"nm":"","ln":"precomp_CPFiH1io7GFKoy0XeOKzr89","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"JFrHn6XK6uZwyGGcm3iKT"},{"ddd":0,"ind":90,"ty":0,"nm":"","ln":"precomp_5L0EmZ5Zh-qIwbDS68Wka90","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"KTZnxLE5CMVvuo_JEWyXK"}]},{"id":"JTOZEzgSQEY43sv4n2tlA","layers":[]},{"id":"lXCZhTwN9hkFjo5_fz7bP","layers":[{"ddd":0,"ind":93,"ty":4,"nm":"","ln":"FCVcMJ8iumjdJd8v7tMxl93","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":271,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[733,300]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.01,0.03,0.09]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"zmQJnYlGdks32zF2cOJsi","layers":[{"ddd":0,"ind":1,"ty":0,"nm":"","ln":"precomp_mY0TBhY2Ik_JpkJeEDX-b1","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":216,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":240,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49706,50000],"h":1},{"t":0,"s":[49706,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49756,50000],"h":1},{"t":24,"s":[49756,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49806,50000],"h":1},{"t":48,"s":[49806,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49856,50000],"h":1},{"t":72,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49906,50000],"h":1},{"t":96,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49956,50000],"h":1},{"t":120,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50006,50000],"h":1},{"t":144,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50056,50000],"h":1},{"t":168,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50106,50000],"h":1},{"t":192,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":216,"s":[50236.75,50000],"h":1},{"t":216,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"KBnueAc3Jde2Y8D1VS1FK"},{"ddd":0,"ind":10,"ty":0,"nm":"","ln":"precomp_9TpNu-V1DIEvuf1cfLX8-10","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":192,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":216,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49756,50000],"h":1},{"t":0,"s":[49756,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49806,50000],"h":1},{"t":24,"s":[49806,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49856,50000],"h":1},{"t":48,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49906,50000],"h":1},{"t":72,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49956,50000],"h":1},{"t":96,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50006,50000],"h":1},{"t":120,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50056,50000],"h":1},{"t":144,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50106,50000],"h":1},{"t":168,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50236.75,50000],"h":1},{"t":192,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":216,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"BLV0J7Lt7DnDPzvyTVtqn"},{"ddd":0,"ind":19,"ty":0,"nm":"","ln":"precomp_SQGQ1DMuRkTyuxSnDukfv19","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":168,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":192,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49806,50000],"h":1},{"t":0,"s":[49806,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49856,50000],"h":1},{"t":24,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49906,50000],"h":1},{"t":48,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49956,50000],"h":1},{"t":72,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50006,50000],"h":1},{"t":96,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50056,50000],"h":1},{"t":120,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50106,50000],"h":1},{"t":144,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50236.75,50000],"h":1},{"t":168,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"QaRXUJAbfNvzOK_o16lsL"},{"ddd":0,"ind":28,"ty":0,"nm":"","ln":"precomp_sQWvef6aRtX68nsqQAjm028","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":144,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":168,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49856,50000],"h":1},{"t":0,"s":[49856,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49906,50000],"h":1},{"t":24,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49956,50000],"h":1},{"t":48,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50006,50000],"h":1},{"t":72,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50056,50000],"h":1},{"t":96,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50106,50000],"h":1},{"t":120,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50236.75,50000],"h":1},{"t":144,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"Ck9MjVfGMNXBrK40rFMUG"},{"ddd":0,"ind":37,"ty":0,"nm":"","ln":"precomp_nzWrUD5tRSgUI4iOAahJm37","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":120,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":144,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49906,50000],"h":1},{"t":0,"s":[49906,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49956,50000],"h":1},{"t":24,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50006,50000],"h":1},{"t":48,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50056,50000],"h":1},{"t":72,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50106,50000],"h":1},{"t":96,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50236.75,50000],"h":1},{"t":120,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"rp0ZHOpavceJcJHS_aO8n"},{"ddd":0,"ind":46,"ty":0,"nm":"","ln":"precomp_Ngqnv5u7c78bv1kKml-JZ46","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":96,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":120,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49956,50000],"h":1},{"t":0,"s":[49956,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50006,50000],"h":1},{"t":24,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50056,50000],"h":1},{"t":48,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50106,50000],"h":1},{"t":72,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50236.75,50000],"h":1},{"t":96,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"ocTdvqp8qP0CBJN5AFzRL"},{"ddd":0,"ind":55,"ty":0,"nm":"","ln":"precomp_d7LGjssn6jk_BAI4iTpbu55","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":72,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":96,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50006,50000],"h":1},{"t":0,"s":[50006,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50056,50000],"h":1},{"t":24,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50106,50000],"h":1},{"t":48,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50236.75,50000],"h":1},{"t":72,"s":[50236.75,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50286.75,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"tO9ekoSfn0rsYia7DQqMF"},{"ddd":0,"ind":64,"ty":0,"nm":"","ln":"precomp_7SfQxvberzjgAVfhsi9pe64","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":48,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":72,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50056,50000],"h":1},{"t":0,"s":[50056,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50106,50000],"h":1},{"t":24,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50232.5,50000],"h":1},{"t":48,"s":[50232.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50282.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"bjR9IuwZvxpB0XMoiJmtV"},{"ddd":0,"ind":73,"ty":0,"nm":"","ln":"precomp_SSbPtfB45NY2wk8qYEhVs73","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":24,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":48,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[50106,50000],"h":1},{"t":0,"s":[50106,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50237.5,50000],"h":1},{"t":24,"s":[50237.5,50000],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50287.5,50000],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"8S8gY5V7-sb-zgTzcr1VR"},{"ddd":0,"ind":82,"ty":0,"nm":"","ln":"precomp_MprMPTSLYQOXKH26z-kdy82","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50236.75,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"ok4gWC1zBtArH8tpnq8He"},{"ddd":0,"ind":91,"ty":0,"nm":"","ln":"precomp_RjDJcDe8E-T7mQsdaC0e-91","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"JTOZEzgSQEY43sv4n2tlA"},{"ddd":0,"ind":92,"ty":0,"nm":"","ln":"precomp_xi_ExXz2tn_cz61rfykgG92","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"lXCZhTwN9hkFjo5_fz7bP"}]}],"ddd":0,"fr":60,"h":300,"ip":0,"layers":[{"ddd":0,"ind":0,"ty":0,"nm":"","ln":"precomp_RhoI5eMdh0y036MGIYl__0","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[366.5,150]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":271,"st":0,"bm":0,"refId":"zmQJnYlGdks32zF2cOJsi"}],"meta":{"g":"https://jitter.video"},"nm":"Fairness-[copy]","op":270,"v":"5.7.4","w":733} diff --git a/frontend/docs/pages/blog/_meta.json b/frontend/docs/pages/blog/_meta.json index 49438a178..b8cf7a40c 100644 --- a/frontend/docs/pages/blog/_meta.json +++ b/frontend/docs/pages/blog/_meta.json @@ -3,4 +3,4 @@ "title": "An unfair advantage: multi-tenant queues in Postgres", "display": "hidden" } -} \ No newline at end of file +} diff --git a/frontend/docs/pages/blog/_multi.json b/frontend/docs/pages/blog/_multi.json index a49686718..67b7e12cb 100644 --- a/frontend/docs/pages/blog/_multi.json +++ b/frontend/docs/pages/blog/_multi.json @@ -1 +1 @@ -{"assets":[{"id":"2uHEIitlvEhXAXuT7rtbi","layers":[{"ddd":0,"ind":4,"ty":4,"nm":"","ln":"MGr6XcqyM6ZtNnaTQx5iA4","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50013.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":5,"ty":4,"nm":"","ln":"umZcEdlnKLFRh9M_DZdxf5","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50005.33,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":6,"ty":4,"nm":"","ln":"0L-RDgjtb_dPNDSOuLEE36","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49997.18,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":7,"ty":4,"nm":"","ln":"ELd3Hab3Lnoae6QFF-Urp7","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49989.04,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":8,"ty":4,"nm":"","ln":"tI5f6mHMTMy8PDtxhWepZ8","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.38,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[6.66,-0.91],[4.93,-3.18],[6.28,-3.18],[7.42,-1.69],[7.72,-1.29],[9.41,0.95],[8.05,0.95],[6.94,-0.54],[6.66,-0.91]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":2,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"xrXAHmd2cqSuodyQQslDc","layers":[{"ddd":0,"ind":10,"ty":4,"nm":"","ln":"aJuni2blCHZLZoTIN4o-N10","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50011.74,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,-4.59],[2.25,-4.59],[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.44],[2.31,-6.44],[3.12,-7.38],[4.53,-7.74],[4.53,-7.74],[5.89,-7.42],[6.8,-6.47],[7.12,-4.85],[7.12,-4.85],[7.12,0],[5.95,0],[5.95,-4.77],[5.48,-6.18],[4.2,-6.68],[4.2,-6.68],[3.19,-6.44],[2.5,-5.73],[2.25,-4.59]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.24],[-0.57,0],[0,0],[-0.39,-0.21],[-0.22,-0.42],[0,-0.65],[0,0],[0,0],[0,0],[0,0],[0.31,0.34],[0.54,0],[0,0],[0.29,-0.16],[0.17,-0.31],[0,-0.45]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.18,-0.39],[0.37,-0.24],[0,0],[0.52,0],[0.39,0.21],[0.21,0.43],[0,0],[0,0],[0,0],[0,0],[0,-0.6],[-0.31,-0.33],[0,0],[-0.38,0],[-0.29,0.17],[-0.17,0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":11,"ty":4,"nm":"","ln":"gcLryFT78CFTB94YLMJOP11","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50003.59,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":12,"ty":4,"nm":"","ln":"KYlnWjN1kZvKAjOU6V4V412","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49995.44,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":13,"ty":4,"nm":"","ln":"Y1Ma0SO-KnQcoIG1YMXcB13","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49990.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.48],[2.29,-6.48],[3.04,-7.4],[4.28,-7.76],[4.28,-7.76],[4.6,-7.75],[4.89,-7.74],[4.89,-7.74],[4.89,-6.54],[4.62,-6.59],[4.18,-6.62],[4.18,-6.62],[3.18,-6.39],[2.5,-5.75],[2.25,-4.83],[2.25,-4.83],[2.25,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.23],[-0.46,0],[0,0],[-0.13,-0.01],[-0.07,-0.01],[0,0],[0,0],[0.14,0.02],[0.15,0],[0,0],[0.29,-0.15],[0.17,-0.27],[0,-0.35],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.14,-0.38],[0.37,-0.24],[0,0],[0.08,0],[0.13,0],[0,0],[0,0],[-0.04,-0.01],[-0.14,-0.02],[0,0],[-0.37,0],[-0.29,0.15],[-0.17,0.27],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":14,"ty":4,"nm":"","ln":"i9DYTo2DNGfOt0DFAzLJU14","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49980.06,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[9.47,-7],[8.19,-7],[7.76,-7.9],[7.13,-8.59],[6.3,-9.02],[5.29,-9.17],[5.29,-9.17],[3.64,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.67,-1.48],[5.37,-1.01],[5.37,-1.01],[6.91,-1.39],[7.96,-2.45],[8.33,-4.08],[8.33,-4.08],[8.71,-4],[5.65,-4],[5.65,-5.09],[9.53,-5.09],[9.53,-4],[8.99,-1.81],[7.52,-0.37],[5.37,0.14],[5.37,0.14],[3,-0.5],[1.4,-2.31],[0.84,-5.09],[0.84,-5.09],[1.16,-7.27],[2.08,-8.91],[3.5,-9.96],[5.29,-10.32],[5.29,-10.32],[6.79,-10.08],[8.04,-9.4],[8.96,-8.35],[9.47,-7],[9.47,-7]],"i":[[0,0],[0,0],[0.18,0.27],[0.25,0.19],[0.31,0.1],[0.37,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.51,-0.31],[-0.63,0],[0,0],[-0.45,0.25],[-0.25,0.46],[0,0.63],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.36,-0.62],[0.63,-0.34],[0.81,0],[0,0],[0.68,0.43],[0.38,0.79],[0,1.07],[0,0],[-0.21,0.65],[-0.39,0.45],[-0.55,0.24],[-0.65,0],[0,0],[-0.46,-0.16],[-0.37,-0.29],[-0.25,-0.41],[-0.09,-0.49],[0,0]],"o":[[0,0],[-0.11,-0.33],[-0.17,-0.27],[-0.24,-0.19],[-0.31,-0.1],[0,0],[-0.61,0],[-0.49,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.5,0.31],[0,0],[0.58,0],[0.45,-0.25],[0.25,-0.46],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0.84],[-0.35,0.62],[-0.63,0.34],[0,0],[-0.9,0],[-0.69,-0.42],[-0.37,-0.78],[0,0],[0,-0.81],[0.22,-0.64],[0.4,-0.46],[0.54,-0.24],[0,0],[0.54,0],[0.47,0.16],[0.37,0.29],[0.25,0.41],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"JH-Qh5yFb_R2hngk4MZHU","layers":[{"ddd":0,"ind":3,"ty":0,"nm":"","ln":"precomp_VXkL6qRf6LI04kaA6tDua3","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50021.9,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"2uHEIitlvEhXAXuT7rtbi"},{"ddd":0,"ind":9,"ty":0,"nm":"","ln":"precomp_o4Bbyc5L9OIMQfQ_5nsQS9","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49976.41,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"xrXAHmd2cqSuodyQQslDc"}]},{"id":"7Wus07HRPKsI75JEaEl0n","layers":[{"ddd":0,"ind":2,"ty":0,"nm":"","ln":"precomp_pwNI-chb2pctizggX4lVG2","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"JH-Qh5yFb_R2hngk4MZHU"}]},{"id":"d2AUkWQ53X0lsGkTR4MpT","layers":[{"ddd":0,"ind":18,"ty":4,"nm":"","ln":"_1Fu1BEt4e_6Pkzzxkp4H18","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50013.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":19,"ty":4,"nm":"","ln":"ea7yzB5KrJt2af5T64TPO19","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50005.33,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":20,"ty":4,"nm":"","ln":"9aM7UvRfjgNY9RonWP5ad20","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49997.18,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":21,"ty":4,"nm":"","ln":"pvuFDnIu6DnAOry3BT42l21","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49989.04,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":22,"ty":4,"nm":"","ln":"DCMAtpW49_2UUlAts219822","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.38,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[6.66,-0.91],[4.93,-3.18],[6.28,-3.18],[7.42,-1.69],[7.72,-1.29],[9.41,0.95],[8.05,0.95],[6.94,-0.54],[6.66,-0.91]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":2,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"u6N3VAn9hoOmLDTz2sClC","layers":[{"ddd":0,"ind":24,"ty":4,"nm":"","ln":"AX_DzdIWUTyoQWFHtCi--24","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50016.17,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":25,"ty":4,"nm":"","ln":"CQdnIF9xj5JPsVmYMlHBf25","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50007.64,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.16,3.02],[4.16,3.02],[2.69,2.81],[1.68,2.24],[1.03,1.49],[1.03,1.49],[1.97,0.84],[2.37,1.31],[3.04,1.79],[4.16,1.99],[4.16,1.99],[5.68,1.54],[6.28,0.14],[6.28,0.14],[6.28,-1.41],[6.18,-1.41],[5.82,-0.9],[5.14,-0.36],[3.96,-0.12],[3.96,-0.12],[2.3,-0.56],[1.14,-1.83],[0.72,-3.86],[0.72,-3.86],[1.13,-5.9],[2.28,-7.26],[3.98,-7.74],[3.98,-7.74],[5.16,-7.49],[5.84,-6.93],[6.2,-6.42],[6.2,-6.42],[6.32,-6.42],[6.32,-7.64],[7.46,-7.64],[7.46,0.22],[7.01,1.82],[5.82,2.73],[4.16,3.02]],"i":[[0,0],[0,0],[0.41,0.14],[0.27,0.23],[0.16,0.27],[0,0],[0,0],[-0.16,-0.18],[-0.28,-0.13],[-0.46,0],[0,0],[-0.4,0.3],[0,0.63],[0,0],[0,0],[0,0],[0.16,-0.2],[0.29,-0.15],[0.49,0],[0,0],[0.49,0.29],[0.29,0.56],[0,0.8],[0,0],[-0.27,0.58],[-0.49,0.32],[-0.65,0],[0,0],[-0.29,-0.17],[-0.16,-0.21],[-0.08,-0.13],[0,0],[0,0],[0,0],[0,0],[0,0],[0.3,-0.41],[0.5,-0.19],[0.61,0]],"o":[[0,0],[-0.57,0],[-0.41,-0.15],[-0.27,-0.23],[0,0],[0,0],[0.11,0.13],[0.17,0.19],[0.29,0.13],[0,0],[0.61,0],[0.4,-0.3],[0,0],[0,0],[0,0],[-0.08,0.14],[-0.16,0.21],[-0.29,0.16],[0,0],[-0.62,0],[-0.49,-0.29],[-0.28,-0.55],[0,0],[0,-0.78],[0.27,-0.59],[0.49,-0.32],[0,0],[0.49,0],[0.29,0.17],[0.16,0.21],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0.65],[-0.29,0.41],[-0.5,0.19],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[4.12,-1.17],[4.12,-1.17],[5.31,-1.5],[6.05,-2.43],[6.3,-3.88],[6.3,-3.88],[6.06,-5.33],[5.32,-6.32],[4.12,-6.68],[4.12,-6.68],[2.88,-6.3],[2.14,-5.29],[1.89,-3.88],[1.89,-3.88],[2.14,-2.47],[2.89,-1.52],[4.12,-1.17]],"i":[[0,0],[0,0],[-0.33,0.22],[-0.17,0.41],[0,0.57],[0,0],[0.16,0.42],[0.33,0.23],[0.47,0],[0,0],[0.33,-0.25],[0.16,-0.43],[0,-0.51],[0,0],[-0.17,-0.41],[-0.33,-0.23],[-0.49,0]],"o":[[0,0],[0.47,0],[0.33,-0.21],[0.17,-0.4],[0,0],[0,-0.55],[-0.17,-0.43],[-0.33,-0.24],[0,0],[-0.5,0],[-0.33,0.25],[-0.17,0.43],[0,0],[0,0.53],[0.17,0.41],[0.33,0.23],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":26,"ty":4,"nm":"","ln":"PAStx1VrGPKLuideNtw4n26","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49999.44,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,-4.59],[2.25,-4.59],[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.44],[2.31,-6.44],[3.12,-7.38],[4.53,-7.74],[4.53,-7.74],[5.89,-7.42],[6.8,-6.47],[7.12,-4.85],[7.12,-4.85],[7.12,0],[5.95,0],[5.95,-4.77],[5.48,-6.18],[4.2,-6.68],[4.2,-6.68],[3.19,-6.44],[2.5,-5.73],[2.25,-4.59]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.24],[-0.57,0],[0,0],[-0.39,-0.21],[-0.22,-0.42],[0,-0.65],[0,0],[0,0],[0,0],[0,0],[0.31,0.34],[0.54,0],[0,0],[0.29,-0.16],[0.17,-0.31],[0,-0.45]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.18,-0.39],[0.37,-0.24],[0,0],[0.52,0],[0.39,0.21],[0.21,0.43],[0,0],[0,0],[0,0],[0,0],[0,-0.6],[-0.31,-0.33],[0,0],[-0.38,0],[-0.29,0.17],[-0.17,0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":27,"ty":4,"nm":"","ln":"3xyOLy3ngRnUReqnad5ze27","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49991.55,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[3.32,0.18],[3.32,0.18],[2,-0.1],[1.06,-0.9],[0.72,-2.17],[0.72,-2.17],[0.97,-3.23],[1.67,-3.88],[2.62,-4.23],[3.68,-4.41],[3.68,-4.41],[4.81,-4.55],[5.45,-4.71],[5.65,-5.11],[5.65,-5.11],[5.65,-5.15],[5.25,-6.29],[4.04,-6.7],[4.04,-6.7],[2.72,-6.33],[2.05,-5.55],[2.05,-5.55],[0.93,-5.95],[1.73,-7.03],[2.83,-7.58],[4,-7.74],[4,-7.74],[4.84,-7.65],[5.77,-7.29],[6.52,-6.48],[6.82,-5.03],[6.82,-5.03],[6.82,0],[5.65,0],[5.65,-1.03],[5.59,-1.03],[5.19,-0.5],[4.45,-0.02],[3.32,0.18]],"i":[[0,0],[0,0],[0.4,0.19],[0.23,0.35],[0,0.5],[0,0],[-0.17,0.27],[-0.29,0.16],[-0.35,0.08],[-0.35,0.04],[0,0],[-0.29,0.03],[-0.13,0.07],[0,0.19],[0,0],[0,0],[0.27,0.27],[0.54,0],[0,0],[0.32,-0.25],[0.13,-0.28],[0,0],[0,0],[-0.33,0.26],[-0.4,0.11],[-0.39,0],[0,0],[-0.31,-0.06],[-0.3,-0.18],[-0.2,-0.36],[0,-0.61],[0,0],[0,0],[0,0],[0,0],[0,0],[0.19,-0.19],[0.31,-0.13],[0.45,0]],"o":[[0,0],[-0.48,0],[-0.39,-0.18],[-0.23,-0.35],[0,0],[0,-0.43],[0.17,-0.27],[0.29,-0.15],[0.35,-0.08],[0,0],[0.47,-0.06],[0.29,-0.03],[0.13,-0.08],[0,0],[0,0],[0,-0.49],[-0.27,-0.27],[0,0],[-0.56,0],[-0.32,0.24],[0,0],[0,0],[0.2,-0.46],[0.33,-0.26],[0.39,-0.11],[0,0],[0.25,0],[0.32,0.06],[0.3,0.18],[0.2,0.36],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.08,0.16],[-0.19,0.19],[-0.31,0.13],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[3.5,-0.88],[3.5,-0.88],[4.68,-1.15],[5.4,-1.85],[5.65,-2.76],[5.65,-2.76],[5.65,-3.84],[5.32,-3.68],[4.75,-3.55],[4.11,-3.46],[3.62,-3.4],[3.62,-3.4],[2.77,-3.21],[2.13,-2.82],[1.89,-2.11],[1.89,-2.11],[2.34,-1.19],[3.5,-0.88]],"i":[[0,0],[0,0],[-0.32,0.18],[-0.16,0.29],[0,0.31],[0,0],[0,0],[0.17,-0.05],[0.21,-0.03],[0.21,-0.03],[0.13,-0.02],[0,0],[0.26,-0.09],[0.16,-0.17],[0,-0.3],[0,0],[-0.3,-0.21],[-0.47,0]],"o":[[0,0],[0.47,0],[0.32,-0.18],[0.17,-0.29],[0,0],[0,0],[-0.05,0.06],[-0.17,0.05],[-0.22,0.03],[-0.2,0.02],[0,0],[-0.31,0.04],[-0.27,0.09],[-0.16,0.17],[0,0],[0,0.41],[0.31,0.21],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":28,"ty":4,"nm":"","ln":"hSrS9H20rEu1Rf2IO6-Wq28","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49986.34,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.48],[2.29,-6.48],[3.04,-7.4],[4.28,-7.76],[4.28,-7.76],[4.6,-7.75],[4.89,-7.74],[4.89,-7.74],[4.89,-6.54],[4.62,-6.59],[4.18,-6.62],[4.18,-6.62],[3.18,-6.39],[2.5,-5.75],[2.25,-4.83],[2.25,-4.83],[2.25,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.23],[-0.46,0],[0,0],[-0.13,-0.01],[-0.07,-0.01],[0,0],[0,0],[0.14,0.02],[0.15,0],[0,0],[0.29,-0.15],[0.17,-0.27],[0,-0.35],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.14,-0.38],[0.37,-0.24],[0,0],[0.08,0],[0.13,0],[0,0],[0,0],[-0.04,-0.01],[-0.14,-0.02],[0,0],[-0.37,0],[-0.29,0.15],[-0.17,0.27],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":29,"ty":4,"nm":"","ln":"L3SWoyp-j49t2zuQkxO3l29","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49975.68,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"qOK4BaItY-C8lU0fm3KpK","layers":[{"ddd":0,"ind":17,"ty":0,"nm":"","ln":"precomp_z7IxkdFMFgi3TNtxAe_fX17","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50026.29,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"d2AUkWQ53X0lsGkTR4MpT"},{"ddd":0,"ind":23,"ty":0,"nm":"","ln":"precomp_xdmtx-bgRuEkiGSrNwut223","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49976.41,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"u6N3VAn9hoOmLDTz2sClC"}]},{"id":"Jp0B0YmZgZOEb0g-EEFFt","layers":[{"ddd":0,"ind":16,"ty":0,"nm":"","ln":"precomp_P1gYn2p2qDoQoZwCwknj-16","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"qOK4BaItY-C8lU0fm3KpK"}]},{"id":"EOsV9MOwzFUC7kk9K6GQM","layers":[{"ddd":0,"ind":33,"ty":4,"nm":"","ln":"wEkGeMt12AicdhHEXZZ7a33","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50013.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":34,"ty":4,"nm":"","ln":"ckPvY0o9YFn5ALybKT07j34","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50005.33,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":35,"ty":4,"nm":"","ln":"KLn_7JYlJscPThGivYdZF35","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49997.18,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":36,"ty":4,"nm":"","ln":"RirA09qq9chiwWyfdSCeL36","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49989.04,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":37,"ty":4,"nm":"","ln":"6ERYQJxjS8AQzOU71wWbx37","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.38,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[6.66,-0.91],[4.93,-3.18],[6.28,-3.18],[7.42,-1.69],[7.72,-1.29],[9.41,0.95],[8.05,0.95],[6.94,-0.54],[6.66,-0.91]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":2,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"FGsxvzMnAXygwmffmG9kG","layers":[{"ddd":0,"ind":39,"ty":4,"nm":"","ln":"9Epq2a7eCuOJhlTAJMl0P39","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50012.97,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":40,"ty":4,"nm":"","ln":"fj0d3kQxQ7J9NrWrHHmq040","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50009.64,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[1.07,-10.18],[2.25,-10.18],[2.25,0],[1.07,0],[1.07,-10.18]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":41,"ty":4,"nm":"","ln":"U9hrGN3PveO9dFWoBVZ0841","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50001.11,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,2.86],[1.07,2.86],[1.07,-7.64],[2.21,-7.64],[2.21,-6.42],[2.35,-6.42],[2.71,-6.93],[3.37,-7.49],[4.55,-7.74],[4.55,-7.74],[6.25,-7.25],[7.4,-5.89],[7.82,-3.8],[7.82,-3.8],[7.4,-1.7],[6.26,-0.33],[4.57,0.16],[4.57,0.16],[3.4,-0.09],[2.71,-0.65],[2.35,-1.17],[2.35,-1.17],[2.25,-1.17],[2.25,2.86]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.15,0.21],[-0.29,0.17],[-0.49,0],[0,0],[-0.49,-0.33],[-0.27,-0.59],[0,-0.8],[0,0],[0.28,-0.59],[0.49,-0.32],[0.64,0],[0,0],[0.29,0.17],[0.16,0.21],[0.09,0.14],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.09,-0.13],[0.15,-0.21],[0.29,-0.17],[0,0],[0.65,0],[0.49,0.32],[0.28,0.59],[0,0],[0,0.81],[-0.27,0.59],[-0.49,0.33],[0,0],[-0.49,0],[-0.3,-0.16],[-0.15,-0.21],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[2.23,-3.82],[2.23,-3.82],[2.48,-2.29],[3.22,-1.27],[4.41,-0.89],[4.41,-0.89],[5.65,-1.29],[6.39,-2.34],[6.64,-3.82],[6.64,-3.82],[6.4,-5.27],[5.66,-6.3],[4.41,-6.68],[4.41,-6.68],[3.21,-6.32],[2.48,-5.32],[2.23,-3.82]],"i":[[0,0],[0,0],[-0.17,-0.44],[-0.33,-0.25],[-0.47,0],[0,0],[-0.33,0.27],[-0.17,0.44],[0,0.55],[0,0],[0.16,0.43],[0.33,0.25],[0.5,0],[0,0],[0.33,-0.24],[0.16,-0.43],[0,-0.57]],"o":[[0,0],[0,0.58],[0.17,0.43],[0.33,0.25],[0,0],[0.49,0],[0.33,-0.26],[0.17,-0.44],[0,0],[0,-0.53],[-0.17,-0.43],[-0.33,-0.25],[0,0],[-0.47,0],[-0.33,0.24],[-0.17,0.43],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":42,"ty":4,"nm":"","ln":"-FRS8XqTtExS2anQu8Ony42","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49995.9,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.48],[2.29,-6.48],[3.04,-7.4],[4.28,-7.76],[4.28,-7.76],[4.6,-7.75],[4.89,-7.74],[4.89,-7.74],[4.89,-6.54],[4.62,-6.59],[4.18,-6.62],[4.18,-6.62],[3.18,-6.39],[2.5,-5.75],[2.25,-4.83],[2.25,-4.83],[2.25,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.23],[-0.46,0],[0,0],[-0.13,-0.01],[-0.07,-0.01],[0,0],[0,0],[0.14,0.02],[0.15,0],[0,0],[0.29,-0.15],[0.17,-0.27],[0,-0.35],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.14,-0.38],[0.37,-0.24],[0,0],[0.08,0],[0.13,0],[0,0],[0,0],[-0.04,-0.01],[-0.14,-0.02],[0,0],[-0.37,0],[-0.29,0.15],[-0.17,0.27],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":43,"ty":4,"nm":"","ln":"7C6IECMCU00ysAIGILdVR43","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49987.77,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":44,"ty":4,"nm":"","ln":"FRUk4z47ybz2T3K6F0_Dd44","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.88,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.47,0],[1.23,0],[1.23,-10.18],[4.67,-10.18],[6.63,-9.75],[7.77,-8.59],[8.13,-6.96],[8.13,-6.96],[7.77,-5.32],[6.64,-4.15],[4.69,-3.72],[4.69,-3.72],[2.23,-3.72],[2.23,-4.81],[4.65,-4.81],[5.97,-5.1],[6.69,-5.86],[6.92,-6.96],[6.92,-6.96],[6.69,-8.05],[5.97,-8.81],[4.63,-9.09],[4.63,-9.09],[2.47,-9.09],[2.47,0]],"i":[[0,0],[0,0],[0,0],[0,0],[-0.51,-0.29],[-0.25,-0.49],[0,-0.6],[0,0],[0.24,-0.49],[0.51,-0.29],[0.79,0],[0,0],[0,0],[0,0],[0,0],[-0.33,0.19],[-0.15,0.32],[0,0.41],[0,0],[0.15,0.32],[0.33,0.18],[0.55,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0.8,0],[0.51,0.29],[0.24,0.49],[0,0],[0,0.6],[-0.25,0.49],[-0.51,0.29],[0,0],[0,0],[0,0],[0,0],[0.55,0],[0.33,-0.19],[0.15,-0.33],[0,0],[0,-0.41],[-0.15,-0.33],[-0.34,-0.19],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"qYKcfcz58Opar690-lv1r","layers":[{"ddd":0,"ind":32,"ty":0,"nm":"","ln":"precomp_OD3h7LScundq4YaU986-g32","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50023.09,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"EOsV9MOwzFUC7kk9K6GQM"},{"ddd":0,"ind":38,"ty":0,"nm":"","ln":"precomp_pdESY0dM-eoAGB2n_Hx6i38","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49976.41,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"FGsxvzMnAXygwmffmG9kG"}]},{"id":"iRcBi_xHKtXWrwizyeRtv","layers":[{"ddd":0,"ind":31,"ty":0,"nm":"","ln":"precomp_JWl_Hm04muo2mmRqHevzK31","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"qYKcfcz58Opar690-lv1r"}]},{"id":"YH5CVU7UK9vsA0i48-Jtb","layers":[]},{"h":45,"id":"4gQSYJgszUFsKLdudDOOh","p":"","u":"","w":45,"e":1},{"id":"rDQ42Ktp3VuLR4n9_Z5nA","layers":[{"ddd":0,"ind":49,"ty":2,"nm":"","ln":"4gQSYJgszUFsKLdudDOOh49","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"4gQSYJgszUFsKLdudDOOh"}]},{"id":"oB6naqSgwcvST_les_tvT","layers":[{"ddd":0,"ind":51,"ty":4,"nm":"","ln":"c9am_Ppom_grqe2IEAXh351","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"KBec0DrQ2_c6X20v50yTe","layers":[{"ddd":0,"ind":50,"ty":0,"nm":"","td":1,"ln":"precomp_Qavkk4XEYBKesd1zdbo7u50","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"oB6naqSgwcvST_les_tvT"},{"ddd":0,"ind":48,"ty":0,"nm":"","tt":1,"ln":"precomp_9WrMShYnpem-1AAL4MsYB48","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"rDQ42Ktp3VuLR4n9_Z5nA"}]},{"id":"ZM7NsE64fRw7AzB3ggCOq","layers":[]},{"id":"Ub8HZ3uZEsdTV7gkGRft_","layers":[]},{"id":"6zv7zwSlSFp2V9Fl2eCvJ","layers":[{"ddd":0,"ind":46,"ty":0,"nm":"","ln":"precomp_O8v3KhaTlxYoAvYJXZAQH46","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"YH5CVU7UK9vsA0i48-Jtb"},{"ddd":0,"ind":47,"ty":0,"nm":"","ln":"precomp_9WrMShYnpem-1AAL4MsYB47","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"KBec0DrQ2_c6X20v50yTe"},{"ddd":0,"ind":52,"ty":0,"nm":"","ln":"precomp_rr4LMHX3qbYfv66v_rNwK52","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ZM7NsE64fRw7AzB3ggCOq"},{"ddd":0,"ind":53,"ty":0,"nm":"","ln":"precomp_6yBfSdDVRbr5wXFS0Sw6c53","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Ub8HZ3uZEsdTV7gkGRft_"}]},{"id":"tmkAJkuDiGa3k45cfNDHX","layers":[]},{"h":45,"id":"zf_KalaBAksT15wSpMvX2","p":"","u":"","w":45,"e":1},{"id":"s8BZQqN6n0M6mg7CqY1Qv","layers":[{"ddd":0,"ind":58,"ty":2,"nm":"","ln":"zf_KalaBAksT15wSpMvX258","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"zf_KalaBAksT15wSpMvX2"}]},{"id":"iQQ1NcbCwxQk3isyu1EGL","layers":[{"ddd":0,"ind":60,"ty":4,"nm":"","ln":"XlfNcdLpzFtcP5EDbjuBM60","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"rMO7NDpsUMawfmI4isO1C","layers":[{"ddd":0,"ind":59,"ty":0,"nm":"","td":1,"ln":"precomp_YwPM2fEyXoLMBwLIlqB9t59","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"iQQ1NcbCwxQk3isyu1EGL"},{"ddd":0,"ind":57,"ty":0,"nm":"","tt":1,"ln":"precomp_oLXn8rEAW-cAfq-pdGb3v57","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"s8BZQqN6n0M6mg7CqY1Qv"}]},{"id":"uNB88Rz_lXU3aqAGEfNjU","layers":[]},{"id":"4Ld3trQ5W3nh7867Cz32F","layers":[]},{"id":"U9MRzR6pvpiACFeJgrcTv","layers":[{"ddd":0,"ind":55,"ty":0,"nm":"","ln":"precomp_0gCGmua0_mCx5Tr8qES1h55","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"tmkAJkuDiGa3k45cfNDHX"},{"ddd":0,"ind":56,"ty":0,"nm":"","ln":"precomp_oLXn8rEAW-cAfq-pdGb3v56","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"rMO7NDpsUMawfmI4isO1C"},{"ddd":0,"ind":61,"ty":0,"nm":"","ln":"precomp_6hW9dC_jZ8jaVokpru4JO61","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"uNB88Rz_lXU3aqAGEfNjU"},{"ddd":0,"ind":62,"ty":0,"nm":"","ln":"precomp_bGpH1q0BRpXIOh4c-gAC162","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"4Ld3trQ5W3nh7867Cz32F"}]},{"id":"tOUFjDxcKHHewoLwZnDHE","layers":[]},{"h":45,"id":"Egn3387Ps1k4PZkr_SxdI","p":"","u":"","w":45,"e":1},{"id":"GBvZiNr1dBZGkL4f0dzdq","layers":[{"ddd":0,"ind":67,"ty":2,"nm":"","ln":"Egn3387Ps1k4PZkr_SxdI67","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"Egn3387Ps1k4PZkr_SxdI"}]},{"id":"eqHMFBK0-OPPa25ZFkDJX","layers":[{"ddd":0,"ind":69,"ty":4,"nm":"","ln":"venPWQZUyTM5Y-f57iQ8a69","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"08nj_0V728Ao2zZUBJRTF","layers":[{"ddd":0,"ind":68,"ty":0,"nm":"","td":1,"ln":"precomp_Js7ORAxIEuWJ-H6P3V-rY68","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"eqHMFBK0-OPPa25ZFkDJX"},{"ddd":0,"ind":66,"ty":0,"nm":"","tt":1,"ln":"precomp_OoyeP8jO1eoCu9MuuhFoe66","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"GBvZiNr1dBZGkL4f0dzdq"}]},{"id":"Qg4AY92ZLqSCKDtgTrxMT","layers":[]},{"id":"zYr3VrLPQ7g_8Nwq0uMLE","layers":[]},{"id":"CTXWxQT7T1kaNLGT_r06a","layers":[{"ddd":0,"ind":64,"ty":0,"nm":"","ln":"precomp_6XAoblgwfCcPJ8-JeRaKh64","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"tOUFjDxcKHHewoLwZnDHE"},{"ddd":0,"ind":65,"ty":0,"nm":"","ln":"precomp_OoyeP8jO1eoCu9MuuhFoe65","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"08nj_0V728Ao2zZUBJRTF"},{"ddd":0,"ind":70,"ty":0,"nm":"","ln":"precomp_QVRseU6iF0VnLoT1qsWep70","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Qg4AY92ZLqSCKDtgTrxMT"},{"ddd":0,"ind":71,"ty":0,"nm":"","ln":"precomp_U8g1kByldUPc9IEfqnPkV71","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"zYr3VrLPQ7g_8Nwq0uMLE"}]},{"id":"L2qN6o-i6gRUzGdI0CsFi","layers":[]},{"h":45,"id":"KMdw1cMpQZlGE7LBVcdPj","p":"","u":"","w":45,"e":1},{"id":"YsgTAjER5l5U8v3RYfdJz","layers":[{"ddd":0,"ind":76,"ty":2,"nm":"","ln":"KMdw1cMpQZlGE7LBVcdPj76","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"KMdw1cMpQZlGE7LBVcdPj"}]},{"id":"doILsbkwzjCIbpUz1JP3X","layers":[{"ddd":0,"ind":78,"ty":4,"nm":"","ln":"n0N6-66T-9701RzXQmPFU78","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"SA80ewPxeqYmAxpZ6a52i","layers":[{"ddd":0,"ind":77,"ty":0,"nm":"","td":1,"ln":"precomp_s4GOjGMtVDMqjseChok3Q77","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"doILsbkwzjCIbpUz1JP3X"},{"ddd":0,"ind":75,"ty":0,"nm":"","tt":1,"ln":"precomp_X0tHjoBs4lkB_o5nZR8Sv75","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"YsgTAjER5l5U8v3RYfdJz"}]},{"id":"g-IV_G20YAqcsnz4U3jIZ","layers":[]},{"id":"Rh6FgYL5lVjoEqCqOjCjc","layers":[]},{"id":"ac6K0hNLRlJT73rABXMzz","layers":[{"ddd":0,"ind":73,"ty":0,"nm":"","ln":"precomp_zxox19N2bGXUL6IEUmR-373","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"L2qN6o-i6gRUzGdI0CsFi"},{"ddd":0,"ind":74,"ty":0,"nm":"","ln":"precomp_X0tHjoBs4lkB_o5nZR8Sv74","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"SA80ewPxeqYmAxpZ6a52i"},{"ddd":0,"ind":79,"ty":0,"nm":"","ln":"precomp_YxoprXsEdjYTTkxuaMy3G79","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"g-IV_G20YAqcsnz4U3jIZ"},{"ddd":0,"ind":80,"ty":0,"nm":"","ln":"precomp_vUnrU0ps6Nl6yKwYf7j9980","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Rh6FgYL5lVjoEqCqOjCjc"}]},{"id":"QRx4ZZa-w5sDJX1BddG5Z","layers":[]},{"h":45,"id":"7HzyddzLixrgwU_LvBFDC","p":"","u":"","w":45,"e":1},{"id":"yUtOhJ4AciIP5naD2K-bl","layers":[{"ddd":0,"ind":85,"ty":2,"nm":"","ln":"7HzyddzLixrgwU_LvBFDC85","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"7HzyddzLixrgwU_LvBFDC"}]},{"id":"guOmw4JyVkkmWa1H3Tsda","layers":[{"ddd":0,"ind":87,"ty":4,"nm":"","ln":"OVuUOzUtYwL98YLiexuvT87","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"Yxrvz_M4b_DVdKnzui30c","layers":[{"ddd":0,"ind":86,"ty":0,"nm":"","td":1,"ln":"precomp_AvKrXcHD0dh3SEnmUvxWO86","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"guOmw4JyVkkmWa1H3Tsda"},{"ddd":0,"ind":84,"ty":0,"nm":"","tt":1,"ln":"precomp_8V7nMbUE6RYJMl_BNYF7t84","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"yUtOhJ4AciIP5naD2K-bl"}]},{"id":"7UVTHIDzFUcuRq55lecMb","layers":[]},{"id":"EOZbrTqHhNPbPakzdNCZu","layers":[]},{"id":"zp_47RHDhWOPL2YKNJAyO","layers":[{"ddd":0,"ind":82,"ty":0,"nm":"","ln":"precomp_J3SYlmi2KBBjhxhM8ovtN82","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"QRx4ZZa-w5sDJX1BddG5Z"},{"ddd":0,"ind":83,"ty":0,"nm":"","ln":"precomp_8V7nMbUE6RYJMl_BNYF7t83","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Yxrvz_M4b_DVdKnzui30c"},{"ddd":0,"ind":88,"ty":0,"nm":"","ln":"precomp_9Fabst1DZ_JE1t0tFzfsw88","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"7UVTHIDzFUcuRq55lecMb"},{"ddd":0,"ind":89,"ty":0,"nm":"","ln":"precomp_RnOuiWdS-rNWjcz1fFS5g89","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"EOZbrTqHhNPbPakzdNCZu"}]},{"id":"BjqsPFDq7QhVMT_0-LHEw","layers":[]},{"h":45,"id":"Oe4-H4r-_2CJ5a6ulJFK7","p":"","u":"","w":45,"e":1},{"id":"HT-90P5ww_DyBBdZw_KnG","layers":[{"ddd":0,"ind":94,"ty":2,"nm":"","ln":"Oe4-H4r-_2CJ5a6ulJFK794","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"Oe4-H4r-_2CJ5a6ulJFK7"}]},{"id":"pULcnWU_wJiWN9wxtuXJH","layers":[{"ddd":0,"ind":96,"ty":4,"nm":"","ln":"IpcTTbcXedkiHr8lJoawB96","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"liOBLBny93AnNE8mCkE7E","layers":[{"ddd":0,"ind":95,"ty":0,"nm":"","td":1,"ln":"precomp_DjXKQIPqL-EnBoqfMZ50u95","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"pULcnWU_wJiWN9wxtuXJH"},{"ddd":0,"ind":93,"ty":0,"nm":"","tt":1,"ln":"precomp_zBVOqJSvRiXM_slus_4CC93","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"HT-90P5ww_DyBBdZw_KnG"}]},{"id":"ZWB1OZ35Xz_qaAdnxnx26","layers":[]},{"id":"weu9do-hbtEhSLJWq3_vu","layers":[]},{"id":"Zwor7kLpkgNb0k43-Qlph","layers":[{"ddd":0,"ind":91,"ty":0,"nm":"","ln":"precomp_XJJCB_LiWqDiz1c47dyJD91","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"BjqsPFDq7QhVMT_0-LHEw"},{"ddd":0,"ind":92,"ty":0,"nm":"","ln":"precomp_zBVOqJSvRiXM_slus_4CC92","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"liOBLBny93AnNE8mCkE7E"},{"ddd":0,"ind":97,"ty":0,"nm":"","ln":"precomp_9qbOFb_AfcVZ-TcWaVDJ697","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ZWB1OZ35Xz_qaAdnxnx26"},{"ddd":0,"ind":98,"ty":0,"nm":"","ln":"precomp_luUeyeJAVHkTtwf5HIdI198","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"weu9do-hbtEhSLJWq3_vu"}]},{"id":"ZzhyZtXwWuhCUsiEMA6DD","layers":[]},{"h":45,"id":"YPR-Pq_UPuqhLd0PjOmxa","p":"","u":"","w":45,"e":1},{"id":"vVKtULnfcLUD3W_q0h9WN","layers":[{"ddd":0,"ind":103,"ty":2,"nm":"","ln":"YPR-Pq_UPuqhLd0PjOmxa103","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"YPR-Pq_UPuqhLd0PjOmxa"}]},{"id":"FswEgEHGVGPK2BFw6MT2M","layers":[{"ddd":0,"ind":105,"ty":4,"nm":"","ln":"ecCiEfUjOAqnLU4fShpT6105","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"kf7Z-bKDQ78VsspA5rgB5","layers":[{"ddd":0,"ind":104,"ty":0,"nm":"","td":1,"ln":"precomp_9X69EtdqtBoAE_cekJYNI104","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"FswEgEHGVGPK2BFw6MT2M"},{"ddd":0,"ind":102,"ty":0,"nm":"","tt":1,"ln":"precomp_GGTS4qBu0LqAzUFNxzLs8102","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"vVKtULnfcLUD3W_q0h9WN"}]},{"id":"gUbvnQ5a-CQbiE8gBECK2","layers":[]},{"id":"A64O5AX8OEuDPOhsPuyXA","layers":[]},{"id":"2FY4b6yj0H0r1F0E-SaDS","layers":[{"ddd":0,"ind":100,"ty":0,"nm":"","ln":"precomp_7YbozT97zj8vwyy8PIjHS100","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ZzhyZtXwWuhCUsiEMA6DD"},{"ddd":0,"ind":101,"ty":0,"nm":"","ln":"precomp_GGTS4qBu0LqAzUFNxzLs8101","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"kf7Z-bKDQ78VsspA5rgB5"},{"ddd":0,"ind":106,"ty":0,"nm":"","ln":"precomp_QbJcqJiQpEVaPnZ2XcqtI106","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"gUbvnQ5a-CQbiE8gBECK2"},{"ddd":0,"ind":107,"ty":0,"nm":"","ln":"precomp_4JgBf9w6NrnRb8Yw6xsBw107","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"A64O5AX8OEuDPOhsPuyXA"}]},{"id":"wsnlJJ6BwaLar_mbnzbWT","layers":[]},{"h":45,"id":"3aVU97k5BdyNqgXYA8m3D","p":"","u":"","w":45,"e":1},{"id":"QOcQ7YDqL5F4lOp43c1zZ","layers":[{"ddd":0,"ind":112,"ty":2,"nm":"","ln":"3aVU97k5BdyNqgXYA8m3D112","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"3aVU97k5BdyNqgXYA8m3D"}]},{"id":"3ek5i8a5n5WqRnU0zh4yy","layers":[{"ddd":0,"ind":114,"ty":4,"nm":"","ln":"Qot_ZAGZLZhknO-G6M-OP114","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"Wrd3THBcgTm3mGXGbIu1X","layers":[{"ddd":0,"ind":113,"ty":0,"nm":"","td":1,"ln":"precomp_MfYiM8cjBucHmD2lS7VZC113","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"3ek5i8a5n5WqRnU0zh4yy"},{"ddd":0,"ind":111,"ty":0,"nm":"","tt":1,"ln":"precomp__3cKk1jl4F-GlXoEdcNGK111","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"QOcQ7YDqL5F4lOp43c1zZ"}]},{"id":"jbf6cJ3QSyuOEmBqKuwFm","layers":[]},{"id":"YL8YeExpJmTDNK1e5-4Yg","layers":[]},{"id":"LPpqaL_n_K6M0hFvh0ZHA","layers":[{"ddd":0,"ind":109,"ty":0,"nm":"","ln":"precomp_O0oO7A3sOYEBTum1bQnJ_109","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"wsnlJJ6BwaLar_mbnzbWT"},{"ddd":0,"ind":110,"ty":0,"nm":"","ln":"precomp__3cKk1jl4F-GlXoEdcNGK110","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Wrd3THBcgTm3mGXGbIu1X"},{"ddd":0,"ind":115,"ty":0,"nm":"","ln":"precomp_YgJGQLmGv_eVAj3VLGPBv115","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"jbf6cJ3QSyuOEmBqKuwFm"},{"ddd":0,"ind":116,"ty":0,"nm":"","ln":"precomp_mM2kXxgqNx4h2rm9US3vU116","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"YL8YeExpJmTDNK1e5-4Yg"}]},{"id":"JU6aq4uQ3FDCe4pX6h6xO","layers":[{"ddd":0,"ind":118,"ty":4,"nm":"","ln":"jDg1YVeGmP2sr7VK1ce0I118","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"st","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"lc":2,"lj":1,"o":{"a":0,"k":100},"w":{"a":0,"k":1}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":119,"ty":4,"nm":"","ln":"SLNGnzt3_E43BNmHRC3Zd119","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.7,0.7,0.7]},"r":1,"o":{"a":0,"k":0}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"C44CHRfofMBfxsVf6xzqk","layers":[{"ddd":0,"ind":121,"ty":4,"nm":"","ln":"4OxLQY2uuXuNzQDmnuQoC121","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"st","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"lc":2,"lj":1,"o":{"a":0,"k":100},"w":{"a":0,"k":1}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":122,"ty":4,"nm":"","ln":"ZuU_jXvp3bS07fGJIcLdU122","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.7,0.7,0.7]},"r":1,"o":{"a":0,"k":0}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"bdXhUv_rFrJiTxgrT6WmR","layers":[{"ddd":0,"ind":124,"ty":4,"nm":"","ln":"O2ysFUVPGT5B9DNxVxiT9124","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"st","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"lc":2,"lj":1,"o":{"a":0,"k":100},"w":{"a":0,"k":1}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":125,"ty":4,"nm":"","ln":"q7kCcu6ZzObus8lTKSDuJ125","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.7,0.7,0.7]},"r":1,"o":{"a":0,"k":0}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"HKTTx1IfJ95JzDbiU12TF","layers":[]},{"h":184,"id":"8JHreVabrDZr8b36yyKem","p":"","u":"","w":218,"e":1},{"id":"OpasQtHEzNjFrAyIMhq1h","layers":[{"ddd":0,"ind":130,"ty":2,"nm":"","ln":"8JHreVabrDZr8b36yyKem130","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49891,49908]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"8JHreVabrDZr8b36yyKem"}]},{"id":"iASKmFknps-PMSPHPktmU","layers":[{"ddd":0,"ind":132,"ty":4,"nm":"","ln":"wqjpeOIRUjlQtSTiVFQKJ132","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[218,184]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"MTzeEoZrdGajlen8_elC6","layers":[{"ddd":0,"ind":131,"ty":0,"nm":"","td":1,"ln":"precomp_cd9iq9L8hqrjrg6w1b9DZ131","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"iASKmFknps-PMSPHPktmU"},{"ddd":0,"ind":129,"ty":0,"nm":"","tt":1,"ln":"precomp_dBih5zMtUBC9gUMXHdJaq129","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"OpasQtHEzNjFrAyIMhq1h"}]},{"id":"VVdYvgSHPfZdtbNGkxmQU","layers":[]},{"id":"DxOD47BsEaNsp1aUQiNwF","layers":[]},{"id":"EOIxbBO4OXrBVS5vldXGp","layers":[{"ddd":0,"ind":127,"ty":0,"nm":"","ln":"precomp_Ci5NyvMt_mnWFF98RfA0w127","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"HKTTx1IfJ95JzDbiU12TF"},{"ddd":0,"ind":128,"ty":0,"nm":"","ln":"precomp_dBih5zMtUBC9gUMXHdJaq128","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"MTzeEoZrdGajlen8_elC6"},{"ddd":0,"ind":133,"ty":0,"nm":"","ln":"precomp_JrcgqlSEFwVyfuM1FVHuq133","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"VVdYvgSHPfZdtbNGkxmQU"},{"ddd":0,"ind":134,"ty":0,"nm":"","ln":"precomp_AkAiHLuUlBqZbFRAvgQ70134","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"DxOD47BsEaNsp1aUQiNwF"}]},{"id":"Wc3ZJh16yNCYrhrQQEGG5","layers":[]},{"id":"nL2T8CWzs8Ca8b5QEazrI","layers":[{"ddd":0,"ind":137,"ty":4,"nm":"","ln":"oBl3iqGqOsXoSKUDeyhbr137","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[920,526]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.01,0.03,0.09]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"eUQiNf0YSBZDw8yiy9TGE","layers":[{"ddd":0,"ind":1,"ty":0,"nm":"","ln":"precomp_50BjCsuBo5ifoBCeP1Ny01","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49865.25,50056]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"7Wus07HRPKsI75JEaEl0n"},{"ddd":0,"ind":15,"ty":0,"nm":"","ln":"precomp_wtXxtSFgt6thxf3c9tnmo15","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49869.25,49977]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Jp0B0YmZgZOEb0g-EEFFt"},{"ddd":0,"ind":30,"ty":0,"nm":"","ln":"precomp_m7Kl0SSG4ANVOTJU_73bd30","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49866.25,49897.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"iRcBi_xHKtXWrwizyeRtv"},{"ddd":0,"ind":45,"ty":0,"nm":"","ln":"precomp_HKgzMMXB_9yz2gNJ3gAEg45","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":360,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":384,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49437.5,50010.5],"h":1},{"t":0,"s":[49437.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49487.5,50010.5],"h":1},{"t":24,"s":[49487.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49537.5,50010.5],"h":1},{"t":48,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49587.5,50010.5],"h":1},{"t":72,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49637.5,50010.5],"h":1},{"t":96,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49687.5,50010.5],"h":1},{"t":120,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49737.5,50010.5],"h":1},{"t":144,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50087.5,50092],"h":1},{"t":240,"s":[50087.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50137.5,50092],"h":1},{"t":288,"s":[50137.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":312,"s":[50187.5,50092],"h":1},{"t":336,"s":[50187.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":360,"s":[50328.25,50010.5],"h":1},{"t":360,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":384,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"6zv7zwSlSFp2V9Fl2eCvJ"},{"ddd":0,"ind":54,"ty":0,"nm":"","ln":"precomp_N7nhrh3I-fJEG56En1Z2Z54","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":312,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":336,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49487.5,50010.5],"h":1},{"t":0,"s":[49487.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49537.5,50010.5],"h":1},{"t":24,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49587.5,50010.5],"h":1},{"t":48,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49637.5,50010.5],"h":1},{"t":72,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49687.5,50010.5],"h":1},{"t":96,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49737.5,50010.5],"h":1},{"t":120,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50137.5,50092],"h":1},{"t":240,"s":[50137.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50187.5,50092],"h":1},{"t":288,"s":[50187.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":312,"s":[50328.25,50013],"h":1},{"t":312,"s":[50328.25,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":336,"s":[50378.25,50013],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"U9MRzR6pvpiACFeJgrcTv"},{"ddd":0,"ind":63,"ty":0,"nm":"","ln":"precomp_d7LGjssn6jk_BAI4iTpbu63","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":264,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":288,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49537.5,50010.5],"h":1},{"t":0,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49587.5,50010.5],"h":1},{"t":24,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49637.5,50010.5],"h":1},{"t":48,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49687.5,50010.5],"h":1},{"t":72,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49737.5,50010.5],"h":1},{"t":96,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50187.5,50092],"h":1},{"t":240,"s":[50187.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50328.25,50010.5],"h":1},{"t":264,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"CTXWxQT7T1kaNLGT_r06a"},{"ddd":0,"ind":72,"ty":0,"nm":"","ln":"precomp_7SfQxvberzjgAVfhsi9pe72","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":216,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":240,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49737.5,50010.5],"h":1},{"t":0,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50187.5,49933.5],"h":1},{"t":192,"s":[50187.5,49933.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":216,"s":[50328.25,50010.5],"h":1},{"t":216,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ac6K0hNLRlJT73rABXMzz"},{"ddd":0,"ind":81,"ty":0,"nm":"","ln":"precomp_FIHMNKbi4iu5cCbZxUXdf81","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":384,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":408,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49387.5,50010.5],"h":1},{"t":0,"s":[49387.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49437.5,50010.5],"h":1},{"t":24,"s":[49437.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49487.5,50010.5],"h":1},{"t":48,"s":[49487.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49537.5,50010.5],"h":1},{"t":72,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49587.5,50010.5],"h":1},{"t":96,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49637.5,50010.5],"h":1},{"t":120,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49687.5,50010.5],"h":1},{"t":144,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[49737.5,50010.5],"h":1},{"t":168,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50037.5,50013],"h":1},{"t":216,"s":[50037.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50087.5,50013],"h":1},{"t":264,"s":[50087.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50137.5,50013],"h":1},{"t":312,"s":[50137.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":336,"s":[50187.5,50013],"h":1},{"t":360,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":384,"s":[50328.25,50010.5],"h":1},{"t":384,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":408,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"zp_47RHDhWOPL2YKNJAyO"},{"ddd":0,"ind":90,"ty":0,"nm":"","ln":"precomp_7_FmaXQ-YbQ-1IYDy1rMY90","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":336,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":360,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49587.5,50010.5],"h":1},{"t":0,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49637.5,50010.5],"h":1},{"t":24,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49687.5,50010.5],"h":1},{"t":48,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49737.5,50010.5],"h":1},{"t":72,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50087.5,50013],"h":1},{"t":216,"s":[50087.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50137.5,50013],"h":1},{"t":264,"s":[50137.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50187.5,50013],"h":1},{"t":312,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":336,"s":[50328.25,50013],"h":1},{"t":336,"s":[50328.25,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":360,"s":[50378.25,50013],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Zwor7kLpkgNb0k43-Qlph"},{"ddd":0,"ind":99,"ty":0,"nm":"","ln":"precomp_emRKRZikc8bw6EY2cjzDa99","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":288,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":312,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49637.5,50010.5],"h":1},{"t":0,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49687.5,50010.5],"h":1},{"t":24,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49737.5,50010.5],"h":1},{"t":48,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50137.5,50013],"h":1},{"t":216,"s":[50137.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50187.5,50013],"h":1},{"t":264,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50328.25,50010.5],"h":1},{"t":288,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":312,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"2FY4b6yj0H0r1F0E-SaDS"},{"ddd":0,"ind":108,"ty":0,"nm":"","ln":"precomp_SSbPtfB45NY2wk8qYEhVs108","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":240,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":264,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49687.5,50010.5],"h":1},{"t":0,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49737.5,50010.5],"h":1},{"t":24,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50187.5,50013],"h":1},{"t":216,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50328.25,50010.5],"h":1},{"t":240,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"LPpqaL_n_K6M0hFvh0ZHA"},{"ddd":0,"ind":117,"ty":0,"nm":"","ln":"precomp_W7YJwshIba8BmduW68GOG117","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50020.25,50089.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"JU6aq4uQ3FDCe4pX6h6xO"},{"ddd":0,"ind":120,"ty":0,"nm":"","ln":"precomp_4RgBXf7W72K7CtHuqb6BB120","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50020.25,50010.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"C44CHRfofMBfxsVf6xzqk"},{"ddd":0,"ind":123,"ty":0,"nm":"","ln":"precomp_9GlXlSWfNMzKJUuUoVjCr123","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50020.25,49931]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"bdXhUv_rFrJiTxgrT6WmR"},{"ddd":0,"ind":126,"ty":0,"nm":"","ln":"precomp_MprMPTSLYQOXKH26z-kdy126","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50328.25,50010.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"EOIxbBO4OXrBVS5vldXGp"},{"ddd":0,"ind":135,"ty":0,"nm":"","ln":"precomp_-nOOjocjnxeOr4WDqY2TE135","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Wc3ZJh16yNCYrhrQQEGG5"},{"ddd":0,"ind":136,"ty":0,"nm":"","ln":"precomp_M2rXmKrDr3yuZuZknJ3v-136","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"nL2T8CWzs8Ca8b5QEazrI"}]}],"ddd":0,"fr":60,"h":526,"ip":0,"layers":[{"ddd":0,"ind":0,"ty":0,"nm":"","ln":"precomp_RhoI5eMdh0y036MGIYl__0","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[460,263]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"eUQiNf0YSBZDw8yiy9TGE"}],"meta":{"g":"https://jitter.video"},"nm":"Fairness-[copy]","op":450,"v":"5.7.4","w":920} \ No newline at end of file +{"assets":[{"id":"2uHEIitlvEhXAXuT7rtbi","layers":[{"ddd":0,"ind":4,"ty":4,"nm":"","ln":"MGr6XcqyM6ZtNnaTQx5iA4","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50013.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":5,"ty":4,"nm":"","ln":"umZcEdlnKLFRh9M_DZdxf5","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50005.33,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":6,"ty":4,"nm":"","ln":"0L-RDgjtb_dPNDSOuLEE36","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49997.18,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":7,"ty":4,"nm":"","ln":"ELd3Hab3Lnoae6QFF-Urp7","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49989.04,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":8,"ty":4,"nm":"","ln":"tI5f6mHMTMy8PDtxhWepZ8","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.38,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[6.66,-0.91],[4.93,-3.18],[6.28,-3.18],[7.42,-1.69],[7.72,-1.29],[9.41,0.95],[8.05,0.95],[6.94,-0.54],[6.66,-0.91]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":2,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"xrXAHmd2cqSuodyQQslDc","layers":[{"ddd":0,"ind":10,"ty":4,"nm":"","ln":"aJuni2blCHZLZoTIN4o-N10","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50011.74,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,-4.59],[2.25,-4.59],[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.44],[2.31,-6.44],[3.12,-7.38],[4.53,-7.74],[4.53,-7.74],[5.89,-7.42],[6.8,-6.47],[7.12,-4.85],[7.12,-4.85],[7.12,0],[5.95,0],[5.95,-4.77],[5.48,-6.18],[4.2,-6.68],[4.2,-6.68],[3.19,-6.44],[2.5,-5.73],[2.25,-4.59]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.24],[-0.57,0],[0,0],[-0.39,-0.21],[-0.22,-0.42],[0,-0.65],[0,0],[0,0],[0,0],[0,0],[0.31,0.34],[0.54,0],[0,0],[0.29,-0.16],[0.17,-0.31],[0,-0.45]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.18,-0.39],[0.37,-0.24],[0,0],[0.52,0],[0.39,0.21],[0.21,0.43],[0,0],[0,0],[0,0],[0,0],[0,-0.6],[-0.31,-0.33],[0,0],[-0.38,0],[-0.29,0.17],[-0.17,0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":11,"ty":4,"nm":"","ln":"gcLryFT78CFTB94YLMJOP11","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50003.59,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":12,"ty":4,"nm":"","ln":"KYlnWjN1kZvKAjOU6V4V412","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49995.44,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":13,"ty":4,"nm":"","ln":"Y1Ma0SO-KnQcoIG1YMXcB13","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49990.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.48],[2.29,-6.48],[3.04,-7.4],[4.28,-7.76],[4.28,-7.76],[4.6,-7.75],[4.89,-7.74],[4.89,-7.74],[4.89,-6.54],[4.62,-6.59],[4.18,-6.62],[4.18,-6.62],[3.18,-6.39],[2.5,-5.75],[2.25,-4.83],[2.25,-4.83],[2.25,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.23],[-0.46,0],[0,0],[-0.13,-0.01],[-0.07,-0.01],[0,0],[0,0],[0.14,0.02],[0.15,0],[0,0],[0.29,-0.15],[0.17,-0.27],[0,-0.35],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.14,-0.38],[0.37,-0.24],[0,0],[0.08,0],[0.13,0],[0,0],[0,0],[-0.04,-0.01],[-0.14,-0.02],[0,0],[-0.37,0],[-0.29,0.15],[-0.17,0.27],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":14,"ty":4,"nm":"","ln":"i9DYTo2DNGfOt0DFAzLJU14","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49980.06,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[9.47,-7],[8.19,-7],[7.76,-7.9],[7.13,-8.59],[6.3,-9.02],[5.29,-9.17],[5.29,-9.17],[3.64,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.67,-1.48],[5.37,-1.01],[5.37,-1.01],[6.91,-1.39],[7.96,-2.45],[8.33,-4.08],[8.33,-4.08],[8.71,-4],[5.65,-4],[5.65,-5.09],[9.53,-5.09],[9.53,-4],[8.99,-1.81],[7.52,-0.37],[5.37,0.14],[5.37,0.14],[3,-0.5],[1.4,-2.31],[0.84,-5.09],[0.84,-5.09],[1.16,-7.27],[2.08,-8.91],[3.5,-9.96],[5.29,-10.32],[5.29,-10.32],[6.79,-10.08],[8.04,-9.4],[8.96,-8.35],[9.47,-7],[9.47,-7]],"i":[[0,0],[0,0],[0.18,0.27],[0.25,0.19],[0.31,0.1],[0.37,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.51,-0.31],[-0.63,0],[0,0],[-0.45,0.25],[-0.25,0.46],[0,0.63],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.36,-0.62],[0.63,-0.34],[0.81,0],[0,0],[0.68,0.43],[0.38,0.79],[0,1.07],[0,0],[-0.21,0.65],[-0.39,0.45],[-0.55,0.24],[-0.65,0],[0,0],[-0.46,-0.16],[-0.37,-0.29],[-0.25,-0.41],[-0.09,-0.49],[0,0]],"o":[[0,0],[-0.11,-0.33],[-0.17,-0.27],[-0.24,-0.19],[-0.31,-0.1],[0,0],[-0.61,0],[-0.49,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.5,0.31],[0,0],[0.58,0],[0.45,-0.25],[0.25,-0.46],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0.84],[-0.35,0.62],[-0.63,0.34],[0,0],[-0.9,0],[-0.69,-0.42],[-0.37,-0.78],[0,0],[0,-0.81],[0.22,-0.64],[0.4,-0.46],[0.54,-0.24],[0,0],[0.54,0],[0.47,0.16],[0.37,0.29],[0.25,0.41],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"JH-Qh5yFb_R2hngk4MZHU","layers":[{"ddd":0,"ind":3,"ty":0,"nm":"","ln":"precomp_VXkL6qRf6LI04kaA6tDua3","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50021.9,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"2uHEIitlvEhXAXuT7rtbi"},{"ddd":0,"ind":9,"ty":0,"nm":"","ln":"precomp_o4Bbyc5L9OIMQfQ_5nsQS9","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49976.41,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"xrXAHmd2cqSuodyQQslDc"}]},{"id":"7Wus07HRPKsI75JEaEl0n","layers":[{"ddd":0,"ind":2,"ty":0,"nm":"","ln":"precomp_pwNI-chb2pctizggX4lVG2","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"JH-Qh5yFb_R2hngk4MZHU"}]},{"id":"d2AUkWQ53X0lsGkTR4MpT","layers":[{"ddd":0,"ind":18,"ty":4,"nm":"","ln":"_1Fu1BEt4e_6Pkzzxkp4H18","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50013.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":19,"ty":4,"nm":"","ln":"ea7yzB5KrJt2af5T64TPO19","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50005.33,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":20,"ty":4,"nm":"","ln":"9aM7UvRfjgNY9RonWP5ad20","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49997.18,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":21,"ty":4,"nm":"","ln":"pvuFDnIu6DnAOry3BT42l21","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49989.04,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":22,"ty":4,"nm":"","ln":"DCMAtpW49_2UUlAts219822","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.38,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[6.66,-0.91],[4.93,-3.18],[6.28,-3.18],[7.42,-1.69],[7.72,-1.29],[9.41,0.95],[8.05,0.95],[6.94,-0.54],[6.66,-0.91]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":2,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"u6N3VAn9hoOmLDTz2sClC","layers":[{"ddd":0,"ind":24,"ty":4,"nm":"","ln":"AX_DzdIWUTyoQWFHtCi--24","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50016.17,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":25,"ty":4,"nm":"","ln":"CQdnIF9xj5JPsVmYMlHBf25","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50007.64,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.16,3.02],[4.16,3.02],[2.69,2.81],[1.68,2.24],[1.03,1.49],[1.03,1.49],[1.97,0.84],[2.37,1.31],[3.04,1.79],[4.16,1.99],[4.16,1.99],[5.68,1.54],[6.28,0.14],[6.28,0.14],[6.28,-1.41],[6.18,-1.41],[5.82,-0.9],[5.14,-0.36],[3.96,-0.12],[3.96,-0.12],[2.3,-0.56],[1.14,-1.83],[0.72,-3.86],[0.72,-3.86],[1.13,-5.9],[2.28,-7.26],[3.98,-7.74],[3.98,-7.74],[5.16,-7.49],[5.84,-6.93],[6.2,-6.42],[6.2,-6.42],[6.32,-6.42],[6.32,-7.64],[7.46,-7.64],[7.46,0.22],[7.01,1.82],[5.82,2.73],[4.16,3.02]],"i":[[0,0],[0,0],[0.41,0.14],[0.27,0.23],[0.16,0.27],[0,0],[0,0],[-0.16,-0.18],[-0.28,-0.13],[-0.46,0],[0,0],[-0.4,0.3],[0,0.63],[0,0],[0,0],[0,0],[0.16,-0.2],[0.29,-0.15],[0.49,0],[0,0],[0.49,0.29],[0.29,0.56],[0,0.8],[0,0],[-0.27,0.58],[-0.49,0.32],[-0.65,0],[0,0],[-0.29,-0.17],[-0.16,-0.21],[-0.08,-0.13],[0,0],[0,0],[0,0],[0,0],[0,0],[0.3,-0.41],[0.5,-0.19],[0.61,0]],"o":[[0,0],[-0.57,0],[-0.41,-0.15],[-0.27,-0.23],[0,0],[0,0],[0.11,0.13],[0.17,0.19],[0.29,0.13],[0,0],[0.61,0],[0.4,-0.3],[0,0],[0,0],[0,0],[-0.08,0.14],[-0.16,0.21],[-0.29,0.16],[0,0],[-0.62,0],[-0.49,-0.29],[-0.28,-0.55],[0,0],[0,-0.78],[0.27,-0.59],[0.49,-0.32],[0,0],[0.49,0],[0.29,0.17],[0.16,0.21],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0.65],[-0.29,0.41],[-0.5,0.19],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[4.12,-1.17],[4.12,-1.17],[5.31,-1.5],[6.05,-2.43],[6.3,-3.88],[6.3,-3.88],[6.06,-5.33],[5.32,-6.32],[4.12,-6.68],[4.12,-6.68],[2.88,-6.3],[2.14,-5.29],[1.89,-3.88],[1.89,-3.88],[2.14,-2.47],[2.89,-1.52],[4.12,-1.17]],"i":[[0,0],[0,0],[-0.33,0.22],[-0.17,0.41],[0,0.57],[0,0],[0.16,0.42],[0.33,0.23],[0.47,0],[0,0],[0.33,-0.25],[0.16,-0.43],[0,-0.51],[0,0],[-0.17,-0.41],[-0.33,-0.23],[-0.49,0]],"o":[[0,0],[0.47,0],[0.33,-0.21],[0.17,-0.4],[0,0],[0,-0.55],[-0.17,-0.43],[-0.33,-0.24],[0,0],[-0.5,0],[-0.33,0.25],[-0.17,0.43],[0,0],[0,0.53],[0.17,0.41],[0.33,0.23],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":26,"ty":4,"nm":"","ln":"PAStx1VrGPKLuideNtw4n26","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49999.44,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,-4.59],[2.25,-4.59],[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.44],[2.31,-6.44],[3.12,-7.38],[4.53,-7.74],[4.53,-7.74],[5.89,-7.42],[6.8,-6.47],[7.12,-4.85],[7.12,-4.85],[7.12,0],[5.95,0],[5.95,-4.77],[5.48,-6.18],[4.2,-6.68],[4.2,-6.68],[3.19,-6.44],[2.5,-5.73],[2.25,-4.59]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.24],[-0.57,0],[0,0],[-0.39,-0.21],[-0.22,-0.42],[0,-0.65],[0,0],[0,0],[0,0],[0,0],[0.31,0.34],[0.54,0],[0,0],[0.29,-0.16],[0.17,-0.31],[0,-0.45]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.18,-0.39],[0.37,-0.24],[0,0],[0.52,0],[0.39,0.21],[0.21,0.43],[0,0],[0,0],[0,0],[0,0],[0,-0.6],[-0.31,-0.33],[0,0],[-0.38,0],[-0.29,0.17],[-0.17,0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":27,"ty":4,"nm":"","ln":"3xyOLy3ngRnUReqnad5ze27","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49991.55,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[3.32,0.18],[3.32,0.18],[2,-0.1],[1.06,-0.9],[0.72,-2.17],[0.72,-2.17],[0.97,-3.23],[1.67,-3.88],[2.62,-4.23],[3.68,-4.41],[3.68,-4.41],[4.81,-4.55],[5.45,-4.71],[5.65,-5.11],[5.65,-5.11],[5.65,-5.15],[5.25,-6.29],[4.04,-6.7],[4.04,-6.7],[2.72,-6.33],[2.05,-5.55],[2.05,-5.55],[0.93,-5.95],[1.73,-7.03],[2.83,-7.58],[4,-7.74],[4,-7.74],[4.84,-7.65],[5.77,-7.29],[6.52,-6.48],[6.82,-5.03],[6.82,-5.03],[6.82,0],[5.65,0],[5.65,-1.03],[5.59,-1.03],[5.19,-0.5],[4.45,-0.02],[3.32,0.18]],"i":[[0,0],[0,0],[0.4,0.19],[0.23,0.35],[0,0.5],[0,0],[-0.17,0.27],[-0.29,0.16],[-0.35,0.08],[-0.35,0.04],[0,0],[-0.29,0.03],[-0.13,0.07],[0,0.19],[0,0],[0,0],[0.27,0.27],[0.54,0],[0,0],[0.32,-0.25],[0.13,-0.28],[0,0],[0,0],[-0.33,0.26],[-0.4,0.11],[-0.39,0],[0,0],[-0.31,-0.06],[-0.3,-0.18],[-0.2,-0.36],[0,-0.61],[0,0],[0,0],[0,0],[0,0],[0,0],[0.19,-0.19],[0.31,-0.13],[0.45,0]],"o":[[0,0],[-0.48,0],[-0.39,-0.18],[-0.23,-0.35],[0,0],[0,-0.43],[0.17,-0.27],[0.29,-0.15],[0.35,-0.08],[0,0],[0.47,-0.06],[0.29,-0.03],[0.13,-0.08],[0,0],[0,0],[0,-0.49],[-0.27,-0.27],[0,0],[-0.56,0],[-0.32,0.24],[0,0],[0,0],[0.2,-0.46],[0.33,-0.26],[0.39,-0.11],[0,0],[0.25,0],[0.32,0.06],[0.3,0.18],[0.2,0.36],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.08,0.16],[-0.19,0.19],[-0.31,0.13],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[3.5,-0.88],[3.5,-0.88],[4.68,-1.15],[5.4,-1.85],[5.65,-2.76],[5.65,-2.76],[5.65,-3.84],[5.32,-3.68],[4.75,-3.55],[4.11,-3.46],[3.62,-3.4],[3.62,-3.4],[2.77,-3.21],[2.13,-2.82],[1.89,-2.11],[1.89,-2.11],[2.34,-1.19],[3.5,-0.88]],"i":[[0,0],[0,0],[-0.32,0.18],[-0.16,0.29],[0,0.31],[0,0],[0,0],[0.17,-0.05],[0.21,-0.03],[0.21,-0.03],[0.13,-0.02],[0,0],[0.26,-0.09],[0.16,-0.17],[0,-0.3],[0,0],[-0.3,-0.21],[-0.47,0]],"o":[[0,0],[0.47,0],[0.32,-0.18],[0.17,-0.29],[0,0],[0,0],[-0.05,0.06],[-0.17,0.05],[-0.22,0.03],[-0.2,0.02],[0,0],[-0.31,0.04],[-0.27,0.09],[-0.16,0.17],[0,0],[0,0.41],[0.31,0.21],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":28,"ty":4,"nm":"","ln":"hSrS9H20rEu1Rf2IO6-Wq28","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49986.34,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.48],[2.29,-6.48],[3.04,-7.4],[4.28,-7.76],[4.28,-7.76],[4.6,-7.75],[4.89,-7.74],[4.89,-7.74],[4.89,-6.54],[4.62,-6.59],[4.18,-6.62],[4.18,-6.62],[3.18,-6.39],[2.5,-5.75],[2.25,-4.83],[2.25,-4.83],[2.25,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.23],[-0.46,0],[0,0],[-0.13,-0.01],[-0.07,-0.01],[0,0],[0,0],[0.14,0.02],[0.15,0],[0,0],[0.29,-0.15],[0.17,-0.27],[0,-0.35],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.14,-0.38],[0.37,-0.24],[0,0],[0.08,0],[0.13,0],[0,0],[0,0],[-0.04,-0.01],[-0.14,-0.02],[0,0],[-0.37,0],[-0.29,0.15],[-0.17,0.27],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":29,"ty":4,"nm":"","ln":"L3SWoyp-j49t2zuQkxO3l29","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49975.68,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"qOK4BaItY-C8lU0fm3KpK","layers":[{"ddd":0,"ind":17,"ty":0,"nm":"","ln":"precomp_z7IxkdFMFgi3TNtxAe_fX17","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50026.29,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"d2AUkWQ53X0lsGkTR4MpT"},{"ddd":0,"ind":23,"ty":0,"nm":"","ln":"precomp_xdmtx-bgRuEkiGSrNwut223","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49976.41,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"u6N3VAn9hoOmLDTz2sClC"}]},{"id":"Jp0B0YmZgZOEb0g-EEFFt","layers":[{"ddd":0,"ind":16,"ty":0,"nm":"","ln":"precomp_P1gYn2p2qDoQoZwCwknj-16","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"qOK4BaItY-C8lU0fm3KpK"}]},{"id":"EOsV9MOwzFUC7kk9K6GQM","layers":[{"ddd":0,"ind":33,"ty":4,"nm":"","ln":"wEkGeMt12AicdhHEXZZ7a33","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50013.46,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":34,"ty":4,"nm":"","ln":"ckPvY0o9YFn5ALybKT07j34","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50005.33,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":35,"ty":4,"nm":"","ln":"KLn_7JYlJscPThGivYdZF35","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49997.18,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":36,"ty":4,"nm":"","ln":"RirA09qq9chiwWyfdSCeL36","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49989.04,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":37,"ty":4,"nm":"","ln":"6ERYQJxjS8AQzOU71wWbx37","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.38,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[6.66,-0.91],[4.93,-3.18],[6.28,-3.18],[7.42,-1.69],[7.72,-1.29],[9.41,0.95],[8.05,0.95],[6.94,-0.54],[6.66,-0.91]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[9.82,-5.09],[9.82,-5.09],[9.24,-2.31],[7.65,-0.5],[5.33,0.14],[5.33,0.14],[3.01,-0.5],[1.42,-2.31],[0.84,-5.09],[0.84,-5.09],[1.42,-7.88],[3.01,-9.68],[5.33,-10.32],[5.33,-10.32],[7.65,-9.68],[9.24,-7.88],[9.82,-5.09]],"i":[[0,0],[0,0],[0.39,-0.78],[0.67,-0.42],[0.87,0],[0,0],[0.68,0.43],[0.39,0.79],[0,1.07],[0,0],[-0.39,0.79],[-0.67,0.42],[-0.87,0],[0,0],[-0.68,-0.43],[-0.39,-0.78],[0,-1.07]],"o":[[0,0],[0,1.07],[-0.39,0.79],[-0.68,0.43],[0,0],[-0.87,0],[-0.67,-0.42],[-0.39,-0.78],[0,0],[0,-1.07],[0.39,-0.78],[0.68,-0.43],[0,0],[0.87,0],[0.67,0.42],[0.39,0.79],[0,0]]}}},{"ty":"sh","hd":false,"ix":2,"ks":{"a":0,"k":{"v":[[8.63,-5.09],[8.63,-5.09],[8.19,-7.32],[7,-8.7],[5.33,-9.17],[5.33,-9.17],[3.66,-8.7],[2.47,-7.32],[2.03,-5.09],[2.03,-5.09],[2.47,-2.86],[3.66,-1.48],[5.33,-1.01],[5.33,-1.01],[7,-1.48],[8.19,-2.86],[8.63,-5.09]],"i":[[0,0],[0,0],[0.29,0.61],[0.5,0.31],[0.61,0],[0,0],[0.49,-0.31],[0.29,-0.61],[0,-0.88],[0,0],[-0.29,-0.61],[-0.5,-0.31],[-0.62,0],[0,0],[-0.5,0.31],[-0.29,0.61],[0,0.88]],"o":[[0,0],[0,-0.88],[-0.29,-0.61],[-0.5,-0.31],[0,0],[-0.62,0],[-0.5,0.31],[-0.29,0.61],[0,0],[0,0.88],[0.29,0.61],[0.49,0.31],[0,0],[0.61,0],[0.5,-0.31],[0.29,-0.61],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"FGsxvzMnAXygwmffmG9kG","layers":[{"ddd":0,"ind":39,"ty":4,"nm":"","ln":"9Epq2a7eCuOJhlTAJMl0P39","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50012.97,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[4.28,0.16],[4.28,0.16],[2.37,-0.33],[1.15,-1.7],[0.72,-3.76],[0.72,-3.76],[1.15,-5.83],[2.35,-7.23],[4.16,-7.74],[4.16,-7.74],[5.33,-7.54],[6.39,-6.89],[7.15,-5.72],[7.44,-3.92],[7.44,-3.92],[7.44,-3.42],[1.55,-3.42],[1.55,-4.43],[6.24,-4.43],[5.99,-5.59],[5.26,-6.39],[4.16,-6.68],[4.16,-6.68],[2.95,-6.34],[2.16,-5.44],[1.89,-4.26],[1.89,-4.26],[1.89,-3.58],[2.19,-2.12],[3.03,-1.21],[4.28,-0.89],[4.28,-0.89],[5.11,-1.03],[5.76,-1.42],[6.18,-2.09],[6.18,-2.09],[7.32,-1.77],[6.72,-0.76],[5.67,-0.08],[4.28,0.16]],"i":[[0,0],[0,0],[0.53,0.33],[0.29,0.59],[0,0.78],[0,0],[-0.29,0.6],[-0.51,0.33],[-0.69,0],[0,0],[-0.39,-0.13],[-0.31,-0.3],[-0.19,-0.49],[0,-0.71],[0,0],[0,0],[0,0],[0,0],[0,0],[0.17,0.34],[0.31,0.19],[0.42,0],[0,0],[0.34,-0.23],[0.19,-0.37],[0,-0.42],[0,0],[0,0],[-0.2,-0.39],[-0.36,-0.21],[-0.48,0],[0,0],[-0.25,0.09],[-0.18,0.17],[-0.09,0.27],[0,0],[0,0],[0.28,-0.29],[0.41,-0.16],[0.51,0]],"o":[[0,0],[-0.74,0],[-0.53,-0.33],[-0.29,-0.59],[0,0],[0,-0.78],[0.29,-0.6],[0.51,-0.34],[0,0],[0.39,0],[0.39,0.13],[0.32,0.29],[0.19,0.49],[0,0],[0,0],[0,0],[0,0],[0,0],[0,-0.43],[-0.17,-0.34],[-0.31,-0.19],[0,0],[-0.47,0],[-0.34,0.23],[-0.18,0.37],[0,0],[0,0],[0,0.58],[0.2,0.4],[0.35,0.21],[0,0],[0.31,0],[0.25,-0.09],[0.19,-0.18],[0,0],[0,0],[-0.12,0.39],[-0.29,0.29],[-0.41,0.16],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":40,"ty":4,"nm":"","ln":"fj0d3kQxQ7J9NrWrHHmq040","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50009.64,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[1.07,-10.18],[2.25,-10.18],[2.25,0],[1.07,0],[1.07,-10.18]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":41,"ty":4,"nm":"","ln":"U9hrGN3PveO9dFWoBVZ0841","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50001.11,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,2.86],[1.07,2.86],[1.07,-7.64],[2.21,-7.64],[2.21,-6.42],[2.35,-6.42],[2.71,-6.93],[3.37,-7.49],[4.55,-7.74],[4.55,-7.74],[6.25,-7.25],[7.4,-5.89],[7.82,-3.8],[7.82,-3.8],[7.4,-1.7],[6.26,-0.33],[4.57,0.16],[4.57,0.16],[3.4,-0.09],[2.71,-0.65],[2.35,-1.17],[2.35,-1.17],[2.25,-1.17],[2.25,2.86]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.15,0.21],[-0.29,0.17],[-0.49,0],[0,0],[-0.49,-0.33],[-0.27,-0.59],[0,-0.8],[0,0],[0.28,-0.59],[0.49,-0.32],[0.64,0],[0,0],[0.29,0.17],[0.16,0.21],[0.09,0.14],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.09,-0.13],[0.15,-0.21],[0.29,-0.17],[0,0],[0.65,0],[0.49,0.32],[0.28,0.59],[0,0],[0,0.81],[-0.27,0.59],[-0.49,0.33],[0,0],[-0.49,0],[-0.3,-0.16],[-0.15,-0.21],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"sh","hd":false,"ix":1,"ks":{"a":0,"k":{"v":[[2.23,-3.82],[2.23,-3.82],[2.48,-2.29],[3.22,-1.27],[4.41,-0.89],[4.41,-0.89],[5.65,-1.29],[6.39,-2.34],[6.64,-3.82],[6.64,-3.82],[6.4,-5.27],[5.66,-6.3],[4.41,-6.68],[4.41,-6.68],[3.21,-6.32],[2.48,-5.32],[2.23,-3.82]],"i":[[0,0],[0,0],[-0.17,-0.44],[-0.33,-0.25],[-0.47,0],[0,0],[-0.33,0.27],[-0.17,0.44],[0,0.55],[0,0],[0.16,0.43],[0.33,0.25],[0.5,0],[0,0],[0.33,-0.24],[0.16,-0.43],[0,-0.57]],"o":[[0,0],[0,0.58],[0.17,0.43],[0.33,0.25],[0,0],[0.49,0],[0.33,-0.26],[0.17,-0.44],[0,0],[0,-0.53],[-0.17,-0.43],[-0.33,-0.25],[0,0],[-0.47,0],[-0.33,0.24],[-0.17,0.43],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":42,"ty":4,"nm":"","ln":"-FRS8XqTtExS2anQu8Ony42","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49995.9,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.25,0],[1.07,0],[1.07,-7.64],[2.21,-7.64],[2.21,-6.48],[2.29,-6.48],[3.04,-7.4],[4.28,-7.76],[4.28,-7.76],[4.6,-7.75],[4.89,-7.74],[4.89,-7.74],[4.89,-6.54],[4.62,-6.59],[4.18,-6.62],[4.18,-6.62],[3.18,-6.39],[2.5,-5.75],[2.25,-4.83],[2.25,-4.83],[2.25,0]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.36,0.23],[-0.46,0],[0,0],[-0.13,-0.01],[-0.07,-0.01],[0,0],[0,0],[0.14,0.02],[0.15,0],[0,0],[0.29,-0.15],[0.17,-0.27],[0,-0.35],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0.14,-0.38],[0.37,-0.24],[0,0],[0.08,0],[0.13,0],[0,0],[0,0],[-0.04,-0.01],[-0.14,-0.02],[0,0],[-0.37,0],[-0.29,0.15],[-0.17,0.27],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":43,"ty":4,"nm":"","ln":"7C6IECMCU00ysAIGILdVR43","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49987.77,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[5.89,-3.12],[5.89,-3.12],[5.89,-7.64],[7.06,-7.64],[7.06,0],[5.89,0],[5.89,-1.29],[5.81,-1.29],[4.97,-0.31],[3.54,0.1],[3.54,0.1],[2.27,-0.22],[1.39,-1.17],[1.07,-2.78],[1.07,-2.78],[1.07,-7.64],[2.25,-7.64],[2.25,-2.86],[2.72,-1.53],[3.92,-1.03],[3.92,-1.03],[4.81,-1.26],[5.58,-1.94],[5.89,-3.12]],"i":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0.38,-0.27],[0.57,0],[0,0],[0.37,0.21],[0.21,0.43],[0,0.65],[0,0],[0,0],[0,0],[0,0],[-0.31,-0.33],[-0.49,0],[0,0],[-0.3,0.15],[-0.21,0.31],[0,0.47]],"o":[[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[0,0],[-0.18,0.39],[-0.38,0.27],[0,0],[-0.48,0],[-0.37,-0.21],[-0.21,-0.43],[0,0],[0,0],[0,0],[0,0],[0,0.55],[0.31,0.33],[0,0],[0.29,0],[0.3,-0.15],[0.21,-0.31],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":44,"ty":4,"nm":"","ln":"FRUk4z47ybz2T3K6F0_Dd44","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49978.88,50005.09]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"sh","hd":false,"ix":0,"ks":{"a":0,"k":{"v":[[2.47,0],[1.23,0],[1.23,-10.18],[4.67,-10.18],[6.63,-9.75],[7.77,-8.59],[8.13,-6.96],[8.13,-6.96],[7.77,-5.32],[6.64,-4.15],[4.69,-3.72],[4.69,-3.72],[2.23,-3.72],[2.23,-4.81],[4.65,-4.81],[5.97,-5.1],[6.69,-5.86],[6.92,-6.96],[6.92,-6.96],[6.69,-8.05],[5.97,-8.81],[4.63,-9.09],[4.63,-9.09],[2.47,-9.09],[2.47,0]],"i":[[0,0],[0,0],[0,0],[0,0],[-0.51,-0.29],[-0.25,-0.49],[0,-0.6],[0,0],[0.24,-0.49],[0.51,-0.29],[0.79,0],[0,0],[0,0],[0,0],[0,0],[-0.33,0.19],[-0.15,0.32],[0,0.41],[0,0],[0.15,0.32],[0.33,0.18],[0.55,0],[0,0],[0,0],[0,0]],"o":[[0,0],[0,0],[0,0],[0.8,0],[0.51,0.29],[0.24,0.49],[0,0],[0,0.6],[-0.25,0.49],[-0.51,0.29],[0,0],[0,0],[0,0],[0,0],[0.55,0],[0.33,-0.19],[0.15,-0.33],[0,0],[0,-0.41],[-0.15,-0.33],[-0.34,-0.19],[0,0],[0,0],[0,0],[0,0]]}}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"qYKcfcz58Opar690-lv1r","layers":[{"ddd":0,"ind":32,"ty":0,"nm":"","ln":"precomp_OD3h7LScundq4YaU986-g32","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50023.09,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"EOsV9MOwzFUC7kk9K6GQM"},{"ddd":0,"ind":38,"ty":0,"nm":"","ln":"precomp_pdESY0dM-eoAGB2n_Hx6i38","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49976.41,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"FGsxvzMnAXygwmffmG9kG"}]},{"id":"iRcBi_xHKtXWrwizyeRtv","layers":[{"ddd":0,"ind":31,"ty":0,"nm":"","ln":"precomp_JWl_Hm04muo2mmRqHevzK31","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"qYKcfcz58Opar690-lv1r"}]},{"id":"YH5CVU7UK9vsA0i48-Jtb","layers":[]},{"h":45,"id":"4gQSYJgszUFsKLdudDOOh","p":"","u":"","w":45,"e":1},{"id":"rDQ42Ktp3VuLR4n9_Z5nA","layers":[{"ddd":0,"ind":49,"ty":2,"nm":"","ln":"4gQSYJgszUFsKLdudDOOh49","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"4gQSYJgszUFsKLdudDOOh"}]},{"id":"oB6naqSgwcvST_les_tvT","layers":[{"ddd":0,"ind":51,"ty":4,"nm":"","ln":"c9am_Ppom_grqe2IEAXh351","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"KBec0DrQ2_c6X20v50yTe","layers":[{"ddd":0,"ind":50,"ty":0,"nm":"","td":1,"ln":"precomp_Qavkk4XEYBKesd1zdbo7u50","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"oB6naqSgwcvST_les_tvT"},{"ddd":0,"ind":48,"ty":0,"nm":"","tt":1,"ln":"precomp_9WrMShYnpem-1AAL4MsYB48","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"rDQ42Ktp3VuLR4n9_Z5nA"}]},{"id":"ZM7NsE64fRw7AzB3ggCOq","layers":[]},{"id":"Ub8HZ3uZEsdTV7gkGRft_","layers":[]},{"id":"6zv7zwSlSFp2V9Fl2eCvJ","layers":[{"ddd":0,"ind":46,"ty":0,"nm":"","ln":"precomp_O8v3KhaTlxYoAvYJXZAQH46","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"YH5CVU7UK9vsA0i48-Jtb"},{"ddd":0,"ind":47,"ty":0,"nm":"","ln":"precomp_9WrMShYnpem-1AAL4MsYB47","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"KBec0DrQ2_c6X20v50yTe"},{"ddd":0,"ind":52,"ty":0,"nm":"","ln":"precomp_rr4LMHX3qbYfv66v_rNwK52","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ZM7NsE64fRw7AzB3ggCOq"},{"ddd":0,"ind":53,"ty":0,"nm":"","ln":"precomp_6yBfSdDVRbr5wXFS0Sw6c53","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Ub8HZ3uZEsdTV7gkGRft_"}]},{"id":"tmkAJkuDiGa3k45cfNDHX","layers":[]},{"h":45,"id":"zf_KalaBAksT15wSpMvX2","p":"","u":"","w":45,"e":1},{"id":"s8BZQqN6n0M6mg7CqY1Qv","layers":[{"ddd":0,"ind":58,"ty":2,"nm":"","ln":"zf_KalaBAksT15wSpMvX258","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"zf_KalaBAksT15wSpMvX2"}]},{"id":"iQQ1NcbCwxQk3isyu1EGL","layers":[{"ddd":0,"ind":60,"ty":4,"nm":"","ln":"XlfNcdLpzFtcP5EDbjuBM60","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"rMO7NDpsUMawfmI4isO1C","layers":[{"ddd":0,"ind":59,"ty":0,"nm":"","td":1,"ln":"precomp_YwPM2fEyXoLMBwLIlqB9t59","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"iQQ1NcbCwxQk3isyu1EGL"},{"ddd":0,"ind":57,"ty":0,"nm":"","tt":1,"ln":"precomp_oLXn8rEAW-cAfq-pdGb3v57","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"s8BZQqN6n0M6mg7CqY1Qv"}]},{"id":"uNB88Rz_lXU3aqAGEfNjU","layers":[]},{"id":"4Ld3trQ5W3nh7867Cz32F","layers":[]},{"id":"U9MRzR6pvpiACFeJgrcTv","layers":[{"ddd":0,"ind":55,"ty":0,"nm":"","ln":"precomp_0gCGmua0_mCx5Tr8qES1h55","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"tmkAJkuDiGa3k45cfNDHX"},{"ddd":0,"ind":56,"ty":0,"nm":"","ln":"precomp_oLXn8rEAW-cAfq-pdGb3v56","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"rMO7NDpsUMawfmI4isO1C"},{"ddd":0,"ind":61,"ty":0,"nm":"","ln":"precomp_6hW9dC_jZ8jaVokpru4JO61","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"uNB88Rz_lXU3aqAGEfNjU"},{"ddd":0,"ind":62,"ty":0,"nm":"","ln":"precomp_bGpH1q0BRpXIOh4c-gAC162","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"4Ld3trQ5W3nh7867Cz32F"}]},{"id":"tOUFjDxcKHHewoLwZnDHE","layers":[]},{"h":45,"id":"Egn3387Ps1k4PZkr_SxdI","p":"","u":"","w":45,"e":1},{"id":"GBvZiNr1dBZGkL4f0dzdq","layers":[{"ddd":0,"ind":67,"ty":2,"nm":"","ln":"Egn3387Ps1k4PZkr_SxdI67","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"Egn3387Ps1k4PZkr_SxdI"}]},{"id":"eqHMFBK0-OPPa25ZFkDJX","layers":[{"ddd":0,"ind":69,"ty":4,"nm":"","ln":"venPWQZUyTM5Y-f57iQ8a69","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"08nj_0V728Ao2zZUBJRTF","layers":[{"ddd":0,"ind":68,"ty":0,"nm":"","td":1,"ln":"precomp_Js7ORAxIEuWJ-H6P3V-rY68","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"eqHMFBK0-OPPa25ZFkDJX"},{"ddd":0,"ind":66,"ty":0,"nm":"","tt":1,"ln":"precomp_OoyeP8jO1eoCu9MuuhFoe66","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"GBvZiNr1dBZGkL4f0dzdq"}]},{"id":"Qg4AY92ZLqSCKDtgTrxMT","layers":[]},{"id":"zYr3VrLPQ7g_8Nwq0uMLE","layers":[]},{"id":"CTXWxQT7T1kaNLGT_r06a","layers":[{"ddd":0,"ind":64,"ty":0,"nm":"","ln":"precomp_6XAoblgwfCcPJ8-JeRaKh64","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"tOUFjDxcKHHewoLwZnDHE"},{"ddd":0,"ind":65,"ty":0,"nm":"","ln":"precomp_OoyeP8jO1eoCu9MuuhFoe65","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"08nj_0V728Ao2zZUBJRTF"},{"ddd":0,"ind":70,"ty":0,"nm":"","ln":"precomp_QVRseU6iF0VnLoT1qsWep70","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Qg4AY92ZLqSCKDtgTrxMT"},{"ddd":0,"ind":71,"ty":0,"nm":"","ln":"precomp_U8g1kByldUPc9IEfqnPkV71","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"zYr3VrLPQ7g_8Nwq0uMLE"}]},{"id":"L2qN6o-i6gRUzGdI0CsFi","layers":[]},{"h":45,"id":"KMdw1cMpQZlGE7LBVcdPj","p":"","u":"","w":45,"e":1},{"id":"YsgTAjER5l5U8v3RYfdJz","layers":[{"ddd":0,"ind":76,"ty":2,"nm":"","ln":"KMdw1cMpQZlGE7LBVcdPj76","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"KMdw1cMpQZlGE7LBVcdPj"}]},{"id":"doILsbkwzjCIbpUz1JP3X","layers":[{"ddd":0,"ind":78,"ty":4,"nm":"","ln":"n0N6-66T-9701RzXQmPFU78","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"SA80ewPxeqYmAxpZ6a52i","layers":[{"ddd":0,"ind":77,"ty":0,"nm":"","td":1,"ln":"precomp_s4GOjGMtVDMqjseChok3Q77","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"doILsbkwzjCIbpUz1JP3X"},{"ddd":0,"ind":75,"ty":0,"nm":"","tt":1,"ln":"precomp_X0tHjoBs4lkB_o5nZR8Sv75","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"YsgTAjER5l5U8v3RYfdJz"}]},{"id":"g-IV_G20YAqcsnz4U3jIZ","layers":[]},{"id":"Rh6FgYL5lVjoEqCqOjCjc","layers":[]},{"id":"ac6K0hNLRlJT73rABXMzz","layers":[{"ddd":0,"ind":73,"ty":0,"nm":"","ln":"precomp_zxox19N2bGXUL6IEUmR-373","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"L2qN6o-i6gRUzGdI0CsFi"},{"ddd":0,"ind":74,"ty":0,"nm":"","ln":"precomp_X0tHjoBs4lkB_o5nZR8Sv74","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"SA80ewPxeqYmAxpZ6a52i"},{"ddd":0,"ind":79,"ty":0,"nm":"","ln":"precomp_YxoprXsEdjYTTkxuaMy3G79","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"g-IV_G20YAqcsnz4U3jIZ"},{"ddd":0,"ind":80,"ty":0,"nm":"","ln":"precomp_vUnrU0ps6Nl6yKwYf7j9980","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Rh6FgYL5lVjoEqCqOjCjc"}]},{"id":"QRx4ZZa-w5sDJX1BddG5Z","layers":[]},{"h":45,"id":"7HzyddzLixrgwU_LvBFDC","p":"","u":"","w":45,"e":1},{"id":"yUtOhJ4AciIP5naD2K-bl","layers":[{"ddd":0,"ind":85,"ty":2,"nm":"","ln":"7HzyddzLixrgwU_LvBFDC85","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"7HzyddzLixrgwU_LvBFDC"}]},{"id":"guOmw4JyVkkmWa1H3Tsda","layers":[{"ddd":0,"ind":87,"ty":4,"nm":"","ln":"OVuUOzUtYwL98YLiexuvT87","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"Yxrvz_M4b_DVdKnzui30c","layers":[{"ddd":0,"ind":86,"ty":0,"nm":"","td":1,"ln":"precomp_AvKrXcHD0dh3SEnmUvxWO86","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"guOmw4JyVkkmWa1H3Tsda"},{"ddd":0,"ind":84,"ty":0,"nm":"","tt":1,"ln":"precomp_8V7nMbUE6RYJMl_BNYF7t84","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"yUtOhJ4AciIP5naD2K-bl"}]},{"id":"7UVTHIDzFUcuRq55lecMb","layers":[]},{"id":"EOZbrTqHhNPbPakzdNCZu","layers":[]},{"id":"zp_47RHDhWOPL2YKNJAyO","layers":[{"ddd":0,"ind":82,"ty":0,"nm":"","ln":"precomp_J3SYlmi2KBBjhxhM8ovtN82","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"QRx4ZZa-w5sDJX1BddG5Z"},{"ddd":0,"ind":83,"ty":0,"nm":"","ln":"precomp_8V7nMbUE6RYJMl_BNYF7t83","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Yxrvz_M4b_DVdKnzui30c"},{"ddd":0,"ind":88,"ty":0,"nm":"","ln":"precomp_9Fabst1DZ_JE1t0tFzfsw88","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"7UVTHIDzFUcuRq55lecMb"},{"ddd":0,"ind":89,"ty":0,"nm":"","ln":"precomp_RnOuiWdS-rNWjcz1fFS5g89","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"EOZbrTqHhNPbPakzdNCZu"}]},{"id":"BjqsPFDq7QhVMT_0-LHEw","layers":[]},{"h":45,"id":"Oe4-H4r-_2CJ5a6ulJFK7","p":"","u":"","w":45,"e":1},{"id":"HT-90P5ww_DyBBdZw_KnG","layers":[{"ddd":0,"ind":94,"ty":2,"nm":"","ln":"Oe4-H4r-_2CJ5a6ulJFK794","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"Oe4-H4r-_2CJ5a6ulJFK7"}]},{"id":"pULcnWU_wJiWN9wxtuXJH","layers":[{"ddd":0,"ind":96,"ty":4,"nm":"","ln":"IpcTTbcXedkiHr8lJoawB96","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"liOBLBny93AnNE8mCkE7E","layers":[{"ddd":0,"ind":95,"ty":0,"nm":"","td":1,"ln":"precomp_DjXKQIPqL-EnBoqfMZ50u95","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"pULcnWU_wJiWN9wxtuXJH"},{"ddd":0,"ind":93,"ty":0,"nm":"","tt":1,"ln":"precomp_zBVOqJSvRiXM_slus_4CC93","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"HT-90P5ww_DyBBdZw_KnG"}]},{"id":"ZWB1OZ35Xz_qaAdnxnx26","layers":[]},{"id":"weu9do-hbtEhSLJWq3_vu","layers":[]},{"id":"Zwor7kLpkgNb0k43-Qlph","layers":[{"ddd":0,"ind":91,"ty":0,"nm":"","ln":"precomp_XJJCB_LiWqDiz1c47dyJD91","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"BjqsPFDq7QhVMT_0-LHEw"},{"ddd":0,"ind":92,"ty":0,"nm":"","ln":"precomp_zBVOqJSvRiXM_slus_4CC92","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"liOBLBny93AnNE8mCkE7E"},{"ddd":0,"ind":97,"ty":0,"nm":"","ln":"precomp_9qbOFb_AfcVZ-TcWaVDJ697","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ZWB1OZ35Xz_qaAdnxnx26"},{"ddd":0,"ind":98,"ty":0,"nm":"","ln":"precomp_luUeyeJAVHkTtwf5HIdI198","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"weu9do-hbtEhSLJWq3_vu"}]},{"id":"ZzhyZtXwWuhCUsiEMA6DD","layers":[]},{"h":45,"id":"YPR-Pq_UPuqhLd0PjOmxa","p":"","u":"","w":45,"e":1},{"id":"vVKtULnfcLUD3W_q0h9WN","layers":[{"ddd":0,"ind":103,"ty":2,"nm":"","ln":"YPR-Pq_UPuqhLd0PjOmxa103","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"YPR-Pq_UPuqhLd0PjOmxa"}]},{"id":"FswEgEHGVGPK2BFw6MT2M","layers":[{"ddd":0,"ind":105,"ty":4,"nm":"","ln":"ecCiEfUjOAqnLU4fShpT6105","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"kf7Z-bKDQ78VsspA5rgB5","layers":[{"ddd":0,"ind":104,"ty":0,"nm":"","td":1,"ln":"precomp_9X69EtdqtBoAE_cekJYNI104","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"FswEgEHGVGPK2BFw6MT2M"},{"ddd":0,"ind":102,"ty":0,"nm":"","tt":1,"ln":"precomp_GGTS4qBu0LqAzUFNxzLs8102","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"vVKtULnfcLUD3W_q0h9WN"}]},{"id":"gUbvnQ5a-CQbiE8gBECK2","layers":[]},{"id":"A64O5AX8OEuDPOhsPuyXA","layers":[]},{"id":"2FY4b6yj0H0r1F0E-SaDS","layers":[{"ddd":0,"ind":100,"ty":0,"nm":"","ln":"precomp_7YbozT97zj8vwyy8PIjHS100","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ZzhyZtXwWuhCUsiEMA6DD"},{"ddd":0,"ind":101,"ty":0,"nm":"","ln":"precomp_GGTS4qBu0LqAzUFNxzLs8101","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"kf7Z-bKDQ78VsspA5rgB5"},{"ddd":0,"ind":106,"ty":0,"nm":"","ln":"precomp_QbJcqJiQpEVaPnZ2XcqtI106","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"gUbvnQ5a-CQbiE8gBECK2"},{"ddd":0,"ind":107,"ty":0,"nm":"","ln":"precomp_4JgBf9w6NrnRb8Yw6xsBw107","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"A64O5AX8OEuDPOhsPuyXA"}]},{"id":"wsnlJJ6BwaLar_mbnzbWT","layers":[]},{"h":45,"id":"3aVU97k5BdyNqgXYA8m3D","p":"","u":"","w":45,"e":1},{"id":"QOcQ7YDqL5F4lOp43c1zZ","layers":[{"ddd":0,"ind":112,"ty":2,"nm":"","ln":"3aVU97k5BdyNqgXYA8m3D112","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49977.5,49977.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"3aVU97k5BdyNqgXYA8m3D"}]},{"id":"3ek5i8a5n5WqRnU0zh4yy","layers":[{"ddd":0,"ind":114,"ty":4,"nm":"","ln":"Qot_ZAGZLZhknO-G6M-OP114","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[45,45]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"Wrd3THBcgTm3mGXGbIu1X","layers":[{"ddd":0,"ind":113,"ty":0,"nm":"","td":1,"ln":"precomp_MfYiM8cjBucHmD2lS7VZC113","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"3ek5i8a5n5WqRnU0zh4yy"},{"ddd":0,"ind":111,"ty":0,"nm":"","tt":1,"ln":"precomp__3cKk1jl4F-GlXoEdcNGK111","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"QOcQ7YDqL5F4lOp43c1zZ"}]},{"id":"jbf6cJ3QSyuOEmBqKuwFm","layers":[]},{"id":"YL8YeExpJmTDNK1e5-4Yg","layers":[]},{"id":"LPpqaL_n_K6M0hFvh0ZHA","layers":[{"ddd":0,"ind":109,"ty":0,"nm":"","ln":"precomp_O0oO7A3sOYEBTum1bQnJ_109","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"wsnlJJ6BwaLar_mbnzbWT"},{"ddd":0,"ind":110,"ty":0,"nm":"","ln":"precomp__3cKk1jl4F-GlXoEdcNGK110","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Wrd3THBcgTm3mGXGbIu1X"},{"ddd":0,"ind":115,"ty":0,"nm":"","ln":"precomp_YgJGQLmGv_eVAj3VLGPBv115","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"jbf6cJ3QSyuOEmBqKuwFm"},{"ddd":0,"ind":116,"ty":0,"nm":"","ln":"precomp_mM2kXxgqNx4h2rm9US3vU116","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"YL8YeExpJmTDNK1e5-4Yg"}]},{"id":"JU6aq4uQ3FDCe4pX6h6xO","layers":[{"ddd":0,"ind":118,"ty":4,"nm":"","ln":"jDg1YVeGmP2sr7VK1ce0I118","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"st","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"lc":2,"lj":1,"o":{"a":0,"k":100},"w":{"a":0,"k":1}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":119,"ty":4,"nm":"","ln":"SLNGnzt3_E43BNmHRC3Zd119","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.7,0.7,0.7]},"r":1,"o":{"a":0,"k":0}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"C44CHRfofMBfxsVf6xzqk","layers":[{"ddd":0,"ind":121,"ty":4,"nm":"","ln":"4OxLQY2uuXuNzQDmnuQoC121","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"st","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"lc":2,"lj":1,"o":{"a":0,"k":100},"w":{"a":0,"k":1}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":122,"ty":4,"nm":"","ln":"ZuU_jXvp3bS07fGJIcLdU122","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.7,0.7,0.7]},"r":1,"o":{"a":0,"k":0}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"bdXhUv_rFrJiTxgrT6WmR","layers":[{"ddd":0,"ind":124,"ty":4,"nm":"","ln":"O2ysFUVPGT5B9DNxVxiT9124","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"st","hd":false,"bm":0,"c":{"a":0,"k":[1,1,1]},"lc":2,"lj":1,"o":{"a":0,"k":100},"w":{"a":0,"k":1}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]},{"ddd":0,"ind":125,"ty":4,"nm":"","ln":"q7kCcu6ZzObus8lTKSDuJ125","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":8},"s":{"a":0,"k":[398,50]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.7,0.7,0.7]},"r":1,"o":{"a":0,"k":0}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"HKTTx1IfJ95JzDbiU12TF","layers":[]},{"h":184,"id":"8JHreVabrDZr8b36yyKem","p":"","u":"","w":218,"e":1},{"id":"OpasQtHEzNjFrAyIMhq1h","layers":[{"ddd":0,"ind":130,"ty":2,"nm":"","ln":"8JHreVabrDZr8b36yyKem130","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49891,49908]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"refId":"8JHreVabrDZr8b36yyKem"}]},{"id":"iASKmFknps-PMSPHPktmU","layers":[{"ddd":0,"ind":132,"ty":4,"nm":"","ln":"wqjpeOIRUjlQtSTiVFQKJ132","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[218,184]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0,0,0]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"MTzeEoZrdGajlen8_elC6","layers":[{"ddd":0,"ind":131,"ty":0,"nm":"","td":1,"ln":"precomp_cd9iq9L8hqrjrg6w1b9DZ131","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"iASKmFknps-PMSPHPktmU"},{"ddd":0,"ind":129,"ty":0,"nm":"","tt":1,"ln":"precomp_dBih5zMtUBC9gUMXHdJaq129","sr":1,"ks":{"a":{"a":0,"k":[100000,100000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[100000,100000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"OpasQtHEzNjFrAyIMhq1h"}]},{"id":"VVdYvgSHPfZdtbNGkxmQU","layers":[]},{"id":"DxOD47BsEaNsp1aUQiNwF","layers":[]},{"id":"EOIxbBO4OXrBVS5vldXGp","layers":[{"ddd":0,"ind":127,"ty":0,"nm":"","ln":"precomp_Ci5NyvMt_mnWFF98RfA0w127","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"HKTTx1IfJ95JzDbiU12TF"},{"ddd":0,"ind":128,"ty":0,"nm":"","ln":"precomp_dBih5zMtUBC9gUMXHdJaq128","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"MTzeEoZrdGajlen8_elC6"},{"ddd":0,"ind":133,"ty":0,"nm":"","ln":"precomp_JrcgqlSEFwVyfuM1FVHuq133","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"VVdYvgSHPfZdtbNGkxmQU"},{"ddd":0,"ind":134,"ty":0,"nm":"","ln":"precomp_AkAiHLuUlBqZbFRAvgQ70134","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"DxOD47BsEaNsp1aUQiNwF"}]},{"id":"Wc3ZJh16yNCYrhrQQEGG5","layers":[]},{"id":"nL2T8CWzs8Ca8b5QEazrI","layers":[{"ddd":0,"ind":137,"ty":4,"nm":"","ln":"oBl3iqGqOsXoSKUDeyhbr137","sr":1,"ks":{"a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"ip":0,"op":451,"st":0,"bm":0,"shapes":[{"ty":"gr","hd":false,"bm":0,"it":[{"ty":"rc","hd":false,"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[920,526]}},{"ty":"fl","hd":false,"bm":0,"c":{"a":0,"k":[0.01,0.03,0.09]},"r":1,"o":{"a":0,"k":100}},{"ty":"tr","nm":"Transform","a":{"a":0,"k":[0,0]},"o":{"a":0,"k":100},"p":{"a":0,"k":[0,0]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}}],"np":0}]}]},{"id":"eUQiNf0YSBZDw8yiy9TGE","layers":[{"ddd":0,"ind":1,"ty":0,"nm":"","ln":"precomp_50BjCsuBo5ifoBCeP1Ny01","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49865.25,50056]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"7Wus07HRPKsI75JEaEl0n"},{"ddd":0,"ind":15,"ty":0,"nm":"","ln":"precomp_wtXxtSFgt6thxf3c9tnmo15","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49869.25,49977]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Jp0B0YmZgZOEb0g-EEFFt"},{"ddd":0,"ind":30,"ty":0,"nm":"","ln":"precomp_m7Kl0SSG4ANVOTJU_73bd30","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[49866.25,49897.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"iRcBi_xHKtXWrwizyeRtv"},{"ddd":0,"ind":45,"ty":0,"nm":"","ln":"precomp_HKgzMMXB_9yz2gNJ3gAEg45","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":360,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":384,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49437.5,50010.5],"h":1},{"t":0,"s":[49437.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49487.5,50010.5],"h":1},{"t":24,"s":[49487.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49537.5,50010.5],"h":1},{"t":48,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49587.5,50010.5],"h":1},{"t":72,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49637.5,50010.5],"h":1},{"t":96,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49687.5,50010.5],"h":1},{"t":120,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49737.5,50010.5],"h":1},{"t":144,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[50087.5,50092],"h":1},{"t":240,"s":[50087.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50137.5,50092],"h":1},{"t":288,"s":[50137.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":312,"s":[50187.5,50092],"h":1},{"t":336,"s":[50187.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":360,"s":[50328.25,50010.5],"h":1},{"t":360,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":384,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"6zv7zwSlSFp2V9Fl2eCvJ"},{"ddd":0,"ind":54,"ty":0,"nm":"","ln":"precomp_N7nhrh3I-fJEG56En1Z2Z54","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":312,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":336,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49487.5,50010.5],"h":1},{"t":0,"s":[49487.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49537.5,50010.5],"h":1},{"t":24,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49587.5,50010.5],"h":1},{"t":48,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49637.5,50010.5],"h":1},{"t":72,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49687.5,50010.5],"h":1},{"t":96,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49737.5,50010.5],"h":1},{"t":120,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[50137.5,50092],"h":1},{"t":240,"s":[50137.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50187.5,50092],"h":1},{"t":288,"s":[50187.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":312,"s":[50328.25,50013],"h":1},{"t":312,"s":[50328.25,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":336,"s":[50378.25,50013],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"U9MRzR6pvpiACFeJgrcTv"},{"ddd":0,"ind":63,"ty":0,"nm":"","ln":"precomp_d7LGjssn6jk_BAI4iTpbu63","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":264,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":288,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49537.5,50010.5],"h":1},{"t":0,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49587.5,50010.5],"h":1},{"t":24,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49637.5,50010.5],"h":1},{"t":48,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49687.5,50010.5],"h":1},{"t":72,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49737.5,50010.5],"h":1},{"t":96,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[50187.5,50092],"h":1},{"t":240,"s":[50187.5,50092],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50328.25,50010.5],"h":1},{"t":264,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"CTXWxQT7T1kaNLGT_r06a"},{"ddd":0,"ind":72,"ty":0,"nm":"","ln":"precomp_7SfQxvberzjgAVfhsi9pe72","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":216,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":240,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49737.5,50010.5],"h":1},{"t":0,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[50187.5,49933.5],"h":1},{"t":192,"s":[50187.5,49933.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":216,"s":[50328.25,50010.5],"h":1},{"t":216,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"ac6K0hNLRlJT73rABXMzz"},{"ddd":0,"ind":81,"ty":0,"nm":"","ln":"precomp_FIHMNKbi4iu5cCbZxUXdf81","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":384,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":408,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49387.5,50010.5],"h":1},{"t":0,"s":[49387.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49437.5,50010.5],"h":1},{"t":24,"s":[49437.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49487.5,50010.5],"h":1},{"t":48,"s":[49487.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49537.5,50010.5],"h":1},{"t":72,"s":[49537.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[49587.5,50010.5],"h":1},{"t":96,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":120,"s":[49637.5,50010.5],"h":1},{"t":120,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":144,"s":[49687.5,50010.5],"h":1},{"t":144,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":168,"s":[49737.5,50010.5],"h":1},{"t":168,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":192,"s":[50037.5,50013],"h":1},{"t":216,"s":[50037.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50087.5,50013],"h":1},{"t":264,"s":[50087.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50137.5,50013],"h":1},{"t":312,"s":[50137.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":336,"s":[50187.5,50013],"h":1},{"t":360,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":384,"s":[50328.25,50010.5],"h":1},{"t":384,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":408,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"zp_47RHDhWOPL2YKNJAyO"},{"ddd":0,"ind":90,"ty":0,"nm":"","ln":"precomp_7_FmaXQ-YbQ-1IYDy1rMY90","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":336,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":360,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49587.5,50010.5],"h":1},{"t":0,"s":[49587.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49637.5,50010.5],"h":1},{"t":24,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49687.5,50010.5],"h":1},{"t":48,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[49737.5,50010.5],"h":1},{"t":72,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":96,"s":[50087.5,50013],"h":1},{"t":216,"s":[50087.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50137.5,50013],"h":1},{"t":264,"s":[50137.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50187.5,50013],"h":1},{"t":312,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":336,"s":[50328.25,50013],"h":1},{"t":336,"s":[50328.25,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":360,"s":[50378.25,50013],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Zwor7kLpkgNb0k43-Qlph"},{"ddd":0,"ind":99,"ty":0,"nm":"","ln":"precomp_emRKRZikc8bw6EY2cjzDa99","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":288,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":312,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49637.5,50010.5],"h":1},{"t":0,"s":[49637.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49687.5,50010.5],"h":1},{"t":24,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[49737.5,50010.5],"h":1},{"t":48,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":72,"s":[50137.5,50013],"h":1},{"t":216,"s":[50137.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50187.5,50013],"h":1},{"t":264,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":288,"s":[50328.25,50010.5],"h":1},{"t":288,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":312,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"2FY4b6yj0H0r1F0E-SaDS"},{"ddd":0,"ind":108,"ty":0,"nm":"","ln":"precomp_SSbPtfB45NY2wk8qYEhVs108","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":1,"k":[{"t":0,"s":[100],"h":1},{"t":240,"s":[100],"i":{"x":1,"y":1},"o":{"x":0,"y":0}},{"t":264,"s":[0],"h":1}]},"p":{"a":1,"k":[{"t":0,"s":[49687.5,50010.5],"h":1},{"t":0,"s":[49687.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":24,"s":[49737.5,50010.5],"h":1},{"t":24,"s":[49737.5,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":48,"s":[50187.5,50013],"h":1},{"t":216,"s":[50187.5,50013],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":240,"s":[50328.25,50010.5],"h":1},{"t":240,"s":[50328.25,50010.5],"i":{"x":0,"y":1},"o":{"x":0.5,"y":0}},{"t":264,"s":[50378.25,50010.5],"h":1}]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"LPpqaL_n_K6M0hFvh0ZHA"},{"ddd":0,"ind":117,"ty":0,"nm":"","ln":"precomp_W7YJwshIba8BmduW68GOG117","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50020.25,50089.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"JU6aq4uQ3FDCe4pX6h6xO"},{"ddd":0,"ind":120,"ty":0,"nm":"","ln":"precomp_4RgBXf7W72K7CtHuqb6BB120","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50020.25,50010.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"C44CHRfofMBfxsVf6xzqk"},{"ddd":0,"ind":123,"ty":0,"nm":"","ln":"precomp_9GlXlSWfNMzKJUuUoVjCr123","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50020.25,49931]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"bdXhUv_rFrJiTxgrT6WmR"},{"ddd":0,"ind":126,"ty":0,"nm":"","ln":"precomp_MprMPTSLYQOXKH26z-kdy126","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50328.25,50010.5]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"EOIxbBO4OXrBVS5vldXGp"},{"ddd":0,"ind":135,"ty":0,"nm":"","ln":"precomp_-nOOjocjnxeOr4WDqY2TE135","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"Wc3ZJh16yNCYrhrQQEGG5"},{"ddd":0,"ind":136,"ty":0,"nm":"","ln":"precomp_M2rXmKrDr3yuZuZknJ3v-136","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[50000,50000]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"nL2T8CWzs8Ca8b5QEazrI"}]}],"ddd":0,"fr":60,"h":526,"ip":0,"layers":[{"ddd":0,"ind":0,"ty":0,"nm":"","ln":"precomp_RhoI5eMdh0y036MGIYl__0","sr":1,"ks":{"a":{"a":0,"k":[50000,50000]},"o":{"a":0,"k":100},"p":{"a":0,"k":[460,263]},"r":{"a":0,"k":0},"s":{"a":0,"k":[100,100]},"sk":{"a":0,"k":0},"sa":{"a":0,"k":0}},"ao":0,"w":100000,"h":100000,"ip":0,"op":451,"st":0,"bm":0,"refId":"eUQiNf0YSBZDw8yiy9TGE"}],"meta":{"g":"https://jitter.video"},"nm":"Fairness-[copy]","op":450,"v":"5.7.4","w":920} diff --git a/frontend/docs/pages/contributing/_meta.json b/frontend/docs/pages/contributing/_meta.json index 0c3892cba..c8072fac4 100644 --- a/frontend/docs/pages/contributing/_meta.json +++ b/frontend/docs/pages/contributing/_meta.json @@ -2,4 +2,4 @@ "index": "Contributing", "github-app-setup": "GitHub App Setup", "sdks": "SDKs" -} \ No newline at end of file +} diff --git a/frontend/docs/pages/home/features/concurrency/_meta.json b/frontend/docs/pages/home/features/concurrency/_meta.json index f05237b6e..0bc5736d0 100644 --- a/frontend/docs/pages/home/features/concurrency/_meta.json +++ b/frontend/docs/pages/home/features/concurrency/_meta.json @@ -2,4 +2,4 @@ "overview": "Overview", "cancel-in-progress": "Cancel In Progress", "round-robin": "Round Robin" -} \ No newline at end of file +} diff --git a/frontend/docs/pages/home/quickstart/_meta.json b/frontend/docs/pages/home/quickstart/_meta.json index 0f6a95ac5..725c3ef4f 100644 --- a/frontend/docs/pages/home/quickstart/_meta.json +++ b/frontend/docs/pages/home/quickstart/_meta.json @@ -1,4 +1,4 @@ { "installation": "Installation & Setup", "first-workflow": "Running your first Step" -} \ No newline at end of file +} diff --git a/frontend/docs/pages/launches/_meta.json b/frontend/docs/pages/launches/_meta.json index 49de2fa9f..230d7e776 100644 --- a/frontend/docs/pages/launches/_meta.json +++ b/frontend/docs/pages/launches/_meta.json @@ -11,4 +11,4 @@ "title": "April 12th - v0.20 Release", "display": "hidden" } -} \ No newline at end of file +} diff --git a/frontend/docs/pages/sdks/_meta.json b/frontend/docs/pages/sdks/_meta.json index 615356a05..ad75f9fcd 100644 --- a/frontend/docs/pages/sdks/_meta.json +++ b/frontend/docs/pages/sdks/_meta.json @@ -9,4 +9,4 @@ "python-sdk": "Python SDK", "typescript-sdk": "TypeScript SDK", "go-sdk": "Go SDK" -} \ No newline at end of file +} diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIError.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIError.md index f6969eb41..36078cac7 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIError.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIError.md @@ -28,5 +28,3 @@ api_error_dict = api_error_instance.to_dict() api_error_form_dict = api_error.from_dict(api_error_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIErrors.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIErrors.md index bb878634d..f808d93c9 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIErrors.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIErrors.md @@ -25,5 +25,3 @@ api_errors_dict = api_errors_instance.to_dict() api_errors_form_dict = api_errors.from_dict(api_errors_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMeta.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMeta.md index dd31f0a65..1d1038e6b 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMeta.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMeta.md @@ -25,5 +25,3 @@ api_meta_dict = api_meta_instance.to_dict() api_meta_form_dict = api_meta.from_dict(api_meta_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaAuth.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaAuth.md index 890cce920..f25393f67 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaAuth.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaAuth.md @@ -25,5 +25,3 @@ api_meta_auth_dict = api_meta_auth_instance.to_dict() api_meta_auth_form_dict = api_meta_auth.from_dict(api_meta_auth_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaIntegration.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaIntegration.md index cada2f4c1..54eecd5a0 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaIntegration.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIMetaIntegration.md @@ -26,5 +26,3 @@ api_meta_integration_dict = api_meta_integration_instance.to_dict() api_meta_integration_form_dict = api_meta_integration.from_dict(api_meta_integration_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIResourceMeta.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIResourceMeta.md index 27e255c69..edd455732 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/APIResourceMeta.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/APIResourceMeta.md @@ -27,5 +27,3 @@ api_resource_meta_dict = api_resource_meta_instance.to_dict() api_resource_meta_form_dict = api_resource_meta.from_dict(api_resource_meta_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/PaginationResponse.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/PaginationResponse.md index fe46cce16..98cdc1936 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/PaginationResponse.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/PaginationResponse.md @@ -27,5 +27,3 @@ pagination_response_dict = pagination_response_instance.to_dict() pagination_response_form_dict = pagination_response.from_dict(pagination_response_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/Workflow.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/Workflow.md index f9dd1d295..44dd8a970 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/Workflow.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/Workflow.md @@ -32,5 +32,3 @@ workflow_dict = workflow_instance.to_dict() workflow_form_dict = workflow.from_dict(workflow_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowApi.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowApi.md index d90057507..21dfe58f9 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowApi.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowApi.md @@ -914,4 +914,3 @@ Name | Type | Description | Notes **404** | Not found | - | [[Back to top]](#) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to Model list]](../README.md#documentation-for-models) [[Back to README]](../README.md) - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowDeploymentConfig.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowDeploymentConfig.md index bfbd89474..a62cebffb 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowDeploymentConfig.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowDeploymentConfig.md @@ -30,5 +30,3 @@ workflow_deployment_config_dict = workflow_deployment_config_instance.to_dict() workflow_deployment_config_form_dict = workflow_deployment_config.from_dict(workflow_deployment_config_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowList.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowList.md index 1b5713e2d..f3e4c03b4 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowList.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowList.md @@ -27,5 +27,3 @@ workflow_list_dict = workflow_list_instance.to_dict() workflow_list_form_dict = workflow_list.from_dict(workflow_list_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRun.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRun.md index 629c58c2a..4ae440e94 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRun.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRun.md @@ -36,5 +36,3 @@ workflow_run_dict = workflow_run_instance.to_dict() workflow_run_form_dict = workflow_run.from_dict(workflow_run_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunApi.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunApi.md index 68bc25b3a..96b1df3f5 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunApi.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunApi.md @@ -99,4 +99,3 @@ Name | Type | Description | Notes **404** | Not found | - | [[Back to top]](#) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to Model list]](../README.md#documentation-for-models) [[Back to README]](../README.md) - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunList.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunList.md index 7cf1e69d9..39bca90ea 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunList.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunList.md @@ -26,5 +26,3 @@ workflow_run_list_dict = workflow_run_list_instance.to_dict() workflow_run_list_form_dict = workflow_run_list.from_dict(workflow_run_list_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunStatus.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunStatus.md index 8c96732de..ce8167192 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunStatus.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunStatus.md @@ -7,5 +7,3 @@ Name | Type | Description | Notes ------------ | ------------- | ------------- | ------------- [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunTriggeredBy.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunTriggeredBy.md index e4045e90b..9163f8a6c 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunTriggeredBy.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowRunTriggeredBy.md @@ -30,5 +30,3 @@ workflow_run_triggered_by_dict = workflow_run_triggered_by_instance.to_dict() workflow_run_triggered_by_form_dict = workflow_run_triggered_by.from_dict(workflow_run_triggered_by_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTag.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTag.md index 10759c26b..46ab59939 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTag.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTag.md @@ -26,5 +26,3 @@ workflow_tag_dict = workflow_tag_instance.to_dict() workflow_tag_form_dict = workflow_tag.from_dict(workflow_tag_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerCronRef.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerCronRef.md index 9e861fed7..f21e107d7 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerCronRef.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerCronRef.md @@ -26,5 +26,3 @@ workflow_trigger_cron_ref_dict = workflow_trigger_cron_ref_instance.to_dict() workflow_trigger_cron_ref_form_dict = workflow_trigger_cron_ref.from_dict(workflow_trigger_cron_ref_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerEventRef.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerEventRef.md index 9a09b7ae9..33c19213b 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerEventRef.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggerEventRef.md @@ -26,5 +26,3 @@ workflow_trigger_event_ref_dict = workflow_trigger_event_ref_instance.to_dict() workflow_trigger_event_ref_form_dict = workflow_trigger_event_ref.from_dict(workflow_trigger_event_ref_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggers.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggers.md index 7306aaace..cceda4da9 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggers.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowTriggers.md @@ -29,5 +29,3 @@ workflow_triggers_dict = workflow_triggers_instance.to_dict() workflow_triggers_form_dict = workflow_triggers.from_dict(workflow_triggers_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersion.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersion.md index a64a87c9f..9836e8b93 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersion.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersion.md @@ -31,5 +31,3 @@ workflow_version_dict = workflow_version_instance.to_dict() workflow_version_form_dict = workflow_version.from_dict(workflow_version_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionDefinition.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionDefinition.md index 66d53d906..13e66507f 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionDefinition.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionDefinition.md @@ -25,5 +25,3 @@ workflow_version_definition_dict = workflow_version_definition_instance.to_dict( workflow_version_definition_form_dict = workflow_version_definition.from_dict(workflow_version_definition_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionMeta.md b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionMeta.md index 5f3eb9c28..24cf8d843 100644 --- a/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionMeta.md +++ b/frontend/docs/pages/sdks/python-sdk/_api/_types/WorkflowVersionMeta.md @@ -29,5 +29,3 @@ workflow_version_meta_dict = workflow_version_meta_instance.to_dict() workflow_version_meta_form_dict = workflow_version_meta.from_dict(workflow_version_meta_dict) ``` [[Back to Model list]](../README.md#documentation-for-models) [[Back to API list]](../README.md#documentation-for-api-endpoints) [[Back to README]](../README.md) - - diff --git a/frontend/docs/pages/sdks/python-sdk/_meta.json b/frontend/docs/pages/sdks/python-sdk/_meta.json index ecea2ea77..0c7d2de21 100644 --- a/frontend/docs/pages/sdks/python-sdk/_meta.json +++ b/frontend/docs/pages/sdks/python-sdk/_meta.json @@ -4,4 +4,4 @@ "creating-a-worker": "Creating a Worker", "pushing-events": "Pushing Events", "api": "API" -} \ No newline at end of file +} diff --git a/frontend/docs/pages/sdks/typescript-sdk/_meta.json b/frontend/docs/pages/sdks/typescript-sdk/_meta.json index ecea2ea77..0c7d2de21 100644 --- a/frontend/docs/pages/sdks/typescript-sdk/_meta.json +++ b/frontend/docs/pages/sdks/typescript-sdk/_meta.json @@ -4,4 +4,4 @@ "creating-a-worker": "Creating a Worker", "pushing-events": "Pushing Events", "api": "API" -} \ No newline at end of file +} diff --git a/frontend/docs/pages/sdks/typescript-sdk/api/_meta.json b/frontend/docs/pages/sdks/typescript-sdk/api/_meta.json index ea87ec93c..95ebc2512 100644 --- a/frontend/docs/pages/sdks/typescript-sdk/api/_meta.json +++ b/frontend/docs/pages/sdks/typescript-sdk/api/_meta.json @@ -1,3 +1,3 @@ { "admin-client": "Admin" -} \ No newline at end of file +} diff --git a/frontend/docs/pages/self-hosting/_meta.json b/frontend/docs/pages/self-hosting/_meta.json index 630335985..dcf108174 100644 --- a/frontend/docs/pages/self-hosting/_meta.json +++ b/frontend/docs/pages/self-hosting/_meta.json @@ -12,4 +12,4 @@ }, "configuration-options": "Configuration Options", "github-app-setup": "GitHub App Setup" -} \ No newline at end of file +} diff --git a/frontend/docs/postcss.config.js b/frontend/docs/postcss.config.js index 88a3558e2..ed172def3 100644 --- a/frontend/docs/postcss.config.js +++ b/frontend/docs/postcss.config.js @@ -3,4 +3,4 @@ module.exports = { tailwindcss: {}, autoprefixer: {}, }, - } \ No newline at end of file + } diff --git a/frontend/docs/styles/global.css b/frontend/docs/styles/global.css index e916c40ee..008f4ec42 100644 --- a/frontend/docs/styles/global.css +++ b/frontend/docs/styles/global.css @@ -160,4 +160,4 @@ nav { :is(html[class~="dark"]) .nextra-nav-container-blur.nx-pointer-events-none { background-color: var(--background) !important; -} \ No newline at end of file +} diff --git a/frontend/docs/tailwind.config.js b/frontend/docs/tailwind.config.js index 1195c4897..e5161b686 100644 --- a/frontend/docs/tailwind.config.js +++ b/frontend/docs/tailwind.config.js @@ -12,4 +12,4 @@ module.exports = { extend: {}, }, plugins: [], - }; \ No newline at end of file + }; diff --git a/hack/dev/generate-dev-api-token.sh b/hack/dev/generate-dev-api-token.sh index e7119c984..c95c81920 100644 --- a/hack/dev/generate-dev-api-token.sh +++ b/hack/dev/generate-dev-api-token.sh @@ -7,4 +7,4 @@ set -a . .env set +a -go run ./cmd/hatchet-admin token create --name "local" --tenant-id 707d0855-80ab-4e1f-a156-f1c4546cbf52 \ No newline at end of file +go run ./cmd/hatchet-admin token create --name "local" --tenant-id 707d0855-80ab-4e1f-a156-f1c4546cbf52 diff --git a/hack/dev/generate-local-encryption-keys.sh b/hack/dev/generate-local-encryption-keys.sh index 74730fbce..a50f38519 100644 --- a/hack/dev/generate-local-encryption-keys.sh +++ b/hack/dev/generate-local-encryption-keys.sh @@ -14,4 +14,3 @@ mkdir -p $ENCRYPTION_KEYS_DIR # Generate a master encryption key go run ./cmd/hatchet-admin keyset create-local-keys --key-dir $ENCRYPTION_KEYS_DIR - diff --git a/hack/oas/generate-clients.sh b/hack/oas/generate-clients.sh index ade295c6e..7ccb03163 100644 --- a/hack/oas/generate-clients.sh +++ b/hack/oas/generate-clients.sh @@ -49,4 +49,4 @@ cp $tmp_dir/hatchet_sdk/clients/rest/models/__init__.py $dst_dir/models/__init__ cp $tmp_dir/hatchet_sdk/clients/rest/api/__init__.py $dst_dir/api/__init__.py # remove tmp folder -rm -rf $tmp_dir \ No newline at end of file +rm -rf $tmp_dir diff --git a/nodemon.api.json b/nodemon.api.json index e3f3d10f5..5db67bbd5 100644 --- a/nodemon.api.json +++ b/nodemon.api.json @@ -10,4 +10,4 @@ "go.mod", "go.sum" ] -} \ No newline at end of file +} diff --git a/nodemon.engine.json b/nodemon.engine.json index 6b36170d8..93f36bc6f 100644 --- a/nodemon.engine.json +++ b/nodemon.engine.json @@ -9,4 +9,4 @@ "go.mod", "go.sum" ] -} \ No newline at end of file +} diff --git a/prisma/migrations/migration_lock.toml b/prisma/migrations/migration_lock.toml index fbffa92c2..99e4f2009 100644 --- a/prisma/migrations/migration_lock.toml +++ b/prisma/migrations/migration_lock.toml @@ -1,3 +1,3 @@ # Please do not edit this file manually # It should be added in your version-control system (i.e. Git) -provider = "postgresql" \ No newline at end of file +provider = "postgresql" diff --git a/python-sdk/.gitignore b/python-sdk/.gitignore index 6769e21d9..68bc17f9f 100644 --- a/python-sdk/.gitignore +++ b/python-sdk/.gitignore @@ -157,4 +157,4 @@ cython_debug/ # be found at https://github.com/github/gitignore/blob/main/Global/JetBrains.gitignore # and can be added to the global gitignore or merged into this file. For a more nuclear # option (not recommended) you can uncomment the following to ignore the entire idea folder. -#.idea/ \ No newline at end of file +#.idea/ diff --git a/python-sdk/examples/api/api.py b/python-sdk/examples/api/api.py index 62e96e14c..b7dc1a06f 100644 --- a/python-sdk/examples/api/api.py +++ b/python-sdk/examples/api/api.py @@ -1,11 +1,12 @@ -from hatchet_sdk import Hatchet, WorkflowList from dotenv import load_dotenv +from hatchet_sdk import Hatchet, WorkflowList + load_dotenv() hatchet = Hatchet(debug=True) -list : WorkflowList = hatchet.client.rest().workflow_list() +list: WorkflowList = hatchet.client.rest().workflow_list() for workflow in list.rows: print(workflow.name) diff --git a/python-sdk/examples/async/event_test.py b/python-sdk/examples/async/event_test.py index 8b4def4e8..53fe94730 100644 --- a/python-sdk/examples/async/event_test.py +++ b/python-sdk/examples/async/event_test.py @@ -1,13 +1,9 @@ -from hatchet_sdk import new_client from dotenv import load_dotenv +from hatchet_sdk import new_client + load_dotenv() client = new_client() -client.event.push( - "user:create", - { - "test": "test" - } -) \ No newline at end of file +client.event.push("user:create", {"test": "test"}) diff --git a/python-sdk/examples/async/worker.py b/python-sdk/examples/async/worker.py index f0dee860c..2388f9d55 100644 --- a/python-sdk/examples/async/worker.py +++ b/python-sdk/examples/async/worker.py @@ -1,36 +1,40 @@ -from hatchet_sdk import Hatchet, Context -from dotenv import load_dotenv import asyncio +from dotenv import load_dotenv + +from hatchet_sdk import Context, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["user:create"]) class AsyncWorkflow: def __init__(self): self.my_value = "test" - @hatchet.step(timeout='5s') + @hatchet.step(timeout="5s") def step1(self, context: Context): async def async_step1(): print("started step1") await asyncio.sleep(2) print("finished step1") - return 'result' + return "result" res = asyncio.run(async_step1()) print(res) - return {'test': 'test'} + return {"test": "test"} - @hatchet.step(parents=["step1"],timeout='4s') + @hatchet.step(parents=["step1"], timeout="4s") async def step2(self, context): print("started async step2") await asyncio.sleep(2) print("finished step2") + workflow = AsyncWorkflow() -worker = hatchet.worker('test-worker', max_runs=4) +worker = hatchet.worker("test-worker", max_runs=4) worker.register_workflow(workflow) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/cancellation/worker.py b/python-sdk/examples/cancellation/worker.py index bae5d7d63..26426e646 100644 --- a/python-sdk/examples/cancellation/worker.py +++ b/python-sdk/examples/cancellation/worker.py @@ -1,16 +1,20 @@ -from hatchet_sdk import Hatchet, Context -from dotenv import load_dotenv import asyncio + +from dotenv import load_dotenv + +from hatchet_sdk import Context, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["user:create"]) class CancelWorkflow: def __init__(self): self.my_value = "test" - @hatchet.step(timeout='10s', retries=1) + @hatchet.step(timeout="10s", retries=1) async def step1(self, context: Context): i = 0 while not context.exit_flag.is_set() and i < 20: @@ -23,7 +27,7 @@ class CancelWorkflow: workflow = CancelWorkflow() -worker = hatchet.worker('test-worker', max_runs=4) +worker = hatchet.worker("test-worker", max_runs=4) worker.register_workflow(workflow) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/concurrency-limit-rr/event_test.py b/python-sdk/examples/concurrency-limit-rr/event_test.py index eb657b64a..16b2bcd09 100644 --- a/python-sdk/examples/concurrency-limit-rr/event_test.py +++ b/python-sdk/examples/concurrency-limit-rr/event_test.py @@ -1,6 +1,7 @@ -from hatchet_sdk import new_client from dotenv import load_dotenv +from hatchet_sdk import new_client + load_dotenv() client = new_client() @@ -11,9 +12,4 @@ for i in range(200): if i % 2 == 0: group = "1" - client.event.push( - "concurrency-test", - { - "group": group - } - ) \ No newline at end of file + client.event.push("concurrency-test", {"group": group}) diff --git a/python-sdk/examples/concurrency-limit-rr/worker.py b/python-sdk/examples/concurrency-limit-rr/worker.py index b07ee51b1..927ac127f 100644 --- a/python-sdk/examples/concurrency-limit-rr/worker.py +++ b/python-sdk/examples/concurrency-limit-rr/worker.py @@ -1,19 +1,23 @@ -from hatchet_sdk import Hatchet, ConcurrencyLimitStrategy, Context from dotenv import load_dotenv +from hatchet_sdk import ConcurrencyLimitStrategy, Context, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) -@hatchet.workflow(on_events=["concurrency-test"],schedule_timeout="10m") + +@hatchet.workflow(on_events=["concurrency-test"], schedule_timeout="10m") class ConcurrencyDemoWorkflowRR: - @hatchet.concurrency(max_runs=1, limit_strategy=ConcurrencyLimitStrategy.GROUP_ROUND_ROBIN) - def concurrency(self, context : Context) -> str: + @hatchet.concurrency( + max_runs=1, limit_strategy=ConcurrencyLimitStrategy.GROUP_ROUND_ROBIN + ) + def concurrency(self, context: Context) -> str: input = context.workflow_input() print(input) - return input.get('group') + return input.get("group") @hatchet.step() def step1(self, context): @@ -22,8 +26,9 @@ class ConcurrencyDemoWorkflowRR: print("finished step1") pass + workflow = ConcurrencyDemoWorkflowRR() -worker = hatchet.worker('concurrency-demo-worker-rr', max_runs=10) +worker = hatchet.worker("concurrency-demo-worker-rr", max_runs=10) worker.register_workflow(workflow) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/concurrency-limit/event_test.py b/python-sdk/examples/concurrency-limit/event_test.py index 3c8fa7a06..68371933b 100644 --- a/python-sdk/examples/concurrency-limit/event_test.py +++ b/python-sdk/examples/concurrency-limit/event_test.py @@ -1,13 +1,9 @@ -from hatchet_sdk import new_client from dotenv import load_dotenv +from hatchet_sdk import new_client + load_dotenv() client = new_client() -client.event.push( - "concurrency-test", - { - "test": "test" - } -) \ No newline at end of file +client.event.push("concurrency-test", {"test": "test"}) diff --git a/python-sdk/examples/concurrency-limit/worker.py b/python-sdk/examples/concurrency-limit/worker.py index c324fd7a3..7355c82d2 100644 --- a/python-sdk/examples/concurrency-limit/worker.py +++ b/python-sdk/examples/concurrency-limit/worker.py @@ -1,10 +1,12 @@ -from hatchet_sdk import Hatchet from dotenv import load_dotenv +from hatchet_sdk import Hatchet + load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["concurrency-test"]) class ConcurrencyDemoWorkflow: def __init__(self): @@ -19,14 +21,15 @@ class ConcurrencyDemoWorkflow: print("executed step1") pass - @hatchet.step(parents=["step1"],timeout='4s') + @hatchet.step(parents=["step1"], timeout="4s") def step2(self, context): print("started step2") context.sleep(1) print("finished step2") + workflow = ConcurrencyDemoWorkflow() -worker = hatchet.worker('concurrency-demo-worker', max_runs=4) +worker = hatchet.worker("concurrency-demo-worker", max_runs=4) worker.register_workflow(workflow) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/dag/event_test.py b/python-sdk/examples/dag/event_test.py index 926c311d7..d6a149f08 100644 --- a/python-sdk/examples/dag/event_test.py +++ b/python-sdk/examples/dag/event_test.py @@ -1,15 +1,10 @@ -from hatchet_sdk import new_client from dotenv import load_dotenv +from hatchet_sdk import new_client + load_dotenv() client = new_client() for i in range(10): - client.event.push( - "user:create", - { - "test": "test" - } - ) - + client.event.push("user:create", {"test": "test"}) diff --git a/python-sdk/examples/dag/worker.py b/python-sdk/examples/dag/worker.py index 006265321..539a3171f 100644 --- a/python-sdk/examples/dag/worker.py +++ b/python-sdk/examples/dag/worker.py @@ -1,19 +1,26 @@ import time -from hatchet_sdk import Hatchet, Context + from dotenv import load_dotenv +from hatchet_sdk import Context, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) -@hatchet.workflow(on_events=["user:create"],schedule_timeout="10m") + +@hatchet.workflow(on_events=["user:create"], schedule_timeout="10m") class MyWorkflow: def __init__(self): self.my_value = "test" @hatchet.step() - def step1(self, context : Context): - print("starting step1", time.strftime("%H:%M:%S", time.localtime()), context.workflow_input()) + def step1(self, context: Context): + print( + "starting step1", + time.strftime("%H:%M:%S", time.localtime()), + context.workflow_input(), + ) overrideValue = context.playground("prompt", "You are an AI assistant...") time.sleep(5) # pretty-print time @@ -23,8 +30,12 @@ class MyWorkflow: } @hatchet.step() - def step2(self, context : Context): - print("starting step2", time.strftime("%H:%M:%S", time.localtime()), context.workflow_input()) + def step2(self, context: Context): + print( + "starting step2", + time.strftime("%H:%M:%S", time.localtime()), + context.workflow_input(), + ) time.sleep(5) print("executed step2", time.strftime("%H:%M:%S", time.localtime())) return { @@ -32,21 +43,34 @@ class MyWorkflow: } @hatchet.step(parents=["step1", "step2"]) - def step3(self, context : Context): - print("executed step3", time.strftime("%H:%M:%S", time.localtime()), context.workflow_input(), context.step_output("step1"), context.step_output("step2")) + def step3(self, context: Context): + print( + "executed step3", + time.strftime("%H:%M:%S", time.localtime()), + context.workflow_input(), + context.step_output("step1"), + context.step_output("step2"), + ) return { "step3": "step3", } - + @hatchet.step(parents=["step1", "step3"]) - def step4(self, context : Context): - print("executed step4", time.strftime("%H:%M:%S", time.localtime()), context.workflow_input(), context.step_output("step1"), context.step_output("step3")) + def step4(self, context: Context): + print( + "executed step4", + time.strftime("%H:%M:%S", time.localtime()), + context.workflow_input(), + context.step_output("step1"), + context.step_output("step3"), + ) return { "step4": "step4", } + workflow = MyWorkflow() -worker = hatchet.worker('test-worker') +worker = hatchet.worker("test-worker") worker.register_workflow(workflow) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/delayed/event_test.py b/python-sdk/examples/delayed/event_test.py index ba9246e3d..cdc16ac64 100644 --- a/python-sdk/examples/delayed/event_test.py +++ b/python-sdk/examples/delayed/event_test.py @@ -1,13 +1,9 @@ -from hatchet_sdk import new_client from dotenv import load_dotenv +from hatchet_sdk import new_client + load_dotenv() client = new_client() -client.event.push( - "printer:schedule", - { - "message": "test" - } -) \ No newline at end of file +client.event.push("printer:schedule", {"message": "test"}) diff --git a/python-sdk/examples/delayed/worker.py b/python-sdk/examples/delayed/worker.py index ade824749..c6e5ded82 100644 --- a/python-sdk/examples/delayed/worker.py +++ b/python-sdk/examples/delayed/worker.py @@ -1,36 +1,39 @@ from datetime import datetime, timedelta -from hatchet_sdk import Hatchet, Context + from dotenv import load_dotenv +from hatchet_sdk import Context, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["printer:schedule"]) class PrintSchedule: @hatchet.step() - def schedule(self, context:Context): + def schedule(self, context: Context): now = datetime.now() - print(f"the time is \t {now.strftime("%H:%M:%S")}") + print(f"the time is \t {now.strftime('%H:%M:%S')}") future_time = now + timedelta(seconds=15) - print(f"scheduling for \t {future_time.strftime("%H:%M:%S")}") + print(f"scheduling for \t {future_time.strftime('%H:%M:%S')}") hatchet.client.admin.schedule_workflow( - 'PrintPrinter', - [future_time], - context.workflow_input() + "PrintPrinter", [future_time], context.workflow_input() ) + @hatchet.workflow() class PrintPrinter: @hatchet.step() def step1(self, context: Context): now = datetime.now() - print(f"printed at \t {now.strftime("%H:%M:%S")}") + print(f"printed at \t {now.strftime('%H:%M:%S')}") print(f"message \t {context.workflow_input()['message']}") -worker = hatchet.worker('test-worker', max_runs=4) + +worker = hatchet.worker("test-worker", max_runs=4) worker.register_workflow(PrintSchedule()) worker.register_workflow(PrintPrinter()) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/fanout/worker.py b/python-sdk/examples/fanout/worker.py index 6288144b1..f1b7b5363 100644 --- a/python-sdk/examples/fanout/worker.py +++ b/python-sdk/examples/fanout/worker.py @@ -1,17 +1,20 @@ -from hatchet_sdk import Hatchet, Context from dotenv import load_dotenv +from hatchet_sdk import Context, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["parent:create"]) class Parent: - @hatchet.step(timeout='10s') + @hatchet.step(timeout="10s") async def spawn(self, context: Context): print("spawning child") child = await context.spawn_workflow("Child", key="child").result() - print(f'results {child}') + print(f"results {child}") + @hatchet.workflow(on_events=["child:create"]) class Child: @@ -21,8 +24,8 @@ class Child: return {"status": "success"} -worker = hatchet.worker('fanout-worker', max_runs=4) +worker = hatchet.worker("fanout-worker", max_runs=4) worker.register_workflow(Parent()) worker.register_workflow(Child()) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/logger/worker.py b/python-sdk/examples/logger/worker.py index 77a688abe..144f9b65f 100644 --- a/python-sdk/examples/logger/worker.py +++ b/python-sdk/examples/logger/worker.py @@ -1,25 +1,29 @@ import time -from hatchet_sdk import Hatchet, Context + from dotenv import load_dotenv +from hatchet_sdk import Context, Hatchet + load_dotenv() hatchet = Hatchet() -@hatchet.workflow(on_events=["user:create"],schedule_timeout="10m") + +@hatchet.workflow(on_events=["user:create"], schedule_timeout="10m") class LoggingWorkflow: @hatchet.step() - def logger(self, context : Context): + def logger(self, context: Context): for i in range(1000): context.log(f"Logging message {i}") - + return { "step1": "completed", } + workflow = LoggingWorkflow() -worker = hatchet.worker('logging-worker-py') +worker = hatchet.worker("logging-worker-py") worker.register_workflow(workflow) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/manual_trigger/stream.py b/python-sdk/examples/manual_trigger/stream.py index 2a9942053..7d868ec22 100644 --- a/python-sdk/examples/manual_trigger/stream.py +++ b/python-sdk/examples/manual_trigger/stream.py @@ -1,15 +1,20 @@ -import os -from hatchet_sdk import new_client -from dotenv import load_dotenv -import json import asyncio -from hatchet_sdk.clients.listener import StepRunEventType import base64 +import json +import os + +from dotenv import load_dotenv + +from hatchet_sdk import new_client +from hatchet_sdk.clients.listener import StepRunEventType + async def main(): load_dotenv() hatchet = new_client() - workflowRunId = hatchet.admin.run_workflow("ManualTriggerWorkflow", {"test": "test"}) + workflowRunId = hatchet.admin.run_workflow( + "ManualTriggerWorkflow", {"test": "test"} + ) listener = hatchet.listener.stream(workflowRunId) # Get the directory of the current script @@ -30,11 +35,9 @@ async def main(): with open(payload_path, "wb") as f: f.write(decoded_payload) - data = json.dumps({ - "type": event.type, - "messageId": workflowRunId - }) + data = json.dumps({"type": event.type, "messageId": workflowRunId}) print("data: " + data + "\n\n") + if __name__ == "__main__": - asyncio.run(main()) \ No newline at end of file + asyncio.run(main()) diff --git a/python-sdk/examples/manual_trigger/worker.py b/python-sdk/examples/manual_trigger/worker.py index 6c2e38c0d..14253fc1f 100644 --- a/python-sdk/examples/manual_trigger/worker.py +++ b/python-sdk/examples/manual_trigger/worker.py @@ -1,8 +1,10 @@ -from hatchet_sdk import Hatchet, Context -from dotenv import load_dotenv import base64 import os +from dotenv import load_dotenv + +from hatchet_sdk import Context, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) @@ -12,39 +14,40 @@ hatchet = Hatchet(debug=True) class ManualTriggerWorkflow: @hatchet.step() def step1(self, context: Context): - res = context.playground('res', "HELLO") + res = context.playground("res", "HELLO") # Get the directory of the current script script_dir = os.path.dirname(os.path.abspath(__file__)) - + # Construct the path to the image file relative to the script's directory image_path = os.path.join(script_dir, "image.jpeg") - + # Load the image file with open(image_path, "rb") as image_file: image_data = image_file.read() - + print(len(image_data)) # Encode the image data as base64 - base64_image = base64.b64encode(image_data).decode('utf-8') - + base64_image = base64.b64encode(image_data).decode("utf-8") + # Stream the base64-encoded image data context.put_stream(base64_image) context.sleep(3) print("executed step1") - return {"step1": "data1 "+res} + return {"step1": "data1 " + res} - @hatchet.step(parents=["step1"], timeout='4s') + @hatchet.step(parents=["step1"], timeout="4s") def step2(self, context): print("started step2") context.sleep(1) print("finished step2") return {"step2": "data2"} + workflow = ManualTriggerWorkflow() -worker = hatchet.worker('manual-worker', max_runs=4) +worker = hatchet.worker("manual-worker", max_runs=4) worker.register_workflow(workflow) worker.start() diff --git a/python-sdk/examples/rate_limit/event_test.py b/python-sdk/examples/rate_limit/event_test.py index 77994b8dd..ae8776fd2 100644 --- a/python-sdk/examples/rate_limit/event_test.py +++ b/python-sdk/examples/rate_limit/event_test.py @@ -1,25 +1,11 @@ from dotenv import load_dotenv + from hatchet_sdk.hatchet import Hatchet load_dotenv() hatchet = Hatchet(debug=True) -hatchet.client.event.push( - "rate_limit:create", - { - "test": "1" - } -) -hatchet.client.event.push( - "rate_limit:create", - { - "test": "2" - } -) -hatchet.client.event.push( - "rate_limit:create", - { - "test": "3" - } -) \ No newline at end of file +hatchet.client.event.push("rate_limit:create", {"test": "1"}) +hatchet.client.event.push("rate_limit:create", {"test": "2"}) +hatchet.client.event.push("rate_limit:create", {"test": "3"}) diff --git a/python-sdk/examples/rate_limit/worker.py b/python-sdk/examples/rate_limit/worker.py index bd15177e4..48637cef1 100644 --- a/python-sdk/examples/rate_limit/worker.py +++ b/python-sdk/examples/rate_limit/worker.py @@ -1,24 +1,27 @@ -from hatchet_sdk import Hatchet, Context from dotenv import load_dotenv + +from hatchet_sdk import Context, Hatchet from hatchet_sdk.rate_limit import RateLimit, RateLimitDuration load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["rate_limit:create"]) class RateLimitWorkflow: def __init__(self): self.my_value = "test" - @hatchet.step(rate_limits = [RateLimit(key='test-limit', units=1)]) + @hatchet.step(rate_limits=[RateLimit(key="test-limit", units=1)]) def step1(self, context: Context): print("executed step1") pass -hatchet.client.admin.put_rate_limit('test-limit', 2, RateLimitDuration.MINUTE) -worker = hatchet.worker('test-worker', max_runs=4) +hatchet.client.admin.put_rate_limit("test-limit", 2, RateLimitDuration.MINUTE) + +worker = hatchet.worker("test-worker", max_runs=4) worker.register_workflow(RateLimitWorkflow()) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/simple/event_test.py b/python-sdk/examples/simple/event_test.py index 8b4def4e8..53fe94730 100644 --- a/python-sdk/examples/simple/event_test.py +++ b/python-sdk/examples/simple/event_test.py @@ -1,13 +1,9 @@ -from hatchet_sdk import new_client from dotenv import load_dotenv +from hatchet_sdk import new_client + load_dotenv() client = new_client() -client.event.push( - "user:create", - { - "test": "test" - } -) \ No newline at end of file +client.event.push("user:create", {"test": "test"}) diff --git a/python-sdk/examples/simple/worker.py b/python-sdk/examples/simple/worker.py index 7decc0b00..f7b5ba958 100644 --- a/python-sdk/examples/simple/worker.py +++ b/python-sdk/examples/simple/worker.py @@ -1,11 +1,14 @@ import json -from hatchet_sdk import Hatchet, Context, CreateWorkflowVersionOpts + from dotenv import load_dotenv +from hatchet_sdk import Context, CreateWorkflowVersionOpts, Hatchet + load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["user:create"]) class MyWorkflow: def __init__(self): @@ -23,19 +26,20 @@ class MyWorkflow: print("executed step1") pass - @hatchet.step(parents=["step1"],timeout='4s') + @hatchet.step(parents=["step1"], timeout="4s") def step2(self, context): print("started step2") context.sleep(1) print("finished step2") + workflow = MyWorkflow() -worker = hatchet.worker('test-worker', max_runs=4) +worker = hatchet.worker("test-worker", max_runs=4) worker.register_workflow(workflow) # workflow1 = hatchet.client.admin.put_workflow( # "workflow-copy-2", -# MyWorkflow(), +# MyWorkflow(), # overrides=CreateWorkflowVersionOpts( # cron_triggers=["* * * * *"], # cron_input=json.dumps({"test": "test"}), @@ -44,4 +48,4 @@ worker.register_workflow(workflow) # print(workflow1) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/examples/timeout/event_test.py b/python-sdk/examples/timeout/event_test.py index 8b4def4e8..53fe94730 100644 --- a/python-sdk/examples/timeout/event_test.py +++ b/python-sdk/examples/timeout/event_test.py @@ -1,13 +1,9 @@ -from hatchet_sdk import new_client from dotenv import load_dotenv +from hatchet_sdk import new_client + load_dotenv() client = new_client() -client.event.push( - "user:create", - { - "test": "test" - } -) \ No newline at end of file +client.event.push("user:create", {"test": "test"}) diff --git a/python-sdk/examples/timeout/worker.py b/python-sdk/examples/timeout/worker.py index d9e34ebdf..47d4717bd 100644 --- a/python-sdk/examples/timeout/worker.py +++ b/python-sdk/examples/timeout/worker.py @@ -1,16 +1,18 @@ -from hatchet_sdk import Hatchet from dotenv import load_dotenv +from hatchet_sdk import Hatchet + load_dotenv() hatchet = Hatchet(debug=True) + @hatchet.workflow(on_events=["user:create"]) class TimeoutWorkflow: def __init__(self): self.my_value = "test" - @hatchet.step(timeout='4s') + @hatchet.step(timeout="4s") def timeout(self, context): try: print("started step2") @@ -20,8 +22,9 @@ class TimeoutWorkflow: print("caught an exception: " + str(e)) raise e + workflow = TimeoutWorkflow() -worker = hatchet.worker('timeout-worker', max_runs=4) +worker = hatchet.worker("timeout-worker", max_runs=4) worker.register_workflow(workflow) -worker.start() \ No newline at end of file +worker.start() diff --git a/python-sdk/hatchet_sdk/__init__.py b/python-sdk/hatchet_sdk/__init__.py index 447fc6e06..9963dfbe3 100644 --- a/python-sdk/hatchet_sdk/__init__.py +++ b/python-sdk/hatchet_sdk/__init__.py @@ -1,9 +1,4 @@ -from .hatchet import Hatchet -from .clients.listener import StepRunEventType -from .worker import Worker -from .client import new_client -from .context import Context -from .workflows_pb2 import ConcurrencyLimitStrategy, CreateWorkflowVersionOpts, RateLimitDuration +from hatchet_sdk.clients.rest.models.accept_invite_request import AcceptInviteRequest # import models into sdk package from hatchet_sdk.clients.rest.models.api_error import APIError @@ -13,34 +8,59 @@ from hatchet_sdk.clients.rest.models.api_meta_auth import APIMetaAuth from hatchet_sdk.clients.rest.models.api_meta_integration import APIMetaIntegration from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.api_token import APIToken -from hatchet_sdk.clients.rest.models.accept_invite_request import AcceptInviteRequest -from hatchet_sdk.clients.rest.models.create_api_token_request import CreateAPITokenRequest -from hatchet_sdk.clients.rest.models.create_api_token_response import CreateAPITokenResponse -from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import CreatePullRequestFromStepRun -from hatchet_sdk.clients.rest.models.create_tenant_invite_request import CreateTenantInviteRequest +from hatchet_sdk.clients.rest.models.create_api_token_request import ( + CreateAPITokenRequest, +) +from hatchet_sdk.clients.rest.models.create_api_token_response import ( + CreateAPITokenResponse, +) +from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import ( + CreatePullRequestFromStepRun, +) +from hatchet_sdk.clients.rest.models.create_tenant_invite_request import ( + CreateTenantInviteRequest, +) from hatchet_sdk.clients.rest.models.create_tenant_request import CreateTenantRequest from hatchet_sdk.clients.rest.models.event import Event from hatchet_sdk.clients.rest.models.event_data import EventData from hatchet_sdk.clients.rest.models.event_key_list import EventKeyList from hatchet_sdk.clients.rest.models.event_list import EventList -from hatchet_sdk.clients.rest.models.event_order_by_direction import EventOrderByDirection +from hatchet_sdk.clients.rest.models.event_order_by_direction import ( + EventOrderByDirection, +) from hatchet_sdk.clients.rest.models.event_order_by_field import EventOrderByField -from hatchet_sdk.clients.rest.models.event_workflow_run_summary import EventWorkflowRunSummary -from hatchet_sdk.clients.rest.models.get_step_run_diff_response import GetStepRunDiffResponse -from hatchet_sdk.clients.rest.models.github_app_installation import GithubAppInstallation +from hatchet_sdk.clients.rest.models.event_workflow_run_summary import ( + EventWorkflowRunSummary, +) +from hatchet_sdk.clients.rest.models.get_step_run_diff_response import ( + GetStepRunDiffResponse, +) +from hatchet_sdk.clients.rest.models.github_app_installation import ( + GithubAppInstallation, +) from hatchet_sdk.clients.rest.models.github_branch import GithubBranch from hatchet_sdk.clients.rest.models.github_repo import GithubRepo from hatchet_sdk.clients.rest.models.job import Job from hatchet_sdk.clients.rest.models.job_run import JobRun from hatchet_sdk.clients.rest.models.job_run_status import JobRunStatus -from hatchet_sdk.clients.rest.models.link_github_repository_request import LinkGithubRepositoryRequest -from hatchet_sdk.clients.rest.models.list_api_tokens_response import ListAPITokensResponse -from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ListGithubAppInstallationsResponse -from hatchet_sdk.clients.rest.models.list_pull_requests_response import ListPullRequestsResponse +from hatchet_sdk.clients.rest.models.link_github_repository_request import ( + LinkGithubRepositoryRequest, +) +from hatchet_sdk.clients.rest.models.list_api_tokens_response import ( + ListAPITokensResponse, +) +from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ( + ListGithubAppInstallationsResponse, +) +from hatchet_sdk.clients.rest.models.list_pull_requests_response import ( + ListPullRequestsResponse, +) from hatchet_sdk.clients.rest.models.log_line import LogLine from hatchet_sdk.clients.rest.models.log_line_level import LogLineLevel from hatchet_sdk.clients.rest.models.log_line_list import LogLineList -from hatchet_sdk.clients.rest.models.log_line_order_by_direction import LogLineOrderByDirection +from hatchet_sdk.clients.rest.models.log_line_order_by_direction import ( + LogLineOrderByDirection, +) from hatchet_sdk.clients.rest.models.log_line_order_by_field import LogLineOrderByField from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.pull_request import PullRequest @@ -59,26 +79,53 @@ from hatchet_sdk.clients.rest.models.tenant_list import TenantList from hatchet_sdk.clients.rest.models.tenant_member import TenantMember from hatchet_sdk.clients.rest.models.tenant_member_list import TenantMemberList from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole -from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import TriggerWorkflowRunRequest -from hatchet_sdk.clients.rest.models.update_tenant_invite_request import UpdateTenantInviteRequest +from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import ( + TriggerWorkflowRunRequest, +) +from hatchet_sdk.clients.rest.models.update_tenant_invite_request import ( + UpdateTenantInviteRequest, +) from hatchet_sdk.clients.rest.models.user import User from hatchet_sdk.clients.rest.models.user_login_request import UserLoginRequest from hatchet_sdk.clients.rest.models.user_register_request import UserRegisterRequest -from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import UserTenantMembershipsList +from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import ( + UserTenantMembershipsList, +) from hatchet_sdk.clients.rest.models.user_tenant_public import UserTenantPublic from hatchet_sdk.clients.rest.models.worker import Worker from hatchet_sdk.clients.rest.models.worker_list import WorkerList from hatchet_sdk.clients.rest.models.workflow import Workflow -from hatchet_sdk.clients.rest.models.workflow_deployment_config import WorkflowDeploymentConfig +from hatchet_sdk.clients.rest.models.workflow_deployment_config import ( + WorkflowDeploymentConfig, +) from hatchet_sdk.clients.rest.models.workflow_list import WorkflowList from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun from hatchet_sdk.clients.rest.models.workflow_run_list import WorkflowRunList from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus -from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import WorkflowRunTriggeredBy +from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import ( + WorkflowRunTriggeredBy, +) from hatchet_sdk.clients.rest.models.workflow_tag import WorkflowTag -from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import WorkflowTriggerCronRef -from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import WorkflowTriggerEventRef +from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import ( + WorkflowTriggerCronRef, +) +from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import ( + WorkflowTriggerEventRef, +) from hatchet_sdk.clients.rest.models.workflow_triggers import WorkflowTriggers from hatchet_sdk.clients.rest.models.workflow_version import WorkflowVersion -from hatchet_sdk.clients.rest.models.workflow_version_definition import WorkflowVersionDefinition +from hatchet_sdk.clients.rest.models.workflow_version_definition import ( + WorkflowVersionDefinition, +) from hatchet_sdk.clients.rest.models.workflow_version_meta import WorkflowVersionMeta + +from .client import new_client +from .clients.listener import StepRunEventType +from .context import Context +from .hatchet import Hatchet +from .worker import Worker +from .workflows_pb2 import ( + ConcurrencyLimitStrategy, + CreateWorkflowVersionOpts, + RateLimitDuration, +) diff --git a/python-sdk/hatchet_sdk/client.py b/python-sdk/hatchet_sdk/client.py index c6d6c608e..cb8ba2d6b 100644 --- a/python-sdk/hatchet_sdk/client.py +++ b/python-sdk/hatchet_sdk/client.py @@ -2,20 +2,21 @@ import os from typing import Any -from hatchet_sdk.connection import new_conn -from .clients.admin import AdminClientImpl, new_admin -from .clients.events import EventClientImpl, new_event -from .clients.dispatcher import DispatcherClientImpl, new_dispatcher -from .clients.listener import ListenerClientImpl, new_listener - -from .loader import ConfigLoader, ClientConfig import grpc -from .clients.rest.api_client import ApiClient +from hatchet_sdk.connection import new_conn + +from .clients.admin import AdminClientImpl, new_admin +from .clients.dispatcher import DispatcherClientImpl, new_dispatcher +from .clients.events import EventClientImpl, new_event +from .clients.listener import ListenerClientImpl, new_listener from .clients.rest.api.workflow_api import WorkflowApi from .clients.rest.api.workflow_run_api import WorkflowRunApi +from .clients.rest.api_client import ApiClient from .clients.rest.configuration import Configuration from .clients.rest_client import RestApi +from .loader import ClientConfig, ConfigLoader + class Client: admin: AdminClientImpl @@ -27,14 +28,14 @@ class Client: class ClientImpl(Client): def __init__( - self, - event_client: EventClientImpl, - admin_client: AdminClientImpl, - dispatcher_client: DispatcherClientImpl, - listener_client: ListenerClientImpl, - rest_client: RestApi, - config: ClientConfig - ): + self, + event_client: EventClientImpl, + admin_client: AdminClientImpl, + dispatcher_client: DispatcherClientImpl, + listener_client: ListenerClientImpl, + rest_client: RestApi, + config: ClientConfig, + ): self.admin = admin_client self.dispatcher = dispatcher_client self.event = event_client @@ -42,6 +43,7 @@ class ClientImpl(Client): self.rest = rest_client self.config = config + def with_host_port(host: str, port: int): def with_host_port_impl(config: ClientConfig): config.host = host @@ -62,7 +64,7 @@ def new_client(*opts_functions): if config.host_port is None: raise ValueError("Host and port are required") - conn : grpc.Channel = new_conn(config) + conn: grpc.Channel = new_conn(config) # Instantiate client implementations event_client = new_event(conn, config) @@ -71,4 +73,11 @@ def new_client(*opts_functions): listener_client = new_listener(conn, config) rest_client = RestApi(config.server_url, config.token, config.tenant_id) - return ClientImpl(event_client, admin_client, dispatcher_client, listener_client, rest_client, config) + return ClientImpl( + event_client, + admin_client, + dispatcher_client, + listener_client, + rest_client, + config, + ) diff --git a/python-sdk/hatchet_sdk/clients/admin.py b/python-sdk/hatchet_sdk/clients/admin.py index 386fbf694..fbc39fed8 100644 --- a/python-sdk/hatchet_sdk/clients/admin.py +++ b/python-sdk/hatchet_sdk/clients/admin.py @@ -1,14 +1,25 @@ +import json from datetime import datetime -from typing import List, Union +from typing import List, Optional, TypedDict, Union + import grpc from google.protobuf import timestamp_pb2 -from ..workflows_pb2_grpc import WorkflowServiceStub -from ..workflows_pb2 import CreateWorkflowVersionOpts, PutRateLimitRequest, RateLimitDuration, ScheduleWorkflowRequest, TriggerWorkflowRequest, PutWorkflowRequest, TriggerWorkflowResponse, WorkflowVersion + from ..loader import ClientConfig from ..metadata import get_metadata -import json -from typing import TypedDict, Optional from ..workflow import WorkflowMeta +from ..workflows_pb2 import ( + CreateWorkflowVersionOpts, + PutRateLimitRequest, + PutWorkflowRequest, + RateLimitDuration, + ScheduleWorkflowRequest, + TriggerWorkflowRequest, + TriggerWorkflowResponse, + WorkflowVersion, +) +from ..workflows_pb2_grpc import WorkflowServiceStub + def new_admin(conn, config: ClientConfig): return AdminClientImpl( @@ -16,20 +27,27 @@ def new_admin(conn, config: ClientConfig): token=config.token, ) + class TriggerWorkflowParentOptions(TypedDict): parent_id: Optional[str] parent_step_run_id: Optional[str] child_index: Optional[int] child_key: Optional[str] + class AdminClientImpl: def __init__(self, client: WorkflowServiceStub, token): self.client = client self.token = token - def put_workflow(self, name: str, workflow: CreateWorkflowVersionOpts | WorkflowMeta, overrides: CreateWorkflowVersionOpts | None = None) -> WorkflowVersion: + def put_workflow( + self, + name: str, + workflow: CreateWorkflowVersionOpts | WorkflowMeta, + overrides: CreateWorkflowVersionOpts | None = None, + ) -> WorkflowVersion: try: - opts : CreateWorkflowVersionOpts + opts: CreateWorkflowVersionOpts if isinstance(workflow, CreateWorkflowVersionOpts): opts = workflow @@ -49,8 +67,13 @@ class AdminClientImpl: ) except grpc.RpcError as e: raise ValueError(f"Could not put workflow: {e}") - - def put_rate_limit(self, key: str, limit: int, duration: RateLimitDuration = RateLimitDuration.SECOND): + + def put_rate_limit( + self, + key: str, + limit: int, + duration: RateLimitDuration = RateLimitDuration.SECOND, + ): try: self.client.PutRateLimit( PutRateLimitRequest( @@ -63,7 +86,13 @@ class AdminClientImpl: except grpc.RpcError as e: raise ValueError(f"Could not put rate limit: {e}") - def schedule_workflow(self, name: str, schedules: List[Union[datetime, timestamp_pb2.Timestamp]], input={}, options: TriggerWorkflowParentOptions = None): + def schedule_workflow( + self, + name: str, + schedules: List[Union[datetime, timestamp_pb2.Timestamp]], + input={}, + options: TriggerWorkflowParentOptions = None, + ): timestamp_schedules = [] for schedule in schedules: if isinstance(schedule, datetime): @@ -75,28 +104,39 @@ class AdminClientImpl: elif isinstance(schedule, timestamp_pb2.Timestamp): timestamp_schedules.append(schedule) else: - raise ValueError("Invalid schedule type. Must be datetime or timestamp_pb2.Timestamp.") + raise ValueError( + "Invalid schedule type. Must be datetime or timestamp_pb2.Timestamp." + ) try: - self.client.ScheduleWorkflow(ScheduleWorkflowRequest( - name=name, - schedules=timestamp_schedules, - input=json.dumps(input), - **(options or {}) - ), metadata=get_metadata(self.token)) + self.client.ScheduleWorkflow( + ScheduleWorkflowRequest( + name=name, + schedules=timestamp_schedules, + input=json.dumps(input), + **(options or {}), + ), + metadata=get_metadata(self.token), + ) except grpc.RpcError as e: raise ValueError(f"gRPC error: {e}") - def run_workflow(self, workflow_name: str, input: any, options: TriggerWorkflowParentOptions = None): + def run_workflow( + self, + workflow_name: str, + input: any, + options: TriggerWorkflowParentOptions = None, + ): try: payload_data = json.dumps(input) - resp: TriggerWorkflowResponse = self.client.TriggerWorkflow(TriggerWorkflowRequest( - name=workflow_name, - input=payload_data, - **(options or {}) - ), metadata=get_metadata(self.token)) + resp: TriggerWorkflowResponse = self.client.TriggerWorkflow( + TriggerWorkflowRequest( + name=workflow_name, input=payload_data, **(options or {}) + ), + metadata=get_metadata(self.token), + ) return resp.workflow_run_id except grpc.RpcError as e: diff --git a/python-sdk/hatchet_sdk/clients/dispatcher.py b/python-sdk/hatchet_sdk/clients/dispatcher.py index 5463930d7..2645d91af 100644 --- a/python-sdk/hatchet_sdk/clients/dispatcher.py +++ b/python-sdk/hatchet_sdk/clients/dispatcher.py @@ -1,17 +1,29 @@ # relative imports +import json import threading -from ..dispatcher_pb2 import GroupKeyActionEvent, StepActionEvent, ActionEventResponse, ActionType, AssignedAction, WorkerListenRequest, WorkerRegisterRequest, WorkerUnsubscribeRequest, WorkerRegisterResponse, OverridesData, HeartbeatRequest -from ..dispatcher_pb2_grpc import DispatcherStub - import time +from typing import Callable, List, Union + +import grpc + +from ..dispatcher_pb2 import ( + ActionEventResponse, + ActionType, + AssignedAction, + GroupKeyActionEvent, + HeartbeatRequest, + OverridesData, + StepActionEvent, + WorkerListenRequest, + WorkerRegisterRequest, + WorkerRegisterResponse, + WorkerUnsubscribeRequest, +) +from ..dispatcher_pb2_grpc import DispatcherStub from ..loader import ClientConfig from ..logger import logger -import json -import grpc -from typing import Callable, List, Union from ..metadata import get_metadata from .events import proto_timestamp_now -import time def new_dispatcher(conn, config: ClientConfig): @@ -19,7 +31,8 @@ def new_dispatcher(conn, config: ClientConfig): client=DispatcherStub(conn), token=config.token, ) - + + class DispatcherClient: def get_action_listener(self, ctx, req): raise NotImplementedError @@ -35,14 +48,35 @@ DEFAULT_REGISTER_TIMEOUT = 30 class GetActionListenerRequest: - def __init__(self, worker_name: str, services: List[str], actions: List[str], max_runs: int | None = None): + def __init__( + self, + worker_name: str, + services: List[str], + actions: List[str], + max_runs: int | None = None, + ): self.worker_name = worker_name self.services = services self.actions = actions self.max_runs = max_runs + class Action: - def __init__(self, worker_id: str, tenant_id: str, workflow_run_id: str, get_group_key_run_id: str, job_id: str, job_name: str, job_run_id: str, step_id: str, step_run_id: str, action_id: str, action_payload: str, action_type: ActionType): + def __init__( + self, + worker_id: str, + tenant_id: str, + workflow_run_id: str, + get_group_key_run_id: str, + job_id: str, + job_name: str, + job_run_id: str, + step_id: str, + step_run_id: str, + action_id: str, + action_payload: str, + action_type: ActionType, + ): self.worker_id = worker_id self.workflow_run_id = workflow_run_id self.get_group_key_run_id = get_group_key_run_id @@ -56,6 +90,7 @@ class Action: self.action_payload = action_payload self.action_type = action_type + class WorkerActionListener: def actions(self, ctx, err_ch): raise NotImplementedError @@ -63,12 +98,14 @@ class WorkerActionListener: def unregister(self): raise NotImplementedError + START_STEP_RUN = 0 CANCEL_STEP_RUN = 1 START_GET_GROUP_KEY = 2 + class ActionListenerImpl(WorkerActionListener): - def __init__(self, client : DispatcherStub, token, worker_id): + def __init__(self, client: DispatcherStub, token, worker_id): self.client = client self.token = token self.worker_id = worker_id @@ -105,7 +142,7 @@ class ActionListenerImpl(WorkerActionListener): def start_heartbeater(self): if self.heartbeat_thread is not None: return - + # create a new thread to send heartbeats heartbeat_thread = threading.Thread(target=self.heartbeat) heartbeat_thread.start() @@ -114,8 +151,7 @@ class ActionListenerImpl(WorkerActionListener): def actions(self): while True: - logger.info( - "Connecting to Hatchet to establish listener for actions...") + logger.info("Connecting to Hatchet to establish listener for actions...") try: for assigned_action in self.get_listen_client(): @@ -125,10 +161,15 @@ class ActionListenerImpl(WorkerActionListener): # Process the received action action_type = self.map_action_type(assigned_action.actionType) - if assigned_action.actionPayload is None or assigned_action.actionPayload == "": + if ( + assigned_action.actionPayload is None + or assigned_action.actionPayload == "" + ): action_payload = None else: - action_payload = self.parse_action_payload(assigned_action.actionPayload) + action_payload = self.parse_action_payload( + assigned_action.actionPayload + ) action = Action( tenant_id=assigned_action.tenantId, @@ -156,7 +197,10 @@ class ActionListenerImpl(WorkerActionListener): elif e.code() == grpc.StatusCode.DEADLINE_EXCEEDED: logger.info("Deadline exceeded, retrying subscription") continue - elif self.listen_strategy == "v2" and e.code() == grpc.StatusCode.UNIMPLEMENTED: + elif ( + self.listen_strategy == "v2" + and e.code() == grpc.StatusCode.UNIMPLEMENTED + ): # ListenV2 is not available, fallback to Listen self.listen_strategy = "v1" self.run_heartbeat = False @@ -170,7 +214,7 @@ class ActionListenerImpl(WorkerActionListener): self.retries = self.retries + 1 - def parse_action_payload(self, payload : str): + def parse_action_payload(self, payload: str): try: payload_data = json.loads(payload) except json.JSONDecodeError as e: @@ -187,43 +231,46 @@ class ActionListenerImpl(WorkerActionListener): else: # self.logger.error(f"Unknown action type: {action_type}") return None - + def get_listen_client(self): current_time = int(time.time()) - if current_time-self.last_connection_attempt > DEFAULT_ACTION_LISTENER_RETRY_INTERVAL: + if ( + current_time - self.last_connection_attempt + > DEFAULT_ACTION_LISTENER_RETRY_INTERVAL + ): self.retries = 0 if self.retries > DEFAULT_ACTION_LISTENER_RETRY_COUNT: raise Exception( - f"Could not subscribe to the worker after {DEFAULT_ACTION_LISTENER_RETRY_COUNT} retries") + f"Could not subscribe to the worker after {DEFAULT_ACTION_LISTENER_RETRY_COUNT} retries" + ) elif self.retries >= 1: # logger.info # if we are retrying, we wait for a bit. this should eventually be replaced with exp backoff + jitter time.sleep(DEFAULT_ACTION_LISTENER_RETRY_INTERVAL) logger.info( - f"Could not connect to Hatchet, retrying... {self.retries}/{DEFAULT_ACTION_LISTENER_RETRY_COUNT}") - + f"Could not connect to Hatchet, retrying... {self.retries}/{DEFAULT_ACTION_LISTENER_RETRY_COUNT}" + ) + if self.listen_strategy == "v2": - listener = self.client.ListenV2(WorkerListenRequest( - workerId=self.worker_id - ), + listener = self.client.ListenV2( + WorkerListenRequest(workerId=self.worker_id), metadata=get_metadata(self.token), ) self.start_heartbeater() else: # if ListenV2 is not available, fallback to Listen - listener = self.client.Listen(WorkerListenRequest( - workerId=self.worker_id - ), + listener = self.client.Listen( + WorkerListenRequest(workerId=self.worker_id), timeout=DEFAULT_ACTION_TIMEOUT, metadata=get_metadata(self.token), ) self.last_connection_attempt = current_time - logger.info('Listener established.') + logger.info("Listener established.") return listener def unregister(self): @@ -231,17 +278,16 @@ class ActionListenerImpl(WorkerActionListener): try: self.client.Unsubscribe( - WorkerUnsubscribeRequest( - workerId=self.worker_id - ), + WorkerUnsubscribeRequest(workerId=self.worker_id), timeout=DEFAULT_REGISTER_TIMEOUT, metadata=get_metadata(self.token), ) except grpc.RpcError as e: raise Exception(f"Failed to unsubscribe: {e}") + class DispatcherClientImpl(DispatcherClient): - def __init__(self, client : DispatcherStub, token): + def __init__(self, client: DispatcherStub, token): self.client = client self.token = token # self.logger = logger @@ -249,26 +295,39 @@ class DispatcherClientImpl(DispatcherClient): def get_action_listener(self, req: GetActionListenerRequest) -> ActionListenerImpl: # Register the worker - response : WorkerRegisterResponse = self.client.Register(WorkerRegisterRequest( - workerName=req.worker_name, - actions=req.actions, - services=req.services, - maxRuns=req.max_runs - ), timeout=DEFAULT_REGISTER_TIMEOUT, metadata=get_metadata(self.token)) + response: WorkerRegisterResponse = self.client.Register( + WorkerRegisterRequest( + workerName=req.worker_name, + actions=req.actions, + services=req.services, + maxRuns=req.max_runs, + ), + timeout=DEFAULT_REGISTER_TIMEOUT, + metadata=get_metadata(self.token), + ) return ActionListenerImpl(self.client, self.token, response.workerId) def send_step_action_event(self, in_: StepActionEvent): - response : ActionEventResponse = self.client.SendStepActionEvent(in_, metadata=get_metadata(self.token),) + response: ActionEventResponse = self.client.SendStepActionEvent( + in_, + metadata=get_metadata(self.token), + ) return response - + def send_group_key_action_event(self, in_: GroupKeyActionEvent): - response : ActionEventResponse = self.client.SendGroupKeyActionEvent(in_, metadata=get_metadata(self.token),) + response: ActionEventResponse = self.client.SendGroupKeyActionEvent( + in_, + metadata=get_metadata(self.token), + ) return response - + def put_overrides_data(self, data: OverridesData): - response : ActionEventResponse = self.client.PutOverridesData(data, metadata=get_metadata(self.token),) + response: ActionEventResponse = self.client.PutOverridesData( + data, + metadata=get_metadata(self.token), + ) return response diff --git a/python-sdk/hatchet_sdk/clients/events.py b/python-sdk/hatchet_sdk/clients/events.py index 1f13875a2..aa931c815 100644 --- a/python-sdk/hatchet_sdk/clients/events.py +++ b/python-sdk/hatchet_sdk/clients/events.py @@ -1,19 +1,22 @@ -from ..events_pb2_grpc import EventsServiceStub -from ..events_pb2 import PushEventRequest, PutLogRequest, PutStreamEventRequest - import datetime -from ..loader import ClientConfig import json + import grpc from google.protobuf import timestamp_pb2 + +from ..events_pb2 import PushEventRequest, PutLogRequest, PutStreamEventRequest +from ..events_pb2_grpc import EventsServiceStub +from ..loader import ClientConfig from ..metadata import get_metadata + def new_event(conn, config: ClientConfig): return EventClientImpl( client=EventsServiceStub(conn), config=config, ) + def proto_timestamp_now(): t = datetime.datetime.now().timestamp() seconds = int(t) @@ -21,6 +24,7 @@ def proto_timestamp_now(): return timestamp_pb2.Timestamp(seconds=seconds, nanos=nanos) + class EventClientImpl: def __init__(self, client: EventsServiceStub, config: ClientConfig): self.client = client @@ -28,11 +32,11 @@ class EventClientImpl: self.namespace = config.namespace def push(self, event_key, payload): - + namespaced_event_key = self.namespace + event_key - + try: - payload_bytes = json.dumps(payload).encode('utf-8') + payload_bytes = json.dumps(payload).encode("utf-8") except json.UnicodeEncodeError as e: raise ValueError(f"Error encoding payload: {e}") @@ -46,7 +50,7 @@ class EventClientImpl: self.client.Push(request, metadata=get_metadata(self.token)) except grpc.RpcError as e: raise ValueError(f"gRPC error: {e}") - + def log(self, message: str, step_run_id: str): try: request = PutLogRequest( @@ -58,16 +62,16 @@ class EventClientImpl: self.client.PutLog(request, metadata=get_metadata(self.token)) except Exception as e: raise ValueError(f"Error logging: {e}") - + def stream(self, data: str | bytes, step_run_id: str): try: if isinstance(data, str): - data_bytes = data.encode('utf-8') + data_bytes = data.encode("utf-8") elif isinstance(data, bytes): data_bytes = data else: raise ValueError("Invalid data type. Expected str, bytes, or file.") - + request = PutStreamEventRequest( stepRunId=step_run_id, createdAt=proto_timestamp_now(), @@ -75,4 +79,4 @@ class EventClientImpl: ) self.client.PutStreamEvent(request, metadata=get_metadata(self.token)) except Exception as e: - raise ValueError(f"Error putting stream event: {e}") \ No newline at end of file + raise ValueError(f"Error putting stream event: {e}") diff --git a/python-sdk/hatchet_sdk/clients/listener.py b/python-sdk/hatchet_sdk/clients/listener.py index ba19b9090..05fd1f619 100644 --- a/python-sdk/hatchet_sdk/clients/listener.py +++ b/python-sdk/hatchet_sdk/clients/listener.py @@ -1,33 +1,42 @@ +import asyncio +import json from typing import AsyncGenerator -import grpc -from hatchet_sdk.connection import new_conn -from ..dispatcher_pb2_grpc import DispatcherStub -from ..dispatcher_pb2 import SubscribeToWorkflowEventsRequest, ResourceEventType, WorkflowEvent, RESOURCE_TYPE_STEP_RUN, RESOURCE_TYPE_WORKFLOW_RUN +import grpc + +from hatchet_sdk.connection import new_conn + +from ..dispatcher_pb2 import ( + RESOURCE_TYPE_STEP_RUN, + RESOURCE_TYPE_WORKFLOW_RUN, + ResourceEventType, + SubscribeToWorkflowEventsRequest, + WorkflowEvent, +) +from ..dispatcher_pb2_grpc import DispatcherStub from ..loader import ClientConfig from ..metadata import get_metadata -import json -import asyncio - DEFAULT_ACTION_LISTENER_RETRY_INTERVAL = 5 # seconds DEFAULT_ACTION_LISTENER_RETRY_COUNT = 5 class StepRunEventType: - STEP_RUN_EVENT_TYPE_STARTED = 'STEP_RUN_EVENT_TYPE_STARTED' - STEP_RUN_EVENT_TYPE_COMPLETED = 'STEP_RUN_EVENT_TYPE_COMPLETED' - STEP_RUN_EVENT_TYPE_FAILED = 'STEP_RUN_EVENT_TYPE_FAILED' - STEP_RUN_EVENT_TYPE_CANCELLED = 'STEP_RUN_EVENT_TYPE_CANCELLED' - STEP_RUN_EVENT_TYPE_TIMED_OUT = 'STEP_RUN_EVENT_TYPE_TIMED_OUT' - STEP_RUN_EVENT_TYPE_STREAM = 'STEP_RUN_EVENT_TYPE_STREAM' + STEP_RUN_EVENT_TYPE_STARTED = "STEP_RUN_EVENT_TYPE_STARTED" + STEP_RUN_EVENT_TYPE_COMPLETED = "STEP_RUN_EVENT_TYPE_COMPLETED" + STEP_RUN_EVENT_TYPE_FAILED = "STEP_RUN_EVENT_TYPE_FAILED" + STEP_RUN_EVENT_TYPE_CANCELLED = "STEP_RUN_EVENT_TYPE_CANCELLED" + STEP_RUN_EVENT_TYPE_TIMED_OUT = "STEP_RUN_EVENT_TYPE_TIMED_OUT" + STEP_RUN_EVENT_TYPE_STREAM = "STEP_RUN_EVENT_TYPE_STREAM" + class WorkflowRunEventType: - WORKFLOW_RUN_EVENT_TYPE_STARTED = 'WORKFLOW_RUN_EVENT_TYPE_STARTED' - WORKFLOW_RUN_EVENT_TYPE_COMPLETED = 'WORKFLOW_RUN_EVENT_TYPE_COMPLETED' - WORKFLOW_RUN_EVENT_TYPE_FAILED = 'WORKFLOW_RUN_EVENT_TYPE_FAILED' - WORKFLOW_RUN_EVENT_TYPE_CANCELLED = 'WORKFLOW_RUN_EVENT_TYPE_CANCELLED' - WORKFLOW_RUN_EVENT_TYPE_TIMED_OUT = 'WORKFLOW_RUN_EVENT_TYPE_TIMED_OUT' + WORKFLOW_RUN_EVENT_TYPE_STARTED = "WORKFLOW_RUN_EVENT_TYPE_STARTED" + WORKFLOW_RUN_EVENT_TYPE_COMPLETED = "WORKFLOW_RUN_EVENT_TYPE_COMPLETED" + WORKFLOW_RUN_EVENT_TYPE_FAILED = "WORKFLOW_RUN_EVENT_TYPE_FAILED" + WORKFLOW_RUN_EVENT_TYPE_CANCELLED = "WORKFLOW_RUN_EVENT_TYPE_CANCELLED" + WORKFLOW_RUN_EVENT_TYPE_TIMED_OUT = "WORKFLOW_RUN_EVENT_TYPE_TIMED_OUT" + step_run_event_type_mapping = { ResourceEventType.RESOURCE_EVENT_TYPE_STARTED: StepRunEventType.STEP_RUN_EVENT_TYPE_STARTED, @@ -46,6 +55,7 @@ workflow_run_event_type_mapping = { ResourceEventType.RESOURCE_EVENT_TYPE_TIMED_OUT: WorkflowRunEventType.WORKFLOW_RUN_EVENT_TYPE_TIMED_OUT, } + class StepRunEvent: def __init__(self, type: StepRunEventType, payload: str): self.type = type @@ -54,9 +64,7 @@ class StepRunEvent: def new_listener(conn, config: ClientConfig): return ListenerClientImpl( - client=DispatcherStub(conn), - token=config.token, - config=config + client=DispatcherStub(conn), token=config.token, config=config ) @@ -87,10 +95,13 @@ class HatchetListener: eventType = None if workflow_event.resourceType == RESOURCE_TYPE_STEP_RUN: if workflow_event.eventType in step_run_event_type_mapping: - eventType = step_run_event_type_mapping[workflow_event.eventType] + eventType = step_run_event_type_mapping[ + workflow_event.eventType + ] else: raise Exception( - f"Unknown event type: {workflow_event.eventType}") + f"Unknown event type: {workflow_event.eventType}" + ) payload = None try: @@ -103,13 +114,16 @@ class HatchetListener: yield StepRunEvent(type=eventType, payload=payload) elif workflow_event.resourceType == RESOURCE_TYPE_WORKFLOW_RUN: if workflow_event.eventType in workflow_run_event_type_mapping: - eventType = workflow_run_event_type_mapping[workflow_event.eventType] + eventType = workflow_run_event_type_mapping[ + workflow_event.eventType + ] else: raise Exception( - f"Unknown event type: {workflow_event.eventType}") - + f"Unknown event type: {workflow_event.eventType}" + ) + payload = None - + try: if workflow_event.eventPayload: payload = json.loads(workflow_event.eventPayload) @@ -117,10 +131,10 @@ class HatchetListener: pass yield StepRunEvent(type=eventType, payload=payload) - + if workflow_event.hangup: listener = None - print('hangup stopping listener...') + print("hangup stopping listener...") break except grpc.RpcError as e: @@ -151,7 +165,9 @@ class HatchetListener: listener = self.client.SubscribeToWorkflowEvents( SubscribeToWorkflowEventsRequest( workflowRunId=self.workflow_run_id, - ), metadata=get_metadata(self.token)) + ), + metadata=get_metadata(self.token), + ) return listener except grpc.RpcError as e: if e.code() == grpc.StatusCode.UNAVAILABLE: diff --git a/python-sdk/hatchet_sdk/clients/rest/__init__.py b/python-sdk/hatchet_sdk/clients/rest/__init__.py index 5454e3931..2dfe9aad3 100644 --- a/python-sdk/hatchet_sdk/clients/rest/__init__.py +++ b/python-sdk/hatchet_sdk/clients/rest/__init__.py @@ -18,6 +18,7 @@ __version__ = "1.0.0" # import apis into sdk package from hatchet_sdk.clients.rest.api.api_token_api import APITokenApi +from hatchet_sdk.clients.rest.api.default_api import DefaultApi from hatchet_sdk.clients.rest.api.event_api import EventApi from hatchet_sdk.clients.rest.api.github_api import GithubApi from hatchet_sdk.clients.rest.api.healthcheck_api import HealthcheckApi @@ -30,18 +31,20 @@ from hatchet_sdk.clients.rest.api.user_api import UserApi from hatchet_sdk.clients.rest.api.worker_api import WorkerApi from hatchet_sdk.clients.rest.api.workflow_api import WorkflowApi from hatchet_sdk.clients.rest.api.workflow_run_api import WorkflowRunApi -from hatchet_sdk.clients.rest.api.default_api import DefaultApi +from hatchet_sdk.clients.rest.api_client import ApiClient # import ApiClient from hatchet_sdk.clients.rest.api_response import ApiResponse -from hatchet_sdk.clients.rest.api_client import ApiClient from hatchet_sdk.clients.rest.configuration import Configuration -from hatchet_sdk.clients.rest.exceptions import OpenApiException -from hatchet_sdk.clients.rest.exceptions import ApiTypeError -from hatchet_sdk.clients.rest.exceptions import ApiValueError -from hatchet_sdk.clients.rest.exceptions import ApiKeyError -from hatchet_sdk.clients.rest.exceptions import ApiAttributeError -from hatchet_sdk.clients.rest.exceptions import ApiException +from hatchet_sdk.clients.rest.exceptions import ( + ApiAttributeError, + ApiException, + ApiKeyError, + ApiTypeError, + ApiValueError, + OpenApiException, +) +from hatchet_sdk.clients.rest.models.accept_invite_request import AcceptInviteRequest # import models into sdk package from hatchet_sdk.clients.rest.models.api_error import APIError @@ -51,36 +54,63 @@ from hatchet_sdk.clients.rest.models.api_meta_auth import APIMetaAuth from hatchet_sdk.clients.rest.models.api_meta_integration import APIMetaIntegration from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.api_token import APIToken -from hatchet_sdk.clients.rest.models.accept_invite_request import AcceptInviteRequest -from hatchet_sdk.clients.rest.models.create_api_token_request import CreateAPITokenRequest -from hatchet_sdk.clients.rest.models.create_api_token_response import CreateAPITokenResponse -from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import CreatePullRequestFromStepRun -from hatchet_sdk.clients.rest.models.create_sns_integration_request import CreateSNSIntegrationRequest -from hatchet_sdk.clients.rest.models.create_tenant_invite_request import CreateTenantInviteRequest +from hatchet_sdk.clients.rest.models.create_api_token_request import ( + CreateAPITokenRequest, +) +from hatchet_sdk.clients.rest.models.create_api_token_response import ( + CreateAPITokenResponse, +) +from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import ( + CreatePullRequestFromStepRun, +) +from hatchet_sdk.clients.rest.models.create_sns_integration_request import ( + CreateSNSIntegrationRequest, +) +from hatchet_sdk.clients.rest.models.create_tenant_invite_request import ( + CreateTenantInviteRequest, +) from hatchet_sdk.clients.rest.models.create_tenant_request import CreateTenantRequest from hatchet_sdk.clients.rest.models.event import Event from hatchet_sdk.clients.rest.models.event_data import EventData from hatchet_sdk.clients.rest.models.event_key_list import EventKeyList from hatchet_sdk.clients.rest.models.event_list import EventList -from hatchet_sdk.clients.rest.models.event_order_by_direction import EventOrderByDirection +from hatchet_sdk.clients.rest.models.event_order_by_direction import ( + EventOrderByDirection, +) from hatchet_sdk.clients.rest.models.event_order_by_field import EventOrderByField -from hatchet_sdk.clients.rest.models.event_workflow_run_summary import EventWorkflowRunSummary -from hatchet_sdk.clients.rest.models.get_step_run_diff_response import GetStepRunDiffResponse -from hatchet_sdk.clients.rest.models.github_app_installation import GithubAppInstallation +from hatchet_sdk.clients.rest.models.event_workflow_run_summary import ( + EventWorkflowRunSummary, +) +from hatchet_sdk.clients.rest.models.get_step_run_diff_response import ( + GetStepRunDiffResponse, +) +from hatchet_sdk.clients.rest.models.github_app_installation import ( + GithubAppInstallation, +) from hatchet_sdk.clients.rest.models.github_branch import GithubBranch from hatchet_sdk.clients.rest.models.github_repo import GithubRepo from hatchet_sdk.clients.rest.models.job import Job from hatchet_sdk.clients.rest.models.job_run import JobRun from hatchet_sdk.clients.rest.models.job_run_status import JobRunStatus -from hatchet_sdk.clients.rest.models.link_github_repository_request import LinkGithubRepositoryRequest -from hatchet_sdk.clients.rest.models.list_api_tokens_response import ListAPITokensResponse -from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ListGithubAppInstallationsResponse -from hatchet_sdk.clients.rest.models.list_pull_requests_response import ListPullRequestsResponse +from hatchet_sdk.clients.rest.models.link_github_repository_request import ( + LinkGithubRepositoryRequest, +) +from hatchet_sdk.clients.rest.models.list_api_tokens_response import ( + ListAPITokensResponse, +) +from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ( + ListGithubAppInstallationsResponse, +) +from hatchet_sdk.clients.rest.models.list_pull_requests_response import ( + ListPullRequestsResponse, +) from hatchet_sdk.clients.rest.models.list_sns_integrations import ListSNSIntegrations from hatchet_sdk.clients.rest.models.log_line import LogLine from hatchet_sdk.clients.rest.models.log_line_level import LogLineLevel from hatchet_sdk.clients.rest.models.log_line_list import LogLineList -from hatchet_sdk.clients.rest.models.log_line_order_by_direction import LogLineOrderByDirection +from hatchet_sdk.clients.rest.models.log_line_order_by_direction import ( + LogLineOrderByDirection, +) from hatchet_sdk.clients.rest.models.log_line_order_by_field import LogLineOrderByField from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.pull_request import PullRequest @@ -100,29 +130,47 @@ from hatchet_sdk.clients.rest.models.tenant_list import TenantList from hatchet_sdk.clients.rest.models.tenant_member import TenantMember from hatchet_sdk.clients.rest.models.tenant_member_list import TenantMemberList from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole -from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import TriggerWorkflowRunRequest -from hatchet_sdk.clients.rest.models.update_tenant_invite_request import UpdateTenantInviteRequest +from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import ( + TriggerWorkflowRunRequest, +) +from hatchet_sdk.clients.rest.models.update_tenant_invite_request import ( + UpdateTenantInviteRequest, +) from hatchet_sdk.clients.rest.models.user import User -from hatchet_sdk.clients.rest.models.user_change_password_request import UserChangePasswordRequest +from hatchet_sdk.clients.rest.models.user_change_password_request import ( + UserChangePasswordRequest, +) from hatchet_sdk.clients.rest.models.user_login_request import UserLoginRequest from hatchet_sdk.clients.rest.models.user_register_request import UserRegisterRequest -from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import UserTenantMembershipsList +from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import ( + UserTenantMembershipsList, +) from hatchet_sdk.clients.rest.models.user_tenant_public import UserTenantPublic from hatchet_sdk.clients.rest.models.worker import Worker from hatchet_sdk.clients.rest.models.worker_list import WorkerList from hatchet_sdk.clients.rest.models.workflow import Workflow from hatchet_sdk.clients.rest.models.workflow_concurrency import WorkflowConcurrency -from hatchet_sdk.clients.rest.models.workflow_deployment_config import WorkflowDeploymentConfig +from hatchet_sdk.clients.rest.models.workflow_deployment_config import ( + WorkflowDeploymentConfig, +) from hatchet_sdk.clients.rest.models.workflow_list import WorkflowList from hatchet_sdk.clients.rest.models.workflow_metrics import WorkflowMetrics from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun from hatchet_sdk.clients.rest.models.workflow_run_list import WorkflowRunList from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus -from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import WorkflowRunTriggeredBy +from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import ( + WorkflowRunTriggeredBy, +) from hatchet_sdk.clients.rest.models.workflow_tag import WorkflowTag -from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import WorkflowTriggerCronRef -from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import WorkflowTriggerEventRef +from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import ( + WorkflowTriggerCronRef, +) +from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import ( + WorkflowTriggerEventRef, +) from hatchet_sdk.clients.rest.models.workflow_triggers import WorkflowTriggers from hatchet_sdk.clients.rest.models.workflow_version import WorkflowVersion -from hatchet_sdk.clients.rest.models.workflow_version_definition import WorkflowVersionDefinition +from hatchet_sdk.clients.rest.models.workflow_version_definition import ( + WorkflowVersionDefinition, +) from hatchet_sdk.clients.rest.models.workflow_version_meta import WorkflowVersionMeta diff --git a/python-sdk/hatchet_sdk/clients/rest/api/__init__.py b/python-sdk/hatchet_sdk/clients/rest/api/__init__.py index 13d312d5d..8a7cf7866 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/__init__.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/__init__.py @@ -2,6 +2,7 @@ # import apis into api package from hatchet_sdk.clients.rest.api.api_token_api import APITokenApi +from hatchet_sdk.clients.rest.api.default_api import DefaultApi from hatchet_sdk.clients.rest.api.event_api import EventApi from hatchet_sdk.clients.rest.api.github_api import GithubApi from hatchet_sdk.clients.rest.api.healthcheck_api import HealthcheckApi @@ -14,5 +15,3 @@ from hatchet_sdk.clients.rest.api.user_api import UserApi from hatchet_sdk.clients.rest.api.worker_api import WorkerApi from hatchet_sdk.clients.rest.api.workflow_api import WorkflowApi from hatchet_sdk.clients.rest.api.workflow_run_api import WorkflowRunApi -from hatchet_sdk.clients.rest.api.default_api import DefaultApi - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/api_token_api.py b/python-sdk/hatchet_sdk/clients/rest/api/api_token_api.py index b2fc545af..983038748 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/api_token_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/api_token_api.py @@ -12,19 +12,22 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field -from typing import Optional +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.create_api_token_request import CreateAPITokenRequest -from hatchet_sdk.clients.rest.models.create_api_token_response import CreateAPITokenResponse -from hatchet_sdk.clients.rest.models.list_api_tokens_response import ListAPITokensResponse from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.create_api_token_request import ( + CreateAPITokenRequest, +) +from hatchet_sdk.clients.rest.models.create_api_token_response import ( + CreateAPITokenResponse, +) +from hatchet_sdk.clients.rest.models.list_api_tokens_response import ( + ListAPITokensResponse, +) from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -40,19 +43,22 @@ class APITokenApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def api_token_create( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], create_api_token_request: Optional[CreateAPITokenRequest] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -87,7 +93,7 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_create_serialize( tenant=tenant, @@ -95,17 +101,16 @@ class APITokenApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "CreateAPITokenResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "CreateAPITokenResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -113,19 +118,22 @@ class APITokenApi: response_types_map=_response_types_map, ).data - @validate_call def api_token_create_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], create_api_token_request: Optional[CreateAPITokenRequest] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -160,7 +168,7 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_create_serialize( tenant=tenant, @@ -168,17 +176,16 @@ class APITokenApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "CreateAPITokenResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "CreateAPITokenResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -186,19 +193,22 @@ class APITokenApi: response_types_map=_response_types_map, ) - @validate_call def api_token_create_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], create_api_token_request: Optional[CreateAPITokenRequest] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -233,7 +243,7 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_create_serialize( tenant=tenant, @@ -241,21 +251,19 @@ class APITokenApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "CreateAPITokenResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "CreateAPITokenResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _api_token_create_serialize( self, tenant, @@ -268,8 +276,7 @@ class APITokenApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -280,7 +287,7 @@ class APITokenApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters @@ -288,37 +295,27 @@ class APITokenApi: if create_api_token_request is not None: _body_params = create_api_token_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/tenants/{tenant}/api-tokens', + method="POST", + resource_path="/api/v1/tenants/{tenant}/api-tokens", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -328,23 +325,24 @@ class APITokenApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def api_token_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -377,24 +375,23 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListAPITokensResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "ListAPITokensResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -402,18 +399,21 @@ class APITokenApi: response_types_map=_response_types_map, ).data - @validate_call def api_token_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -446,24 +446,23 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListAPITokensResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "ListAPITokensResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -471,18 +470,21 @@ class APITokenApi: response_types_map=_response_types_map, ) - @validate_call def api_token_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -515,28 +517,26 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListAPITokensResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "ListAPITokensResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _api_token_list_serialize( self, tenant, @@ -548,8 +548,7 @@ class APITokenApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -560,30 +559,23 @@ class APITokenApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/api-tokens', + method="GET", + resource_path="/api/v1/tenants/{tenant}/api-tokens", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -593,23 +585,24 @@ class APITokenApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def api_token_update_revoke( self, - api_token: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The API token")], + api_token: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The API token" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -642,24 +635,23 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_update_revoke_serialize( api_token=api_token, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '403': "APIErrors", + "204": None, + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -667,18 +659,21 @@ class APITokenApi: response_types_map=_response_types_map, ).data - @validate_call def api_token_update_revoke_with_http_info( self, - api_token: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The API token")], + api_token: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The API token" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -711,24 +706,23 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_update_revoke_serialize( api_token=api_token, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '403': "APIErrors", + "204": None, + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -736,18 +730,21 @@ class APITokenApi: response_types_map=_response_types_map, ) - @validate_call def api_token_update_revoke_without_preload_content( self, - api_token: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The API token")], + api_token: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The API token" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -780,28 +777,26 @@ class APITokenApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._api_token_update_revoke_serialize( api_token=api_token, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '403': "APIErrors", + "204": None, + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _api_token_update_revoke_serialize( self, api_token, @@ -813,8 +808,7 @@ class APITokenApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -825,30 +819,23 @@ class APITokenApi: # process the path parameters if api_token is not None: - _path_params['api-token'] = api_token + _path_params["api-token"] = api_token # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/api-tokens/{api-token}', + method="POST", + resource_path="/api/v1/api-tokens/{api-token}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -858,7 +845,5 @@ class APITokenApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/default_api.py b/python-sdk/hatchet_sdk/clients/rest/api/default_api.py index 18c070165..aaa1bddf4 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/default_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/default_api.py @@ -12,17 +12,17 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.tenant_invite import TenantInvite -from hatchet_sdk.clients.rest.models.update_tenant_invite_request import UpdateTenantInviteRequest from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.tenant_invite import TenantInvite +from hatchet_sdk.clients.rest.models.update_tenant_invite_request import ( + UpdateTenantInviteRequest, +) from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -38,19 +38,30 @@ class DefaultApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def tenant_invite_delete( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - tenant_invite: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant invite id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + tenant_invite: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The tenant invite id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -85,7 +96,7 @@ class DefaultApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_delete_serialize( tenant=tenant, @@ -93,16 +104,15 @@ class DefaultApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInvite", - '400': "APIErrors", + "200": "TenantInvite", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -110,19 +120,30 @@ class DefaultApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_invite_delete_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - tenant_invite: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant invite id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + tenant_invite: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The tenant invite id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -157,7 +178,7 @@ class DefaultApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_delete_serialize( tenant=tenant, @@ -165,16 +186,15 @@ class DefaultApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInvite", - '400': "APIErrors", + "200": "TenantInvite", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -182,19 +202,30 @@ class DefaultApi: response_types_map=_response_types_map, ) - @validate_call def tenant_invite_delete_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - tenant_invite: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant invite id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + tenant_invite: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The tenant invite id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -229,7 +260,7 @@ class DefaultApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_delete_serialize( tenant=tenant, @@ -237,20 +268,18 @@ class DefaultApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInvite", - '400': "APIErrors", + "200": "TenantInvite", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_invite_delete_serialize( self, tenant, @@ -263,8 +292,7 @@ class DefaultApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -275,32 +303,25 @@ class DefaultApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if tenant_invite is not None: - _path_params['tenant-invite'] = tenant_invite + _path_params["tenant-invite"] = tenant_invite # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='DELETE', - resource_path='/api/v1/tenants/{tenant}/invites/{tenant-invite}', + method="DELETE", + resource_path="/api/v1/tenants/{tenant}/invites/{tenant-invite}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -310,25 +331,36 @@ class DefaultApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def tenant_invite_update( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - tenant_invite: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant invite id")], - update_tenant_invite_request: Annotated[UpdateTenantInviteRequest, Field(description="The tenant invite to update")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + tenant_invite: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The tenant invite id", + ), + ], + update_tenant_invite_request: Annotated[ + UpdateTenantInviteRequest, Field(description="The tenant invite to update") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -365,7 +397,7 @@ class DefaultApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_update_serialize( tenant=tenant, @@ -374,16 +406,15 @@ class DefaultApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInvite", - '400': "APIErrors", + "200": "TenantInvite", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -391,20 +422,33 @@ class DefaultApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_invite_update_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - tenant_invite: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant invite id")], - update_tenant_invite_request: Annotated[UpdateTenantInviteRequest, Field(description="The tenant invite to update")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + tenant_invite: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The tenant invite id", + ), + ], + update_tenant_invite_request: Annotated[ + UpdateTenantInviteRequest, Field(description="The tenant invite to update") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -441,7 +485,7 @@ class DefaultApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_update_serialize( tenant=tenant, @@ -450,16 +494,15 @@ class DefaultApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInvite", - '400': "APIErrors", + "200": "TenantInvite", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -467,20 +510,33 @@ class DefaultApi: response_types_map=_response_types_map, ) - @validate_call def tenant_invite_update_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - tenant_invite: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant invite id")], - update_tenant_invite_request: Annotated[UpdateTenantInviteRequest, Field(description="The tenant invite to update")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + tenant_invite: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The tenant invite id", + ), + ], + update_tenant_invite_request: Annotated[ + UpdateTenantInviteRequest, Field(description="The tenant invite to update") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -517,7 +573,7 @@ class DefaultApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_update_serialize( tenant=tenant, @@ -526,20 +582,18 @@ class DefaultApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInvite", - '400': "APIErrors", + "200": "TenantInvite", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_invite_update_serialize( self, tenant, @@ -553,8 +607,7 @@ class DefaultApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -565,9 +618,9 @@ class DefaultApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if tenant_invite is not None: - _path_params['tenant-invite'] = tenant_invite + _path_params["tenant-invite"] = tenant_invite # process the query parameters # process the header parameters # process the form parameters @@ -575,37 +628,27 @@ class DefaultApi: if update_tenant_invite_request is not None: _body_params = update_tenant_invite_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='PATCH', - resource_path='/api/v1/tenants/{tenant}/invites/{tenant-invite}', + method="PATCH", + resource_path="/api/v1/tenants/{tenant}/invites/{tenant-invite}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -615,7 +658,5 @@ class DefaultApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/event_api.py b/python-sdk/hatchet_sdk/clients/rest/api/event_api.py index 6b1a576e2..33342e0a5 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/event_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/event_api.py @@ -12,23 +12,22 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field, StrictInt, StrictStr -from typing import List, Optional +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.event_data import EventData -from hatchet_sdk.clients.rest.models.event_key_list import EventKeyList -from hatchet_sdk.clients.rest.models.event_list import EventList -from hatchet_sdk.clients.rest.models.event_order_by_direction import EventOrderByDirection -from hatchet_sdk.clients.rest.models.event_order_by_field import EventOrderByField -from hatchet_sdk.clients.rest.models.replay_event_request import ReplayEventRequest -from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.event_data import EventData +from hatchet_sdk.clients.rest.models.event_key_list import EventKeyList +from hatchet_sdk.clients.rest.models.event_list import EventList +from hatchet_sdk.clients.rest.models.event_order_by_direction import ( + EventOrderByDirection, +) +from hatchet_sdk.clients.rest.models.event_order_by_field import EventOrderByField +from hatchet_sdk.clients.rest.models.replay_event_request import ReplayEventRequest +from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -44,18 +43,21 @@ class EventApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def event_data_get( self, - event: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The event id")], + event: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The event id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -88,24 +90,23 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_data_get_serialize( event=event, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventData", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventData", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -113,18 +114,21 @@ class EventApi: response_types_map=_response_types_map, ).data - @validate_call def event_data_get_with_http_info( self, - event: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The event id")], + event: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The event id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -157,24 +161,23 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_data_get_serialize( event=event, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventData", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventData", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -182,18 +185,21 @@ class EventApi: response_types_map=_response_types_map, ) - @validate_call def event_data_get_without_preload_content( self, - event: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The event id")], + event: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The event id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -226,28 +232,26 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_data_get_serialize( event=event, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventData", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventData", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _event_data_get_serialize( self, event, @@ -259,8 +263,7 @@ class EventApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -271,30 +274,23 @@ class EventApi: # process the path parameters if event is not None: - _path_params['event'] = event + _path_params["event"] = event # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/events/{event}/data', + method="GET", + resource_path="/api/v1/events/{event}/data", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -304,23 +300,24 @@ class EventApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def event_key_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -353,24 +350,23 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_key_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventKeyList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventKeyList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -378,18 +374,21 @@ class EventApi: response_types_map=_response_types_map, ).data - @validate_call def event_key_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -422,24 +421,23 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_key_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventKeyList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventKeyList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -447,18 +445,21 @@ class EventApi: response_types_map=_response_types_map, ) - @validate_call def event_key_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -491,28 +492,26 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_key_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventKeyList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventKeyList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _event_key_list_serialize( self, tenant, @@ -524,8 +523,7 @@ class EventApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -536,30 +534,23 @@ class EventApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/events/keys', + method="GET", + resource_path="/api/v1/tenants/{tenant}/events/keys", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -569,31 +560,50 @@ class EventApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def event_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - keys: Annotated[Optional[List[StrictStr]], Field(description="A list of keys to filter by")] = None, - workflows: Annotated[Optional[List[StrictStr]], Field(description="A list of workflow IDs to filter by")] = None, - statuses: Annotated[Optional[List[WorkflowRunStatus]], Field(description="A list of workflow run statuses to filter by")] = None, - search: Annotated[Optional[StrictStr], Field(description="The search query to filter for")] = None, - order_by_field: Annotated[Optional[EventOrderByField], Field(description="What to order by")] = None, - order_by_direction: Annotated[Optional[EventOrderByDirection], Field(description="The order direction")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + keys: Annotated[ + Optional[List[StrictStr]], Field(description="A list of keys to filter by") + ] = None, + workflows: Annotated[ + Optional[List[StrictStr]], + Field(description="A list of workflow IDs to filter by"), + ] = None, + statuses: Annotated[ + Optional[List[WorkflowRunStatus]], + Field(description="A list of workflow run statuses to filter by"), + ] = None, + search: Annotated[ + Optional[StrictStr], Field(description="The search query to filter for") + ] = None, + order_by_field: Annotated[ + Optional[EventOrderByField], Field(description="What to order by") + ] = None, + order_by_direction: Annotated[ + Optional[EventOrderByDirection], Field(description="The order direction") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -642,7 +652,7 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_list_serialize( tenant=tenant, @@ -657,17 +667,16 @@ class EventApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -675,26 +684,47 @@ class EventApi: response_types_map=_response_types_map, ).data - @validate_call def event_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - keys: Annotated[Optional[List[StrictStr]], Field(description="A list of keys to filter by")] = None, - workflows: Annotated[Optional[List[StrictStr]], Field(description="A list of workflow IDs to filter by")] = None, - statuses: Annotated[Optional[List[WorkflowRunStatus]], Field(description="A list of workflow run statuses to filter by")] = None, - search: Annotated[Optional[StrictStr], Field(description="The search query to filter for")] = None, - order_by_field: Annotated[Optional[EventOrderByField], Field(description="What to order by")] = None, - order_by_direction: Annotated[Optional[EventOrderByDirection], Field(description="The order direction")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + keys: Annotated[ + Optional[List[StrictStr]], Field(description="A list of keys to filter by") + ] = None, + workflows: Annotated[ + Optional[List[StrictStr]], + Field(description="A list of workflow IDs to filter by"), + ] = None, + statuses: Annotated[ + Optional[List[WorkflowRunStatus]], + Field(description="A list of workflow run statuses to filter by"), + ] = None, + search: Annotated[ + Optional[StrictStr], Field(description="The search query to filter for") + ] = None, + order_by_field: Annotated[ + Optional[EventOrderByField], Field(description="What to order by") + ] = None, + order_by_direction: Annotated[ + Optional[EventOrderByDirection], Field(description="The order direction") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -743,7 +773,7 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_list_serialize( tenant=tenant, @@ -758,17 +788,16 @@ class EventApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -776,26 +805,47 @@ class EventApi: response_types_map=_response_types_map, ) - @validate_call def event_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - keys: Annotated[Optional[List[StrictStr]], Field(description="A list of keys to filter by")] = None, - workflows: Annotated[Optional[List[StrictStr]], Field(description="A list of workflow IDs to filter by")] = None, - statuses: Annotated[Optional[List[WorkflowRunStatus]], Field(description="A list of workflow run statuses to filter by")] = None, - search: Annotated[Optional[StrictStr], Field(description="The search query to filter for")] = None, - order_by_field: Annotated[Optional[EventOrderByField], Field(description="What to order by")] = None, - order_by_direction: Annotated[Optional[EventOrderByDirection], Field(description="The order direction")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + keys: Annotated[ + Optional[List[StrictStr]], Field(description="A list of keys to filter by") + ] = None, + workflows: Annotated[ + Optional[List[StrictStr]], + Field(description="A list of workflow IDs to filter by"), + ] = None, + statuses: Annotated[ + Optional[List[WorkflowRunStatus]], + Field(description="A list of workflow run statuses to filter by"), + ] = None, + search: Annotated[ + Optional[StrictStr], Field(description="The search query to filter for") + ] = None, + order_by_field: Annotated[ + Optional[EventOrderByField], Field(description="What to order by") + ] = None, + order_by_direction: Annotated[ + Optional[EventOrderByDirection], Field(description="The order direction") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -844,7 +894,7 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_list_serialize( tenant=tenant, @@ -859,21 +909,19 @@ class EventApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _event_list_serialize( self, tenant, @@ -894,9 +942,9 @@ class EventApi: _host = None _collection_formats: Dict[str, str] = { - 'keys': 'multi', - 'workflows': 'multi', - 'statuses': 'multi', + "keys": "multi", + "workflows": "multi", + "statuses": "multi", } _path_params: Dict[str, str] = {} @@ -908,62 +956,55 @@ class EventApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters if offset is not None: - - _query_params.append(('offset', offset)) - + + _query_params.append(("offset", offset)) + if limit is not None: - - _query_params.append(('limit', limit)) - + + _query_params.append(("limit", limit)) + if keys is not None: - - _query_params.append(('keys', keys)) - + + _query_params.append(("keys", keys)) + if workflows is not None: - - _query_params.append(('workflows', workflows)) - + + _query_params.append(("workflows", workflows)) + if statuses is not None: - - _query_params.append(('statuses', statuses)) - + + _query_params.append(("statuses", statuses)) + if search is not None: - - _query_params.append(('search', search)) - + + _query_params.append(("search", search)) + if order_by_field is not None: - - _query_params.append(('orderByField', order_by_field.value)) - + + _query_params.append(("orderByField", order_by_field.value)) + if order_by_direction is not None: - - _query_params.append(('orderByDirection', order_by_direction.value)) - + + _query_params.append(("orderByDirection", order_by_direction.value)) + # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/events', + method="GET", + resource_path="/api/v1/tenants/{tenant}/events", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -973,24 +1014,27 @@ class EventApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def event_update_replay( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - replay_event_request: Annotated[ReplayEventRequest, Field(description="The event ids to replay")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + replay_event_request: Annotated[ + ReplayEventRequest, Field(description="The event ids to replay") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1025,7 +1069,7 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_update_replay_serialize( tenant=tenant, @@ -1033,17 +1077,16 @@ class EventApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1051,19 +1094,24 @@ class EventApi: response_types_map=_response_types_map, ).data - @validate_call def event_update_replay_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - replay_event_request: Annotated[ReplayEventRequest, Field(description="The event ids to replay")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + replay_event_request: Annotated[ + ReplayEventRequest, Field(description="The event ids to replay") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1098,7 +1146,7 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_update_replay_serialize( tenant=tenant, @@ -1106,17 +1154,16 @@ class EventApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1124,19 +1171,24 @@ class EventApi: response_types_map=_response_types_map, ) - @validate_call def event_update_replay_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - replay_event_request: Annotated[ReplayEventRequest, Field(description="The event ids to replay")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + replay_event_request: Annotated[ + ReplayEventRequest, Field(description="The event ids to replay") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1171,7 +1223,7 @@ class EventApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._event_update_replay_serialize( tenant=tenant, @@ -1179,21 +1231,19 @@ class EventApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "EventList", - '400': "APIErrors", - '403': "APIErrors", + "200": "EventList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _event_update_replay_serialize( self, tenant, @@ -1206,8 +1256,7 @@ class EventApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1218,7 +1267,7 @@ class EventApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters @@ -1226,37 +1275,27 @@ class EventApi: if replay_event_request is not None: _body_params = replay_event_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/tenants/{tenant}/events/replay', + method="POST", + resource_path="/api/v1/tenants/{tenant}/events/replay", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1266,7 +1305,5 @@ class EventApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/github_api.py b/python-sdk/hatchet_sdk/clients/rest/api/github_api.py index 34e535df6..b6288828f 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/github_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/github_api.py @@ -12,18 +12,18 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field, StrictStr +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.github_branch import GithubBranch -from hatchet_sdk.clients.rest.models.github_repo import GithubRepo -from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ListGithubAppInstallationsResponse from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.github_branch import GithubBranch +from hatchet_sdk.clients.rest.models.github_repo import GithubRepo +from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ( + ListGithubAppInstallationsResponse, +) from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -39,20 +39,26 @@ class GithubApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def github_app_list_branches( self, - gh_installation: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The installation id")], + gh_installation: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The installation id", + ), + ], gh_repo_owner: Annotated[StrictStr, Field(description="The repository owner")], gh_repo_name: Annotated[StrictStr, Field(description="The repository name")], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -89,7 +95,7 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_branches_serialize( gh_installation=gh_installation, @@ -98,18 +104,17 @@ class GithubApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[GithubBranch]", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "List[GithubBranch]", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -117,20 +122,26 @@ class GithubApi: response_types_map=_response_types_map, ).data - @validate_call def github_app_list_branches_with_http_info( self, - gh_installation: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The installation id")], + gh_installation: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The installation id", + ), + ], gh_repo_owner: Annotated[StrictStr, Field(description="The repository owner")], gh_repo_name: Annotated[StrictStr, Field(description="The repository name")], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -167,7 +178,7 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_branches_serialize( gh_installation=gh_installation, @@ -176,18 +187,17 @@ class GithubApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[GithubBranch]", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "List[GithubBranch]", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -195,20 +205,26 @@ class GithubApi: response_types_map=_response_types_map, ) - @validate_call def github_app_list_branches_without_preload_content( self, - gh_installation: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The installation id")], + gh_installation: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The installation id", + ), + ], gh_repo_owner: Annotated[StrictStr, Field(description="The repository owner")], gh_repo_name: Annotated[StrictStr, Field(description="The repository name")], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -245,7 +261,7 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_branches_serialize( gh_installation=gh_installation, @@ -254,22 +270,20 @@ class GithubApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[GithubBranch]", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "List[GithubBranch]", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _github_app_list_branches_serialize( self, gh_installation, @@ -283,8 +297,7 @@ class GithubApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -295,33 +308,27 @@ class GithubApi: # process the path parameters if gh_installation is not None: - _path_params['gh-installation'] = gh_installation + _path_params["gh-installation"] = gh_installation if gh_repo_owner is not None: - _path_params['gh-repo-owner'] = gh_repo_owner + _path_params["gh-repo-owner"] = gh_repo_owner if gh_repo_name is not None: - _path_params['gh-repo-name'] = gh_repo_name + _path_params["gh-repo-name"] = gh_repo_name # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/github-app/installations/{gh-installation}/repos/{gh-repo-owner}/{gh-repo-name}/branches', + method="GET", + resource_path="/api/v1/github-app/installations/{gh-installation}/repos/{gh-repo-owner}/{gh-repo-name}/branches", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -331,12 +338,9 @@ class GithubApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def github_app_list_installations( self, @@ -344,9 +348,8 @@ class GithubApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -377,24 +380,23 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_installations_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListGithubAppInstallationsResponse", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "ListGithubAppInstallationsResponse", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -402,7 +404,6 @@ class GithubApi: response_types_map=_response_types_map, ).data - @validate_call def github_app_list_installations_with_http_info( self, @@ -410,9 +411,8 @@ class GithubApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -443,24 +443,23 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_installations_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListGithubAppInstallationsResponse", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "ListGithubAppInstallationsResponse", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -468,7 +467,6 @@ class GithubApi: response_types_map=_response_types_map, ) - @validate_call def github_app_list_installations_without_preload_content( self, @@ -476,9 +474,8 @@ class GithubApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -509,28 +506,26 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_installations_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListGithubAppInstallationsResponse", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "ListGithubAppInstallationsResponse", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _github_app_list_installations_serialize( self, _request_auth, @@ -541,8 +536,7 @@ class GithubApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -557,23 +551,17 @@ class GithubApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/github-app/installations', + method="GET", + resource_path="/api/v1/github-app/installations", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -583,23 +571,27 @@ class GithubApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def github_app_list_repos( self, - gh_installation: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The installation id")], + gh_installation: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The installation id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -632,25 +624,24 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_repos_serialize( gh_installation=gh_installation, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[GithubRepo]", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "List[GithubRepo]", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -658,18 +649,24 @@ class GithubApi: response_types_map=_response_types_map, ).data - @validate_call def github_app_list_repos_with_http_info( self, - gh_installation: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The installation id")], + gh_installation: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The installation id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -702,25 +699,24 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_repos_serialize( gh_installation=gh_installation, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[GithubRepo]", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "List[GithubRepo]", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -728,18 +724,24 @@ class GithubApi: response_types_map=_response_types_map, ) - @validate_call def github_app_list_repos_without_preload_content( self, - gh_installation: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The installation id")], + gh_installation: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The installation id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -772,29 +774,27 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_app_list_repos_serialize( gh_installation=gh_installation, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[GithubRepo]", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "List[GithubRepo]", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _github_app_list_repos_serialize( self, gh_installation, @@ -806,8 +806,7 @@ class GithubApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -818,29 +817,23 @@ class GithubApi: # process the path parameters if gh_installation is not None: - _path_params['gh-installation'] = gh_installation + _path_params["gh-installation"] = gh_installation # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/github-app/installations/{gh-installation}/repos', + method="GET", + resource_path="/api/v1/github-app/installations/{gh-installation}/repos", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -850,12 +843,9 @@ class GithubApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def github_update_global_webhook( self, @@ -863,9 +853,8 @@ class GithubApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -896,24 +885,23 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_update_global_webhook_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -921,7 +909,6 @@ class GithubApi: response_types_map=_response_types_map, ).data - @validate_call def github_update_global_webhook_with_http_info( self, @@ -929,9 +916,8 @@ class GithubApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -962,24 +948,23 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_update_global_webhook_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -987,7 +972,6 @@ class GithubApi: response_types_map=_response_types_map, ) - @validate_call def github_update_global_webhook_without_preload_content( self, @@ -995,9 +979,8 @@ class GithubApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1028,28 +1011,26 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_update_global_webhook_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _github_update_global_webhook_serialize( self, _request_auth, @@ -1060,8 +1041,7 @@ class GithubApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1076,22 +1056,17 @@ class GithubApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/github/webhook', + method="POST", + resource_path="/api/v1/github/webhook", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1101,23 +1076,24 @@ class GithubApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def github_update_tenant_webhook( self, - webhook: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The webhook id")], + webhook: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The webhook id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1150,25 +1126,24 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_update_tenant_webhook_serialize( webhook=webhook, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1176,18 +1151,21 @@ class GithubApi: response_types_map=_response_types_map, ).data - @validate_call def github_update_tenant_webhook_with_http_info( self, - webhook: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The webhook id")], + webhook: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The webhook id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1220,25 +1198,24 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_update_tenant_webhook_serialize( webhook=webhook, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1246,18 +1223,21 @@ class GithubApi: response_types_map=_response_types_map, ) - @validate_call def github_update_tenant_webhook_without_preload_content( self, - webhook: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The webhook id")], + webhook: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The webhook id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1290,29 +1270,27 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._github_update_tenant_webhook_serialize( webhook=webhook, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _github_update_tenant_webhook_serialize( self, webhook, @@ -1324,8 +1302,7 @@ class GithubApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1336,28 +1313,23 @@ class GithubApi: # process the path parameters if webhook is not None: - _path_params['webhook'] = webhook + _path_params["webhook"] = webhook # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/github/webhook/{webhook}', + method="POST", + resource_path="/api/v1/github/webhook/{webhook}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1367,24 +1339,30 @@ class GithubApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def sns_update( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - event: Annotated[str, Field(min_length=1, strict=True, max_length=255, description="The event key")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + event: Annotated[ + str, + Field( + min_length=1, strict=True, max_length=255, description="The event key" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1419,7 +1397,7 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_update_serialize( tenant=tenant, @@ -1427,18 +1405,17 @@ class GithubApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1446,19 +1423,27 @@ class GithubApi: response_types_map=_response_types_map, ).data - @validate_call def sns_update_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - event: Annotated[str, Field(min_length=1, strict=True, max_length=255, description="The event key")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + event: Annotated[ + str, + Field( + min_length=1, strict=True, max_length=255, description="The event key" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1493,7 +1478,7 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_update_serialize( tenant=tenant, @@ -1501,18 +1486,17 @@ class GithubApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1520,19 +1504,27 @@ class GithubApi: response_types_map=_response_types_map, ) - @validate_call def sns_update_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - event: Annotated[str, Field(min_length=1, strict=True, max_length=255, description="The event key")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + event: Annotated[ + str, + Field( + min_length=1, strict=True, max_length=255, description="The event key" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1567,7 +1559,7 @@ class GithubApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_update_serialize( tenant=tenant, @@ -1575,22 +1567,20 @@ class GithubApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _sns_update_serialize( self, tenant, @@ -1603,8 +1593,7 @@ class GithubApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1615,30 +1604,25 @@ class GithubApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if event is not None: - _path_params['event'] = event + _path_params["event"] = event # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/sns/{tenant}/{event}', + method="POST", + resource_path="/api/v1/sns/{tenant}/{event}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1648,7 +1632,5 @@ class GithubApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/healthcheck_api.py b/python-sdk/hatchet_sdk/clients/rest/api/healthcheck_api.py index 8fe018af0..a2bd12c68 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/healthcheck_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/healthcheck_api.py @@ -12,10 +12,10 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call +from typing_extensions import Annotated from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse @@ -34,7 +34,6 @@ class HealthcheckApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def liveness_get( self, @@ -42,9 +41,8 @@ class HealthcheckApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -75,22 +73,21 @@ class HealthcheckApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._liveness_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '500': None, + "200": None, + "500": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -98,7 +95,6 @@ class HealthcheckApi: response_types_map=_response_types_map, ).data - @validate_call def liveness_get_with_http_info( self, @@ -106,9 +102,8 @@ class HealthcheckApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -139,22 +134,21 @@ class HealthcheckApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._liveness_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '500': None, + "200": None, + "500": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -162,7 +156,6 @@ class HealthcheckApi: response_types_map=_response_types_map, ) - @validate_call def liveness_get_without_preload_content( self, @@ -170,9 +163,8 @@ class HealthcheckApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -203,26 +195,24 @@ class HealthcheckApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._liveness_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '500': None, + "200": None, + "500": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _liveness_get_serialize( self, _request_auth, @@ -233,8 +223,7 @@ class HealthcheckApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -249,16 +238,12 @@ class HealthcheckApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='GET', - resource_path='/api/live', + method="GET", + resource_path="/api/live", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -268,12 +253,9 @@ class HealthcheckApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def readiness_get( self, @@ -281,9 +263,8 @@ class HealthcheckApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -314,22 +295,21 @@ class HealthcheckApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._readiness_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '500': None, + "200": None, + "500": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -337,7 +317,6 @@ class HealthcheckApi: response_types_map=_response_types_map, ).data - @validate_call def readiness_get_with_http_info( self, @@ -345,9 +324,8 @@ class HealthcheckApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -378,22 +356,21 @@ class HealthcheckApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._readiness_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '500': None, + "200": None, + "500": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -401,7 +378,6 @@ class HealthcheckApi: response_types_map=_response_types_map, ) - @validate_call def readiness_get_without_preload_content( self, @@ -409,9 +385,8 @@ class HealthcheckApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -442,26 +417,24 @@ class HealthcheckApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._readiness_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '500': None, + "200": None, + "500": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _readiness_get_serialize( self, _request_auth, @@ -472,8 +445,7 @@ class HealthcheckApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -488,16 +460,12 @@ class HealthcheckApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='GET', - resource_path='/api/ready', + method="GET", + resource_path="/api/ready", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -507,7 +475,5 @@ class HealthcheckApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/log_api.py b/python-sdk/hatchet_sdk/clients/rest/api/log_api.py index 72bdf801c..43833d609 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/log_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/log_api.py @@ -12,20 +12,19 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field, StrictInt, StrictStr -from typing import List, Optional +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.log_line_level import LogLineLevel -from hatchet_sdk.clients.rest.models.log_line_list import LogLineList -from hatchet_sdk.clients.rest.models.log_line_order_by_direction import LogLineOrderByDirection -from hatchet_sdk.clients.rest.models.log_line_order_by_field import LogLineOrderByField from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.log_line_level import LogLineLevel +from hatchet_sdk.clients.rest.models.log_line_list import LogLineList +from hatchet_sdk.clients.rest.models.log_line_order_by_direction import ( + LogLineOrderByDirection, +) +from hatchet_sdk.clients.rest.models.log_line_order_by_field import LogLineOrderByField from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -41,24 +40,40 @@ class LogApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def log_line_list( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - levels: Annotated[Optional[List[LogLineLevel]], Field(description="A list of levels to filter by")] = None, - search: Annotated[Optional[StrictStr], Field(description="The search query to filter for")] = None, - order_by_field: Annotated[Optional[LogLineOrderByField], Field(description="What to order by")] = None, - order_by_direction: Annotated[Optional[LogLineOrderByDirection], Field(description="The order direction")] = None, + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + levels: Annotated[ + Optional[List[LogLineLevel]], + Field(description="A list of levels to filter by"), + ] = None, + search: Annotated[ + Optional[StrictStr], Field(description="The search query to filter for") + ] = None, + order_by_field: Annotated[ + Optional[LogLineOrderByField], Field(description="What to order by") + ] = None, + order_by_direction: Annotated[ + Optional[LogLineOrderByDirection], Field(description="The order direction") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -103,7 +118,7 @@ class LogApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._log_line_list_serialize( step_run=step_run, @@ -116,17 +131,16 @@ class LogApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "LogLineList", - '400': "APIErrors", - '403': "APIErrors", + "200": "LogLineList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -134,24 +148,40 @@ class LogApi: response_types_map=_response_types_map, ).data - @validate_call def log_line_list_with_http_info( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - levels: Annotated[Optional[List[LogLineLevel]], Field(description="A list of levels to filter by")] = None, - search: Annotated[Optional[StrictStr], Field(description="The search query to filter for")] = None, - order_by_field: Annotated[Optional[LogLineOrderByField], Field(description="What to order by")] = None, - order_by_direction: Annotated[Optional[LogLineOrderByDirection], Field(description="The order direction")] = None, + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + levels: Annotated[ + Optional[List[LogLineLevel]], + Field(description="A list of levels to filter by"), + ] = None, + search: Annotated[ + Optional[StrictStr], Field(description="The search query to filter for") + ] = None, + order_by_field: Annotated[ + Optional[LogLineOrderByField], Field(description="What to order by") + ] = None, + order_by_direction: Annotated[ + Optional[LogLineOrderByDirection], Field(description="The order direction") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -196,7 +226,7 @@ class LogApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._log_line_list_serialize( step_run=step_run, @@ -209,17 +239,16 @@ class LogApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "LogLineList", - '400': "APIErrors", - '403': "APIErrors", + "200": "LogLineList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -227,24 +256,40 @@ class LogApi: response_types_map=_response_types_map, ) - @validate_call def log_line_list_without_preload_content( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - levels: Annotated[Optional[List[LogLineLevel]], Field(description="A list of levels to filter by")] = None, - search: Annotated[Optional[StrictStr], Field(description="The search query to filter for")] = None, - order_by_field: Annotated[Optional[LogLineOrderByField], Field(description="What to order by")] = None, - order_by_direction: Annotated[Optional[LogLineOrderByDirection], Field(description="The order direction")] = None, + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + levels: Annotated[ + Optional[List[LogLineLevel]], + Field(description="A list of levels to filter by"), + ] = None, + search: Annotated[ + Optional[StrictStr], Field(description="The search query to filter for") + ] = None, + order_by_field: Annotated[ + Optional[LogLineOrderByField], Field(description="What to order by") + ] = None, + order_by_direction: Annotated[ + Optional[LogLineOrderByDirection], Field(description="The order direction") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -289,7 +334,7 @@ class LogApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._log_line_list_serialize( step_run=step_run, @@ -302,21 +347,19 @@ class LogApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "LogLineList", - '400': "APIErrors", - '403': "APIErrors", + "200": "LogLineList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _log_line_list_serialize( self, step_run, @@ -335,7 +378,7 @@ class LogApi: _host = None _collection_formats: Dict[str, str] = { - 'levels': 'multi', + "levels": "multi", } _path_params: Dict[str, str] = {} @@ -347,54 +390,47 @@ class LogApi: # process the path parameters if step_run is not None: - _path_params['step-run'] = step_run + _path_params["step-run"] = step_run # process the query parameters if offset is not None: - - _query_params.append(('offset', offset)) - + + _query_params.append(("offset", offset)) + if limit is not None: - - _query_params.append(('limit', limit)) - + + _query_params.append(("limit", limit)) + if levels is not None: - - _query_params.append(('levels', levels)) - + + _query_params.append(("levels", levels)) + if search is not None: - - _query_params.append(('search', search)) - + + _query_params.append(("search", search)) + if order_by_field is not None: - - _query_params.append(('orderByField', order_by_field.value)) - + + _query_params.append(("orderByField", order_by_field.value)) + if order_by_direction is not None: - - _query_params.append(('orderByDirection', order_by_direction.value)) - + + _query_params.append(("orderByDirection", order_by_direction.value)) + # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/step-runs/{step-run}/logs', + method="GET", + resource_path="/api/v1/step-runs/{step-run}/logs", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -404,7 +440,5 @@ class LogApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/metadata_api.py b/python-sdk/hatchet_sdk/clients/rest/api/metadata_api.py index 7b458ee6b..fa4c606d9 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/metadata_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/metadata_api.py @@ -12,15 +12,15 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.api_meta import APIMeta -from hatchet_sdk.clients.rest.models.api_meta_integration import APIMetaIntegration +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call +from typing_extensions import Annotated from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.api_meta import APIMeta +from hatchet_sdk.clients.rest.models.api_meta_integration import APIMetaIntegration from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -36,7 +36,6 @@ class MetadataApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def metadata_get( self, @@ -44,9 +43,8 @@ class MetadataApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -77,22 +75,21 @@ class MetadataApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._metadata_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "APIMeta", - '400': "APIErrors", + "200": "APIMeta", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -100,7 +97,6 @@ class MetadataApi: response_types_map=_response_types_map, ).data - @validate_call def metadata_get_with_http_info( self, @@ -108,9 +104,8 @@ class MetadataApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -141,22 +136,21 @@ class MetadataApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._metadata_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "APIMeta", - '400': "APIErrors", + "200": "APIMeta", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -164,7 +158,6 @@ class MetadataApi: response_types_map=_response_types_map, ) - @validate_call def metadata_get_without_preload_content( self, @@ -172,9 +165,8 @@ class MetadataApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -205,26 +197,24 @@ class MetadataApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._metadata_get_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "APIMeta", - '400': "APIErrors", + "200": "APIMeta", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _metadata_get_serialize( self, _request_auth, @@ -235,8 +225,7 @@ class MetadataApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -251,22 +240,17 @@ class MetadataApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/meta', + method="GET", + resource_path="/api/v1/meta", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -276,12 +260,9 @@ class MetadataApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def metadata_list_integrations( self, @@ -289,9 +270,8 @@ class MetadataApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -322,22 +302,21 @@ class MetadataApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._metadata_list_integrations_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[APIMetaIntegration]", - '400': "APIErrors", + "200": "List[APIMetaIntegration]", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -345,7 +324,6 @@ class MetadataApi: response_types_map=_response_types_map, ).data - @validate_call def metadata_list_integrations_with_http_info( self, @@ -353,9 +331,8 @@ class MetadataApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -386,22 +363,21 @@ class MetadataApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._metadata_list_integrations_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[APIMetaIntegration]", - '400': "APIErrors", + "200": "List[APIMetaIntegration]", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -409,7 +385,6 @@ class MetadataApi: response_types_map=_response_types_map, ) - @validate_call def metadata_list_integrations_without_preload_content( self, @@ -417,9 +392,8 @@ class MetadataApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -450,26 +424,24 @@ class MetadataApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._metadata_list_integrations_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "List[APIMetaIntegration]", - '400': "APIErrors", + "200": "List[APIMetaIntegration]", + "400": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _metadata_list_integrations_serialize( self, _request_auth, @@ -480,8 +452,7 @@ class MetadataApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -496,24 +467,17 @@ class MetadataApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/meta/integrations', + method="GET", + resource_path="/api/v1/meta/integrations", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -523,7 +487,5 @@ class MetadataApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/sns_api.py b/python-sdk/hatchet_sdk/clients/rest/api/sns_api.py index 191fb4d65..97a6fe5de 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/sns_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/sns_api.py @@ -12,19 +12,18 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field -from typing import Optional +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.create_sns_integration_request import CreateSNSIntegrationRequest -from hatchet_sdk.clients.rest.models.list_sns_integrations import ListSNSIntegrations -from hatchet_sdk.clients.rest.models.sns_integration import SNSIntegration from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.create_sns_integration_request import ( + CreateSNSIntegrationRequest, +) +from hatchet_sdk.clients.rest.models.list_sns_integrations import ListSNSIntegrations +from hatchet_sdk.clients.rest.models.sns_integration import SNSIntegration from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -40,19 +39,22 @@ class SNSApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def sns_create( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], create_sns_integration_request: Optional[CreateSNSIntegrationRequest] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -87,7 +89,7 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_create_serialize( tenant=tenant, @@ -95,18 +97,17 @@ class SNSApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '201': "SNSIntegration", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "201": "SNSIntegration", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -114,19 +115,22 @@ class SNSApi: response_types_map=_response_types_map, ).data - @validate_call def sns_create_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], create_sns_integration_request: Optional[CreateSNSIntegrationRequest] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -161,7 +165,7 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_create_serialize( tenant=tenant, @@ -169,18 +173,17 @@ class SNSApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '201': "SNSIntegration", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "201": "SNSIntegration", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -188,19 +191,22 @@ class SNSApi: response_types_map=_response_types_map, ) - @validate_call def sns_create_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], create_sns_integration_request: Optional[CreateSNSIntegrationRequest] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -235,7 +241,7 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_create_serialize( tenant=tenant, @@ -243,22 +249,20 @@ class SNSApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '201': "SNSIntegration", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "201": "SNSIntegration", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _sns_create_serialize( self, tenant, @@ -271,8 +275,7 @@ class SNSApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -283,7 +286,7 @@ class SNSApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters @@ -291,37 +294,27 @@ class SNSApi: if create_sns_integration_request is not None: _body_params = create_sns_integration_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/tenants/{tenant}/sns', + method="POST", + resource_path="/api/v1/tenants/{tenant}/sns", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -331,23 +324,27 @@ class SNSApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def sns_delete( self, - sns: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The SNS integration id")], + sns: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The SNS integration id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -380,25 +377,24 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_delete_serialize( sns=sns, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "204": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -406,18 +402,24 @@ class SNSApi: response_types_map=_response_types_map, ).data - @validate_call def sns_delete_with_http_info( self, - sns: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The SNS integration id")], + sns: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The SNS integration id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -450,25 +452,24 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_delete_serialize( sns=sns, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "204": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -476,18 +477,24 @@ class SNSApi: response_types_map=_response_types_map, ) - @validate_call def sns_delete_without_preload_content( self, - sns: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The SNS integration id")], + sns: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The SNS integration id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -520,29 +527,27 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_delete_serialize( sns=sns, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "204": None, + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _sns_delete_serialize( self, sns, @@ -554,8 +559,7 @@ class SNSApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -566,30 +570,23 @@ class SNSApi: # process the path parameters if sns is not None: - _path_params['sns'] = sns + _path_params["sns"] = sns # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='DELETE', - resource_path='/api/v1/sns/{sns}', + method="DELETE", + resource_path="/api/v1/sns/{sns}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -599,23 +596,24 @@ class SNSApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def sns_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -648,25 +646,24 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListSNSIntegrations", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "ListSNSIntegrations", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -674,18 +671,21 @@ class SNSApi: response_types_map=_response_types_map, ).data - @validate_call def sns_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -718,25 +718,24 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListSNSIntegrations", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "ListSNSIntegrations", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -744,18 +743,21 @@ class SNSApi: response_types_map=_response_types_map, ) - @validate_call def sns_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -788,29 +790,27 @@ class SNSApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._sns_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListSNSIntegrations", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "ListSNSIntegrations", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _sns_list_serialize( self, tenant, @@ -822,8 +822,7 @@ class SNSApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -834,30 +833,23 @@ class SNSApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/sns', + method="GET", + resource_path="/api/v1/tenants/{tenant}/sns", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -867,7 +859,5 @@ class SNSApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/step_run_api.py b/python-sdk/hatchet_sdk/clients/rest/api/step_run_api.py index d4477ec8a..77bd4ba66 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/step_run_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/step_run_api.py @@ -12,17 +12,15 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.rerun_step_run_request import RerunStepRunRequest -from hatchet_sdk.clients.rest.models.step_run import StepRun from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.rerun_step_run_request import RerunStepRunRequest +from hatchet_sdk.clients.rest.models.step_run import StepRun from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -38,19 +36,27 @@ class StepRunApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def step_run_get( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -85,7 +91,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_serialize( tenant=tenant, @@ -93,18 +99,17 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -112,19 +117,27 @@ class StepRunApi: response_types_map=_response_types_map, ).data - @validate_call def step_run_get_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -159,7 +172,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_serialize( tenant=tenant, @@ -167,18 +180,17 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -186,19 +198,27 @@ class StepRunApi: response_types_map=_response_types_map, ) - @validate_call def step_run_get_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -233,7 +253,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_serialize( tenant=tenant, @@ -241,22 +261,20 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _step_run_get_serialize( self, tenant, @@ -269,8 +287,7 @@ class StepRunApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -281,32 +298,25 @@ class StepRunApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if step_run is not None: - _path_params['step-run'] = step_run + _path_params["step-run"] = step_run # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/step-runs/{step-run}', + method="GET", + resource_path="/api/v1/tenants/{tenant}/step-runs/{step-run}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -316,24 +326,30 @@ class StepRunApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def step_run_get_schema( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -368,7 +384,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_schema_serialize( tenant=tenant, @@ -376,18 +392,17 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "object", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "object", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -395,19 +410,27 @@ class StepRunApi: response_types_map=_response_types_map, ).data - @validate_call def step_run_get_schema_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -442,7 +465,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_schema_serialize( tenant=tenant, @@ -450,18 +473,17 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "object", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "object", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -469,19 +491,27 @@ class StepRunApi: response_types_map=_response_types_map, ) - @validate_call def step_run_get_schema_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -516,7 +546,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_schema_serialize( tenant=tenant, @@ -524,22 +554,20 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "object", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "object", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _step_run_get_schema_serialize( self, tenant, @@ -552,8 +580,7 @@ class StepRunApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -564,32 +591,25 @@ class StepRunApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if step_run is not None: - _path_params['step-run'] = step_run + _path_params["step-run"] = step_run # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/step-runs/{step-run}/schema', + method="GET", + resource_path="/api/v1/tenants/{tenant}/step-runs/{step-run}/schema", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -599,24 +619,30 @@ class StepRunApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def step_run_update_cancel( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -651,7 +677,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_cancel_serialize( tenant=tenant, @@ -659,17 +685,16 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -677,19 +702,27 @@ class StepRunApi: response_types_map=_response_types_map, ).data - @validate_call def step_run_update_cancel_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -724,7 +757,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_cancel_serialize( tenant=tenant, @@ -732,17 +765,16 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -750,19 +782,27 @@ class StepRunApi: response_types_map=_response_types_map, ) - @validate_call def step_run_update_cancel_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -797,7 +837,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_cancel_serialize( tenant=tenant, @@ -805,21 +845,19 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _step_run_update_cancel_serialize( self, tenant, @@ -832,8 +870,7 @@ class StepRunApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -844,32 +881,25 @@ class StepRunApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if step_run is not None: - _path_params['step-run'] = step_run + _path_params["step-run"] = step_run # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/tenants/{tenant}/step-runs/{step-run}/cancel', + method="POST", + resource_path="/api/v1/tenants/{tenant}/step-runs/{step-run}/cancel", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -879,25 +909,33 @@ class StepRunApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def step_run_update_rerun( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - rerun_step_run_request: Annotated[RerunStepRunRequest, Field(description="The input to the rerun")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + rerun_step_run_request: Annotated[ + RerunStepRunRequest, Field(description="The input to the rerun") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -934,7 +972,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_rerun_serialize( tenant=tenant, @@ -943,17 +981,16 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -961,20 +998,30 @@ class StepRunApi: response_types_map=_response_types_map, ).data - @validate_call def step_run_update_rerun_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - rerun_step_run_request: Annotated[RerunStepRunRequest, Field(description="The input to the rerun")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + rerun_step_run_request: Annotated[ + RerunStepRunRequest, Field(description="The input to the rerun") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1011,7 +1058,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_rerun_serialize( tenant=tenant, @@ -1020,17 +1067,16 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1038,20 +1084,30 @@ class StepRunApi: response_types_map=_response_types_map, ) - @validate_call def step_run_update_rerun_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - rerun_step_run_request: Annotated[RerunStepRunRequest, Field(description="The input to the rerun")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + rerun_step_run_request: Annotated[ + RerunStepRunRequest, Field(description="The input to the rerun") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1088,7 +1144,7 @@ class StepRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_rerun_serialize( tenant=tenant, @@ -1097,21 +1153,19 @@ class StepRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "StepRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "StepRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _step_run_update_rerun_serialize( self, tenant, @@ -1125,8 +1179,7 @@ class StepRunApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1137,9 +1190,9 @@ class StepRunApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if step_run is not None: - _path_params['step-run'] = step_run + _path_params["step-run"] = step_run # process the query parameters # process the header parameters # process the form parameters @@ -1147,37 +1200,27 @@ class StepRunApi: if rerun_step_run_request is not None: _body_params = rerun_step_run_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/tenants/{tenant}/step-runs/{step-run}/rerun', + method="POST", + resource_path="/api/v1/tenants/{tenant}/step-runs/{step-run}/rerun", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1187,7 +1230,5 @@ class StepRunApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/tenant_api.py b/python-sdk/hatchet_sdk/clients/rest/api/tenant_api.py index 75319afe5..8a913d5ea 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/tenant_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/tenant_api.py @@ -12,24 +12,23 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union + +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from pydantic import Field -from typing import Optional -from typing_extensions import Annotated +from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized +from hatchet_sdk.clients.rest.api_response import ApiResponse from hatchet_sdk.clients.rest.models.accept_invite_request import AcceptInviteRequest -from hatchet_sdk.clients.rest.models.create_tenant_invite_request import CreateTenantInviteRequest +from hatchet_sdk.clients.rest.models.create_tenant_invite_request import ( + CreateTenantInviteRequest, +) from hatchet_sdk.clients.rest.models.create_tenant_request import CreateTenantRequest from hatchet_sdk.clients.rest.models.reject_invite_request import RejectInviteRequest from hatchet_sdk.clients.rest.models.tenant import Tenant from hatchet_sdk.clients.rest.models.tenant_invite import TenantInvite from hatchet_sdk.clients.rest.models.tenant_invite_list import TenantInviteList from hatchet_sdk.clients.rest.models.tenant_member_list import TenantMemberList - -from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized -from hatchet_sdk.clients.rest.api_response import ApiResponse from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -45,18 +44,18 @@ class TenantApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def tenant_create( self, - create_tenant_request: Annotated[CreateTenantRequest, Field(description="The tenant to create")], + create_tenant_request: Annotated[ + CreateTenantRequest, Field(description="The tenant to create") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -89,24 +88,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_create_serialize( create_tenant_request=create_tenant_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Tenant", - '400': "APIErrors", - '403': "APIError", + "200": "Tenant", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -114,18 +112,18 @@ class TenantApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_create_with_http_info( self, - create_tenant_request: Annotated[CreateTenantRequest, Field(description="The tenant to create")], + create_tenant_request: Annotated[ + CreateTenantRequest, Field(description="The tenant to create") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -158,24 +156,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_create_serialize( create_tenant_request=create_tenant_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Tenant", - '400': "APIErrors", - '403': "APIError", + "200": "Tenant", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -183,18 +180,18 @@ class TenantApi: response_types_map=_response_types_map, ) - @validate_call def tenant_create_without_preload_content( self, - create_tenant_request: Annotated[CreateTenantRequest, Field(description="The tenant to create")], + create_tenant_request: Annotated[ + CreateTenantRequest, Field(description="The tenant to create") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -227,28 +224,26 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_create_serialize( create_tenant_request=create_tenant_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Tenant", - '400': "APIErrors", - '403': "APIError", + "200": "Tenant", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_create_serialize( self, create_tenant_request, @@ -260,8 +255,7 @@ class TenantApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -278,37 +272,27 @@ class TenantApi: if create_tenant_request is not None: _body_params = create_tenant_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/tenants', + method="POST", + resource_path="/api/v1/tenants", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -318,12 +302,9 @@ class TenantApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def tenant_invite_accept( self, @@ -332,9 +313,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -367,24 +347,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_accept_serialize( accept_invite_request=accept_invite_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '403': "APIError", + "200": None, + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -392,7 +371,6 @@ class TenantApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_invite_accept_with_http_info( self, @@ -401,9 +379,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -436,24 +413,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_accept_serialize( accept_invite_request=accept_invite_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '403': "APIError", + "200": None, + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -461,7 +437,6 @@ class TenantApi: response_types_map=_response_types_map, ) - @validate_call def tenant_invite_accept_without_preload_content( self, @@ -470,9 +445,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -505,28 +479,26 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_accept_serialize( accept_invite_request=accept_invite_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '403': "APIError", + "200": None, + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_invite_accept_serialize( self, accept_invite_request, @@ -538,8 +510,7 @@ class TenantApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -556,37 +527,27 @@ class TenantApi: if accept_invite_request is not None: _body_params = accept_invite_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/users/invites/accept', + method="POST", + resource_path="/api/v1/users/invites/accept", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -596,24 +557,27 @@ class TenantApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def tenant_invite_create( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - create_tenant_invite_request: Annotated[CreateTenantInviteRequest, Field(description="The tenant invite to create")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + create_tenant_invite_request: Annotated[ + CreateTenantInviteRequest, Field(description="The tenant invite to create") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -648,7 +612,7 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_create_serialize( tenant=tenant, @@ -656,17 +620,16 @@ class TenantApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '201': "TenantInvite", - '400': "APIErrors", - '403': "APIError", + "201": "TenantInvite", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -674,19 +637,24 @@ class TenantApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_invite_create_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - create_tenant_invite_request: Annotated[CreateTenantInviteRequest, Field(description="The tenant invite to create")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + create_tenant_invite_request: Annotated[ + CreateTenantInviteRequest, Field(description="The tenant invite to create") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -721,7 +689,7 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_create_serialize( tenant=tenant, @@ -729,17 +697,16 @@ class TenantApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '201': "TenantInvite", - '400': "APIErrors", - '403': "APIError", + "201": "TenantInvite", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -747,19 +714,24 @@ class TenantApi: response_types_map=_response_types_map, ) - @validate_call def tenant_invite_create_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - create_tenant_invite_request: Annotated[CreateTenantInviteRequest, Field(description="The tenant invite to create")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + create_tenant_invite_request: Annotated[ + CreateTenantInviteRequest, Field(description="The tenant invite to create") + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -794,7 +766,7 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_create_serialize( tenant=tenant, @@ -802,21 +774,19 @@ class TenantApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '201': "TenantInvite", - '400': "APIErrors", - '403': "APIError", + "201": "TenantInvite", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_invite_create_serialize( self, tenant, @@ -829,8 +799,7 @@ class TenantApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -841,7 +810,7 @@ class TenantApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters @@ -849,37 +818,27 @@ class TenantApi: if create_tenant_invite_request is not None: _body_params = create_tenant_invite_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/tenants/{tenant}/invites', + method="POST", + resource_path="/api/v1/tenants/{tenant}/invites", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -889,23 +848,24 @@ class TenantApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def tenant_invite_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -938,24 +898,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInviteList", - '400': "APIErrors", - '403': "APIError", + "200": "TenantInviteList", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -963,18 +922,21 @@ class TenantApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_invite_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1007,24 +969,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInviteList", - '400': "APIErrors", - '403': "APIError", + "200": "TenantInviteList", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1032,18 +993,21 @@ class TenantApi: response_types_map=_response_types_map, ) - @validate_call def tenant_invite_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1076,28 +1040,26 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInviteList", - '400': "APIErrors", - '403': "APIError", + "200": "TenantInviteList", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_invite_list_serialize( self, tenant, @@ -1109,8 +1071,7 @@ class TenantApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1121,30 +1082,23 @@ class TenantApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/invites', + method="GET", + resource_path="/api/v1/tenants/{tenant}/invites", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1154,12 +1108,9 @@ class TenantApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def tenant_invite_reject( self, @@ -1168,9 +1119,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1203,24 +1153,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_reject_serialize( reject_invite_request=reject_invite_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '403': "APIError", + "200": None, + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1228,7 +1177,6 @@ class TenantApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_invite_reject_with_http_info( self, @@ -1237,9 +1185,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1272,24 +1219,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_reject_serialize( reject_invite_request=reject_invite_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '403': "APIError", + "200": None, + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1297,7 +1243,6 @@ class TenantApi: response_types_map=_response_types_map, ) - @validate_call def tenant_invite_reject_without_preload_content( self, @@ -1306,9 +1251,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1341,28 +1285,26 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_invite_reject_serialize( reject_invite_request=reject_invite_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': None, - '400': "APIErrors", - '403': "APIError", + "200": None, + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_invite_reject_serialize( self, reject_invite_request, @@ -1374,8 +1316,7 @@ class TenantApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1392,37 +1333,27 @@ class TenantApi: if reject_invite_request is not None: _body_params = reject_invite_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/users/invites/reject', + method="POST", + resource_path="/api/v1/users/invites/reject", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1432,23 +1363,24 @@ class TenantApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def tenant_member_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1481,24 +1413,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_member_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantMemberList", - '400': "APIErrors", - '403': "APIError", + "200": "TenantMemberList", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1506,18 +1437,21 @@ class TenantApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_member_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1550,24 +1484,23 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_member_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantMemberList", - '400': "APIErrors", - '403': "APIError", + "200": "TenantMemberList", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1575,18 +1508,21 @@ class TenantApi: response_types_map=_response_types_map, ) - @validate_call def tenant_member_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1619,28 +1555,26 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_member_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantMemberList", - '400': "APIErrors", - '403': "APIError", + "200": "TenantMemberList", + "400": "APIErrors", + "403": "APIError", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_member_list_serialize( self, tenant, @@ -1652,8 +1586,7 @@ class TenantApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1664,30 +1597,23 @@ class TenantApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/members', + method="GET", + resource_path="/api/v1/tenants/{tenant}/members", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1697,12 +1623,9 @@ class TenantApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_list_tenant_invites( self, @@ -1710,9 +1633,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1743,23 +1665,22 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_list_tenant_invites_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInviteList", - '400': "APIErrors", - '403': "APIErrors", + "200": "TenantInviteList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1767,7 +1688,6 @@ class TenantApi: response_types_map=_response_types_map, ).data - @validate_call def user_list_tenant_invites_with_http_info( self, @@ -1775,9 +1695,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1808,23 +1727,22 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_list_tenant_invites_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInviteList", - '400': "APIErrors", - '403': "APIErrors", + "200": "TenantInviteList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1832,7 +1750,6 @@ class TenantApi: response_types_map=_response_types_map, ) - @validate_call def user_list_tenant_invites_without_preload_content( self, @@ -1840,9 +1757,8 @@ class TenantApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1873,27 +1789,25 @@ class TenantApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_list_tenant_invites_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "TenantInviteList", - '400': "APIErrors", - '403': "APIErrors", + "200": "TenantInviteList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_list_tenant_invites_serialize( self, _request_auth, @@ -1904,8 +1818,7 @@ class TenantApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1920,23 +1833,17 @@ class TenantApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/invites', + method="GET", + resource_path="/api/v1/users/invites", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1946,7 +1853,5 @@ class TenantApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/user_api.py b/python-sdk/hatchet_sdk/clients/rest/api/user_api.py index befa2fe94..d73285d94 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/user_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/user_api.py @@ -12,19 +12,22 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from typing import Optional -from hatchet_sdk.clients.rest.models.user import User -from hatchet_sdk.clients.rest.models.user_change_password_request import UserChangePasswordRequest -from hatchet_sdk.clients.rest.models.user_login_request import UserLoginRequest -from hatchet_sdk.clients.rest.models.user_register_request import UserRegisterRequest -from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import UserTenantMembershipsList +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call +from typing_extensions import Annotated from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.user import User +from hatchet_sdk.clients.rest.models.user_change_password_request import ( + UserChangePasswordRequest, +) +from hatchet_sdk.clients.rest.models.user_login_request import UserLoginRequest +from hatchet_sdk.clients.rest.models.user_register_request import UserRegisterRequest +from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import ( + UserTenantMembershipsList, +) from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -40,7 +43,6 @@ class UserApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def tenant_memberships_list( self, @@ -48,9 +50,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -81,23 +82,22 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_memberships_list_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "UserTenantMembershipsList", - '400': "APIErrors", - '403': "APIErrors", + "200": "UserTenantMembershipsList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -105,7 +105,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def tenant_memberships_list_with_http_info( self, @@ -113,9 +112,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -146,23 +144,22 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_memberships_list_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "UserTenantMembershipsList", - '400': "APIErrors", - '403': "APIErrors", + "200": "UserTenantMembershipsList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -170,7 +167,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def tenant_memberships_list_without_preload_content( self, @@ -178,9 +174,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -211,27 +206,25 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._tenant_memberships_list_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "UserTenantMembershipsList", - '400': "APIErrors", - '403': "APIErrors", + "200": "UserTenantMembershipsList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _tenant_memberships_list_serialize( self, _request_auth, @@ -242,8 +235,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -258,23 +250,17 @@ class UserApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/memberships', + method="GET", + resource_path="/api/v1/users/memberships", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -284,12 +270,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_create( self, @@ -298,9 +281,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -333,25 +315,24 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_create_serialize( user_register_request=user_register_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -359,7 +340,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_create_with_http_info( self, @@ -368,9 +348,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -403,25 +382,24 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_create_serialize( user_register_request=user_register_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -429,7 +407,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_create_without_preload_content( self, @@ -438,9 +415,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -473,29 +449,27 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_create_serialize( user_register_request=user_register_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_create_serialize( self, user_register_request, @@ -507,8 +481,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -525,35 +498,27 @@ class UserApi: if user_register_request is not None: _body_params = user_register_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/users/register', + method="POST", + resource_path="/api/v1/users/register", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -563,12 +528,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_get_current( self, @@ -576,9 +538,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -609,24 +570,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_get_current_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -634,7 +594,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_get_current_with_http_info( self, @@ -642,9 +601,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -675,24 +633,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_get_current_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -700,7 +657,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_get_current_without_preload_content( self, @@ -708,9 +664,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -741,28 +696,26 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_get_current_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_get_current_serialize( self, _request_auth, @@ -773,8 +726,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -789,23 +741,17 @@ class UserApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/current', + method="GET", + resource_path="/api/v1/users/current", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -815,12 +761,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_github_app_oauth_callback( self, @@ -828,9 +771,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -861,21 +803,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_app_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -883,7 +824,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_github_app_oauth_callback_with_http_info( self, @@ -891,9 +831,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -924,21 +863,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_app_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -946,7 +884,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_github_app_oauth_callback_without_preload_content( self, @@ -954,9 +891,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -987,25 +923,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_app_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_github_app_oauth_callback_serialize( self, _request_auth, @@ -1016,8 +950,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1032,17 +965,12 @@ class UserApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/github-app/callback', + method="GET", + resource_path="/api/v1/users/github-app/callback", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1052,12 +980,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_github_app_oauth_start( self, @@ -1065,9 +990,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1098,21 +1022,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_app_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1120,7 +1043,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_github_app_oauth_start_with_http_info( self, @@ -1128,9 +1050,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1161,21 +1082,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_app_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1183,7 +1103,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_github_app_oauth_start_without_preload_content( self, @@ -1191,9 +1110,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1224,25 +1142,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_app_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_github_app_oauth_start_serialize( self, _request_auth, @@ -1253,8 +1169,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1269,17 +1184,12 @@ class UserApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/github-app/start', + method="GET", + resource_path="/api/v1/users/github-app/start", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1289,12 +1199,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_github_oauth_callback( self, @@ -1302,9 +1209,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1335,21 +1241,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1357,7 +1262,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_github_oauth_callback_with_http_info( self, @@ -1365,9 +1269,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1398,21 +1301,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1420,7 +1322,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_github_oauth_callback_without_preload_content( self, @@ -1428,9 +1329,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1461,25 +1361,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_github_oauth_callback_serialize( self, _request_auth, @@ -1490,8 +1388,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1506,16 +1403,12 @@ class UserApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/github/callback', + method="GET", + resource_path="/api/v1/users/github/callback", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1525,12 +1418,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_github_oauth_start( self, @@ -1538,9 +1428,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1571,21 +1460,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1593,7 +1481,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_github_oauth_start_with_http_info( self, @@ -1601,9 +1488,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1634,21 +1520,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1656,7 +1541,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_github_oauth_start_without_preload_content( self, @@ -1664,9 +1548,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1697,25 +1580,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_github_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_github_oauth_start_serialize( self, _request_auth, @@ -1726,8 +1607,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1742,16 +1622,12 @@ class UserApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/github/start', + method="GET", + resource_path="/api/v1/users/github/start", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1761,12 +1637,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_google_oauth_callback( self, @@ -1774,9 +1647,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1807,21 +1679,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_google_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1829,7 +1700,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_google_oauth_callback_with_http_info( self, @@ -1837,9 +1707,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1870,21 +1739,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_google_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1892,7 +1760,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_google_oauth_callback_without_preload_content( self, @@ -1900,9 +1767,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1933,25 +1799,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_google_oauth_callback_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_google_oauth_callback_serialize( self, _request_auth, @@ -1962,8 +1826,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1978,16 +1841,12 @@ class UserApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/google/callback', + method="GET", + resource_path="/api/v1/users/google/callback", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1997,12 +1856,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_google_oauth_start( self, @@ -2010,9 +1866,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2043,21 +1898,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_google_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2065,7 +1919,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_google_oauth_start_with_http_info( self, @@ -2073,9 +1926,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2106,21 +1958,20 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_google_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2128,7 +1979,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_google_oauth_start_without_preload_content( self, @@ -2136,9 +1986,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2169,25 +2018,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_google_oauth_start_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '302': None, + "302": None, } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_google_oauth_start_serialize( self, _request_auth, @@ -2198,8 +2045,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -2214,16 +2060,12 @@ class UserApi: # process the form parameters # process the body parameter - - - # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/users/google/start', + method="GET", + resource_path="/api/v1/users/google/start", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -2233,12 +2075,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_login( self, @@ -2247,9 +2086,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2282,25 +2120,24 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_login_serialize( user_login_request=user_login_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2308,7 +2145,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_login_with_http_info( self, @@ -2317,9 +2153,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2352,25 +2187,24 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_login_serialize( user_login_request=user_login_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2378,7 +2212,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_login_without_preload_content( self, @@ -2387,9 +2220,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2422,29 +2254,27 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_login_serialize( user_login_request=user_login_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_login_serialize( self, user_login_request, @@ -2456,8 +2286,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -2474,35 +2303,27 @@ class UserApi: if user_login_request is not None: _body_params = user_login_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - ] + _auth_settings: List[str] = [] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/users/login', + method="POST", + resource_path="/api/v1/users/login", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -2512,12 +2333,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_logout( self, @@ -2525,9 +2343,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2558,24 +2375,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_logout_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2583,7 +2399,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_logout_with_http_info( self, @@ -2591,9 +2406,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2624,24 +2438,23 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_logout_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2649,7 +2462,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_logout_without_preload_content( self, @@ -2657,9 +2469,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2690,28 +2501,26 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_logout_serialize( _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_logout_serialize( self, _request_auth, @@ -2722,8 +2531,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -2738,23 +2546,17 @@ class UserApi: # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/users/logout', + method="POST", + resource_path="/api/v1/users/logout", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -2764,12 +2566,9 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def user_update_password( self, @@ -2778,9 +2577,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2813,25 +2611,24 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_password_serialize( user_change_password_request=user_change_password_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2839,7 +2636,6 @@ class UserApi: response_types_map=_response_types_map, ).data - @validate_call def user_update_password_with_http_info( self, @@ -2848,9 +2644,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2883,25 +2678,24 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_password_serialize( user_change_password_request=user_change_password_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2909,7 +2703,6 @@ class UserApi: response_types_map=_response_types_map, ) - @validate_call def user_update_password_without_preload_content( self, @@ -2918,9 +2711,8 @@ class UserApi: None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2953,29 +2745,27 @@ class UserApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._user_update_password_serialize( user_change_password_request=user_change_password_request, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "User", - '400': "APIErrors", - '401': "APIErrors", - '405': "APIErrors", + "200": "User", + "400": "APIErrors", + "401": "APIErrors", + "405": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _user_update_password_serialize( self, user_change_password_request, @@ -2987,8 +2777,7 @@ class UserApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -3005,36 +2794,27 @@ class UserApi: if user_change_password_request is not None: _body_params = user_change_password_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth' - ] + _auth_settings: List[str] = ["cookieAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/users/password', + method="POST", + resource_path="/api/v1/users/password", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -3044,7 +2824,5 @@ class UserApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/worker_api.py b/python-sdk/hatchet_sdk/clients/rest/api/worker_api.py index a81ab38b4..265c7631c 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/worker_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/worker_api.py @@ -12,17 +12,15 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.worker import Worker -from hatchet_sdk.clients.rest.models.worker_list import WorkerList from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.worker import Worker +from hatchet_sdk.clients.rest.models.worker_list import WorkerList from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -38,18 +36,21 @@ class WorkerApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def worker_get( self, - worker: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The worker id")], + worker: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The worker id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -82,24 +83,23 @@ class WorkerApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._worker_get_serialize( worker=worker, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Worker", - '400': "APIErrors", - '403': "APIErrors", + "200": "Worker", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -107,18 +107,21 @@ class WorkerApi: response_types_map=_response_types_map, ).data - @validate_call def worker_get_with_http_info( self, - worker: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The worker id")], + worker: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The worker id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -151,24 +154,23 @@ class WorkerApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._worker_get_serialize( worker=worker, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Worker", - '400': "APIErrors", - '403': "APIErrors", + "200": "Worker", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -176,18 +178,21 @@ class WorkerApi: response_types_map=_response_types_map, ) - @validate_call def worker_get_without_preload_content( self, - worker: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The worker id")], + worker: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The worker id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -220,28 +225,26 @@ class WorkerApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._worker_get_serialize( worker=worker, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Worker", - '400': "APIErrors", - '403': "APIErrors", + "200": "Worker", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _worker_get_serialize( self, worker, @@ -253,8 +256,7 @@ class WorkerApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -265,30 +267,23 @@ class WorkerApi: # process the path parameters if worker is not None: - _path_params['worker'] = worker + _path_params["worker"] = worker # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/workers/{worker}', + method="GET", + resource_path="/api/v1/workers/{worker}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -298,23 +293,24 @@ class WorkerApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def worker_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -347,24 +343,23 @@ class WorkerApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._worker_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkerList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkerList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -372,18 +367,21 @@ class WorkerApi: response_types_map=_response_types_map, ).data - @validate_call def worker_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -416,24 +414,23 @@ class WorkerApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._worker_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkerList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkerList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -441,18 +438,21 @@ class WorkerApi: response_types_map=_response_types_map, ) - @validate_call def worker_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -485,28 +485,26 @@ class WorkerApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._worker_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkerList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkerList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _worker_list_serialize( self, tenant, @@ -518,8 +516,7 @@ class WorkerApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -530,30 +527,23 @@ class WorkerApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/worker', + method="GET", + resource_path="/api/v1/tenants/{tenant}/worker", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -563,7 +553,5 @@ class WorkerApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/workflow_api.py b/python-sdk/hatchet_sdk/clients/rest/api/workflow_api.py index 6a7949142..1439ad57d 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/workflow_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/workflow_api.py @@ -12,17 +12,25 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union + +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from pydantic import Field, StrictInt, StrictStr -from typing import Optional -from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import CreatePullRequestFromStepRun -from hatchet_sdk.clients.rest.models.get_step_run_diff_response import GetStepRunDiffResponse -from hatchet_sdk.clients.rest.models.link_github_repository_request import LinkGithubRepositoryRequest -from hatchet_sdk.clients.rest.models.list_pull_requests_response import ListPullRequestsResponse +from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized +from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import ( + CreatePullRequestFromStepRun, +) +from hatchet_sdk.clients.rest.models.get_step_run_diff_response import ( + GetStepRunDiffResponse, +) +from hatchet_sdk.clients.rest.models.link_github_repository_request import ( + LinkGithubRepositoryRequest, +) +from hatchet_sdk.clients.rest.models.list_pull_requests_response import ( + ListPullRequestsResponse, +) from hatchet_sdk.clients.rest.models.pull_request_state import PullRequestState from hatchet_sdk.clients.rest.models.workflow import Workflow from hatchet_sdk.clients.rest.models.workflow_list import WorkflowList @@ -31,10 +39,9 @@ from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun from hatchet_sdk.clients.rest.models.workflow_run_list import WorkflowRunList from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus from hatchet_sdk.clients.rest.models.workflow_version import WorkflowVersion -from hatchet_sdk.clients.rest.models.workflow_version_definition import WorkflowVersionDefinition - -from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized -from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.workflow_version_definition import ( + WorkflowVersionDefinition, +) from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -50,18 +57,21 @@ class WorkflowApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def step_run_get_diff( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -94,25 +104,24 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_diff_serialize( step_run=step_run, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "GetStepRunDiffResponse", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "GetStepRunDiffResponse", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -120,18 +129,21 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def step_run_get_diff_with_http_info( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -164,25 +176,24 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_diff_serialize( step_run=step_run, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "GetStepRunDiffResponse", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "GetStepRunDiffResponse", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -190,18 +201,21 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def step_run_get_diff_without_preload_content( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -234,29 +248,27 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_get_diff_serialize( step_run=step_run, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "GetStepRunDiffResponse", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "GetStepRunDiffResponse", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _step_run_get_diff_serialize( self, step_run, @@ -268,8 +280,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -280,30 +291,23 @@ class WorkflowApi: # process the path parameters if step_run is not None: - _path_params['step-run'] = step_run + _path_params["step-run"] = step_run # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/step-runs/{step-run}/diff', + method="GET", + resource_path="/api/v1/step-runs/{step-run}/diff", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -313,24 +317,28 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def step_run_update_create_pr( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - create_pull_request_from_step_run: Annotated[CreatePullRequestFromStepRun, Field(description="The input to create a pull request")], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + create_pull_request_from_step_run: Annotated[ + CreatePullRequestFromStepRun, + Field(description="The input to create a pull request"), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -365,7 +373,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_create_pr_serialize( step_run=step_run, @@ -373,18 +381,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "CreatePullRequestFromStepRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "CreatePullRequestFromStepRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -392,19 +399,25 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def step_run_update_create_pr_with_http_info( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - create_pull_request_from_step_run: Annotated[CreatePullRequestFromStepRun, Field(description="The input to create a pull request")], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + create_pull_request_from_step_run: Annotated[ + CreatePullRequestFromStepRun, + Field(description="The input to create a pull request"), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -439,7 +452,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_create_pr_serialize( step_run=step_run, @@ -447,18 +460,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "CreatePullRequestFromStepRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "CreatePullRequestFromStepRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -466,19 +478,25 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def step_run_update_create_pr_without_preload_content( self, - step_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The step run id")], - create_pull_request_from_step_run: Annotated[CreatePullRequestFromStepRun, Field(description="The input to create a pull request")], + step_run: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The step run id" + ), + ], + create_pull_request_from_step_run: Annotated[ + CreatePullRequestFromStepRun, + Field(description="The input to create a pull request"), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -513,7 +531,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._step_run_update_create_pr_serialize( step_run=step_run, @@ -521,22 +539,20 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "CreatePullRequestFromStepRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "CreatePullRequestFromStepRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _step_run_update_create_pr_serialize( self, step_run, @@ -549,8 +565,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -561,7 +576,7 @@ class WorkflowApi: # process the path parameters if step_run is not None: - _path_params['step-run'] = step_run + _path_params["step-run"] = step_run # process the query parameters # process the header parameters # process the form parameters @@ -569,37 +584,27 @@ class WorkflowApi: if create_pull_request_from_step_run is not None: _body_params = create_pull_request_from_step_run - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/step-runs/{step-run}/create-pr', + method="POST", + resource_path="/api/v1/step-runs/{step-run}/create-pr", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -609,23 +614,24 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_delete( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -658,25 +664,24 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_delete_serialize( workflow=workflow, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "204": None, + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -684,18 +689,21 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_delete_with_http_info( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -728,25 +736,24 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_delete_serialize( workflow=workflow, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "204": None, + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -754,18 +761,21 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_delete_without_preload_content( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -798,29 +808,27 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_delete_serialize( workflow=workflow, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '204': None, - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "204": None, + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_delete_serialize( self, workflow, @@ -832,8 +840,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -844,30 +851,23 @@ class WorkflowApi: # process the path parameters if workflow is not None: - _path_params['workflow'] = workflow + _path_params["workflow"] = workflow # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='DELETE', - resource_path='/api/v1/workflows/{workflow}', + method="DELETE", + resource_path="/api/v1/workflows/{workflow}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -877,23 +877,24 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_get( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -926,24 +927,23 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_get_serialize( workflow=workflow, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Workflow", - '400': "APIErrors", - '403': "APIErrors", + "200": "Workflow", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -951,18 +951,21 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_get_with_http_info( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -995,24 +998,23 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_get_serialize( workflow=workflow, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Workflow", - '400': "APIErrors", - '403': "APIErrors", + "200": "Workflow", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1020,18 +1022,21 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_get_without_preload_content( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1064,28 +1069,26 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_get_serialize( workflow=workflow, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Workflow", - '400': "APIErrors", - '403': "APIErrors", + "200": "Workflow", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_get_serialize( self, workflow, @@ -1097,8 +1100,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1109,30 +1111,23 @@ class WorkflowApi: # process the path parameters if workflow is not None: - _path_params['workflow'] = workflow + _path_params["workflow"] = workflow # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/workflows/{workflow}', + method="GET", + resource_path="/api/v1/workflows/{workflow}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1142,25 +1137,31 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_get_metrics( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - status: Annotated[Optional[WorkflowRunStatus], Field(description="A status of workflow runs to filter by")] = None, - group_key: Annotated[Optional[StrictStr], Field(description="A group key to filter metrics by")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + status: Annotated[ + Optional[WorkflowRunStatus], + Field(description="A status of workflow runs to filter by"), + ] = None, + group_key: Annotated[ + Optional[StrictStr], Field(description="A group key to filter metrics by") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1197,7 +1198,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_get_metrics_serialize( workflow=workflow, @@ -1206,18 +1207,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowMetrics", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowMetrics", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1225,20 +1225,28 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_get_metrics_with_http_info( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - status: Annotated[Optional[WorkflowRunStatus], Field(description="A status of workflow runs to filter by")] = None, - group_key: Annotated[Optional[StrictStr], Field(description="A group key to filter metrics by")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + status: Annotated[ + Optional[WorkflowRunStatus], + Field(description="A status of workflow runs to filter by"), + ] = None, + group_key: Annotated[ + Optional[StrictStr], Field(description="A group key to filter metrics by") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1275,7 +1283,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_get_metrics_serialize( workflow=workflow, @@ -1284,18 +1292,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowMetrics", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowMetrics", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1303,20 +1310,28 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_get_metrics_without_preload_content( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - status: Annotated[Optional[WorkflowRunStatus], Field(description="A status of workflow runs to filter by")] = None, - group_key: Annotated[Optional[StrictStr], Field(description="A group key to filter metrics by")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + status: Annotated[ + Optional[WorkflowRunStatus], + Field(description="A status of workflow runs to filter by"), + ] = None, + group_key: Annotated[ + Optional[StrictStr], Field(description="A group key to filter metrics by") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1353,7 +1368,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_get_metrics_serialize( workflow=workflow, @@ -1362,22 +1377,20 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowMetrics", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowMetrics", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_get_metrics_serialize( self, workflow, @@ -1391,8 +1404,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1403,38 +1415,31 @@ class WorkflowApi: # process the path parameters if workflow is not None: - _path_params['workflow'] = workflow + _path_params["workflow"] = workflow # process the query parameters if status is not None: - - _query_params.append(('status', status.value)) - + + _query_params.append(("status", status.value)) + if group_key is not None: - - _query_params.append(('groupKey', group_key)) - + + _query_params.append(("groupKey", group_key)) + # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/workflows/{workflow}/metrics', + method="GET", + resource_path="/api/v1/workflows/{workflow}/metrics", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1444,23 +1449,24 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1493,24 +1499,23 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1518,18 +1523,21 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1562,24 +1570,23 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1587,18 +1594,21 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1631,28 +1641,26 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_list_serialize( tenant=tenant, _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_list_serialize( self, tenant, @@ -1664,8 +1672,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1676,30 +1683,23 @@ class WorkflowApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/workflows', + method="GET", + resource_path="/api/v1/tenants/{tenant}/workflows", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1709,24 +1709,33 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_run_get( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - workflow_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + workflow_run: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The workflow run id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1761,7 +1770,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_get_serialize( tenant=tenant, @@ -1769,17 +1778,16 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1787,19 +1795,30 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_run_get_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - workflow_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + workflow_run: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The workflow run id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1834,7 +1853,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_get_serialize( tenant=tenant, @@ -1842,17 +1861,16 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -1860,19 +1878,30 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_run_get_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - workflow_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow run id")], + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + workflow_run: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The workflow run id", + ), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -1907,7 +1936,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_get_serialize( tenant=tenant, @@ -1915,21 +1944,19 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRun", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowRun", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_run_get_serialize( self, tenant, @@ -1942,8 +1969,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -1954,32 +1980,25 @@ class WorkflowApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if workflow_run is not None: - _path_params['workflow-run'] = workflow_run + _path_params["workflow-run"] = workflow_run # process the query parameters # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/workflow-runs/{workflow-run}', + method="GET", + resource_path="/api/v1/tenants/{tenant}/workflow-runs/{workflow-run}", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -1989,29 +2008,46 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_run_list( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - event_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The event id to get runs for.")] = None, - workflow_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow id to get runs for.")] = None, - parent_workflow_run_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The parent workflow run id")] = None, - parent_step_run_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The parent step run id")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + event_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The event id to get runs for."), + ] = None, + workflow_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The workflow id to get runs for."), + ] = None, + parent_workflow_run_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The parent workflow run id"), + ] = None, + parent_step_run_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The parent step run id"), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2056,7 +2092,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_list_serialize( tenant=tenant, @@ -2069,17 +2105,16 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRunList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowRunList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2087,24 +2122,43 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_run_list_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - event_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The event id to get runs for.")] = None, - workflow_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow id to get runs for.")] = None, - parent_workflow_run_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The parent workflow run id")] = None, - parent_step_run_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The parent step run id")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + event_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The event id to get runs for."), + ] = None, + workflow_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The workflow id to get runs for."), + ] = None, + parent_workflow_run_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The parent workflow run id"), + ] = None, + parent_step_run_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The parent step run id"), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2149,7 +2203,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_list_serialize( tenant=tenant, @@ -2162,17 +2216,16 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRunList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowRunList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2180,24 +2233,43 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_run_list_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - offset: Annotated[Optional[StrictInt], Field(description="The number to skip")] = None, - limit: Annotated[Optional[StrictInt], Field(description="The number to limit by")] = None, - event_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The event id to get runs for.")] = None, - workflow_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow id to get runs for.")] = None, - parent_workflow_run_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The parent workflow run id")] = None, - parent_step_run_id: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The parent step run id")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + offset: Annotated[ + Optional[StrictInt], Field(description="The number to skip") + ] = None, + limit: Annotated[ + Optional[StrictInt], Field(description="The number to limit by") + ] = None, + event_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The event id to get runs for."), + ] = None, + workflow_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The workflow id to get runs for."), + ] = None, + parent_workflow_run_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The parent workflow run id"), + ] = None, + parent_step_run_id: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field(description="The parent step run id"), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2242,7 +2314,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_list_serialize( tenant=tenant, @@ -2255,21 +2327,19 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRunList", - '400': "APIErrors", - '403': "APIErrors", + "200": "WorkflowRunList", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_run_list_serialize( self, tenant, @@ -2287,8 +2357,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -2299,54 +2368,47 @@ class WorkflowApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant # process the query parameters if offset is not None: - - _query_params.append(('offset', offset)) - + + _query_params.append(("offset", offset)) + if limit is not None: - - _query_params.append(('limit', limit)) - + + _query_params.append(("limit", limit)) + if event_id is not None: - - _query_params.append(('eventId', event_id)) - + + _query_params.append(("eventId", event_id)) + if workflow_id is not None: - - _query_params.append(('workflowId', workflow_id)) - + + _query_params.append(("workflowId", workflow_id)) + if parent_workflow_run_id is not None: - - _query_params.append(('parentWorkflowRunId', parent_workflow_run_id)) - + + _query_params.append(("parentWorkflowRunId", parent_workflow_run_id)) + if parent_step_run_id is not None: - - _query_params.append(('parentStepRunId', parent_step_run_id)) - + + _query_params.append(("parentStepRunId", parent_step_run_id)) + # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/workflows/runs', + method="GET", + resource_path="/api/v1/tenants/{tenant}/workflows/runs", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -2356,25 +2418,36 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_run_list_pull_requests( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - workflow_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow run id")], - state: Annotated[Optional[PullRequestState], Field(description="The pull request state")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + workflow_run: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The workflow run id", + ), + ], + state: Annotated[ + Optional[PullRequestState], Field(description="The pull request state") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2411,7 +2484,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_list_pull_requests_serialize( tenant=tenant, @@ -2420,17 +2493,16 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListPullRequestsResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "ListPullRequestsResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2438,20 +2510,33 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_run_list_pull_requests_with_http_info( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - workflow_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow run id")], - state: Annotated[Optional[PullRequestState], Field(description="The pull request state")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + workflow_run: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The workflow run id", + ), + ], + state: Annotated[ + Optional[PullRequestState], Field(description="The pull request state") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2488,7 +2573,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_list_pull_requests_serialize( tenant=tenant, @@ -2497,17 +2582,16 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListPullRequestsResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "ListPullRequestsResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2515,20 +2599,33 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_run_list_pull_requests_without_preload_content( self, - tenant: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The tenant id")], - workflow_run: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow run id")], - state: Annotated[Optional[PullRequestState], Field(description="The pull request state")] = None, + tenant: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The tenant id" + ), + ], + workflow_run: Annotated[ + str, + Field( + min_length=36, + strict=True, + max_length=36, + description="The workflow run id", + ), + ], + state: Annotated[ + Optional[PullRequestState], Field(description="The pull request state") + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2565,7 +2662,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_list_pull_requests_serialize( tenant=tenant, @@ -2574,21 +2671,19 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "ListPullRequestsResponse", - '400': "APIErrors", - '403': "APIErrors", + "200": "ListPullRequestsResponse", + "400": "APIErrors", + "403": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_run_list_pull_requests_serialize( self, tenant, @@ -2602,8 +2697,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -2614,36 +2708,29 @@ class WorkflowApi: # process the path parameters if tenant is not None: - _path_params['tenant'] = tenant + _path_params["tenant"] = tenant if workflow_run is not None: - _path_params['workflow-run'] = workflow_run + _path_params["workflow-run"] = workflow_run # process the query parameters if state is not None: - - _query_params.append(('state', state.value)) - + + _query_params.append(("state", state.value)) + # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/tenants/{tenant}/workflow-runs/{workflow-run}/prs', + method="GET", + resource_path="/api/v1/tenants/{tenant}/workflow-runs/{workflow-run}/prs", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -2653,24 +2740,28 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_update_link_github( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - link_github_repository_request: Annotated[LinkGithubRepositoryRequest, Field(description="The input to link a github repository")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + link_github_repository_request: Annotated[ + LinkGithubRepositoryRequest, + Field(description="The input to link a github repository"), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2705,7 +2796,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_update_link_github_serialize( workflow=workflow, @@ -2713,18 +2804,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Workflow", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "Workflow", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2732,19 +2822,25 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_update_link_github_with_http_info( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - link_github_repository_request: Annotated[LinkGithubRepositoryRequest, Field(description="The input to link a github repository")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + link_github_repository_request: Annotated[ + LinkGithubRepositoryRequest, + Field(description="The input to link a github repository"), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2779,7 +2875,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_update_link_github_serialize( workflow=workflow, @@ -2787,18 +2883,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Workflow", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "Workflow", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -2806,19 +2901,25 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_update_link_github_without_preload_content( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - link_github_repository_request: Annotated[LinkGithubRepositoryRequest, Field(description="The input to link a github repository")], + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + link_github_repository_request: Annotated[ + LinkGithubRepositoryRequest, + Field(description="The input to link a github repository"), + ], _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -2853,7 +2954,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_update_link_github_serialize( workflow=workflow, @@ -2861,22 +2962,20 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "Workflow", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "Workflow", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_update_link_github_serialize( self, workflow, @@ -2889,8 +2988,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -2901,7 +2999,7 @@ class WorkflowApi: # process the path parameters if workflow is not None: - _path_params['workflow'] = workflow + _path_params["workflow"] = workflow # process the query parameters # process the header parameters # process the form parameters @@ -2909,37 +3007,27 @@ class WorkflowApi: if link_github_repository_request is not None: _body_params = link_github_repository_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/workflows/{workflow}/link-github', + method="POST", + resource_path="/api/v1/workflows/{workflow}/link-github", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -2949,24 +3037,30 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_version_get( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -3001,7 +3095,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_version_get_serialize( workflow=workflow, @@ -3009,18 +3103,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowVersion", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowVersion", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -3028,19 +3121,27 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_version_get_with_http_info( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -3075,7 +3176,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_version_get_serialize( workflow=workflow, @@ -3083,18 +3184,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowVersion", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowVersion", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -3102,19 +3202,27 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_version_get_without_preload_content( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -3149,7 +3257,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_version_get_serialize( workflow=workflow, @@ -3157,22 +3265,20 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowVersion", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowVersion", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_version_get_serialize( self, workflow, @@ -3185,8 +3291,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -3197,34 +3302,27 @@ class WorkflowApi: # process the path parameters if workflow is not None: - _path_params['workflow'] = workflow + _path_params["workflow"] = workflow # process the query parameters if version is not None: - - _query_params.append(('version', version)) - + + _query_params.append(("version", version)) + # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/workflows/{workflow}/versions', + method="GET", + resource_path="/api/v1/workflows/{workflow}/versions", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -3234,24 +3332,30 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - - @validate_call def workflow_version_get_definition( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -3286,7 +3390,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_version_get_definition_serialize( workflow=workflow, @@ -3294,18 +3398,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowVersionDefinition", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowVersionDefinition", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -3313,19 +3416,27 @@ class WorkflowApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_version_get_definition_with_http_info( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -3360,7 +3471,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_version_get_definition_serialize( workflow=workflow, @@ -3368,18 +3479,17 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowVersionDefinition", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowVersionDefinition", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -3387,19 +3497,27 @@ class WorkflowApi: response_types_map=_response_types_map, ) - @validate_call def workflow_version_get_definition_without_preload_content( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -3434,7 +3552,7 @@ class WorkflowApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_version_get_definition_serialize( workflow=workflow, @@ -3442,22 +3560,20 @@ class WorkflowApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowVersionDefinition", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowVersionDefinition", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_version_get_definition_serialize( self, workflow, @@ -3470,8 +3586,7 @@ class WorkflowApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -3482,34 +3597,27 @@ class WorkflowApi: # process the path parameters if workflow is not None: - _path_params['workflow'] = workflow + _path_params["workflow"] = workflow # process the query parameters if version is not None: - - _query_params.append(('version', version)) - + + _query_params.append(("version", version)) + # process the header parameters # process the form parameters # process the body parameter - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) - # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='GET', - resource_path='/api/v1/workflows/{workflow}/versions/definition', + method="GET", + resource_path="/api/v1/workflows/{workflow}/versions/definition", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -3519,7 +3627,5 @@ class WorkflowApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api/workflow_run_api.py b/python-sdk/hatchet_sdk/clients/rest/api/workflow_run_api.py index 382381a3d..e41d90584 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api/workflow_run_api.py +++ b/python-sdk/hatchet_sdk/clients/rest/api/workflow_run_api.py @@ -12,18 +12,17 @@ """ # noqa: E501 import warnings -from pydantic import validate_call, Field, StrictFloat, StrictStr, StrictInt from typing import Any, Dict, List, Optional, Tuple, Union -from typing_extensions import Annotated -from pydantic import Field -from typing import Optional +from pydantic import Field, StrictFloat, StrictInt, StrictStr, validate_call from typing_extensions import Annotated -from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import TriggerWorkflowRunRequest -from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun from hatchet_sdk.clients.rest.api_client import ApiClient, RequestSerialized from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import ( + TriggerWorkflowRunRequest, +) +from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun from hatchet_sdk.clients.rest.rest import RESTResponseType @@ -39,20 +38,31 @@ class WorkflowRunApi: api_client = ApiClient.get_default() self.api_client = api_client - @validate_call def workflow_run_create( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - trigger_workflow_run_request: Annotated[TriggerWorkflowRunRequest, Field(description="The input to the workflow run")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + trigger_workflow_run_request: Annotated[ + TriggerWorkflowRunRequest, + Field(description="The input to the workflow run"), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -89,7 +99,7 @@ class WorkflowRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_create_serialize( workflow=workflow, @@ -98,18 +108,17 @@ class WorkflowRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -117,20 +126,31 @@ class WorkflowRunApi: response_types_map=_response_types_map, ).data - @validate_call def workflow_run_create_with_http_info( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - trigger_workflow_run_request: Annotated[TriggerWorkflowRunRequest, Field(description="The input to the workflow run")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + trigger_workflow_run_request: Annotated[ + TriggerWorkflowRunRequest, + Field(description="The input to the workflow run"), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -167,7 +187,7 @@ class WorkflowRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_create_serialize( workflow=workflow, @@ -176,18 +196,17 @@ class WorkflowRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) response_data.read() return self.api_client.response_deserialize( @@ -195,20 +214,31 @@ class WorkflowRunApi: response_types_map=_response_types_map, ) - @validate_call def workflow_run_create_without_preload_content( self, - workflow: Annotated[str, Field(min_length=36, strict=True, max_length=36, description="The workflow id")], - trigger_workflow_run_request: Annotated[TriggerWorkflowRunRequest, Field(description="The input to the workflow run")], - version: Annotated[Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], Field(description="The workflow version. If not supplied, the latest version is fetched.")] = None, + workflow: Annotated[ + str, + Field( + min_length=36, strict=True, max_length=36, description="The workflow id" + ), + ], + trigger_workflow_run_request: Annotated[ + TriggerWorkflowRunRequest, + Field(description="The input to the workflow run"), + ], + version: Annotated[ + Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]], + Field( + description="The workflow version. If not supplied, the latest version is fetched." + ), + ] = None, _request_timeout: Union[ None, Annotated[StrictFloat, Field(gt=0)], Tuple[ - Annotated[StrictFloat, Field(gt=0)], - Annotated[StrictFloat, Field(gt=0)] - ] + Annotated[StrictFloat, Field(gt=0)], Annotated[StrictFloat, Field(gt=0)] + ], ] = None, _request_auth: Optional[Dict[StrictStr, Any]] = None, _content_type: Optional[StrictStr] = None, @@ -245,7 +275,7 @@ class WorkflowRunApi: in the spec for a single request. :type _host_index: int, optional :return: Returns the result object. - """ # noqa: E501 + """ # noqa: E501 _param = self._workflow_run_create_serialize( workflow=workflow, @@ -254,22 +284,20 @@ class WorkflowRunApi: _request_auth=_request_auth, _content_type=_content_type, _headers=_headers, - _host_index=_host_index + _host_index=_host_index, ) _response_types_map: Dict[str, Optional[str]] = { - '200': "WorkflowRun", - '400': "APIErrors", - '403': "APIErrors", - '404': "APIErrors", + "200": "WorkflowRun", + "400": "APIErrors", + "403": "APIErrors", + "404": "APIErrors", } response_data = self.api_client.call_api( - *_param, - _request_timeout=_request_timeout + *_param, _request_timeout=_request_timeout ) return response_data.response - def _workflow_run_create_serialize( self, workflow, @@ -283,8 +311,7 @@ class WorkflowRunApi: _host = None - _collection_formats: Dict[str, str] = { - } + _collection_formats: Dict[str, str] = {} _path_params: Dict[str, str] = {} _query_params: List[Tuple[str, str]] = [] @@ -295,49 +322,39 @@ class WorkflowRunApi: # process the path parameters if workflow is not None: - _path_params['workflow'] = workflow + _path_params["workflow"] = workflow # process the query parameters if version is not None: - - _query_params.append(('version', version)) - + + _query_params.append(("version", version)) + # process the header parameters # process the form parameters # process the body parameter if trigger_workflow_run_request is not None: _body_params = trigger_workflow_run_request - # set the HTTP header `Accept` - _header_params['Accept'] = self.api_client.select_header_accept( - [ - 'application/json' - ] + _header_params["Accept"] = self.api_client.select_header_accept( + ["application/json"] ) # set the HTTP header `Content-Type` if _content_type: - _header_params['Content-Type'] = _content_type + _header_params["Content-Type"] = _content_type else: - _default_content_type = ( - self.api_client.select_header_content_type( - [ - 'application/json' - ] - ) + _default_content_type = self.api_client.select_header_content_type( + ["application/json"] ) if _default_content_type is not None: - _header_params['Content-Type'] = _default_content_type + _header_params["Content-Type"] = _default_content_type # authentication setting - _auth_settings: List[str] = [ - 'cookieAuth', - 'bearerAuth' - ] + _auth_settings: List[str] = ["cookieAuth", "bearerAuth"] return self.api_client.param_serialize( - method='POST', - resource_path='/api/v1/workflows/{workflow}/trigger', + method="POST", + resource_path="/api/v1/workflows/{workflow}/trigger", path_params=_path_params, query_params=_query_params, header_params=_header_params, @@ -347,7 +364,5 @@ class WorkflowRunApi: auth_settings=_auth_settings, collection_formats=_collection_formats, _host=_host, - _request_auth=_request_auth + _request_auth=_request_auth, ) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/api_client.py b/python-sdk/hatchet_sdk/clients/rest/api_client.py index 29d2e9946..7051c17de 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api_client.py +++ b/python-sdk/hatchet_sdk/clients/rest/api_client.py @@ -13,33 +13,35 @@ import datetime -from dateutil.parser import parse -from enum import Enum import json import mimetypes import os import re import tempfile - +from enum import Enum +from typing import Dict, List, Optional, Tuple from urllib.parse import quote -from typing import Tuple, Optional, List, Dict -from hatchet_sdk.clients.rest.configuration import Configuration -from hatchet_sdk.clients.rest.api_response import ApiResponse, T as ApiResponseT +from dateutil.parser import parse + import hatchet_sdk.clients.rest.models from hatchet_sdk.clients.rest import rest +from hatchet_sdk.clients.rest.api_response import ApiResponse +from hatchet_sdk.clients.rest.api_response import T as ApiResponseT +from hatchet_sdk.clients.rest.configuration import Configuration from hatchet_sdk.clients.rest.exceptions import ( - ApiValueError, ApiException, + ApiValueError, BadRequestException, - UnauthorizedException, ForbiddenException, NotFoundException, - ServiceException + ServiceException, + UnauthorizedException, ) RequestSerialized = Tuple[str, str, Dict[str, str], Optional[str], List[str]] + class ApiClient: """Generic API client for OpenAPI client library builds. @@ -58,23 +60,19 @@ class ApiClient: PRIMITIVE_TYPES = (float, bool, bytes, str, int) NATIVE_TYPES_MAPPING = { - 'int': int, - 'long': int, # TODO remove as only py3 is supported? - 'float': float, - 'str': str, - 'bool': bool, - 'date': datetime.date, - 'datetime': datetime.datetime, - 'object': object, + "int": int, + "long": int, # TODO remove as only py3 is supported? + "float": float, + "str": str, + "bool": bool, + "date": datetime.date, + "datetime": datetime.datetime, + "object": object, } _pool = None def __init__( - self, - configuration=None, - header_name=None, - header_value=None, - cookie=None + self, configuration=None, header_name=None, header_value=None, cookie=None ) -> None: # use default configuration if none is provided if configuration is None: @@ -87,7 +85,7 @@ class ApiClient: self.default_headers[header_name] = header_value self.cookie = cookie # Set default User-Agent. - self.user_agent = 'OpenAPI-Generator/1.0.0/python' + self.user_agent = "OpenAPI-Generator/1.0.0/python" self.client_side_validation = configuration.client_side_validation def __enter__(self): @@ -99,16 +97,15 @@ class ApiClient: @property def user_agent(self): """User agent for this API client""" - return self.default_headers['User-Agent'] + return self.default_headers["User-Agent"] @user_agent.setter def user_agent(self, value): - self.default_headers['User-Agent'] = value + self.default_headers["User-Agent"] = value def set_default_header(self, header_name, header_value): self.default_headers[header_name] = header_value - _default = None @classmethod @@ -144,12 +141,12 @@ class ApiClient: header_params=None, body=None, post_params=None, - files=None, auth_settings=None, + files=None, + auth_settings=None, collection_formats=None, _host=None, - _request_auth=None + _request_auth=None, ) -> RequestSerialized: - """Builds the HTTP request params needed by the request. :param method: Method to call. :param resource_path: Path to method endpoint. @@ -178,35 +175,28 @@ class ApiClient: header_params = header_params or {} header_params.update(self.default_headers) if self.cookie: - header_params['Cookie'] = self.cookie + header_params["Cookie"] = self.cookie if header_params: header_params = self.sanitize_for_serialization(header_params) header_params = dict( - self.parameters_to_tuples(header_params,collection_formats) + self.parameters_to_tuples(header_params, collection_formats) ) # path parameters if path_params: path_params = self.sanitize_for_serialization(path_params) - path_params = self.parameters_to_tuples( - path_params, - collection_formats - ) + path_params = self.parameters_to_tuples(path_params, collection_formats) for k, v in path_params: # specified safe chars, encode everything resource_path = resource_path.replace( - '{%s}' % k, - quote(str(v), safe=config.safe_chars_for_path_param) + "{%s}" % k, quote(str(v), safe=config.safe_chars_for_path_param) ) # post parameters if post_params or files: post_params = post_params if post_params else [] post_params = self.sanitize_for_serialization(post_params) - post_params = self.parameters_to_tuples( - post_params, - collection_formats - ) + post_params = self.parameters_to_tuples(post_params, collection_formats) post_params.extend(self.files_parameters(files)) # auth setting @@ -217,7 +207,7 @@ class ApiClient: resource_path, method, body, - request_auth=_request_auth + request_auth=_request_auth, ) # body @@ -234,15 +224,11 @@ class ApiClient: # query parameters if query_params: query_params = self.sanitize_for_serialization(query_params) - url_query = self.parameters_to_url_query( - query_params, - collection_formats - ) + url_query = self.parameters_to_url_query(query_params, collection_formats) url += "?" + url_query return method, url, header_params, body, post_params - def call_api( self, method, @@ -250,7 +236,7 @@ class ApiClient: header_params=None, body=None, post_params=None, - _request_timeout=None + _request_timeout=None, ) -> rest.RESTResponse: """Makes the HTTP request (synchronous) :param method: Method to call. @@ -267,10 +253,12 @@ class ApiClient: try: # perform request and return response response_data = self.rest_client.request( - method, url, + method, + url, headers=header_params, - body=body, post_params=post_params, - _request_timeout=_request_timeout + body=body, + post_params=post_params, + _request_timeout=_request_timeout, ) except ApiException as e: @@ -281,7 +269,7 @@ class ApiClient: def response_deserialize( self, response_data: rest.RESTResponse, - response_types_map: Optional[Dict[str, ApiResponseT]]=None + response_types_map: Optional[Dict[str, ApiResponseT]] = None, ) -> ApiResponse[ApiResponseT]: """Deserializes response into an object. :param response_data: RESTResponse object to be deserialized. @@ -293,9 +281,15 @@ class ApiClient: assert response_data.data is not None, msg response_type = response_types_map.get(str(response_data.status), None) - if not response_type and isinstance(response_data.status, int) and 100 <= response_data.status <= 599: + if ( + not response_type + and isinstance(response_data.status, int) + and 100 <= response_data.status <= 599 + ): # if not found, look for '1XX', '2XX', etc. - response_type = response_types_map.get(str(response_data.status)[0] + "XX", None) + response_type = response_types_map.get( + str(response_data.status)[0] + "XX", None + ) # deserialize response data response_text = None @@ -307,7 +301,7 @@ class ApiClient: return_data = self.__deserialize_file(response_data) elif response_type is not None: match = None - content_type = response_data.getheader('content-type') + content_type = response_data.getheader("content-type") if content_type is not None: match = re.search(r"charset=([a-zA-Z\-\d]+)[\s;]?", content_type) encoding = match.group(1) if match else "utf-8" @@ -322,10 +316,10 @@ class ApiClient: ) return ApiResponse( - status_code = response_data.status, - data = return_data, - headers = response_data.getheaders(), - raw_data = response_data.data + status_code=response_data.status, + data=return_data, + headers=response_data.getheaders(), + raw_data=response_data.data, ) def sanitize_for_serialization(self, obj): @@ -347,13 +341,9 @@ class ApiClient: elif isinstance(obj, self.PRIMITIVE_TYPES): return obj elif isinstance(obj, list): - return [ - self.sanitize_for_serialization(sub_obj) for sub_obj in obj - ] + return [self.sanitize_for_serialization(sub_obj) for sub_obj in obj] elif isinstance(obj, tuple): - return tuple( - self.sanitize_for_serialization(sub_obj) for sub_obj in obj - ) + return tuple(self.sanitize_for_serialization(sub_obj) for sub_obj in obj) elif isinstance(obj, (datetime.datetime, datetime.date)): return obj.isoformat() @@ -368,8 +358,7 @@ class ApiClient: obj_dict = obj.to_dict() return { - key: self.sanitize_for_serialization(val) - for key, val in obj_dict.items() + key: self.sanitize_for_serialization(val) for key, val in obj_dict.items() } def deserialize(self, response_text, response_type): @@ -402,19 +391,17 @@ class ApiClient: return None if isinstance(klass, str): - if klass.startswith('List['): - m = re.match(r'List\[(.*)]', klass) + if klass.startswith("List["): + m = re.match(r"List\[(.*)]", klass) assert m is not None, "Malformed List type definition" sub_kls = m.group(1) - return [self.__deserialize(sub_data, sub_kls) - for sub_data in data] + return [self.__deserialize(sub_data, sub_kls) for sub_data in data] - if klass.startswith('Dict['): - m = re.match(r'Dict\[([^,]*), (.*)]', klass) + if klass.startswith("Dict["): + m = re.match(r"Dict\[([^,]*), (.*)]", klass) assert m is not None, "Malformed Dict type definition" sub_kls = m.group(2) - return {k: self.__deserialize(v, sub_kls) - for k, v in data.items()} + return {k: self.__deserialize(v, sub_kls) for k, v in data.items()} # convert str to class if klass in self.NATIVE_TYPES_MAPPING: @@ -448,19 +435,18 @@ class ApiClient: for k, v in params.items() if isinstance(params, dict) else params: if k in collection_formats: collection_format = collection_formats[k] - if collection_format == 'multi': + if collection_format == "multi": new_params.extend((k, value) for value in v) else: - if collection_format == 'ssv': - delimiter = ' ' - elif collection_format == 'tsv': - delimiter = '\t' - elif collection_format == 'pipes': - delimiter = '|' + if collection_format == "ssv": + delimiter = " " + elif collection_format == "tsv": + delimiter = "\t" + elif collection_format == "pipes": + delimiter = "|" else: # csv is the default - delimiter = ',' - new_params.append( - (k, delimiter.join(str(value) for value in v))) + delimiter = "," + new_params.append((k, delimiter.join(str(value) for value in v))) else: new_params.append((k, v)) return new_params @@ -485,17 +471,17 @@ class ApiClient: if k in collection_formats: collection_format = collection_formats[k] - if collection_format == 'multi': + if collection_format == "multi": new_params.extend((k, str(value)) for value in v) else: - if collection_format == 'ssv': - delimiter = ' ' - elif collection_format == 'tsv': - delimiter = '\t' - elif collection_format == 'pipes': - delimiter = '|' + if collection_format == "ssv": + delimiter = " " + elif collection_format == "tsv": + delimiter = "\t" + elif collection_format == "pipes": + delimiter = "|" else: # csv is the default - delimiter = ',' + delimiter = "," new_params.append( (k, delimiter.join(quote(str(value)) for value in v)) ) @@ -518,16 +504,14 @@ class ApiClient: continue file_names = v if type(v) is list else [v] for n in file_names: - with open(n, 'rb') as f: + with open(n, "rb") as f: filename = os.path.basename(f.name) filedata = f.read() mimetype = ( mimetypes.guess_type(filename)[0] - or 'application/octet-stream' - ) - params.append( - tuple([k, tuple([filename, filedata, mimetype])]) + or "application/octet-stream" ) + params.append(tuple([k, tuple([filename, filedata, mimetype])])) return params @@ -541,7 +525,7 @@ class ApiClient: return None for accept in accepts: - if re.search('json', accept, re.IGNORECASE): + if re.search("json", accept, re.IGNORECASE): return accept return accepts[0] @@ -556,7 +540,7 @@ class ApiClient: return None for content_type in content_types: - if re.search('json', content_type, re.IGNORECASE): + if re.search("json", content_type, re.IGNORECASE): return content_type return content_types[0] @@ -569,7 +553,7 @@ class ApiClient: resource_path, method, body, - request_auth=None + request_auth=None, ) -> None: """Updates header and query params based on authentication setting. @@ -588,34 +572,18 @@ class ApiClient: if request_auth: self._apply_auth_params( - headers, - queries, - resource_path, - method, - body, - request_auth + headers, queries, resource_path, method, body, request_auth ) else: for auth in auth_settings: auth_setting = self.configuration.auth_settings().get(auth) if auth_setting: self._apply_auth_params( - headers, - queries, - resource_path, - method, - body, - auth_setting + headers, queries, resource_path, method, body, auth_setting ) def _apply_auth_params( - self, - headers, - queries, - resource_path, - method, - body, - auth_setting + self, headers, queries, resource_path, method, body, auth_setting ) -> None: """Updates the request parameters based on a single auth_setting @@ -627,17 +595,15 @@ class ApiClient: The object type is the return value of sanitize_for_serialization(). :param auth_setting: auth settings for the endpoint """ - if auth_setting['in'] == 'cookie': - headers['Cookie'] = auth_setting['value'] - elif auth_setting['in'] == 'header': - if auth_setting['type'] != 'http-signature': - headers[auth_setting['key']] = auth_setting['value'] - elif auth_setting['in'] == 'query': - queries.append((auth_setting['key'], auth_setting['value'])) + if auth_setting["in"] == "cookie": + headers["Cookie"] = auth_setting["value"] + elif auth_setting["in"] == "header": + if auth_setting["type"] != "http-signature": + headers[auth_setting["key"]] = auth_setting["value"] + elif auth_setting["in"] == "query": + queries.append((auth_setting["key"], auth_setting["value"])) else: - raise ApiValueError( - 'Authentication token must be in `query` or `header`' - ) + raise ApiValueError("Authentication token must be in `query` or `header`") def __deserialize_file(self, response): """Deserializes body to file @@ -657,10 +623,7 @@ class ApiClient: content_disposition = response.getheader("Content-Disposition") if content_disposition: - m = re.search( - r'filename=[\'"]?([^\'"\s]+)[\'"]?', - content_disposition - ) + m = re.search(r'filename=[\'"]?([^\'"\s]+)[\'"]?', content_disposition) assert m is not None, "Unexpected 'content-disposition' header value" filename = m.group(1) path = os.path.join(os.path.dirname(path), filename) @@ -704,8 +667,7 @@ class ApiClient: return string except ValueError: raise rest.ApiException( - status=0, - reason="Failed to parse `{0}` as date object".format(string) + status=0, reason="Failed to parse `{0}` as date object".format(string) ) def __deserialize_datetime(self, string): @@ -723,10 +685,7 @@ class ApiClient: except ValueError: raise rest.ApiException( status=0, - reason=( - "Failed to parse `{0}` as datetime object" - .format(string) - ) + reason=("Failed to parse `{0}` as datetime object".format(string)), ) def __deserialize_enum(self, data, klass): @@ -740,11 +699,7 @@ class ApiClient: return klass(data) except ValueError: raise rest.ApiException( - status=0, - reason=( - "Failed to parse `{0}` as `{1}`" - .format(data, klass) - ) + status=0, reason=("Failed to parse `{0}` as `{1}`".format(data, klass)) ) def __deserialize_model(self, data, klass): diff --git a/python-sdk/hatchet_sdk/clients/rest/api_response.py b/python-sdk/hatchet_sdk/clients/rest/api_response.py index 9bc7c11f6..ca801da0b 100644 --- a/python-sdk/hatchet_sdk/clients/rest/api_response.py +++ b/python-sdk/hatchet_sdk/clients/rest/api_response.py @@ -1,11 +1,14 @@ """API response object.""" from __future__ import annotations -from typing import Optional, Generic, Mapping, TypeVar -from pydantic import Field, StrictInt, StrictBytes, BaseModel + +from typing import Generic, Mapping, Optional, TypeVar + +from pydantic import BaseModel, Field, StrictBytes, StrictInt T = TypeVar("T") + class ApiResponse(BaseModel, Generic[T]): """ API response object @@ -16,6 +19,4 @@ class ApiResponse(BaseModel, Generic[T]): data: T = Field(description="Deserialized data given the data type") raw_data: StrictBytes = Field(description="Raw data (HTTP response body)") - model_config = { - "arbitrary_types_allowed": True - } + model_config = {"arbitrary_types_allowed": True} diff --git a/python-sdk/hatchet_sdk/clients/rest/configuration.py b/python-sdk/hatchet_sdk/clients/rest/configuration.py index 9c53cd4a1..454a9abd2 100644 --- a/python-sdk/hatchet_sdk/clients/rest/configuration.py +++ b/python-sdk/hatchet_sdk/clients/rest/configuration.py @@ -13,82 +13,95 @@ import copy +import http.client as httplib import logging -from logging import FileHandler import multiprocessing import sys +from logging import FileHandler from typing import Optional + import urllib3 -import http.client as httplib - JSON_SCHEMA_VALIDATION_KEYWORDS = { - 'multipleOf', 'maximum', 'exclusiveMaximum', - 'minimum', 'exclusiveMinimum', 'maxLength', - 'minLength', 'pattern', 'maxItems', 'minItems' + "multipleOf", + "maximum", + "exclusiveMaximum", + "minimum", + "exclusiveMinimum", + "maxLength", + "minLength", + "pattern", + "maxItems", + "minItems", } + class Configuration: """This class contains various settings of the API client. - :param host: Base url. - :param api_key: Dict to store API key(s). - Each entry in the dict specifies an API key. - The dict key is the name of the security scheme in the OAS specification. - The dict value is the API key secret. - :param api_key_prefix: Dict to store API prefix (e.g. Bearer). - The dict key is the name of the security scheme in the OAS specification. - The dict value is an API key prefix when generating the auth data. - :param username: Username for HTTP basic authentication. - :param password: Password for HTTP basic authentication. - :param access_token: Access token. - :param server_index: Index to servers configuration. - :param server_variables: Mapping with string values to replace variables in - templated server configuration. The validation of enums is performed for - variables with defined enum values before. - :param server_operation_index: Mapping from operation ID to an index to server - configuration. - :param server_operation_variables: Mapping from operation ID to a mapping with - string values to replace variables in templated server configuration. - The validation of enums is performed for variables with defined enum - values before. - :param ssl_ca_cert: str - the path to a file of concatenated CA certificates - in PEM format. + :param host: Base url. + :param api_key: Dict to store API key(s). + Each entry in the dict specifies an API key. + The dict key is the name of the security scheme in the OAS specification. + The dict value is the API key secret. + :param api_key_prefix: Dict to store API prefix (e.g. Bearer). + The dict key is the name of the security scheme in the OAS specification. + The dict value is an API key prefix when generating the auth data. + :param username: Username for HTTP basic authentication. + :param password: Password for HTTP basic authentication. + :param access_token: Access token. + :param server_index: Index to servers configuration. + :param server_variables: Mapping with string values to replace variables in + templated server configuration. The validation of enums is performed for + variables with defined enum values before. + :param server_operation_index: Mapping from operation ID to an index to server + configuration. + :param server_operation_variables: Mapping from operation ID to a mapping with + string values to replace variables in templated server configuration. + The validation of enums is performed for variables with defined enum + values before. + :param ssl_ca_cert: str - the path to a file of concatenated CA certificates + in PEM format. - :Example: + :Example: - API Key Authentication Example. - Given the following security scheme in the OpenAPI specification: - components: - securitySchemes: - cookieAuth: # name for the security scheme - type: apiKey - in: cookie - name: JSESSIONID # cookie name + API Key Authentication Example. + Given the following security scheme in the OpenAPI specification: + components: + securitySchemes: + cookieAuth: # name for the security scheme + type: apiKey + in: cookie + name: JSESSIONID # cookie name - You can programmatically set the cookie: + You can programmatically set the cookie: -conf = hatchet_sdk.clients.rest.Configuration( - api_key={'cookieAuth': 'abc123'} - api_key_prefix={'cookieAuth': 'JSESSIONID'} -) + conf = hatchet_sdk.clients.rest.Configuration( + api_key={'cookieAuth': 'abc123'} + api_key_prefix={'cookieAuth': 'JSESSIONID'} + ) - The following cookie will be added to the HTTP request: - Cookie: JSESSIONID abc123 + The following cookie will be added to the HTTP request: + Cookie: JSESSIONID abc123 """ _default = None - def __init__(self, host=None, - api_key=None, api_key_prefix=None, - username=None, password=None, - access_token=None, - server_index=None, server_variables=None, - server_operation_index=None, server_operation_variables=None, - ssl_ca_cert=None, - ) -> None: - """Constructor - """ + def __init__( + self, + host=None, + api_key=None, + api_key_prefix=None, + username=None, + password=None, + access_token=None, + server_index=None, + server_variables=None, + server_operation_index=None, + server_operation_variables=None, + ssl_ca_cert=None, + ) -> None: + """Constructor""" self._base_path = "http://localhost" if host is None else host """Default Base url """ @@ -131,7 +144,7 @@ conf = hatchet_sdk.clients.rest.Configuration( """ self.logger["package_logger"] = logging.getLogger("hatchet_sdk.clients.rest") self.logger["urllib3_logger"] = logging.getLogger("urllib3") - self.logger_format = '%(asctime)s %(levelname)s %(message)s' + self.logger_format = "%(asctime)s %(levelname)s %(message)s" """Log format """ self.logger_stream_handler = None @@ -183,7 +196,7 @@ conf = hatchet_sdk.clients.rest.Configuration( self.proxy_headers = None """Proxy headers """ - self.safe_chars_for_path_param = '' + self.safe_chars_for_path_param = "" """Safe chars for path_param """ self.retries = None @@ -209,7 +222,7 @@ conf = hatchet_sdk.clients.rest.Configuration( result = cls.__new__(cls) memo[id(self)] = result for k, v in self.__dict__.items(): - if k not in ('logger', 'logger_file_handler'): + if k not in ("logger", "logger_file_handler"): setattr(result, k, copy.deepcopy(v, memo)) # shallow copy of loggers result.logger = copy.copy(self.logger) @@ -350,7 +363,9 @@ conf = hatchet_sdk.clients.rest.Configuration( """ if self.refresh_api_key_hook is not None: self.refresh_api_key_hook(self) - key = self.api_key.get(identifier, self.api_key.get(alias) if alias is not None else None) + key = self.api_key.get( + identifier, self.api_key.get(alias) if alias is not None else None + ) if key: prefix = self.api_key_prefix.get(identifier) if prefix: @@ -369,9 +384,9 @@ conf = hatchet_sdk.clients.rest.Configuration( password = "" if self.password is not None: password = self.password - return urllib3.util.make_headers( - basic_auth=username + ':' + password - ).get('authorization') + return urllib3.util.make_headers(basic_auth=username + ":" + password).get( + "authorization" + ) def auth_settings(self): """Gets Auth Settings dict for api client. @@ -380,19 +395,19 @@ conf = hatchet_sdk.clients.rest.Configuration( """ auth = {} if self.access_token is not None: - auth['bearerAuth'] = { - 'type': 'bearer', - 'in': 'header', - 'key': 'Authorization', - 'value': 'Bearer ' + self.access_token + auth["bearerAuth"] = { + "type": "bearer", + "in": "header", + "key": "Authorization", + "value": "Bearer " + self.access_token, } - if 'cookieAuth' in self.api_key: - auth['cookieAuth'] = { - 'type': 'api_key', - 'in': 'cookie', - 'key': 'hatchet', - 'value': self.get_api_key_with_prefix( - 'cookieAuth', + if "cookieAuth" in self.api_key: + auth["cookieAuth"] = { + "type": "api_key", + "in": "cookie", + "key": "hatchet", + "value": self.get_api_key_with_prefix( + "cookieAuth", ), } return auth @@ -402,12 +417,13 @@ conf = hatchet_sdk.clients.rest.Configuration( :return: The report for debugging. """ - return "Python SDK Debug Report:\n"\ - "OS: {env}\n"\ - "Python Version: {pyversion}\n"\ - "Version of the API: 1.0.0\n"\ - "SDK Package Version: 1.0.0".\ - format(env=sys.platform, pyversion=sys.version) + return ( + "Python SDK Debug Report:\n" + "OS: {env}\n" + "Python Version: {pyversion}\n" + "Version of the API: 1.0.0\n" + "SDK Package Version: 1.0.0".format(env=sys.platform, pyversion=sys.version) + ) def get_host_settings(self): """Gets an array of host settings @@ -416,8 +432,8 @@ conf = hatchet_sdk.clients.rest.Configuration( """ return [ { - 'url': "", - 'description': "No description provided", + "url": "", + "description": "No description provided", } ] @@ -439,22 +455,22 @@ conf = hatchet_sdk.clients.rest.Configuration( except IndexError: raise ValueError( "Invalid index {0} when selecting the host settings. " - "Must be less than {1}".format(index, len(servers))) + "Must be less than {1}".format(index, len(servers)) + ) - url = server['url'] + url = server["url"] # go through variables and replace placeholders - for variable_name, variable in server.get('variables', {}).items(): - used_value = variables.get( - variable_name, variable['default_value']) + for variable_name, variable in server.get("variables", {}).items(): + used_value = variables.get(variable_name, variable["default_value"]) - if 'enum_values' in variable \ - and used_value not in variable['enum_values']: + if "enum_values" in variable and used_value not in variable["enum_values"]: raise ValueError( "The variable `{0}` in the host URL has invalid value " "{1}. Must be {2}.".format( - variable_name, variables[variable_name], - variable['enum_values'])) + variable_name, variables[variable_name], variable["enum_values"] + ) + ) url = url.replace("{" + variable_name + "}", used_value) @@ -463,7 +479,9 @@ conf = hatchet_sdk.clients.rest.Configuration( @property def host(self): """Return generated host.""" - return self.get_host_from_settings(self.server_index, variables=self.server_variables) + return self.get_host_from_settings( + self.server_index, variables=self.server_variables + ) @host.setter def host(self, value): diff --git a/python-sdk/hatchet_sdk/clients/rest/exceptions.py b/python-sdk/hatchet_sdk/clients/rest/exceptions.py index 205c95b69..b41ac1d28 100644 --- a/python-sdk/hatchet_sdk/clients/rest/exceptions.py +++ b/python-sdk/hatchet_sdk/clients/rest/exceptions.py @@ -12,16 +12,19 @@ """ # noqa: E501 from typing import Any, Optional + from typing_extensions import Self + class OpenApiException(Exception): """The base exception class for all OpenAPIExceptions""" class ApiTypeError(OpenApiException, TypeError): - def __init__(self, msg, path_to_item=None, valid_classes=None, - key_type=None) -> None: - """ Raises an exception for TypeErrors + def __init__( + self, msg, path_to_item=None, valid_classes=None, key_type=None + ) -> None: + """Raises an exception for TypeErrors Args: msg (str): the exception message @@ -104,9 +107,9 @@ class ApiKeyError(OpenApiException, KeyError): class ApiException(OpenApiException): def __init__( - self, - status=None, - reason=None, + self, + status=None, + reason=None, http_resp=None, *, body: Optional[str] = None, @@ -125,17 +128,17 @@ class ApiException(OpenApiException): self.reason = http_resp.reason if self.body is None: try: - self.body = http_resp.data.decode('utf-8') + self.body = http_resp.data.decode("utf-8") except Exception: pass self.headers = http_resp.getheaders() @classmethod def from_response( - cls, - *, - http_resp, - body: Optional[str], + cls, + *, + http_resp, + body: Optional[str], data: Optional[Any], ) -> Self: if http_resp.status == 400: @@ -156,11 +159,9 @@ class ApiException(OpenApiException): def __str__(self): """Custom error messages for exception""" - error_message = "({0})\n"\ - "Reason: {1}\n".format(self.status, self.reason) + error_message = "({0})\n" "Reason: {1}\n".format(self.status, self.reason) if self.headers: - error_message += "HTTP response headers: {0}\n".format( - self.headers) + error_message += "HTTP response headers: {0}\n".format(self.headers) if self.data or self.body: error_message += "HTTP response body: {0}\n".format(self.data or self.body) diff --git a/python-sdk/hatchet_sdk/clients/rest/models/__init__.py b/python-sdk/hatchet_sdk/clients/rest/models/__init__.py index c4fdb723d..d585c5347 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/__init__.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/__init__.py @@ -13,6 +13,8 @@ """ # noqa: E501 +from hatchet_sdk.clients.rest.models.accept_invite_request import AcceptInviteRequest + # import models into model package from hatchet_sdk.clients.rest.models.api_error import APIError from hatchet_sdk.clients.rest.models.api_errors import APIErrors @@ -21,36 +23,63 @@ from hatchet_sdk.clients.rest.models.api_meta_auth import APIMetaAuth from hatchet_sdk.clients.rest.models.api_meta_integration import APIMetaIntegration from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.api_token import APIToken -from hatchet_sdk.clients.rest.models.accept_invite_request import AcceptInviteRequest -from hatchet_sdk.clients.rest.models.create_api_token_request import CreateAPITokenRequest -from hatchet_sdk.clients.rest.models.create_api_token_response import CreateAPITokenResponse -from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import CreatePullRequestFromStepRun -from hatchet_sdk.clients.rest.models.create_sns_integration_request import CreateSNSIntegrationRequest -from hatchet_sdk.clients.rest.models.create_tenant_invite_request import CreateTenantInviteRequest +from hatchet_sdk.clients.rest.models.create_api_token_request import ( + CreateAPITokenRequest, +) +from hatchet_sdk.clients.rest.models.create_api_token_response import ( + CreateAPITokenResponse, +) +from hatchet_sdk.clients.rest.models.create_pull_request_from_step_run import ( + CreatePullRequestFromStepRun, +) +from hatchet_sdk.clients.rest.models.create_sns_integration_request import ( + CreateSNSIntegrationRequest, +) +from hatchet_sdk.clients.rest.models.create_tenant_invite_request import ( + CreateTenantInviteRequest, +) from hatchet_sdk.clients.rest.models.create_tenant_request import CreateTenantRequest from hatchet_sdk.clients.rest.models.event import Event from hatchet_sdk.clients.rest.models.event_data import EventData from hatchet_sdk.clients.rest.models.event_key_list import EventKeyList from hatchet_sdk.clients.rest.models.event_list import EventList -from hatchet_sdk.clients.rest.models.event_order_by_direction import EventOrderByDirection +from hatchet_sdk.clients.rest.models.event_order_by_direction import ( + EventOrderByDirection, +) from hatchet_sdk.clients.rest.models.event_order_by_field import EventOrderByField -from hatchet_sdk.clients.rest.models.event_workflow_run_summary import EventWorkflowRunSummary -from hatchet_sdk.clients.rest.models.get_step_run_diff_response import GetStepRunDiffResponse -from hatchet_sdk.clients.rest.models.github_app_installation import GithubAppInstallation +from hatchet_sdk.clients.rest.models.event_workflow_run_summary import ( + EventWorkflowRunSummary, +) +from hatchet_sdk.clients.rest.models.get_step_run_diff_response import ( + GetStepRunDiffResponse, +) +from hatchet_sdk.clients.rest.models.github_app_installation import ( + GithubAppInstallation, +) from hatchet_sdk.clients.rest.models.github_branch import GithubBranch from hatchet_sdk.clients.rest.models.github_repo import GithubRepo from hatchet_sdk.clients.rest.models.job import Job from hatchet_sdk.clients.rest.models.job_run import JobRun from hatchet_sdk.clients.rest.models.job_run_status import JobRunStatus -from hatchet_sdk.clients.rest.models.link_github_repository_request import LinkGithubRepositoryRequest -from hatchet_sdk.clients.rest.models.list_api_tokens_response import ListAPITokensResponse -from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ListGithubAppInstallationsResponse -from hatchet_sdk.clients.rest.models.list_pull_requests_response import ListPullRequestsResponse +from hatchet_sdk.clients.rest.models.link_github_repository_request import ( + LinkGithubRepositoryRequest, +) +from hatchet_sdk.clients.rest.models.list_api_tokens_response import ( + ListAPITokensResponse, +) +from hatchet_sdk.clients.rest.models.list_github_app_installations_response import ( + ListGithubAppInstallationsResponse, +) +from hatchet_sdk.clients.rest.models.list_pull_requests_response import ( + ListPullRequestsResponse, +) from hatchet_sdk.clients.rest.models.list_sns_integrations import ListSNSIntegrations from hatchet_sdk.clients.rest.models.log_line import LogLine from hatchet_sdk.clients.rest.models.log_line_level import LogLineLevel from hatchet_sdk.clients.rest.models.log_line_list import LogLineList -from hatchet_sdk.clients.rest.models.log_line_order_by_direction import LogLineOrderByDirection +from hatchet_sdk.clients.rest.models.log_line_order_by_direction import ( + LogLineOrderByDirection, +) from hatchet_sdk.clients.rest.models.log_line_order_by_field import LogLineOrderByField from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.pull_request import PullRequest @@ -70,29 +99,47 @@ from hatchet_sdk.clients.rest.models.tenant_list import TenantList from hatchet_sdk.clients.rest.models.tenant_member import TenantMember from hatchet_sdk.clients.rest.models.tenant_member_list import TenantMemberList from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole -from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import TriggerWorkflowRunRequest -from hatchet_sdk.clients.rest.models.update_tenant_invite_request import UpdateTenantInviteRequest +from hatchet_sdk.clients.rest.models.trigger_workflow_run_request import ( + TriggerWorkflowRunRequest, +) +from hatchet_sdk.clients.rest.models.update_tenant_invite_request import ( + UpdateTenantInviteRequest, +) from hatchet_sdk.clients.rest.models.user import User -from hatchet_sdk.clients.rest.models.user_change_password_request import UserChangePasswordRequest +from hatchet_sdk.clients.rest.models.user_change_password_request import ( + UserChangePasswordRequest, +) from hatchet_sdk.clients.rest.models.user_login_request import UserLoginRequest from hatchet_sdk.clients.rest.models.user_register_request import UserRegisterRequest -from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import UserTenantMembershipsList +from hatchet_sdk.clients.rest.models.user_tenant_memberships_list import ( + UserTenantMembershipsList, +) from hatchet_sdk.clients.rest.models.user_tenant_public import UserTenantPublic from hatchet_sdk.clients.rest.models.worker import Worker from hatchet_sdk.clients.rest.models.worker_list import WorkerList from hatchet_sdk.clients.rest.models.workflow import Workflow from hatchet_sdk.clients.rest.models.workflow_concurrency import WorkflowConcurrency -from hatchet_sdk.clients.rest.models.workflow_deployment_config import WorkflowDeploymentConfig +from hatchet_sdk.clients.rest.models.workflow_deployment_config import ( + WorkflowDeploymentConfig, +) from hatchet_sdk.clients.rest.models.workflow_list import WorkflowList from hatchet_sdk.clients.rest.models.workflow_metrics import WorkflowMetrics from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun from hatchet_sdk.clients.rest.models.workflow_run_list import WorkflowRunList from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus -from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import WorkflowRunTriggeredBy +from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import ( + WorkflowRunTriggeredBy, +) from hatchet_sdk.clients.rest.models.workflow_tag import WorkflowTag -from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import WorkflowTriggerCronRef -from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import WorkflowTriggerEventRef +from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import ( + WorkflowTriggerCronRef, +) +from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import ( + WorkflowTriggerEventRef, +) from hatchet_sdk.clients.rest.models.workflow_triggers import WorkflowTriggers from hatchet_sdk.clients.rest.models.workflow_version import WorkflowVersion -from hatchet_sdk.clients.rest.models.workflow_version_definition import WorkflowVersionDefinition +from hatchet_sdk.clients.rest.models.workflow_version_definition import ( + WorkflowVersionDefinition, +) from hatchet_sdk.clients.rest.models.workflow_version_meta import WorkflowVersionMeta diff --git a/python-sdk/hatchet_sdk/clients/rest/models/accept_invite_request.py b/python-sdk/hatchet_sdk/clients/rest/models/accept_invite_request.py index 2c392b9ae..3b150907b 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/accept_invite_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/accept_invite_request.py @@ -13,20 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from typing_extensions import Annotated -from typing import Optional, Set -from typing_extensions import Self +from typing_extensions import Annotated, Self + class AcceptInviteRequest(BaseModel): """ AcceptInviteRequest - """ # noqa: E501 + """ # noqa: E501 + invite: Annotated[str, Field(min_length=36, strict=True, max_length=36)] __properties: ClassVar[List[str]] = ["invite"] @@ -36,7 +37,6 @@ class AcceptInviteRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +61,7 @@ class AcceptInviteRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,9 +79,5 @@ class AcceptInviteRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "invite": obj.get("invite") - }) + _obj = cls.model_validate({"invite": obj.get("invite")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/api_error.py b/python-sdk/hatchet_sdk/clients/rest/models/api_error.py index 0a27967e9..e4030a3b1 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/api_error.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/api_error.py @@ -13,23 +13,33 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class APIError(BaseModel): """ APIError - """ # noqa: E501 - code: Optional[StrictInt] = Field(default=None, description="a custom Hatchet error code") - field: Optional[StrictStr] = Field(default=None, description="the field that this error is associated with, if applicable") + """ # noqa: E501 + + code: Optional[StrictInt] = Field( + default=None, description="a custom Hatchet error code" + ) + field: Optional[StrictStr] = Field( + default=None, + description="the field that this error is associated with, if applicable", + ) description: StrictStr = Field(description="a description for this error") - docs_link: Optional[StrictStr] = Field(default=None, description="a link to the documentation for this error, if it exists") + docs_link: Optional[StrictStr] = Field( + default=None, + description="a link to the documentation for this error, if it exists", + ) __properties: ClassVar[List[str]] = ["code", "field", "description", "docs_link"] model_config = { @@ -38,7 +48,6 @@ class APIError(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +72,7 @@ class APIError(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -82,12 +90,12 @@ class APIError(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "code": obj.get("code"), - "field": obj.get("field"), - "description": obj.get("description"), - "docs_link": obj.get("docs_link") - }) + _obj = cls.model_validate( + { + "code": obj.get("code"), + "field": obj.get("field"), + "description": obj.get("description"), + "docs_link": obj.get("docs_link"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/api_errors.py b/python-sdk/hatchet_sdk/clients/rest/models/api_errors.py index 0121789bc..16979c7e6 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/api_errors.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/api_errors.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.api_error import APIError -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_error import APIError + + class APIErrors(BaseModel): """ APIErrors - """ # noqa: E501 + """ # noqa: E501 + errors: List[APIError] __properties: ClassVar[List[str]] = ["errors"] @@ -36,7 +39,6 @@ class APIErrors(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +63,7 @@ class APIErrors(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -75,7 +76,7 @@ class APIErrors(BaseModel): for _item in self.errors: if _item: _items.append(_item.to_dict()) - _dict['errors'] = _items + _dict["errors"] = _items return _dict @classmethod @@ -87,9 +88,13 @@ class APIErrors(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "errors": [APIError.from_dict(_item) for _item in obj["errors"]] if obj.get("errors") is not None else None - }) + _obj = cls.model_validate( + { + "errors": ( + [APIError.from_dict(_item) for _item in obj["errors"]] + if obj.get("errors") is not None + else None + ) + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/api_meta.py b/python-sdk/hatchet_sdk/clients/rest/models/api_meta.py index 99515545d..0b5ca87c3 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/api_meta.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/api_meta.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_meta_auth import APIMetaAuth -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_meta_auth import APIMetaAuth + + class APIMeta(BaseModel): """ APIMeta - """ # noqa: E501 + """ # noqa: E501 + auth: Optional[APIMetaAuth] = None __properties: ClassVar[List[str]] = ["auth"] @@ -36,7 +39,6 @@ class APIMeta(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +63,7 @@ class APIMeta(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -71,7 +72,7 @@ class APIMeta(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of auth if self.auth: - _dict['auth'] = self.auth.to_dict() + _dict["auth"] = self.auth.to_dict() return _dict @classmethod @@ -83,9 +84,13 @@ class APIMeta(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "auth": APIMetaAuth.from_dict(obj["auth"]) if obj.get("auth") is not None else None - }) + _obj = cls.model_validate( + { + "auth": ( + APIMetaAuth.from_dict(obj["auth"]) + if obj.get("auth") is not None + else None + ) + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/api_meta_auth.py b/python-sdk/hatchet_sdk/clients/rest/models/api_meta_auth.py index 53da28ff5..88169c27a 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/api_meta_auth.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/api_meta_auth.py @@ -13,20 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class APIMetaAuth(BaseModel): """ APIMetaAuth - """ # noqa: E501 - schemes: Optional[List[StrictStr]] = Field(default=None, description="the supported types of authentication") + """ # noqa: E501 + + schemes: Optional[List[StrictStr]] = Field( + default=None, description="the supported types of authentication" + ) __properties: ClassVar[List[str]] = ["schemes"] model_config = { @@ -35,7 +39,6 @@ class APIMetaAuth(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +63,7 @@ class APIMetaAuth(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +81,5 @@ class APIMetaAuth(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "schemes": obj.get("schemes") - }) + _obj = cls.model_validate({"schemes": obj.get("schemes")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/api_meta_integration.py b/python-sdk/hatchet_sdk/clients/rest/models/api_meta_integration.py index 2db71a2fa..ad9836092 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/api_meta_integration.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/api_meta_integration.py @@ -13,21 +13,25 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictBool, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class APIMetaIntegration(BaseModel): """ APIMetaIntegration - """ # noqa: E501 + """ # noqa: E501 + name: StrictStr = Field(description="the name of the integration") - enabled: StrictBool = Field(description="whether this integration is enabled on the instance") + enabled: StrictBool = Field( + description="whether this integration is enabled on the instance" + ) __properties: ClassVar[List[str]] = ["name", "enabled"] model_config = { @@ -36,7 +40,6 @@ class APIMetaIntegration(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +64,7 @@ class APIMetaIntegration(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +82,7 @@ class APIMetaIntegration(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "name": obj.get("name"), - "enabled": obj.get("enabled") - }) + _obj = cls.model_validate( + {"name": obj.get("name"), "enabled": obj.get("enabled")} + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/api_resource_meta.py b/python-sdk/hatchet_sdk/clients/rest/models/api_resource_meta.py index 1f3b9ea31..554af0945 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/api_resource_meta.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/api_resource_meta.py @@ -13,24 +13,31 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from typing_extensions import Annotated -from typing import Optional, Set -from typing_extensions import Self +from typing_extensions import Annotated, Self + class APIResourceMeta(BaseModel): """ APIResourceMeta - """ # noqa: E501 - id: Annotated[str, Field(min_length=36, strict=True, max_length=36)] = Field(description="the id of this resource, in UUID format") - created_at: datetime = Field(description="the time that this resource was created", alias="createdAt") - updated_at: datetime = Field(description="the time that this resource was last updated", alias="updatedAt") + """ # noqa: E501 + + id: Annotated[str, Field(min_length=36, strict=True, max_length=36)] = Field( + description="the id of this resource, in UUID format" + ) + created_at: datetime = Field( + description="the time that this resource was created", alias="createdAt" + ) + updated_at: datetime = Field( + description="the time that this resource was last updated", alias="updatedAt" + ) __properties: ClassVar[List[str]] = ["id", "createdAt", "updatedAt"] model_config = { @@ -39,7 +46,6 @@ class APIResourceMeta(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -64,8 +70,7 @@ class APIResourceMeta(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -83,11 +88,11 @@ class APIResourceMeta(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "id": obj.get("id"), - "createdAt": obj.get("createdAt"), - "updatedAt": obj.get("updatedAt") - }) + _obj = cls.model_validate( + { + "id": obj.get("id"), + "createdAt": obj.get("createdAt"), + "updatedAt": obj.get("updatedAt"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/api_token.py b/python-sdk/hatchet_sdk/clients/rest/models/api_token.py index 2e9e3ec8f..6238592d0 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/api_token.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/api_token.py @@ -13,25 +13,31 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from typing_extensions import Annotated +from typing_extensions import Annotated, Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from typing import Optional, Set -from typing_extensions import Self + class APIToken(BaseModel): """ APIToken - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta - name: Annotated[str, Field(strict=True, max_length=255)] = Field(description="The name of the API token.") - expires_at: datetime = Field(description="When the API token expires.", alias="expiresAt") + name: Annotated[str, Field(strict=True, max_length=255)] = Field( + description="The name of the API token." + ) + expires_at: datetime = Field( + description="When the API token expires.", alias="expiresAt" + ) __properties: ClassVar[List[str]] = ["metadata", "name", "expiresAt"] model_config = { @@ -40,7 +46,6 @@ class APIToken(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -65,8 +70,7 @@ class APIToken(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -75,7 +79,7 @@ class APIToken(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() return _dict @classmethod @@ -87,11 +91,15 @@ class APIToken(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "name": obj.get("name"), - "expiresAt": obj.get("expiresAt") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "name": obj.get("name"), + "expiresAt": obj.get("expiresAt"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/cancel_step_run_request.py b/python-sdk/hatchet_sdk/clients/rest/models/cancel_step_run_request.py index fcde3a327..69e972975 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/cancel_step_run_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/cancel_step_run_request.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class CancelStepRunRequest(BaseModel): """ CancelStepRunRequest - """ # noqa: E501 + """ # noqa: E501 + input: Dict[str, Any] __properties: ClassVar[List[str]] = ["input"] @@ -35,7 +37,6 @@ class CancelStepRunRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +61,7 @@ class CancelStepRunRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +79,5 @@ class CancelStepRunRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "input": obj.get("input") - }) + _obj = cls.model_validate({"input": obj.get("input")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_request.py b/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_request.py index d5ba9996a..04f9e9def 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_request.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from typing_extensions import Annotated -from typing import Optional, Set -from typing_extensions import Self +from typing_extensions import Annotated, Self + class CreateAPITokenRequest(BaseModel): """ CreateAPITokenRequest - """ # noqa: E501 - name: Annotated[str, Field(strict=True, max_length=255)] = Field(description="A name for the API token.") + """ # noqa: E501 + + name: Annotated[str, Field(strict=True, max_length=255)] = Field( + description="A name for the API token." + ) __properties: ClassVar[List[str]] = ["name"] model_config = { @@ -36,7 +39,6 @@ class CreateAPITokenRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +63,7 @@ class CreateAPITokenRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,9 +81,5 @@ class CreateAPITokenRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "name": obj.get("name") - }) + _obj = cls.model_validate({"name": obj.get("name")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_response.py b/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_response.py index ebc76f6f7..589f4bf80 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_response.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/create_api_token_response.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class CreateAPITokenResponse(BaseModel): """ CreateAPITokenResponse - """ # noqa: E501 + """ # noqa: E501 + token: StrictStr = Field(description="The API token.") __properties: ClassVar[List[str]] = ["token"] @@ -35,7 +37,6 @@ class CreateAPITokenResponse(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +61,7 @@ class CreateAPITokenResponse(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +79,5 @@ class CreateAPITokenResponse(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "token": obj.get("token") - }) + _obj = cls.model_validate({"token": obj.get("token")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/create_pull_request_from_step_run.py b/python-sdk/hatchet_sdk/clients/rest/models/create_pull_request_from_step_run.py index 893f9208b..de30be373 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/create_pull_request_from_step_run.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/create_pull_request_from_step_run.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class CreatePullRequestFromStepRun(BaseModel): """ CreatePullRequestFromStepRun - """ # noqa: E501 + """ # noqa: E501 + branch_name: StrictStr = Field(alias="branchName") __properties: ClassVar[List[str]] = ["branchName"] @@ -35,7 +37,6 @@ class CreatePullRequestFromStepRun(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +61,7 @@ class CreatePullRequestFromStepRun(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +79,5 @@ class CreatePullRequestFromStepRun(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "branchName": obj.get("branchName") - }) + _obj = cls.model_validate({"branchName": obj.get("branchName")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/create_sns_integration_request.py b/python-sdk/hatchet_sdk/clients/rest/models/create_sns_integration_request.py index cacce2c39..2a2b4201a 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/create_sns_integration_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/create_sns_integration_request.py @@ -13,20 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class CreateSNSIntegrationRequest(BaseModel): """ CreateSNSIntegrationRequest - """ # noqa: E501 - topic_arn: StrictStr = Field(description="The Amazon Resource Name (ARN) of the SNS topic.", alias="topicArn") + """ # noqa: E501 + + topic_arn: StrictStr = Field( + description="The Amazon Resource Name (ARN) of the SNS topic.", alias="topicArn" + ) __properties: ClassVar[List[str]] = ["topicArn"] model_config = { @@ -35,7 +39,6 @@ class CreateSNSIntegrationRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +63,7 @@ class CreateSNSIntegrationRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +81,5 @@ class CreateSNSIntegrationRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "topicArn": obj.get("topicArn") - }) + _obj = cls.model_validate({"topicArn": obj.get("topicArn")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_invite_request.py b/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_invite_request.py index 4dcf823db..d4f0f1513 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_invite_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_invite_request.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole + + class CreateTenantInviteRequest(BaseModel): """ CreateTenantInviteRequest - """ # noqa: E501 + """ # noqa: E501 + email: StrictStr = Field(description="The email of the user to invite.") role: TenantMemberRole = Field(description="The role of the user in the tenant.") __properties: ClassVar[List[str]] = ["email", "role"] @@ -37,7 +40,6 @@ class CreateTenantInviteRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -62,8 +64,7 @@ class CreateTenantInviteRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -81,10 +82,5 @@ class CreateTenantInviteRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "email": obj.get("email"), - "role": obj.get("role") - }) + _obj = cls.model_validate({"email": obj.get("email"), "role": obj.get("role")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_request.py b/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_request.py index 0ad8a46c2..8351c18a4 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/create_tenant_request.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class CreateTenantRequest(BaseModel): """ CreateTenantRequest - """ # noqa: E501 + """ # noqa: E501 + name: StrictStr = Field(description="The name of the tenant.") slug: StrictStr = Field(description="The slug of the tenant.") __properties: ClassVar[List[str]] = ["name", "slug"] @@ -36,7 +38,6 @@ class CreateTenantRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +62,7 @@ class CreateTenantRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +80,5 @@ class CreateTenantRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "name": obj.get("name"), - "slug": obj.get("slug") - }) + _obj = cls.model_validate({"name": obj.get("name"), "slug": obj.get("slug")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/event.py b/python-sdk/hatchet_sdk/clients/rest/models/event.py index 2f93c5733..09c34379d 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/event.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/event.py @@ -13,28 +13,47 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from hatchet_sdk.clients.rest.models.event_workflow_run_summary import EventWorkflowRunSummary -from hatchet_sdk.clients.rest.models.tenant import Tenant -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta +from hatchet_sdk.clients.rest.models.event_workflow_run_summary import ( + EventWorkflowRunSummary, +) +from hatchet_sdk.clients.rest.models.tenant import Tenant + + class Event(BaseModel): """ Event - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta key: StrictStr = Field(description="The key for the event.") - tenant: Optional[Tenant] = Field(default=None, description="The tenant associated with this event.") - tenant_id: StrictStr = Field(description="The ID of the tenant associated with this event.", alias="tenantId") - workflow_run_summary: Optional[EventWorkflowRunSummary] = Field(default=None, description="The workflow run summary for this event.", alias="workflowRunSummary") - __properties: ClassVar[List[str]] = ["metadata", "key", "tenant", "tenantId", "workflowRunSummary"] + tenant: Optional[Tenant] = Field( + default=None, description="The tenant associated with this event." + ) + tenant_id: StrictStr = Field( + description="The ID of the tenant associated with this event.", alias="tenantId" + ) + workflow_run_summary: Optional[EventWorkflowRunSummary] = Field( + default=None, + description="The workflow run summary for this event.", + alias="workflowRunSummary", + ) + __properties: ClassVar[List[str]] = [ + "metadata", + "key", + "tenant", + "tenantId", + "workflowRunSummary", + ] model_config = { "populate_by_name": True, @@ -42,7 +61,6 @@ class Event(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -67,8 +85,7 @@ class Event(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -77,13 +94,13 @@ class Event(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of tenant if self.tenant: - _dict['tenant'] = self.tenant.to_dict() + _dict["tenant"] = self.tenant.to_dict() # override the default output from pydantic by calling `to_dict()` of workflow_run_summary if self.workflow_run_summary: - _dict['workflowRunSummary'] = self.workflow_run_summary.to_dict() + _dict["workflowRunSummary"] = self.workflow_run_summary.to_dict() return _dict @classmethod @@ -95,13 +112,25 @@ class Event(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "key": obj.get("key"), - "tenant": Tenant.from_dict(obj["tenant"]) if obj.get("tenant") is not None else None, - "tenantId": obj.get("tenantId"), - "workflowRunSummary": EventWorkflowRunSummary.from_dict(obj["workflowRunSummary"]) if obj.get("workflowRunSummary") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "key": obj.get("key"), + "tenant": ( + Tenant.from_dict(obj["tenant"]) + if obj.get("tenant") is not None + else None + ), + "tenantId": obj.get("tenantId"), + "workflowRunSummary": ( + EventWorkflowRunSummary.from_dict(obj["workflowRunSummary"]) + if obj.get("workflowRunSummary") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/event_data.py b/python-sdk/hatchet_sdk/clients/rest/models/event_data.py index 16a73536a..767125f85 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/event_data.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/event_data.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class EventData(BaseModel): """ EventData - """ # noqa: E501 + """ # noqa: E501 + data: StrictStr = Field(description="The data for the event (JSON bytes).") __properties: ClassVar[List[str]] = ["data"] @@ -35,7 +37,6 @@ class EventData(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +61,7 @@ class EventData(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +79,5 @@ class EventData(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "data": obj.get("data") - }) + _obj = cls.model_validate({"data": obj.get("data")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/event_key_list.py b/python-sdk/hatchet_sdk/clients/rest/models/event_key_list.py index dbfae81b3..7ceb8a3ce 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/event_key_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/event_key_list.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse + + class EventKeyList(BaseModel): """ EventKeyList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[StrictStr]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -37,7 +40,6 @@ class EventKeyList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -62,8 +64,7 @@ class EventKeyList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -72,7 +73,7 @@ class EventKeyList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() return _dict @classmethod @@ -84,10 +85,14 @@ class EventKeyList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": obj.get("rows") - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": obj.get("rows"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/event_list.py b/python-sdk/hatchet_sdk/clients/rest/models/event_list.py index 2aeb909a7..75a0b4796 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/event_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/event_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.event import Event from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse -from typing import Optional, Set -from typing_extensions import Self + class EventList(BaseModel): """ EventList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[Event]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class EventList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class EventList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class EventList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class EventList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [Event.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [Event.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_direction.py b/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_direction.py index 6af67b0fe..24255e0d4 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_direction.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_direction.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,12 +28,10 @@ class EventOrderByDirection(str, Enum): """ allowed enum values """ - ASC = 'asc' - DESC = 'desc' + ASC = "asc" + DESC = "desc" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of EventOrderByDirection from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_field.py b/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_field.py index a053f5595..da2193c30 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_field.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/event_order_by_field.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,11 +28,9 @@ class EventOrderByField(str, Enum): """ allowed enum values """ - CREATEDAT = 'createdAt' + CREATEDAT = "createdAt" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of EventOrderByField from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/event_workflow_run_summary.py b/python-sdk/hatchet_sdk/clients/rest/models/event_workflow_run_summary.py index 71a1e0ff7..24ad7eb60 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/event_workflow_run_summary.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/event_workflow_run_summary.py @@ -13,25 +13,43 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class EventWorkflowRunSummary(BaseModel): """ EventWorkflowRunSummary - """ # noqa: E501 - pending: Optional[StrictInt] = Field(default=None, description="The number of pending runs.") - running: Optional[StrictInt] = Field(default=None, description="The number of running runs.") - queued: Optional[StrictInt] = Field(default=None, description="The number of queued runs.") - succeeded: Optional[StrictInt] = Field(default=None, description="The number of succeeded runs.") - failed: Optional[StrictInt] = Field(default=None, description="The number of failed runs.") - __properties: ClassVar[List[str]] = ["pending", "running", "queued", "succeeded", "failed"] + """ # noqa: E501 + + pending: Optional[StrictInt] = Field( + default=None, description="The number of pending runs." + ) + running: Optional[StrictInt] = Field( + default=None, description="The number of running runs." + ) + queued: Optional[StrictInt] = Field( + default=None, description="The number of queued runs." + ) + succeeded: Optional[StrictInt] = Field( + default=None, description="The number of succeeded runs." + ) + failed: Optional[StrictInt] = Field( + default=None, description="The number of failed runs." + ) + __properties: ClassVar[List[str]] = [ + "pending", + "running", + "queued", + "succeeded", + "failed", + ] model_config = { "populate_by_name": True, @@ -39,7 +57,6 @@ class EventWorkflowRunSummary(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -64,8 +81,7 @@ class EventWorkflowRunSummary(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -83,13 +99,13 @@ class EventWorkflowRunSummary(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pending": obj.get("pending"), - "running": obj.get("running"), - "queued": obj.get("queued"), - "succeeded": obj.get("succeeded"), - "failed": obj.get("failed") - }) + _obj = cls.model_validate( + { + "pending": obj.get("pending"), + "running": obj.get("running"), + "queued": obj.get("queued"), + "succeeded": obj.get("succeeded"), + "failed": obj.get("failed"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/get_step_run_diff_response.py b/python-sdk/hatchet_sdk/clients/rest/models/get_step_run_diff_response.py index 2ded03cb9..117f3bb5f 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/get_step_run_diff_response.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/get_step_run_diff_response.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.step_run_diff import StepRunDiff -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.step_run_diff import StepRunDiff + + class GetStepRunDiffResponse(BaseModel): """ GetStepRunDiffResponse - """ # noqa: E501 + """ # noqa: E501 + diffs: List[StepRunDiff] __properties: ClassVar[List[str]] = ["diffs"] @@ -36,7 +39,6 @@ class GetStepRunDiffResponse(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +63,7 @@ class GetStepRunDiffResponse(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -75,7 +76,7 @@ class GetStepRunDiffResponse(BaseModel): for _item in self.diffs: if _item: _items.append(_item.to_dict()) - _dict['diffs'] = _items + _dict["diffs"] = _items return _dict @classmethod @@ -87,9 +88,13 @@ class GetStepRunDiffResponse(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "diffs": [StepRunDiff.from_dict(_item) for _item in obj["diffs"]] if obj.get("diffs") is not None else None - }) + _obj = cls.model_validate( + { + "diffs": ( + [StepRunDiff.from_dict(_item) for _item in obj["diffs"]] + if obj.get("diffs") is not None + else None + ) + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/github_app_installation.py b/python-sdk/hatchet_sdk/clients/rest/models/github_app_installation.py index b5585bf2c..03616feac 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/github_app_installation.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/github_app_installation.py @@ -13,25 +13,33 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictStr -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta + + class GithubAppInstallation(BaseModel): """ GithubAppInstallation - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta installation_settings_url: StrictStr account_name: StrictStr account_avatar_url: StrictStr - __properties: ClassVar[List[str]] = ["metadata", "installation_settings_url", "account_name", "account_avatar_url"] + __properties: ClassVar[List[str]] = [ + "metadata", + "installation_settings_url", + "account_name", + "account_avatar_url", + ] model_config = { "populate_by_name": True, @@ -39,7 +47,6 @@ class GithubAppInstallation(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -64,8 +71,7 @@ class GithubAppInstallation(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -74,7 +80,7 @@ class GithubAppInstallation(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() return _dict @classmethod @@ -86,12 +92,16 @@ class GithubAppInstallation(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "installation_settings_url": obj.get("installation_settings_url"), - "account_name": obj.get("account_name"), - "account_avatar_url": obj.get("account_avatar_url") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "installation_settings_url": obj.get("installation_settings_url"), + "account_name": obj.get("account_name"), + "account_avatar_url": obj.get("account_avatar_url"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/github_branch.py b/python-sdk/hatchet_sdk/clients/rest/models/github_branch.py index f3d0b2ff9..162d7f781 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/github_branch.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/github_branch.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictBool, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class GithubBranch(BaseModel): """ GithubBranch - """ # noqa: E501 + """ # noqa: E501 + branch_name: StrictStr is_default: StrictBool __properties: ClassVar[List[str]] = ["branch_name", "is_default"] @@ -36,7 +38,6 @@ class GithubBranch(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +62,7 @@ class GithubBranch(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +80,7 @@ class GithubBranch(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "branch_name": obj.get("branch_name"), - "is_default": obj.get("is_default") - }) + _obj = cls.model_validate( + {"branch_name": obj.get("branch_name"), "is_default": obj.get("is_default")} + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/github_repo.py b/python-sdk/hatchet_sdk/clients/rest/models/github_repo.py index 4f9bb0341..672a917de 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/github_repo.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/github_repo.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class GithubRepo(BaseModel): """ GithubRepo - """ # noqa: E501 + """ # noqa: E501 + repo_owner: StrictStr repo_name: StrictStr __properties: ClassVar[List[str]] = ["repo_owner", "repo_name"] @@ -36,7 +38,6 @@ class GithubRepo(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +62,7 @@ class GithubRepo(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +80,7 @@ class GithubRepo(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "repo_owner": obj.get("repo_owner"), - "repo_name": obj.get("repo_name") - }) + _obj = cls.model_validate( + {"repo_owner": obj.get("repo_owner"), "repo_name": obj.get("repo_name")} + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/job.py b/python-sdk/hatchet_sdk/clients/rest/models/job.py index 0b93f879f..871bdb8c6 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/job.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/job.py @@ -13,29 +13,44 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.step import Step -from typing import Optional, Set -from typing_extensions import Self + class Job(BaseModel): """ Job - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta tenant_id: StrictStr = Field(alias="tenantId") version_id: StrictStr = Field(alias="versionId") name: StrictStr - description: Optional[StrictStr] = Field(default=None, description="The description of the job.") + description: Optional[StrictStr] = Field( + default=None, description="The description of the job." + ) steps: List[Step] - timeout: Optional[StrictStr] = Field(default=None, description="The timeout of the job.") - __properties: ClassVar[List[str]] = ["metadata", "tenantId", "versionId", "name", "description", "steps", "timeout"] + timeout: Optional[StrictStr] = Field( + default=None, description="The timeout of the job." + ) + __properties: ClassVar[List[str]] = [ + "metadata", + "tenantId", + "versionId", + "name", + "description", + "steps", + "timeout", + ] model_config = { "populate_by_name": True, @@ -43,7 +58,6 @@ class Job(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -68,8 +82,7 @@ class Job(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -78,14 +91,14 @@ class Job(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in steps (list) _items = [] if self.steps: for _item in self.steps: if _item: _items.append(_item.to_dict()) - _dict['steps'] = _items + _dict["steps"] = _items return _dict @classmethod @@ -97,15 +110,23 @@ class Job(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "tenantId": obj.get("tenantId"), - "versionId": obj.get("versionId"), - "name": obj.get("name"), - "description": obj.get("description"), - "steps": [Step.from_dict(_item) for _item in obj["steps"]] if obj.get("steps") is not None else None, - "timeout": obj.get("timeout") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "tenantId": obj.get("tenantId"), + "versionId": obj.get("versionId"), + "name": obj.get("name"), + "description": obj.get("description"), + "steps": ( + [Step.from_dict(_item) for _item in obj["steps"]] + if obj.get("steps") is not None + else None + ), + "timeout": obj.get("timeout"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/job_run.py b/python-sdk/hatchet_sdk/clients/rest/models/job_run.py index 0262a5c4d..f70f44158 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/job_run.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/job_run.py @@ -13,23 +13,26 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.job import Job from hatchet_sdk.clients.rest.models.job_run_status import JobRunStatus -from typing import Optional, Set -from typing_extensions import Self + class JobRun(BaseModel): """ JobRun - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta tenant_id: StrictStr = Field(alias="tenantId") workflow_run_id: StrictStr = Field(alias="workflowRunId") @@ -46,7 +49,24 @@ class JobRun(BaseModel): cancelled_at: Optional[datetime] = Field(default=None, alias="cancelledAt") cancelled_reason: Optional[StrictStr] = Field(default=None, alias="cancelledReason") cancelled_error: Optional[StrictStr] = Field(default=None, alias="cancelledError") - __properties: ClassVar[List[str]] = ["metadata", "tenantId", "workflowRunId", "workflowRun", "jobId", "job", "tickerId", "stepRuns", "status", "result", "startedAt", "finishedAt", "timeoutAt", "cancelledAt", "cancelledReason", "cancelledError"] + __properties: ClassVar[List[str]] = [ + "metadata", + "tenantId", + "workflowRunId", + "workflowRun", + "jobId", + "job", + "tickerId", + "stepRuns", + "status", + "result", + "startedAt", + "finishedAt", + "timeoutAt", + "cancelledAt", + "cancelledReason", + "cancelledError", + ] model_config = { "populate_by_name": True, @@ -54,7 +74,6 @@ class JobRun(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -79,8 +98,7 @@ class JobRun(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -89,20 +107,20 @@ class JobRun(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of workflow_run if self.workflow_run: - _dict['workflowRun'] = self.workflow_run.to_dict() + _dict["workflowRun"] = self.workflow_run.to_dict() # override the default output from pydantic by calling `to_dict()` of job if self.job: - _dict['job'] = self.job.to_dict() + _dict["job"] = self.job.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in step_runs (list) _items = [] if self.step_runs: for _item in self.step_runs: if _item: _items.append(_item.to_dict()) - _dict['stepRuns'] = _items + _dict["stepRuns"] = _items return _dict @classmethod @@ -114,28 +132,45 @@ class JobRun(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "tenantId": obj.get("tenantId"), - "workflowRunId": obj.get("workflowRunId"), - "workflowRun": WorkflowRun.from_dict(obj["workflowRun"]) if obj.get("workflowRun") is not None else None, - "jobId": obj.get("jobId"), - "job": Job.from_dict(obj["job"]) if obj.get("job") is not None else None, - "tickerId": obj.get("tickerId"), - "stepRuns": [StepRun.from_dict(_item) for _item in obj["stepRuns"]] if obj.get("stepRuns") is not None else None, - "status": obj.get("status"), - "result": obj.get("result"), - "startedAt": obj.get("startedAt"), - "finishedAt": obj.get("finishedAt"), - "timeoutAt": obj.get("timeoutAt"), - "cancelledAt": obj.get("cancelledAt"), - "cancelledReason": obj.get("cancelledReason"), - "cancelledError": obj.get("cancelledError") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "tenantId": obj.get("tenantId"), + "workflowRunId": obj.get("workflowRunId"), + "workflowRun": ( + WorkflowRun.from_dict(obj["workflowRun"]) + if obj.get("workflowRun") is not None + else None + ), + "jobId": obj.get("jobId"), + "job": ( + Job.from_dict(obj["job"]) if obj.get("job") is not None else None + ), + "tickerId": obj.get("tickerId"), + "stepRuns": ( + [StepRun.from_dict(_item) for _item in obj["stepRuns"]] + if obj.get("stepRuns") is not None + else None + ), + "status": obj.get("status"), + "result": obj.get("result"), + "startedAt": obj.get("startedAt"), + "finishedAt": obj.get("finishedAt"), + "timeoutAt": obj.get("timeoutAt"), + "cancelledAt": obj.get("cancelledAt"), + "cancelledReason": obj.get("cancelledReason"), + "cancelledError": obj.get("cancelledError"), + } + ) return _obj + from hatchet_sdk.clients.rest.models.step_run import StepRun from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun + # TODO: Rewrite to not use raise_errors JobRun.model_rebuild(raise_errors=False) - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/job_run_status.py b/python-sdk/hatchet_sdk/clients/rest/models/job_run_status.py index 4036f3452..3952edf03 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/job_run_status.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/job_run_status.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,15 +28,13 @@ class JobRunStatus(str, Enum): """ allowed enum values """ - PENDING = 'PENDING' - RUNNING = 'RUNNING' - SUCCEEDED = 'SUCCEEDED' - FAILED = 'FAILED' - CANCELLED = 'CANCELLED' + PENDING = "PENDING" + RUNNING = "RUNNING" + SUCCEEDED = "SUCCEEDED" + FAILED = "FAILED" + CANCELLED = "CANCELLED" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of JobRunStatus from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/link_github_repository_request.py b/python-sdk/hatchet_sdk/clients/rest/models/link_github_repository_request.py index 1cb673996..15642078c 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/link_github_repository_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/link_github_repository_request.py @@ -13,25 +13,39 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing_extensions import Annotated -from typing import Optional, Set -from typing_extensions import Self +from typing_extensions import Annotated, Self + class LinkGithubRepositoryRequest(BaseModel): """ LinkGithubRepositoryRequest - """ # noqa: E501 - installation_id: Annotated[str, Field(min_length=36, strict=True, max_length=36)] = Field(description="The repository name.", alias="installationId") - git_repo_name: StrictStr = Field(description="The repository name.", alias="gitRepoName") - git_repo_owner: StrictStr = Field(description="The repository owner.", alias="gitRepoOwner") - git_repo_branch: StrictStr = Field(description="The repository branch.", alias="gitRepoBranch") - __properties: ClassVar[List[str]] = ["installationId", "gitRepoName", "gitRepoOwner", "gitRepoBranch"] + """ # noqa: E501 + + installation_id: Annotated[ + str, Field(min_length=36, strict=True, max_length=36) + ] = Field(description="The repository name.", alias="installationId") + git_repo_name: StrictStr = Field( + description="The repository name.", alias="gitRepoName" + ) + git_repo_owner: StrictStr = Field( + description="The repository owner.", alias="gitRepoOwner" + ) + git_repo_branch: StrictStr = Field( + description="The repository branch.", alias="gitRepoBranch" + ) + __properties: ClassVar[List[str]] = [ + "installationId", + "gitRepoName", + "gitRepoOwner", + "gitRepoBranch", + ] model_config = { "populate_by_name": True, @@ -39,7 +53,6 @@ class LinkGithubRepositoryRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -64,8 +77,7 @@ class LinkGithubRepositoryRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -83,12 +95,12 @@ class LinkGithubRepositoryRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "installationId": obj.get("installationId"), - "gitRepoName": obj.get("gitRepoName"), - "gitRepoOwner": obj.get("gitRepoOwner"), - "gitRepoBranch": obj.get("gitRepoBranch") - }) + _obj = cls.model_validate( + { + "installationId": obj.get("installationId"), + "gitRepoName": obj.get("gitRepoName"), + "gitRepoOwner": obj.get("gitRepoOwner"), + "gitRepoBranch": obj.get("gitRepoBranch"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/list_api_tokens_response.py b/python-sdk/hatchet_sdk/clients/rest/models/list_api_tokens_response.py index df4e5fc55..a75038e47 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/list_api_tokens_response.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/list_api_tokens_response.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_token import APIToken from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse -from typing import Optional, Set -from typing_extensions import Self + class ListAPITokensResponse(BaseModel): """ ListAPITokensResponse - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[APIToken]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class ListAPITokensResponse(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class ListAPITokensResponse(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class ListAPITokensResponse(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class ListAPITokensResponse(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [APIToken.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [APIToken.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/list_github_app_installations_response.py b/python-sdk/hatchet_sdk/clients/rest/models/list_github_app_installations_response.py index 79577f8d9..3f30aa9a7 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/list_github_app_installations_response.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/list_github_app_installations_response.py @@ -13,21 +13,26 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.github_app_installation import GithubAppInstallation -from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.github_app_installation import ( + GithubAppInstallation, +) +from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse + + class ListGithubAppInstallationsResponse(BaseModel): """ ListGithubAppInstallationsResponse - """ # noqa: E501 + """ # noqa: E501 + pagination: PaginationResponse rows: List[GithubAppInstallation] __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +43,6 @@ class ListGithubAppInstallationsResponse(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +67,7 @@ class ListGithubAppInstallationsResponse(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +76,14 @@ class ListGithubAppInstallationsResponse(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +95,18 @@ class ListGithubAppInstallationsResponse(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [GithubAppInstallation.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [GithubAppInstallation.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/list_pull_requests_response.py b/python-sdk/hatchet_sdk/clients/rest/models/list_pull_requests_response.py index 83c0701f4..252f9e835 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/list_pull_requests_response.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/list_pull_requests_response.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.pull_request import PullRequest -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.pull_request import PullRequest + + class ListPullRequestsResponse(BaseModel): """ ListPullRequestsResponse - """ # noqa: E501 + """ # noqa: E501 + pull_requests: List[PullRequest] = Field(alias="pullRequests") __properties: ClassVar[List[str]] = ["pullRequests"] @@ -36,7 +39,6 @@ class ListPullRequestsResponse(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +63,7 @@ class ListPullRequestsResponse(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -75,7 +76,7 @@ class ListPullRequestsResponse(BaseModel): for _item in self.pull_requests: if _item: _items.append(_item.to_dict()) - _dict['pullRequests'] = _items + _dict["pullRequests"] = _items return _dict @classmethod @@ -87,9 +88,13 @@ class ListPullRequestsResponse(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pullRequests": [PullRequest.from_dict(_item) for _item in obj["pullRequests"]] if obj.get("pullRequests") is not None else None - }) + _obj = cls.model_validate( + { + "pullRequests": ( + [PullRequest.from_dict(_item) for _item in obj["pullRequests"]] + if obj.get("pullRequests") is not None + else None + ) + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/list_sns_integrations.py b/python-sdk/hatchet_sdk/clients/rest/models/list_sns_integrations.py index 18647ba8c..8316b631e 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/list_sns_integrations.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/list_sns_integrations.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.sns_integration import SNSIntegration -from typing import Optional, Set -from typing_extensions import Self + class ListSNSIntegrations(BaseModel): """ ListSNSIntegrations - """ # noqa: E501 + """ # noqa: E501 + pagination: PaginationResponse rows: List[SNSIntegration] __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class ListSNSIntegrations(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class ListSNSIntegrations(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class ListSNSIntegrations(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class ListSNSIntegrations(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [SNSIntegration.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [SNSIntegration.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/log_line.py b/python-sdk/hatchet_sdk/clients/rest/models/log_line.py index 2508d20f2..ef7448186 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/log_line.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/log_line.py @@ -13,21 +13,25 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class LogLine(BaseModel): """ LogLine - """ # noqa: E501 - created_at: datetime = Field(description="The creation date of the log line.", alias="createdAt") + """ # noqa: E501 + + created_at: datetime = Field( + description="The creation date of the log line.", alias="createdAt" + ) message: StrictStr = Field(description="The log message.") metadata: Dict[str, Any] = Field(description="The log metadata.") __properties: ClassVar[List[str]] = ["createdAt", "message", "metadata"] @@ -38,7 +42,6 @@ class LogLine(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +66,7 @@ class LogLine(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -82,11 +84,11 @@ class LogLine(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "createdAt": obj.get("createdAt"), - "message": obj.get("message"), - "metadata": obj.get("metadata") - }) + _obj = cls.model_validate( + { + "createdAt": obj.get("createdAt"), + "message": obj.get("message"), + "metadata": obj.get("metadata"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/log_line_level.py b/python-sdk/hatchet_sdk/clients/rest/models/log_line_level.py index daba89ed6..63fbec414 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/log_line_level.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/log_line_level.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,14 +28,12 @@ class LogLineLevel(str, Enum): """ allowed enum values """ - DEBUG = 'DEBUG' - INFO = 'INFO' - WARN = 'WARN' - ERROR = 'ERROR' + DEBUG = "DEBUG" + INFO = "INFO" + WARN = "WARN" + ERROR = "ERROR" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of LogLineLevel from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/log_line_list.py b/python-sdk/hatchet_sdk/clients/rest/models/log_line_list.py index 83c136585..2fc277a73 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/log_line_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/log_line_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.log_line import LogLine from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse -from typing import Optional, Set -from typing_extensions import Self + class LogLineList(BaseModel): """ LogLineList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[LogLine]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class LogLineList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class LogLineList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class LogLineList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class LogLineList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [LogLine.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [LogLine.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_direction.py b/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_direction.py index 6c25dae79..5f66f59b3 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_direction.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_direction.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,12 +28,10 @@ class LogLineOrderByDirection(str, Enum): """ allowed enum values """ - ASC = 'asc' - DESC = 'desc' + ASC = "asc" + DESC = "desc" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of LogLineOrderByDirection from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_field.py b/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_field.py index f0cb01d35..93b925263 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_field.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/log_line_order_by_field.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,11 +28,9 @@ class LogLineOrderByField(str, Enum): """ allowed enum values """ - CREATEDAT = 'createdAt' + CREATEDAT = "createdAt" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of LogLineOrderByField from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/pagination_response.py b/python-sdk/hatchet_sdk/clients/rest/models/pagination_response.py index 12dc3c1db..c76266b64 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/pagination_response.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/pagination_response.py @@ -13,22 +13,28 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class PaginationResponse(BaseModel): """ PaginationResponse - """ # noqa: E501 - current_page: Optional[StrictInt] = Field(default=None, description="the current page") + """ # noqa: E501 + + current_page: Optional[StrictInt] = Field( + default=None, description="the current page" + ) next_page: Optional[StrictInt] = Field(default=None, description="the next page") - num_pages: Optional[StrictInt] = Field(default=None, description="the total number of pages for listing") + num_pages: Optional[StrictInt] = Field( + default=None, description="the total number of pages for listing" + ) __properties: ClassVar[List[str]] = ["current_page", "next_page", "num_pages"] model_config = { @@ -37,7 +43,6 @@ class PaginationResponse(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -62,8 +67,7 @@ class PaginationResponse(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -81,11 +85,11 @@ class PaginationResponse(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "current_page": obj.get("current_page"), - "next_page": obj.get("next_page"), - "num_pages": obj.get("num_pages") - }) + _obj = cls.model_validate( + { + "current_page": obj.get("current_page"), + "next_page": obj.get("next_page"), + "num_pages": obj.get("num_pages"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/pull_request.py b/python-sdk/hatchet_sdk/clients/rest/models/pull_request.py index c266b33d9..b835f26e7 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/pull_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/pull_request.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt, StrictStr -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.pull_request_state import PullRequestState -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.pull_request_state import PullRequestState + + class PullRequest(BaseModel): """ PullRequest - """ # noqa: E501 + """ # noqa: E501 + repository_owner: StrictStr = Field(alias="repositoryOwner") repository_name: StrictStr = Field(alias="repositoryName") pull_request_id: StrictInt = Field(alias="pullRequestID") @@ -35,7 +38,16 @@ class PullRequest(BaseModel): pull_request_head_branch: StrictStr = Field(alias="pullRequestHeadBranch") pull_request_base_branch: StrictStr = Field(alias="pullRequestBaseBranch") pull_request_state: PullRequestState = Field(alias="pullRequestState") - __properties: ClassVar[List[str]] = ["repositoryOwner", "repositoryName", "pullRequestID", "pullRequestTitle", "pullRequestNumber", "pullRequestHeadBranch", "pullRequestBaseBranch", "pullRequestState"] + __properties: ClassVar[List[str]] = [ + "repositoryOwner", + "repositoryName", + "pullRequestID", + "pullRequestTitle", + "pullRequestNumber", + "pullRequestHeadBranch", + "pullRequestBaseBranch", + "pullRequestState", + ] model_config = { "populate_by_name": True, @@ -43,7 +55,6 @@ class PullRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -68,8 +79,7 @@ class PullRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -87,16 +97,16 @@ class PullRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "repositoryOwner": obj.get("repositoryOwner"), - "repositoryName": obj.get("repositoryName"), - "pullRequestID": obj.get("pullRequestID"), - "pullRequestTitle": obj.get("pullRequestTitle"), - "pullRequestNumber": obj.get("pullRequestNumber"), - "pullRequestHeadBranch": obj.get("pullRequestHeadBranch"), - "pullRequestBaseBranch": obj.get("pullRequestBaseBranch"), - "pullRequestState": obj.get("pullRequestState") - }) + _obj = cls.model_validate( + { + "repositoryOwner": obj.get("repositoryOwner"), + "repositoryName": obj.get("repositoryName"), + "pullRequestID": obj.get("pullRequestID"), + "pullRequestTitle": obj.get("pullRequestTitle"), + "pullRequestNumber": obj.get("pullRequestNumber"), + "pullRequestHeadBranch": obj.get("pullRequestHeadBranch"), + "pullRequestBaseBranch": obj.get("pullRequestBaseBranch"), + "pullRequestState": obj.get("pullRequestState"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/pull_request_state.py b/python-sdk/hatchet_sdk/clients/rest/models/pull_request_state.py index 9cd42f0c6..a44d06cc7 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/pull_request_state.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/pull_request_state.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,12 +28,10 @@ class PullRequestState(str, Enum): """ allowed enum values """ - OPEN = 'open' - CLOSED = 'closed' + OPEN = "open" + CLOSED = "closed" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of PullRequestState from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/reject_invite_request.py b/python-sdk/hatchet_sdk/clients/rest/models/reject_invite_request.py index 342a3e84e..faf45ee83 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/reject_invite_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/reject_invite_request.py @@ -13,20 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from typing_extensions import Annotated -from typing import Optional, Set -from typing_extensions import Self +from typing_extensions import Annotated, Self + class RejectInviteRequest(BaseModel): """ RejectInviteRequest - """ # noqa: E501 + """ # noqa: E501 + invite: Annotated[str, Field(min_length=36, strict=True, max_length=36)] __properties: ClassVar[List[str]] = ["invite"] @@ -36,7 +37,6 @@ class RejectInviteRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +61,7 @@ class RejectInviteRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,9 +79,5 @@ class RejectInviteRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "invite": obj.get("invite") - }) + _obj = cls.model_validate({"invite": obj.get("invite")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/replay_event_request.py b/python-sdk/hatchet_sdk/clients/rest/models/replay_event_request.py index 08eb39e8f..4a31fbd78 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/replay_event_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/replay_event_request.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from typing_extensions import Annotated -from typing import Optional, Set -from typing_extensions import Self +from typing_extensions import Annotated, Self + class ReplayEventRequest(BaseModel): """ ReplayEventRequest - """ # noqa: E501 - event_ids: List[Annotated[str, Field(min_length=36, strict=True, max_length=36)]] = Field(alias="eventIds") + """ # noqa: E501 + + event_ids: List[ + Annotated[str, Field(min_length=36, strict=True, max_length=36)] + ] = Field(alias="eventIds") __properties: ClassVar[List[str]] = ["eventIds"] model_config = { @@ -36,7 +39,6 @@ class ReplayEventRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +63,7 @@ class ReplayEventRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,9 +81,5 @@ class ReplayEventRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "eventIds": obj.get("eventIds") - }) + _obj = cls.model_validate({"eventIds": obj.get("eventIds")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/rerun_step_run_request.py b/python-sdk/hatchet_sdk/clients/rest/models/rerun_step_run_request.py index e77b79bb0..5ab339870 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/rerun_step_run_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/rerun_step_run_request.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class RerunStepRunRequest(BaseModel): """ RerunStepRunRequest - """ # noqa: E501 + """ # noqa: E501 + input: Dict[str, Any] __properties: ClassVar[List[str]] = ["input"] @@ -35,7 +37,6 @@ class RerunStepRunRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +61,7 @@ class RerunStepRunRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +79,5 @@ class RerunStepRunRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "input": obj.get("input") - }) + _obj = cls.model_validate({"input": obj.get("input")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/sns_integration.py b/python-sdk/hatchet_sdk/clients/rest/models/sns_integration.py index b3b18d517..543561603 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/sns_integration.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/sns_integration.py @@ -13,25 +13,40 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta + + class SNSIntegration(BaseModel): """ SNSIntegration - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta - tenant_id: StrictStr = Field(description="The unique identifier for the tenant that the SNS integration belongs to.", alias="tenantId") - topic_arn: StrictStr = Field(description="The Amazon Resource Name (ARN) of the SNS topic.", alias="topicArn") - ingest_url: Optional[StrictStr] = Field(default=None, description="The URL to send SNS messages to.", alias="ingestUrl") - __properties: ClassVar[List[str]] = ["metadata", "tenantId", "topicArn", "ingestUrl"] + tenant_id: StrictStr = Field( + description="The unique identifier for the tenant that the SNS integration belongs to.", + alias="tenantId", + ) + topic_arn: StrictStr = Field( + description="The Amazon Resource Name (ARN) of the SNS topic.", alias="topicArn" + ) + ingest_url: Optional[StrictStr] = Field( + default=None, description="The URL to send SNS messages to.", alias="ingestUrl" + ) + __properties: ClassVar[List[str]] = [ + "metadata", + "tenantId", + "topicArn", + "ingestUrl", + ] model_config = { "populate_by_name": True, @@ -39,7 +54,6 @@ class SNSIntegration(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -64,8 +78,7 @@ class SNSIntegration(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -74,7 +87,7 @@ class SNSIntegration(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() return _dict @classmethod @@ -86,12 +99,16 @@ class SNSIntegration(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "tenantId": obj.get("tenantId"), - "topicArn": obj.get("topicArn"), - "ingestUrl": obj.get("ingestUrl") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "tenantId": obj.get("tenantId"), + "topicArn": obj.get("topicArn"), + "ingestUrl": obj.get("ingestUrl"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/step.py b/python-sdk/hatchet_sdk/clients/rest/models/step.py index d1d91ca9f..20183de10 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/step.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/step.py @@ -13,29 +13,45 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta + + class Step(BaseModel): """ Step - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta - readable_id: StrictStr = Field(description="The readable id of the step.", alias="readableId") + readable_id: StrictStr = Field( + description="The readable id of the step.", alias="readableId" + ) tenant_id: StrictStr = Field(alias="tenantId") job_id: StrictStr = Field(alias="jobId") action: StrictStr - timeout: Optional[StrictStr] = Field(default=None, description="The timeout of the step.") + timeout: Optional[StrictStr] = Field( + default=None, description="The timeout of the step." + ) children: Optional[List[StrictStr]] = None parents: Optional[List[StrictStr]] = None - __properties: ClassVar[List[str]] = ["metadata", "readableId", "tenantId", "jobId", "action", "timeout", "children", "parents"] + __properties: ClassVar[List[str]] = [ + "metadata", + "readableId", + "tenantId", + "jobId", + "action", + "timeout", + "children", + "parents", + ] model_config = { "populate_by_name": True, @@ -43,7 +59,6 @@ class Step(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -68,8 +83,7 @@ class Step(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -78,7 +92,7 @@ class Step(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() return _dict @classmethod @@ -90,16 +104,20 @@ class Step(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "readableId": obj.get("readableId"), - "tenantId": obj.get("tenantId"), - "jobId": obj.get("jobId"), - "action": obj.get("action"), - "timeout": obj.get("timeout"), - "children": obj.get("children"), - "parents": obj.get("parents") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "readableId": obj.get("readableId"), + "tenantId": obj.get("tenantId"), + "jobId": obj.get("jobId"), + "action": obj.get("action"), + "timeout": obj.get("timeout"), + "children": obj.get("children"), + "parents": obj.get("parents"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/step_run.py b/python-sdk/hatchet_sdk/clients/rest/models/step_run.py index ddb8a9732..dcd102290 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/step_run.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/step_run.py @@ -13,23 +13,26 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field, StrictInt, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.step import Step from hatchet_sdk.clients.rest.models.step_run_status import StepRunStatus -from typing import Optional, Set -from typing_extensions import Self + class StepRun(BaseModel): """ StepRun - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta tenant_id: StrictStr = Field(alias="tenantId") job_run_id: StrictStr = Field(alias="jobRunId") @@ -38,7 +41,9 @@ class StepRun(BaseModel): step: Optional[Step] = None children: Optional[List[StrictStr]] = None parents: Optional[List[StrictStr]] = None - child_workflow_runs: Optional[List[StrictStr]] = Field(default=None, alias="childWorkflowRuns") + child_workflow_runs: Optional[List[StrictStr]] = Field( + default=None, alias="childWorkflowRuns" + ) worker_id: Optional[StrictStr] = Field(default=None, alias="workerId") input: Optional[StrictStr] = None output: Optional[StrictStr] = None @@ -49,14 +54,45 @@ class StepRun(BaseModel): started_at: Optional[datetime] = Field(default=None, alias="startedAt") started_at_epoch: Optional[StrictInt] = Field(default=None, alias="startedAtEpoch") finished_at: Optional[datetime] = Field(default=None, alias="finishedAt") - finished_at_epoch: Optional[StrictInt] = Field(default=None, alias="finishedAtEpoch") + finished_at_epoch: Optional[StrictInt] = Field( + default=None, alias="finishedAtEpoch" + ) timeout_at: Optional[datetime] = Field(default=None, alias="timeoutAt") timeout_at_epoch: Optional[StrictInt] = Field(default=None, alias="timeoutAtEpoch") cancelled_at: Optional[datetime] = Field(default=None, alias="cancelledAt") - cancelled_at_epoch: Optional[StrictInt] = Field(default=None, alias="cancelledAtEpoch") + cancelled_at_epoch: Optional[StrictInt] = Field( + default=None, alias="cancelledAtEpoch" + ) cancelled_reason: Optional[StrictStr] = Field(default=None, alias="cancelledReason") cancelled_error: Optional[StrictStr] = Field(default=None, alias="cancelledError") - __properties: ClassVar[List[str]] = ["metadata", "tenantId", "jobRunId", "jobRun", "stepId", "step", "children", "parents", "childWorkflowRuns", "workerId", "input", "output", "status", "requeueAfter", "result", "error", "startedAt", "startedAtEpoch", "finishedAt", "finishedAtEpoch", "timeoutAt", "timeoutAtEpoch", "cancelledAt", "cancelledAtEpoch", "cancelledReason", "cancelledError"] + __properties: ClassVar[List[str]] = [ + "metadata", + "tenantId", + "jobRunId", + "jobRun", + "stepId", + "step", + "children", + "parents", + "childWorkflowRuns", + "workerId", + "input", + "output", + "status", + "requeueAfter", + "result", + "error", + "startedAt", + "startedAtEpoch", + "finishedAt", + "finishedAtEpoch", + "timeoutAt", + "timeoutAtEpoch", + "cancelledAt", + "cancelledAtEpoch", + "cancelledReason", + "cancelledError", + ] model_config = { "populate_by_name": True, @@ -64,7 +100,6 @@ class StepRun(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -89,8 +124,7 @@ class StepRun(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -99,13 +133,13 @@ class StepRun(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of job_run if self.job_run: - _dict['jobRun'] = self.job_run.to_dict() + _dict["jobRun"] = self.job_run.to_dict() # override the default output from pydantic by calling `to_dict()` of step if self.step: - _dict['step'] = self.step.to_dict() + _dict["step"] = self.step.to_dict() return _dict @classmethod @@ -117,37 +151,50 @@ class StepRun(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "tenantId": obj.get("tenantId"), - "jobRunId": obj.get("jobRunId"), - "jobRun": JobRun.from_dict(obj["jobRun"]) if obj.get("jobRun") is not None else None, - "stepId": obj.get("stepId"), - "step": Step.from_dict(obj["step"]) if obj.get("step") is not None else None, - "children": obj.get("children"), - "parents": obj.get("parents"), - "childWorkflowRuns": obj.get("childWorkflowRuns"), - "workerId": obj.get("workerId"), - "input": obj.get("input"), - "output": obj.get("output"), - "status": obj.get("status"), - "requeueAfter": obj.get("requeueAfter"), - "result": obj.get("result"), - "error": obj.get("error"), - "startedAt": obj.get("startedAt"), - "startedAtEpoch": obj.get("startedAtEpoch"), - "finishedAt": obj.get("finishedAt"), - "finishedAtEpoch": obj.get("finishedAtEpoch"), - "timeoutAt": obj.get("timeoutAt"), - "timeoutAtEpoch": obj.get("timeoutAtEpoch"), - "cancelledAt": obj.get("cancelledAt"), - "cancelledAtEpoch": obj.get("cancelledAtEpoch"), - "cancelledReason": obj.get("cancelledReason"), - "cancelledError": obj.get("cancelledError") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "tenantId": obj.get("tenantId"), + "jobRunId": obj.get("jobRunId"), + "jobRun": ( + JobRun.from_dict(obj["jobRun"]) + if obj.get("jobRun") is not None + else None + ), + "stepId": obj.get("stepId"), + "step": ( + Step.from_dict(obj["step"]) if obj.get("step") is not None else None + ), + "children": obj.get("children"), + "parents": obj.get("parents"), + "childWorkflowRuns": obj.get("childWorkflowRuns"), + "workerId": obj.get("workerId"), + "input": obj.get("input"), + "output": obj.get("output"), + "status": obj.get("status"), + "requeueAfter": obj.get("requeueAfter"), + "result": obj.get("result"), + "error": obj.get("error"), + "startedAt": obj.get("startedAt"), + "startedAtEpoch": obj.get("startedAtEpoch"), + "finishedAt": obj.get("finishedAt"), + "finishedAtEpoch": obj.get("finishedAtEpoch"), + "timeoutAt": obj.get("timeoutAt"), + "timeoutAtEpoch": obj.get("timeoutAtEpoch"), + "cancelledAt": obj.get("cancelledAt"), + "cancelledAtEpoch": obj.get("cancelledAtEpoch"), + "cancelledReason": obj.get("cancelledReason"), + "cancelledError": obj.get("cancelledError"), + } + ) return _obj + from hatchet_sdk.clients.rest.models.job_run import JobRun + # TODO: Rewrite to not use raise_errors StepRun.model_rebuild(raise_errors=False) - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/step_run_diff.py b/python-sdk/hatchet_sdk/clients/rest/models/step_run_diff.py index c9a8ce50d..bac6881ef 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/step_run_diff.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/step_run_diff.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class StepRunDiff(BaseModel): """ StepRunDiff - """ # noqa: E501 + """ # noqa: E501 + key: StrictStr original: StrictStr modified: StrictStr @@ -37,7 +39,6 @@ class StepRunDiff(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -62,8 +63,7 @@ class StepRunDiff(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -81,11 +81,11 @@ class StepRunDiff(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "key": obj.get("key"), - "original": obj.get("original"), - "modified": obj.get("modified") - }) + _obj = cls.model_validate( + { + "key": obj.get("key"), + "original": obj.get("original"), + "modified": obj.get("modified"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/step_run_status.py b/python-sdk/hatchet_sdk/clients/rest/models/step_run_status.py index c937891ad..2672aacf3 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/step_run_status.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/step_run_status.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,17 +28,15 @@ class StepRunStatus(str, Enum): """ allowed enum values """ - PENDING = 'PENDING' - PENDING_ASSIGNMENT = 'PENDING_ASSIGNMENT' - ASSIGNED = 'ASSIGNED' - RUNNING = 'RUNNING' - SUCCEEDED = 'SUCCEEDED' - FAILED = 'FAILED' - CANCELLED = 'CANCELLED' + PENDING = "PENDING" + PENDING_ASSIGNMENT = "PENDING_ASSIGNMENT" + ASSIGNED = "ASSIGNED" + RUNNING = "RUNNING" + SUCCEEDED = "SUCCEEDED" + FAILED = "FAILED" + CANCELLED = "CANCELLED" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of StepRunStatus from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/tenant.py b/python-sdk/hatchet_sdk/clients/rest/models/tenant.py index b00a47d25..fa48aeeba 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/tenant.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/tenant.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta + + class Tenant(BaseModel): """ Tenant - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta name: StrictStr = Field(description="The name of the tenant.") slug: StrictStr = Field(description="The slug of the tenant.") @@ -38,7 +41,6 @@ class Tenant(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class Tenant(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,7 +74,7 @@ class Tenant(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() return _dict @classmethod @@ -85,11 +86,15 @@ class Tenant(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "name": obj.get("name"), - "slug": obj.get("slug") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "name": obj.get("name"), + "slug": obj.get("slug"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite.py b/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite.py index 5f11c6aad..97d356eda 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite.py @@ -13,29 +13,44 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole -from typing import Optional, Set -from typing_extensions import Self + class TenantInvite(BaseModel): """ TenantInvite - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta email: StrictStr = Field(description="The email of the user to invite.") role: TenantMemberRole = Field(description="The role of the user in the tenant.") - tenant_id: StrictStr = Field(description="The tenant id associated with this tenant invite.", alias="tenantId") - tenant_name: Optional[StrictStr] = Field(default=None, description="The tenant name for the tenant.", alias="tenantName") + tenant_id: StrictStr = Field( + description="The tenant id associated with this tenant invite.", + alias="tenantId", + ) + tenant_name: Optional[StrictStr] = Field( + default=None, description="The tenant name for the tenant.", alias="tenantName" + ) expires: datetime = Field(description="The time that this invite expires.") - __properties: ClassVar[List[str]] = ["metadata", "email", "role", "tenantId", "tenantName", "expires"] + __properties: ClassVar[List[str]] = [ + "metadata", + "email", + "role", + "tenantId", + "tenantName", + "expires", + ] model_config = { "populate_by_name": True, @@ -43,7 +58,6 @@ class TenantInvite(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -68,8 +82,7 @@ class TenantInvite(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -78,7 +91,7 @@ class TenantInvite(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() return _dict @classmethod @@ -90,14 +103,18 @@ class TenantInvite(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "email": obj.get("email"), - "role": obj.get("role"), - "tenantId": obj.get("tenantId"), - "tenantName": obj.get("tenantName"), - "expires": obj.get("expires") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "email": obj.get("email"), + "role": obj.get("role"), + "tenantId": obj.get("tenantId"), + "tenantName": obj.get("tenantName"), + "expires": obj.get("expires"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite_list.py b/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite_list.py index 17173370a..42c0c3c36 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/tenant_invite_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.tenant_invite import TenantInvite -from typing import Optional, Set -from typing_extensions import Self + class TenantInviteList(BaseModel): """ TenantInviteList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[TenantInvite]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class TenantInviteList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class TenantInviteList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class TenantInviteList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class TenantInviteList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [TenantInvite.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [TenantInvite.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/tenant_list.py b/python-sdk/hatchet_sdk/clients/rest/models/tenant_list.py index c9f4fe5f4..bba332bbe 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/tenant_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/tenant_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.tenant import Tenant -from typing import Optional, Set -from typing_extensions import Self + class TenantList(BaseModel): """ TenantList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[Tenant]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class TenantList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class TenantList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class TenantList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class TenantList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [Tenant.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [Tenant.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/tenant_member.py b/python-sdk/hatchet_sdk/clients/rest/models/tenant_member.py index d444e177b..6c1b8d550 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/tenant_member.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/tenant_member.py @@ -13,27 +13,34 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.tenant import Tenant from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole from hatchet_sdk.clients.rest.models.user_tenant_public import UserTenantPublic -from typing import Optional, Set -from typing_extensions import Self + class TenantMember(BaseModel): """ TenantMember - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta - user: UserTenantPublic = Field(description="The user associated with this tenant member.") + user: UserTenantPublic = Field( + description="The user associated with this tenant member." + ) role: TenantMemberRole = Field(description="The role of the user in the tenant.") - tenant: Optional[Tenant] = Field(default=None, description="The tenant associated with this tenant member.") + tenant: Optional[Tenant] = Field( + default=None, description="The tenant associated with this tenant member." + ) __properties: ClassVar[List[str]] = ["metadata", "user", "role", "tenant"] model_config = { @@ -42,7 +49,6 @@ class TenantMember(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -67,8 +73,7 @@ class TenantMember(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -77,13 +82,13 @@ class TenantMember(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of user if self.user: - _dict['user'] = self.user.to_dict() + _dict["user"] = self.user.to_dict() # override the default output from pydantic by calling `to_dict()` of tenant if self.tenant: - _dict['tenant'] = self.tenant.to_dict() + _dict["tenant"] = self.tenant.to_dict() return _dict @classmethod @@ -95,12 +100,24 @@ class TenantMember(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "user": UserTenantPublic.from_dict(obj["user"]) if obj.get("user") is not None else None, - "role": obj.get("role"), - "tenant": Tenant.from_dict(obj["tenant"]) if obj.get("tenant") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "user": ( + UserTenantPublic.from_dict(obj["user"]) + if obj.get("user") is not None + else None + ), + "role": obj.get("role"), + "tenant": ( + Tenant.from_dict(obj["tenant"]) + if obj.get("tenant") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_list.py b/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_list.py index e3938c587..194b5b97c 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.tenant_member import TenantMember -from typing import Optional, Set -from typing_extensions import Self + class TenantMemberList(BaseModel): """ TenantMemberList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[TenantMember]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class TenantMemberList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class TenantMemberList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class TenantMemberList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class TenantMemberList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [TenantMember.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [TenantMember.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_role.py b/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_role.py index fd89bb334..446c70446 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_role.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/tenant_member_role.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,13 +28,11 @@ class TenantMemberRole(str, Enum): """ allowed enum values """ - OWNER = 'OWNER' - ADMIN = 'ADMIN' - MEMBER = 'MEMBER' + OWNER = "OWNER" + ADMIN = "ADMIN" + MEMBER = "MEMBER" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of TenantMemberRole from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/trigger_workflow_run_request.py b/python-sdk/hatchet_sdk/clients/rest/models/trigger_workflow_run_request.py index e29d1d20c..de1eae5e5 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/trigger_workflow_run_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/trigger_workflow_run_request.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class TriggerWorkflowRunRequest(BaseModel): """ TriggerWorkflowRunRequest - """ # noqa: E501 + """ # noqa: E501 + input: Dict[str, Any] __properties: ClassVar[List[str]] = ["input"] @@ -35,7 +37,6 @@ class TriggerWorkflowRunRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +61,7 @@ class TriggerWorkflowRunRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +79,5 @@ class TriggerWorkflowRunRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "input": obj.get("input") - }) + _obj = cls.model_validate({"input": obj.get("input")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/update_tenant_invite_request.py b/python-sdk/hatchet_sdk/clients/rest/models/update_tenant_invite_request.py index 6fd02f17e..55a75f50c 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/update_tenant_invite_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/update_tenant_invite_request.py @@ -13,20 +13,23 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field -from typing import Any, ClassVar, Dict, List -from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.tenant_member_role import TenantMemberRole + + class UpdateTenantInviteRequest(BaseModel): """ UpdateTenantInviteRequest - """ # noqa: E501 + """ # noqa: E501 + role: TenantMemberRole = Field(description="The role of the user in the tenant.") __properties: ClassVar[List[str]] = ["role"] @@ -36,7 +39,6 @@ class UpdateTenantInviteRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +63,7 @@ class UpdateTenantInviteRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,9 +81,5 @@ class UpdateTenantInviteRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "role": obj.get("role") - }) + _obj = cls.model_validate({"role": obj.get("role")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/user.py b/python-sdk/hatchet_sdk/clients/rest/models/user.py index 3fe66874a..24b96c4fb 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/user.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/user.py @@ -13,26 +13,44 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictBool, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta + + class User(BaseModel): """ User - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta - name: Optional[StrictStr] = Field(default=None, description="The display name of the user.") + name: Optional[StrictStr] = Field( + default=None, description="The display name of the user." + ) email: StrictStr = Field(description="The email address of the user.") - email_verified: StrictBool = Field(description="Whether the user has verified their email address.", alias="emailVerified") - has_password: Optional[StrictBool] = Field(default=None, description="Whether the user has a password set.", alias="hasPassword") - __properties: ClassVar[List[str]] = ["metadata", "name", "email", "emailVerified", "hasPassword"] + email_verified: StrictBool = Field( + description="Whether the user has verified their email address.", + alias="emailVerified", + ) + has_password: Optional[StrictBool] = Field( + default=None, + description="Whether the user has a password set.", + alias="hasPassword", + ) + __properties: ClassVar[List[str]] = [ + "metadata", + "name", + "email", + "emailVerified", + "hasPassword", + ] model_config = { "populate_by_name": True, @@ -40,7 +58,6 @@ class User(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -65,8 +82,7 @@ class User(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -75,7 +91,7 @@ class User(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() return _dict @classmethod @@ -87,13 +103,17 @@ class User(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "name": obj.get("name"), - "email": obj.get("email"), - "emailVerified": obj.get("emailVerified"), - "hasPassword": obj.get("hasPassword") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "name": obj.get("name"), + "email": obj.get("email"), + "emailVerified": obj.get("emailVerified"), + "hasPassword": obj.get("hasPassword"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/user_change_password_request.py b/python-sdk/hatchet_sdk/clients/rest/models/user_change_password_request.py index 73a551d06..49ac1d5c5 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/user_change_password_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/user_change_password_request.py @@ -13,21 +13,25 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class UserChangePasswordRequest(BaseModel): """ UserChangePasswordRequest - """ # noqa: E501 + """ # noqa: E501 + password: StrictStr = Field(description="The password of the user.") - new_password: StrictStr = Field(description="The new password for the user.", alias="newPassword") + new_password: StrictStr = Field( + description="The new password for the user.", alias="newPassword" + ) __properties: ClassVar[List[str]] = ["password", "newPassword"] model_config = { @@ -36,7 +40,6 @@ class UserChangePasswordRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +64,7 @@ class UserChangePasswordRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +82,7 @@ class UserChangePasswordRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "password": obj.get("password"), - "newPassword": obj.get("newPassword") - }) + _obj = cls.model_validate( + {"password": obj.get("password"), "newPassword": obj.get("newPassword")} + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/user_login_request.py b/python-sdk/hatchet_sdk/clients/rest/models/user_login_request.py index fbf313645..596c433e6 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/user_login_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/user_login_request.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class UserLoginRequest(BaseModel): """ UserLoginRequest - """ # noqa: E501 + """ # noqa: E501 + email: StrictStr = Field(description="The email address of the user.") password: StrictStr = Field(description="The password of the user.") __properties: ClassVar[List[str]] = ["email", "password"] @@ -36,7 +38,6 @@ class UserLoginRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +62,7 @@ class UserLoginRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +80,7 @@ class UserLoginRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "email": obj.get("email"), - "password": obj.get("password") - }) + _obj = cls.model_validate( + {"email": obj.get("email"), "password": obj.get("password")} + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/user_register_request.py b/python-sdk/hatchet_sdk/clients/rest/models/user_register_request.py index ea8da249b..7fb7dbfdd 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/user_register_request.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/user_register_request.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class UserRegisterRequest(BaseModel): """ UserRegisterRequest - """ # noqa: E501 + """ # noqa: E501 + name: StrictStr = Field(description="The name of the user.") email: StrictStr = Field(description="The email address of the user.") password: StrictStr = Field(description="The password of the user.") @@ -37,7 +39,6 @@ class UserRegisterRequest(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -62,8 +63,7 @@ class UserRegisterRequest(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -81,11 +81,11 @@ class UserRegisterRequest(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "name": obj.get("name"), - "email": obj.get("email"), - "password": obj.get("password") - }) + _obj = cls.model_validate( + { + "name": obj.get("name"), + "email": obj.get("email"), + "password": obj.get("password"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_memberships_list.py b/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_memberships_list.py index 6be797f76..2a9b0f583 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_memberships_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_memberships_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.tenant_member import TenantMember -from typing import Optional, Set -from typing_extensions import Self + class UserTenantMembershipsList(BaseModel): """ UserTenantMembershipsList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[TenantMember]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class UserTenantMembershipsList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class UserTenantMembershipsList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class UserTenantMembershipsList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class UserTenantMembershipsList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [TenantMember.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [TenantMember.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_public.py b/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_public.py index 43888940b..eb6e12977 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_public.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/user_tenant_public.py @@ -13,21 +13,25 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class UserTenantPublic(BaseModel): """ UserTenantPublic - """ # noqa: E501 + """ # noqa: E501 + email: StrictStr = Field(description="The email address of the user.") - name: Optional[StrictStr] = Field(default=None, description="The display name of the user.") + name: Optional[StrictStr] = Field( + default=None, description="The display name of the user." + ) __properties: ClassVar[List[str]] = ["email", "name"] model_config = { @@ -36,7 +40,6 @@ class UserTenantPublic(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +64,7 @@ class UserTenantPublic(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +82,5 @@ class UserTenantPublic(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "email": obj.get("email"), - "name": obj.get("name") - }) + _obj = cls.model_validate({"email": obj.get("email"), "name": obj.get("name")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/worker.py b/python-sdk/hatchet_sdk/clients/rest/models/worker.py index 090ab0965..0f035bee3 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/worker.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/worker.py @@ -13,28 +13,47 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.step_run import StepRun -from typing import Optional, Set -from typing_extensions import Self + class Worker(BaseModel): """ Worker - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta name: StrictStr = Field(description="The name of the worker.") - last_heartbeat_at: Optional[datetime] = Field(default=None, description="The time this worker last sent a heartbeat.", alias="lastHeartbeatAt") - actions: Optional[List[StrictStr]] = Field(default=None, description="The actions this worker can perform.") - recent_step_runs: Optional[List[StepRun]] = Field(default=None, description="The recent step runs for this worker.", alias="recentStepRuns") - __properties: ClassVar[List[str]] = ["metadata", "name", "lastHeartbeatAt", "actions", "recentStepRuns"] + last_heartbeat_at: Optional[datetime] = Field( + default=None, + description="The time this worker last sent a heartbeat.", + alias="lastHeartbeatAt", + ) + actions: Optional[List[StrictStr]] = Field( + default=None, description="The actions this worker can perform." + ) + recent_step_runs: Optional[List[StepRun]] = Field( + default=None, + description="The recent step runs for this worker.", + alias="recentStepRuns", + ) + __properties: ClassVar[List[str]] = [ + "metadata", + "name", + "lastHeartbeatAt", + "actions", + "recentStepRuns", + ] model_config = { "populate_by_name": True, @@ -42,7 +61,6 @@ class Worker(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -67,8 +85,7 @@ class Worker(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -77,14 +94,14 @@ class Worker(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in recent_step_runs (list) _items = [] if self.recent_step_runs: for _item in self.recent_step_runs: if _item: _items.append(_item.to_dict()) - _dict['recentStepRuns'] = _items + _dict["recentStepRuns"] = _items return _dict @classmethod @@ -96,13 +113,21 @@ class Worker(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "name": obj.get("name"), - "lastHeartbeatAt": obj.get("lastHeartbeatAt"), - "actions": obj.get("actions"), - "recentStepRuns": [StepRun.from_dict(_item) for _item in obj["recentStepRuns"]] if obj.get("recentStepRuns") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "name": obj.get("name"), + "lastHeartbeatAt": obj.get("lastHeartbeatAt"), + "actions": obj.get("actions"), + "recentStepRuns": ( + [StepRun.from_dict(_item) for _item in obj["recentStepRuns"]] + if obj.get("recentStepRuns") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/worker_list.py b/python-sdk/hatchet_sdk/clients/rest/models/worker_list.py index c2bf2415c..dccbb3026 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/worker_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/worker_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.worker import Worker -from typing import Optional, Set -from typing_extensions import Self + class WorkerList(BaseModel): """ WorkerList - """ # noqa: E501 + """ # noqa: E501 + pagination: Optional[PaginationResponse] = None rows: Optional[List[Worker]] = None __properties: ClassVar[List[str]] = ["pagination", "rows"] @@ -38,7 +41,6 @@ class WorkerList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class WorkerList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -73,14 +74,14 @@ class WorkerList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items return _dict @classmethod @@ -92,10 +93,18 @@ class WorkerList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None, - "rows": [Worker.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None - }) + _obj = cls.model_validate( + { + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + "rows": ( + [Worker.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow.py index b7ec37e87..39214e423 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow.py @@ -13,32 +13,52 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.job import Job -from hatchet_sdk.clients.rest.models.workflow_deployment_config import WorkflowDeploymentConfig +from hatchet_sdk.clients.rest.models.workflow_deployment_config import ( + WorkflowDeploymentConfig, +) from hatchet_sdk.clients.rest.models.workflow_tag import WorkflowTag -from typing import Optional, Set -from typing_extensions import Self + class Workflow(BaseModel): """ Workflow - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta name: StrictStr = Field(description="The name of the workflow.") - description: Optional[StrictStr] = Field(default=None, description="The description of the workflow.") + description: Optional[StrictStr] = Field( + default=None, description="The description of the workflow." + ) versions: Optional[List[WorkflowVersionMeta]] = None - tags: Optional[List[WorkflowTag]] = Field(default=None, description="The tags of the workflow.") + tags: Optional[List[WorkflowTag]] = Field( + default=None, description="The tags of the workflow." + ) last_run: Optional[WorkflowRun] = Field(default=None, alias="lastRun") - jobs: Optional[List[Job]] = Field(default=None, description="The jobs of the workflow.") + jobs: Optional[List[Job]] = Field( + default=None, description="The jobs of the workflow." + ) deployment: Optional[WorkflowDeploymentConfig] = None - __properties: ClassVar[List[str]] = ["metadata", "name", "description", "versions", "tags", "lastRun", "jobs", "deployment"] + __properties: ClassVar[List[str]] = [ + "metadata", + "name", + "description", + "versions", + "tags", + "lastRun", + "jobs", + "deployment", + ] model_config = { "populate_by_name": True, @@ -46,7 +66,6 @@ class Workflow(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -71,8 +90,7 @@ class Workflow(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -81,34 +99,34 @@ class Workflow(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in versions (list) _items = [] if self.versions: for _item in self.versions: if _item: _items.append(_item.to_dict()) - _dict['versions'] = _items + _dict["versions"] = _items # override the default output from pydantic by calling `to_dict()` of each item in tags (list) _items = [] if self.tags: for _item in self.tags: if _item: _items.append(_item.to_dict()) - _dict['tags'] = _items + _dict["tags"] = _items # override the default output from pydantic by calling `to_dict()` of last_run if self.last_run: - _dict['lastRun'] = self.last_run.to_dict() + _dict["lastRun"] = self.last_run.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in jobs (list) _items = [] if self.jobs: for _item in self.jobs: if _item: _items.append(_item.to_dict()) - _dict['jobs'] = _items + _dict["jobs"] = _items # override the default output from pydantic by calling `to_dict()` of deployment if self.deployment: - _dict['deployment'] = self.deployment.to_dict() + _dict["deployment"] = self.deployment.to_dict() return _dict @classmethod @@ -120,20 +138,47 @@ class Workflow(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "name": obj.get("name"), - "description": obj.get("description"), - "versions": [WorkflowVersionMeta.from_dict(_item) for _item in obj["versions"]] if obj.get("versions") is not None else None, - "tags": [WorkflowTag.from_dict(_item) for _item in obj["tags"]] if obj.get("tags") is not None else None, - "lastRun": WorkflowRun.from_dict(obj["lastRun"]) if obj.get("lastRun") is not None else None, - "jobs": [Job.from_dict(_item) for _item in obj["jobs"]] if obj.get("jobs") is not None else None, - "deployment": WorkflowDeploymentConfig.from_dict(obj["deployment"]) if obj.get("deployment") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "name": obj.get("name"), + "description": obj.get("description"), + "versions": ( + [WorkflowVersionMeta.from_dict(_item) for _item in obj["versions"]] + if obj.get("versions") is not None + else None + ), + "tags": ( + [WorkflowTag.from_dict(_item) for _item in obj["tags"]] + if obj.get("tags") is not None + else None + ), + "lastRun": ( + WorkflowRun.from_dict(obj["lastRun"]) + if obj.get("lastRun") is not None + else None + ), + "jobs": ( + [Job.from_dict(_item) for _item in obj["jobs"]] + if obj.get("jobs") is not None + else None + ), + "deployment": ( + WorkflowDeploymentConfig.from_dict(obj["deployment"]) + if obj.get("deployment") is not None + else None + ), + } + ) return _obj + from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun from hatchet_sdk.clients.rest.models.workflow_version_meta import WorkflowVersionMeta + # TODO: Rewrite to not use raise_errors Workflow.model_rebuild(raise_errors=False) - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_concurrency.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_concurrency.py index b0b40fa24..4c96b4ce6 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_concurrency.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_concurrency.py @@ -13,29 +13,47 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt, StrictStr, field_validator -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class WorkflowConcurrency(BaseModel): """ WorkflowConcurrency - """ # noqa: E501 - max_runs: StrictInt = Field(description="The maximum number of concurrent workflow runs.", alias="maxRuns") - limit_strategy: StrictStr = Field(description="The strategy to use when the concurrency limit is reached.", alias="limitStrategy") - get_concurrency_group: StrictStr = Field(description="An action which gets the concurrency group for the WorkflowRun.", alias="getConcurrencyGroup") - __properties: ClassVar[List[str]] = ["maxRuns", "limitStrategy", "getConcurrencyGroup"] + """ # noqa: E501 - @field_validator('limit_strategy') + max_runs: StrictInt = Field( + description="The maximum number of concurrent workflow runs.", alias="maxRuns" + ) + limit_strategy: StrictStr = Field( + description="The strategy to use when the concurrency limit is reached.", + alias="limitStrategy", + ) + get_concurrency_group: StrictStr = Field( + description="An action which gets the concurrency group for the WorkflowRun.", + alias="getConcurrencyGroup", + ) + __properties: ClassVar[List[str]] = [ + "maxRuns", + "limitStrategy", + "getConcurrencyGroup", + ] + + @field_validator("limit_strategy") def limit_strategy_validate_enum(cls, value): """Validates the enum""" - if value not in set(['CANCEL_IN_PROGRESS', 'DROP_NEWEST', 'QUEUE_NEWEST', 'GROUP_ROUND_ROBIN']): - raise ValueError("must be one of enum values ('CANCEL_IN_PROGRESS', 'DROP_NEWEST', 'QUEUE_NEWEST', 'GROUP_ROUND_ROBIN')") + if value not in set( + ["CANCEL_IN_PROGRESS", "DROP_NEWEST", "QUEUE_NEWEST", "GROUP_ROUND_ROBIN"] + ): + raise ValueError( + "must be one of enum values ('CANCEL_IN_PROGRESS', 'DROP_NEWEST', 'QUEUE_NEWEST', 'GROUP_ROUND_ROBIN')" + ) return value model_config = { @@ -44,7 +62,6 @@ class WorkflowConcurrency(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -69,8 +86,7 @@ class WorkflowConcurrency(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -88,11 +104,11 @@ class WorkflowConcurrency(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "maxRuns": obj.get("maxRuns"), - "limitStrategy": obj.get("limitStrategy"), - "getConcurrencyGroup": obj.get("getConcurrencyGroup") - }) + _obj = cls.model_validate( + { + "maxRuns": obj.get("maxRuns"), + "limitStrategy": obj.get("limitStrategy"), + "getConcurrencyGroup": obj.get("getConcurrencyGroup"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_deployment_config.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_deployment_config.py index e1c57008a..338d04614 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_deployment_config.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_deployment_config.py @@ -13,28 +13,53 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from hatchet_sdk.clients.rest.models.github_app_installation import GithubAppInstallation -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta +from hatchet_sdk.clients.rest.models.github_app_installation import ( + GithubAppInstallation, +) + + class WorkflowDeploymentConfig(BaseModel): """ WorkflowDeploymentConfig - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta - git_repo_name: StrictStr = Field(description="The repository name.", alias="gitRepoName") - git_repo_owner: StrictStr = Field(description="The repository owner.", alias="gitRepoOwner") - git_repo_branch: StrictStr = Field(description="The repository branch.", alias="gitRepoBranch") - github_app_installation: Optional[GithubAppInstallation] = Field(default=None, description="The Github App installation.", alias="githubAppInstallation") - github_app_installation_id: StrictStr = Field(description="The id of the Github App installation.", alias="githubAppInstallationId") - __properties: ClassVar[List[str]] = ["metadata", "gitRepoName", "gitRepoOwner", "gitRepoBranch", "githubAppInstallation", "githubAppInstallationId"] + git_repo_name: StrictStr = Field( + description="The repository name.", alias="gitRepoName" + ) + git_repo_owner: StrictStr = Field( + description="The repository owner.", alias="gitRepoOwner" + ) + git_repo_branch: StrictStr = Field( + description="The repository branch.", alias="gitRepoBranch" + ) + github_app_installation: Optional[GithubAppInstallation] = Field( + default=None, + description="The Github App installation.", + alias="githubAppInstallation", + ) + github_app_installation_id: StrictStr = Field( + description="The id of the Github App installation.", + alias="githubAppInstallationId", + ) + __properties: ClassVar[List[str]] = [ + "metadata", + "gitRepoName", + "gitRepoOwner", + "gitRepoBranch", + "githubAppInstallation", + "githubAppInstallationId", + ] model_config = { "populate_by_name": True, @@ -42,7 +67,6 @@ class WorkflowDeploymentConfig(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -67,8 +91,7 @@ class WorkflowDeploymentConfig(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -77,10 +100,10 @@ class WorkflowDeploymentConfig(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of github_app_installation if self.github_app_installation: - _dict['githubAppInstallation'] = self.github_app_installation.to_dict() + _dict["githubAppInstallation"] = self.github_app_installation.to_dict() return _dict @classmethod @@ -92,14 +115,22 @@ class WorkflowDeploymentConfig(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "gitRepoName": obj.get("gitRepoName"), - "gitRepoOwner": obj.get("gitRepoOwner"), - "gitRepoBranch": obj.get("gitRepoBranch"), - "githubAppInstallation": GithubAppInstallation.from_dict(obj["githubAppInstallation"]) if obj.get("githubAppInstallation") is not None else None, - "githubAppInstallationId": obj.get("githubAppInstallationId") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "gitRepoName": obj.get("gitRepoName"), + "gitRepoOwner": obj.get("gitRepoOwner"), + "gitRepoBranch": obj.get("gitRepoBranch"), + "githubAppInstallation": ( + GithubAppInstallation.from_dict(obj["githubAppInstallation"]) + if obj.get("githubAppInstallation") is not None + else None + ), + "githubAppInstallationId": obj.get("githubAppInstallationId"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_list.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_list.py index 68b2da1a3..ccea81ca3 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_list.py @@ -13,22 +13,25 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.workflow import Workflow -from typing import Optional, Set -from typing_extensions import Self + class WorkflowList(BaseModel): """ WorkflowList - """ # noqa: E501 + """ # noqa: E501 + metadata: Optional[APIResourceMeta] = None rows: Optional[List[Workflow]] = None pagination: Optional[PaginationResponse] = None @@ -40,7 +43,6 @@ class WorkflowList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -65,8 +67,7 @@ class WorkflowList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -75,17 +76,17 @@ class WorkflowList(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in rows (list) _items = [] if self.rows: for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() return _dict @classmethod @@ -97,11 +98,23 @@ class WorkflowList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "rows": [Workflow.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None, - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "rows": ( + [Workflow.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_metrics.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_metrics.py index 0fb83d17e..f6da769a1 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_metrics.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_metrics.py @@ -13,21 +13,31 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class WorkflowMetrics(BaseModel): """ WorkflowMetrics - """ # noqa: E501 - group_key_runs_count: Optional[StrictInt] = Field(default=None, description="The number of runs for a specific group key (passed via filter)", alias="groupKeyRunsCount") - group_key_count: Optional[StrictInt] = Field(default=None, description="The total number of concurrency group keys.", alias="groupKeyCount") + """ # noqa: E501 + + group_key_runs_count: Optional[StrictInt] = Field( + default=None, + description="The number of runs for a specific group key (passed via filter)", + alias="groupKeyRunsCount", + ) + group_key_count: Optional[StrictInt] = Field( + default=None, + description="The total number of concurrency group keys.", + alias="groupKeyCount", + ) __properties: ClassVar[List[str]] = ["groupKeyRunsCount", "groupKeyCount"] model_config = { @@ -36,7 +46,6 @@ class WorkflowMetrics(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +70,7 @@ class WorkflowMetrics(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +88,10 @@ class WorkflowMetrics(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "groupKeyRunsCount": obj.get("groupKeyRunsCount"), - "groupKeyCount": obj.get("groupKeyCount") - }) + _obj = cls.model_validate( + { + "groupKeyRunsCount": obj.get("groupKeyRunsCount"), + "groupKeyCount": obj.get("groupKeyCount"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run.py index ced168985..92d10e509 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run.py @@ -13,28 +13,34 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json - from datetime import datetime +from typing import Any, ClassVar, Dict, List, Optional, Set + from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from typing_extensions import Annotated +from typing_extensions import Annotated, Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus -from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import WorkflowRunTriggeredBy -from typing import Optional, Set -from typing_extensions import Self +from hatchet_sdk.clients.rest.models.workflow_run_triggered_by import ( + WorkflowRunTriggeredBy, +) + class WorkflowRun(BaseModel): """ WorkflowRun - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta tenant_id: StrictStr = Field(alias="tenantId") workflow_version_id: StrictStr = Field(alias="workflowVersionId") - workflow_version: Optional[WorkflowVersion] = Field(default=None, alias="workflowVersion") + workflow_version: Optional[WorkflowVersion] = Field( + default=None, alias="workflowVersion" + ) status: WorkflowRunStatus display_name: Optional[StrictStr] = Field(default=None, alias="displayName") job_runs: Optional[List[JobRun]] = Field(default=None, alias="jobRuns") @@ -43,9 +49,28 @@ class WorkflowRun(BaseModel): error: Optional[StrictStr] = None started_at: Optional[datetime] = Field(default=None, alias="startedAt") finished_at: Optional[datetime] = Field(default=None, alias="finishedAt") - parent_id: Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]] = Field(default=None, alias="parentId") - parent_step_run_id: Optional[Annotated[str, Field(min_length=36, strict=True, max_length=36)]] = Field(default=None, alias="parentStepRunId") - __properties: ClassVar[List[str]] = ["metadata", "tenantId", "workflowVersionId", "workflowVersion", "status", "displayName", "jobRuns", "triggeredBy", "input", "error", "startedAt", "finishedAt", "parentId", "parentStepRunId"] + parent_id: Optional[ + Annotated[str, Field(min_length=36, strict=True, max_length=36)] + ] = Field(default=None, alias="parentId") + parent_step_run_id: Optional[ + Annotated[str, Field(min_length=36, strict=True, max_length=36)] + ] = Field(default=None, alias="parentStepRunId") + __properties: ClassVar[List[str]] = [ + "metadata", + "tenantId", + "workflowVersionId", + "workflowVersion", + "status", + "displayName", + "jobRuns", + "triggeredBy", + "input", + "error", + "startedAt", + "finishedAt", + "parentId", + "parentStepRunId", + ] model_config = { "populate_by_name": True, @@ -53,7 +78,6 @@ class WorkflowRun(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -78,8 +102,7 @@ class WorkflowRun(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -88,20 +111,20 @@ class WorkflowRun(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of workflow_version if self.workflow_version: - _dict['workflowVersion'] = self.workflow_version.to_dict() + _dict["workflowVersion"] = self.workflow_version.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in job_runs (list) _items = [] if self.job_runs: for _item in self.job_runs: if _item: _items.append(_item.to_dict()) - _dict['jobRuns'] = _items + _dict["jobRuns"] = _items # override the default output from pydantic by calling `to_dict()` of triggered_by if self.triggered_by: - _dict['triggeredBy'] = self.triggered_by.to_dict() + _dict["triggeredBy"] = self.triggered_by.to_dict() return _dict @classmethod @@ -113,26 +136,45 @@ class WorkflowRun(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "tenantId": obj.get("tenantId"), - "workflowVersionId": obj.get("workflowVersionId"), - "workflowVersion": WorkflowVersion.from_dict(obj["workflowVersion"]) if obj.get("workflowVersion") is not None else None, - "status": obj.get("status"), - "displayName": obj.get("displayName"), - "jobRuns": [JobRun.from_dict(_item) for _item in obj["jobRuns"]] if obj.get("jobRuns") is not None else None, - "triggeredBy": WorkflowRunTriggeredBy.from_dict(obj["triggeredBy"]) if obj.get("triggeredBy") is not None else None, - "input": obj.get("input"), - "error": obj.get("error"), - "startedAt": obj.get("startedAt"), - "finishedAt": obj.get("finishedAt"), - "parentId": obj.get("parentId"), - "parentStepRunId": obj.get("parentStepRunId") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "tenantId": obj.get("tenantId"), + "workflowVersionId": obj.get("workflowVersionId"), + "workflowVersion": ( + WorkflowVersion.from_dict(obj["workflowVersion"]) + if obj.get("workflowVersion") is not None + else None + ), + "status": obj.get("status"), + "displayName": obj.get("displayName"), + "jobRuns": ( + [JobRun.from_dict(_item) for _item in obj["jobRuns"]] + if obj.get("jobRuns") is not None + else None + ), + "triggeredBy": ( + WorkflowRunTriggeredBy.from_dict(obj["triggeredBy"]) + if obj.get("triggeredBy") is not None + else None + ), + "input": obj.get("input"), + "error": obj.get("error"), + "startedAt": obj.get("startedAt"), + "finishedAt": obj.get("finishedAt"), + "parentId": obj.get("parentId"), + "parentStepRunId": obj.get("parentStepRunId"), + } + ) return _obj + from hatchet_sdk.clients.rest.models.job_run import JobRun from hatchet_sdk.clients.rest.models.workflow_version import WorkflowVersion + # TODO: Rewrite to not use raise_errors WorkflowRun.model_rebuild(raise_errors=False) - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_list.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_list.py index bb7f0dec3..f474396d3 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_list.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_list.py @@ -13,21 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.pagination_response import PaginationResponse from hatchet_sdk.clients.rest.models.workflow_run import WorkflowRun -from typing import Optional, Set -from typing_extensions import Self + class WorkflowRunList(BaseModel): """ WorkflowRunList - """ # noqa: E501 + """ # noqa: E501 + rows: Optional[List[WorkflowRun]] = None pagination: Optional[PaginationResponse] = None __properties: ClassVar[List[str]] = ["rows", "pagination"] @@ -38,7 +41,6 @@ class WorkflowRunList(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -63,8 +65,7 @@ class WorkflowRunList(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -77,10 +78,10 @@ class WorkflowRunList(BaseModel): for _item in self.rows: if _item: _items.append(_item.to_dict()) - _dict['rows'] = _items + _dict["rows"] = _items # override the default output from pydantic by calling `to_dict()` of pagination if self.pagination: - _dict['pagination'] = self.pagination.to_dict() + _dict["pagination"] = self.pagination.to_dict() return _dict @classmethod @@ -92,10 +93,18 @@ class WorkflowRunList(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "rows": [WorkflowRun.from_dict(_item) for _item in obj["rows"]] if obj.get("rows") is not None else None, - "pagination": PaginationResponse.from_dict(obj["pagination"]) if obj.get("pagination") is not None else None - }) + _obj = cls.model_validate( + { + "rows": ( + [WorkflowRun.from_dict(_item) for _item in obj["rows"]] + if obj.get("rows") is not None + else None + ), + "pagination": ( + PaginationResponse.from_dict(obj["pagination"]) + if obj.get("pagination") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_status.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_status.py index 68fb41547..a79312165 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_status.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_status.py @@ -13,8 +13,10 @@ from __future__ import annotations + import json from enum import Enum + from typing_extensions import Self @@ -26,16 +28,14 @@ class WorkflowRunStatus(str, Enum): """ allowed enum values """ - PENDING = 'PENDING' - RUNNING = 'RUNNING' - SUCCEEDED = 'SUCCEEDED' - FAILED = 'FAILED' - CANCELLED = 'CANCELLED' - QUEUED = 'QUEUED' + PENDING = "PENDING" + RUNNING = "RUNNING" + SUCCEEDED = "SUCCEEDED" + FAILED = "FAILED" + CANCELLED = "CANCELLED" + QUEUED = "QUEUED" @classmethod def from_json(cls, json_str: str) -> Self: """Create an instance of WorkflowRunStatus from a JSON string""" return cls(json.loads(json_str)) - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_triggered_by.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_triggered_by.py index 3b1c259d7..2867ac3e5 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_triggered_by.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_run_triggered_by.py @@ -13,28 +13,38 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.event import Event -from typing import Optional, Set -from typing_extensions import Self + class WorkflowRunTriggeredBy(BaseModel): """ WorkflowRunTriggeredBy - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta parent_id: StrictStr = Field(alias="parentId") event_id: Optional[StrictStr] = Field(default=None, alias="eventId") event: Optional[Event] = None cron_parent_id: Optional[StrictStr] = Field(default=None, alias="cronParentId") cron_schedule: Optional[StrictStr] = Field(default=None, alias="cronSchedule") - __properties: ClassVar[List[str]] = ["metadata", "parentId", "eventId", "event", "cronParentId", "cronSchedule"] + __properties: ClassVar[List[str]] = [ + "metadata", + "parentId", + "eventId", + "event", + "cronParentId", + "cronSchedule", + ] model_config = { "populate_by_name": True, @@ -42,7 +52,6 @@ class WorkflowRunTriggeredBy(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -67,8 +76,7 @@ class WorkflowRunTriggeredBy(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -77,10 +85,10 @@ class WorkflowRunTriggeredBy(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of event if self.event: - _dict['event'] = self.event.to_dict() + _dict["event"] = self.event.to_dict() return _dict @classmethod @@ -92,14 +100,22 @@ class WorkflowRunTriggeredBy(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "parentId": obj.get("parentId"), - "eventId": obj.get("eventId"), - "event": Event.from_dict(obj["event"]) if obj.get("event") is not None else None, - "cronParentId": obj.get("cronParentId"), - "cronSchedule": obj.get("cronSchedule") - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "parentId": obj.get("parentId"), + "eventId": obj.get("eventId"), + "event": ( + Event.from_dict(obj["event"]) + if obj.get("event") is not None + else None + ), + "cronParentId": obj.get("cronParentId"), + "cronSchedule": obj.get("cronSchedule"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_tag.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_tag.py index 7b04e2290..7817fba09 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_tag.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_tag.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class WorkflowTag(BaseModel): """ WorkflowTag - """ # noqa: E501 + """ # noqa: E501 + name: StrictStr = Field(description="The name of the workflow.") color: StrictStr = Field(description="The description of the workflow.") __properties: ClassVar[List[str]] = ["name", "color"] @@ -36,7 +38,6 @@ class WorkflowTag(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +62,7 @@ class WorkflowTag(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +80,5 @@ class WorkflowTag(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "name": obj.get("name"), - "color": obj.get("color") - }) + _obj = cls.model_validate({"name": obj.get("name"), "color": obj.get("color")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_cron_ref.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_cron_ref.py index 6e43bb911..ce09baee8 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_cron_ref.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_cron_ref.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class WorkflowTriggerCronRef(BaseModel): """ WorkflowTriggerCronRef - """ # noqa: E501 + """ # noqa: E501 + parent_id: Optional[StrictStr] = None cron: Optional[StrictStr] = None __properties: ClassVar[List[str]] = ["parent_id", "cron"] @@ -36,7 +38,6 @@ class WorkflowTriggerCronRef(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +62,7 @@ class WorkflowTriggerCronRef(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +80,7 @@ class WorkflowTriggerCronRef(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "parent_id": obj.get("parent_id"), - "cron": obj.get("cron") - }) + _obj = cls.model_validate( + {"parent_id": obj.get("parent_id"), "cron": obj.get("cron")} + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_event_ref.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_event_ref.py index 0ffb4d9bc..4975210ca 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_event_ref.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_trigger_event_ref.py @@ -13,19 +13,21 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from typing import Optional, Set from typing_extensions import Self + class WorkflowTriggerEventRef(BaseModel): """ WorkflowTriggerEventRef - """ # noqa: E501 + """ # noqa: E501 + parent_id: Optional[StrictStr] = None event_key: Optional[StrictStr] = None __properties: ClassVar[List[str]] = ["parent_id", "event_key"] @@ -36,7 +38,6 @@ class WorkflowTriggerEventRef(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -61,8 +62,7 @@ class WorkflowTriggerEventRef(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -80,10 +80,7 @@ class WorkflowTriggerEventRef(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "parent_id": obj.get("parent_id"), - "event_key": obj.get("event_key") - }) + _obj = cls.model_validate( + {"parent_id": obj.get("parent_id"), "event_key": obj.get("event_key")} + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_triggers.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_triggers.py index 9ecc23b77..fc1cc909b 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_triggers.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_triggers.py @@ -13,28 +13,41 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import WorkflowTriggerCronRef -from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import WorkflowTriggerEventRef -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta +from hatchet_sdk.clients.rest.models.workflow_trigger_cron_ref import ( + WorkflowTriggerCronRef, +) +from hatchet_sdk.clients.rest.models.workflow_trigger_event_ref import ( + WorkflowTriggerEventRef, +) + + class WorkflowTriggers(BaseModel): """ WorkflowTriggers - """ # noqa: E501 + """ # noqa: E501 + metadata: Optional[APIResourceMeta] = None workflow_version_id: Optional[StrictStr] = None tenant_id: Optional[StrictStr] = None events: Optional[List[WorkflowTriggerEventRef]] = None crons: Optional[List[WorkflowTriggerCronRef]] = None - __properties: ClassVar[List[str]] = ["metadata", "workflow_version_id", "tenant_id", "events", "crons"] + __properties: ClassVar[List[str]] = [ + "metadata", + "workflow_version_id", + "tenant_id", + "events", + "crons", + ] model_config = { "populate_by_name": True, @@ -42,7 +55,6 @@ class WorkflowTriggers(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -67,8 +79,7 @@ class WorkflowTriggers(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -77,21 +88,21 @@ class WorkflowTriggers(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in events (list) _items = [] if self.events: for _item in self.events: if _item: _items.append(_item.to_dict()) - _dict['events'] = _items + _dict["events"] = _items # override the default output from pydantic by calling `to_dict()` of each item in crons (list) _items = [] if self.crons: for _item in self.crons: if _item: _items.append(_item.to_dict()) - _dict['crons'] = _items + _dict["crons"] = _items return _dict @classmethod @@ -103,13 +114,28 @@ class WorkflowTriggers(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "workflow_version_id": obj.get("workflow_version_id"), - "tenant_id": obj.get("tenant_id"), - "events": [WorkflowTriggerEventRef.from_dict(_item) for _item in obj["events"]] if obj.get("events") is not None else None, - "crons": [WorkflowTriggerCronRef.from_dict(_item) for _item in obj["crons"]] if obj.get("crons") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "workflow_version_id": obj.get("workflow_version_id"), + "tenant_id": obj.get("tenant_id"), + "events": ( + [ + WorkflowTriggerEventRef.from_dict(_item) + for _item in obj["events"] + ] + if obj.get("events") is not None + else None + ), + "crons": ( + [WorkflowTriggerCronRef.from_dict(_item) for _item in obj["crons"]] + if obj.get("crons") is not None + else None + ), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version.py index 8c196c714..e70d8c8be 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version.py @@ -13,23 +13,26 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt, StrictStr -from typing import Any, ClassVar, Dict, List, Optional +from typing_extensions import Self + from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta from hatchet_sdk.clients.rest.models.job import Job from hatchet_sdk.clients.rest.models.workflow_concurrency import WorkflowConcurrency from hatchet_sdk.clients.rest.models.workflow_triggers import WorkflowTriggers -from typing import Optional, Set -from typing_extensions import Self + class WorkflowVersion(BaseModel): """ WorkflowVersion - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta version: StrictStr = Field(description="The version of the workflow.") order: StrictInt @@ -38,7 +41,16 @@ class WorkflowVersion(BaseModel): concurrency: Optional[WorkflowConcurrency] = None triggers: Optional[WorkflowTriggers] = None jobs: Optional[List[Job]] = None - __properties: ClassVar[List[str]] = ["metadata", "version", "order", "workflowId", "workflow", "concurrency", "triggers", "jobs"] + __properties: ClassVar[List[str]] = [ + "metadata", + "version", + "order", + "workflowId", + "workflow", + "concurrency", + "triggers", + "jobs", + ] model_config = { "populate_by_name": True, @@ -46,7 +58,6 @@ class WorkflowVersion(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -71,8 +82,7 @@ class WorkflowVersion(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -81,23 +91,23 @@ class WorkflowVersion(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of workflow if self.workflow: - _dict['workflow'] = self.workflow.to_dict() + _dict["workflow"] = self.workflow.to_dict() # override the default output from pydantic by calling `to_dict()` of concurrency if self.concurrency: - _dict['concurrency'] = self.concurrency.to_dict() + _dict["concurrency"] = self.concurrency.to_dict() # override the default output from pydantic by calling `to_dict()` of triggers if self.triggers: - _dict['triggers'] = self.triggers.to_dict() + _dict["triggers"] = self.triggers.to_dict() # override the default output from pydantic by calling `to_dict()` of each item in jobs (list) _items = [] if self.jobs: for _item in self.jobs: if _item: _items.append(_item.to_dict()) - _dict['jobs'] = _items + _dict["jobs"] = _items return _dict @classmethod @@ -109,19 +119,42 @@ class WorkflowVersion(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "version": obj.get("version"), - "order": obj.get("order"), - "workflowId": obj.get("workflowId"), - "workflow": Workflow.from_dict(obj["workflow"]) if obj.get("workflow") is not None else None, - "concurrency": WorkflowConcurrency.from_dict(obj["concurrency"]) if obj.get("concurrency") is not None else None, - "triggers": WorkflowTriggers.from_dict(obj["triggers"]) if obj.get("triggers") is not None else None, - "jobs": [Job.from_dict(_item) for _item in obj["jobs"]] if obj.get("jobs") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "version": obj.get("version"), + "order": obj.get("order"), + "workflowId": obj.get("workflowId"), + "workflow": ( + Workflow.from_dict(obj["workflow"]) + if obj.get("workflow") is not None + else None + ), + "concurrency": ( + WorkflowConcurrency.from_dict(obj["concurrency"]) + if obj.get("concurrency") is not None + else None + ), + "triggers": ( + WorkflowTriggers.from_dict(obj["triggers"]) + if obj.get("triggers") is not None + else None + ), + "jobs": ( + [Job.from_dict(_item) for _item in obj["jobs"]] + if obj.get("jobs") is not None + else None + ), + } + ) return _obj + from hatchet_sdk.clients.rest.models.workflow import Workflow + # TODO: Rewrite to not use raise_errors WorkflowVersion.model_rebuild(raise_errors=False) - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_concurrency.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_concurrency.py index dfaca5c60..d9893920f 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_concurrency.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_concurrency.py @@ -13,29 +13,47 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt, StrictStr, field_validator -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class WorkflowVersionConcurrency(BaseModel): """ WorkflowVersionConcurrency - """ # noqa: E501 - max_runs: StrictInt = Field(description="The maximum number of concurrent workflow runs.", alias="maxRuns") - limit_strategy: StrictStr = Field(description="The strategy to use when the concurrency limit is reached.", alias="limitStrategy") - get_concurrency_group: StrictStr = Field(description="An action which gets the concurrency group for the WorkflowRun.", alias="getConcurrencyGroup") - __properties: ClassVar[List[str]] = ["maxRuns", "limitStrategy", "getConcurrencyGroup"] + """ # noqa: E501 - @field_validator('limit_strategy') + max_runs: StrictInt = Field( + description="The maximum number of concurrent workflow runs.", alias="maxRuns" + ) + limit_strategy: StrictStr = Field( + description="The strategy to use when the concurrency limit is reached.", + alias="limitStrategy", + ) + get_concurrency_group: StrictStr = Field( + description="An action which gets the concurrency group for the WorkflowRun.", + alias="getConcurrencyGroup", + ) + __properties: ClassVar[List[str]] = [ + "maxRuns", + "limitStrategy", + "getConcurrencyGroup", + ] + + @field_validator("limit_strategy") def limit_strategy_validate_enum(cls, value): """Validates the enum""" - if value not in set(['CANCEL_IN_PROGRESS', 'DROP_NEWEST', 'QUEUE_NEWEST', 'GROUP_ROUND_ROBIN']): - raise ValueError("must be one of enum values ('CANCEL_IN_PROGRESS', 'DROP_NEWEST', 'QUEUE_NEWEST', 'GROUP_ROUND_ROBIN')") + if value not in set( + ["CANCEL_IN_PROGRESS", "DROP_NEWEST", "QUEUE_NEWEST", "GROUP_ROUND_ROBIN"] + ): + raise ValueError( + "must be one of enum values ('CANCEL_IN_PROGRESS', 'DROP_NEWEST', 'QUEUE_NEWEST', 'GROUP_ROUND_ROBIN')" + ) return value model_config = { @@ -44,7 +62,6 @@ class WorkflowVersionConcurrency(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -69,8 +86,7 @@ class WorkflowVersionConcurrency(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -88,11 +104,11 @@ class WorkflowVersionConcurrency(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "maxRuns": obj.get("maxRuns"), - "limitStrategy": obj.get("limitStrategy"), - "getConcurrencyGroup": obj.get("getConcurrencyGroup") - }) + _obj = cls.model_validate( + { + "maxRuns": obj.get("maxRuns"), + "limitStrategy": obj.get("limitStrategy"), + "getConcurrencyGroup": obj.get("getConcurrencyGroup"), + } + ) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_definition.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_definition.py index c8cf8a89b..2eb3f023f 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_definition.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_definition.py @@ -13,20 +13,24 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictStr -from typing import Any, ClassVar, Dict, List -from typing import Optional, Set from typing_extensions import Self + class WorkflowVersionDefinition(BaseModel): """ WorkflowVersionDefinition - """ # noqa: E501 - raw_definition: StrictStr = Field(description="The raw YAML definition of the workflow.", alias="rawDefinition") + """ # noqa: E501 + + raw_definition: StrictStr = Field( + description="The raw YAML definition of the workflow.", alias="rawDefinition" + ) __properties: ClassVar[List[str]] = ["rawDefinition"] model_config = { @@ -35,7 +39,6 @@ class WorkflowVersionDefinition(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -60,8 +63,7 @@ class WorkflowVersionDefinition(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -79,9 +81,5 @@ class WorkflowVersionDefinition(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "rawDefinition": obj.get("rawDefinition") - }) + _obj = cls.model_validate({"rawDefinition": obj.get("rawDefinition")}) return _obj - - diff --git a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_meta.py b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_meta.py index f9d11d6c3..5ade64427 100644 --- a/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_meta.py +++ b/python-sdk/hatchet_sdk/clients/rest/models/workflow_version_meta.py @@ -13,26 +13,35 @@ from __future__ import annotations + +import json import pprint import re # noqa: F401 -import json +from typing import Any, ClassVar, Dict, List, Optional, Set from pydantic import BaseModel, Field, StrictInt, StrictStr -from typing import Any, ClassVar, Dict, List, Optional -from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta -from typing import Optional, Set from typing_extensions import Self +from hatchet_sdk.clients.rest.models.api_resource_meta import APIResourceMeta + + class WorkflowVersionMeta(BaseModel): """ WorkflowVersionMeta - """ # noqa: E501 + """ # noqa: E501 + metadata: APIResourceMeta version: StrictStr = Field(description="The version of the workflow.") order: StrictInt workflow_id: StrictStr = Field(alias="workflowId") workflow: Optional[Workflow] = None - __properties: ClassVar[List[str]] = ["metadata", "version", "order", "workflowId", "workflow"] + __properties: ClassVar[List[str]] = [ + "metadata", + "version", + "order", + "workflowId", + "workflow", + ] model_config = { "populate_by_name": True, @@ -40,7 +49,6 @@ class WorkflowVersionMeta(BaseModel): "protected_namespaces": (), } - def to_str(self) -> str: """Returns the string representation of the model using alias""" return pprint.pformat(self.model_dump(by_alias=True)) @@ -65,8 +73,7 @@ class WorkflowVersionMeta(BaseModel): were set at model initialization. Other fields with value `None` are ignored. """ - excluded_fields: Set[str] = set([ - ]) + excluded_fields: Set[str] = set([]) _dict = self.model_dump( by_alias=True, @@ -75,10 +82,10 @@ class WorkflowVersionMeta(BaseModel): ) # override the default output from pydantic by calling `to_dict()` of metadata if self.metadata: - _dict['metadata'] = self.metadata.to_dict() + _dict["metadata"] = self.metadata.to_dict() # override the default output from pydantic by calling `to_dict()` of workflow if self.workflow: - _dict['workflow'] = self.workflow.to_dict() + _dict["workflow"] = self.workflow.to_dict() return _dict @classmethod @@ -90,16 +97,27 @@ class WorkflowVersionMeta(BaseModel): if not isinstance(obj, dict): return cls.model_validate(obj) - _obj = cls.model_validate({ - "metadata": APIResourceMeta.from_dict(obj["metadata"]) if obj.get("metadata") is not None else None, - "version": obj.get("version"), - "order": obj.get("order"), - "workflowId": obj.get("workflowId"), - "workflow": Workflow.from_dict(obj["workflow"]) if obj.get("workflow") is not None else None - }) + _obj = cls.model_validate( + { + "metadata": ( + APIResourceMeta.from_dict(obj["metadata"]) + if obj.get("metadata") is not None + else None + ), + "version": obj.get("version"), + "order": obj.get("order"), + "workflowId": obj.get("workflowId"), + "workflow": ( + Workflow.from_dict(obj["workflow"]) + if obj.get("workflow") is not None + else None + ), + } + ) return _obj + from hatchet_sdk.clients.rest.models.workflow import Workflow + # TODO: Rewrite to not use raise_errors WorkflowVersionMeta.model_rebuild(raise_errors=False) - diff --git a/python-sdk/hatchet_sdk/clients/rest/rest.py b/python-sdk/hatchet_sdk/clients/rest/rest.py index 4d5210906..1fd9d49ff 100644 --- a/python-sdk/hatchet_sdk/clients/rest/rest.py +++ b/python-sdk/hatchet_sdk/clients/rest/rest.py @@ -78,22 +78,19 @@ class RESTClientObject: "key_file": configuration.key_file, } if configuration.assert_hostname is not None: - pool_args['assert_hostname'] = ( - configuration.assert_hostname - ) + pool_args["assert_hostname"] = configuration.assert_hostname if configuration.retries is not None: - pool_args['retries'] = configuration.retries + pool_args["retries"] = configuration.retries if configuration.tls_server_name: - pool_args['server_hostname'] = configuration.tls_server_name - + pool_args["server_hostname"] = configuration.tls_server_name if configuration.socket_options is not None: - pool_args['socket_options'] = configuration.socket_options + pool_args["socket_options"] = configuration.socket_options if configuration.connection_pool_maxsize is not None: - pool_args['maxsize'] = configuration.connection_pool_maxsize + pool_args["maxsize"] = configuration.connection_pool_maxsize # https pool manager self.pool_manager: urllib3.PoolManager @@ -101,6 +98,7 @@ class RESTClientObject: if configuration.proxy: if is_socks_proxy_url(configuration.proxy): from urllib3.contrib.socks import SOCKSProxyManager + pool_args["proxy_url"] = configuration.proxy pool_args["headers"] = configuration.proxy_headers self.pool_manager = SOCKSProxyManager(**pool_args) @@ -118,7 +116,7 @@ class RESTClientObject: headers=None, body=None, post_params=None, - _request_timeout=None + _request_timeout=None, ): """Perform requests. @@ -135,15 +133,7 @@ class RESTClientObject: (connection, read) timeouts. """ method = method.upper() - assert method in [ - 'GET', - 'HEAD', - 'DELETE', - 'POST', - 'PUT', - 'PATCH', - 'OPTIONS' - ] + assert method in ["GET", "HEAD", "DELETE", "POST", "PUT", "PATCH", "OPTIONS"] if post_params and body: raise ApiValueError( @@ -157,25 +147,18 @@ class RESTClientObject: if _request_timeout: if isinstance(_request_timeout, (int, float)): timeout = urllib3.Timeout(total=_request_timeout) - elif ( - isinstance(_request_timeout, tuple) - and len(_request_timeout) == 2 - ): + elif isinstance(_request_timeout, tuple) and len(_request_timeout) == 2: timeout = urllib3.Timeout( - connect=_request_timeout[0], - read=_request_timeout[1] + connect=_request_timeout[0], read=_request_timeout[1] ) try: # For `POST`, `PUT`, `PATCH`, `OPTIONS`, `DELETE` - if method in ['POST', 'PUT', 'PATCH', 'OPTIONS', 'DELETE']: + if method in ["POST", "PUT", "PATCH", "OPTIONS", "DELETE"]: # no content type provided or payload is json - content_type = headers.get('Content-Type') - if ( - not content_type - or re.search('json', content_type, re.IGNORECASE) - ): + content_type = headers.get("Content-Type") + if not content_type or re.search("json", content_type, re.IGNORECASE): request_body = None if body is not None: request_body = json.dumps(body) @@ -185,9 +168,9 @@ class RESTClientObject: body=request_body, timeout=timeout, headers=headers, - preload_content=False + preload_content=False, ) - elif content_type == 'application/x-www-form-urlencoded': + elif content_type == "application/x-www-form-urlencoded": r = self.pool_manager.request( method, url, @@ -195,13 +178,13 @@ class RESTClientObject: encode_multipart=False, timeout=timeout, headers=headers, - preload_content=False + preload_content=False, ) - elif content_type == 'multipart/form-data': + elif content_type == "multipart/form-data": # must del headers['Content-Type'], or the correct # Content-Type which generated by urllib3 will be # overwritten. - del headers['Content-Type'] + del headers["Content-Type"] r = self.pool_manager.request( method, url, @@ -209,7 +192,7 @@ class RESTClientObject: encode_multipart=True, timeout=timeout, headers=headers, - preload_content=False + preload_content=False, ) # Pass a `string` parameter directly in the body to support # other content types than JSON when `body` argument is @@ -221,9 +204,9 @@ class RESTClientObject: body=body, timeout=timeout, headers=headers, - preload_content=False + preload_content=False, ) - elif headers['Content-Type'] == 'text/plain' and isinstance(body, bool): + elif headers["Content-Type"] == "text/plain" and isinstance(body, bool): request_body = "true" if body else "false" r = self.pool_manager.request( method, @@ -231,7 +214,8 @@ class RESTClientObject: body=request_body, preload_content=False, timeout=timeout, - headers=headers) + headers=headers, + ) else: # Cannot generate the request from given parameters msg = """Cannot prepare a request message for provided @@ -246,7 +230,7 @@ class RESTClientObject: fields={}, timeout=timeout, headers=headers, - preload_content=False + preload_content=False, ) except urllib3.exceptions.SSLError as e: msg = "\n".join([type(e).__name__, str(e)]) diff --git a/python-sdk/hatchet_sdk/clients/rest_client.py b/python-sdk/hatchet_sdk/clients/rest_client.py index b65588009..b5f1f420a 100644 --- a/python-sdk/hatchet_sdk/clients/rest_client.py +++ b/python-sdk/hatchet_sdk/clients/rest_client.py @@ -1,12 +1,14 @@ from typing import Any, Dict -from .rest.api_client import ApiClient + +from .rest.api.log_api import LogApi +from .rest.api.step_run_api import StepRunApi from .rest.api.workflow_api import WorkflowApi from .rest.api.workflow_run_api import WorkflowRunApi -from .rest.api.step_run_api import StepRunApi -from .rest.api.log_api import LogApi +from .rest.api_client import ApiClient from .rest.configuration import Configuration from .rest.models import TriggerWorkflowRunRequest + class RestApi: def __init__(self, host: str, api_key: str, tenant_id: str): self.tenant_id = tenant_id @@ -22,25 +24,25 @@ class RestApi: self.workflow_run_api = WorkflowRunApi(api_client) self.step_run_api = StepRunApi(api_client) self.log_api = LogApi(api_client) - + def workflow_list(self): return self.workflow_api.workflow_list( tenant=self.tenant_id, ) - + def workflow_get(self, workflow_id: str): return self.workflow_api.workflow_get( workflow=workflow_id, ) - + def workflow_version_get(self, workflow_id: str, version: str | None = None): return self.workflow_api.workflow_version_get( workflow=workflow_id, version=version, ) - + def workflow_run_list( - self, + self, workflow_id: str | None = None, offset: int | None = None, limit: int | None = None, @@ -53,22 +55,22 @@ class RestApi: workflow_id=workflow_id, event_id=event_id, ) - + def workflow_run_get(self, workflow_run_id: str): return self.workflow_api.workflow_run_get( tenant=self.tenant_id, workflow_run=workflow_run_id, ) - + def workflow_run_create(self, workflow_id: str, input: Dict[str, Any]): return self.workflow_run_api.workflow_run_create( workflow=workflow_id, trigger_workflow_run_request=TriggerWorkflowRunRequest( input=input, - ) + ), ) - + def list_logs(self, step_run_id: str): return self.log_api.log_line_list( step_run=step_run_id, - ) \ No newline at end of file + ) diff --git a/python-sdk/hatchet_sdk/connection.py b/python-sdk/hatchet_sdk/connection.py index ce597024a..87a95f319 100644 --- a/python-sdk/hatchet_sdk/connection.py +++ b/python-sdk/hatchet_sdk/connection.py @@ -1,4 +1,5 @@ from typing import Any + import grpc @@ -7,24 +8,27 @@ def new_conn(config, aio=False): credentials: grpc.ChannelCredentials | None = None # load channel credentials - if config.tls_config.tls_strategy == 'tls': + if config.tls_config.tls_strategy == "tls": root: Any | None = None if config.tls_config.ca_file: root = open(config.tls_config.ca_file, "rb").read() credentials = grpc.ssl_channel_credentials(root_certificates=root) - elif config.tls_config.tls_strategy == 'mtls': + elif config.tls_config.tls_strategy == "mtls": root = open(config.tls_config.ca_file, "rb").read() private_key = open(config.tls_config.key_file, "rb").read() certificate_chain = open(config.tls_config.cert_file, "rb").read() credentials = grpc.ssl_channel_credentials( - root_certificates=root, private_key=private_key, certificate_chain=certificate_chain) + root_certificates=root, + private_key=private_key, + certificate_chain=certificate_chain, + ) strat = grpc if not aio else grpc.aio - if config.tls_config.tls_strategy == 'none': + if config.tls_config.tls_strategy == "none": conn = strat.insecure_channel( target=config.host_port, ) @@ -32,7 +36,6 @@ def new_conn(config, aio=False): conn = strat.secure_channel( target=config.host_port, credentials=credentials, - options=[('grpc.ssl_target_name_override', - config.tls_config.server_name)], + options=[("grpc.ssl_target_name_override", config.tls_config.server_name)], ) - return conn \ No newline at end of file + return conn diff --git a/python-sdk/hatchet_sdk/context.py b/python-sdk/hatchet_sdk/context.py index 23990e7d8..c480a4262 100644 --- a/python-sdk/hatchet_sdk/context.py +++ b/python-sdk/hatchet_sdk/context.py @@ -1,25 +1,29 @@ -from concurrent.futures import ThreadPoolExecutor -import inspect -from multiprocessing import Event -from .clients.dispatcher import Action -from .client import ClientImpl -from .clients.admin import TriggerWorkflowParentOptions -from .clients.listener import StepRunEvent, WorkflowRunEventType - -from .dispatcher_pb2 import OverridesData -from .logger import logger -import json import asyncio -from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus +import inspect +import json +from concurrent.futures import ThreadPoolExecutor +from multiprocessing import Event + from aiostream.stream import merge -DEFAULT_WORKFLOW_POLLING_INTERVAL = 5 # Seconds +from hatchet_sdk.clients.rest.models.workflow_run_status import WorkflowRunStatus + +from .client import ClientImpl +from .clients.admin import TriggerWorkflowParentOptions +from .clients.dispatcher import Action +from .clients.listener import StepRunEvent, WorkflowRunEventType +from .dispatcher_pb2 import OverridesData +from .logger import logger + +DEFAULT_WORKFLOW_POLLING_INTERVAL = 5 # Seconds + def get_caller_file_path(): caller_frame = inspect.stack()[2] return caller_frame.filename + class ChildWorkflowRef: workflow_run_id: str client: ClientImpl @@ -37,9 +41,9 @@ class ChildWorkflowRef: step_run_output = {} for run in step_runs: - stepId = run.step.readable_id if run.step else '' + stepId = run.step.readable_id if run.step else "" step_run_output[stepId] = json.loads(run.output) if run.output else {} - + statusMap = { WorkflowRunStatus.SUCCEEDED: WorkflowRunEventType.WORKFLOW_RUN_EVENT_TYPE_COMPLETED, WorkflowRunStatus.FAILED: WorkflowRunEventType.WORKFLOW_RUN_EVENT_TYPE_FAILED, @@ -48,8 +52,7 @@ class ChildWorkflowRef: if res.status in statusMap: return StepRunEvent( - type=statusMap[res.status], - payload=json.dumps(step_run_output) + type=statusMap[res.status], payload=json.dumps(step_run_output) ) except Exception as e: @@ -63,7 +66,9 @@ class ChildWorkflowRef: res = self.getResult() if res: yield res - await asyncio.sleep(DEFAULT_WORKFLOW_POLLING_INTERVAL if self.pollAttempts > 10 else 0.5) + await asyncio.sleep( + DEFAULT_WORKFLOW_POLLING_INTERVAL if self.pollAttempts > 10 else 0.5 + ) async def stream(self): listener_stream = self.client.listener.stream(self.workflow_run_id) @@ -94,7 +99,7 @@ class ChildWorkflowRef: event.type == WorkflowRunEventType.WORKFLOW_RUN_EVENT_TYPE_FAILED or event.type == WorkflowRunEventType.WORKFLOW_RUN_EVENT_TYPE_CANCELLED or event.type == WorkflowRunEventType.WORKFLOW_RUN_EVENT_TYPE_TIMED_OUT - ): + ): self.close() raise RuntimeError(event.type) @@ -117,7 +122,9 @@ class Context: self.data = {} else: # Directly assign the payload to self.data if it's already a dict - self.data = action.action_payload if isinstance(action.action_payload, dict) else {} + self.data = ( + action.action_payload if isinstance(action.action_payload, dict) else {} + ) self.action = action self.stepRunId = action.step_run_id @@ -125,31 +132,31 @@ class Context: self.client = client # FIXME: this limits the number of concurrent log requests to 1, which means we can do about - # 100 log lines per second but this depends on network. + # 100 log lines per second but this depends on network. self.logger_thread_pool = ThreadPoolExecutor(max_workers=1) self.stream_event_thread_pool = ThreadPoolExecutor(max_workers=1) # store each key in the overrides field in a lookup table # overrides_data is a dictionary of key-value pairs - self.overrides_data = self.data.get('overrides', {}) + self.overrides_data = self.data.get("overrides", {}) if action.get_group_key_run_id != "": self.input = self.data else: - self.input = self.data.get('input', {}) + self.input = self.data.get("input", {}) def step_output(self, step: str): try: - return self.data['parents'][step] + return self.data["parents"][step] except KeyError: raise ValueError(f"Step output for '{step}' not found") def triggered_by_event(self) -> bool: - return self.data.get('triggered_by', '') == 'event' + return self.data.get("triggered_by", "") == "event" def workflow_input(self): return self.input - + def workflow_run_id(self): return self.action.workflow_run_id @@ -158,7 +165,7 @@ class Context: if self.exit_flag.is_set(): raise Exception("Context cancelled") - + def cancel(self): logger.info("Cancelling step...") self.exit_flag.set() @@ -166,42 +173,40 @@ class Context: # done returns true if the context has been cancelled def done(self): return self.exit_flag.is_set() - + def playground(self, name: str, default: str = None): # if the key exists in the overrides_data field, return the value if name in self.overrides_data: return self.overrides_data[name] - + caller_file = get_caller_file_path() - + self.client.dispatcher.put_overrides_data( OverridesData( stepRunId=self.stepRunId, path=name, value=json.dumps(default), - callerFilename=caller_file + callerFilename=caller_file, ) ) return default - + def spawn_workflow(self, workflow_name: str, input: dict = {}, key: str = None): workflow_run_id = self.action.workflow_run_id step_run_id = self.action.step_run_id options: TriggerWorkflowParentOptions = { - 'parent_id': workflow_run_id, - 'parent_step_run_id': step_run_id, - 'child_key': key, - 'child_index': self.spawn_index + "parent_id": workflow_run_id, + "parent_step_run_id": step_run_id, + "child_key": key, + "child_index": self.spawn_index, } self.spawn_index += 1 child_workflow_run_id = self.client.admin.run_workflow( - workflow_name, - input, - options + workflow_name, input, options ) return ChildWorkflowRef(child_workflow_run_id, self.client) @@ -211,11 +216,11 @@ class Context: self.client.event.log(message=line, step_run_id=self.stepRunId) except Exception as e: logger.error(f"Error logging: {e}") - + def log(self, line: str): if self.stepRunId == "": return - + self.logger_thread_pool.submit(self._log, line) def _put_stream(self, data: str | bytes): @@ -223,9 +228,9 @@ class Context: self.client.event.stream(data=data, step_run_id=self.stepRunId) except Exception as e: logger.error(f"Error putting stream event: {e}") - + def put_stream(self, data: str | bytes): if self.stepRunId == "": return - + self.stream_event_thread_pool.submit(self._put_stream, data) diff --git a/python-sdk/hatchet_sdk/hatchet.py b/python-sdk/hatchet_sdk/hatchet.py index f9e1440a4..16d30784f 100644 --- a/python-sdk/hatchet_sdk/hatchet.py +++ b/python-sdk/hatchet_sdk/hatchet.py @@ -1,11 +1,13 @@ -from hatchet_sdk.rate_limit import RateLimit -from .client import ClientImpl, new_client -from typing import List import asyncio from functools import wraps -from .workflow import WorkflowMeta -from .worker import Worker +from typing import List + +from hatchet_sdk.rate_limit import RateLimit + +from .client import ClientImpl, new_client from .logger import logger +from .worker import Worker +from .workflow import WorkflowMeta from .workflows_pb2 import ConcurrencyLimitStrategy, CreateStepRateLimit @@ -19,36 +21,52 @@ class Hatchet: if not debug: logger.disable("hatchet_sdk") - def concurrency(self, name : str='', max_runs : int = 1, limit_strategy : ConcurrencyLimitStrategy = ConcurrencyLimitStrategy.CANCEL_IN_PROGRESS): + def concurrency( + self, + name: str = "", + max_runs: int = 1, + limit_strategy: ConcurrencyLimitStrategy = ConcurrencyLimitStrategy.CANCEL_IN_PROGRESS, + ): def inner(func): func._concurrency_fn_name = name or func.__name__ func._concurrency_max_runs = max_runs func._concurrency_limit_strategy = limit_strategy return func - + return inner - def workflow(self, name : str='', on_events : list=[], on_crons : list=[], version : str='', timeout : str = '60m', schedule_timeout : str = '5m'): + def workflow( + self, + name: str = "", + on_events: list = [], + on_crons: list = [], + version: str = "", + timeout: str = "60m", + schedule_timeout: str = "5m", + ): def inner(cls): - cls.on_events = on_events - cls.on_crons = on_crons - cls.name = name or str(cls.__name__) - cls.client = self.client - cls.version = version - cls.timeout = timeout - cls.schedule_timeout = schedule_timeout + cls.on_events = on_events + cls.on_crons = on_crons + cls.name = name or str(cls.__name__) + cls.client = self.client + cls.version = version + cls.timeout = timeout + cls.schedule_timeout = schedule_timeout + + # Define a new class with the same name and bases as the original, but with WorkflowMeta as its metaclass + return WorkflowMeta(cls.name, cls.__bases__, dict(cls.__dict__)) - # Define a new class with the same name and bases as the original, but with WorkflowMeta as its metaclass - return WorkflowMeta(cls.name, cls.__bases__, dict(cls.__dict__)) - return inner - def step(self, name: str='', - timeout: str='', - parents: List[str] = [], - retries: int = 0, - rate_limits: List[RateLimit] | None = None): + def step( + self, + name: str = "", + timeout: str = "", + parents: List[str] = [], + retries: int = 0, + rate_limits: List[RateLimit] | None = None, + ): def inner(func): @wraps(func) def wrapper(*args, **kwargs): @@ -59,7 +77,10 @@ class Hatchet: limits = None if rate_limits: - limits = [CreateStepRateLimit(key=rate_limit.key, units=rate_limit.units) for rate_limit in rate_limits or []] + limits = [ + CreateStepRateLimit(key=rate_limit.key, units=rate_limit.units) + for rate_limit in rate_limits or [] + ] wrapper._step_name = name or func.__name__ wrapper._step_parents = parents @@ -69,6 +90,6 @@ class Hatchet: return wrapper return inner - + def worker(self, name: str, max_runs: int | None = None): return Worker(name=name, max_runs=max_runs) diff --git a/python-sdk/hatchet_sdk/loader.py b/python-sdk/hatchet_sdk/loader.py index 0a36c9d0d..ab9b2c5fe 100644 --- a/python-sdk/hatchet_sdk/loader.py +++ b/python-sdk/hatchet_sdk/loader.py @@ -1,18 +1,37 @@ import os +from typing import Any, Dict, Optional + import yaml -from typing import Any, Optional, Dict + from .token import get_addresses_from_jwt, get_tenant_id_from_jwt + class ClientTLSConfig: - def __init__(self, tls_strategy: str, cert_file: str, key_file: str, ca_file: str, server_name: str): + def __init__( + self, + tls_strategy: str, + cert_file: str, + key_file: str, + ca_file: str, + server_name: str, + ): self.tls_strategy = tls_strategy self.cert_file = cert_file self.key_file = key_file self.ca_file = ca_file self.server_name = server_name + class ClientConfig: - def __init__(self, tenant_id: str, tls_config: ClientTLSConfig, token: str, host_port: str="localhost:7070", server_url: str="https://app.dev.hatchet-tools.com", namespace: str=None): + def __init__( + self, + tenant_id: str, + tls_config: ClientTLSConfig, + token: str, + host_port: str = "localhost:7070", + server_url: str = "https://app.dev.hatchet-tools.com", + namespace: str = None, + ): self.tenant_id = tenant_id self.tls_config = tls_config self.host_port = host_port @@ -20,6 +39,7 @@ class ClientConfig: self.server_url = server_url self.namespace = (f"{namespace}_" if namespace else "").lower() + class ConfigLoader: def __init__(self, directory: str): self.directory = directory @@ -27,24 +47,42 @@ class ConfigLoader: def load_client_config(self) -> ClientConfig: config_file_path = os.path.join(self.directory, "client.yaml") - config_data : Any = { + config_data: Any = { "tls": {}, } # determine if client.yaml exists if os.path.exists(config_file_path): - with open(config_file_path, 'r') as file: + with open(config_file_path, "r") as file: config_data = yaml.safe_load(file) - - namespace = config_data['namespace'] if 'namespace' in config_data else self._get_env_var('HATCHET_CLIENT_NAMESPACE') - tenant_id = config_data['tenantId'] if 'tenantId' in config_data else self._get_env_var('HATCHET_CLIENT_TENANT_ID') - token = config_data['token'] if 'token' in config_data else self._get_env_var('HATCHET_CLIENT_TOKEN') + + namespace = ( + config_data["namespace"] + if "namespace" in config_data + else self._get_env_var("HATCHET_CLIENT_NAMESPACE") + ) + tenant_id = ( + config_data["tenantId"] + if "tenantId" in config_data + else self._get_env_var("HATCHET_CLIENT_TENANT_ID") + ) + token = ( + config_data["token"] + if "token" in config_data + else self._get_env_var("HATCHET_CLIENT_TOKEN") + ) if not token: - raise ValueError('Token must be set via HATCHET_CLIENT_TOKEN environment variable') + raise ValueError( + "Token must be set via HATCHET_CLIENT_TOKEN environment variable" + ) - host_port = config_data['hostPort'] if 'hostPort' in config_data else self._get_env_var('HATCHET_CLIENT_HOST_PORT') - server_url : str | None = None + host_port = ( + config_data["hostPort"] + if "hostPort" in config_data + else self._get_env_var("HATCHET_CLIENT_HOST_PORT") + ) + server_url: str | None = None if not host_port: # extract host and port from token @@ -55,26 +93,48 @@ class ConfigLoader: if not tenant_id: tenant_id = get_tenant_id_from_jwt(token) - tls_config = self._load_tls_config(config_data['tls'], host_port) + tls_config = self._load_tls_config(config_data["tls"], host_port) - return ClientConfig(tenant_id, tls_config, token, host_port, server_url, namespace) + return ClientConfig( + tenant_id, tls_config, token, host_port, server_url, namespace + ) def _load_tls_config(self, tls_data: Dict, host_port) -> ClientTLSConfig: - tls_strategy = tls_data['tlsStrategy'] if 'tlsStrategy' in tls_data else self._get_env_var('HATCHET_CLIENT_TLS_STRATEGY') + tls_strategy = ( + tls_data["tlsStrategy"] + if "tlsStrategy" in tls_data + else self._get_env_var("HATCHET_CLIENT_TLS_STRATEGY") + ) if not tls_strategy: - tls_strategy = 'tls' + tls_strategy = "tls" - cert_file = tls_data['tlsCertFile'] if 'tlsCertFile' in tls_data else self._get_env_var('HATCHET_CLIENT_TLS_CERT_FILE') - key_file = tls_data['tlsKeyFile'] if 'tlsKeyFile' in tls_data else self._get_env_var('HATCHET_CLIENT_TLS_KEY_FILE') - ca_file = tls_data['tlsRootCAFile'] if 'tlsRootCAFile' in tls_data else self._get_env_var('HATCHET_CLIENT_TLS_ROOT_CA_FILE') + cert_file = ( + tls_data["tlsCertFile"] + if "tlsCertFile" in tls_data + else self._get_env_var("HATCHET_CLIENT_TLS_CERT_FILE") + ) + key_file = ( + tls_data["tlsKeyFile"] + if "tlsKeyFile" in tls_data + else self._get_env_var("HATCHET_CLIENT_TLS_KEY_FILE") + ) + ca_file = ( + tls_data["tlsRootCAFile"] + if "tlsRootCAFile" in tls_data + else self._get_env_var("HATCHET_CLIENT_TLS_ROOT_CA_FILE") + ) - server_name = tls_data['tlsServerName'] if 'tlsServerName' in tls_data else self._get_env_var('HATCHET_CLIENT_TLS_SERVER_NAME') + server_name = ( + tls_data["tlsServerName"] + if "tlsServerName" in tls_data + else self._get_env_var("HATCHET_CLIENT_TLS_SERVER_NAME") + ) # if server_name is not set, use the host from the host_port if not server_name: - server_name = host_port.split(':')[0] - + server_name = host_port.split(":")[0] + return ClientTLSConfig(tls_strategy, cert_file, key_file, ca_file, server_name) @staticmethod diff --git a/python-sdk/hatchet_sdk/logger.py b/python-sdk/hatchet_sdk/logger.py index 598f5faa9..89ffdd1cd 100644 --- a/python-sdk/hatchet_sdk/logger.py +++ b/python-sdk/hatchet_sdk/logger.py @@ -1,5 +1,6 @@ import os import sys + from loguru import logger # loguru config diff --git a/python-sdk/hatchet_sdk/metadata.py b/python-sdk/hatchet_sdk/metadata.py index 49ec89234..38a31b8bc 100644 --- a/python-sdk/hatchet_sdk/metadata.py +++ b/python-sdk/hatchet_sdk/metadata.py @@ -1,2 +1,2 @@ def get_metadata(token: str): - return [('authorization', 'bearer ' + token)] \ No newline at end of file + return [("authorization", "bearer " + token)] diff --git a/python-sdk/hatchet_sdk/rate_limit.py b/python-sdk/hatchet_sdk/rate_limit.py index ebba88b43..d4864bca0 100644 --- a/python-sdk/hatchet_sdk/rate_limit.py +++ b/python-sdk/hatchet_sdk/rate_limit.py @@ -6,7 +6,8 @@ class RateLimit: key: str units: int + class RateLimitDuration: - SECOND='SECOND' - MINUTE='MINUTE' - HOUR='HOUR' \ No newline at end of file + SECOND = "SECOND" + MINUTE = "MINUTE" + HOUR = "HOUR" diff --git a/python-sdk/hatchet_sdk/semver.py b/python-sdk/hatchet_sdk/semver.py index 429359662..4bb9aa4f8 100644 --- a/python-sdk/hatchet_sdk/semver.py +++ b/python-sdk/hatchet_sdk/semver.py @@ -9,11 +9,11 @@ def bump_minor_version(version: str) -> str: """ # if it starts with a v, remove it had_v = False - if version.startswith('v'): + if version.startswith("v"): version = version[1:] had_v = True - parts = version.split('.') + parts = version.split(".") if len(parts) != 3: raise ValueError(f"Invalid semantic version: {version}") @@ -27,4 +27,4 @@ def bump_minor_version(version: str) -> str: if had_v: new_version = "v" + new_version - return new_version \ No newline at end of file + return new_version diff --git a/python-sdk/hatchet_sdk/token.py b/python-sdk/hatchet_sdk/token.py index 5b537ed29..313a6671d 100644 --- a/python-sdk/hatchet_sdk/token.py +++ b/python-sdk/hatchet_sdk/token.py @@ -1,24 +1,27 @@ import base64 import json + def get_tenant_id_from_jwt(token: str) -> str: claims = extract_claims_from_jwt(token) - return claims.get('sub') + return claims.get("sub") + def get_addresses_from_jwt(token: str) -> (str, str): claims = extract_claims_from_jwt(token) - return claims.get('server_url'), claims.get('grpc_broadcast_address') + return claims.get("server_url"), claims.get("grpc_broadcast_address") + def extract_claims_from_jwt(token: str): - parts = token.split('.') + parts = token.split(".") if len(parts) != 3: - raise ValueError('Invalid token format') + raise ValueError("Invalid token format") claims_part = parts[1] - claims_part += '=' * ((4 - len(claims_part) % 4) % 4) # Padding for base64 decoding + claims_part += "=" * ((4 - len(claims_part) % 4) % 4) # Padding for base64 decoding claims_data = base64.urlsafe_b64decode(claims_part) claims = json.loads(claims_data) - return claims \ No newline at end of file + return claims diff --git a/python-sdk/hatchet_sdk/worker.py b/python-sdk/hatchet_sdk/worker.py index 3450a4899..5143e830e 100644 --- a/python-sdk/hatchet_sdk/worker.py +++ b/python-sdk/hatchet_sdk/worker.py @@ -2,32 +2,47 @@ import ctypes import json import signal import sys -from threading import Thread, current_thread import threading import time +from concurrent.futures import Future, ThreadPoolExecutor +from threading import Thread, current_thread +from typing import Any, Callable, Dict import grpc -from typing import Any, Callable, Dict -from .workflow import WorkflowMeta -from .clients.dispatcher import GetActionListenerRequest, ActionListenerImpl, Action -from .dispatcher_pb2 import ActionType, StepActionEvent, StepActionEventType, GroupKeyActionEvent, GroupKeyActionEventType, STEP_EVENT_TYPE_COMPLETED, STEP_EVENT_TYPE_STARTED, STEP_EVENT_TYPE_FAILED, GROUP_KEY_EVENT_TYPE_STARTED, GROUP_KEY_EVENT_TYPE_COMPLETED, GROUP_KEY_EVENT_TYPE_FAILED -from .client import new_client -from concurrent.futures import ThreadPoolExecutor, Future from google.protobuf.timestamp_pb2 import Timestamp + +from .client import new_client +from .clients.dispatcher import Action, ActionListenerImpl, GetActionListenerRequest from .context import Context +from .dispatcher_pb2 import ( + GROUP_KEY_EVENT_TYPE_COMPLETED, + GROUP_KEY_EVENT_TYPE_FAILED, + GROUP_KEY_EVENT_TYPE_STARTED, + STEP_EVENT_TYPE_COMPLETED, + STEP_EVENT_TYPE_FAILED, + STEP_EVENT_TYPE_STARTED, + ActionType, + GroupKeyActionEvent, + GroupKeyActionEventType, + StepActionEvent, + StepActionEventType, +) from .logger import logger +from .workflow import WorkflowMeta class Worker: - def __init__(self, name: str, max_runs: int | None = None, debug=False, handle_kill=True): + def __init__( + self, name: str, max_runs: int | None = None, debug=False, handle_kill=True + ): self.client = new_client() - self.name = self.client.config.namespace+name + self.name = self.client.config.namespace + name self.threads: Dict[str, Thread] = {} # Store step run ids and threads self.max_runs = max_runs self.thread_pool = ThreadPoolExecutor(max_workers=max_runs) self.futures: Dict[str, Future] = {} # Store step run ids and futures self.contexts: Dict[str, Context] = {} # Store step run ids and contexts - self.action_registry : dict[str, Callable[..., Any]] = {} + self.action_registry: dict[str, Callable[..., Any]] = {} signal.signal(signal.SIGINT, self.exit_gracefully) signal.signal(signal.SIGTERM, self.exit_gracefully) @@ -35,9 +50,9 @@ class Worker: self.killing = False self.handle_kill = handle_kill - def handle_start_step_run(self, action : Action): - action_name = action.action_id - context = Context(action, self.client) + def handle_start_step_run(self, action: Action): + action_name = action.action_id + context = Context(action, self.client) self.contexts[action.step_run_id] = context @@ -45,7 +60,8 @@ class Worker: action_func = self.action_registry.get(action_name) if action_func: - def callback(future : Future): + + def callback(future: Future): errored = False # Get the output from the future @@ -92,7 +108,9 @@ class Worker: finally: if action.step_run_id in self.threads: # remove the thread id - logger.debug(f"Removing step run id {action.step_run_id} from threads") + logger.debug( + f"Removing step run id {action.step_run_id} from threads" + ) del self.threads[action.step_run_id] @@ -109,7 +127,7 @@ class Worker: # Send the action event to the dispatcher self.client.dispatcher.send_step_action_event(event) - def handle_start_group_key_run(self, action : Action): + def handle_start_group_key_run(self, action: Action): action_name = action.action_id context = Context(action, self.client) @@ -119,7 +137,8 @@ class Worker: action_func = self.action_registry.get(action_name) if action_func: - def callback(future : Future): + + def callback(future: Future): errored = False # Get the output from the future @@ -129,7 +148,9 @@ class Worker: errored = True # This except is coming from the application itself, so we want to send that to the Hatchet instance - event = self.get_group_key_action_event(action, GROUP_KEY_EVENT_TYPE_FAILED) + event = self.get_group_key_action_event( + action, GROUP_KEY_EVENT_TYPE_FAILED + ) event.eventPayload = str(e) try: @@ -166,7 +187,9 @@ class Worker: finally: if action.get_group_key_run_id in self.threads: # remove the thread id - logger.debug(f"Removing step run id {action.get_group_key_run_id} from threads") + logger.debug( + f"Removing step run id {action.get_group_key_run_id} from threads" + ) del self.threads[action.get_group_key_run_id] @@ -176,7 +199,9 @@ class Worker: # send an event that the step run has started try: - event = self.get_group_key_action_event(action, GROUP_KEY_EVENT_TYPE_STARTED) + event = self.get_group_key_action_event( + action, GROUP_KEY_EVENT_TYPE_STARTED + ) except Exception as e: logger.error(f"Could not create action event: {e}") @@ -188,7 +213,7 @@ class Worker: try: if not thread.is_alive(): return - + logger.info(f"Forcefully terminating thread {thread.ident}") exc = ctypes.py_object(SystemExit) @@ -203,7 +228,7 @@ class Worker: # Call with exception set to 0 is needed to cleanup properly. ctypes.pythonapi.PyThreadState_SetAsyncExc(thread.ident, 0) raise SystemError("PyThreadState_SetAsyncExc failed") - + logger.info(f"Successfully terminated thread {thread.ident}") # Immediately add a new thread to the thread pool, because we've actually killed a worker @@ -211,7 +236,7 @@ class Worker: self.thread_pool.submit(lambda: None) except Exception as e: logger.exception(f"Failed to terminate thread: {e}") - + def handle_cancel_action(self, run_id: str): # call cancel to signal the context to stop context = self.contexts.get(run_id) @@ -237,8 +262,10 @@ class Worker: if run_id in self.threads: del self.threads[run_id] - - def get_step_action_event(self, action : Action, event_type : StepActionEventType) -> StepActionEvent: + + def get_step_action_event( + self, action: Action, event_type: StepActionEventType + ) -> StepActionEvent: eventTimestamp = Timestamp() eventTimestamp.GetCurrentTime() @@ -252,15 +279,17 @@ class Worker: eventTimestamp=eventTimestamp, eventType=event_type, ) - - def get_step_action_finished_event(self, action : Action, output : Any) -> StepActionEvent: + + def get_step_action_finished_event( + self, action: Action, output: Any + ) -> StepActionEvent: try: event = self.get_step_action_event(action, STEP_EVENT_TYPE_COMPLETED) except Exception as e: logger.error(f"Could not create action finished event: {e}") raise e - output_bytes = '' + output_bytes = "" if output is not None: output_bytes = json.dumps(output) @@ -268,8 +297,10 @@ class Worker: event.eventPayload = output_bytes return event - - def get_group_key_action_event(self, action : Action, event_type : GroupKeyActionEventType) -> GroupKeyActionEvent: + + def get_group_key_action_event( + self, action: Action, event_type: GroupKeyActionEventType + ) -> GroupKeyActionEvent: eventTimestamp = Timestamp() eventTimestamp.GetCurrentTime() @@ -281,27 +312,32 @@ class Worker: eventTimestamp=eventTimestamp, eventType=event_type, ) - - def get_group_key_action_finished_event(self, action : Action, output : str) -> StepActionEvent: + + def get_group_key_action_finished_event( + self, action: Action, output: str + ) -> StepActionEvent: try: - event = self.get_group_key_action_event(action, GROUP_KEY_EVENT_TYPE_COMPLETED) + event = self.get_group_key_action_event( + action, GROUP_KEY_EVENT_TYPE_COMPLETED + ) except Exception as e: logger.error(f"Could not create action finished event: {e}") raise e - + try: event.eventPayload = output except Exception as e: event.eventPayload = "" return event - - def register_workflow(self, workflow : WorkflowMeta): + + def register_workflow(self, workflow: WorkflowMeta): self.client.admin.put_workflow(workflow.get_name(), workflow.get_create_opts()) def create_action_function(action_func): def action_function(context): return action_func(workflow, context) + return action_function for action_name, action_func in workflow.get_actions(): @@ -327,17 +363,21 @@ class Worker: if self.handle_kill: logger.info("Exiting...") sys.exit(0) - + def start(self, retry_count=1): logger.info("Starting worker...") try: - self.listener : ActionListenerImpl = self.client.dispatcher.get_action_listener(GetActionListenerRequest( - worker_name=self.name, - services=["default"], - actions=self.action_registry.keys(), - max_runs=self.max_runs, - )) + self.listener: ActionListenerImpl = ( + self.client.dispatcher.get_action_listener( + GetActionListenerRequest( + worker_name=self.name, + services=["default"], + actions=self.action_registry.keys(), + max_runs=self.max_runs, + ) + ) + ) generator = self.listener.actions() @@ -345,7 +385,9 @@ class Worker: if action.action_type == ActionType.START_STEP_RUN: self.handle_start_step_run(action) elif action.action_type == ActionType.CANCEL_STEP_RUN: - self.thread_pool.submit(self.handle_cancel_action, action.step_run_id) + self.thread_pool.submit( + self.handle_cancel_action, action.step_run_id + ) elif action.action_type == ActionType.START_GET_GROUP_KEY: self.handle_start_group_key_run(action) else: diff --git a/python-sdk/hatchet_sdk/workflow.py b/python-sdk/hatchet_sdk/workflow.py index f1e53295d..6458fb6bf 100644 --- a/python-sdk/hatchet_sdk/workflow.py +++ b/python-sdk/hatchet_sdk/workflow.py @@ -1,59 +1,80 @@ -from .workflows_pb2 import CreateWorkflowVersionOpts, CreateWorkflowJobOpts, CreateWorkflowStepOpts, WorkflowConcurrencyOpts -from typing import Callable, List, Tuple, Any +from typing import Any, Callable, List, Tuple + +from .workflows_pb2 import ( + CreateWorkflowJobOpts, + CreateWorkflowStepOpts, + CreateWorkflowVersionOpts, + WorkflowConcurrencyOpts, +) stepsType = List[Tuple[str, Callable[..., Any]]] + class WorkflowMeta(type): def __new__(cls, name, bases, attrs): - namespace = attrs['client'].config.namespace + namespace = attrs["client"].config.namespace serviceName = namespace + name.lower() - concurrencyActions: stepsType = [(func_name, attrs.pop(func_name)) for func_name, func in list(attrs.items()) if hasattr(func, '_concurrency_fn_name')] - steps: stepsType = [(func_name, attrs.pop(func_name)) for func_name, func in list(attrs.items()) if hasattr(func, '_step_name')] + concurrencyActions: stepsType = [ + (func_name, attrs.pop(func_name)) + for func_name, func in list(attrs.items()) + if hasattr(func, "_concurrency_fn_name") + ] + steps: stepsType = [ + (func_name, attrs.pop(func_name)) + for func_name, func in list(attrs.items()) + if hasattr(func, "_step_name") + ] # Define __init__ and get_step_order methods - original_init = attrs.get('__init__') # Get the original __init__ if it exists + original_init = attrs.get("__init__") # Get the original __init__ if it exists def __init__(self, *args, **kwargs): if original_init: original_init(self, *args, **kwargs) # Call original __init__ def get_actions(self) -> stepsType: - func_actions = [(serviceName + ":" + func_name, func) for func_name, func in steps] - concurrency_actions = [(serviceName + ":" + func_name, func) for func_name, func in concurrencyActions] + func_actions = [ + (serviceName + ":" + func_name, func) for func_name, func in steps + ] + concurrency_actions = [ + (serviceName + ":" + func_name, func) + for func_name, func in concurrencyActions + ] return func_actions + concurrency_actions - + # Add these methods and steps to class attributes - attrs['__init__'] = __init__ - attrs['get_actions'] = get_actions + attrs["__init__"] = __init__ + attrs["get_actions"] = get_actions for step_name, step_func in steps: attrs[step_name] = step_func - name = namespace + attrs['name'] - event_triggers = [namespace + event for event in attrs['on_events']] - cron_triggers = attrs['on_crons'] - version = attrs['version'] - workflowTimeout = attrs['timeout'] - schedule_timeout = attrs['schedule_timeout'] + name = namespace + attrs["name"] + event_triggers = [namespace + event for event in attrs["on_events"]] + cron_triggers = attrs["on_crons"] + version = attrs["version"] + workflowTimeout = attrs["timeout"] + schedule_timeout = attrs["schedule_timeout"] createStepOpts: List[CreateWorkflowStepOpts] = [ CreateWorkflowStepOpts( readable_id=func_name, action=serviceName + ":" + func_name, timeout=func._step_timeout or "60s", - inputs='{}', + inputs="{}", parents=[x for x in func._step_parents], retries=func._step_retries, rate_limits=func._step_rate_limits, ) - for func_name, func in attrs.items() if hasattr(func, '_step_name') + for func_name, func in attrs.items() + if hasattr(func, "_step_name") ] - concurrency : WorkflowConcurrencyOpts | None = None + concurrency: WorkflowConcurrencyOpts | None = None if len(concurrencyActions) > 0: action = concurrencyActions[0] @@ -80,11 +101,11 @@ class WorkflowMeta(type): ], concurrency=concurrency, ) - + def get_name(self): return name - - attrs['get_create_opts'] = get_create_opts - attrs['get_name'] = get_name + + attrs["get_create_opts"] = get_create_opts + attrs["get_name"] = get_name return super(WorkflowMeta, cls).__new__(cls, name, bases, attrs) diff --git a/python-sdk/publish.sh b/python-sdk/publish.sh index fd60dd858..345c61c1d 100644 --- a/python-sdk/publish.sh +++ b/python-sdk/publish.sh @@ -8,4 +8,4 @@ if [ -z "$POETRY_PYPI_TOKEN_PYPI" ]; then fi poetry build -poetry publish \ No newline at end of file +poetry publish diff --git a/python-sdk/pyproject.toml b/python-sdk/pyproject.toml index a53426561..e7b3787b8 100644 --- a/python-sdk/pyproject.toml +++ b/python-sdk/pyproject.toml @@ -21,3 +21,17 @@ aiostream = "^0.5.2" [build-system] requires = ["poetry-core"] build-backend = "poetry.core.masonry.api" + +[tool.isort] +profile = "black" +known_third_party = [ + "grpcio", + "grpcio_tools", + "loguru", + "protobuf", + "pydantic", + "python_dotenv", + "python_dateutil", + "pyyaml", + "urllib3" +]