zuplo 6.67.32 → 6.68.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +9 -0
- package/docs/_index.md +44 -0
- package/docs/ai-gateway/apps.mdx +28 -0
- package/docs/ai-gateway/custom-providers.mdx +54 -0
- package/docs/ai-gateway/getting-started.mdx +224 -0
- package/docs/ai-gateway/guardrails.mdx +65 -0
- package/docs/ai-gateway/integrations/ai-sdk.mdx +109 -0
- package/docs/ai-gateway/integrations/claude-code.mdx +49 -0
- package/docs/ai-gateway/integrations/codex.mdx +78 -0
- package/docs/ai-gateway/integrations/goose.mdx +104 -0
- package/docs/ai-gateway/integrations/langchain.mdx +66 -0
- package/docs/ai-gateway/integrations/openai.mdx +99 -0
- package/docs/ai-gateway/introduction.mdx +85 -0
- package/docs/ai-gateway/managing-apps.mdx +46 -0
- package/docs/ai-gateway/managing-providers.mdx +66 -0
- package/docs/ai-gateway/managing-teams.mdx +63 -0
- package/docs/ai-gateway/policies/akamai-ai-firewall.mdx +125 -0
- package/docs/ai-gateway/policies/comet-opik-tracing.mdx +139 -0
- package/docs/ai-gateway/policies/galileo-tracing.mdx +147 -0
- package/docs/ai-gateway/providers.mdx +32 -0
- package/docs/ai-gateway/teams.mdx +38 -0
- package/docs/ai-gateway/universal-api.mdx +43 -0
- package/docs/ai-gateway/usage-limits.mdx +89 -0
- package/docs/api-management/introduction.md +127 -0
- package/docs/articles/accounts/audit-logs.mdx +227 -0
- package/docs/articles/accounts/billing.mdx +25 -0
- package/docs/articles/accounts/default-api-key.mdx +30 -0
- package/docs/articles/accounts/delete-account.mdx +36 -0
- package/docs/articles/accounts/enterprise-sso.mdx +116 -0
- package/docs/articles/accounts/managing-account-members.mdx +45 -0
- package/docs/articles/accounts/managing-project-members.mdx +37 -0
- package/docs/articles/accounts/members-and-roles.mdx +21 -0
- package/docs/articles/accounts/roles-and-permissions.mdx +115 -0
- package/docs/articles/accounts/zuplo-api-keys.mdx +94 -0
- package/docs/articles/add-api-to-backstage.mdx +216 -0
- package/docs/articles/advanced-path-matching.mdx +139 -0
- package/docs/articles/api-key-administration.mdx +47 -0
- package/docs/articles/api-key-api.mdx +220 -0
- package/docs/articles/api-key-authentication.mdx +195 -0
- package/docs/articles/api-key-buckets.mdx +61 -0
- package/docs/articles/api-key-end-users.mdx +52 -0
- package/docs/articles/api-key-leak-detection.mdx +75 -0
- package/docs/articles/api-key-management.mdx +100 -0
- package/docs/articles/api-key-react-component.mdx +90 -0
- package/docs/articles/api-key-service-limits.mdx +14 -0
- package/docs/articles/archiving-requests-to-storage.mdx +119 -0
- package/docs/articles/branch-based-deployments.mdx +184 -0
- package/docs/articles/bypass-policy-for-testing.mdx +117 -0
- package/docs/articles/check-ip-address.mdx +17 -0
- package/docs/articles/ci-cd-azure/basic-deployment.mdx +49 -0
- package/docs/articles/ci-cd-azure/deploy-and-test.mdx +47 -0
- package/docs/articles/ci-cd-azure/local-testing.mdx +59 -0
- package/docs/articles/ci-cd-azure/multi-stage-deployment.mdx +88 -0
- package/docs/articles/ci-cd-azure/pr-preview-environments.mdx +50 -0
- package/docs/articles/ci-cd-azure/tag-based-releases.mdx +37 -0
- package/docs/articles/ci-cd-bitbucket/basic-deployment.mdx +27 -0
- package/docs/articles/ci-cd-bitbucket/deploy-and-test.mdx +41 -0
- package/docs/articles/ci-cd-bitbucket/local-testing.mdx +34 -0
- package/docs/articles/ci-cd-bitbucket/multi-stage-deployment.mdx +52 -0
- package/docs/articles/ci-cd-bitbucket/pr-preview-environments.mdx +46 -0
- package/docs/articles/ci-cd-bitbucket/tag-based-releases.mdx +27 -0
- package/docs/articles/ci-cd-circleci/basic-deployment.mdx +34 -0
- package/docs/articles/ci-cd-circleci/deploy-and-test.mdx +44 -0
- package/docs/articles/ci-cd-circleci/local-testing.mdx +50 -0
- package/docs/articles/ci-cd-circleci/multi-stage-deployment.mdx +82 -0
- package/docs/articles/ci-cd-circleci/pr-preview-environments.mdx +47 -0
- package/docs/articles/ci-cd-circleci/tag-based-releases.mdx +38 -0
- package/docs/articles/ci-cd-github/basic-deployment.mdx +48 -0
- package/docs/articles/ci-cd-github/cleanup-on-branch-delete.mdx +123 -0
- package/docs/articles/ci-cd-github/deploy-and-test.mdx +82 -0
- package/docs/articles/ci-cd-github/local-testing.mdx +102 -0
- package/docs/articles/ci-cd-github/multi-stage-deployment.mdx +136 -0
- package/docs/articles/ci-cd-github/pr-preview-environments.mdx +106 -0
- package/docs/articles/ci-cd-github/tag-based-releases.mdx +99 -0
- package/docs/articles/ci-cd-gitlab/basic-deployment.mdx +28 -0
- package/docs/articles/ci-cd-gitlab/deploy-and-test.mdx +44 -0
- package/docs/articles/ci-cd-gitlab/local-testing.mdx +39 -0
- package/docs/articles/ci-cd-gitlab/mr-preview-environments.mdx +52 -0
- package/docs/articles/ci-cd-gitlab/multi-stage-deployment.mdx +64 -0
- package/docs/articles/ci-cd-gitlab/tag-based-releases.mdx +28 -0
- package/docs/articles/composite-policy-reference.mdx +284 -0
- package/docs/articles/configuring-auth0-for-mcp-auth.mdx +186 -0
- package/docs/articles/configuring-okta-for-mcp-auth.mdx +208 -0
- package/docs/articles/convert-urls-to-openapi.mdx +62 -0
- package/docs/articles/cors.mdx +447 -0
- package/docs/articles/custom-audit-log-policy.mdx +95 -0
- package/docs/articles/custom-ci-cd-azure.mdx +81 -0
- package/docs/articles/custom-ci-cd-bitbucket.mdx +80 -0
- package/docs/articles/custom-ci-cd-circleci.mdx +78 -0
- package/docs/articles/custom-ci-cd-github.mdx +99 -0
- package/docs/articles/custom-ci-cd-gitlab.mdx +79 -0
- package/docs/articles/custom-ci-cd.mdx +82 -0
- package/docs/articles/custom-code-patterns.md +418 -0
- package/docs/articles/custom-domains.mdx +258 -0
- package/docs/articles/custom-logging-example.mdx +139 -0
- package/docs/articles/ddos-protection.mdx +138 -0
- package/docs/articles/development-options.mdx +49 -0
- package/docs/articles/environment-variables.mdx +134 -0
- package/docs/articles/environments.mdx +143 -0
- package/docs/articles/fastly-zuplo-host-setup.mdx +41 -0
- package/docs/articles/github-deployment-testing.mdx +101 -0
- package/docs/articles/gke-with-upstream-auth-policy.mdx +192 -0
- package/docs/articles/graphql-security.mdx +180 -0
- package/docs/articles/handling-form-data.mdx +61 -0
- package/docs/articles/health-checks.mdx +109 -0
- package/docs/articles/hosting-options.mdx +70 -0
- package/docs/articles/lazy-load-configuration-into-cache.mdx +92 -0
- package/docs/articles/limits.mdx +98 -0
- package/docs/articles/local-development-debugging.mdx +44 -0
- package/docs/articles/local-development-env-variables.mdx +23 -0
- package/docs/articles/local-development-installing-packages.mdx +23 -0
- package/docs/articles/local-development-routes-designer.mdx +27 -0
- package/docs/articles/local-development-services.mdx +40 -0
- package/docs/articles/local-development-troubleshooting.mdx +56 -0
- package/docs/articles/local-development.mdx +81 -0
- package/docs/articles/log-plugin-aws-cloudwatch.mdx +83 -0
- package/docs/articles/log-plugin-datadog.mdx +84 -0
- package/docs/articles/log-plugin-dynatrace.mdx +75 -0
- package/docs/articles/log-plugin-gcp.mdx +75 -0
- package/docs/articles/log-plugin-loki.mdx +136 -0
- package/docs/articles/log-plugin-new-relic.mdx +84 -0
- package/docs/articles/log-plugin-splunk.mdx +104 -0
- package/docs/articles/log-plugin-sumo.mdx +73 -0
- package/docs/articles/log-plugin-vmware-log-insight.mdx +154 -0
- package/docs/articles/log-request-response-data.mdx +398 -0
- package/docs/articles/logging.mdx +115 -0
- package/docs/articles/manual-mcp-oauth-testing.mdx +193 -0
- package/docs/articles/mcp-quickstart.mdx +135 -0
- package/docs/articles/metrics-plugins.mdx +371 -0
- package/docs/articles/migrate-from-apigee.md +408 -0
- package/docs/articles/migrate-from-aws-api-gateway.md +248 -0
- package/docs/articles/migrate-from-azure-apim.md +292 -0
- package/docs/articles/migrate-from-kong.md +300 -0
- package/docs/articles/migration-overview.md +81 -0
- package/docs/articles/monetization/api-access.mdx +69 -0
- package/docs/articles/monetization/billing-models.md +520 -0
- package/docs/articles/monetization/developer-portal.md +167 -0
- package/docs/articles/monetization/features.mdx +98 -0
- package/docs/articles/monetization/index.mdx +113 -0
- package/docs/articles/monetization/meters.mdx +135 -0
- package/docs/articles/monetization/monetization-policy.md +314 -0
- package/docs/articles/monetization/plan-examples.mdx +366 -0
- package/docs/articles/monetization/plans.mdx +266 -0
- package/docs/articles/monetization/pricing-models.mdx +225 -0
- package/docs/articles/monetization/private-plans.md +154 -0
- package/docs/articles/monetization/quickstart.md +355 -0
- package/docs/articles/monetization/rate-cards.mdx +171 -0
- package/docs/articles/monetization/stripe-integration.md +195 -0
- package/docs/articles/monetization/subscription-lifecycle.md +298 -0
- package/docs/articles/monetization/tax-collection.md +166 -0
- package/docs/articles/monetization/troubleshooting.md +272 -0
- package/docs/articles/monetization-custom.mdx +71 -0
- package/docs/articles/monetization-integrations.mdx +104 -0
- package/docs/articles/monitoring-your-gateway.mdx +53 -0
- package/docs/articles/monorepo-deployment.mdx +350 -0
- package/docs/articles/multiple-auth-policies.mdx +81 -0
- package/docs/articles/non-standard-ports.mdx +30 -0
- package/docs/articles/oauth-authentication.mdx +54 -0
- package/docs/articles/openapi-server-urls.mdx +60 -0
- package/docs/articles/openapi.mdx +130 -0
- package/docs/articles/opentelemetry.mdx +250 -0
- package/docs/articles/per-user-rate-limits-using-db.mdx +112 -0
- package/docs/articles/performance-testing.mdx +304 -0
- package/docs/articles/plugin-akamai-api-security.mdx +76 -0
- package/docs/articles/plugin-azure-blob.mdx +73 -0
- package/docs/articles/plugin-azure-event-hubs.mdx +64 -0
- package/docs/articles/plugin-hydrolix-traffic-peak.mdx +147 -0
- package/docs/articles/policies.mdx +33 -0
- package/docs/articles/rename-or-move-project.mdx +39 -0
- package/docs/articles/rick-and-morty-api-developer-portal-example.mdx +23 -0
- package/docs/articles/routing.mdx +193 -0
- package/docs/articles/s3-signed-url-uploads.mdx +521 -0
- package/docs/articles/secure-tunnel.mdx +84 -0
- package/docs/articles/securing-backend-mtls.mdx +268 -0
- package/docs/articles/securing-your-backend.mdx +148 -0
- package/docs/articles/security.mdx +105 -0
- package/docs/articles/sharing-code-across-projects.mdx +412 -0
- package/docs/articles/source-control-setup-azure.mdx +13 -0
- package/docs/articles/source-control-setup-bitbucket.mdx +43 -0
- package/docs/articles/source-control-setup-github.mdx +172 -0
- package/docs/articles/source-control-setup-gitlab.mdx +12 -0
- package/docs/articles/source-control.mdx +80 -0
- package/docs/articles/step-1-setup-basic-gateway-local.mdx +136 -0
- package/docs/articles/step-1-setup-basic-gateway.mdx +118 -0
- package/docs/articles/step-2-add-rate-limiting-local.mdx +126 -0
- package/docs/articles/step-2-add-rate-limiting.mdx +82 -0
- package/docs/articles/step-3-add-api-key-auth-local.mdx +199 -0
- package/docs/articles/step-3-add-api-key-auth.mdx +166 -0
- package/docs/articles/step-4-deploying-to-the-edge.mdx +220 -0
- package/docs/articles/step-5-dynamic-rate-limiting.mdx +167 -0
- package/docs/articles/support.mdx +144 -0
- package/docs/articles/terraform.mdx +114 -0
- package/docs/articles/testing-graphql.mdx +34 -0
- package/docs/articles/testing.mdx +522 -0
- package/docs/articles/troubleshooting-slow-responses.mdx +301 -0
- package/docs/articles/troubleshooting.md +302 -0
- package/docs/articles/tsconfig.mdx +105 -0
- package/docs/articles/tunnel-setup.mdx +195 -0
- package/docs/articles/tunnel-troubleshooting.mdx +50 -0
- package/docs/articles/update-zup-in-github-action.mdx +110 -0
- package/docs/articles/use-openapi-extension-data.mdx +79 -0
- package/docs/articles/users/multifactor-authentication.mdx +64 -0
- package/docs/articles/users/profile.mdx +13 -0
- package/docs/articles/versioning-on-zuplo.mdx +89 -0
- package/docs/articles/waf-ddos-akamai.md +133 -0
- package/docs/articles/waf-ddos-aws-waf-shield.mdx +85 -0
- package/docs/articles/waf-ddos-fastly.mdx +251 -0
- package/docs/articles/waf-ddos.mdx +140 -0
- package/docs/articles/zuplo-waf.mdx +156 -0
- package/docs/ask.mdx +3 -0
- package/docs/cli/authentication.mdx +56 -0
- package/docs/cli/connectivity.mdx +38 -0
- package/docs/cli/create-zuplo-api.mdx +80 -0
- package/docs/cli/delete.mdx +79 -0
- package/docs/cli/deploy.mdx +156 -0
- package/docs/cli/deploy.partial.mdx +46 -0
- package/docs/cli/dev.mdx +115 -0
- package/docs/cli/docs.mdx +66 -0
- package/docs/cli/editor.mdx +50 -0
- package/docs/cli/global-options.mdx +19 -0
- package/docs/cli/init.mdx +74 -0
- package/docs/cli/link.mdx +74 -0
- package/docs/cli/list.mdx +55 -0
- package/docs/cli/mtls-certificate-create.mdx +94 -0
- package/docs/cli/mtls-certificate-delete.mdx +55 -0
- package/docs/cli/mtls-certificate-describe.mdx +55 -0
- package/docs/cli/mtls-certificate-disable.mdx +55 -0
- package/docs/cli/mtls-certificate-list.mdx +47 -0
- package/docs/cli/mtls-certificate-update.mdx +72 -0
- package/docs/cli/openapi-convert.mdx +111 -0
- package/docs/cli/openapi-merge.mdx +138 -0
- package/docs/cli/openapi-merge.partial.mdx +29 -0
- package/docs/cli/openapi-overlay.mdx +123 -0
- package/docs/cli/overview.mdx +78 -0
- package/docs/cli/project-create.mdx +43 -0
- package/docs/cli/source-migrate.mdx +18 -0
- package/docs/cli/source-upgrade.mdx +41 -0
- package/docs/cli/test.mdx +70 -0
- package/docs/cli/test.partial.mdx +7 -0
- package/docs/cli/tunnel-create.mdx +53 -0
- package/docs/cli/tunnel-create.partial.mdx +9 -0
- package/docs/cli/tunnel-delete.mdx +35 -0
- package/docs/cli/tunnel-delete.partial.mdx +9 -0
- package/docs/cli/tunnel-describe.mdx +45 -0
- package/docs/cli/tunnel-describe.partial.mdx +5 -0
- package/docs/cli/tunnel-list.mdx +35 -0
- package/docs/cli/tunnel-list.partial.mdx +9 -0
- package/docs/cli/tunnel-rate-token.partial.mdx +9 -0
- package/docs/cli/tunnel-rotate-token.mdx +39 -0
- package/docs/cli/tunnel-services-describe.mdx +45 -0
- package/docs/cli/tunnel-services-describe.partial.mdx +9 -0
- package/docs/cli/tunnel-services-update.mdx +48 -0
- package/docs/cli/variable-create.mdx +91 -0
- package/docs/cli/variable-create.partial.mdx +5 -0
- package/docs/cli/variable-update.mdx +75 -0
- package/docs/cli/variable-update.partial.mdx +5 -0
- package/docs/concepts/api-keys.md +146 -0
- package/docs/concepts/authentication.mdx +109 -0
- package/docs/concepts/how-zuplo-works.mdx +120 -0
- package/docs/concepts/project-structure.mdx +174 -0
- package/docs/concepts/rate-limiting.md +246 -0
- package/docs/concepts/request-lifecycle.mdx +56 -0
- package/docs/concepts/source-control-and-deployment.mdx +229 -0
- package/docs/conferences/conference-prize-terms.mdx +80 -0
- package/docs/dedicated/akamai/ai-powered-applications.mdx +223 -0
- package/docs/dedicated/akamai/architecture.mdx +280 -0
- package/docs/dedicated/akamai/caching.mdx +212 -0
- package/docs/dedicated/akamai/cdn.mdx +156 -0
- package/docs/dedicated/architecture.mdx +208 -0
- package/docs/dedicated/custom-domains.mdx +31 -0
- package/docs/dedicated/federated-gateways.mdx +80 -0
- package/docs/dedicated/networking.mdx +69 -0
- package/docs/dedicated/overview.mdx +80 -0
- package/docs/dedicated/source-control.mdx +63 -0
- package/docs/dev-portal/dev-portal-create-consumer-on-auth.mdx +134 -0
- package/docs/dev-portal/introduction.mdx +65 -0
- package/docs/dev-portal/local-development.mdx +72 -0
- package/docs/dev-portal/migration.mdx +526 -0
- package/docs/dev-portal/node-modules.mdx +45 -0
- package/docs/dev-portal/updating.mdx +28 -0
- package/docs/dev-portal/zudoku/components/alert.mdx +130 -0
- package/docs/dev-portal/zudoku/components/badge.mdx +70 -0
- package/docs/dev-portal/zudoku/components/button.mdx +132 -0
- package/docs/dev-portal/zudoku/components/callout.mdx +112 -0
- package/docs/dev-portal/zudoku/components/card.mdx +104 -0
- package/docs/dev-portal/zudoku/components/checkbox.mdx +72 -0
- package/docs/dev-portal/zudoku/components/client-only.mdx +79 -0
- package/docs/dev-portal/zudoku/components/code-tabs.mdx +179 -0
- package/docs/dev-portal/zudoku/components/dialog.mdx +167 -0
- package/docs/dev-portal/zudoku/components/head.mdx +199 -0
- package/docs/dev-portal/zudoku/components/icons.mdx +27 -0
- package/docs/dev-portal/zudoku/components/input.mdx +96 -0
- package/docs/dev-portal/zudoku/components/label.mdx +86 -0
- package/docs/dev-portal/zudoku/components/link.mdx +242 -0
- package/docs/dev-portal/zudoku/components/markdown.mdx +151 -0
- package/docs/dev-portal/zudoku/components/mermaid.mdx +81 -0
- package/docs/dev-portal/zudoku/components/playground.mdx +87 -0
- package/docs/dev-portal/zudoku/components/secret.mdx +78 -0
- package/docs/dev-portal/zudoku/components/select.mdx +176 -0
- package/docs/dev-portal/zudoku/components/shadcn.mdx +73 -0
- package/docs/dev-portal/zudoku/components/slider.mdx +108 -0
- package/docs/dev-portal/zudoku/components/slot.mdx +119 -0
- package/docs/dev-portal/zudoku/components/stepper.mdx +138 -0
- package/docs/dev-portal/zudoku/components/switch.mdx +96 -0
- package/docs/dev-portal/zudoku/components/syntax-highlight.mdx +602 -0
- package/docs/dev-portal/zudoku/components/textarea.mdx +78 -0
- package/docs/dev-portal/zudoku/components/tooltip.mdx +195 -0
- package/docs/dev-portal/zudoku/components/typography.mdx +61 -0
- package/docs/dev-portal/zudoku/configuration/ai-assistants.md +64 -0
- package/docs/dev-portal/zudoku/configuration/api-catalog.md +108 -0
- package/docs/dev-portal/zudoku/configuration/api-reference.md +397 -0
- package/docs/dev-portal/zudoku/configuration/authentication-auth0.md +173 -0
- package/docs/dev-portal/zudoku/configuration/authentication-azure-ad.md +238 -0
- package/docs/dev-portal/zudoku/configuration/authentication-clerk.md +110 -0
- package/docs/dev-portal/zudoku/configuration/authentication-firebase.md +61 -0
- package/docs/dev-portal/zudoku/configuration/authentication-pingfederate.md +136 -0
- package/docs/dev-portal/zudoku/configuration/authentication-supabase.md +225 -0
- package/docs/dev-portal/zudoku/configuration/authentication.md +199 -0
- package/docs/dev-portal/zudoku/configuration/build-configuration.mdx +147 -0
- package/docs/dev-portal/zudoku/configuration/docs.md +282 -0
- package/docs/dev-portal/zudoku/configuration/footer.mdx +214 -0
- package/docs/dev-portal/zudoku/configuration/llms.md +89 -0
- package/docs/dev-portal/zudoku/configuration/navigation.mdx +408 -0
- package/docs/dev-portal/zudoku/configuration/overview.md +380 -0
- package/docs/dev-portal/zudoku/configuration/protected-routes.md +149 -0
- package/docs/dev-portal/zudoku/configuration/search.md +169 -0
- package/docs/dev-portal/zudoku/configuration/sentry.mdx +44 -0
- package/docs/dev-portal/zudoku/configuration/site.md +124 -0
- package/docs/dev-portal/zudoku/configuration/slots.mdx +124 -0
- package/docs/dev-portal/zudoku/configuration/vite-config.md +18 -0
- package/docs/dev-portal/zudoku/custom-plugins.md +287 -0
- package/docs/dev-portal/zudoku/customization/colors-theme.mdx +275 -0
- package/docs/dev-portal/zudoku/customization/fonts.md +110 -0
- package/docs/dev-portal/zudoku/extending/events.md +124 -0
- package/docs/dev-portal/zudoku/guides/custom-pages.md +106 -0
- package/docs/dev-portal/zudoku/guides/environment-variables.md +99 -0
- package/docs/dev-portal/zudoku/guides/mermaid.mdx +70 -0
- package/docs/dev-portal/zudoku/guides/navigation-migration.md +87 -0
- package/docs/dev-portal/zudoku/guides/navigation-rules.mdx +197 -0
- package/docs/dev-portal/zudoku/guides/processors.mdx +234 -0
- package/docs/dev-portal/zudoku/guides/static-files.md +55 -0
- package/docs/dev-portal/zudoku/guides/transforming-examples.md +156 -0
- package/docs/dev-portal/zudoku/guides/using-multiple-apis.md +87 -0
- package/docs/dev-portal/zudoku/markdown/admonitions.md +128 -0
- package/docs/dev-portal/zudoku/markdown/code-blocks.md +196 -0
- package/docs/dev-portal/zudoku/markdown/frontmatter.md +172 -0
- package/docs/dev-portal/zudoku/markdown/mdx.md +68 -0
- package/docs/dev-portal/zudoku/markdown/overview.md +275 -0
- package/docs/dev-portal/zudoku/plugins.md +5 -0
- package/docs/dev-portal/zudoku/writing.mdx +72 -0
- package/docs/errors/bad-request.mdx +39 -0
- package/docs/errors/build-error.mdx +45 -0
- package/docs/errors/fatal-project-error.mdx +39 -0
- package/docs/errors/gateway-timeout.mdx +33 -0
- package/docs/errors/get-head-body-error.mdx +41 -0
- package/docs/errors/main-mod-error.mdx +40 -0
- package/docs/errors/no-project-set.mdx +41 -0
- package/docs/errors/not-found.mdx +43 -0
- package/docs/errors/rate-limit-exceeded.mdx +31 -0
- package/docs/errors/schema-validation-failed.mdx +51 -0
- package/docs/errors/system-configuration-error.mdx +44 -0
- package/docs/errors/unauthorized.mdx +50 -0
- package/docs/errors/unknown-error.mdx +42 -0
- package/docs/errors.mdx +14 -0
- package/docs/guides/canary-routing-for-employees.mdx +385 -0
- package/docs/guides/geolocation-backend-routing.mdx +404 -0
- package/docs/guides/modify-openapi-paths.mdx +371 -0
- package/docs/guides/openapi-overlays.mdx +492 -0
- package/docs/guides/overview.mdx +12 -0
- package/docs/guides/user-based-backend-routing.mdx +437 -0
- package/docs/handlers/aws-lambda.mdx +201 -0
- package/docs/handlers/custom-handler.mdx +112 -0
- package/docs/handlers/legacy-dev-portal-handler.mdx +135 -0
- package/docs/handlers/mcp-server.mdx +730 -0
- package/docs/handlers/openapi.mdx +78 -0
- package/docs/handlers/redirect.mdx +115 -0
- package/docs/handlers/system-handlers.mdx +41 -0
- package/docs/handlers/url-forward.mdx +204 -0
- package/docs/handlers/url-rewrite.mdx +224 -0
- package/docs/handlers/websocket-handler.mdx +154 -0
- package/docs/home.mdx +6 -0
- package/docs/managed-edge/overview.md +78 -0
- package/docs/mcp-server/configuration-migration-guide.mdx +344 -0
- package/docs/mcp-server/custom-tools.mdx +487 -0
- package/docs/mcp-server/graphql.mdx +241 -0
- package/docs/mcp-server/introduction.mdx +122 -0
- package/docs/mcp-server/openai-apps-sdk.mdx +160 -0
- package/docs/mcp-server/prompts.mdx +283 -0
- package/docs/mcp-server/resources.mdx +288 -0
- package/docs/mcp-server/testing.mdx +53 -0
- package/docs/mcp-server/tools.mdx +306 -0
- package/docs/policies/_index.md +92 -0
- package/docs/policies/ab-test-inbound/intro.md +8 -0
- package/docs/policies/ab-test-inbound/policy.ts +14 -0
- package/docs/policies/ab-test-inbound/schema.json +27 -0
- package/docs/policies/ab-test-outbound/intro.md +8 -0
- package/docs/policies/ab-test-outbound/policy.ts +26 -0
- package/docs/policies/ab-test-outbound/schema.json +27 -0
- package/docs/policies/acl-policy-inbound/intro.md +5 -0
- package/docs/policies/acl-policy-inbound/policy.ts +32 -0
- package/docs/policies/acl-policy-inbound/schema.json +52 -0
- package/docs/policies/akamai-ai-firewall/schema.json +98 -0
- package/docs/policies/amberflo-metering-inbound/doc.md +183 -0
- package/docs/policies/amberflo-metering-inbound/intro.md +20 -0
- package/docs/policies/amberflo-metering-inbound/schema.json +108 -0
- package/docs/policies/api-key-inbound/doc.md +77 -0
- package/docs/policies/api-key-inbound/intro.md +30 -0
- package/docs/policies/api-key-inbound/schema.json +84 -0
- package/docs/policies/archive-request-aws-s3-inbound/intro.md +4 -0
- package/docs/policies/archive-request-aws-s3-inbound/policy.ts +58 -0
- package/docs/policies/archive-request-aws-s3-inbound/schema.json +68 -0
- package/docs/policies/archive-request-azure-storage-inbound/doc.md +31 -0
- package/docs/policies/archive-request-azure-storage-inbound/intro.md +4 -0
- package/docs/policies/archive-request-azure-storage-inbound/policy.ts +54 -0
- package/docs/policies/archive-request-azure-storage-inbound/schema.json +53 -0
- package/docs/policies/archive-request-gcp-storage-inbound/doc.md +63 -0
- package/docs/policies/archive-request-gcp-storage-inbound/intro.md +4 -0
- package/docs/policies/archive-request-gcp-storage-inbound/policy.ts +68 -0
- package/docs/policies/archive-request-gcp-storage-inbound/schema.json +47 -0
- package/docs/policies/archive-response-aws-s3-outbound/intro.md +2 -0
- package/docs/policies/archive-response-aws-s3-outbound/policy.ts +59 -0
- package/docs/policies/archive-response-aws-s3-outbound/schema.json +68 -0
- package/docs/policies/archive-response-azure-storage-outbound/doc.md +31 -0
- package/docs/policies/archive-response-azure-storage-outbound/intro.md +3 -0
- package/docs/policies/archive-response-azure-storage-outbound/policy.ts +54 -0
- package/docs/policies/archive-response-azure-storage-outbound/schema.json +53 -0
- package/docs/policies/audit-log-inbound/doc.md +78 -0
- package/docs/policies/audit-log-inbound/intro.md +10 -0
- package/docs/policies/audit-log-inbound/schema.json +81 -0
- package/docs/policies/auth0-jwt-auth-inbound/doc.md +125 -0
- package/docs/policies/auth0-jwt-auth-inbound/intro.md +17 -0
- package/docs/policies/auth0-jwt-auth-inbound/schema.json +74 -0
- package/docs/policies/authzen-inbound/doc.md +24 -0
- package/docs/policies/authzen-inbound/intro.md +31 -0
- package/docs/policies/authzen-inbound/schema.json +126 -0
- package/docs/policies/axiomatics-authz-inbound/doc.md +144 -0
- package/docs/policies/axiomatics-authz-inbound/intro.md +11 -0
- package/docs/policies/axiomatics-authz-inbound/schema.json +161 -0
- package/docs/policies/basic-auth-inbound/intro.md +9 -0
- package/docs/policies/basic-auth-inbound/schema.json +99 -0
- package/docs/policies/bot-detection-inbound/intro.md +4 -0
- package/docs/policies/bot-detection-inbound/schema.json +56 -0
- package/docs/policies/brownout-inbound/doc.md +55 -0
- package/docs/policies/brownout-inbound/intro.md +12 -0
- package/docs/policies/brownout-inbound/schema.json +115 -0
- package/docs/policies/caching-inbound/doc.md +209 -0
- package/docs/policies/caching-inbound/intro.md +23 -0
- package/docs/policies/caching-inbound/schema.json +98 -0
- package/docs/policies/change-method-inbound/schema.json +56 -0
- package/docs/policies/clear-headers-inbound/schema.json +59 -0
- package/docs/policies/clear-headers-outbound/schema.json +59 -0
- package/docs/policies/clerk-jwt-auth-inbound/doc.md +85 -0
- package/docs/policies/clerk-jwt-auth-inbound/intro.md +4 -0
- package/docs/policies/clerk-jwt-auth-inbound/schema.json +68 -0
- package/docs/policies/cognito-jwt-auth-inbound/intro.md +7 -0
- package/docs/policies/cognito-jwt-auth-inbound/schema.json +74 -0
- package/docs/policies/comet-opik-tracing-inbound/schema.json +65 -0
- package/docs/policies/complex-rate-limit-inbound/doc.md +20 -0
- package/docs/policies/complex-rate-limit-inbound/intro.md +23 -0
- package/docs/policies/complex-rate-limit-inbound/schema.json +142 -0
- package/docs/policies/composite-inbound/doc.md +69 -0
- package/docs/policies/composite-inbound/intro.md +15 -0
- package/docs/policies/composite-inbound/schema.json +59 -0
- package/docs/policies/composite-outbound/intro.md +6 -0
- package/docs/policies/composite-outbound/schema.json +59 -0
- package/docs/policies/curity-phantom-token-inbound/doc.md +109 -0
- package/docs/policies/curity-phantom-token-inbound/intro.md +3 -0
- package/docs/policies/curity-phantom-token-inbound/schema.json +68 -0
- package/docs/policies/custom-code-inbound/doc.md +267 -0
- package/docs/policies/custom-code-inbound/intro.md +2 -0
- package/docs/policies/custom-code-inbound/schema.json +48 -0
- package/docs/policies/custom-code-outbound/doc.md +235 -0
- package/docs/policies/custom-code-outbound/intro.md +2 -0
- package/docs/policies/custom-code-outbound/schema.json +43 -0
- package/docs/policies/firebase-jwt-inbound/intro.md +6 -0
- package/docs/policies/firebase-jwt-inbound/schema.json +68 -0
- package/docs/policies/formdata-to-json-inbound/schema.json +60 -0
- package/docs/policies/galileo-tracing-inbound/schema.json +65 -0
- package/docs/policies/geo-filter-inbound/doc.md +33 -0
- package/docs/policies/geo-filter-inbound/schema.json +108 -0
- package/docs/policies/graphql-complexity-limit-inbound/doc.md +48 -0
- package/docs/policies/graphql-complexity-limit-inbound/intro.md +2 -0
- package/docs/policies/graphql-complexity-limit-inbound/schema.json +90 -0
- package/docs/policies/graphql-disable-introspection-inbound/doc.md +66 -0
- package/docs/policies/graphql-disable-introspection-inbound/intro.md +15 -0
- package/docs/policies/graphql-disable-introspection-inbound/schema.json +48 -0
- package/docs/policies/graphql-introspection-filter-outbound/doc.md +148 -0
- package/docs/policies/graphql-introspection-filter-outbound/schema.json +79 -0
- package/docs/policies/hmac-auth-inbound/doc.md +30 -0
- package/docs/policies/hmac-auth-inbound/intro.md +10 -0
- package/docs/policies/hmac-auth-inbound/policy.ts +70 -0
- package/docs/policies/hmac-auth-inbound/schema.json +53 -0
- package/docs/policies/http-deprecation-outbound/doc.md +73 -0
- package/docs/policies/http-deprecation-outbound/schema.json +83 -0
- package/docs/policies/ip-restriction-inbound/intro.md +8 -0
- package/docs/policies/ip-restriction-inbound/policy.ts +40 -0
- package/docs/policies/ip-restriction-inbound/schema.json +58 -0
- package/docs/policies/jwt-scopes-inbound/schema.json +59 -0
- package/docs/policies/ldap-auth-inbound/schema.json +56 -0
- package/docs/policies/mock-api-inbound/schema.json +72 -0
- package/docs/policies/moesif-inbound/doc.md +44 -0
- package/docs/policies/moesif-inbound/intro.md +6 -0
- package/docs/policies/moesif-inbound/schema.json +68 -0
- package/docs/policies/monetization-inbound/doc.md +87 -0
- package/docs/policies/monetization-inbound/intro.md +6 -0
- package/docs/policies/monetization-inbound/schema.json +102 -0
- package/docs/policies/mtls-auth-inbound/intro.md +6 -0
- package/docs/policies/mtls-auth-inbound/schema.json +68 -0
- package/docs/policies/okta-fga-authz-inbound/doc.md +181 -0
- package/docs/policies/okta-fga-authz-inbound/intro.md +20 -0
- package/docs/policies/okta-fga-authz-inbound/schema.json +104 -0
- package/docs/policies/okta-jwt-auth-inbound/intro.md +7 -0
- package/docs/policies/okta-jwt-auth-inbound/schema.json +74 -0
- package/docs/policies/open-id-jwt-auth-inbound/doc.md +58 -0
- package/docs/policies/open-id-jwt-auth-inbound/intro.md +30 -0
- package/docs/policies/open-id-jwt-auth-inbound/schema.json +128 -0
- package/docs/policies/openfga-authz-inbound/doc.md +207 -0
- package/docs/policies/openfga-authz-inbound/intro.md +17 -0
- package/docs/policies/openfga-authz-inbound/schema.json +191 -0
- package/docs/policies/openmeter-inbound/doc.md +163 -0
- package/docs/policies/openmeter-inbound/intro.md +18 -0
- package/docs/policies/openmeter-inbound/schema.json +183 -0
- package/docs/policies/prompt-injection-outbound/doc.md +106 -0
- package/docs/policies/prompt-injection-outbound/intro.md +4 -0
- package/docs/policies/prompt-injection-outbound/schema.json +74 -0
- package/docs/policies/propel-auth-jwt-inbound/doc.md +88 -0
- package/docs/policies/propel-auth-jwt-inbound/intro.md +4 -0
- package/docs/policies/propel-auth-jwt-inbound/schema.json +74 -0
- package/docs/policies/query-param-to-header-inbound/doc.md +70 -0
- package/docs/policies/query-param-to-header-inbound/intro.md +5 -0
- package/docs/policies/query-param-to-header-inbound/schema.json +74 -0
- package/docs/policies/quota-inbound/doc.md +235 -0
- package/docs/policies/quota-inbound/intro.md +7 -0
- package/docs/policies/quota-inbound/schema.json +133 -0
- package/docs/policies/rate-limit-inbound/doc.md +78 -0
- package/docs/policies/rate-limit-inbound/intro.md +30 -0
- package/docs/policies/rate-limit-inbound/schema.json +134 -0
- package/docs/policies/rbac-policy-inbound/intro.md +3 -0
- package/docs/policies/rbac-policy-inbound/policy.ts +42 -0
- package/docs/policies/rbac-policy-inbound/schema.json +52 -0
- package/docs/policies/readme-metrics-inbound/doc.md +1 -0
- package/docs/policies/readme-metrics-inbound/intro.md +3 -0
- package/docs/policies/readme-metrics-inbound/schema.json +84 -0
- package/docs/policies/remove-headers-inbound/schema.json +59 -0
- package/docs/policies/remove-headers-outbound/schema.json +59 -0
- package/docs/policies/remove-query-params-inbound/schema.json +59 -0
- package/docs/policies/replace-string-outbound/schema.json +69 -0
- package/docs/policies/request-size-limit-inbound/schema.json +60 -0
- package/docs/policies/request-validation-inbound/doc.md +72 -0
- package/docs/policies/request-validation-inbound/intro.md +24 -0
- package/docs/policies/request-validation-inbound/schema.json +98 -0
- package/docs/policies/require-origin-inbound/intro.md +12 -0
- package/docs/policies/require-origin-inbound/schema.json +65 -0
- package/docs/policies/secret-masking-outbound/doc.md +41 -0
- package/docs/policies/secret-masking-outbound/intro.md +13 -0
- package/docs/policies/secret-masking-outbound/schema.json +65 -0
- package/docs/policies/semantic-cache-inbound/doc.md +63 -0
- package/docs/policies/semantic-cache-inbound/intro.md +4 -0
- package/docs/policies/semantic-cache-inbound/schema.json +179 -0
- package/docs/policies/set-body-inbound/intro.md +7 -0
- package/docs/policies/set-body-inbound/schema.json +56 -0
- package/docs/policies/set-headers-inbound/doc.md +41 -0
- package/docs/policies/set-headers-inbound/intro.md +2 -0
- package/docs/policies/set-headers-inbound/schema.json +83 -0
- package/docs/policies/set-headers-outbound/schema.json +83 -0
- package/docs/policies/set-query-params-inbound/schema.json +83 -0
- package/docs/policies/set-status-outbound/schema.json +62 -0
- package/docs/policies/sleep-inbound/schema.json +56 -0
- package/docs/policies/stripe-webhook-verification-inbound/intro.md +2 -0
- package/docs/policies/stripe-webhook-verification-inbound/schema.json +60 -0
- package/docs/policies/supabase-jwt-auth-inbound/doc.md +29 -0
- package/docs/policies/supabase-jwt-auth-inbound/intro.md +12 -0
- package/docs/policies/supabase-jwt-auth-inbound/schema.json +86 -0
- package/docs/policies/transform-body-inbound/intro.md +8 -0
- package/docs/policies/transform-body-inbound/policy.ts +16 -0
- package/docs/policies/transform-body-inbound/schema.json +27 -0
- package/docs/policies/transform-body-outbound/intro.md +8 -0
- package/docs/policies/transform-body-outbound/policy.ts +19 -0
- package/docs/policies/transform-body-outbound/schema.json +27 -0
- package/docs/policies/upstream-azure-ad-service-auth-inbound/doc.md +82 -0
- package/docs/policies/upstream-azure-ad-service-auth-inbound/intro.md +20 -0
- package/docs/policies/upstream-azure-ad-service-auth-inbound/schema.json +84 -0
- package/docs/policies/upstream-firebase-admin-auth-inbound/intro.md +10 -0
- package/docs/policies/upstream-firebase-admin-auth-inbound/schema.json +68 -0
- package/docs/policies/upstream-firebase-user-auth-inbound/intro.md +2 -0
- package/docs/policies/upstream-firebase-user-auth-inbound/schema.json +113 -0
- package/docs/policies/upstream-gcp-federated-auth-inbound/doc.md +139 -0
- package/docs/policies/upstream-gcp-federated-auth-inbound/intro.md +21 -0
- package/docs/policies/upstream-gcp-federated-auth-inbound/schema.json +96 -0
- package/docs/policies/upstream-gcp-jwt-inbound/intro.md +10 -0
- package/docs/policies/upstream-gcp-jwt-inbound/schema.json +62 -0
- package/docs/policies/upstream-gcp-service-auth-inbound/doc.md +132 -0
- package/docs/policies/upstream-gcp-service-auth-inbound/intro.md +25 -0
- package/docs/policies/upstream-gcp-service-auth-inbound/schema.json +95 -0
- package/docs/policies/upstream-zuplo-jwt-auth-inbound/doc.md +213 -0
- package/docs/policies/upstream-zuplo-jwt-auth-inbound/intro.md +16 -0
- package/docs/policies/upstream-zuplo-jwt-auth-inbound/schema.json +101 -0
- package/docs/policies/validate-json-schema-inbound/doc.md +129 -0
- package/docs/policies/validate-json-schema-inbound/intro.md +7 -0
- package/docs/policies/validate-json-schema-inbound/schema.json +56 -0
- package/docs/policies/web-bot-auth-inbound/doc.md +104 -0
- package/docs/policies/web-bot-auth-inbound/intro.md +16 -0
- package/docs/policies/web-bot-auth-inbound/schema.json +76 -0
- package/docs/policies/xml-to-json-outbound/doc.md +71 -0
- package/docs/policies/xml-to-json-outbound/intro.md +4 -0
- package/docs/policies/xml-to-json-outbound/schema.json +117 -0
- package/docs/programmable-api/audit-log.mdx +74 -0
- package/docs/programmable-api/background-dispatcher.mdx +124 -0
- package/docs/programmable-api/background-loader.mdx +104 -0
- package/docs/programmable-api/cache.mdx +186 -0
- package/docs/programmable-api/compatibility-dates.mdx +201 -0
- package/docs/programmable-api/console-logging.mdx +48 -0
- package/docs/programmable-api/context-data.mdx +127 -0
- package/docs/programmable-api/custom-cors-policy.mdx +64 -0
- package/docs/programmable-api/environment.mdx +328 -0
- package/docs/programmable-api/hooks.mdx +569 -0
- package/docs/programmable-api/http-problems.mdx +385 -0
- package/docs/programmable-api/jwt-service-plugin.mdx +420 -0
- package/docs/programmable-api/logger.mdx +223 -0
- package/docs/programmable-api/memory-zone-read-through-cache.mdx +96 -0
- package/docs/programmable-api/node-modules.mdx +67 -0
- package/docs/programmable-api/not-found-handler.mdx +47 -0
- package/docs/programmable-api/oauth-protected-resource-plugin.mdx +46 -0
- package/docs/programmable-api/overview.mdx +213 -0
- package/docs/programmable-api/problem-response-formatter.mdx +183 -0
- package/docs/programmable-api/request-user.mdx +289 -0
- package/docs/programmable-api/reusing-code.mdx +26 -0
- package/docs/programmable-api/route-raw.mdx +55 -0
- package/docs/programmable-api/runtime-behaviors.mdx +25 -0
- package/docs/programmable-api/runtime-errors.mdx +246 -0
- package/docs/programmable-api/runtime-extensions.mdx +340 -0
- package/docs/programmable-api/safely-clone-a-request-or-response.mdx +57 -0
- package/docs/programmable-api/streaming-zone-cache.mdx +155 -0
- package/docs/programmable-api/web-crypto-apis.mdx +219 -0
- package/docs/programmable-api/web-standard-apis.mdx +109 -0
- package/docs/programmable-api/zone-cache.mdx +131 -0
- package/docs/programmable-api/zp-body-removed.mdx +32 -0
- package/docs/programmable-api/zuplo-context.mdx +414 -0
- package/docs/programmable-api/zuplo-id-token.mdx +90 -0
- package/docs/programmable-api/zuplo-json.mdx +91 -0
- package/docs/programmable-api/zuplo-request.mdx +200 -0
- package/docs/sample-apis.mdx +78 -0
- package/docs/self-hosted/overview.md +60 -0
- package/package.json +6 -5
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Azure Pipelines: Multi-Stage Deployment"
|
|
3
|
+
sidebar_label: Multi-Stage Deployment
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy to staging, test, then promote to production with approval.
|
|
7
|
+
|
|
8
|
+
```yaml title="azure-pipelines.yml"
|
|
9
|
+
trigger:
|
|
10
|
+
- main
|
|
11
|
+
|
|
12
|
+
pool:
|
|
13
|
+
vmImage: ubuntu-latest
|
|
14
|
+
|
|
15
|
+
stages:
|
|
16
|
+
- stage: DeployStaging
|
|
17
|
+
displayName: "Deploy to Staging"
|
|
18
|
+
jobs:
|
|
19
|
+
- job: Deploy
|
|
20
|
+
steps:
|
|
21
|
+
- task: NodeTool@0
|
|
22
|
+
inputs:
|
|
23
|
+
versionSpec: "20.x"
|
|
24
|
+
|
|
25
|
+
- script: npm install
|
|
26
|
+
|
|
27
|
+
- script: |
|
|
28
|
+
set -o pipefail
|
|
29
|
+
npx zuplo deploy --api-key $(ZUPLO_API_KEY) --environment staging 2>&1 | tee ./STAGING_STDOUT
|
|
30
|
+
STAGING_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)' ./STAGING_STDOUT)
|
|
31
|
+
echo "##vso[task.setvariable variable=STAGING_URL;isOutput=true]$STAGING_URL"
|
|
32
|
+
name: deployStep
|
|
33
|
+
displayName: "Deploy to staging"
|
|
34
|
+
|
|
35
|
+
- stage: TestStaging
|
|
36
|
+
displayName: "Test Staging"
|
|
37
|
+
dependsOn: DeployStaging
|
|
38
|
+
variables:
|
|
39
|
+
STAGING_URL:
|
|
40
|
+
$[
|
|
41
|
+
stageDependencies.DeployStaging.Deploy.outputs['deployStep.STAGING_URL']
|
|
42
|
+
]
|
|
43
|
+
jobs:
|
|
44
|
+
- job: Test
|
|
45
|
+
steps:
|
|
46
|
+
- task: NodeTool@0
|
|
47
|
+
inputs:
|
|
48
|
+
versionSpec: "20.x"
|
|
49
|
+
|
|
50
|
+
- script: npm install
|
|
51
|
+
|
|
52
|
+
- script: npx zuplo test --endpoint $(STAGING_URL)
|
|
53
|
+
displayName: "Run tests against staging"
|
|
54
|
+
|
|
55
|
+
- stage: DeployProduction
|
|
56
|
+
displayName: "Deploy to Production"
|
|
57
|
+
dependsOn: TestStaging
|
|
58
|
+
jobs:
|
|
59
|
+
- deployment: Deploy
|
|
60
|
+
environment: production
|
|
61
|
+
strategy:
|
|
62
|
+
runOnce:
|
|
63
|
+
deploy:
|
|
64
|
+
steps:
|
|
65
|
+
- checkout: self
|
|
66
|
+
|
|
67
|
+
- task: NodeTool@0
|
|
68
|
+
inputs:
|
|
69
|
+
versionSpec: "20.x"
|
|
70
|
+
|
|
71
|
+
- script: npm install
|
|
72
|
+
|
|
73
|
+
- script:
|
|
74
|
+
npx zuplo deploy --api-key $(ZUPLO_API_KEY) --environment
|
|
75
|
+
production
|
|
76
|
+
displayName: "Deploy to production"
|
|
77
|
+
```
|
|
78
|
+
|
|
79
|
+
## Setting Up Approval
|
|
80
|
+
|
|
81
|
+
Create an environment with approval checks:
|
|
82
|
+
|
|
83
|
+
1. Go to **Pipelines** > **Environments**
|
|
84
|
+
2. Create an environment named `production`
|
|
85
|
+
3. Add **Approvals and checks**
|
|
86
|
+
4. Add required approvers
|
|
87
|
+
|
|
88
|
+
The pipeline pauses before production deployment until approved.
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Azure Pipelines: PR Preview Environments"
|
|
3
|
+
sidebar_label: PR Preview Environments
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy preview environments for pull requests and clean up when they close.
|
|
7
|
+
|
|
8
|
+
```yaml title="azure-pipelines.yml"
|
|
9
|
+
trigger:
|
|
10
|
+
- main
|
|
11
|
+
|
|
12
|
+
pr:
|
|
13
|
+
- main
|
|
14
|
+
|
|
15
|
+
pool:
|
|
16
|
+
vmImage: ubuntu-latest
|
|
17
|
+
|
|
18
|
+
steps:
|
|
19
|
+
- task: NodeTool@0
|
|
20
|
+
inputs:
|
|
21
|
+
versionSpec: "20.x"
|
|
22
|
+
displayName: "Install Node.js"
|
|
23
|
+
|
|
24
|
+
- script: npm install
|
|
25
|
+
displayName: "Install dependencies"
|
|
26
|
+
|
|
27
|
+
- script: |
|
|
28
|
+
set -o pipefail
|
|
29
|
+
npx zuplo deploy --api-key $(ZUPLO_API_KEY) 2>&1 | tee ./DEPLOYMENT_STDOUT
|
|
30
|
+
displayName: "Deploy to Zuplo"
|
|
31
|
+
|
|
32
|
+
- script: |
|
|
33
|
+
DEPLOYMENT_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)' ./DEPLOYMENT_STDOUT)
|
|
34
|
+
echo "##vso[task.setvariable variable=DEPLOYMENT_URL]$DEPLOYMENT_URL"
|
|
35
|
+
npx zuplo test --endpoint "$DEPLOYMENT_URL"
|
|
36
|
+
displayName: "Run tests"
|
|
37
|
+
|
|
38
|
+
- script: |
|
|
39
|
+
npx zuplo delete --url $(DEPLOYMENT_URL) --api-key $(ZUPLO_API_KEY) --wait
|
|
40
|
+
displayName: "Delete environment"
|
|
41
|
+
condition: eq(variables['Build.Reason'], 'PullRequest')
|
|
42
|
+
```
|
|
43
|
+
|
|
44
|
+
The cleanup step only runs for pull requests, deleting the preview environment
|
|
45
|
+
after tests pass.
|
|
46
|
+
|
|
47
|
+
## Next Steps
|
|
48
|
+
|
|
49
|
+
- Implement [multi-stage deployment](./multi-stage-deployment.mdx) for
|
|
50
|
+
production
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Azure Pipelines: Tag-Based Releases"
|
|
3
|
+
sidebar_label: Tag-Based Releases
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy only when tags are pushed for controlled releases.
|
|
7
|
+
|
|
8
|
+
```yaml title="azure-pipelines.yml"
|
|
9
|
+
trigger:
|
|
10
|
+
tags:
|
|
11
|
+
include:
|
|
12
|
+
- v*
|
|
13
|
+
|
|
14
|
+
pool:
|
|
15
|
+
vmImage: ubuntu-latest
|
|
16
|
+
|
|
17
|
+
steps:
|
|
18
|
+
- task: NodeTool@0
|
|
19
|
+
inputs:
|
|
20
|
+
versionSpec: "20.x"
|
|
21
|
+
displayName: "Install Node.js"
|
|
22
|
+
|
|
23
|
+
- script: npm install
|
|
24
|
+
displayName: "Install dependencies"
|
|
25
|
+
|
|
26
|
+
- script: |
|
|
27
|
+
TAG_NAME=$(echo $(Build.SourceBranch) | sed 's|refs/tags/||')
|
|
28
|
+
npx zuplo deploy --api-key $(ZUPLO_API_KEY) --environment "$TAG_NAME"
|
|
29
|
+
displayName: "Deploy with tag name"
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
This pipeline triggers only on tags matching `v*` (like `v1.0.0`) and creates an
|
|
33
|
+
environment named after the tag.
|
|
34
|
+
|
|
35
|
+
## Next Steps
|
|
36
|
+
|
|
37
|
+
- Add [multi-stage deployment](./multi-stage-deployment.mdx) with approval
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Bitbucket Pipelines: Basic Deployment"
|
|
3
|
+
sidebar_label: Basic Deployment
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
The simplest pipeline deploys your API to Zuplo on every push to main.
|
|
7
|
+
|
|
8
|
+
```yaml title="bitbucket-pipelines.yml"
|
|
9
|
+
image: node:20
|
|
10
|
+
|
|
11
|
+
pipelines:
|
|
12
|
+
branches:
|
|
13
|
+
main:
|
|
14
|
+
- step:
|
|
15
|
+
name: Deploy to Zuplo
|
|
16
|
+
script:
|
|
17
|
+
- npm install
|
|
18
|
+
- npx zuplo deploy --api-key "$ZUPLO_API_KEY"
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
Store `ZUPLO_API_KEY` in **Repository settings** > **Pipelines** > **Repository
|
|
22
|
+
variables**.
|
|
23
|
+
|
|
24
|
+
## Next Steps
|
|
25
|
+
|
|
26
|
+
- Add [automated testing](./deploy-and-test.mdx) after deployment
|
|
27
|
+
- Set up [PR preview environments](./pr-preview-environments.mdx)
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Bitbucket Pipelines: Deploy and Test"
|
|
3
|
+
sidebar_label: Deploy and Test
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Run your test suite against the deployed environment to validate changes.
|
|
7
|
+
|
|
8
|
+
```yaml title="bitbucket-pipelines.yml"
|
|
9
|
+
image: node:20
|
|
10
|
+
|
|
11
|
+
pipelines:
|
|
12
|
+
default:
|
|
13
|
+
- step:
|
|
14
|
+
name: Deploy to Zuplo
|
|
15
|
+
script:
|
|
16
|
+
- npm install
|
|
17
|
+
- npx zuplo deploy --api-key "$ZUPLO_API_KEY" 2>&1 | tee
|
|
18
|
+
./DEPLOYMENT_STDOUT
|
|
19
|
+
- echo "DEPLOYMENT_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)'
|
|
20
|
+
./DEPLOYMENT_STDOUT)" >> deployment.env
|
|
21
|
+
artifacts:
|
|
22
|
+
- deployment.env
|
|
23
|
+
|
|
24
|
+
- step:
|
|
25
|
+
name: Run Tests
|
|
26
|
+
script:
|
|
27
|
+
- source deployment.env
|
|
28
|
+
- npm install
|
|
29
|
+
- npx zuplo test --endpoint "$DEPLOYMENT_URL"
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
This pipeline:
|
|
33
|
+
|
|
34
|
+
1. Deploys to Zuplo and captures the output
|
|
35
|
+
2. Extracts the deployment URL and saves it as an artifact
|
|
36
|
+
3. Runs tests against the deployed environment
|
|
37
|
+
|
|
38
|
+
## Next Steps
|
|
39
|
+
|
|
40
|
+
- Add [PR preview environments](./pr-preview-environments.mdx) with cleanup
|
|
41
|
+
- Run [local tests](./local-testing.mdx) before deploying
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Bitbucket Pipelines: Local Testing in CI"
|
|
3
|
+
sidebar_label: Local Testing in CI
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Test against a local Zuplo server before deploying anywhere.
|
|
7
|
+
|
|
8
|
+
```yaml title="bitbucket-pipelines.yml"
|
|
9
|
+
image: node:20
|
|
10
|
+
|
|
11
|
+
pipelines:
|
|
12
|
+
branches:
|
|
13
|
+
main:
|
|
14
|
+
- step:
|
|
15
|
+
name: Local Testing
|
|
16
|
+
script:
|
|
17
|
+
- npm install
|
|
18
|
+
- npx zuplo dev &
|
|
19
|
+
- sleep 10
|
|
20
|
+
- npx zuplo test --endpoint http://localhost:9000
|
|
21
|
+
- kill %1
|
|
22
|
+
|
|
23
|
+
- step:
|
|
24
|
+
name: Deploy to Zuplo
|
|
25
|
+
script:
|
|
26
|
+
- npm install
|
|
27
|
+
- npx zuplo deploy --api-key "$ZUPLO_API_KEY"
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
Local tests run first. Only if they pass does deployment proceed.
|
|
31
|
+
|
|
32
|
+
## Next Steps
|
|
33
|
+
|
|
34
|
+
- Add [multi-stage deployment](./multi-stage-deployment.mdx) with staging
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Bitbucket Pipelines: Multi-Stage Deployment"
|
|
3
|
+
sidebar_label: Multi-Stage Deployment
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy to staging, test, then promote to production with approval.
|
|
7
|
+
|
|
8
|
+
```yaml title="bitbucket-pipelines.yml"
|
|
9
|
+
image: node:20
|
|
10
|
+
|
|
11
|
+
pipelines:
|
|
12
|
+
branches:
|
|
13
|
+
main:
|
|
14
|
+
- step:
|
|
15
|
+
name: Deploy to Staging
|
|
16
|
+
script:
|
|
17
|
+
- npm install
|
|
18
|
+
- npx zuplo deploy --api-key "$ZUPLO_API_KEY" --environment staging
|
|
19
|
+
2>&1 | tee ./DEPLOYMENT_STDOUT
|
|
20
|
+
- echo "STAGING_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)'
|
|
21
|
+
./DEPLOYMENT_STDOUT)" >> staging.env
|
|
22
|
+
artifacts:
|
|
23
|
+
- staging.env
|
|
24
|
+
|
|
25
|
+
- step:
|
|
26
|
+
name: Test Staging
|
|
27
|
+
script:
|
|
28
|
+
- source staging.env
|
|
29
|
+
- npm install
|
|
30
|
+
- npx zuplo test --endpoint "$STAGING_URL"
|
|
31
|
+
|
|
32
|
+
- step:
|
|
33
|
+
name: Deploy to Production
|
|
34
|
+
trigger: manual
|
|
35
|
+
deployment: production
|
|
36
|
+
script:
|
|
37
|
+
- npm install
|
|
38
|
+
- npx zuplo deploy --api-key "$ZUPLO_API_KEY" --environment
|
|
39
|
+
production
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
## Setting Up Approval
|
|
43
|
+
|
|
44
|
+
The `trigger: manual` setting requires someone to click "Run" in the Bitbucket
|
|
45
|
+
UI to trigger production deployment.
|
|
46
|
+
|
|
47
|
+
For more control, use
|
|
48
|
+
[Deployment permissions](https://support.atlassian.com/bitbucket-cloud/docs/set-up-and-monitor-deployments/):
|
|
49
|
+
|
|
50
|
+
1. Go to **Repository settings** > **Deployments**
|
|
51
|
+
2. Create a `production` deployment environment
|
|
52
|
+
3. Add required reviewers under **Deployment restrictions**
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Bitbucket Pipelines: PR Preview Environments"
|
|
3
|
+
sidebar_label: PR Preview Environments
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy preview environments for pull requests and clean up when they close.
|
|
7
|
+
|
|
8
|
+
```yaml title="bitbucket-pipelines.yml"
|
|
9
|
+
image: node:20
|
|
10
|
+
|
|
11
|
+
pipelines:
|
|
12
|
+
pull-requests:
|
|
13
|
+
"**":
|
|
14
|
+
- step:
|
|
15
|
+
name: Deploy Preview
|
|
16
|
+
script:
|
|
17
|
+
- npm install
|
|
18
|
+
- npx zuplo deploy --api-key "$ZUPLO_API_KEY" 2>&1 | tee
|
|
19
|
+
./DEPLOYMENT_STDOUT
|
|
20
|
+
- echo "DEPLOYMENT_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)'
|
|
21
|
+
./DEPLOYMENT_STDOUT)" >> deployment.env
|
|
22
|
+
artifacts:
|
|
23
|
+
- deployment.env
|
|
24
|
+
|
|
25
|
+
- step:
|
|
26
|
+
name: Run Tests
|
|
27
|
+
script:
|
|
28
|
+
- source deployment.env
|
|
29
|
+
- npm install
|
|
30
|
+
- npx zuplo test --endpoint "$DEPLOYMENT_URL"
|
|
31
|
+
|
|
32
|
+
- step:
|
|
33
|
+
name: Cleanup Preview
|
|
34
|
+
script:
|
|
35
|
+
- source deployment.env
|
|
36
|
+
- npm install
|
|
37
|
+
- npx zuplo delete --url "$DEPLOYMENT_URL" --api-key
|
|
38
|
+
"$ZUPLO_API_KEY" --wait
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
The cleanup step runs after tests complete, deleting the preview environment.
|
|
42
|
+
|
|
43
|
+
## Next Steps
|
|
44
|
+
|
|
45
|
+
- Implement [multi-stage deployment](./multi-stage-deployment.mdx) for
|
|
46
|
+
production
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "Bitbucket Pipelines: Tag-Based Releases"
|
|
3
|
+
sidebar_label: Tag-Based Releases
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy only when tags are pushed for controlled releases.
|
|
7
|
+
|
|
8
|
+
```yaml title="bitbucket-pipelines.yml"
|
|
9
|
+
image: node:20
|
|
10
|
+
|
|
11
|
+
pipelines:
|
|
12
|
+
tags:
|
|
13
|
+
v*:
|
|
14
|
+
- step:
|
|
15
|
+
name: Deploy Release
|
|
16
|
+
script:
|
|
17
|
+
- npm install
|
|
18
|
+
- npx zuplo deploy --api-key "$ZUPLO_API_KEY" --environment
|
|
19
|
+
"$BITBUCKET_TAG"
|
|
20
|
+
```
|
|
21
|
+
|
|
22
|
+
This pipeline triggers only on tags matching `v*` (like `v1.0.0`) and creates an
|
|
23
|
+
environment named after the tag.
|
|
24
|
+
|
|
25
|
+
## Next Steps
|
|
26
|
+
|
|
27
|
+
- Add [multi-stage deployment](./multi-stage-deployment.mdx) with approval
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "CircleCI: Basic Deployment"
|
|
3
|
+
sidebar_label: Basic Deployment
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
The simplest workflow deploys your API to Zuplo on every push to main.
|
|
7
|
+
|
|
8
|
+
```yaml title=".circleci/config.yml"
|
|
9
|
+
version: 2.1
|
|
10
|
+
|
|
11
|
+
jobs:
|
|
12
|
+
deploy:
|
|
13
|
+
docker:
|
|
14
|
+
- image: cimg/node:20.0
|
|
15
|
+
steps:
|
|
16
|
+
- checkout
|
|
17
|
+
- run: npm install
|
|
18
|
+
- run: npx zuplo deploy --api-key "$ZUPLO_API_KEY"
|
|
19
|
+
|
|
20
|
+
workflows:
|
|
21
|
+
deploy:
|
|
22
|
+
jobs:
|
|
23
|
+
- deploy:
|
|
24
|
+
filters:
|
|
25
|
+
branches:
|
|
26
|
+
only: main
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
Store `ZUPLO_API_KEY` in **Project Settings** > **Environment Variables**.
|
|
30
|
+
|
|
31
|
+
## Next Steps
|
|
32
|
+
|
|
33
|
+
- Add [automated testing](./deploy-and-test.mdx) after deployment
|
|
34
|
+
- Set up [PR preview environments](./pr-preview-environments.mdx)
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "CircleCI: Deploy and Test"
|
|
3
|
+
sidebar_label: Deploy and Test
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Run your test suite against the deployed environment to validate changes.
|
|
7
|
+
|
|
8
|
+
```yaml title=".circleci/config.yml"
|
|
9
|
+
version: 2.1
|
|
10
|
+
|
|
11
|
+
jobs:
|
|
12
|
+
deploy:
|
|
13
|
+
docker:
|
|
14
|
+
- image: cimg/node:20.0
|
|
15
|
+
steps:
|
|
16
|
+
- checkout
|
|
17
|
+
- run: npm install
|
|
18
|
+
- run:
|
|
19
|
+
name: Deploy to Zuplo
|
|
20
|
+
command: |
|
|
21
|
+
set -o pipefail
|
|
22
|
+
npx zuplo deploy --api-key "$ZUPLO_API_KEY" 2>&1 | tee ./DEPLOYMENT_STDOUT
|
|
23
|
+
DEPLOYMENT_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)' ./DEPLOYMENT_STDOUT)
|
|
24
|
+
echo "export DEPLOYMENT_URL=$DEPLOYMENT_URL" >> "$BASH_ENV"
|
|
25
|
+
- run:
|
|
26
|
+
name: Run Tests
|
|
27
|
+
command: npx zuplo test --endpoint "$DEPLOYMENT_URL"
|
|
28
|
+
|
|
29
|
+
workflows:
|
|
30
|
+
deploy-and-test:
|
|
31
|
+
jobs:
|
|
32
|
+
- deploy
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
This workflow:
|
|
36
|
+
|
|
37
|
+
1. Deploys to Zuplo and captures the output
|
|
38
|
+
2. Extracts the deployment URL
|
|
39
|
+
3. Runs tests against the deployed environment
|
|
40
|
+
|
|
41
|
+
## Next Steps
|
|
42
|
+
|
|
43
|
+
- Add [PR preview environments](./pr-preview-environments.mdx) with cleanup
|
|
44
|
+
- Run [local tests](./local-testing.mdx) before deploying
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "CircleCI: Local Testing in CI"
|
|
3
|
+
sidebar_label: Local Testing in CI
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Test against a local Zuplo server before deploying anywhere.
|
|
7
|
+
|
|
8
|
+
```yaml title=".circleci/config.yml"
|
|
9
|
+
version: 2.1
|
|
10
|
+
|
|
11
|
+
jobs:
|
|
12
|
+
local-test:
|
|
13
|
+
docker:
|
|
14
|
+
- image: cimg/node:20.0
|
|
15
|
+
steps:
|
|
16
|
+
- checkout
|
|
17
|
+
- run: npm install
|
|
18
|
+
- run:
|
|
19
|
+
name: Start local server and run tests
|
|
20
|
+
command: |
|
|
21
|
+
npx zuplo dev &
|
|
22
|
+
sleep 10
|
|
23
|
+
npx zuplo test --endpoint http://localhost:9000
|
|
24
|
+
kill %1
|
|
25
|
+
|
|
26
|
+
deploy:
|
|
27
|
+
docker:
|
|
28
|
+
- image: cimg/node:20.0
|
|
29
|
+
steps:
|
|
30
|
+
- checkout
|
|
31
|
+
- run: npm install
|
|
32
|
+
- run: npx zuplo deploy --api-key "$ZUPLO_API_KEY"
|
|
33
|
+
|
|
34
|
+
workflows:
|
|
35
|
+
test-and-deploy:
|
|
36
|
+
jobs:
|
|
37
|
+
- local-test
|
|
38
|
+
- deploy:
|
|
39
|
+
requires:
|
|
40
|
+
- local-test
|
|
41
|
+
filters:
|
|
42
|
+
branches:
|
|
43
|
+
only: main
|
|
44
|
+
```
|
|
45
|
+
|
|
46
|
+
Local tests run first. Only if they pass does deployment proceed.
|
|
47
|
+
|
|
48
|
+
## Next Steps
|
|
49
|
+
|
|
50
|
+
- Add [multi-stage deployment](./multi-stage-deployment.mdx) with staging
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "CircleCI: Multi-Stage Deployment"
|
|
3
|
+
sidebar_label: Multi-Stage Deployment
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy to staging, test, then promote to production with approval.
|
|
7
|
+
|
|
8
|
+
```yaml title=".circleci/config.yml"
|
|
9
|
+
version: 2.1
|
|
10
|
+
|
|
11
|
+
jobs:
|
|
12
|
+
deploy-staging:
|
|
13
|
+
docker:
|
|
14
|
+
- image: cimg/node:20.0
|
|
15
|
+
steps:
|
|
16
|
+
- checkout
|
|
17
|
+
- run: npm install
|
|
18
|
+
- run:
|
|
19
|
+
name: Deploy to Staging
|
|
20
|
+
command: |
|
|
21
|
+
set -o pipefail
|
|
22
|
+
npx zuplo deploy --api-key "$ZUPLO_API_KEY" --environment staging 2>&1 | tee ./DEPLOYMENT_STDOUT
|
|
23
|
+
STAGING_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)' ./DEPLOYMENT_STDOUT)
|
|
24
|
+
echo "export STAGING_URL=$STAGING_URL" >> "$BASH_ENV"
|
|
25
|
+
echo "$STAGING_URL" > staging_url.txt
|
|
26
|
+
- persist_to_workspace:
|
|
27
|
+
root: .
|
|
28
|
+
paths:
|
|
29
|
+
- staging_url.txt
|
|
30
|
+
|
|
31
|
+
test-staging:
|
|
32
|
+
docker:
|
|
33
|
+
- image: cimg/node:20.0
|
|
34
|
+
steps:
|
|
35
|
+
- checkout
|
|
36
|
+
- attach_workspace:
|
|
37
|
+
at: .
|
|
38
|
+
- run: npm install
|
|
39
|
+
- run:
|
|
40
|
+
name: Run Tests
|
|
41
|
+
command: |
|
|
42
|
+
STAGING_URL=$(cat staging_url.txt)
|
|
43
|
+
npx zuplo test --endpoint "$STAGING_URL"
|
|
44
|
+
|
|
45
|
+
deploy-production:
|
|
46
|
+
docker:
|
|
47
|
+
- image: cimg/node:20.0
|
|
48
|
+
steps:
|
|
49
|
+
- checkout
|
|
50
|
+
- run: npm install
|
|
51
|
+
- run:
|
|
52
|
+
npx zuplo deploy --api-key "$ZUPLO_API_KEY" --environment production
|
|
53
|
+
|
|
54
|
+
workflows:
|
|
55
|
+
staging-to-production:
|
|
56
|
+
jobs:
|
|
57
|
+
- deploy-staging:
|
|
58
|
+
filters:
|
|
59
|
+
branches:
|
|
60
|
+
only: main
|
|
61
|
+
- test-staging:
|
|
62
|
+
requires:
|
|
63
|
+
- deploy-staging
|
|
64
|
+
- hold-for-approval:
|
|
65
|
+
type: approval
|
|
66
|
+
requires:
|
|
67
|
+
- test-staging
|
|
68
|
+
- deploy-production:
|
|
69
|
+
requires:
|
|
70
|
+
- hold-for-approval
|
|
71
|
+
```
|
|
72
|
+
|
|
73
|
+
## Setting Up Approval
|
|
74
|
+
|
|
75
|
+
The `type: approval` job pauses the workflow until someone approves it in the
|
|
76
|
+
CircleCI UI.
|
|
77
|
+
|
|
78
|
+
For more control:
|
|
79
|
+
|
|
80
|
+
1. Go to **Project Settings** > **Advanced**
|
|
81
|
+
2. Enable **Only build pull requests** for protected branches
|
|
82
|
+
3. Use CircleCI contexts to restrict who can approve production deployments
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: "CircleCI: PR Preview Environments"
|
|
3
|
+
sidebar_label: PR Preview Environments
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
Deploy preview environments for pull requests and clean up after tests.
|
|
7
|
+
|
|
8
|
+
```yaml title=".circleci/config.yml"
|
|
9
|
+
version: 2.1
|
|
10
|
+
|
|
11
|
+
jobs:
|
|
12
|
+
deploy-and-test:
|
|
13
|
+
docker:
|
|
14
|
+
- image: cimg/node:20.0
|
|
15
|
+
steps:
|
|
16
|
+
- checkout
|
|
17
|
+
- run: npm install
|
|
18
|
+
- run:
|
|
19
|
+
name: Deploy to Zuplo
|
|
20
|
+
command: |
|
|
21
|
+
set -o pipefail
|
|
22
|
+
npx zuplo deploy --api-key "$ZUPLO_API_KEY" 2>&1 | tee ./DEPLOYMENT_STDOUT
|
|
23
|
+
DEPLOYMENT_URL=$(grep -oP 'Deployed to \K(https://[^ ]+)' ./DEPLOYMENT_STDOUT)
|
|
24
|
+
echo "export DEPLOYMENT_URL=$DEPLOYMENT_URL" >> "$BASH_ENV"
|
|
25
|
+
- run:
|
|
26
|
+
name: Run Tests
|
|
27
|
+
command: npx zuplo test --endpoint "$DEPLOYMENT_URL"
|
|
28
|
+
- run:
|
|
29
|
+
name: Cleanup Preview
|
|
30
|
+
command:
|
|
31
|
+
npx zuplo delete --url "$DEPLOYMENT_URL" --api-key "$ZUPLO_API_KEY"
|
|
32
|
+
--wait
|
|
33
|
+
when: always
|
|
34
|
+
|
|
35
|
+
workflows:
|
|
36
|
+
preview:
|
|
37
|
+
jobs:
|
|
38
|
+
- deploy-and-test
|
|
39
|
+
```
|
|
40
|
+
|
|
41
|
+
The cleanup step runs after tests complete (whether they pass or fail), deleting
|
|
42
|
+
the preview environment.
|
|
43
|
+
|
|
44
|
+
## Next Steps
|
|
45
|
+
|
|
46
|
+
- Implement [multi-stage deployment](./multi-stage-deployment.mdx) for
|
|
47
|
+
production
|