@reyemtech/nimbus 1.2.0 → 2.0.1
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 +32 -28
- package/dist/cjs/access/dns.d.ts +26 -0
- package/dist/cjs/access/dns.d.ts.map +1 -0
- package/dist/cjs/access/dns.js +136 -0
- package/dist/cjs/access/dns.js.map +1 -0
- package/dist/cjs/access/index.d.ts +30 -0
- package/dist/cjs/access/index.d.ts.map +1 -0
- package/dist/cjs/access/index.js +45 -0
- package/dist/cjs/access/index.js.map +1 -0
- package/dist/cjs/access/interfaces.d.ts +97 -0
- package/dist/cjs/access/interfaces.d.ts.map +1 -0
- package/dist/cjs/access/interfaces.js +17 -0
- package/dist/cjs/access/interfaces.js.map +1 -0
- package/dist/cjs/access/proxy.d.ts +21 -0
- package/dist/cjs/access/proxy.d.ts.map +1 -0
- package/dist/cjs/access/proxy.js +155 -0
- package/dist/cjs/access/proxy.js.map +1 -0
- package/dist/cjs/access/tailscale-dns.d.ts +28 -0
- package/dist/cjs/access/tailscale-dns.d.ts.map +1 -0
- package/dist/cjs/access/tailscale-dns.js +131 -0
- package/dist/cjs/access/tailscale-dns.js.map +1 -0
- package/dist/cjs/access/tailscale.d.ts +14 -0
- package/dist/cjs/access/tailscale.d.ts.map +1 -0
- package/dist/cjs/access/tailscale.js +135 -0
- package/dist/cjs/access/tailscale.js.map +1 -0
- package/dist/cjs/access/wireguard.d.ts +14 -0
- package/dist/cjs/access/wireguard.d.ts.map +1 -0
- package/dist/cjs/access/wireguard.js +140 -0
- package/dist/cjs/access/wireguard.js.map +1 -0
- package/dist/cjs/argocd/app.d.ts +31 -0
- package/dist/cjs/argocd/app.d.ts.map +1 -0
- package/dist/cjs/argocd/app.js +194 -0
- package/dist/cjs/argocd/app.js.map +1 -0
- package/dist/cjs/argocd/argocd.d.ts +33 -0
- package/dist/cjs/argocd/argocd.d.ts.map +1 -0
- package/dist/cjs/argocd/argocd.js +182 -0
- package/dist/cjs/argocd/argocd.js.map +1 -0
- package/dist/cjs/argocd/external-secrets.d.ts +23 -0
- package/dist/cjs/argocd/external-secrets.d.ts.map +1 -0
- package/dist/cjs/argocd/external-secrets.js +121 -0
- package/dist/cjs/argocd/external-secrets.js.map +1 -0
- package/dist/cjs/argocd/index.d.ts +18 -0
- package/dist/cjs/argocd/index.d.ts.map +1 -0
- package/dist/cjs/argocd/index.js +27 -0
- package/dist/cjs/argocd/index.js.map +1 -0
- package/dist/cjs/argocd/interfaces.d.ts +144 -0
- package/dist/cjs/argocd/interfaces.d.ts.map +1 -0
- package/dist/cjs/argocd/interfaces.js +8 -0
- package/dist/cjs/argocd/interfaces.js.map +1 -0
- package/dist/cjs/argocd/project.d.ts +23 -0
- package/dist/cjs/argocd/project.d.ts.map +1 -0
- package/dist/cjs/argocd/project.js +93 -0
- package/dist/cjs/argocd/project.js.map +1 -0
- package/dist/cjs/argocd/repo.d.ts +15 -0
- package/dist/cjs/argocd/repo.d.ts.map +1 -0
- package/dist/cjs/argocd/repo.js +83 -0
- package/dist/cjs/argocd/repo.js.map +1 -0
- package/dist/cjs/argocd/secrets.d.ts +23 -0
- package/dist/cjs/argocd/secrets.d.ts.map +1 -0
- package/dist/cjs/argocd/secrets.js +87 -0
- package/dist/cjs/argocd/secrets.js.map +1 -0
- package/dist/cjs/azure/index.d.ts +1 -0
- package/dist/cjs/azure/index.d.ts.map +1 -1
- package/dist/cjs/azure/index.js +3 -1
- package/dist/cjs/azure/index.js.map +1 -1
- package/dist/cjs/azure/resource-group.d.ts +37 -0
- package/dist/cjs/azure/resource-group.d.ts.map +1 -0
- package/dist/cjs/azure/resource-group.js +79 -0
- package/dist/cjs/azure/resource-group.js.map +1 -0
- package/dist/cjs/azure/secrets.d.ts +6 -3
- package/dist/cjs/azure/secrets.d.ts.map +1 -1
- package/dist/cjs/azure/secrets.js +17 -3
- package/dist/cjs/azure/secrets.js.map +1 -1
- package/dist/cjs/backup/index.d.ts +20 -0
- package/dist/cjs/backup/index.d.ts.map +1 -0
- package/dist/cjs/backup/index.js +206 -0
- package/dist/cjs/backup/index.js.map +1 -0
- package/dist/cjs/backup/interfaces.d.ts +29 -0
- package/dist/cjs/backup/interfaces.d.ts.map +1 -0
- package/dist/cjs/backup/interfaces.js +3 -0
- package/dist/cjs/backup/interfaces.js.map +1 -0
- package/dist/cjs/cache/cache.d.ts +38 -0
- package/dist/cjs/cache/cache.d.ts.map +1 -0
- package/dist/cjs/cache/cache.js +189 -0
- package/dist/cjs/cache/cache.js.map +1 -0
- package/dist/cjs/cache/index.d.ts +2 -0
- package/dist/cjs/cache/index.d.ts.map +1 -1
- package/dist/cjs/cache/index.js +7 -0
- package/dist/cjs/cache/index.js.map +1 -1
- package/dist/cjs/cache/interfaces.d.ts +20 -0
- package/dist/cjs/cache/interfaces.d.ts.map +1 -1
- package/dist/cjs/cache/interfaces.js +18 -0
- package/dist/cjs/cache/interfaces.js.map +1 -1
- package/dist/cjs/cli/azure-prompts.d.ts +3 -12
- package/dist/cjs/cli/azure-prompts.d.ts.map +1 -1
- package/dist/cjs/cli/azure-prompts.js +4 -23
- package/dist/cjs/cli/azure-prompts.js.map +1 -1
- package/dist/cjs/cli/templates-azure.d.ts.map +1 -1
- package/dist/cjs/cli/templates-azure.js +20 -15
- package/dist/cjs/cli/templates-azure.js.map +1 -1
- package/dist/cjs/cli/templates.d.ts +0 -1
- package/dist/cjs/cli/templates.d.ts.map +1 -1
- package/dist/cjs/cli/templates.js.map +1 -1
- package/dist/cjs/cli.js +1 -1
- package/dist/cjs/cli.js.map +1 -1
- package/dist/cjs/cluster/index.d.ts +1 -1
- package/dist/cjs/cluster/index.d.ts.map +1 -1
- package/dist/cjs/cluster/interfaces.d.ts +18 -1
- package/dist/cjs/cluster/interfaces.d.ts.map +1 -1
- package/dist/cjs/database/index.d.ts +1 -0
- package/dist/cjs/database/index.d.ts.map +1 -1
- package/dist/cjs/database/index.js +5 -0
- package/dist/cjs/database/index.js.map +1 -1
- package/dist/cjs/database/interfaces.d.ts +19 -0
- package/dist/cjs/database/interfaces.d.ts.map +1 -1
- package/dist/cjs/database/interfaces.js +20 -0
- package/dist/cjs/database/interfaces.js.map +1 -1
- package/dist/cjs/dns/index.d.ts +1 -0
- package/dist/cjs/dns/index.d.ts.map +1 -1
- package/dist/cjs/dns/index.js +3 -0
- package/dist/cjs/dns/index.js.map +1 -1
- package/dist/cjs/dns/interfaces.d.ts +11 -0
- package/dist/cjs/dns/interfaces.d.ts.map +1 -1
- package/dist/cjs/dns/interfaces.js +12 -0
- package/dist/cjs/dns/interfaces.js.map +1 -1
- package/dist/cjs/email/index.d.ts +41 -0
- package/dist/cjs/email/index.d.ts.map +1 -0
- package/dist/cjs/email/index.js +318 -0
- package/dist/cjs/email/index.js.map +1 -0
- package/dist/cjs/email/interfaces.d.ts +119 -0
- package/dist/cjs/email/interfaces.d.ts.map +1 -0
- package/dist/cjs/email/interfaces.js +19 -0
- package/dist/cjs/email/interfaces.js.map +1 -0
- package/dist/cjs/factories/cluster.d.ts +1 -1
- package/dist/cjs/factories/cluster.d.ts.map +1 -1
- package/dist/cjs/factories/cluster.js +16 -0
- package/dist/cjs/factories/cluster.js.map +1 -1
- package/dist/cjs/factories/index.d.ts +1 -1
- package/dist/cjs/factories/index.d.ts.map +1 -1
- package/dist/cjs/factories/index.js.map +1 -1
- package/dist/cjs/factories/secrets.d.ts +1 -1
- package/dist/cjs/factories/secrets.js +3 -3
- package/dist/cjs/factories/secrets.js.map +1 -1
- package/dist/cjs/factories/types.d.ts +26 -0
- package/dist/cjs/factories/types.d.ts.map +1 -1
- package/dist/cjs/factories/types.js.map +1 -1
- package/dist/cjs/index.d.ts +27 -5
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +75 -8
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/network/index.d.ts +1 -0
- package/dist/cjs/network/index.d.ts.map +1 -1
- package/dist/cjs/network/index.js +3 -1
- package/dist/cjs/network/index.js.map +1 -1
- package/dist/cjs/network/interfaces.d.ts +6 -0
- package/dist/cjs/network/interfaces.d.ts.map +1 -1
- package/dist/cjs/network/interfaces.js +7 -0
- package/dist/cjs/network/interfaces.js.map +1 -1
- package/dist/cjs/nimbus/index.d.ts +28 -0
- package/dist/cjs/nimbus/index.d.ts.map +1 -0
- package/dist/cjs/nimbus/index.js +44 -0
- package/dist/cjs/nimbus/index.js.map +1 -0
- package/dist/cjs/nimbus/interfaces.d.ts +64 -0
- package/dist/cjs/nimbus/interfaces.d.ts.map +1 -0
- package/dist/cjs/nimbus/interfaces.js +10 -0
- package/dist/cjs/nimbus/interfaces.js.map +1 -0
- package/dist/cjs/nimbus/registry.d.ts +19 -0
- package/dist/cjs/nimbus/registry.d.ts.map +1 -0
- package/dist/cjs/nimbus/registry.js +123 -0
- package/dist/cjs/nimbus/registry.js.map +1 -0
- package/dist/cjs/observability/alerts.d.ts +51 -0
- package/dist/cjs/observability/alerts.d.ts.map +1 -0
- package/dist/cjs/observability/alerts.js +281 -0
- package/dist/cjs/observability/alerts.js.map +1 -0
- package/dist/cjs/observability/dashboards/_helpers.d.ts +38 -0
- package/dist/cjs/observability/dashboards/_helpers.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/_helpers.js +141 -0
- package/dist/cjs/observability/dashboards/_helpers.js.map +1 -0
- package/dist/cjs/observability/dashboards/alerts.d.ts +12 -0
- package/dist/cjs/observability/dashboards/alerts.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/alerts.js +261 -0
- package/dist/cjs/observability/dashboards/alerts.js.map +1 -0
- package/dist/cjs/observability/dashboards/argocd-app.d.ts +18 -0
- package/dist/cjs/observability/dashboards/argocd-app.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/argocd-app.js +212 -0
- package/dist/cjs/observability/dashboards/argocd-app.js.map +1 -0
- package/dist/cjs/observability/dashboards/argocd.d.ts +9 -0
- package/dist/cjs/observability/dashboards/argocd.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/argocd.js +141 -0
- package/dist/cjs/observability/dashboards/argocd.js.map +1 -0
- package/dist/cjs/observability/dashboards/cert-manager.d.ts +9 -0
- package/dist/cjs/observability/dashboards/cert-manager.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/cert-manager.js +167 -0
- package/dist/cjs/observability/dashboards/cert-manager.js.map +1 -0
- package/dist/cjs/observability/dashboards/cnpg-cluster.d.ts +15 -0
- package/dist/cjs/observability/dashboards/cnpg-cluster.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/cnpg-cluster.js +376 -0
- package/dist/cjs/observability/dashboards/cnpg-cluster.js.map +1 -0
- package/dist/cjs/observability/dashboards/cnpg.d.ts +10 -0
- package/dist/cjs/observability/dashboards/cnpg.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/cnpg.js +181 -0
- package/dist/cjs/observability/dashboards/cnpg.js.map +1 -0
- package/dist/cjs/observability/dashboards/index.d.ts +28 -0
- package/dist/cjs/observability/dashboards/index.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/index.js +159 -0
- package/dist/cjs/observability/dashboards/index.js.map +1 -0
- package/dist/cjs/observability/dashboards/loki.d.ts +9 -0
- package/dist/cjs/observability/dashboards/loki.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/loki.js +113 -0
- package/dist/cjs/observability/dashboards/loki.js.map +1 -0
- package/dist/cjs/observability/dashboards/mariadb-cluster.d.ts +15 -0
- package/dist/cjs/observability/dashboards/mariadb-cluster.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/mariadb-cluster.js +424 -0
- package/dist/cjs/observability/dashboards/mariadb-cluster.js.map +1 -0
- package/dist/cjs/observability/dashboards/mariadb.d.ts +10 -0
- package/dist/cjs/observability/dashboards/mariadb.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/mariadb.js +181 -0
- package/dist/cjs/observability/dashboards/mariadb.js.map +1 -0
- package/dist/cjs/observability/dashboards/minio.d.ts +9 -0
- package/dist/cjs/observability/dashboards/minio.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/minio.js +267 -0
- package/dist/cjs/observability/dashboards/minio.js.map +1 -0
- package/dist/cjs/observability/dashboards/neo4j-cluster.d.ts +16 -0
- package/dist/cjs/observability/dashboards/neo4j-cluster.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/neo4j-cluster.js +223 -0
- package/dist/cjs/observability/dashboards/neo4j-cluster.js.map +1 -0
- package/dist/cjs/observability/dashboards/neo4j.d.ts +9 -0
- package/dist/cjs/observability/dashboards/neo4j.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/neo4j.js +156 -0
- package/dist/cjs/observability/dashboards/neo4j.js.map +1 -0
- package/dist/cjs/observability/dashboards/redis.d.ts +9 -0
- package/dist/cjs/observability/dashboards/redis.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/redis.js +221 -0
- package/dist/cjs/observability/dashboards/redis.js.map +1 -0
- package/dist/cjs/observability/dashboards/traefik.d.ts +9 -0
- package/dist/cjs/observability/dashboards/traefik.d.ts.map +1 -0
- package/dist/cjs/observability/dashboards/traefik.js +387 -0
- package/dist/cjs/observability/dashboards/traefik.js.map +1 -0
- package/dist/cjs/observability/index.d.ts +10 -0
- package/dist/cjs/observability/index.d.ts.map +1 -0
- package/dist/cjs/observability/index.js +14 -0
- package/dist/cjs/observability/index.js.map +1 -0
- package/dist/cjs/observability/interfaces.d.ts +173 -0
- package/dist/cjs/observability/interfaces.d.ts.map +1 -0
- package/dist/cjs/observability/interfaces.js +11 -0
- package/dist/cjs/observability/interfaces.js.map +1 -0
- package/dist/cjs/observability/stack.d.ts +31 -0
- package/dist/cjs/observability/stack.d.ts.map +1 -0
- package/dist/cjs/observability/stack.js +523 -0
- package/dist/cjs/observability/stack.js.map +1 -0
- package/dist/cjs/operator/cnpg.d.ts +22 -0
- package/dist/cjs/operator/cnpg.d.ts.map +1 -0
- package/dist/cjs/operator/cnpg.js +412 -0
- package/dist/cjs/operator/cnpg.js.map +1 -0
- package/dist/cjs/operator/index.d.ts +48 -0
- package/dist/cjs/operator/index.d.ts.map +1 -0
- package/dist/cjs/operator/index.js +155 -0
- package/dist/cjs/operator/index.js.map +1 -0
- package/dist/cjs/operator/interfaces.d.ts +192 -0
- package/dist/cjs/operator/interfaces.d.ts.map +1 -0
- package/dist/cjs/operator/interfaces.js +20 -0
- package/dist/cjs/operator/interfaces.js.map +1 -0
- package/dist/cjs/operator/mariadb.d.ts +22 -0
- package/dist/cjs/operator/mariadb.d.ts.map +1 -0
- package/dist/cjs/operator/mariadb.js +389 -0
- package/dist/cjs/operator/mariadb.js.map +1 -0
- package/dist/cjs/operator/minio.d.ts +37 -0
- package/dist/cjs/operator/minio.d.ts.map +1 -0
- package/dist/cjs/operator/minio.js +364 -0
- package/dist/cjs/operator/minio.js.map +1 -0
- package/dist/cjs/operator/neo4j.d.ts +48 -0
- package/dist/cjs/operator/neo4j.d.ts.map +1 -0
- package/dist/cjs/operator/neo4j.js +431 -0
- package/dist/cjs/operator/neo4j.js.map +1 -0
- package/dist/cjs/platform/components/argocd.d.ts +9 -0
- package/dist/cjs/platform/components/argocd.d.ts.map +1 -0
- package/dist/cjs/platform/components/argocd.js +82 -0
- package/dist/cjs/platform/components/argocd.js.map +1 -0
- package/dist/cjs/platform/components/cert-manager.d.ts +9 -0
- package/dist/cjs/platform/components/cert-manager.d.ts.map +1 -0
- package/dist/cjs/platform/components/cert-manager.js +56 -0
- package/dist/cjs/platform/components/cert-manager.js.map +1 -0
- package/dist/cjs/platform/components/descheduler.d.ts +9 -0
- package/dist/cjs/platform/components/descheduler.d.ts.map +1 -0
- package/dist/cjs/platform/components/descheduler.js +67 -0
- package/dist/cjs/platform/components/descheduler.js.map +1 -0
- package/dist/cjs/platform/components/external-dns.d.ts +9 -0
- package/dist/cjs/platform/components/external-dns.d.ts.map +1 -0
- package/dist/cjs/platform/components/external-dns.js +83 -0
- package/dist/cjs/platform/components/external-dns.js.map +1 -0
- package/dist/cjs/platform/components/external-secrets.d.ts +9 -0
- package/dist/cjs/platform/components/external-secrets.d.ts.map +1 -0
- package/dist/cjs/platform/components/external-secrets.js +62 -0
- package/dist/cjs/platform/components/external-secrets.js.map +1 -0
- package/dist/cjs/platform/components/index.d.ts +17 -0
- package/dist/cjs/platform/components/index.d.ts.map +1 -0
- package/dist/cjs/platform/components/index.js +28 -0
- package/dist/cjs/platform/components/index.js.map +1 -0
- package/dist/cjs/platform/components/oauth2-proxy.d.ts +14 -0
- package/dist/cjs/platform/components/oauth2-proxy.d.ts.map +1 -0
- package/dist/cjs/platform/components/oauth2-proxy.js +80 -0
- package/dist/cjs/platform/components/oauth2-proxy.js.map +1 -0
- package/dist/cjs/platform/components/traefik.d.ts +9 -0
- package/dist/cjs/platform/components/traefik.d.ts.map +1 -0
- package/dist/cjs/platform/components/traefik.js +74 -0
- package/dist/cjs/platform/components/traefik.js.map +1 -0
- package/dist/cjs/platform/components/vault.d.ts +12 -0
- package/dist/cjs/platform/components/vault.d.ts.map +1 -0
- package/dist/cjs/platform/components/vault.js +474 -0
- package/dist/cjs/platform/components/vault.js.map +1 -0
- package/dist/cjs/platform/index.d.ts +2 -1
- package/dist/cjs/platform/index.d.ts.map +1 -1
- package/dist/cjs/platform/index.js +3 -1
- package/dist/cjs/platform/index.js.map +1 -1
- package/dist/cjs/platform/interfaces.d.ts +73 -1
- package/dist/cjs/platform/interfaces.d.ts.map +1 -1
- package/dist/cjs/platform/interfaces.js +8 -0
- package/dist/cjs/platform/interfaces.js.map +1 -1
- package/dist/cjs/platform/stack.d.ts +1 -1
- package/dist/cjs/platform/stack.d.ts.map +1 -1
- package/dist/cjs/platform/stack.js +363 -153
- package/dist/cjs/platform/stack.js.map +1 -1
- package/dist/cjs/queue/index.d.ts +1 -0
- package/dist/cjs/queue/index.d.ts.map +1 -1
- package/dist/cjs/queue/index.js +5 -0
- package/dist/cjs/queue/index.js.map +1 -1
- package/dist/cjs/queue/interfaces.d.ts +20 -0
- package/dist/cjs/queue/interfaces.d.ts.map +1 -1
- package/dist/cjs/queue/interfaces.js +21 -0
- package/dist/cjs/queue/interfaces.js.map +1 -1
- package/dist/cjs/rackspace/cluster.d.ts +30 -0
- package/dist/cjs/rackspace/cluster.d.ts.map +1 -0
- package/dist/cjs/rackspace/cluster.js +116 -0
- package/dist/cjs/rackspace/cluster.js.map +1 -0
- package/dist/cjs/rackspace/index.d.ts +7 -0
- package/dist/cjs/rackspace/index.d.ts.map +1 -0
- package/dist/cjs/rackspace/index.js +11 -0
- package/dist/cjs/rackspace/index.js.map +1 -0
- package/dist/cjs/secrets/index.d.ts +1 -0
- package/dist/cjs/secrets/index.d.ts.map +1 -1
- package/dist/cjs/secrets/index.js +3 -0
- package/dist/cjs/secrets/index.js.map +1 -1
- package/dist/cjs/secrets/interfaces.d.ts +7 -0
- package/dist/cjs/secrets/interfaces.d.ts.map +1 -1
- package/dist/cjs/secrets/interfaces.js +8 -0
- package/dist/cjs/secrets/interfaces.js.map +1 -1
- package/dist/cjs/state/index.d.ts +1 -0
- package/dist/cjs/state/index.d.ts.map +1 -1
- package/dist/cjs/state/index.js +3 -0
- package/dist/cjs/state/index.js.map +1 -1
- package/dist/cjs/state/interfaces.d.ts +6 -0
- package/dist/cjs/state/interfaces.d.ts.map +1 -1
- package/dist/cjs/state/interfaces.js +7 -0
- package/dist/cjs/state/interfaces.js.map +1 -1
- package/dist/cjs/types/cloud-target.d.ts +7 -0
- package/dist/cjs/types/cloud-target.d.ts.map +1 -1
- package/dist/cjs/types/cloud-target.js +9 -2
- package/dist/cjs/types/cloud-target.js.map +1 -1
- package/dist/cjs/types/exposed-service.d.ts +20 -0
- package/dist/cjs/types/exposed-service.d.ts.map +1 -0
- package/dist/cjs/types/exposed-service.js +8 -0
- package/dist/cjs/types/exposed-service.js.map +1 -0
- package/dist/cjs/types/index.d.ts +3 -1
- package/dist/cjs/types/index.d.ts.map +1 -1
- package/dist/cjs/types/index.js +5 -1
- package/dist/cjs/types/index.js.map +1 -1
- package/dist/cjs/types/storage-tiers.d.ts +26 -0
- package/dist/cjs/types/storage-tiers.d.ts.map +1 -0
- package/dist/cjs/types/storage-tiers.js +30 -0
- package/dist/cjs/types/storage-tiers.js.map +1 -0
- package/dist/cjs/utils/ensure-namespace.d.ts +7 -0
- package/dist/cjs/utils/ensure-namespace.d.ts.map +1 -0
- package/dist/cjs/utils/ensure-namespace.js +53 -0
- package/dist/cjs/utils/ensure-namespace.js.map +1 -0
- package/dist/cjs/utils/index.d.ts +1 -0
- package/dist/cjs/utils/index.d.ts.map +1 -1
- package/dist/cjs/utils/index.js +3 -1
- package/dist/cjs/utils/index.js.map +1 -1
- package/dist/esm/access/dns.d.ts +26 -0
- package/dist/esm/access/dns.d.ts.map +1 -0
- package/dist/esm/access/dns.js +136 -0
- package/dist/esm/access/dns.js.map +1 -0
- package/dist/esm/access/index.d.ts +30 -0
- package/dist/esm/access/index.d.ts.map +1 -0
- package/dist/esm/access/index.js +45 -0
- package/dist/esm/access/index.js.map +1 -0
- package/dist/esm/access/interfaces.d.ts +97 -0
- package/dist/esm/access/interfaces.d.ts.map +1 -0
- package/dist/esm/access/interfaces.js +17 -0
- package/dist/esm/access/interfaces.js.map +1 -0
- package/dist/esm/access/proxy.d.ts +21 -0
- package/dist/esm/access/proxy.d.ts.map +1 -0
- package/dist/esm/access/proxy.js +155 -0
- package/dist/esm/access/proxy.js.map +1 -0
- package/dist/esm/access/tailscale-dns.d.ts +28 -0
- package/dist/esm/access/tailscale-dns.d.ts.map +1 -0
- package/dist/esm/access/tailscale-dns.js +131 -0
- package/dist/esm/access/tailscale-dns.js.map +1 -0
- package/dist/esm/access/tailscale.d.ts +14 -0
- package/dist/esm/access/tailscale.d.ts.map +1 -0
- package/dist/esm/access/tailscale.js +135 -0
- package/dist/esm/access/tailscale.js.map +1 -0
- package/dist/esm/access/wireguard.d.ts +14 -0
- package/dist/esm/access/wireguard.d.ts.map +1 -0
- package/dist/esm/access/wireguard.js +140 -0
- package/dist/esm/access/wireguard.js.map +1 -0
- package/dist/esm/argocd/app.d.ts +31 -0
- package/dist/esm/argocd/app.d.ts.map +1 -0
- package/dist/esm/argocd/app.js +194 -0
- package/dist/esm/argocd/app.js.map +1 -0
- package/dist/esm/argocd/argocd.d.ts +33 -0
- package/dist/esm/argocd/argocd.d.ts.map +1 -0
- package/dist/esm/argocd/argocd.js +182 -0
- package/dist/esm/argocd/argocd.js.map +1 -0
- package/dist/esm/argocd/external-secrets.d.ts +23 -0
- package/dist/esm/argocd/external-secrets.d.ts.map +1 -0
- package/dist/esm/argocd/external-secrets.js +121 -0
- package/dist/esm/argocd/external-secrets.js.map +1 -0
- package/dist/esm/argocd/index.d.ts +18 -0
- package/dist/esm/argocd/index.d.ts.map +1 -0
- package/dist/esm/argocd/index.js +27 -0
- package/dist/esm/argocd/index.js.map +1 -0
- package/dist/esm/argocd/interfaces.d.ts +144 -0
- package/dist/esm/argocd/interfaces.d.ts.map +1 -0
- package/dist/esm/argocd/interfaces.js +8 -0
- package/dist/esm/argocd/interfaces.js.map +1 -0
- package/dist/esm/argocd/project.d.ts +23 -0
- package/dist/esm/argocd/project.d.ts.map +1 -0
- package/dist/esm/argocd/project.js +93 -0
- package/dist/esm/argocd/project.js.map +1 -0
- package/dist/esm/argocd/repo.d.ts +15 -0
- package/dist/esm/argocd/repo.d.ts.map +1 -0
- package/dist/esm/argocd/repo.js +83 -0
- package/dist/esm/argocd/repo.js.map +1 -0
- package/dist/esm/argocd/secrets.d.ts +23 -0
- package/dist/esm/argocd/secrets.d.ts.map +1 -0
- package/dist/esm/argocd/secrets.js +87 -0
- package/dist/esm/argocd/secrets.js.map +1 -0
- package/dist/esm/azure/index.d.ts +1 -0
- package/dist/esm/azure/index.d.ts.map +1 -1
- package/dist/esm/azure/index.js +3 -1
- package/dist/esm/azure/index.js.map +1 -1
- package/dist/esm/azure/resource-group.d.ts +37 -0
- package/dist/esm/azure/resource-group.d.ts.map +1 -0
- package/dist/esm/azure/resource-group.js +79 -0
- package/dist/esm/azure/resource-group.js.map +1 -0
- package/dist/esm/azure/secrets.d.ts +6 -3
- package/dist/esm/azure/secrets.d.ts.map +1 -1
- package/dist/esm/azure/secrets.js +17 -3
- package/dist/esm/azure/secrets.js.map +1 -1
- package/dist/esm/backup/index.d.ts +20 -0
- package/dist/esm/backup/index.d.ts.map +1 -0
- package/dist/esm/backup/index.js +206 -0
- package/dist/esm/backup/index.js.map +1 -0
- package/dist/esm/backup/interfaces.d.ts +29 -0
- package/dist/esm/backup/interfaces.d.ts.map +1 -0
- package/dist/esm/backup/interfaces.js +3 -0
- package/dist/esm/backup/interfaces.js.map +1 -0
- package/dist/esm/cache/cache.d.ts +38 -0
- package/dist/esm/cache/cache.d.ts.map +1 -0
- package/dist/esm/cache/cache.js +189 -0
- package/dist/esm/cache/cache.js.map +1 -0
- package/dist/esm/cache/index.d.ts +2 -0
- package/dist/esm/cache/index.d.ts.map +1 -1
- package/dist/esm/cache/index.js +7 -0
- package/dist/esm/cache/index.js.map +1 -1
- package/dist/esm/cache/interfaces.d.ts +20 -0
- package/dist/esm/cache/interfaces.d.ts.map +1 -1
- package/dist/esm/cache/interfaces.js +18 -0
- package/dist/esm/cache/interfaces.js.map +1 -1
- package/dist/esm/cli/azure-prompts.d.ts +3 -12
- package/dist/esm/cli/azure-prompts.d.ts.map +1 -1
- package/dist/esm/cli/azure-prompts.js +4 -23
- package/dist/esm/cli/azure-prompts.js.map +1 -1
- package/dist/esm/cli/templates-azure.d.ts.map +1 -1
- package/dist/esm/cli/templates-azure.js +20 -15
- package/dist/esm/cli/templates-azure.js.map +1 -1
- package/dist/esm/cli/templates.d.ts +0 -1
- package/dist/esm/cli/templates.d.ts.map +1 -1
- package/dist/esm/cli/templates.js.map +1 -1
- package/dist/esm/cli.js +1 -1
- package/dist/esm/cli.js.map +1 -1
- package/dist/esm/cluster/index.d.ts +1 -1
- package/dist/esm/cluster/index.d.ts.map +1 -1
- package/dist/esm/cluster/interfaces.d.ts +18 -1
- package/dist/esm/cluster/interfaces.d.ts.map +1 -1
- package/dist/esm/database/index.d.ts +1 -0
- package/dist/esm/database/index.d.ts.map +1 -1
- package/dist/esm/database/index.js +5 -0
- package/dist/esm/database/index.js.map +1 -1
- package/dist/esm/database/interfaces.d.ts +19 -0
- package/dist/esm/database/interfaces.d.ts.map +1 -1
- package/dist/esm/database/interfaces.js +20 -0
- package/dist/esm/database/interfaces.js.map +1 -1
- package/dist/esm/dns/index.d.ts +1 -0
- package/dist/esm/dns/index.d.ts.map +1 -1
- package/dist/esm/dns/index.js +3 -0
- package/dist/esm/dns/index.js.map +1 -1
- package/dist/esm/dns/interfaces.d.ts +11 -0
- package/dist/esm/dns/interfaces.d.ts.map +1 -1
- package/dist/esm/dns/interfaces.js +12 -0
- package/dist/esm/dns/interfaces.js.map +1 -1
- package/dist/esm/email/index.d.ts +41 -0
- package/dist/esm/email/index.d.ts.map +1 -0
- package/dist/esm/email/index.js +318 -0
- package/dist/esm/email/index.js.map +1 -0
- package/dist/esm/email/interfaces.d.ts +119 -0
- package/dist/esm/email/interfaces.d.ts.map +1 -0
- package/dist/esm/email/interfaces.js +19 -0
- package/dist/esm/email/interfaces.js.map +1 -0
- package/dist/esm/factories/cluster.d.ts +1 -1
- package/dist/esm/factories/cluster.d.ts.map +1 -1
- package/dist/esm/factories/cluster.js +16 -0
- package/dist/esm/factories/cluster.js.map +1 -1
- package/dist/esm/factories/index.d.ts +1 -1
- package/dist/esm/factories/index.d.ts.map +1 -1
- package/dist/esm/factories/index.js.map +1 -1
- package/dist/esm/factories/secrets.d.ts +1 -1
- package/dist/esm/factories/secrets.js +3 -3
- package/dist/esm/factories/secrets.js.map +1 -1
- package/dist/esm/factories/types.d.ts +26 -0
- package/dist/esm/factories/types.d.ts.map +1 -1
- package/dist/esm/factories/types.js.map +1 -1
- package/dist/esm/index.d.ts +27 -5
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +75 -8
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/network/index.d.ts +1 -0
- package/dist/esm/network/index.d.ts.map +1 -1
- package/dist/esm/network/index.js +3 -1
- package/dist/esm/network/index.js.map +1 -1
- package/dist/esm/network/interfaces.d.ts +6 -0
- package/dist/esm/network/interfaces.d.ts.map +1 -1
- package/dist/esm/network/interfaces.js +7 -0
- package/dist/esm/network/interfaces.js.map +1 -1
- package/dist/esm/nimbus/index.d.ts +28 -0
- package/dist/esm/nimbus/index.d.ts.map +1 -0
- package/dist/esm/nimbus/index.js +44 -0
- package/dist/esm/nimbus/index.js.map +1 -0
- package/dist/esm/nimbus/interfaces.d.ts +64 -0
- package/dist/esm/nimbus/interfaces.d.ts.map +1 -0
- package/dist/esm/nimbus/interfaces.js +10 -0
- package/dist/esm/nimbus/interfaces.js.map +1 -0
- package/dist/esm/nimbus/registry.d.ts +19 -0
- package/dist/esm/nimbus/registry.d.ts.map +1 -0
- package/dist/esm/nimbus/registry.js +123 -0
- package/dist/esm/nimbus/registry.js.map +1 -0
- package/dist/esm/observability/alerts.d.ts +51 -0
- package/dist/esm/observability/alerts.d.ts.map +1 -0
- package/dist/esm/observability/alerts.js +281 -0
- package/dist/esm/observability/alerts.js.map +1 -0
- package/dist/esm/observability/dashboards/_helpers.d.ts +38 -0
- package/dist/esm/observability/dashboards/_helpers.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/_helpers.js +141 -0
- package/dist/esm/observability/dashboards/_helpers.js.map +1 -0
- package/dist/esm/observability/dashboards/alerts.d.ts +12 -0
- package/dist/esm/observability/dashboards/alerts.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/alerts.js +261 -0
- package/dist/esm/observability/dashboards/alerts.js.map +1 -0
- package/dist/esm/observability/dashboards/argocd-app.d.ts +18 -0
- package/dist/esm/observability/dashboards/argocd-app.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/argocd-app.js +212 -0
- package/dist/esm/observability/dashboards/argocd-app.js.map +1 -0
- package/dist/esm/observability/dashboards/argocd.d.ts +9 -0
- package/dist/esm/observability/dashboards/argocd.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/argocd.js +141 -0
- package/dist/esm/observability/dashboards/argocd.js.map +1 -0
- package/dist/esm/observability/dashboards/cert-manager.d.ts +9 -0
- package/dist/esm/observability/dashboards/cert-manager.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/cert-manager.js +167 -0
- package/dist/esm/observability/dashboards/cert-manager.js.map +1 -0
- package/dist/esm/observability/dashboards/cnpg-cluster.d.ts +15 -0
- package/dist/esm/observability/dashboards/cnpg-cluster.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/cnpg-cluster.js +376 -0
- package/dist/esm/observability/dashboards/cnpg-cluster.js.map +1 -0
- package/dist/esm/observability/dashboards/cnpg.d.ts +10 -0
- package/dist/esm/observability/dashboards/cnpg.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/cnpg.js +181 -0
- package/dist/esm/observability/dashboards/cnpg.js.map +1 -0
- package/dist/esm/observability/dashboards/index.d.ts +28 -0
- package/dist/esm/observability/dashboards/index.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/index.js +159 -0
- package/dist/esm/observability/dashboards/index.js.map +1 -0
- package/dist/esm/observability/dashboards/loki.d.ts +9 -0
- package/dist/esm/observability/dashboards/loki.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/loki.js +113 -0
- package/dist/esm/observability/dashboards/loki.js.map +1 -0
- package/dist/esm/observability/dashboards/mariadb-cluster.d.ts +15 -0
- package/dist/esm/observability/dashboards/mariadb-cluster.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/mariadb-cluster.js +424 -0
- package/dist/esm/observability/dashboards/mariadb-cluster.js.map +1 -0
- package/dist/esm/observability/dashboards/mariadb.d.ts +10 -0
- package/dist/esm/observability/dashboards/mariadb.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/mariadb.js +181 -0
- package/dist/esm/observability/dashboards/mariadb.js.map +1 -0
- package/dist/esm/observability/dashboards/minio.d.ts +9 -0
- package/dist/esm/observability/dashboards/minio.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/minio.js +267 -0
- package/dist/esm/observability/dashboards/minio.js.map +1 -0
- package/dist/esm/observability/dashboards/neo4j-cluster.d.ts +16 -0
- package/dist/esm/observability/dashboards/neo4j-cluster.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/neo4j-cluster.js +223 -0
- package/dist/esm/observability/dashboards/neo4j-cluster.js.map +1 -0
- package/dist/esm/observability/dashboards/neo4j.d.ts +9 -0
- package/dist/esm/observability/dashboards/neo4j.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/neo4j.js +156 -0
- package/dist/esm/observability/dashboards/neo4j.js.map +1 -0
- package/dist/esm/observability/dashboards/redis.d.ts +9 -0
- package/dist/esm/observability/dashboards/redis.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/redis.js +221 -0
- package/dist/esm/observability/dashboards/redis.js.map +1 -0
- package/dist/esm/observability/dashboards/traefik.d.ts +9 -0
- package/dist/esm/observability/dashboards/traefik.d.ts.map +1 -0
- package/dist/esm/observability/dashboards/traefik.js +387 -0
- package/dist/esm/observability/dashboards/traefik.js.map +1 -0
- package/dist/esm/observability/index.d.ts +10 -0
- package/dist/esm/observability/index.d.ts.map +1 -0
- package/dist/esm/observability/index.js +14 -0
- package/dist/esm/observability/index.js.map +1 -0
- package/dist/esm/observability/interfaces.d.ts +173 -0
- package/dist/esm/observability/interfaces.d.ts.map +1 -0
- package/dist/esm/observability/interfaces.js +11 -0
- package/dist/esm/observability/interfaces.js.map +1 -0
- package/dist/esm/observability/stack.d.ts +31 -0
- package/dist/esm/observability/stack.d.ts.map +1 -0
- package/dist/esm/observability/stack.js +523 -0
- package/dist/esm/observability/stack.js.map +1 -0
- package/dist/esm/operator/cnpg.d.ts +22 -0
- package/dist/esm/operator/cnpg.d.ts.map +1 -0
- package/dist/esm/operator/cnpg.js +412 -0
- package/dist/esm/operator/cnpg.js.map +1 -0
- package/dist/esm/operator/index.d.ts +48 -0
- package/dist/esm/operator/index.d.ts.map +1 -0
- package/dist/esm/operator/index.js +155 -0
- package/dist/esm/operator/index.js.map +1 -0
- package/dist/esm/operator/interfaces.d.ts +192 -0
- package/dist/esm/operator/interfaces.d.ts.map +1 -0
- package/dist/esm/operator/interfaces.js +20 -0
- package/dist/esm/operator/interfaces.js.map +1 -0
- package/dist/esm/operator/mariadb.d.ts +22 -0
- package/dist/esm/operator/mariadb.d.ts.map +1 -0
- package/dist/esm/operator/mariadb.js +389 -0
- package/dist/esm/operator/mariadb.js.map +1 -0
- package/dist/esm/operator/minio.d.ts +37 -0
- package/dist/esm/operator/minio.d.ts.map +1 -0
- package/dist/esm/operator/minio.js +364 -0
- package/dist/esm/operator/minio.js.map +1 -0
- package/dist/esm/operator/neo4j.d.ts +48 -0
- package/dist/esm/operator/neo4j.d.ts.map +1 -0
- package/dist/esm/operator/neo4j.js +431 -0
- package/dist/esm/operator/neo4j.js.map +1 -0
- package/dist/esm/platform/components/argocd.d.ts +9 -0
- package/dist/esm/platform/components/argocd.d.ts.map +1 -0
- package/dist/esm/platform/components/argocd.js +82 -0
- package/dist/esm/platform/components/argocd.js.map +1 -0
- package/dist/esm/platform/components/cert-manager.d.ts +9 -0
- package/dist/esm/platform/components/cert-manager.d.ts.map +1 -0
- package/dist/esm/platform/components/cert-manager.js +56 -0
- package/dist/esm/platform/components/cert-manager.js.map +1 -0
- package/dist/esm/platform/components/descheduler.d.ts +9 -0
- package/dist/esm/platform/components/descheduler.d.ts.map +1 -0
- package/dist/esm/platform/components/descheduler.js +67 -0
- package/dist/esm/platform/components/descheduler.js.map +1 -0
- package/dist/esm/platform/components/external-dns.d.ts +9 -0
- package/dist/esm/platform/components/external-dns.d.ts.map +1 -0
- package/dist/esm/platform/components/external-dns.js +83 -0
- package/dist/esm/platform/components/external-dns.js.map +1 -0
- package/dist/esm/platform/components/external-secrets.d.ts +9 -0
- package/dist/esm/platform/components/external-secrets.d.ts.map +1 -0
- package/dist/esm/platform/components/external-secrets.js +62 -0
- package/dist/esm/platform/components/external-secrets.js.map +1 -0
- package/dist/esm/platform/components/index.d.ts +17 -0
- package/dist/esm/platform/components/index.d.ts.map +1 -0
- package/dist/esm/platform/components/index.js +28 -0
- package/dist/esm/platform/components/index.js.map +1 -0
- package/dist/esm/platform/components/oauth2-proxy.d.ts +14 -0
- package/dist/esm/platform/components/oauth2-proxy.d.ts.map +1 -0
- package/dist/esm/platform/components/oauth2-proxy.js +80 -0
- package/dist/esm/platform/components/oauth2-proxy.js.map +1 -0
- package/dist/esm/platform/components/traefik.d.ts +9 -0
- package/dist/esm/platform/components/traefik.d.ts.map +1 -0
- package/dist/esm/platform/components/traefik.js +74 -0
- package/dist/esm/platform/components/traefik.js.map +1 -0
- package/dist/esm/platform/components/vault.d.ts +12 -0
- package/dist/esm/platform/components/vault.d.ts.map +1 -0
- package/dist/esm/platform/components/vault.js +474 -0
- package/dist/esm/platform/components/vault.js.map +1 -0
- package/dist/esm/platform/index.d.ts +2 -1
- package/dist/esm/platform/index.d.ts.map +1 -1
- package/dist/esm/platform/index.js +3 -1
- package/dist/esm/platform/index.js.map +1 -1
- package/dist/esm/platform/interfaces.d.ts +73 -1
- package/dist/esm/platform/interfaces.d.ts.map +1 -1
- package/dist/esm/platform/interfaces.js +8 -0
- package/dist/esm/platform/interfaces.js.map +1 -1
- package/dist/esm/platform/stack.d.ts +1 -1
- package/dist/esm/platform/stack.d.ts.map +1 -1
- package/dist/esm/platform/stack.js +363 -153
- package/dist/esm/platform/stack.js.map +1 -1
- package/dist/esm/queue/index.d.ts +1 -0
- package/dist/esm/queue/index.d.ts.map +1 -1
- package/dist/esm/queue/index.js +5 -0
- package/dist/esm/queue/index.js.map +1 -1
- package/dist/esm/queue/interfaces.d.ts +20 -0
- package/dist/esm/queue/interfaces.d.ts.map +1 -1
- package/dist/esm/queue/interfaces.js +21 -0
- package/dist/esm/queue/interfaces.js.map +1 -1
- package/dist/esm/rackspace/cluster.d.ts +30 -0
- package/dist/esm/rackspace/cluster.d.ts.map +1 -0
- package/dist/esm/rackspace/cluster.js +116 -0
- package/dist/esm/rackspace/cluster.js.map +1 -0
- package/dist/esm/rackspace/index.d.ts +7 -0
- package/dist/esm/rackspace/index.d.ts.map +1 -0
- package/dist/esm/rackspace/index.js +11 -0
- package/dist/esm/rackspace/index.js.map +1 -0
- package/dist/esm/secrets/index.d.ts +1 -0
- package/dist/esm/secrets/index.d.ts.map +1 -1
- package/dist/esm/secrets/index.js +3 -0
- package/dist/esm/secrets/index.js.map +1 -1
- package/dist/esm/secrets/interfaces.d.ts +7 -0
- package/dist/esm/secrets/interfaces.d.ts.map +1 -1
- package/dist/esm/secrets/interfaces.js +8 -0
- package/dist/esm/secrets/interfaces.js.map +1 -1
- package/dist/esm/state/index.d.ts +1 -0
- package/dist/esm/state/index.d.ts.map +1 -1
- package/dist/esm/state/index.js +3 -0
- package/dist/esm/state/index.js.map +1 -1
- package/dist/esm/state/interfaces.d.ts +6 -0
- package/dist/esm/state/interfaces.d.ts.map +1 -1
- package/dist/esm/state/interfaces.js +7 -0
- package/dist/esm/state/interfaces.js.map +1 -1
- package/dist/esm/types/cloud-target.d.ts +7 -0
- package/dist/esm/types/cloud-target.d.ts.map +1 -1
- package/dist/esm/types/cloud-target.js +9 -2
- package/dist/esm/types/cloud-target.js.map +1 -1
- package/dist/esm/types/exposed-service.d.ts +20 -0
- package/dist/esm/types/exposed-service.d.ts.map +1 -0
- package/dist/esm/types/exposed-service.js +8 -0
- package/dist/esm/types/exposed-service.js.map +1 -0
- package/dist/esm/types/index.d.ts +3 -1
- package/dist/esm/types/index.d.ts.map +1 -1
- package/dist/esm/types/index.js +5 -1
- package/dist/esm/types/index.js.map +1 -1
- package/dist/esm/types/storage-tiers.d.ts +26 -0
- package/dist/esm/types/storage-tiers.d.ts.map +1 -0
- package/dist/esm/types/storage-tiers.js +30 -0
- package/dist/esm/types/storage-tiers.js.map +1 -0
- package/dist/esm/utils/ensure-namespace.d.ts +7 -0
- package/dist/esm/utils/ensure-namespace.d.ts.map +1 -0
- package/dist/esm/utils/ensure-namespace.js +53 -0
- package/dist/esm/utils/ensure-namespace.js.map +1 -0
- package/dist/esm/utils/index.d.ts +1 -0
- package/dist/esm/utils/index.d.ts.map +1 -1
- package/dist/esm/utils/index.js +3 -1
- package/dist/esm/utils/index.js.map +1 -1
- package/package.json +8 -4
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Resource group abstraction — declare once, reuse across all Azure resources.
|
|
4
|
+
*
|
|
5
|
+
* Caches by name so multiple factories referencing the same resource group
|
|
6
|
+
* share a single Pulumi resource declaration. Idempotent by design:
|
|
7
|
+
* Pulumi handles create/update/no-op on each `pulumi up`.
|
|
8
|
+
*
|
|
9
|
+
* @module azure/resource-group
|
|
10
|
+
*/
|
|
11
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
12
|
+
if (k2 === undefined) k2 = k;
|
|
13
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
14
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
15
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
16
|
+
}
|
|
17
|
+
Object.defineProperty(o, k2, desc);
|
|
18
|
+
}) : (function(o, m, k, k2) {
|
|
19
|
+
if (k2 === undefined) k2 = k;
|
|
20
|
+
o[k2] = m[k];
|
|
21
|
+
}));
|
|
22
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
23
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
24
|
+
}) : function(o, v) {
|
|
25
|
+
o["default"] = v;
|
|
26
|
+
});
|
|
27
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
28
|
+
var ownKeys = function(o) {
|
|
29
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
30
|
+
var ar = [];
|
|
31
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
32
|
+
return ar;
|
|
33
|
+
};
|
|
34
|
+
return ownKeys(o);
|
|
35
|
+
};
|
|
36
|
+
return function (mod) {
|
|
37
|
+
if (mod && mod.__esModule) return mod;
|
|
38
|
+
var result = {};
|
|
39
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
40
|
+
__setModuleDefault(result, mod);
|
|
41
|
+
return result;
|
|
42
|
+
};
|
|
43
|
+
})();
|
|
44
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
45
|
+
exports.ensureResourceGroup = ensureResourceGroup;
|
|
46
|
+
const azure = __importStar(require("@pulumi/azure-native/resources"));
|
|
47
|
+
/** Cache of declared resource groups, keyed by name. */
|
|
48
|
+
const cache = new Map();
|
|
49
|
+
/**
|
|
50
|
+
* Ensure a resource group is declared in the Pulumi stack.
|
|
51
|
+
*
|
|
52
|
+
* First call creates the Pulumi resource; subsequent calls with the
|
|
53
|
+
* same name return the cached reference. This is pure declaration —
|
|
54
|
+
* Pulumi decides whether to create, update, or skip at deploy time.
|
|
55
|
+
*
|
|
56
|
+
* @param name - Desired resource group name in Azure (e.g. "rg-myapp-canadacentral")
|
|
57
|
+
* @param opts - Optional tags and location override
|
|
58
|
+
* @returns The ResourceGroup's name as a Pulumi Output (for dependency chaining)
|
|
59
|
+
*
|
|
60
|
+
* @example
|
|
61
|
+
* ```typescript
|
|
62
|
+
* const rgName = ensureResourceGroup("rg-prod-canadacentral", {
|
|
63
|
+
* tags: { environment: "production" },
|
|
64
|
+
* });
|
|
65
|
+
* ```
|
|
66
|
+
*/
|
|
67
|
+
function ensureResourceGroup(name, opts) {
|
|
68
|
+
const existing = cache.get(name);
|
|
69
|
+
if (existing)
|
|
70
|
+
return existing.name;
|
|
71
|
+
const rg = new azure.ResourceGroup(`nimbus-rg-${name}`, {
|
|
72
|
+
resourceGroupName: name,
|
|
73
|
+
location: opts?.location,
|
|
74
|
+
tags: opts?.tags,
|
|
75
|
+
});
|
|
76
|
+
cache.set(name, rg);
|
|
77
|
+
return rg.name;
|
|
78
|
+
}
|
|
79
|
+
//# sourceMappingURL=resource-group.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resource-group.js","sourceRoot":"","sources":["../../../src/azure/resource-group.ts"],"names":[],"mappings":";AAAA;;;;;;;;GAQG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkCH,kDAeC;AA/CD,sEAAwD;AAGxD,wDAAwD;AACxD,MAAM,KAAK,GAAG,IAAI,GAAG,EAA+B,CAAC;AAUrD;;;;;;;;;;;;;;;;;GAiBG;AACH,SAAgB,mBAAmB,CACjC,IAAY,EACZ,IAA4B;IAE5B,MAAM,QAAQ,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACjC,IAAI,QAAQ;QAAE,OAAO,QAAQ,CAAC,IAAI,CAAC;IAEnC,MAAM,EAAE,GAAG,IAAI,KAAK,CAAC,aAAa,CAAC,aAAa,IAAI,EAAE,EAAE;QACtD,iBAAiB,EAAE,IAAI;QACvB,QAAQ,EAAE,IAAI,EAAE,QAAQ;QACxB,IAAI,EAAE,IAAI,EAAE,IAAI;KACjB,CAAC,CAAC;IAEH,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;IACpB,OAAO,EAAE,CAAC,IAAI,CAAC;AACjB,CAAC"}
|
|
@@ -9,8 +9,8 @@ import type { ISecrets, ISecretsConfig } from "../secrets";
|
|
|
9
9
|
export interface IAzureSecretsOptions {
|
|
10
10
|
/** Resource group name. Required for Azure. */
|
|
11
11
|
readonly resourceGroupName: pulumi.Input<string>;
|
|
12
|
-
/** Azure AD tenant ID.
|
|
13
|
-
readonly tenantId
|
|
12
|
+
/** Azure AD tenant ID. Auto-detected via `getClientConfigOutput()` when omitted. */
|
|
13
|
+
readonly tenantId?: pulumi.Input<string>;
|
|
14
14
|
/** Object ID of the principal that should have access to secrets. */
|
|
15
15
|
readonly objectId?: pulumi.Input<string>;
|
|
16
16
|
/** Key Vault SKU. Default: "standard". */
|
|
@@ -19,6 +19,10 @@ export interface IAzureSecretsOptions {
|
|
|
19
19
|
/**
|
|
20
20
|
* Create an Azure Key Vault for secret management.
|
|
21
21
|
*
|
|
22
|
+
* When `tenantId` is omitted, it is auto-detected from the current Azure
|
|
23
|
+
* identity via `getClientConfigOutput()`. A Key Vault Secrets Officer RBAC
|
|
24
|
+
* role assignment is automatically created for the deploying principal.
|
|
25
|
+
*
|
|
22
26
|
* @example
|
|
23
27
|
* ```typescript
|
|
24
28
|
* const secrets = createAzureSecrets("prod", {
|
|
@@ -26,7 +30,6 @@ export interface IAzureSecretsOptions {
|
|
|
26
30
|
* backend: "azure-key-vault",
|
|
27
31
|
* }, {
|
|
28
32
|
* resourceGroupName: "my-rg",
|
|
29
|
-
* tenantId: "00000000-0000-0000-0000-000000000000",
|
|
30
33
|
* });
|
|
31
34
|
*
|
|
32
35
|
* secrets.putSecret("database", { host: "db.example.com", password: dbPassword });
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"secrets.d.ts","sourceRoot":"","sources":["../../../src/azure/secrets.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,MAAM,MAAM,gBAAgB,CAAC;AACzC,OAAO,KAAK,EAAc,QAAQ,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;
|
|
1
|
+
{"version":3,"file":"secrets.d.ts","sourceRoot":"","sources":["../../../src/azure/secrets.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,MAAM,MAAM,gBAAgB,CAAC;AACzC,OAAO,KAAK,EAAc,QAAQ,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAYvE,sCAAsC;AACtC,MAAM,WAAW,oBAAoB;IACnC,+CAA+C;IAC/C,QAAQ,CAAC,iBAAiB,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACjD,oFAAoF;IACpF,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACzC,qEAAqE;IACrE,QAAQ,CAAC,QAAQ,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACzC,0CAA0C;IAC1C,QAAQ,CAAC,GAAG,CAAC,EAAE,UAAU,GAAG,SAAS,CAAC;CACvC;AAED;;;;;;;;;;;;;;;;;;;GAmBG;AACH,wBAAgB,kBAAkB,CAChC,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,oBAAoB,GAC5B,QAAQ,CAmHV"}
|
|
@@ -46,9 +46,15 @@ const types_1 = require("../types");
|
|
|
46
46
|
const KEY_VAULT_NAME_MAX_LENGTH = 24;
|
|
47
47
|
/** Default soft-delete retention period in days for Key Vault. */
|
|
48
48
|
const SOFT_DELETE_RETENTION_DAYS = 90;
|
|
49
|
+
/** Well-known role definition ID for Key Vault Secrets Officer. */
|
|
50
|
+
const KEY_VAULT_SECRETS_OFFICER_ROLE_ID = "b86a8fe4-44ce-4948-aee5-eccb2c155cd7";
|
|
49
51
|
/**
|
|
50
52
|
* Create an Azure Key Vault for secret management.
|
|
51
53
|
*
|
|
54
|
+
* When `tenantId` is omitted, it is auto-detected from the current Azure
|
|
55
|
+
* identity via `getClientConfigOutput()`. A Key Vault Secrets Officer RBAC
|
|
56
|
+
* role assignment is automatically created for the deploying principal.
|
|
57
|
+
*
|
|
52
58
|
* @example
|
|
53
59
|
* ```typescript
|
|
54
60
|
* const secrets = createAzureSecrets("prod", {
|
|
@@ -56,7 +62,6 @@ const SOFT_DELETE_RETENTION_DAYS = 90;
|
|
|
56
62
|
* backend: "azure-key-vault",
|
|
57
63
|
* }, {
|
|
58
64
|
* resourceGroupName: "my-rg",
|
|
59
|
-
* tenantId: "00000000-0000-0000-0000-000000000000",
|
|
60
65
|
* });
|
|
61
66
|
*
|
|
62
67
|
* secrets.putSecret("database", { host: "db.example.com", password: dbPassword });
|
|
@@ -68,12 +73,15 @@ function createAzureSecrets(name, config, options) {
|
|
|
68
73
|
const target = (0, types_1.resolveCloudTarget)(cloud);
|
|
69
74
|
const tags = config.tags ?? {};
|
|
70
75
|
const rgName = options.resourceGroupName;
|
|
76
|
+
// Auto-detect tenantId from current Azure identity when not provided
|
|
77
|
+
const clientConfig = azure.authorization.getClientConfigOutput();
|
|
78
|
+
const tenantId = options.tenantId ?? clientConfig.tenantId;
|
|
71
79
|
// Key Vault names must be 3-24 chars, alphanumeric + hyphens
|
|
72
80
|
const vaultName = name.replace(/[^a-zA-Z0-9-]/g, "-").substring(0, KEY_VAULT_NAME_MAX_LENGTH);
|
|
73
81
|
const accessPolicies = [];
|
|
74
82
|
if (options.objectId) {
|
|
75
83
|
accessPolicies.push({
|
|
76
|
-
tenantId
|
|
84
|
+
tenantId,
|
|
77
85
|
objectId: options.objectId,
|
|
78
86
|
permissions: {
|
|
79
87
|
secrets: ["Get", "List", "Set", "Delete"],
|
|
@@ -84,7 +92,7 @@ function createAzureSecrets(name, config, options) {
|
|
|
84
92
|
vaultName,
|
|
85
93
|
resourceGroupName: rgName,
|
|
86
94
|
properties: {
|
|
87
|
-
tenantId
|
|
95
|
+
tenantId,
|
|
88
96
|
sku: {
|
|
89
97
|
family: "A",
|
|
90
98
|
name: options.sku === "premium"
|
|
@@ -98,6 +106,12 @@ function createAzureSecrets(name, config, options) {
|
|
|
98
106
|
},
|
|
99
107
|
tags: { ...tags, Name: `${name}-kv` },
|
|
100
108
|
});
|
|
109
|
+
// Grant the deploying principal Key Vault Secrets Officer on this vault
|
|
110
|
+
new azure.authorization.RoleAssignment(`${name}-kv-secrets-officer`, {
|
|
111
|
+
principalId: clientConfig.objectId,
|
|
112
|
+
roleDefinitionId: clientConfig.subscriptionId.apply((sub) => `/subscriptions/${sub}/providers/Microsoft.Authorization/roleDefinitions/${KEY_VAULT_SECRETS_OFFICER_ROLE_ID}`),
|
|
113
|
+
scope: vault.id,
|
|
114
|
+
});
|
|
101
115
|
// Track created secrets for getSecretRef lookups
|
|
102
116
|
const secretResources = new Map();
|
|
103
117
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"secrets.js","sourceRoot":"","sources":["../../../src/azure/secrets.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"secrets.js","sourceRoot":"","sources":["../../../src/azure/secrets.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Backup target module — S3-backed backup destinations with IAM credentials
|
|
3
|
+
* and optional cross-region replication.
|
|
4
|
+
*
|
|
5
|
+
* @module backup
|
|
6
|
+
*/
|
|
7
|
+
import type { IBackupTarget, IBackupTargetConfig } from "./interfaces";
|
|
8
|
+
export type { IBackupReplicationConfig, IBackupTargetConfig, IBackupTarget } from "./interfaces";
|
|
9
|
+
/**
|
|
10
|
+
* Create an S3-backed backup target with IAM credentials.
|
|
11
|
+
*
|
|
12
|
+
* Provisions an S3 bucket with versioning, an IAM user scoped to that bucket,
|
|
13
|
+
* and optionally a replica bucket in another region for cross-region replication.
|
|
14
|
+
*
|
|
15
|
+
* @param name - Logical name prefix for all created resources
|
|
16
|
+
* @param config - Backup target configuration
|
|
17
|
+
* @returns IBackupTarget with bucket name, credentials, and optional replica bucket
|
|
18
|
+
*/
|
|
19
|
+
export declare function createBackupTarget(name: string, config: IBackupTargetConfig): IBackupTarget;
|
|
20
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/backup/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAIH,OAAO,KAAK,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAEvE,YAAY,EAAE,wBAAwB,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,cAAc,CAAC;AAEjG;;;;;;;;;GASG;AACH,wBAAgB,kBAAkB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,mBAAmB,GAAG,aAAa,CAsN3F"}
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Backup target module — S3-backed backup destinations with IAM credentials
|
|
4
|
+
* and optional cross-region replication.
|
|
5
|
+
*
|
|
6
|
+
* @module backup
|
|
7
|
+
*/
|
|
8
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
9
|
+
if (k2 === undefined) k2 = k;
|
|
10
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
11
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
12
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
13
|
+
}
|
|
14
|
+
Object.defineProperty(o, k2, desc);
|
|
15
|
+
}) : (function(o, m, k, k2) {
|
|
16
|
+
if (k2 === undefined) k2 = k;
|
|
17
|
+
o[k2] = m[k];
|
|
18
|
+
}));
|
|
19
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
20
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
21
|
+
}) : function(o, v) {
|
|
22
|
+
o["default"] = v;
|
|
23
|
+
});
|
|
24
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
25
|
+
var ownKeys = function(o) {
|
|
26
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
27
|
+
var ar = [];
|
|
28
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
29
|
+
return ar;
|
|
30
|
+
};
|
|
31
|
+
return ownKeys(o);
|
|
32
|
+
};
|
|
33
|
+
return function (mod) {
|
|
34
|
+
if (mod && mod.__esModule) return mod;
|
|
35
|
+
var result = {};
|
|
36
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
37
|
+
__setModuleDefault(result, mod);
|
|
38
|
+
return result;
|
|
39
|
+
};
|
|
40
|
+
})();
|
|
41
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
42
|
+
exports.createBackupTarget = createBackupTarget;
|
|
43
|
+
const aws = __importStar(require("@pulumi/aws"));
|
|
44
|
+
const pulumi = __importStar(require("@pulumi/pulumi"));
|
|
45
|
+
/**
|
|
46
|
+
* Create an S3-backed backup target with IAM credentials.
|
|
47
|
+
*
|
|
48
|
+
* Provisions an S3 bucket with versioning, an IAM user scoped to that bucket,
|
|
49
|
+
* and optionally a replica bucket in another region for cross-region replication.
|
|
50
|
+
*
|
|
51
|
+
* @param name - Logical name prefix for all created resources
|
|
52
|
+
* @param config - Backup target configuration
|
|
53
|
+
* @returns IBackupTarget with bucket name, credentials, and optional replica bucket
|
|
54
|
+
*/
|
|
55
|
+
function createBackupTarget(name, config) {
|
|
56
|
+
const bucketName = config.bucketPrefix ? `${config.bucketPrefix}-${name}` : name;
|
|
57
|
+
const providerOpts = config.awsProvider
|
|
58
|
+
? { provider: config.awsProvider }
|
|
59
|
+
: {};
|
|
60
|
+
// Primary bucket
|
|
61
|
+
const bucket = new aws.s3.Bucket(`${name}-bucket`, {
|
|
62
|
+
bucket: bucketName,
|
|
63
|
+
tags: config.tags,
|
|
64
|
+
}, providerOpts);
|
|
65
|
+
// Enable versioning on the primary bucket
|
|
66
|
+
new aws.s3.BucketVersioning(`${name}-bucket-versioning`, {
|
|
67
|
+
bucket: bucket.bucket,
|
|
68
|
+
versioningConfiguration: {
|
|
69
|
+
status: "Enabled",
|
|
70
|
+
},
|
|
71
|
+
}, { ...providerOpts, dependsOn: [bucket] });
|
|
72
|
+
// IAM user for backup credentials
|
|
73
|
+
const iamUser = new aws.iam.User(`${name}-backup-user`, {
|
|
74
|
+
name: `nimbus-backup-${name}`,
|
|
75
|
+
path: "/nimbus/",
|
|
76
|
+
tags: config.tags,
|
|
77
|
+
}, providerOpts);
|
|
78
|
+
// IAM policy scoped to the bucket
|
|
79
|
+
const iamPolicy = new aws.iam.Policy(`${name}-backup-policy`, {
|
|
80
|
+
name: `nimbus-backup-${name}`,
|
|
81
|
+
description: `Nimbus backup policy for bucket ${bucketName}`,
|
|
82
|
+
policy: pulumi.all([bucket.arn]).apply(([bucketArn]) => JSON.stringify({
|
|
83
|
+
Version: "2012-10-17",
|
|
84
|
+
Statement: [
|
|
85
|
+
{
|
|
86
|
+
Effect: "Allow",
|
|
87
|
+
Action: ["s3:PutObject", "s3:GetObject", "s3:DeleteObject"],
|
|
88
|
+
Resource: `${bucketArn}/*`,
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
Effect: "Allow",
|
|
92
|
+
Action: ["s3:ListBucket"],
|
|
93
|
+
Resource: bucketArn,
|
|
94
|
+
},
|
|
95
|
+
],
|
|
96
|
+
})),
|
|
97
|
+
tags: config.tags,
|
|
98
|
+
}, providerOpts);
|
|
99
|
+
// Attach policy to user
|
|
100
|
+
new aws.iam.UserPolicyAttachment(`${name}-backup-policy-attachment`, {
|
|
101
|
+
user: iamUser.name,
|
|
102
|
+
policyArn: iamPolicy.arn,
|
|
103
|
+
}, { ...providerOpts, dependsOn: [iamUser, iamPolicy] });
|
|
104
|
+
// IAM access key
|
|
105
|
+
const accessKey = new aws.iam.AccessKey(`${name}-backup-access-key`, {
|
|
106
|
+
user: iamUser.name,
|
|
107
|
+
}, { ...providerOpts, dependsOn: [iamUser] });
|
|
108
|
+
// Optional: cross-region replication
|
|
109
|
+
let replicationBucket;
|
|
110
|
+
if (config.replication?.enabled) {
|
|
111
|
+
const replicaRegion = config.replication.targetRegion;
|
|
112
|
+
// Create a provider for the replica region
|
|
113
|
+
const replicaProvider = new aws.Provider(`${name}-replica-provider`, {
|
|
114
|
+
region: replicaRegion,
|
|
115
|
+
});
|
|
116
|
+
const replicaBucketName = `${bucketName}-replica`;
|
|
117
|
+
const replicaBucketResource = new aws.s3.Bucket(`${name}-replica-bucket`, {
|
|
118
|
+
bucket: replicaBucketName,
|
|
119
|
+
tags: config.tags,
|
|
120
|
+
}, { provider: replicaProvider });
|
|
121
|
+
// Enable versioning on replica (required for replication)
|
|
122
|
+
new aws.s3.BucketVersioning(`${name}-replica-bucket-versioning`, {
|
|
123
|
+
bucket: replicaBucketResource.bucket,
|
|
124
|
+
versioningConfiguration: {
|
|
125
|
+
status: "Enabled",
|
|
126
|
+
},
|
|
127
|
+
}, { provider: replicaProvider, dependsOn: [replicaBucketResource] });
|
|
128
|
+
// IAM role for replication
|
|
129
|
+
const replicationRole = new aws.iam.Role(`${name}-replication-role`, {
|
|
130
|
+
name: `nimbus-replication-${name}`,
|
|
131
|
+
assumeRolePolicy: JSON.stringify({
|
|
132
|
+
Version: "2012-10-17",
|
|
133
|
+
Statement: [
|
|
134
|
+
{
|
|
135
|
+
Effect: "Allow",
|
|
136
|
+
Principal: { Service: "s3.amazonaws.com" },
|
|
137
|
+
Action: "sts:AssumeRole",
|
|
138
|
+
},
|
|
139
|
+
],
|
|
140
|
+
}),
|
|
141
|
+
tags: config.tags,
|
|
142
|
+
}, providerOpts);
|
|
143
|
+
// Replication role policy
|
|
144
|
+
const replicationPolicy = new aws.iam.RolePolicy(`${name}-replication-policy`, {
|
|
145
|
+
role: replicationRole.name,
|
|
146
|
+
policy: pulumi.all([bucket.arn, replicaBucketResource.arn]).apply(([srcArn, dstArn]) => JSON.stringify({
|
|
147
|
+
Version: "2012-10-17",
|
|
148
|
+
Statement: [
|
|
149
|
+
{
|
|
150
|
+
Effect: "Allow",
|
|
151
|
+
Action: ["s3:GetReplicationConfiguration", "s3:ListBucket"],
|
|
152
|
+
Resource: srcArn,
|
|
153
|
+
},
|
|
154
|
+
{
|
|
155
|
+
Effect: "Allow",
|
|
156
|
+
Action: [
|
|
157
|
+
"s3:GetObjectVersionForReplication",
|
|
158
|
+
"s3:GetObjectVersionAcl",
|
|
159
|
+
"s3:GetObjectVersionTagging",
|
|
160
|
+
],
|
|
161
|
+
Resource: `${srcArn}/*`,
|
|
162
|
+
},
|
|
163
|
+
{
|
|
164
|
+
Effect: "Allow",
|
|
165
|
+
Action: ["s3:ReplicateObject", "s3:ReplicateDelete", "s3:ReplicateTags"],
|
|
166
|
+
Resource: `${dstArn}/*`,
|
|
167
|
+
},
|
|
168
|
+
],
|
|
169
|
+
})),
|
|
170
|
+
}, { ...providerOpts, dependsOn: [replicationRole] });
|
|
171
|
+
// Bucket replication configuration
|
|
172
|
+
new aws.s3.BucketReplicationConfig(`${name}-replication-config`, {
|
|
173
|
+
bucket: bucket.bucket,
|
|
174
|
+
role: replicationRole.arn,
|
|
175
|
+
rules: [
|
|
176
|
+
{
|
|
177
|
+
id: `${name}-replicate-all`,
|
|
178
|
+
status: "Enabled",
|
|
179
|
+
destination: {
|
|
180
|
+
bucket: replicaBucketResource.arn,
|
|
181
|
+
storageClass: "STANDARD",
|
|
182
|
+
},
|
|
183
|
+
filter: {
|
|
184
|
+
prefix: "",
|
|
185
|
+
},
|
|
186
|
+
deleteMarkerReplication: {
|
|
187
|
+
status: "Enabled",
|
|
188
|
+
},
|
|
189
|
+
},
|
|
190
|
+
],
|
|
191
|
+
}, { ...providerOpts, dependsOn: [bucket, replicaBucketResource, replicationPolicy] });
|
|
192
|
+
replicationBucket = replicaBucketResource.bucket;
|
|
193
|
+
}
|
|
194
|
+
return {
|
|
195
|
+
name,
|
|
196
|
+
bucket: bucket.bucket,
|
|
197
|
+
region: config.region,
|
|
198
|
+
credentials: {
|
|
199
|
+
accessKeyId: accessKey.id,
|
|
200
|
+
secretAccessKey: accessKey.secret,
|
|
201
|
+
},
|
|
202
|
+
replicationBucket,
|
|
203
|
+
nativeResource: bucket,
|
|
204
|
+
};
|
|
205
|
+
}
|
|
206
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/backup/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Backup target interfaces for @reyemtech/nimbus.
|
|
3
|
+
* @module backup/interfaces
|
|
4
|
+
*/
|
|
5
|
+
import type * as pulumi from "@pulumi/pulumi";
|
|
6
|
+
export interface IBackupReplicationConfig {
|
|
7
|
+
readonly enabled: boolean;
|
|
8
|
+
readonly targetRegion: string;
|
|
9
|
+
}
|
|
10
|
+
export interface IBackupTargetConfig {
|
|
11
|
+
readonly cloud: "aws";
|
|
12
|
+
readonly region: string;
|
|
13
|
+
readonly bucketPrefix?: string;
|
|
14
|
+
readonly replication?: IBackupReplicationConfig;
|
|
15
|
+
readonly tags?: Record<string, string>;
|
|
16
|
+
readonly awsProvider?: pulumi.ProviderResource;
|
|
17
|
+
}
|
|
18
|
+
export interface IBackupTarget {
|
|
19
|
+
readonly name: string;
|
|
20
|
+
readonly bucket: pulumi.Output<string>;
|
|
21
|
+
readonly region: string;
|
|
22
|
+
readonly credentials: {
|
|
23
|
+
readonly accessKeyId: pulumi.Output<string>;
|
|
24
|
+
readonly secretAccessKey: pulumi.Output<string>;
|
|
25
|
+
};
|
|
26
|
+
readonly replicationBucket?: pulumi.Output<string>;
|
|
27
|
+
readonly nativeResource: pulumi.Resource;
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=interfaces.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.d.ts","sourceRoot":"","sources":["../../../src/backup/interfaces.ts"],"names":[],"mappings":"AAAA;;;GAGG;AACH,OAAO,KAAK,KAAK,MAAM,MAAM,gBAAgB,CAAC;AAE9C,MAAM,WAAW,wBAAwB;IACvC,QAAQ,CAAC,OAAO,EAAE,OAAO,CAAC;IAC1B,QAAQ,CAAC,YAAY,EAAE,MAAM,CAAC;CAC/B;AAED,MAAM,WAAW,mBAAmB;IAClC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC;IACtB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,YAAY,CAAC,EAAE,MAAM,CAAC;IAC/B,QAAQ,CAAC,WAAW,CAAC,EAAE,wBAAwB,CAAC;IAChD,QAAQ,CAAC,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACvC,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC,gBAAgB,CAAC;CAChD;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACvC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,WAAW,EAAE;QACpB,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAC5C,QAAQ,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;KACjD,CAAC;IACF,QAAQ,CAAC,iBAAiB,CAAC,EAAE,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACnD,QAAQ,CAAC,cAAc,EAAE,MAAM,CAAC,QAAQ,CAAC;CAC1C"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../src/backup/interfaces.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Cache implementation — deploys Bitnami Redis via Helm.
|
|
3
|
+
*
|
|
4
|
+
* Supports standalone and replication (Sentinel) architectures.
|
|
5
|
+
* Authentication is always enabled; Bitnami creates a `{releaseName}-redis`
|
|
6
|
+
* secret with a `redis-password` key.
|
|
7
|
+
*
|
|
8
|
+
* @module cache/cache
|
|
9
|
+
*/
|
|
10
|
+
import * as k8s from "@pulumi/kubernetes";
|
|
11
|
+
import { type StorageTierMap } from "../types/storage-tiers";
|
|
12
|
+
import type { ICacheConfig, ICache } from "./interfaces";
|
|
13
|
+
/**
|
|
14
|
+
* Deploy a Redis cache using the Bitnami Redis Helm chart.
|
|
15
|
+
*
|
|
16
|
+
* Defaults to `replication` architecture with Sentinel for HA.
|
|
17
|
+
* Use `standalone` for single-node dev/test deployments.
|
|
18
|
+
*
|
|
19
|
+
* @example
|
|
20
|
+
* ```typescript
|
|
21
|
+
* const cache = createCache("session", {
|
|
22
|
+
* cloud: "aws",
|
|
23
|
+
* engine: "redis",
|
|
24
|
+
* mode: "helm",
|
|
25
|
+
* architecture: "replication",
|
|
26
|
+
* replicas: 2,
|
|
27
|
+
* storageGb: 5,
|
|
28
|
+
* metrics: true,
|
|
29
|
+
* }, provider);
|
|
30
|
+
* ```
|
|
31
|
+
*
|
|
32
|
+
* @param name - Logical name for the cache resource (used as Helm release name prefix)
|
|
33
|
+
* @param config - Cache configuration
|
|
34
|
+
* @param provider - Kubernetes provider to deploy into
|
|
35
|
+
* @returns Deployed cache resource
|
|
36
|
+
*/
|
|
37
|
+
export declare function createCache(name: string, config: ICacheConfig, provider: k8s.Provider, storageTiers?: StorageTierMap): ICache;
|
|
38
|
+
//# sourceMappingURL=cache.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cache.d.ts","sourceRoot":"","sources":["../../../src/cache/cache.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,KAAK,GAAG,MAAM,oBAAoB,CAAC;AAK1C,OAAO,EAAsB,KAAK,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAEjF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAezD;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AACH,wBAAgB,WAAW,CACzB,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,YAAY,EACpB,QAAQ,EAAE,GAAG,CAAC,QAAQ,EACtB,YAAY,CAAC,EAAE,cAAc,GAC5B,MAAM,CAgIR"}
|