@reyemtech/nimbus 0.1.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/LICENSE +21 -0
- package/README.md +399 -0
- package/dist/cjs/aws/cluster.d.ts +32 -0
- package/dist/cjs/aws/cluster.d.ts.map +1 -0
- package/dist/cjs/aws/cluster.js +214 -0
- package/dist/cjs/aws/cluster.js.map +1 -0
- package/dist/cjs/aws/dns.d.ts +22 -0
- package/dist/cjs/aws/dns.d.ts.map +1 -0
- package/dist/cjs/aws/dns.js +95 -0
- package/dist/cjs/aws/dns.js.map +1 -0
- package/dist/cjs/aws/index.d.ts +10 -0
- package/dist/cjs/aws/index.d.ts.map +1 -0
- package/dist/cjs/aws/index.js +17 -0
- package/dist/cjs/aws/index.js.map +1 -0
- package/dist/cjs/aws/network.d.ts +27 -0
- package/dist/cjs/aws/network.d.ts.map +1 -0
- package/dist/cjs/aws/network.js +262 -0
- package/dist/cjs/aws/network.js.map +1 -0
- package/dist/cjs/aws/secrets.d.ts +26 -0
- package/dist/cjs/aws/secrets.d.ts.map +1 -0
- package/dist/cjs/aws/secrets.js +127 -0
- package/dist/cjs/aws/secrets.js.map +1 -0
- package/dist/cjs/azure/cluster.d.ts +44 -0
- package/dist/cjs/azure/cluster.d.ts.map +1 -0
- package/dist/cjs/azure/cluster.js +143 -0
- package/dist/cjs/azure/cluster.js.map +1 -0
- package/dist/cjs/azure/dns.d.ts +28 -0
- package/dist/cjs/azure/dns.d.ts.map +1 -0
- package/dist/cjs/azure/dns.js +169 -0
- package/dist/cjs/azure/dns.js.map +1 -0
- package/dist/cjs/azure/index.d.ts +10 -0
- package/dist/cjs/azure/index.d.ts.map +1 -0
- package/dist/cjs/azure/index.js +17 -0
- package/dist/cjs/azure/index.js.map +1 -0
- package/dist/cjs/azure/network.d.ts +28 -0
- package/dist/cjs/azure/network.d.ts.map +1 -0
- package/dist/cjs/azure/network.js +176 -0
- package/dist/cjs/azure/network.js.map +1 -0
- package/dist/cjs/azure/secrets.d.ts +37 -0
- package/dist/cjs/azure/secrets.d.ts.map +1 -0
- package/dist/cjs/azure/secrets.js +150 -0
- package/dist/cjs/azure/secrets.js.map +1 -0
- package/dist/cjs/cache/index.d.ts +7 -0
- package/dist/cjs/cache/index.d.ts.map +1 -0
- package/dist/cjs/cache/index.js +8 -0
- package/dist/cjs/cache/index.js.map +1 -0
- package/dist/cjs/cache/interfaces.d.ts +60 -0
- package/dist/cjs/cache/interfaces.d.ts.map +1 -0
- package/dist/cjs/cache/interfaces.js +11 -0
- package/dist/cjs/cache/interfaces.js.map +1 -0
- package/dist/cjs/cluster/index.d.ts +7 -0
- package/dist/cjs/cluster/index.d.ts.map +1 -0
- package/dist/cjs/cluster/index.js +8 -0
- package/dist/cjs/cluster/index.js.map +1 -0
- package/dist/cjs/cluster/interfaces.d.ts +120 -0
- package/dist/cjs/cluster/interfaces.d.ts.map +1 -0
- package/dist/cjs/cluster/interfaces.js +12 -0
- package/dist/cjs/cluster/interfaces.js.map +1 -0
- package/dist/cjs/database/index.d.ts +7 -0
- package/dist/cjs/database/index.d.ts.map +1 -0
- package/dist/cjs/database/index.js +8 -0
- package/dist/cjs/database/index.js.map +1 -0
- package/dist/cjs/database/interfaces.d.ts +93 -0
- package/dist/cjs/database/interfaces.d.ts.map +1 -0
- package/dist/cjs/database/interfaces.js +12 -0
- package/dist/cjs/database/interfaces.js.map +1 -0
- package/dist/cjs/dns/index.d.ts +7 -0
- package/dist/cjs/dns/index.d.ts.map +1 -0
- package/dist/cjs/dns/index.js +8 -0
- package/dist/cjs/dns/index.js.map +1 -0
- package/dist/cjs/dns/interfaces.d.ts +55 -0
- package/dist/cjs/dns/interfaces.d.ts.map +1 -0
- package/dist/cjs/dns/interfaces.js +11 -0
- package/dist/cjs/dns/interfaces.js.map +1 -0
- package/dist/cjs/factories/cluster.d.ts +45 -0
- package/dist/cjs/factories/cluster.d.ts.map +1 -0
- package/dist/cjs/factories/cluster.js +90 -0
- package/dist/cjs/factories/cluster.js.map +1 -0
- package/dist/cjs/factories/dns.d.ts +30 -0
- package/dist/cjs/factories/dns.d.ts.map +1 -0
- package/dist/cjs/factories/dns.js +56 -0
- package/dist/cjs/factories/dns.js.map +1 -0
- package/dist/cjs/factories/index.d.ts +15 -0
- package/dist/cjs/factories/index.d.ts.map +1 -0
- package/dist/cjs/factories/index.js +23 -0
- package/dist/cjs/factories/index.js.map +1 -0
- package/dist/cjs/factories/network.d.ts +40 -0
- package/dist/cjs/factories/network.d.ts.map +1 -0
- package/dist/cjs/factories/network.js +85 -0
- package/dist/cjs/factories/network.js.map +1 -0
- package/dist/cjs/factories/secrets.d.ts +38 -0
- package/dist/cjs/factories/secrets.d.ts.map +1 -0
- package/dist/cjs/factories/secrets.js +67 -0
- package/dist/cjs/factories/secrets.js.map +1 -0
- package/dist/cjs/factories/types.d.ts +75 -0
- package/dist/cjs/factories/types.d.ts.map +1 -0
- package/dist/cjs/factories/types.js +28 -0
- package/dist/cjs/factories/types.js.map +1 -0
- package/dist/cjs/global-lb/glb.d.ts +29 -0
- package/dist/cjs/global-lb/glb.d.ts.map +1 -0
- package/dist/cjs/global-lb/glb.js +220 -0
- package/dist/cjs/global-lb/glb.js.map +1 -0
- package/dist/cjs/global-lb/index.d.ts +8 -0
- package/dist/cjs/global-lb/index.d.ts.map +1 -0
- package/dist/cjs/global-lb/index.js +11 -0
- package/dist/cjs/global-lb/index.js.map +1 -0
- package/dist/cjs/global-lb/interfaces.d.ts +62 -0
- package/dist/cjs/global-lb/interfaces.d.ts.map +1 -0
- package/dist/cjs/global-lb/interfaces.js +11 -0
- package/dist/cjs/global-lb/interfaces.js.map +1 -0
- package/dist/cjs/index.d.ts +28 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +72 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/network/cidr.d.ts +92 -0
- package/dist/cjs/network/cidr.d.ts.map +1 -0
- package/dist/cjs/network/cidr.js +189 -0
- package/dist/cjs/network/cidr.js.map +1 -0
- package/dist/cjs/network/index.d.ts +8 -0
- package/dist/cjs/network/index.d.ts.map +1 -0
- package/dist/cjs/network/index.js +17 -0
- package/dist/cjs/network/index.js.map +1 -0
- package/dist/cjs/network/interfaces.d.ts +60 -0
- package/dist/cjs/network/interfaces.d.ts.map +1 -0
- package/dist/cjs/network/interfaces.js +12 -0
- package/dist/cjs/network/interfaces.js.map +1 -0
- package/dist/cjs/platform/index.d.ts +8 -0
- package/dist/cjs/platform/index.d.ts.map +1 -0
- package/dist/cjs/platform/index.js +11 -0
- package/dist/cjs/platform/index.js.map +1 -0
- package/dist/cjs/platform/interfaces.d.ts +86 -0
- package/dist/cjs/platform/interfaces.d.ts.map +1 -0
- package/dist/cjs/platform/interfaces.js +12 -0
- package/dist/cjs/platform/interfaces.js.map +1 -0
- package/dist/cjs/platform/stack.d.ts +32 -0
- package/dist/cjs/platform/stack.d.ts.map +1 -0
- package/dist/cjs/platform/stack.js +258 -0
- package/dist/cjs/platform/stack.js.map +1 -0
- package/dist/cjs/queue/index.d.ts +7 -0
- package/dist/cjs/queue/index.d.ts.map +1 -0
- package/dist/cjs/queue/index.js +8 -0
- package/dist/cjs/queue/index.js.map +1 -0
- package/dist/cjs/queue/interfaces.d.ts +46 -0
- package/dist/cjs/queue/interfaces.d.ts.map +1 -0
- package/dist/cjs/queue/interfaces.js +11 -0
- package/dist/cjs/queue/interfaces.js.map +1 -0
- package/dist/cjs/secrets/index.d.ts +7 -0
- package/dist/cjs/secrets/index.d.ts.map +1 -0
- package/dist/cjs/secrets/index.js +8 -0
- package/dist/cjs/secrets/index.js.map +1 -0
- package/dist/cjs/secrets/interfaces.d.ts +73 -0
- package/dist/cjs/secrets/interfaces.d.ts.map +1 -0
- package/dist/cjs/secrets/interfaces.js +11 -0
- package/dist/cjs/secrets/interfaces.js.map +1 -0
- package/dist/cjs/storage/index.d.ts +7 -0
- package/dist/cjs/storage/index.d.ts.map +1 -0
- package/dist/cjs/storage/index.js +8 -0
- package/dist/cjs/storage/index.js.map +1 -0
- package/dist/cjs/storage/interfaces.d.ts +63 -0
- package/dist/cjs/storage/interfaces.d.ts.map +1 -0
- package/dist/cjs/storage/interfaces.js +11 -0
- package/dist/cjs/storage/interfaces.js.map +1 -0
- package/dist/cjs/types/cloud-target.d.ts +89 -0
- package/dist/cjs/types/cloud-target.d.ts.map +1 -0
- package/dist/cjs/types/cloud-target.js +73 -0
- package/dist/cjs/types/cloud-target.js.map +1 -0
- package/dist/cjs/types/errors.d.ts +96 -0
- package/dist/cjs/types/errors.d.ts.map +1 -0
- package/dist/cjs/types/errors.js +127 -0
- package/dist/cjs/types/errors.js.map +1 -0
- package/dist/cjs/types/index.d.ts +10 -0
- package/dist/cjs/types/index.d.ts.map +1 -0
- package/dist/cjs/types/index.js +33 -0
- package/dist/cjs/types/index.js.map +1 -0
- package/dist/cjs/types/tags.d.ts +53 -0
- package/dist/cjs/types/tags.d.ts.map +1 -0
- package/dist/cjs/types/tags.js +110 -0
- package/dist/cjs/types/tags.js.map +1 -0
- package/dist/cjs/types/validation.d.ts +63 -0
- package/dist/cjs/types/validation.d.ts.map +1 -0
- package/dist/cjs/types/validation.js +158 -0
- package/dist/cjs/types/validation.js.map +1 -0
- package/dist/esm/aws/cluster.d.ts +32 -0
- package/dist/esm/aws/cluster.d.ts.map +1 -0
- package/dist/esm/aws/cluster.js +214 -0
- package/dist/esm/aws/cluster.js.map +1 -0
- package/dist/esm/aws/dns.d.ts +22 -0
- package/dist/esm/aws/dns.d.ts.map +1 -0
- package/dist/esm/aws/dns.js +95 -0
- package/dist/esm/aws/dns.js.map +1 -0
- package/dist/esm/aws/index.d.ts +10 -0
- package/dist/esm/aws/index.d.ts.map +1 -0
- package/dist/esm/aws/index.js +17 -0
- package/dist/esm/aws/index.js.map +1 -0
- package/dist/esm/aws/network.d.ts +27 -0
- package/dist/esm/aws/network.d.ts.map +1 -0
- package/dist/esm/aws/network.js +262 -0
- package/dist/esm/aws/network.js.map +1 -0
- package/dist/esm/aws/secrets.d.ts +26 -0
- package/dist/esm/aws/secrets.d.ts.map +1 -0
- package/dist/esm/aws/secrets.js +127 -0
- package/dist/esm/aws/secrets.js.map +1 -0
- package/dist/esm/azure/cluster.d.ts +44 -0
- package/dist/esm/azure/cluster.d.ts.map +1 -0
- package/dist/esm/azure/cluster.js +143 -0
- package/dist/esm/azure/cluster.js.map +1 -0
- package/dist/esm/azure/dns.d.ts +28 -0
- package/dist/esm/azure/dns.d.ts.map +1 -0
- package/dist/esm/azure/dns.js +169 -0
- package/dist/esm/azure/dns.js.map +1 -0
- package/dist/esm/azure/index.d.ts +10 -0
- package/dist/esm/azure/index.d.ts.map +1 -0
- package/dist/esm/azure/index.js +17 -0
- package/dist/esm/azure/index.js.map +1 -0
- package/dist/esm/azure/network.d.ts +28 -0
- package/dist/esm/azure/network.d.ts.map +1 -0
- package/dist/esm/azure/network.js +176 -0
- package/dist/esm/azure/network.js.map +1 -0
- package/dist/esm/azure/secrets.d.ts +37 -0
- package/dist/esm/azure/secrets.d.ts.map +1 -0
- package/dist/esm/azure/secrets.js +150 -0
- package/dist/esm/azure/secrets.js.map +1 -0
- package/dist/esm/cache/index.d.ts +7 -0
- package/dist/esm/cache/index.d.ts.map +1 -0
- package/dist/esm/cache/index.js +8 -0
- package/dist/esm/cache/index.js.map +1 -0
- package/dist/esm/cache/interfaces.d.ts +60 -0
- package/dist/esm/cache/interfaces.d.ts.map +1 -0
- package/dist/esm/cache/interfaces.js +11 -0
- package/dist/esm/cache/interfaces.js.map +1 -0
- package/dist/esm/cluster/index.d.ts +7 -0
- package/dist/esm/cluster/index.d.ts.map +1 -0
- package/dist/esm/cluster/index.js +8 -0
- package/dist/esm/cluster/index.js.map +1 -0
- package/dist/esm/cluster/interfaces.d.ts +120 -0
- package/dist/esm/cluster/interfaces.d.ts.map +1 -0
- package/dist/esm/cluster/interfaces.js +12 -0
- package/dist/esm/cluster/interfaces.js.map +1 -0
- package/dist/esm/database/index.d.ts +7 -0
- package/dist/esm/database/index.d.ts.map +1 -0
- package/dist/esm/database/index.js +8 -0
- package/dist/esm/database/index.js.map +1 -0
- package/dist/esm/database/interfaces.d.ts +93 -0
- package/dist/esm/database/interfaces.d.ts.map +1 -0
- package/dist/esm/database/interfaces.js +12 -0
- package/dist/esm/database/interfaces.js.map +1 -0
- package/dist/esm/dns/index.d.ts +7 -0
- package/dist/esm/dns/index.d.ts.map +1 -0
- package/dist/esm/dns/index.js +8 -0
- package/dist/esm/dns/index.js.map +1 -0
- package/dist/esm/dns/interfaces.d.ts +55 -0
- package/dist/esm/dns/interfaces.d.ts.map +1 -0
- package/dist/esm/dns/interfaces.js +11 -0
- package/dist/esm/dns/interfaces.js.map +1 -0
- package/dist/esm/factories/cluster.d.ts +45 -0
- package/dist/esm/factories/cluster.d.ts.map +1 -0
- package/dist/esm/factories/cluster.js +90 -0
- package/dist/esm/factories/cluster.js.map +1 -0
- package/dist/esm/factories/dns.d.ts +30 -0
- package/dist/esm/factories/dns.d.ts.map +1 -0
- package/dist/esm/factories/dns.js +56 -0
- package/dist/esm/factories/dns.js.map +1 -0
- package/dist/esm/factories/index.d.ts +15 -0
- package/dist/esm/factories/index.d.ts.map +1 -0
- package/dist/esm/factories/index.js +23 -0
- package/dist/esm/factories/index.js.map +1 -0
- package/dist/esm/factories/network.d.ts +40 -0
- package/dist/esm/factories/network.d.ts.map +1 -0
- package/dist/esm/factories/network.js +85 -0
- package/dist/esm/factories/network.js.map +1 -0
- package/dist/esm/factories/secrets.d.ts +38 -0
- package/dist/esm/factories/secrets.d.ts.map +1 -0
- package/dist/esm/factories/secrets.js +67 -0
- package/dist/esm/factories/secrets.js.map +1 -0
- package/dist/esm/factories/types.d.ts +75 -0
- package/dist/esm/factories/types.d.ts.map +1 -0
- package/dist/esm/factories/types.js +28 -0
- package/dist/esm/factories/types.js.map +1 -0
- package/dist/esm/global-lb/glb.d.ts +29 -0
- package/dist/esm/global-lb/glb.d.ts.map +1 -0
- package/dist/esm/global-lb/glb.js +220 -0
- package/dist/esm/global-lb/glb.js.map +1 -0
- package/dist/esm/global-lb/index.d.ts +8 -0
- package/dist/esm/global-lb/index.d.ts.map +1 -0
- package/dist/esm/global-lb/index.js +11 -0
- package/dist/esm/global-lb/index.js.map +1 -0
- package/dist/esm/global-lb/interfaces.d.ts +62 -0
- package/dist/esm/global-lb/interfaces.d.ts.map +1 -0
- package/dist/esm/global-lb/interfaces.js +11 -0
- package/dist/esm/global-lb/interfaces.js.map +1 -0
- package/dist/esm/index.d.ts +28 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +72 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/network/cidr.d.ts +92 -0
- package/dist/esm/network/cidr.d.ts.map +1 -0
- package/dist/esm/network/cidr.js +189 -0
- package/dist/esm/network/cidr.js.map +1 -0
- package/dist/esm/network/index.d.ts +8 -0
- package/dist/esm/network/index.d.ts.map +1 -0
- package/dist/esm/network/index.js +17 -0
- package/dist/esm/network/index.js.map +1 -0
- package/dist/esm/network/interfaces.d.ts +60 -0
- package/dist/esm/network/interfaces.d.ts.map +1 -0
- package/dist/esm/network/interfaces.js +12 -0
- package/dist/esm/network/interfaces.js.map +1 -0
- package/dist/esm/platform/index.d.ts +8 -0
- package/dist/esm/platform/index.d.ts.map +1 -0
- package/dist/esm/platform/index.js +11 -0
- package/dist/esm/platform/index.js.map +1 -0
- package/dist/esm/platform/interfaces.d.ts +86 -0
- package/dist/esm/platform/interfaces.d.ts.map +1 -0
- package/dist/esm/platform/interfaces.js +12 -0
- package/dist/esm/platform/interfaces.js.map +1 -0
- package/dist/esm/platform/stack.d.ts +32 -0
- package/dist/esm/platform/stack.d.ts.map +1 -0
- package/dist/esm/platform/stack.js +258 -0
- package/dist/esm/platform/stack.js.map +1 -0
- package/dist/esm/queue/index.d.ts +7 -0
- package/dist/esm/queue/index.d.ts.map +1 -0
- package/dist/esm/queue/index.js +8 -0
- package/dist/esm/queue/index.js.map +1 -0
- package/dist/esm/queue/interfaces.d.ts +46 -0
- package/dist/esm/queue/interfaces.d.ts.map +1 -0
- package/dist/esm/queue/interfaces.js +11 -0
- package/dist/esm/queue/interfaces.js.map +1 -0
- package/dist/esm/secrets/index.d.ts +7 -0
- package/dist/esm/secrets/index.d.ts.map +1 -0
- package/dist/esm/secrets/index.js +8 -0
- package/dist/esm/secrets/index.js.map +1 -0
- package/dist/esm/secrets/interfaces.d.ts +73 -0
- package/dist/esm/secrets/interfaces.d.ts.map +1 -0
- package/dist/esm/secrets/interfaces.js +11 -0
- package/dist/esm/secrets/interfaces.js.map +1 -0
- package/dist/esm/storage/index.d.ts +7 -0
- package/dist/esm/storage/index.d.ts.map +1 -0
- package/dist/esm/storage/index.js +8 -0
- package/dist/esm/storage/index.js.map +1 -0
- package/dist/esm/storage/interfaces.d.ts +63 -0
- package/dist/esm/storage/interfaces.d.ts.map +1 -0
- package/dist/esm/storage/interfaces.js +11 -0
- package/dist/esm/storage/interfaces.js.map +1 -0
- package/dist/esm/types/cloud-target.d.ts +89 -0
- package/dist/esm/types/cloud-target.d.ts.map +1 -0
- package/dist/esm/types/cloud-target.js +73 -0
- package/dist/esm/types/cloud-target.js.map +1 -0
- package/dist/esm/types/errors.d.ts +96 -0
- package/dist/esm/types/errors.d.ts.map +1 -0
- package/dist/esm/types/errors.js +127 -0
- package/dist/esm/types/errors.js.map +1 -0
- package/dist/esm/types/index.d.ts +10 -0
- package/dist/esm/types/index.d.ts.map +1 -0
- package/dist/esm/types/index.js +33 -0
- package/dist/esm/types/index.js.map +1 -0
- package/dist/esm/types/tags.d.ts +53 -0
- package/dist/esm/types/tags.d.ts.map +1 -0
- package/dist/esm/types/tags.js +110 -0
- package/dist/esm/types/tags.js.map +1 -0
- package/dist/esm/types/validation.d.ts +63 -0
- package/dist/esm/types/validation.d.ts.map +1 -0
- package/dist/esm/types/validation.js +158 -0
- package/dist/esm/types/validation.js.map +1 -0
- package/package.json +88 -0
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure AKS cluster implementation.
|
|
3
|
+
*
|
|
4
|
+
* Supports system + user node pools, spot instances, and
|
|
5
|
+
* Azure Container Instances virtual node.
|
|
6
|
+
*
|
|
7
|
+
* @module azure/cluster
|
|
8
|
+
*/
|
|
9
|
+
import type * as pulumi from "@pulumi/pulumi";
|
|
10
|
+
import type { ICluster, IClusterConfig } from "../cluster";
|
|
11
|
+
import type { INetwork } from "../network";
|
|
12
|
+
/** Azure-specific AKS options beyond the base config. */
|
|
13
|
+
export interface IAksOptions {
|
|
14
|
+
/** Resource group name. Required for Azure. */
|
|
15
|
+
readonly resourceGroupName: pulumi.Input<string>;
|
|
16
|
+
/** Enable Azure CNI networking (vs kubenet). Default: true. */
|
|
17
|
+
readonly azureCni?: boolean;
|
|
18
|
+
/** Enable virtual node (ACI). Default: false. */
|
|
19
|
+
readonly virtualNodes?: boolean;
|
|
20
|
+
/** Azure AD tenant ID for RBAC integration. */
|
|
21
|
+
readonly aadTenantId?: string;
|
|
22
|
+
/** DNS prefix for the cluster FQDN. Default: cluster name. */
|
|
23
|
+
readonly dnsPrefix?: string;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Create an AKS cluster with system + user node pools.
|
|
27
|
+
*
|
|
28
|
+
* @example
|
|
29
|
+
* ```typescript
|
|
30
|
+
* const cluster = createAksCluster("prod", {
|
|
31
|
+
* cloud: "azure",
|
|
32
|
+
* version: "1.32",
|
|
33
|
+
* nodePools: [
|
|
34
|
+
* { name: "system", instanceType: "Standard_D2pds_v6", minNodes: 2, maxNodes: 5, mode: "system" },
|
|
35
|
+
* { name: "workers", instanceType: "Standard_D2pds_v6", minNodes: 2, maxNodes: 8, spot: true },
|
|
36
|
+
* ],
|
|
37
|
+
* }, network, {
|
|
38
|
+
* resourceGroupName: "my-rg",
|
|
39
|
+
* virtualNodes: true,
|
|
40
|
+
* });
|
|
41
|
+
* ```
|
|
42
|
+
*/
|
|
43
|
+
export declare function createAksCluster(name: string, config: IClusterConfig, network: INetwork, options: IAksOptions): ICluster;
|
|
44
|
+
//# sourceMappingURL=cluster.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cluster.d.ts","sourceRoot":"","sources":["../../../src/azure/cluster.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAIH,OAAO,KAAK,KAAK,MAAM,MAAM,gBAAgB,CAAC;AAC9C,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAC3D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAG3C,yDAAyD;AACzD,MAAM,WAAW,WAAW;IAC1B,+CAA+C;IAC/C,QAAQ,CAAC,iBAAiB,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACjD,+DAA+D;IAC/D,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;IAC5B,iDAAiD;IACjD,QAAQ,CAAC,YAAY,CAAC,EAAE,OAAO,CAAC;IAChC,+CAA+C;IAC/C,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC;IAC9B,8DAA8D;IAC9D,QAAQ,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC;CAC7B;AAED;;;;;;;;;;;;;;;;;GAiBG;AACH,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,QAAQ,EACjB,OAAO,EAAE,WAAW,GACnB,QAAQ,CAqFV"}
|
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure AKS cluster implementation.
|
|
4
|
+
*
|
|
5
|
+
* Supports system + user node pools, spot instances, and
|
|
6
|
+
* Azure Container Instances virtual node.
|
|
7
|
+
*
|
|
8
|
+
* @module azure/cluster
|
|
9
|
+
*/
|
|
10
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
11
|
+
if (k2 === undefined) k2 = k;
|
|
12
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
13
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
14
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
15
|
+
}
|
|
16
|
+
Object.defineProperty(o, k2, desc);
|
|
17
|
+
}) : (function(o, m, k, k2) {
|
|
18
|
+
if (k2 === undefined) k2 = k;
|
|
19
|
+
o[k2] = m[k];
|
|
20
|
+
}));
|
|
21
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
22
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
23
|
+
}) : function(o, v) {
|
|
24
|
+
o["default"] = v;
|
|
25
|
+
});
|
|
26
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
27
|
+
var ownKeys = function(o) {
|
|
28
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
29
|
+
var ar = [];
|
|
30
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
31
|
+
return ar;
|
|
32
|
+
};
|
|
33
|
+
return ownKeys(o);
|
|
34
|
+
};
|
|
35
|
+
return function (mod) {
|
|
36
|
+
if (mod && mod.__esModule) return mod;
|
|
37
|
+
var result = {};
|
|
38
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
39
|
+
__setModuleDefault(result, mod);
|
|
40
|
+
return result;
|
|
41
|
+
};
|
|
42
|
+
})();
|
|
43
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
44
|
+
exports.createAksCluster = createAksCluster;
|
|
45
|
+
const azure = __importStar(require("@pulumi/azure-native"));
|
|
46
|
+
const k8s = __importStar(require("@pulumi/kubernetes"));
|
|
47
|
+
const types_1 = require("../types");
|
|
48
|
+
/**
|
|
49
|
+
* Create an AKS cluster with system + user node pools.
|
|
50
|
+
*
|
|
51
|
+
* @example
|
|
52
|
+
* ```typescript
|
|
53
|
+
* const cluster = createAksCluster("prod", {
|
|
54
|
+
* cloud: "azure",
|
|
55
|
+
* version: "1.32",
|
|
56
|
+
* nodePools: [
|
|
57
|
+
* { name: "system", instanceType: "Standard_D2pds_v6", minNodes: 2, maxNodes: 5, mode: "system" },
|
|
58
|
+
* { name: "workers", instanceType: "Standard_D2pds_v6", minNodes: 2, maxNodes: 8, spot: true },
|
|
59
|
+
* ],
|
|
60
|
+
* }, network, {
|
|
61
|
+
* resourceGroupName: "my-rg",
|
|
62
|
+
* virtualNodes: true,
|
|
63
|
+
* });
|
|
64
|
+
* ```
|
|
65
|
+
*/
|
|
66
|
+
function createAksCluster(name, config, network, options) {
|
|
67
|
+
const cloud = Array.isArray(config.cloud) ? (config.cloud[0] ?? "azure") : config.cloud;
|
|
68
|
+
const target = (0, types_1.resolveCloudTarget)(cloud);
|
|
69
|
+
const tags = config.tags ?? {};
|
|
70
|
+
const rgName = options.resourceGroupName;
|
|
71
|
+
const dnsPrefix = options.dnsPrefix ?? name;
|
|
72
|
+
const enableVirtualNodes = options.virtualNodes ?? config.virtualNodes ?? false;
|
|
73
|
+
// Build agent pool profiles from node pool config
|
|
74
|
+
const agentPoolProfiles = config.nodePools.map((np) => ({
|
|
75
|
+
name: np.name.substring(0, 12), // AKS pool names max 12 chars
|
|
76
|
+
vmSize: np.instanceType,
|
|
77
|
+
count: np.desiredNodes ?? np.minNodes,
|
|
78
|
+
minCount: np.minNodes,
|
|
79
|
+
maxCount: np.maxNodes,
|
|
80
|
+
enableAutoScaling: true,
|
|
81
|
+
mode: (np.mode ?? "User"),
|
|
82
|
+
osType: "Linux",
|
|
83
|
+
osDiskSizeGB: 128,
|
|
84
|
+
vnetSubnetId: network.privateSubnetIds.apply((ids) => ids[0] ?? ""),
|
|
85
|
+
scaleSetPriority: np.spot ? "Spot" : "Regular",
|
|
86
|
+
scaleSetEvictionPolicy: np.spot ? "Delete" : undefined,
|
|
87
|
+
spotMaxPrice: np.spot ? -1 : undefined,
|
|
88
|
+
nodeTaints: np.taints?.map((t) => `${t.key}=${t.value}:${t.effect}`) ?? [],
|
|
89
|
+
nodeLabels: np.labels ?? {},
|
|
90
|
+
type: "VirtualMachineScaleSets",
|
|
91
|
+
}));
|
|
92
|
+
// AKS add-on profiles
|
|
93
|
+
const addonProfiles = {};
|
|
94
|
+
if (enableVirtualNodes) {
|
|
95
|
+
addonProfiles["aciConnectorLinux"] = {
|
|
96
|
+
enabled: true,
|
|
97
|
+
config: {
|
|
98
|
+
SubnetName: "aci-subnet",
|
|
99
|
+
},
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
const cluster = new azure.containerservice.ManagedCluster(`${name}-aks`, {
|
|
103
|
+
resourceName: name,
|
|
104
|
+
resourceGroupName: rgName,
|
|
105
|
+
dnsPrefix,
|
|
106
|
+
kubernetesVersion: config.version,
|
|
107
|
+
agentPoolProfiles,
|
|
108
|
+
identity: { type: "SystemAssigned" },
|
|
109
|
+
networkProfile: {
|
|
110
|
+
networkPlugin: options.azureCni !== false ? "azure" : "kubenet",
|
|
111
|
+
serviceCidr: "10.240.0.0/16",
|
|
112
|
+
dnsServiceIP: "10.240.0.10",
|
|
113
|
+
},
|
|
114
|
+
addonProfiles,
|
|
115
|
+
tags: { ...tags, Name: name },
|
|
116
|
+
});
|
|
117
|
+
// Build kubeconfig from AKS cluster credentials
|
|
118
|
+
const creds = azure.containerservice.listManagedClusterUserCredentialsOutput({
|
|
119
|
+
resourceGroupName: rgName,
|
|
120
|
+
resourceName: cluster.name,
|
|
121
|
+
});
|
|
122
|
+
const kubeconfig = creds.kubeconfigs.apply((configs) => {
|
|
123
|
+
const kc = configs[0];
|
|
124
|
+
if (!kc?.value) {
|
|
125
|
+
return "";
|
|
126
|
+
}
|
|
127
|
+
return Buffer.from(kc.value, "base64").toString("utf-8");
|
|
128
|
+
});
|
|
129
|
+
const provider = new k8s.Provider(`${name}-k8s`, {
|
|
130
|
+
kubeconfig,
|
|
131
|
+
});
|
|
132
|
+
return {
|
|
133
|
+
name,
|
|
134
|
+
cloud: target,
|
|
135
|
+
endpoint: cluster.fqdn.apply((fqdn) => `https://${fqdn ?? ""}`),
|
|
136
|
+
kubeconfig,
|
|
137
|
+
version: cluster.kubernetesVersion.apply((v) => v ?? ""),
|
|
138
|
+
nodePools: config.nodePools,
|
|
139
|
+
nativeResource: cluster,
|
|
140
|
+
provider,
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
//# sourceMappingURL=cluster.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"cluster.js","sourceRoot":"","sources":["../../../src/azure/cluster.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure DNS Zone implementation.
|
|
3
|
+
*
|
|
4
|
+
* @module azure/dns
|
|
5
|
+
*/
|
|
6
|
+
import type * as pulumi from "@pulumi/pulumi";
|
|
7
|
+
import type { IDns, IDnsConfig } from "../dns";
|
|
8
|
+
/** Azure-specific DNS options. */
|
|
9
|
+
export interface IAzureDnsOptions {
|
|
10
|
+
/** Resource group name. Required for Azure. */
|
|
11
|
+
readonly resourceGroupName: pulumi.Input<string>;
|
|
12
|
+
}
|
|
13
|
+
/**
|
|
14
|
+
* Create an Azure DNS Zone with optional initial records.
|
|
15
|
+
*
|
|
16
|
+
* @example
|
|
17
|
+
* ```typescript
|
|
18
|
+
* const dns = createAzureDns("prod", {
|
|
19
|
+
* cloud: "azure",
|
|
20
|
+
* zoneName: "metrixgroup.com",
|
|
21
|
+
* records: [
|
|
22
|
+
* { name: "app", type: "A", values: ["1.2.3.4"], ttl: 300 },
|
|
23
|
+
* ],
|
|
24
|
+
* }, { resourceGroupName: "my-rg" });
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare function createAzureDns(name: string, config: IDnsConfig, options: IAzureDnsOptions): IDns;
|
|
28
|
+
//# sourceMappingURL=dns.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dns.d.ts","sourceRoot":"","sources":["../../../src/azure/dns.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,KAAK,MAAM,MAAM,gBAAgB,CAAC;AAC9C,OAAO,KAAK,EAAE,IAAI,EAAE,UAAU,EAAc,MAAM,QAAQ,CAAC;AAG3D,kCAAkC;AAClC,MAAM,WAAW,gBAAgB;IAC/B,+CAA+C;IAC/C,QAAQ,CAAC,iBAAiB,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;CAClD;AAED;;;;;;;;;;;;;GAaG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,OAAO,EAAE,gBAAgB,GAAG,IAAI,CAgChG"}
|
|
@@ -0,0 +1,169 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure DNS Zone implementation.
|
|
4
|
+
*
|
|
5
|
+
* @module azure/dns
|
|
6
|
+
*/
|
|
7
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
8
|
+
if (k2 === undefined) k2 = k;
|
|
9
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
10
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
11
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
12
|
+
}
|
|
13
|
+
Object.defineProperty(o, k2, desc);
|
|
14
|
+
}) : (function(o, m, k, k2) {
|
|
15
|
+
if (k2 === undefined) k2 = k;
|
|
16
|
+
o[k2] = m[k];
|
|
17
|
+
}));
|
|
18
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
19
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
20
|
+
}) : function(o, v) {
|
|
21
|
+
o["default"] = v;
|
|
22
|
+
});
|
|
23
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
24
|
+
var ownKeys = function(o) {
|
|
25
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
26
|
+
var ar = [];
|
|
27
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
28
|
+
return ar;
|
|
29
|
+
};
|
|
30
|
+
return ownKeys(o);
|
|
31
|
+
};
|
|
32
|
+
return function (mod) {
|
|
33
|
+
if (mod && mod.__esModule) return mod;
|
|
34
|
+
var result = {};
|
|
35
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
36
|
+
__setModuleDefault(result, mod);
|
|
37
|
+
return result;
|
|
38
|
+
};
|
|
39
|
+
})();
|
|
40
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
41
|
+
exports.createAzureDns = createAzureDns;
|
|
42
|
+
const azure = __importStar(require("@pulumi/azure-native"));
|
|
43
|
+
const types_1 = require("../types");
|
|
44
|
+
/**
|
|
45
|
+
* Create an Azure DNS Zone with optional initial records.
|
|
46
|
+
*
|
|
47
|
+
* @example
|
|
48
|
+
* ```typescript
|
|
49
|
+
* const dns = createAzureDns("prod", {
|
|
50
|
+
* cloud: "azure",
|
|
51
|
+
* zoneName: "metrixgroup.com",
|
|
52
|
+
* records: [
|
|
53
|
+
* { name: "app", type: "A", values: ["1.2.3.4"], ttl: 300 },
|
|
54
|
+
* ],
|
|
55
|
+
* }, { resourceGroupName: "my-rg" });
|
|
56
|
+
* ```
|
|
57
|
+
*/
|
|
58
|
+
function createAzureDns(name, config, options) {
|
|
59
|
+
const cloud = Array.isArray(config.cloud) ? (config.cloud[0] ?? "azure") : config.cloud;
|
|
60
|
+
const target = (0, types_1.resolveCloudTarget)(cloud);
|
|
61
|
+
const tags = config.tags ?? {};
|
|
62
|
+
const rgName = options.resourceGroupName;
|
|
63
|
+
const zone = new azure.dns.Zone(`${name}-zone`, {
|
|
64
|
+
zoneName: config.zoneName,
|
|
65
|
+
resourceGroupName: rgName,
|
|
66
|
+
zoneType: azure.dns.ZoneType.Public,
|
|
67
|
+
location: "global",
|
|
68
|
+
tags: { ...tags, Name: `${name}-zone` },
|
|
69
|
+
});
|
|
70
|
+
if (config.records) {
|
|
71
|
+
for (const rec of config.records) {
|
|
72
|
+
createRecord(name, rgName, config.zoneName, rec);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
return {
|
|
76
|
+
name,
|
|
77
|
+
cloud: target,
|
|
78
|
+
zoneId: zone.id,
|
|
79
|
+
zoneName: config.zoneName,
|
|
80
|
+
nameServers: zone.nameServers,
|
|
81
|
+
nativeResource: zone,
|
|
82
|
+
addRecord(record) {
|
|
83
|
+
createRecord(name, rgName, config.zoneName, record);
|
|
84
|
+
},
|
|
85
|
+
};
|
|
86
|
+
}
|
|
87
|
+
function createRecord(name, rgName, zoneName, record) {
|
|
88
|
+
const recordName = record.name === "@" ? "@" : record.name;
|
|
89
|
+
const resourceName = `${name}-${record.name || "root"}-${record.type.toLowerCase()}`;
|
|
90
|
+
const ttl = record.ttl ?? 300;
|
|
91
|
+
switch (record.type) {
|
|
92
|
+
case "A":
|
|
93
|
+
new azure.dns.RecordSet(resourceName, {
|
|
94
|
+
relativeRecordSetName: recordName,
|
|
95
|
+
resourceGroupName: rgName,
|
|
96
|
+
zoneName,
|
|
97
|
+
recordType: "A",
|
|
98
|
+
ttl,
|
|
99
|
+
aRecords: record.values.map((v) => ({ ipv4Address: v })),
|
|
100
|
+
});
|
|
101
|
+
break;
|
|
102
|
+
case "AAAA":
|
|
103
|
+
new azure.dns.RecordSet(resourceName, {
|
|
104
|
+
relativeRecordSetName: recordName,
|
|
105
|
+
resourceGroupName: rgName,
|
|
106
|
+
zoneName,
|
|
107
|
+
recordType: "AAAA",
|
|
108
|
+
ttl,
|
|
109
|
+
aaaaRecords: record.values.map((v) => ({ ipv6Address: v })),
|
|
110
|
+
});
|
|
111
|
+
break;
|
|
112
|
+
case "CNAME":
|
|
113
|
+
new azure.dns.RecordSet(resourceName, {
|
|
114
|
+
relativeRecordSetName: recordName,
|
|
115
|
+
resourceGroupName: rgName,
|
|
116
|
+
zoneName,
|
|
117
|
+
recordType: "CNAME",
|
|
118
|
+
ttl,
|
|
119
|
+
cnameRecord: { cname: record.values[0] ?? "" },
|
|
120
|
+
});
|
|
121
|
+
break;
|
|
122
|
+
case "TXT":
|
|
123
|
+
new azure.dns.RecordSet(resourceName, {
|
|
124
|
+
relativeRecordSetName: recordName,
|
|
125
|
+
resourceGroupName: rgName,
|
|
126
|
+
zoneName,
|
|
127
|
+
recordType: "TXT",
|
|
128
|
+
ttl,
|
|
129
|
+
txtRecords: record.values.map((v) => ({ value: [v] })),
|
|
130
|
+
});
|
|
131
|
+
break;
|
|
132
|
+
case "MX":
|
|
133
|
+
new azure.dns.RecordSet(resourceName, {
|
|
134
|
+
relativeRecordSetName: recordName,
|
|
135
|
+
resourceGroupName: rgName,
|
|
136
|
+
zoneName,
|
|
137
|
+
recordType: "MX",
|
|
138
|
+
ttl,
|
|
139
|
+
mxRecords: record.values.map((v) => {
|
|
140
|
+
const parts = v.split(" ");
|
|
141
|
+
return {
|
|
142
|
+
preference: parseInt(parts[0] ?? "10", 10),
|
|
143
|
+
exchange: parts[1] ?? v,
|
|
144
|
+
};
|
|
145
|
+
}),
|
|
146
|
+
});
|
|
147
|
+
break;
|
|
148
|
+
case "NS":
|
|
149
|
+
new azure.dns.RecordSet(resourceName, {
|
|
150
|
+
relativeRecordSetName: recordName,
|
|
151
|
+
resourceGroupName: rgName,
|
|
152
|
+
zoneName,
|
|
153
|
+
recordType: "NS",
|
|
154
|
+
ttl,
|
|
155
|
+
nsRecords: record.values.map((v) => ({ nsdname: v })),
|
|
156
|
+
});
|
|
157
|
+
break;
|
|
158
|
+
default:
|
|
159
|
+
// SRV, CAA — create record set without type-specific fields
|
|
160
|
+
new azure.dns.RecordSet(resourceName, {
|
|
161
|
+
relativeRecordSetName: recordName,
|
|
162
|
+
resourceGroupName: rgName,
|
|
163
|
+
zoneName,
|
|
164
|
+
recordType: record.type,
|
|
165
|
+
ttl,
|
|
166
|
+
});
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
//# sourceMappingURL=dns.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dns.js","sourceRoot":"","sources":["../../../src/azure/dns.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure provider implementations for @reyemtech/nimbus.
|
|
3
|
+
*
|
|
4
|
+
* @module azure
|
|
5
|
+
*/
|
|
6
|
+
export { createAzureNetwork, type IAzureNetworkOptions } from "./network";
|
|
7
|
+
export { createAksCluster, type IAksOptions } from "./cluster";
|
|
8
|
+
export { createAzureDns, type IAzureDnsOptions } from "./dns";
|
|
9
|
+
export { createAzureSecrets, type IAzureSecretsOptions } from "./secrets";
|
|
10
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/azure/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,kBAAkB,EAAE,KAAK,oBAAoB,EAAE,MAAM,WAAW,CAAC;AAC1E,OAAO,EAAE,gBAAgB,EAAE,KAAK,WAAW,EAAE,MAAM,WAAW,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,KAAK,gBAAgB,EAAE,MAAM,OAAO,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,KAAK,oBAAoB,EAAE,MAAM,WAAW,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure provider implementations for @reyemtech/nimbus.
|
|
4
|
+
*
|
|
5
|
+
* @module azure
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.createAzureSecrets = exports.createAzureDns = exports.createAksCluster = exports.createAzureNetwork = void 0;
|
|
9
|
+
var network_1 = require("./network");
|
|
10
|
+
Object.defineProperty(exports, "createAzureNetwork", { enumerable: true, get: function () { return network_1.createAzureNetwork; } });
|
|
11
|
+
var cluster_1 = require("./cluster");
|
|
12
|
+
Object.defineProperty(exports, "createAksCluster", { enumerable: true, get: function () { return cluster_1.createAksCluster; } });
|
|
13
|
+
var dns_1 = require("./dns");
|
|
14
|
+
Object.defineProperty(exports, "createAzureDns", { enumerable: true, get: function () { return dns_1.createAzureDns; } });
|
|
15
|
+
var secrets_1 = require("./secrets");
|
|
16
|
+
Object.defineProperty(exports, "createAzureSecrets", { enumerable: true, get: function () { return secrets_1.createAzureSecrets; } });
|
|
17
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/azure/index.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;AAEH,qCAA0E;AAAjE,6GAAA,kBAAkB,OAAA;AAC3B,qCAA+D;AAAtD,2GAAA,gBAAgB,OAAA;AACzB,6BAA8D;AAArD,qGAAA,cAAc,OAAA;AACvB,qCAA0E;AAAjE,6GAAA,kBAAkB,OAAA"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure VNet network implementation.
|
|
3
|
+
*
|
|
4
|
+
* @module azure/network
|
|
5
|
+
*/
|
|
6
|
+
import * as pulumi from "@pulumi/pulumi";
|
|
7
|
+
import type { INetwork, INetworkConfig } from "../network";
|
|
8
|
+
/** Azure-specific network options beyond the base config. */
|
|
9
|
+
export interface IAzureNetworkOptions {
|
|
10
|
+
/** Resource group name. Required for Azure. */
|
|
11
|
+
readonly resourceGroupName: pulumi.Input<string>;
|
|
12
|
+
/** Number of subnets per type (public/private). Default: 2. */
|
|
13
|
+
readonly subnetCount?: number;
|
|
14
|
+
}
|
|
15
|
+
/**
|
|
16
|
+
* Create an Azure VNet with subnets and optional NAT Gateway.
|
|
17
|
+
*
|
|
18
|
+
* @example
|
|
19
|
+
* ```typescript
|
|
20
|
+
* const network = createAzureNetwork("prod", {
|
|
21
|
+
* cloud: "azure",
|
|
22
|
+
* cidr: "10.1.0.0/16",
|
|
23
|
+
* natStrategy: "managed",
|
|
24
|
+
* }, { resourceGroupName: "my-rg" });
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export declare function createAzureNetwork(name: string, config: INetworkConfig, options: IAzureNetworkOptions): INetwork;
|
|
28
|
+
//# sourceMappingURL=network.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"network.d.ts","sourceRoot":"","sources":["../../../src/azure/network.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,OAAO,KAAK,MAAM,MAAM,gBAAgB,CAAC;AACzC,OAAO,KAAK,EAAE,QAAQ,EAAE,cAAc,EAAe,MAAM,YAAY,CAAC;AAGxE,6DAA6D;AAC7D,MAAM,WAAW,oBAAoB;IACnC,+CAA+C;IAC/C,QAAQ,CAAC,iBAAiB,EAAE,MAAM,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;IACjD,+DAA+D;IAC/D,QAAQ,CAAC,WAAW,CAAC,EAAE,MAAM,CAAC;CAC/B;AAED;;;;;;;;;;;GAWG;AACH,wBAAgB,kBAAkB,CAChC,IAAI,EAAE,MAAM,EACZ,MAAM,EAAE,cAAc,EACtB,OAAO,EAAE,oBAAoB,GAC5B,QAAQ,CAoIV"}
|
|
@@ -0,0 +1,176 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure VNet network implementation.
|
|
4
|
+
*
|
|
5
|
+
* @module azure/network
|
|
6
|
+
*/
|
|
7
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
8
|
+
if (k2 === undefined) k2 = k;
|
|
9
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
10
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
11
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
12
|
+
}
|
|
13
|
+
Object.defineProperty(o, k2, desc);
|
|
14
|
+
}) : (function(o, m, k, k2) {
|
|
15
|
+
if (k2 === undefined) k2 = k;
|
|
16
|
+
o[k2] = m[k];
|
|
17
|
+
}));
|
|
18
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
19
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
20
|
+
}) : function(o, v) {
|
|
21
|
+
o["default"] = v;
|
|
22
|
+
});
|
|
23
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
24
|
+
var ownKeys = function(o) {
|
|
25
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
26
|
+
var ar = [];
|
|
27
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
28
|
+
return ar;
|
|
29
|
+
};
|
|
30
|
+
return ownKeys(o);
|
|
31
|
+
};
|
|
32
|
+
return function (mod) {
|
|
33
|
+
if (mod && mod.__esModule) return mod;
|
|
34
|
+
var result = {};
|
|
35
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
36
|
+
__setModuleDefault(result, mod);
|
|
37
|
+
return result;
|
|
38
|
+
};
|
|
39
|
+
})();
|
|
40
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
41
|
+
exports.createAzureNetwork = createAzureNetwork;
|
|
42
|
+
const azure = __importStar(require("@pulumi/azure-native"));
|
|
43
|
+
const pulumi = __importStar(require("@pulumi/pulumi"));
|
|
44
|
+
const types_1 = require("../types");
|
|
45
|
+
/**
|
|
46
|
+
* Create an Azure VNet with subnets and optional NAT Gateway.
|
|
47
|
+
*
|
|
48
|
+
* @example
|
|
49
|
+
* ```typescript
|
|
50
|
+
* const network = createAzureNetwork("prod", {
|
|
51
|
+
* cloud: "azure",
|
|
52
|
+
* cidr: "10.1.0.0/16",
|
|
53
|
+
* natStrategy: "managed",
|
|
54
|
+
* }, { resourceGroupName: "my-rg" });
|
|
55
|
+
* ```
|
|
56
|
+
*/
|
|
57
|
+
function createAzureNetwork(name, config, options) {
|
|
58
|
+
const cloud = Array.isArray(config.cloud) ? (config.cloud[0] ?? "azure") : config.cloud;
|
|
59
|
+
const target = (0, types_1.resolveCloudTarget)(cloud);
|
|
60
|
+
const cidr = config.cidr ?? "10.1.0.0/16";
|
|
61
|
+
const subnetCount = options.subnetCount ?? 2;
|
|
62
|
+
const natStrategy = config.natStrategy ?? "managed";
|
|
63
|
+
const tags = config.tags ?? {};
|
|
64
|
+
const rgName = options.resourceGroupName;
|
|
65
|
+
const vnet = new azure.network.VirtualNetwork(`${name}-vnet`, {
|
|
66
|
+
virtualNetworkName: `${name}-vnet`,
|
|
67
|
+
resourceGroupName: rgName,
|
|
68
|
+
addressSpace: { addressPrefixes: [cidr] },
|
|
69
|
+
tags: { ...tags, Name: `${name}-vnet` },
|
|
70
|
+
});
|
|
71
|
+
// Public subnets
|
|
72
|
+
const publicSubnets = [];
|
|
73
|
+
for (let i = 0; i < subnetCount; i++) {
|
|
74
|
+
publicSubnets.push(new azure.network.Subnet(`${name}-public-${i}`, {
|
|
75
|
+
subnetName: `${name}-public-${i}`,
|
|
76
|
+
resourceGroupName: rgName,
|
|
77
|
+
virtualNetworkName: vnet.name,
|
|
78
|
+
addressPrefix: `${cidr.split(".").slice(0, 2).join(".")}.${i + 1}.0/24`,
|
|
79
|
+
}));
|
|
80
|
+
}
|
|
81
|
+
// Private subnets
|
|
82
|
+
const privateSubnets = [];
|
|
83
|
+
for (let i = 0; i < subnetCount; i++) {
|
|
84
|
+
const subnet = new azure.network.Subnet(`${name}-private-${i}`, {
|
|
85
|
+
subnetName: `${name}-private-${i}`,
|
|
86
|
+
resourceGroupName: rgName,
|
|
87
|
+
virtualNetworkName: vnet.name,
|
|
88
|
+
addressPrefix: `${cidr.split(".").slice(0, 2).join(".")}.${i + 10}.0/24`,
|
|
89
|
+
});
|
|
90
|
+
privateSubnets.push(subnet);
|
|
91
|
+
}
|
|
92
|
+
// NSG for private subnets
|
|
93
|
+
const nsg = new azure.network.NetworkSecurityGroup(`${name}-private-nsg`, {
|
|
94
|
+
networkSecurityGroupName: `${name}-private-nsg`,
|
|
95
|
+
resourceGroupName: rgName,
|
|
96
|
+
securityRules: [
|
|
97
|
+
{
|
|
98
|
+
name: "AllowVNetInbound",
|
|
99
|
+
priority: 100,
|
|
100
|
+
direction: "Inbound",
|
|
101
|
+
access: "Allow",
|
|
102
|
+
protocol: "*",
|
|
103
|
+
sourceAddressPrefix: "VirtualNetwork",
|
|
104
|
+
sourcePortRange: "*",
|
|
105
|
+
destinationAddressPrefix: "VirtualNetwork",
|
|
106
|
+
destinationPortRange: "*",
|
|
107
|
+
},
|
|
108
|
+
{
|
|
109
|
+
name: "AllowAzureLoadBalancerInbound",
|
|
110
|
+
priority: 200,
|
|
111
|
+
direction: "Inbound",
|
|
112
|
+
access: "Allow",
|
|
113
|
+
protocol: "*",
|
|
114
|
+
sourceAddressPrefix: "AzureLoadBalancer",
|
|
115
|
+
sourcePortRange: "*",
|
|
116
|
+
destinationAddressPrefix: "*",
|
|
117
|
+
destinationPortRange: "*",
|
|
118
|
+
},
|
|
119
|
+
{
|
|
120
|
+
name: "DenyAllInbound",
|
|
121
|
+
priority: 4096,
|
|
122
|
+
direction: "Inbound",
|
|
123
|
+
access: "Deny",
|
|
124
|
+
protocol: "*",
|
|
125
|
+
sourceAddressPrefix: "*",
|
|
126
|
+
sourcePortRange: "*",
|
|
127
|
+
destinationAddressPrefix: "*",
|
|
128
|
+
destinationPortRange: "*",
|
|
129
|
+
},
|
|
130
|
+
],
|
|
131
|
+
tags: { ...tags, Name: `${name}-private-nsg` },
|
|
132
|
+
});
|
|
133
|
+
// NAT Gateway for private subnet internet access
|
|
134
|
+
let natGatewayId;
|
|
135
|
+
if (natStrategy === "managed") {
|
|
136
|
+
const natPip = new azure.network.PublicIPAddress(`${name}-nat-pip`, {
|
|
137
|
+
publicIpAddressName: `${name}-nat-pip`,
|
|
138
|
+
resourceGroupName: rgName,
|
|
139
|
+
sku: { name: "Standard" },
|
|
140
|
+
publicIPAllocationMethod: "Static",
|
|
141
|
+
tags: { ...tags, Name: `${name}-nat-pip` },
|
|
142
|
+
});
|
|
143
|
+
const natGw = new azure.network.NatGateway(`${name}-nat`, {
|
|
144
|
+
natGatewayName: `${name}-nat`,
|
|
145
|
+
resourceGroupName: rgName,
|
|
146
|
+
sku: { name: "Standard" },
|
|
147
|
+
publicIpAddresses: [{ id: natPip.id }],
|
|
148
|
+
tags: { ...tags, Name: `${name}-nat` },
|
|
149
|
+
});
|
|
150
|
+
natGatewayId = natGw.id;
|
|
151
|
+
// Associate NAT gateway with private subnets via subnet updates
|
|
152
|
+
for (let i = 0; i < privateSubnets.length; i++) {
|
|
153
|
+
new azure.network.Subnet(`${name}-private-${i}-nat`, {
|
|
154
|
+
subnetName: `${name}-private-${i}`,
|
|
155
|
+
resourceGroupName: rgName,
|
|
156
|
+
virtualNetworkName: `${name}-vnet`,
|
|
157
|
+
addressPrefix: `${cidr.split(".").slice(0, 2).join(".")}.${i + 10}.0/24`,
|
|
158
|
+
natGateway: { id: natGw.id },
|
|
159
|
+
networkSecurityGroup: { id: nsg.id },
|
|
160
|
+
});
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
const publicSubnetIds = pulumi.all(publicSubnets.map((s) => s.id));
|
|
164
|
+
const privateSubnetIds = pulumi.all(privateSubnets.map((s) => s.id));
|
|
165
|
+
return {
|
|
166
|
+
name,
|
|
167
|
+
cloud: target,
|
|
168
|
+
vpcId: vnet.id,
|
|
169
|
+
cidr,
|
|
170
|
+
publicSubnetIds: publicSubnetIds,
|
|
171
|
+
privateSubnetIds: privateSubnetIds,
|
|
172
|
+
natGatewayId,
|
|
173
|
+
nativeResource: vnet,
|
|
174
|
+
};
|
|
175
|
+
}
|
|
176
|
+
//# sourceMappingURL=network.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"network.js","sourceRoot":"","sources":["../../../src/azure/network.ts"],"names":[],"mappings":"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"}
|