@microsoft/terraform-cdk-constructs 1.9.0 → 1.10.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/.jsii +55122 -31830
- package/API.md +74039 -46109
- package/lib/azure-actiongroup/lib/action-group.js +1 -1
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
- package/lib/azure-aks/lib/aks-cluster.js +1 -1
- package/lib/azure-applicationinsights/index.d.ts +7 -0
- package/lib/azure-applicationinsights/index.js +24 -0
- package/lib/azure-applicationinsights/lib/application-insights-schemas.d.ts +29 -0
- package/lib/azure-applicationinsights/lib/application-insights-schemas.js +162 -0
- package/lib/azure-applicationinsights/lib/application-insights.d.ts +206 -0
- package/lib/azure-applicationinsights/lib/application-insights.js +209 -0
- package/lib/azure-applicationinsights/lib/index.d.ts +5 -0
- package/lib/azure-applicationinsights/lib/index.js +22 -0
- package/lib/azure-applicationinsights/test/application-insights.integ.d.ts +9 -0
- package/lib/azure-applicationinsights/test/application-insights.integ.js +84 -0
- package/lib/azure-applicationinsights/test/application-insights.spec.d.ts +8 -0
- package/lib/azure-applicationinsights/test/application-insights.spec.js +209 -0
- package/lib/azure-containerapps/index.d.ts +1 -0
- package/lib/azure-containerapps/index.js +18 -0
- package/lib/azure-containerapps/lib/container-app-environment-schemas.d.ts +50 -0
- package/lib/azure-containerapps/lib/container-app-environment-schemas.js +522 -0
- package/lib/azure-containerapps/lib/container-app-environment.d.ts +374 -0
- package/lib/azure-containerapps/lib/container-app-environment.js +310 -0
- package/lib/azure-containerapps/lib/container-app-schemas.d.ts +48 -0
- package/lib/azure-containerapps/lib/container-app-schemas.js +466 -0
- package/lib/azure-containerapps/lib/container-app.d.ts +925 -0
- package/lib/azure-containerapps/lib/container-app.js +320 -0
- package/lib/azure-containerapps/lib/index.d.ts +4 -0
- package/lib/azure-containerapps/lib/index.js +21 -0
- package/lib/azure-containerapps/test/container-app-environment.integ.d.ts +10 -0
- package/lib/azure-containerapps/test/container-app-environment.integ.js +82 -0
- package/lib/azure-containerapps/test/container-app-environment.spec.d.ts +9 -0
- package/lib/azure-containerapps/test/container-app-environment.spec.js +412 -0
- package/lib/azure-containerapps/test/container-app.integ.d.ts +10 -0
- package/lib/azure-containerapps/test/container-app.integ.js +119 -0
- package/lib/azure-containerapps/test/container-app.spec.d.ts +9 -0
- package/lib/azure-containerapps/test/container-app.spec.js +839 -0
- package/lib/azure-containerregistry/index.d.ts +1 -0
- package/lib/azure-containerregistry/index.js +18 -0
- package/lib/azure-containerregistry/lib/container-registry-schemas.d.ts +32 -0
- package/lib/azure-containerregistry/lib/container-registry-schemas.js +316 -0
- package/lib/azure-containerregistry/lib/container-registry.d.ts +330 -0
- package/lib/azure-containerregistry/lib/container-registry.js +217 -0
- package/lib/azure-containerregistry/lib/index.d.ts +2 -0
- package/lib/azure-containerregistry/lib/index.js +19 -0
- package/lib/azure-containerregistry/test/container-registry.integ.d.ts +9 -0
- package/lib/azure-containerregistry/test/container-registry.integ.js +101 -0
- package/lib/azure-containerregistry/test/container-registry.spec.d.ts +4 -0
- package/lib/azure-containerregistry/test/container-registry.spec.js +425 -0
- package/lib/azure-cosmosdb/index.d.ts +1 -0
- package/lib/azure-cosmosdb/index.js +18 -0
- package/lib/azure-cosmosdb/lib/cosmos-db-schemas.d.ts +40 -0
- package/lib/azure-cosmosdb/lib/cosmos-db-schemas.js +330 -0
- package/lib/azure-cosmosdb/lib/cosmos-db.d.ts +290 -0
- package/lib/azure-cosmosdb/lib/cosmos-db.js +222 -0
- package/lib/azure-cosmosdb/lib/index.d.ts +2 -0
- package/lib/azure-cosmosdb/lib/index.js +19 -0
- package/lib/azure-cosmosdb/test/cosmos-db.integ.d.ts +9 -0
- package/lib/azure-cosmosdb/test/cosmos-db.integ.js +98 -0
- package/lib/azure-cosmosdb/test/cosmos-db.spec.d.ts +4 -0
- package/lib/azure-cosmosdb/test/cosmos-db.spec.js +339 -0
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
- package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
- package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
- package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
- package/lib/azure-dnszone/lib/dns-zone.js +1 -1
- package/lib/azure-dnszone/lib/records/dns-records.js +10 -10
- package/lib/azure-functionapp/index.d.ts +1 -0
- package/lib/azure-functionapp/index.js +18 -0
- package/lib/azure-functionapp/lib/function-app-schemas.d.ts +32 -0
- package/lib/azure-functionapp/lib/function-app-schemas.js +303 -0
- package/lib/azure-functionapp/lib/function-app.d.ts +367 -0
- package/lib/azure-functionapp/lib/function-app.js +223 -0
- package/lib/azure-functionapp/lib/index.d.ts +2 -0
- package/lib/azure-functionapp/lib/index.js +19 -0
- package/lib/azure-functionapp/test/function-app.integ.d.ts +12 -0
- package/lib/azure-functionapp/test/function-app.integ.js +134 -0
- package/lib/azure-functionapp/test/function-app.spec.d.ts +4 -0
- package/lib/azure-functionapp/test/function-app.spec.js +566 -0
- package/lib/azure-keyvault/index.d.ts +1 -0
- package/lib/azure-keyvault/index.js +18 -0
- package/lib/azure-keyvault/lib/index.d.ts +2 -0
- package/lib/azure-keyvault/lib/index.js +19 -0
- package/lib/azure-keyvault/lib/key-vault-schemas.d.ts +40 -0
- package/lib/azure-keyvault/lib/key-vault-schemas.js +312 -0
- package/lib/azure-keyvault/lib/key-vault.d.ts +344 -0
- package/lib/azure-keyvault/lib/key-vault.js +243 -0
- package/lib/azure-keyvault/test/key-vault.integ.d.ts +9 -0
- package/lib/azure-keyvault/test/key-vault.integ.js +108 -0
- package/lib/azure-keyvault/test/key-vault.spec.d.ts +4 -0
- package/lib/azure-keyvault/test/key-vault.spec.js +264 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +1 -1
- package/lib/azure-metricalert/lib/metric-alert.js +1 -1
- package/lib/azure-networkinterface/lib/network-interface.js +1 -1
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
- package/lib/azure-networkwatcher/lib/network-watcher.js +1 -1
- package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
- package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
- package/lib/azure-policysetdefinition/lib/policy-set-definition.js +1 -1
- package/lib/azure-privatednszone/lib/private-dns-zone.js +1 -1
- package/lib/azure-privatednszone/lib/records/private-dns-records.js +8 -8
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
- package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
- package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
- package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
- package/lib/azure-roledefinition/lib/role-definition.js +1 -1
- package/lib/azure-sreagent/index.d.ts +1 -0
- package/lib/azure-sreagent/index.js +18 -0
- package/lib/azure-sreagent/lib/index.d.ts +2 -0
- package/lib/azure-sreagent/lib/index.js +19 -0
- package/lib/azure-sreagent/lib/sre-agent-schemas.d.ts +29 -0
- package/lib/azure-sreagent/lib/sre-agent-schemas.js +296 -0
- package/lib/azure-sreagent/lib/sre-agent.d.ts +208 -0
- package/lib/azure-sreagent/lib/sre-agent.js +217 -0
- package/lib/azure-sreagent/test/sre-agent.integ.d.ts +9 -0
- package/lib/azure-sreagent/test/sre-agent.integ.js +78 -0
- package/lib/azure-sreagent/test/sre-agent.spec.d.ts +4 -0
- package/lib/azure-sreagent/test/sre-agent.spec.js +216 -0
- package/lib/azure-staticwebapp/index.d.ts +1 -0
- package/lib/azure-staticwebapp/index.js +18 -0
- package/lib/azure-staticwebapp/lib/index.d.ts +2 -0
- package/lib/azure-staticwebapp/lib/index.js +19 -0
- package/lib/azure-staticwebapp/lib/static-web-app-schemas.d.ts +40 -0
- package/lib/azure-staticwebapp/lib/static-web-app-schemas.js +236 -0
- package/lib/azure-staticwebapp/lib/static-web-app.d.ts +242 -0
- package/lib/azure-staticwebapp/lib/static-web-app.js +232 -0
- package/lib/azure-staticwebapp/test/static-web-app.integ.d.ts +9 -0
- package/lib/azure-staticwebapp/test/static-web-app.integ.js +76 -0
- package/lib/azure-staticwebapp/test/static-web-app.spec.d.ts +15 -0
- package/lib/azure-staticwebapp/test/static-web-app.spec.js +293 -0
- package/lib/azure-storageaccount/lib/storage-account.js +1 -1
- package/lib/azure-subnet/lib/subnet.js +1 -1
- package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
- package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +1 -1
- package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
- package/lib/core-azure/lib/azapi/azapi-resource.js +2 -2
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
- package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
- package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
- package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
- package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
- package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
- package/lib/index.d.ts +16 -0
- package/lib/index.js +18 -2
- package/lib/testing/index.js +2 -2
- package/lib/testing/lib/cleanup.js +1 -1
- package/lib/testing/lib/metadata.js +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,108 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure Key Vault
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates basic usage of the KeyVault construct
|
|
6
|
+
* and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* Run with: npm run integration:nostream
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
const cdktf_1 = require("cdktf");
|
|
12
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
13
|
+
const azure_resourcegroup_1 = require("../../azure-resourcegroup");
|
|
14
|
+
const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
|
|
15
|
+
const testing_1 = require("../../testing");
|
|
16
|
+
const metadata_1 = require("../../testing/lib/metadata");
|
|
17
|
+
const key_vault_1 = require("../lib/key-vault");
|
|
18
|
+
// Generate unique test run metadata for this test suite
|
|
19
|
+
const testMetadata = new metadata_1.TestRunMetadata("key-vault-integration", {
|
|
20
|
+
maxAgeHours: 4,
|
|
21
|
+
});
|
|
22
|
+
/**
|
|
23
|
+
* Example stack demonstrating Key Vault usage
|
|
24
|
+
*/
|
|
25
|
+
class KeyVaultExampleStack extends testing_1.BaseTestStack {
|
|
26
|
+
constructor(scope, id) {
|
|
27
|
+
super(scope, id, {
|
|
28
|
+
testRunOptions: {
|
|
29
|
+
maxAgeHours: testMetadata.maxAgeHours,
|
|
30
|
+
autoCleanup: testMetadata.autoCleanup,
|
|
31
|
+
cleanupPolicy: testMetadata.cleanupPolicy,
|
|
32
|
+
},
|
|
33
|
+
});
|
|
34
|
+
// Configure AZAPI provider
|
|
35
|
+
new provider_1.AzapiProvider(this, "azapi", {});
|
|
36
|
+
// Generate unique names
|
|
37
|
+
const rgName = this.generateResourceName("Microsoft.Resources/resourceGroups", "kv");
|
|
38
|
+
// Create a resource group
|
|
39
|
+
const resourceGroup = new azure_resourcegroup_1.ResourceGroup(this, "example-rg", {
|
|
40
|
+
name: rgName,
|
|
41
|
+
location: "eastus",
|
|
42
|
+
tags: {
|
|
43
|
+
...this.systemTags(),
|
|
44
|
+
},
|
|
45
|
+
});
|
|
46
|
+
// Generate unique Key Vault names (must be globally unique, 3-24 chars)
|
|
47
|
+
const basicKvName = this.generateResourceName("Microsoft.KeyVault/vaults", "basic");
|
|
48
|
+
const versionedKvName = this.generateResourceName("Microsoft.KeyVault/vaults", "ver");
|
|
49
|
+
const securedKvName = this.generateResourceName("Microsoft.KeyVault/vaults", "sec");
|
|
50
|
+
// Example 1: Basic Key Vault using current tenant from AZAPI client config
|
|
51
|
+
new key_vault_1.KeyVault(this, "basic-keyvault", {
|
|
52
|
+
name: basicKvName,
|
|
53
|
+
location: resourceGroup.props.location,
|
|
54
|
+
resourceGroupId: resourceGroup.id,
|
|
55
|
+
// softDeleteRetentionInDays minimum 7 keeps test cleanup quick
|
|
56
|
+
softDeleteRetentionInDays: 7,
|
|
57
|
+
tags: {
|
|
58
|
+
...this.systemTags(),
|
|
59
|
+
example: "basic",
|
|
60
|
+
},
|
|
61
|
+
});
|
|
62
|
+
// Example 2: Key Vault with specific API version and Premium SKU
|
|
63
|
+
new key_vault_1.KeyVault(this, "versioned-keyvault", {
|
|
64
|
+
name: versionedKvName,
|
|
65
|
+
location: resourceGroup.props.location,
|
|
66
|
+
resourceGroupId: resourceGroup.id,
|
|
67
|
+
sku: { name: "premium" },
|
|
68
|
+
apiVersion: "2023-07-01",
|
|
69
|
+
softDeleteRetentionInDays: 7,
|
|
70
|
+
tags: {
|
|
71
|
+
...this.systemTags(),
|
|
72
|
+
example: "versioned",
|
|
73
|
+
},
|
|
74
|
+
});
|
|
75
|
+
// Example 3: Key Vault with hardened network and security settings
|
|
76
|
+
new key_vault_1.KeyVault(this, "secured-keyvault", {
|
|
77
|
+
name: securedKvName,
|
|
78
|
+
location: resourceGroup.props.location,
|
|
79
|
+
resourceGroupId: resourceGroup.id,
|
|
80
|
+
sku: { name: "standard" },
|
|
81
|
+
enableRbacAuthorization: true,
|
|
82
|
+
enableSoftDelete: true,
|
|
83
|
+
softDeleteRetentionInDays: 7,
|
|
84
|
+
publicNetworkAccess: "Enabled",
|
|
85
|
+
networkAcls: {
|
|
86
|
+
defaultAction: "Allow",
|
|
87
|
+
bypass: "AzureServices",
|
|
88
|
+
},
|
|
89
|
+
tags: {
|
|
90
|
+
...this.systemTags(),
|
|
91
|
+
example: "secured",
|
|
92
|
+
},
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
describe("Key Vault Integration Test", () => {
|
|
97
|
+
it("should deploy, validate idempotency, and cleanup key vault resources", () => {
|
|
98
|
+
const app = cdktf_1.Testing.app();
|
|
99
|
+
const stack = new KeyVaultExampleStack(app, "test-key-vault");
|
|
100
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
101
|
+
// This will:
|
|
102
|
+
// 1. Run terraform apply to deploy resources
|
|
103
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
104
|
+
// 3. Run terraform destroy to cleanup resources
|
|
105
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized, { verifyCleanup: true });
|
|
106
|
+
}, 1200000); // 20 minute timeout for deployment and cleanup
|
|
107
|
+
});
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LXZhdWx0LmludGVnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F6dXJlLWtleXZhdWx0L3Rlc3Qva2V5LXZhdWx0LmludGVnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7OztHQU9HOztBQUVILGlDQUFnQztBQUVoQywyQ0FBeUM7QUFDekMsbUVBQTBEO0FBQzFELGtGQUFvRjtBQUNwRiwyQ0FBNkU7QUFDN0UseURBQTZEO0FBQzdELGdEQUE0QztBQUU1Qyx3REFBd0Q7QUFDeEQsTUFBTSxZQUFZLEdBQUcsSUFBSSwwQkFBZSxDQUFDLHVCQUF1QixFQUFFO0lBQ2hFLFdBQVcsRUFBRSxDQUFDO0NBQ2YsQ0FBQyxDQUFDO0FBRUg7O0dBRUc7QUFDSCxNQUFNLG9CQUFxQixTQUFRLHVCQUFhO0lBQzlDLFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3RDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxFQUFFO1lBQ2YsY0FBYyxFQUFFO2dCQUNkLFdBQVcsRUFBRSxZQUFZLENBQUMsV0FBVztnQkFDckMsV0FBVyxFQUFFLFlBQVksQ0FBQyxXQUFXO2dCQUNyQyxhQUFhLEVBQUUsWUFBWSxDQUFDLGFBQWE7YUFDMUM7U0FDRixDQUFDLENBQUM7UUFFSCwyQkFBMkI7UUFDM0IsSUFBSSx3QkFBYSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFckMsd0JBQXdCO1FBQ3hCLE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FDdEMsb0NBQW9DLEVBQ3BDLElBQUksQ0FDTCxDQUFDO1FBRUYsMEJBQTBCO1FBQzFCLE1BQU0sYUFBYSxHQUFHLElBQUksbUNBQWEsQ0FBQyxJQUFJLEVBQUUsWUFBWSxFQUFFO1lBQzFELElBQUksRUFBRSxNQUFNO1lBQ1osUUFBUSxFQUFFLFFBQVE7WUFDbEIsSUFBSSxFQUFFO2dCQUNKLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRTthQUNyQjtTQUNGLENBQUMsQ0FBQztRQUVILHdFQUF3RTtRQUN4RSxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQzNDLDJCQUEyQixFQUMzQixPQUFPLENBQ1IsQ0FBQztRQUNGLE1BQU0sZUFBZSxHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FDL0MsMkJBQTJCLEVBQzNCLEtBQUssQ0FDTixDQUFDO1FBQ0YsTUFBTSxhQUFhLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixDQUM3QywyQkFBMkIsRUFDM0IsS0FBSyxDQUNOLENBQUM7UUFFRiwyRUFBMkU7UUFDM0UsSUFBSSxvQkFBUSxDQUFDLElBQUksRUFBRSxnQkFBZ0IsRUFBRTtZQUNuQyxJQUFJLEVBQUUsV0FBVztZQUNqQixRQUFRLEVBQUUsYUFBYSxDQUFDLEtBQUssQ0FBQyxRQUFTO1lBQ3ZDLGVBQWUsRUFBRSxhQUFhLENBQUMsRUFBRTtZQUNqQywrREFBK0Q7WUFDL0QseUJBQXlCLEVBQUUsQ0FBQztZQUM1QixJQUFJLEVBQUU7Z0JBQ0osR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFO2dCQUNwQixPQUFPLEVBQUUsT0FBTzthQUNqQjtTQUNGLENBQUMsQ0FBQztRQUVILGlFQUFpRTtRQUNqRSxJQUFJLG9CQUFRLENBQUMsSUFBSSxFQUFFLG9CQUFvQixFQUFFO1lBQ3ZDLElBQUksRUFBRSxlQUFlO1lBQ3JCLFFBQVEsRUFBRSxhQUFhLENBQUMsS0FBSyxDQUFDLFFBQVM7WUFDdkMsZUFBZSxFQUFFLGFBQWEsQ0FBQyxFQUFFO1lBQ2pDLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUU7WUFDeEIsVUFBVSxFQUFFLFlBQVk7WUFDeEIseUJBQXlCLEVBQUUsQ0FBQztZQUM1QixJQUFJLEVBQUU7Z0JBQ0osR0FBRyxJQUFJLENBQUMsVUFBVSxFQUFFO2dCQUNwQixPQUFPLEVBQUUsV0FBVzthQUNyQjtTQUNGLENBQUMsQ0FBQztRQUVILG1FQUFtRTtRQUNuRSxJQUFJLG9CQUFRLENBQUMsSUFBSSxFQUFFLGtCQUFrQixFQUFFO1lBQ3JDLElBQUksRUFBRSxhQUFhO1lBQ25CLFFBQVEsRUFBRSxhQUFhLENBQUMsS0FBSyxDQUFDLFFBQVM7WUFDdkMsZUFBZSxFQUFFLGFBQWEsQ0FBQyxFQUFFO1lBQ2pDLEdBQUcsRUFBRSxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUU7WUFDekIsdUJBQXVCLEVBQUUsSUFBSTtZQUM3QixnQkFBZ0IsRUFBRSxJQUFJO1lBQ3RCLHlCQUF5QixFQUFFLENBQUM7WUFDNUIsbUJBQW1CLEVBQUUsU0FBUztZQUM5QixXQUFXLEVBQUU7Z0JBQ1gsYUFBYSxFQUFFLE9BQU87Z0JBQ3RCLE1BQU0sRUFBRSxlQUFlO2FBQ3hCO1lBQ0QsSUFBSSxFQUFFO2dCQUNKLEdBQUcsSUFBSSxDQUFDLFVBQVUsRUFBRTtnQkFDcEIsT0FBTyxFQUFFLFNBQVM7YUFDbkI7U0FDRixDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUFFRCxRQUFRLENBQUMsNEJBQTRCLEVBQUUsR0FBRyxFQUFFO0lBQzFDLEVBQUUsQ0FBQyxzRUFBc0UsRUFBRSxHQUFHLEVBQUU7UUFDOUUsTUFBTSxHQUFHLEdBQUcsZUFBTyxDQUFDLEdBQUcsRUFBRSxDQUFDO1FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksb0JBQW9CLENBQUMsR0FBRyxFQUFFLGdCQUFnQixDQUFDLENBQUM7UUFDOUQsTUFBTSxXQUFXLEdBQUcsZUFBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUU3QyxhQUFhO1FBQ2IsNkNBQTZDO1FBQzdDLG1FQUFtRTtRQUNuRSxnREFBZ0Q7UUFDaEQsSUFBQSx1Q0FBNkIsRUFBQyxXQUFXLEVBQUUsRUFBRSxhQUFhLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQztJQUN0RSxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUMsQ0FBQywrQ0FBK0M7QUFDOUQsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEludGVncmF0aW9uIHRlc3QgZm9yIEF6dXJlIEtleSBWYXVsdFxuICpcbiAqIFRoaXMgdGVzdCBkZW1vbnN0cmF0ZXMgYmFzaWMgdXNhZ2Ugb2YgdGhlIEtleVZhdWx0IGNvbnN0cnVjdFxuICogYW5kIHZhbGlkYXRlcyBkZXBsb3ltZW50LCBpZGVtcG90ZW5jeSwgYW5kIGNsZWFudXAuXG4gKlxuICogUnVuIHdpdGg6IG5wbSBydW4gaW50ZWdyYXRpb246bm9zdHJlYW1cbiAqL1xuXG5pbXBvcnQgeyBUZXN0aW5nIH0gZnJvbSBcImNka3RmXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IFwiY2RrdGYvbGliL3Rlc3RpbmcvYWRhcHRlcnMvamVzdFwiO1xuaW1wb3J0IHsgUmVzb3VyY2VHcm91cCB9IGZyb20gXCIuLi8uLi9henVyZS1yZXNvdXJjZWdyb3VwXCI7XG5pbXBvcnQgeyBBemFwaVByb3ZpZGVyIH0gZnJvbSBcIi4uLy4uL2NvcmUtYXp1cmUvbGliL2F6YXBpL3Byb3ZpZGVycy1hemFwaS9wcm92aWRlclwiO1xuaW1wb3J0IHsgQmFzZVRlc3RTdGFjaywgVGVycmFmb3JtQXBwbHlDaGVja0FuZERlc3Ryb3kgfSBmcm9tIFwiLi4vLi4vdGVzdGluZ1wiO1xuaW1wb3J0IHsgVGVzdFJ1bk1ldGFkYXRhIH0gZnJvbSBcIi4uLy4uL3Rlc3RpbmcvbGliL21ldGFkYXRhXCI7XG5pbXBvcnQgeyBLZXlWYXVsdCB9IGZyb20gXCIuLi9saWIva2V5LXZhdWx0XCI7XG5cbi8vIEdlbmVyYXRlIHVuaXF1ZSB0ZXN0IHJ1biBtZXRhZGF0YSBmb3IgdGhpcyB0ZXN0IHN1aXRlXG5jb25zdCB0ZXN0TWV0YWRhdGEgPSBuZXcgVGVzdFJ1bk1ldGFkYXRhKFwia2V5LXZhdWx0LWludGVncmF0aW9uXCIsIHtcbiAgbWF4QWdlSG91cnM6IDQsXG59KTtcblxuLyoqXG4gKiBFeGFtcGxlIHN0YWNrIGRlbW9uc3RyYXRpbmcgS2V5IFZhdWx0IHVzYWdlXG4gKi9cbmNsYXNzIEtleVZhdWx0RXhhbXBsZVN0YWNrIGV4dGVuZHMgQmFzZVRlc3RTdGFjayB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQsIHtcbiAgICAgIHRlc3RSdW5PcHRpb25zOiB7XG4gICAgICAgIG1heEFnZUhvdXJzOiB0ZXN0TWV0YWRhdGEubWF4QWdlSG91cnMsXG4gICAgICAgIGF1dG9DbGVhbnVwOiB0ZXN0TWV0YWRhdGEuYXV0b0NsZWFudXAsXG4gICAgICAgIGNsZWFudXBQb2xpY3k6IHRlc3RNZXRhZGF0YS5jbGVhbnVwUG9saWN5LFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vIENvbmZpZ3VyZSBBWkFQSSBwcm92aWRlclxuICAgIG5ldyBBemFwaVByb3ZpZGVyKHRoaXMsIFwiYXphcGlcIiwge30pO1xuXG4gICAgLy8gR2VuZXJhdGUgdW5pcXVlIG5hbWVzXG4gICAgY29uc3QgcmdOYW1lID0gdGhpcy5nZW5lcmF0ZVJlc291cmNlTmFtZShcbiAgICAgIFwiTWljcm9zb2Z0LlJlc291cmNlcy9yZXNvdXJjZUdyb3Vwc1wiLFxuICAgICAgXCJrdlwiLFxuICAgICk7XG5cbiAgICAvLyBDcmVhdGUgYSByZXNvdXJjZSBncm91cFxuICAgIGNvbnN0IHJlc291cmNlR3JvdXAgPSBuZXcgUmVzb3VyY2VHcm91cCh0aGlzLCBcImV4YW1wbGUtcmdcIiwge1xuICAgICAgbmFtZTogcmdOYW1lLFxuICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICB0YWdzOiB7XG4gICAgICAgIC4uLnRoaXMuc3lzdGVtVGFncygpLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vIEdlbmVyYXRlIHVuaXF1ZSBLZXkgVmF1bHQgbmFtZXMgKG11c3QgYmUgZ2xvYmFsbHkgdW5pcXVlLCAzLTI0IGNoYXJzKVxuICAgIGNvbnN0IGJhc2ljS3ZOYW1lID0gdGhpcy5nZW5lcmF0ZVJlc291cmNlTmFtZShcbiAgICAgIFwiTWljcm9zb2Z0LktleVZhdWx0L3ZhdWx0c1wiLFxuICAgICAgXCJiYXNpY1wiLFxuICAgICk7XG4gICAgY29uc3QgdmVyc2lvbmVkS3ZOYW1lID0gdGhpcy5nZW5lcmF0ZVJlc291cmNlTmFtZShcbiAgICAgIFwiTWljcm9zb2Z0LktleVZhdWx0L3ZhdWx0c1wiLFxuICAgICAgXCJ2ZXJcIixcbiAgICApO1xuICAgIGNvbnN0IHNlY3VyZWRLdk5hbWUgPSB0aGlzLmdlbmVyYXRlUmVzb3VyY2VOYW1lKFxuICAgICAgXCJNaWNyb3NvZnQuS2V5VmF1bHQvdmF1bHRzXCIsXG4gICAgICBcInNlY1wiLFxuICAgICk7XG5cbiAgICAvLyBFeGFtcGxlIDE6IEJhc2ljIEtleSBWYXVsdCB1c2luZyBjdXJyZW50IHRlbmFudCBmcm9tIEFaQVBJIGNsaWVudCBjb25maWdcbiAgICBuZXcgS2V5VmF1bHQodGhpcywgXCJiYXNpYy1rZXl2YXVsdFwiLCB7XG4gICAgICBuYW1lOiBiYXNpY0t2TmFtZSxcbiAgICAgIGxvY2F0aW9uOiByZXNvdXJjZUdyb3VwLnByb3BzLmxvY2F0aW9uISxcbiAgICAgIHJlc291cmNlR3JvdXBJZDogcmVzb3VyY2VHcm91cC5pZCxcbiAgICAgIC8vIHNvZnREZWxldGVSZXRlbnRpb25JbkRheXMgbWluaW11bSA3IGtlZXBzIHRlc3QgY2xlYW51cCBxdWlja1xuICAgICAgc29mdERlbGV0ZVJldGVudGlvbkluRGF5czogNyxcbiAgICAgIHRhZ3M6IHtcbiAgICAgICAgLi4udGhpcy5zeXN0ZW1UYWdzKCksXG4gICAgICAgIGV4YW1wbGU6IFwiYmFzaWNcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyBFeGFtcGxlIDI6IEtleSBWYXVsdCB3aXRoIHNwZWNpZmljIEFQSSB2ZXJzaW9uIGFuZCBQcmVtaXVtIFNLVVxuICAgIG5ldyBLZXlWYXVsdCh0aGlzLCBcInZlcnNpb25lZC1rZXl2YXVsdFwiLCB7XG4gICAgICBuYW1lOiB2ZXJzaW9uZWRLdk5hbWUsXG4gICAgICBsb2NhdGlvbjogcmVzb3VyY2VHcm91cC5wcm9wcy5sb2NhdGlvbiEsXG4gICAgICByZXNvdXJjZUdyb3VwSWQ6IHJlc291cmNlR3JvdXAuaWQsXG4gICAgICBza3U6IHsgbmFtZTogXCJwcmVtaXVtXCIgfSxcbiAgICAgIGFwaVZlcnNpb246IFwiMjAyMy0wNy0wMVwiLFxuICAgICAgc29mdERlbGV0ZVJldGVudGlvbkluRGF5czogNyxcbiAgICAgIHRhZ3M6IHtcbiAgICAgICAgLi4udGhpcy5zeXN0ZW1UYWdzKCksXG4gICAgICAgIGV4YW1wbGU6IFwidmVyc2lvbmVkXCIsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8gRXhhbXBsZSAzOiBLZXkgVmF1bHQgd2l0aCBoYXJkZW5lZCBuZXR3b3JrIGFuZCBzZWN1cml0eSBzZXR0aW5nc1xuICAgIG5ldyBLZXlWYXVsdCh0aGlzLCBcInNlY3VyZWQta2V5dmF1bHRcIiwge1xuICAgICAgbmFtZTogc2VjdXJlZEt2TmFtZSxcbiAgICAgIGxvY2F0aW9uOiByZXNvdXJjZUdyb3VwLnByb3BzLmxvY2F0aW9uISxcbiAgICAgIHJlc291cmNlR3JvdXBJZDogcmVzb3VyY2VHcm91cC5pZCxcbiAgICAgIHNrdTogeyBuYW1lOiBcInN0YW5kYXJkXCIgfSxcbiAgICAgIGVuYWJsZVJiYWNBdXRob3JpemF0aW9uOiB0cnVlLFxuICAgICAgZW5hYmxlU29mdERlbGV0ZTogdHJ1ZSxcbiAgICAgIHNvZnREZWxldGVSZXRlbnRpb25JbkRheXM6IDcsXG4gICAgICBwdWJsaWNOZXR3b3JrQWNjZXNzOiBcIkVuYWJsZWRcIixcbiAgICAgIG5ldHdvcmtBY2xzOiB7XG4gICAgICAgIGRlZmF1bHRBY3Rpb246IFwiQWxsb3dcIixcbiAgICAgICAgYnlwYXNzOiBcIkF6dXJlU2VydmljZXNcIixcbiAgICAgIH0sXG4gICAgICB0YWdzOiB7XG4gICAgICAgIC4uLnRoaXMuc3lzdGVtVGFncygpLFxuICAgICAgICBleGFtcGxlOiBcInNlY3VyZWRcIixcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cblxuZGVzY3JpYmUoXCJLZXkgVmF1bHQgSW50ZWdyYXRpb24gVGVzdFwiLCAoKSA9PiB7XG4gIGl0KFwic2hvdWxkIGRlcGxveSwgdmFsaWRhdGUgaWRlbXBvdGVuY3ksIGFuZCBjbGVhbnVwIGtleSB2YXVsdCByZXNvdXJjZXNcIiwgKCkgPT4ge1xuICAgIGNvbnN0IGFwcCA9IFRlc3RpbmcuYXBwKCk7XG4gICAgY29uc3Qgc3RhY2sgPSBuZXcgS2V5VmF1bHRFeGFtcGxlU3RhY2soYXBwLCBcInRlc3Qta2V5LXZhdWx0XCIpO1xuICAgIGNvbnN0IHN5bnRoZXNpemVkID0gVGVzdGluZy5mdWxsU3ludGgoc3RhY2spO1xuXG4gICAgLy8gVGhpcyB3aWxsOlxuICAgIC8vIDEuIFJ1biB0ZXJyYWZvcm0gYXBwbHkgdG8gZGVwbG95IHJlc291cmNlc1xuICAgIC8vIDIuIFJ1biB0ZXJyYWZvcm0gcGxhbiB0byBjaGVjayBpZGVtcG90ZW5jeSAobm8gY2hhbmdlcyBleHBlY3RlZClcbiAgICAvLyAzLiBSdW4gdGVycmFmb3JtIGRlc3Ryb3kgdG8gY2xlYW51cCByZXNvdXJjZXNcbiAgICBUZXJyYWZvcm1BcHBseUNoZWNrQW5kRGVzdHJveShzeW50aGVzaXplZCwgeyB2ZXJpZnlDbGVhbnVwOiB0cnVlIH0pO1xuICB9LCAxMjAwMDAwKTsgLy8gMjAgbWludXRlIHRpbWVvdXQgZm9yIGRlcGxveW1lbnQgYW5kIGNsZWFudXBcbn0pO1xuIl19
|
|
@@ -0,0 +1,264 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Unit tests for Azure Key Vault using AzapiResource framework
|
|
4
|
+
*/
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const cdktf_1 = require("cdktf");
|
|
7
|
+
const cdktf = require("cdktf");
|
|
8
|
+
const azure_resourcegroup_1 = require("../../azure-resourcegroup");
|
|
9
|
+
const key_vault_1 = require("../lib/key-vault");
|
|
10
|
+
describe("KeyVault", () => {
|
|
11
|
+
let app;
|
|
12
|
+
let stack;
|
|
13
|
+
beforeEach(() => {
|
|
14
|
+
app = cdktf_1.Testing.app();
|
|
15
|
+
stack = new cdktf.TerraformStack(app, "TestStack");
|
|
16
|
+
});
|
|
17
|
+
describe("constructor", () => {
|
|
18
|
+
it("should create a key vault with required properties", () => {
|
|
19
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
20
|
+
name: "test-rg",
|
|
21
|
+
location: "eastus",
|
|
22
|
+
});
|
|
23
|
+
const props = {
|
|
24
|
+
name: "test-keyvault-001",
|
|
25
|
+
location: "eastus",
|
|
26
|
+
resourceGroupId: rg.id,
|
|
27
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
28
|
+
};
|
|
29
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
30
|
+
expect(keyVault).toBeInstanceOf(key_vault_1.KeyVault);
|
|
31
|
+
expect(keyVault.props).toBe(props);
|
|
32
|
+
});
|
|
33
|
+
it("should create a key vault with all properties", () => {
|
|
34
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
35
|
+
name: "test-rg",
|
|
36
|
+
location: "eastus",
|
|
37
|
+
});
|
|
38
|
+
const props = {
|
|
39
|
+
name: "test-keyvault-002",
|
|
40
|
+
location: "eastus",
|
|
41
|
+
resourceGroupId: rg.id,
|
|
42
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
43
|
+
sku: { name: "premium", family: "A" },
|
|
44
|
+
enabledForDeployment: true,
|
|
45
|
+
enabledForDiskEncryption: true,
|
|
46
|
+
enabledForTemplateDeployment: true,
|
|
47
|
+
enableRbacAuthorization: false,
|
|
48
|
+
enableSoftDelete: true,
|
|
49
|
+
softDeleteRetentionInDays: 30,
|
|
50
|
+
enablePurgeProtection: true,
|
|
51
|
+
publicNetworkAccess: "Disabled",
|
|
52
|
+
tags: {
|
|
53
|
+
environment: "test",
|
|
54
|
+
project: "cdktf-constructs",
|
|
55
|
+
},
|
|
56
|
+
networkAcls: {
|
|
57
|
+
defaultAction: "Deny",
|
|
58
|
+
bypass: "AzureServices",
|
|
59
|
+
ipRules: [{ value: "1.2.3.4" }],
|
|
60
|
+
},
|
|
61
|
+
accessPolicies: [
|
|
62
|
+
{
|
|
63
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
64
|
+
objectId: "11111111-1111-1111-1111-111111111111",
|
|
65
|
+
permissions: {
|
|
66
|
+
secrets: ["get", "list"],
|
|
67
|
+
},
|
|
68
|
+
},
|
|
69
|
+
],
|
|
70
|
+
};
|
|
71
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
72
|
+
expect(keyVault.props).toBe(props);
|
|
73
|
+
expect(keyVault.tags).toEqual(props.tags);
|
|
74
|
+
});
|
|
75
|
+
it("should resolve tenantId from AZAPI client config when not specified", () => {
|
|
76
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
77
|
+
name: "test-rg",
|
|
78
|
+
location: "eastus",
|
|
79
|
+
});
|
|
80
|
+
const props = {
|
|
81
|
+
name: "test-keyvault-003",
|
|
82
|
+
location: "eastus",
|
|
83
|
+
resourceGroupId: rg.id,
|
|
84
|
+
};
|
|
85
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
86
|
+
expect(keyVault).toBeInstanceOf(key_vault_1.KeyVault);
|
|
87
|
+
});
|
|
88
|
+
it("should create terraform outputs", () => {
|
|
89
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
90
|
+
name: "test-rg",
|
|
91
|
+
location: "eastus",
|
|
92
|
+
});
|
|
93
|
+
const props = {
|
|
94
|
+
name: "test-keyvault-004",
|
|
95
|
+
location: "eastus",
|
|
96
|
+
resourceGroupId: rg.id,
|
|
97
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
98
|
+
};
|
|
99
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
100
|
+
expect(keyVault.idOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
101
|
+
expect(keyVault.locationOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
102
|
+
expect(keyVault.nameOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
103
|
+
expect(keyVault.tagsOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
104
|
+
expect(keyVault.vaultUriOutput).toBeInstanceOf(cdktf.TerraformOutput);
|
|
105
|
+
});
|
|
106
|
+
it("should expose vaultUri property", () => {
|
|
107
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
108
|
+
name: "test-rg",
|
|
109
|
+
location: "eastus",
|
|
110
|
+
});
|
|
111
|
+
const props = {
|
|
112
|
+
name: "test-keyvault-005",
|
|
113
|
+
location: "eastus",
|
|
114
|
+
resourceGroupId: rg.id,
|
|
115
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
116
|
+
};
|
|
117
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
118
|
+
expect(keyVault.vaultUri).toContain("vault.azure.net");
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
describe("validation", () => {
|
|
122
|
+
it("should reject softDeleteRetentionInDays below 7", () => {
|
|
123
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
124
|
+
name: "test-rg",
|
|
125
|
+
location: "eastus",
|
|
126
|
+
});
|
|
127
|
+
const props = {
|
|
128
|
+
name: "test-keyvault-006",
|
|
129
|
+
location: "eastus",
|
|
130
|
+
resourceGroupId: rg.id,
|
|
131
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
132
|
+
softDeleteRetentionInDays: 3,
|
|
133
|
+
};
|
|
134
|
+
expect(() => new key_vault_1.KeyVault(stack, "TestKv", props)).toThrow(/softDeleteRetentionInDays/);
|
|
135
|
+
});
|
|
136
|
+
it("should reject softDeleteRetentionInDays above 90", () => {
|
|
137
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
138
|
+
name: "test-rg",
|
|
139
|
+
location: "eastus",
|
|
140
|
+
});
|
|
141
|
+
const props = {
|
|
142
|
+
name: "test-keyvault-007",
|
|
143
|
+
location: "eastus",
|
|
144
|
+
resourceGroupId: rg.id,
|
|
145
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
146
|
+
softDeleteRetentionInDays: 365,
|
|
147
|
+
};
|
|
148
|
+
expect(() => new key_vault_1.KeyVault(stack, "TestKv", props)).toThrow(/softDeleteRetentionInDays/);
|
|
149
|
+
});
|
|
150
|
+
});
|
|
151
|
+
describe("SKU configuration", () => {
|
|
152
|
+
it("should accept standard SKU by default", () => {
|
|
153
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
154
|
+
name: "test-rg",
|
|
155
|
+
location: "eastus",
|
|
156
|
+
});
|
|
157
|
+
const props = {
|
|
158
|
+
name: "test-keyvault-008",
|
|
159
|
+
location: "eastus",
|
|
160
|
+
resourceGroupId: rg.id,
|
|
161
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
162
|
+
};
|
|
163
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
164
|
+
expect(keyVault).toBeInstanceOf(key_vault_1.KeyVault);
|
|
165
|
+
});
|
|
166
|
+
it("should accept premium SKU", () => {
|
|
167
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
168
|
+
name: "test-rg",
|
|
169
|
+
location: "eastus",
|
|
170
|
+
});
|
|
171
|
+
const props = {
|
|
172
|
+
name: "test-keyvault-009",
|
|
173
|
+
location: "eastus",
|
|
174
|
+
resourceGroupId: rg.id,
|
|
175
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
176
|
+
sku: { name: "premium" },
|
|
177
|
+
};
|
|
178
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
179
|
+
expect(keyVault.props.sku?.name).toBe("premium");
|
|
180
|
+
});
|
|
181
|
+
});
|
|
182
|
+
describe("tag management", () => {
|
|
183
|
+
let keyVault;
|
|
184
|
+
beforeEach(() => {
|
|
185
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
186
|
+
name: "test-rg",
|
|
187
|
+
location: "eastus",
|
|
188
|
+
});
|
|
189
|
+
const props = {
|
|
190
|
+
name: "test-keyvault-010",
|
|
191
|
+
location: "eastus",
|
|
192
|
+
resourceGroupId: rg.id,
|
|
193
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
194
|
+
tags: {
|
|
195
|
+
environment: "test",
|
|
196
|
+
},
|
|
197
|
+
};
|
|
198
|
+
keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
199
|
+
});
|
|
200
|
+
it("should add a tag", () => {
|
|
201
|
+
keyVault.addTag("newTag", "newValue");
|
|
202
|
+
expect(keyVault.props.tags.newTag).toBe("newValue");
|
|
203
|
+
expect(keyVault.props.tags.environment).toBe("test");
|
|
204
|
+
});
|
|
205
|
+
it("should remove an existing tag", () => {
|
|
206
|
+
keyVault.removeTag("environment");
|
|
207
|
+
expect(keyVault.props.tags.environment).toBeUndefined();
|
|
208
|
+
});
|
|
209
|
+
});
|
|
210
|
+
describe("API versioning", () => {
|
|
211
|
+
it("should use default version when not specified", () => {
|
|
212
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
213
|
+
name: "test-rg",
|
|
214
|
+
location: "eastus",
|
|
215
|
+
});
|
|
216
|
+
const props = {
|
|
217
|
+
name: "test-keyvault-011",
|
|
218
|
+
location: "eastus",
|
|
219
|
+
resourceGroupId: rg.id,
|
|
220
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
221
|
+
};
|
|
222
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
223
|
+
expect(keyVault.resolvedApiVersion).toBe("2024-11-01");
|
|
224
|
+
});
|
|
225
|
+
it("should accept specific API version", () => {
|
|
226
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
227
|
+
name: "test-rg",
|
|
228
|
+
location: "eastus",
|
|
229
|
+
});
|
|
230
|
+
const props = {
|
|
231
|
+
name: "test-keyvault-012",
|
|
232
|
+
location: "eastus",
|
|
233
|
+
resourceGroupId: rg.id,
|
|
234
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
235
|
+
apiVersion: "2023-07-01",
|
|
236
|
+
};
|
|
237
|
+
const keyVault = new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
238
|
+
expect(keyVault.resolvedApiVersion).toBe("2023-07-01");
|
|
239
|
+
});
|
|
240
|
+
});
|
|
241
|
+
describe("CDK Terraform integration", () => {
|
|
242
|
+
it("should synthesize to valid Terraform", () => {
|
|
243
|
+
const rg = new azure_resourcegroup_1.ResourceGroup(stack, "TestRG", {
|
|
244
|
+
name: "test-rg",
|
|
245
|
+
location: "eastus",
|
|
246
|
+
});
|
|
247
|
+
const props = {
|
|
248
|
+
name: "test-keyvault-013",
|
|
249
|
+
location: "eastus",
|
|
250
|
+
resourceGroupId: rg.id,
|
|
251
|
+
tenantId: "00000000-0000-0000-0000-000000000000",
|
|
252
|
+
tags: {
|
|
253
|
+
environment: "test",
|
|
254
|
+
},
|
|
255
|
+
};
|
|
256
|
+
new key_vault_1.KeyVault(stack, "TestKv", props);
|
|
257
|
+
const synthesized = cdktf_1.Testing.synth(stack);
|
|
258
|
+
expect(synthesized).toBeDefined();
|
|
259
|
+
const stackConfig = JSON.parse(synthesized);
|
|
260
|
+
expect(stackConfig.resource).toBeDefined();
|
|
261
|
+
});
|
|
262
|
+
});
|
|
263
|
+
});
|
|
264
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5LXZhdWx0LnNwZWMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXp1cmUta2V5dmF1bHQvdGVzdC9rZXktdmF1bHQuc3BlYy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUE7O0dBRUc7O0FBRUgsaUNBQWdDO0FBQ2hDLCtCQUErQjtBQUMvQixtRUFBMEQ7QUFDMUQsZ0RBQTJEO0FBRTNELFFBQVEsQ0FBQyxVQUFVLEVBQUUsR0FBRyxFQUFFO0lBQ3hCLElBQUksR0FBYyxDQUFDO0lBQ25CLElBQUksS0FBMkIsQ0FBQztJQUVoQyxVQUFVLENBQUMsR0FBRyxFQUFFO1FBQ2QsR0FBRyxHQUFHLGVBQU8sQ0FBQyxHQUFHLEVBQUUsQ0FBQztRQUNwQixLQUFLLEdBQUcsSUFBSSxLQUFLLENBQUMsY0FBYyxDQUFDLEdBQUcsRUFBRSxXQUFXLENBQUMsQ0FBQztJQUNyRCxDQUFDLENBQUMsQ0FBQztJQUVILFFBQVEsQ0FBQyxhQUFhLEVBQUUsR0FBRyxFQUFFO1FBQzNCLEVBQUUsQ0FBQyxvREFBb0QsRUFBRSxHQUFHLEVBQUU7WUFDNUQsTUFBTSxFQUFFLEdBQUcsSUFBSSxtQ0FBYSxDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUU7Z0JBQzVDLElBQUksRUFBRSxTQUFTO2dCQUNmLFFBQVEsRUFBRSxRQUFRO2FBQ25CLENBQUMsQ0FBQztZQUVILE1BQU0sS0FBSyxHQUFrQjtnQkFDM0IsSUFBSSxFQUFFLG1CQUFtQjtnQkFDekIsUUFBUSxFQUFFLFFBQVE7Z0JBQ2xCLGVBQWUsRUFBRSxFQUFFLENBQUMsRUFBRTtnQkFDdEIsUUFBUSxFQUFFLHNDQUFzQzthQUNqRCxDQUFDO1lBRUYsTUFBTSxRQUFRLEdBQUcsSUFBSSxvQkFBUSxDQUFDLEtBQUssRUFBRSxRQUFRLEVBQUUsS0FBSyxDQUFDLENBQUM7WUFFdEQsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLGNBQWMsQ0FBQyxvQkFBUSxDQUFDLENBQUM7WUFDMUMsTUFB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QUFXLEVBQUUsQ0FBQztZQUVsQyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxDQUFDO1lBQzVDLE1BQU0sQ0FBQyxXQUFXLENBQUMsUUFBUSxDQUFDLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDN0MsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUMsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBVbml0IHRlc3RzIGZvciBBenVyZSBLZXkgVmF1bHQgdXNpbmcgQXphcGlSZXNvdXJjZSBmcmFtZXdvcmtcbiAqL1xuXG5pbXBvcnQgeyBUZXN0aW5nIH0gZnJvbSBcImNka3RmXCI7XG5pbXBvcnQgKiBhcyBjZGt0ZiBmcm9tIFwiY2RrdGZcIjtcbmltcG9ydCB7IFJlc291cmNlR3JvdXAgfSBmcm9tIFwiLi4vLi4vYXp1cmUtcmVzb3VyY2Vncm91cFwiO1xuaW1wb3J0IHsgS2V5VmF1bHQsIEtleVZhdWx0UHJvcHMgfSBmcm9tIFwiLi4vbGliL2tleS12YXVsdFwiO1xuXG5kZXNjcmliZShcIktleVZhdWx0XCIsICgpID0+IHtcbiAgbGV0IGFwcDogY2RrdGYuQXBwO1xuICBsZXQgc3RhY2s6IGNka3RmLlRlcnJhZm9ybVN0YWNrO1xuXG4gIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgIGFwcCA9IFRlc3RpbmcuYXBwKCk7XG4gICAgc3RhY2sgPSBuZXcgY2RrdGYuVGVycmFmb3JtU3RhY2soYXBwLCBcIlRlc3RTdGFja1wiKTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJjb25zdHJ1Y3RvclwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgY3JlYXRlIGEga2V5IHZhdWx0IHdpdGggcmVxdWlyZWQgcHJvcGVydGllc1wiLCAoKSA9PiB7XG4gICAgICBjb25zdCByZyA9IG5ldyBSZXNvdXJjZUdyb3VwKHN0YWNrLCBcIlRlc3RSR1wiLCB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1yZ1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBwcm9wczogS2V5VmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LWtleXZhdWx0LTAwMVwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiByZy5pZCxcbiAgICAgICAgdGVuYW50SWQ6IFwiMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwXCIsXG4gICAgICB9O1xuXG4gICAgICBjb25zdCBrZXlWYXVsdCA9IG5ldyBLZXlWYXVsdChzdGFjaywgXCJUZXN0S3ZcIiwgcHJvcHMpO1xuXG4gICAgICBleHBlY3Qoa2V5VmF1bHQpLnRvQmVJbnN0YW5jZU9mKEtleVZhdWx0KTtcbiAgICAgIGV4cGVjdChrZXlWYXVsdC5wcm9wcykudG9CZShwcm9wcyk7XG4gICAgfSk7XG5cbiAgICBpdChcInNob3VsZCBjcmVhdGUgYSBrZXkgdmF1bHQgd2l0aCBhbGwgcHJvcGVydGllc1wiLCAoKSA9PiB7XG4gICAgICBjb25zdCByZyA9IG5ldyBSZXNvdXJjZUdyb3VwKHN0YWNrLCBcIlRlc3RSR1wiLCB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1yZ1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBwcm9wczogS2V5VmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LWtleXZhdWx0LTAwMlwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiByZy5pZCxcbiAgICAgICAgdGVuYW50SWQ6IFwiMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwXCIsXG4gICAgICAgIHNrdTogeyBuYW1lOiBcInByZW1pdW1cIiwgZmFtaWx5OiBcIkFcIiB9LFxuICAgICAgICBlbmFibGVkRm9yRGVwbG95bWVudDogdHJ1ZSxcbiAgICAgICAgZW5hYmxlZEZvckRpc2tFbmNyeXB0aW9uOiB0cnVlLFxuICAgICAgICBlbmFibGVkRm9yVGVtcGxhdGVEZXBsb3ltZW50OiB0cnVlLFxuICAgICAgICBlbmFibGVSYmFjQXV0aG9yaXphdGlvbjogZmFsc2UsXG4gICAgICAgIGVuYWJsZVNvZnREZWxldGU6IHRydWUsXG4gICAgICAgIHNvZnREZWxldGVSZXRlbnRpb25JbkRheXM6IDMwLFxuICAgICAgICBlbmFibGVQdXJnZVByb3RlY3Rpb246IHRydWUsXG4gICAgICAgIHB1YmxpY05ldHdvcmtBY2Nlc3M6IFwiRGlzYWJsZWRcIixcbiAgICAgICAgdGFnczoge1xuICAgICAgICAgIGVudmlyb25tZW50OiBcInRlc3RcIixcbiAgICAgICAgICBwcm9qZWN0OiBcImNka3RmLWNvbnN0cnVjdHNcIixcbiAgICAgICAgfSxcbiAgICAgICAgbmV0d29ya0FjbHM6IHtcbiAgICAgICAgICBkZWZhdWx0QWN0aW9uOiBcIkRlbnlcIixcbiAgICAgICAgICBieXBhc3M6IFwiQXp1cmVTZXJ2aWNlc1wiLFxuICAgICAgICAgIGlwUnVsZXM6IFt7IHZhbHVlOiBcIjEuMi4zLjRcIiB9XSxcbiAgICAgICAgfSxcbiAgICAgICAgYWNjZXNzUG9saWNpZXM6IFtcbiAgICAgICAgICB7XG4gICAgICAgICAgICB0ZW5hbnRJZDogXCIwMDAwMDAwMC0wMDAwLTAwMDAtMDAwMC0wMDAwMDAwMDAwMDBcIixcbiAgICAgICAgICAgIG9iamVjdElkOiBcIjExMTExMTExLTExMTEtMTExMS0xMTExLTExMTExMTExMTExMVwiLFxuICAgICAgICAgICAgcGVybWlzc2lvbnM6IHtcbiAgICAgICAgICAgICAgc2VjcmV0czogW1wiZ2V0XCIsIFwibGlzdFwiXSxcbiAgICAgICAgICAgIH0sXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IGtleVZhdWx0ID0gbmV3IEtleVZhdWx0KHN0YWNrLCBcIlRlc3RLdlwiLCBwcm9wcyk7XG5cbiAgICAgIGV4cGVjdChrZXlWYXVsdC5wcm9wcykudG9CZShwcm9wcyk7XG4gICAgICBleHBlY3Qoa2V5VmF1bHQudGFncykudG9FcXVhbChwcm9wcy50YWdzKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIHJlc29sdmUgdGVuYW50SWQgZnJvbSBBWkFQSSBjbGllbnQgY29uZmlnIHdoZW4gbm90IHNwZWNpZmllZFwiLCAoKSA9PiB7XG4gICAgICBjb25zdCByZyA9IG5ldyBSZXNvdXJjZUdyb3VwKHN0YWNrLCBcIlRlc3RSR1wiLCB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1yZ1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBwcm9wczogS2V5VmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LWtleXZhdWx0LTAwM1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiByZy5pZCxcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IGtleVZhdWx0ID0gbmV3IEtleVZhdWx0KHN0YWNrLCBcIlRlc3RLdlwiLCBwcm9wcyk7XG5cbiAgICAgIGV4cGVjdChrZXlWYXVsdCkudG9CZUluc3RhbmNlT2YoS2V5VmF1bHQpO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgY3JlYXRlIHRlcnJhZm9ybSBvdXRwdXRzXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHJnID0gbmV3IFJlc291cmNlR3JvdXAoc3RhY2ssIFwiVGVzdFJHXCIsIHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LXJnXCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgfSk7XG5cbiAgICAgIGNvbnN0IHByb3BzOiBLZXlWYXVsdFByb3BzID0ge1xuICAgICAgICBuYW1lOiBcInRlc3Qta2V5dmF1bHQtMDA0XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IHJnLmlkLFxuICAgICAgICB0ZW5hbnRJZDogXCIwMDAwMDAwMC0wMDAwLTAwMDAtMDAwMC0wMDAwMDAwMDAwMDBcIixcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IGtleVZhdWx0ID0gbmV3IEtleVZhdWx0KHN0YWNrLCBcIlRlc3RLdlwiLCBwcm9wcyk7XG5cbiAgICAgIGV4cGVjdChrZXlWYXVsdC5pZE91dHB1dCkudG9CZUluc3RhbmNlT2YoY2RrdGYuVGVycmFmb3JtT3V0cHV0KTtcbiAgICAgIGV4cGVjdChrZXlWYXVsdC5sb2NhdGlvbk91dHB1dCkudG9CZUluc3RhbmNlT2YoY2RrdGYuVGVycmFmb3JtT3V0cHV0KTtcbiAgICAgIGV4cGVjdChrZXlWYXVsdC5uYW1lT3V0cHV0KS50b0JlSW5zdGFuY2VPZihjZGt0Zi5UZXJyYWZvcm1PdXRwdXQpO1xuICAgICAgZXhwZWN0KGtleVZhdWx0LnRhZ3NPdXRwdXQpLnRvQmVJbnN0YW5jZU9mKGNka3RmLlRlcnJhZm9ybU91dHB1dCk7XG4gICAgICBleHBlY3Qoa2V5VmF1bHQudmF1bHRVcmlPdXRwdXQpLnRvQmVJbnN0YW5jZU9mKGNka3RmLlRlcnJhZm9ybU91dHB1dCk7XG4gICAgfSk7XG5cbiAgICBpdChcInNob3VsZCBleHBvc2UgdmF1bHRVcmkgcHJvcGVydHlcIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcmcgPSBuZXcgUmVzb3VyY2VHcm91cChzdGFjaywgXCJUZXN0UkdcIiwge1xuICAgICAgICBuYW1lOiBcInRlc3QtcmdcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICB9KTtcblxuICAgICAgY29uc3QgcHJvcHM6IEtleVZhdWx0UHJvcHMgPSB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1rZXl2YXVsdC0wMDVcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogcmcuaWQsXG4gICAgICAgIHRlbmFudElkOiBcIjAwMDAwMDAwLTAwMDAtMDAwMC0wMDAwLTAwMDAwMDAwMDAwMFwiLFxuICAgICAgfTtcblxuICAgICAgY29uc3Qga2V5VmF1bHQgPSBuZXcgS2V5VmF1bHQoc3RhY2ssIFwiVGVzdEt2XCIsIHByb3BzKTtcblxuICAgICAgZXhwZWN0KGtleVZhdWx0LnZhdWx0VXJpKS50b0NvbnRhaW4oXCJ2YXVsdC5henVyZS5uZXRcIik7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKFwidmFsaWRhdGlvblwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgcmVqZWN0IHNvZnREZWxldGVSZXRlbnRpb25JbkRheXMgYmVsb3cgN1wiLCAoKSA9PiB7XG4gICAgICBjb25zdCByZyA9IG5ldyBSZXNvdXJjZUdyb3VwKHN0YWNrLCBcIlRlc3RSR1wiLCB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1yZ1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBwcm9wczogS2V5VmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LWtleXZhdWx0LTAwNlwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiByZy5pZCxcbiAgICAgICAgdGVuYW50SWQ6IFwiMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwXCIsXG4gICAgICAgIHNvZnREZWxldGVSZXRlbnRpb25JbkRheXM6IDMsXG4gICAgICB9O1xuXG4gICAgICBleHBlY3QoKCkgPT4gbmV3IEtleVZhdWx0KHN0YWNrLCBcIlRlc3RLdlwiLCBwcm9wcykpLnRvVGhyb3coXG4gICAgICAgIC9zb2Z0RGVsZXRlUmV0ZW50aW9uSW5EYXlzLyxcbiAgICAgICk7XG4gICAgfSk7XG5cbiAgICBpdChcInNob3VsZCByZWplY3Qgc29mdERlbGV0ZVJldGVudGlvbkluRGF5cyBhYm92ZSA5MFwiLCAoKSA9PiB7XG4gICAgICBjb25zdCByZyA9IG5ldyBSZXNvdXJjZUdyb3VwKHN0YWNrLCBcIlRlc3RSR1wiLCB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1yZ1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBwcm9wczogS2V5VmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LWtleXZhdWx0LTAwN1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiByZy5pZCxcbiAgICAgICAgdGVuYW50SWQ6IFwiMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwXCIsXG4gICAgICAgIHNvZnREZWxldGVSZXRlbnRpb25JbkRheXM6IDM2NSxcbiAgICAgIH07XG5cbiAgICAgIGV4cGVjdCgoKSA9PiBuZXcgS2V5VmF1bHQoc3RhY2ssIFwiVGVzdEt2XCIsIHByb3BzKSkudG9UaHJvdyhcbiAgICAgICAgL3NvZnREZWxldGVSZXRlbnRpb25JbkRheXMvLFxuICAgICAgKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJTS1UgY29uZmlndXJhdGlvblwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgYWNjZXB0IHN0YW5kYXJkIFNLVSBieSBkZWZhdWx0XCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHJnID0gbmV3IFJlc291cmNlR3JvdXAoc3RhY2ssIFwiVGVzdFJHXCIsIHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LXJnXCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgfSk7XG5cbiAgICAgIGNvbnN0IHByb3BzOiBLZXlWYXVsdFByb3BzID0ge1xuICAgICAgICBuYW1lOiBcInRlc3Qta2V5dmF1bHQtMDA4XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IHJnLmlkLFxuICAgICAgICB0ZW5hbnRJZDogXCIwMDAwMDAwMC0wMDAwLTAwMDAtMDAwMC0wMDAwMDAwMDAwMDBcIixcbiAgICAgIH07XG5cbiAgICAgIGNvbnN0IGtleVZhdWx0ID0gbmV3IEtleVZhdWx0KHN0YWNrLCBcIlRlc3RLdlwiLCBwcm9wcyk7XG5cbiAgICAgIGV4cGVjdChrZXlWYXVsdCkudG9CZUluc3RhbmNlT2YoS2V5VmF1bHQpO1xuICAgIH0pO1xuXG4gICAgaXQoXCJzaG91bGQgYWNjZXB0IHByZW1pdW0gU0tVXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IHJnID0gbmV3IFJlc291cmNlR3JvdXAoc3RhY2ssIFwiVGVzdFJHXCIsIHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LXJnXCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgfSk7XG5cbiAgICAgIGNvbnN0IHByb3BzOiBLZXlWYXVsdFByb3BzID0ge1xuICAgICAgICBuYW1lOiBcInRlc3Qta2V5dmF1bHQtMDA5XCIsXG4gICAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgICByZXNvdXJjZUdyb3VwSWQ6IHJnLmlkLFxuICAgICAgICB0ZW5hbnRJZDogXCIwMDAwMDAwMC0wMDAwLTAwMDAtMDAwMC0wMDAwMDAwMDAwMDBcIixcbiAgICAgICAgc2t1OiB7IG5hbWU6IFwicHJlbWl1bVwiIH0sXG4gICAgICB9O1xuXG4gICAgICBjb25zdCBrZXlWYXVsdCA9IG5ldyBLZXlWYXVsdChzdGFjaywgXCJUZXN0S3ZcIiwgcHJvcHMpO1xuXG4gICAgICBleHBlY3Qoa2V5VmF1bHQucHJvcHMuc2t1Py5uYW1lKS50b0JlKFwicHJlbWl1bVwiKTtcbiAgICB9KTtcbiAgfSk7XG5cbiAgZGVzY3JpYmUoXCJ0YWcgbWFuYWdlbWVudFwiLCAoKSA9PiB7XG4gICAgbGV0IGtleVZhdWx0OiBLZXlWYXVsdDtcblxuICAgIGJlZm9yZUVhY2goKCkgPT4ge1xuICAgICAgY29uc3QgcmcgPSBuZXcgUmVzb3VyY2VHcm91cChzdGFjaywgXCJUZXN0UkdcIiwge1xuICAgICAgICBuYW1lOiBcInRlc3QtcmdcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICB9KTtcblxuICAgICAgY29uc3QgcHJvcHM6IEtleVZhdWx0UHJvcHMgPSB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1rZXl2YXVsdC0wMTBcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogcmcuaWQsXG4gICAgICAgIHRlbmFudElkOiBcIjAwMDAwMDAwLTAwMDAtMDAwMC0wMDAwLTAwMDAwMDAwMDAwMFwiLFxuICAgICAgICB0YWdzOiB7XG4gICAgICAgICAgZW52aXJvbm1lbnQ6IFwidGVzdFwiLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICAgICAga2V5VmF1bHQgPSBuZXcgS2V5VmF1bHQoc3RhY2ssIFwiVGVzdEt2XCIsIHByb3BzKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGFkZCBhIHRhZ1wiLCAoKSA9PiB7XG4gICAgICBrZXlWYXVsdC5hZGRUYWcoXCJuZXdUYWdcIiwgXCJuZXdWYWx1ZVwiKTtcblxuICAgICAgZXhwZWN0KGtleVZhdWx0LnByb3BzLnRhZ3MhLm5ld1RhZykudG9CZShcIm5ld1ZhbHVlXCIpO1xuICAgICAgZXhwZWN0KGtleVZhdWx0LnByb3BzLnRhZ3MhLmVudmlyb25tZW50KS50b0JlKFwidGVzdFwiKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIHJlbW92ZSBhbiBleGlzdGluZyB0YWdcIiwgKCkgPT4ge1xuICAgICAga2V5VmF1bHQucmVtb3ZlVGFnKFwiZW52aXJvbm1lbnRcIik7XG5cbiAgICAgIGV4cGVjdChrZXlWYXVsdC5wcm9wcy50YWdzIS5lbnZpcm9ubWVudCkudG9CZVVuZGVmaW5lZCgpO1xuICAgIH0pO1xuICB9KTtcblxuICBkZXNjcmliZShcIkFQSSB2ZXJzaW9uaW5nXCIsICgpID0+IHtcbiAgICBpdChcInNob3VsZCB1c2UgZGVmYXVsdCB2ZXJzaW9uIHdoZW4gbm90IHNwZWNpZmllZFwiLCAoKSA9PiB7XG4gICAgICBjb25zdCByZyA9IG5ldyBSZXNvdXJjZUdyb3VwKHN0YWNrLCBcIlRlc3RSR1wiLCB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1yZ1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBwcm9wczogS2V5VmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LWtleXZhdWx0LTAxMVwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiByZy5pZCxcbiAgICAgICAgdGVuYW50SWQ6IFwiMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwXCIsXG4gICAgICB9O1xuXG4gICAgICBjb25zdCBrZXlWYXVsdCA9IG5ldyBLZXlWYXVsdChzdGFjaywgXCJUZXN0S3ZcIiwgcHJvcHMpO1xuXG4gICAgICBleHBlY3Qoa2V5VmF1bHQucmVzb2x2ZWRBcGlWZXJzaW9uKS50b0JlKFwiMjAyNC0xMS0wMVwiKTtcbiAgICB9KTtcblxuICAgIGl0KFwic2hvdWxkIGFjY2VwdCBzcGVjaWZpYyBBUEkgdmVyc2lvblwiLCAoKSA9PiB7XG4gICAgICBjb25zdCByZyA9IG5ldyBSZXNvdXJjZUdyb3VwKHN0YWNrLCBcIlRlc3RSR1wiLCB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1yZ1wiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgIH0pO1xuXG4gICAgICBjb25zdCBwcm9wczogS2V5VmF1bHRQcm9wcyA9IHtcbiAgICAgICAgbmFtZTogXCJ0ZXN0LWtleXZhdWx0LTAxMlwiLFxuICAgICAgICBsb2NhdGlvbjogXCJlYXN0dXNcIixcbiAgICAgICAgcmVzb3VyY2VHcm91cElkOiByZy5pZCxcbiAgICAgICAgdGVuYW50SWQ6IFwiMDAwMDAwMDAtMDAwMC0wMDAwLTAwMDAtMDAwMDAwMDAwMDAwXCIsXG4gICAgICAgIGFwaVZlcnNpb246IFwiMjAyMy0wNy0wMVwiLFxuICAgICAgfTtcblxuICAgICAgY29uc3Qga2V5VmF1bHQgPSBuZXcgS2V5VmF1bHQoc3RhY2ssIFwiVGVzdEt2XCIsIHByb3BzKTtcblxuICAgICAgZXhwZWN0KGtleVZhdWx0LnJlc29sdmVkQXBpVmVyc2lvbikudG9CZShcIjIwMjMtMDctMDFcIik7XG4gICAgfSk7XG4gIH0pO1xuXG4gIGRlc2NyaWJlKFwiQ0RLIFRlcnJhZm9ybSBpbnRlZ3JhdGlvblwiLCAoKSA9PiB7XG4gICAgaXQoXCJzaG91bGQgc3ludGhlc2l6ZSB0byB2YWxpZCBUZXJyYWZvcm1cIiwgKCkgPT4ge1xuICAgICAgY29uc3QgcmcgPSBuZXcgUmVzb3VyY2VHcm91cChzdGFjaywgXCJUZXN0UkdcIiwge1xuICAgICAgICBuYW1lOiBcInRlc3QtcmdcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICB9KTtcblxuICAgICAgY29uc3QgcHJvcHM6IEtleVZhdWx0UHJvcHMgPSB7XG4gICAgICAgIG5hbWU6IFwidGVzdC1rZXl2YXVsdC0wMTNcIixcbiAgICAgICAgbG9jYXRpb246IFwiZWFzdHVzXCIsXG4gICAgICAgIHJlc291cmNlR3JvdXBJZDogcmcuaWQsXG4gICAgICAgIHRlbmFudElkOiBcIjAwMDAwMDAwLTAwMDAtMDAwMC0wMDAwLTAwMDAwMDAwMDAwMFwiLFxuICAgICAgICB0YWdzOiB7XG4gICAgICAgICAgZW52aXJvbm1lbnQ6IFwidGVzdFwiLFxuICAgICAgICB9LFxuICAgICAgfTtcblxuICAgICAgbmV3IEtleVZhdWx0KHN0YWNrLCBcIlRlc3RLdlwiLCBwcm9wcyk7XG5cbiAgICAgIGNvbnN0IHN5bnRoZXNpemVkID0gVGVzdGluZy5zeW50aChzdGFjayk7XG4gICAgICBleHBlY3Qoc3ludGhlc2l6ZWQpLnRvQmVEZWZpbmVkKCk7XG5cbiAgICAgIGNvbnN0IHN0YWNrQ29uZmlnID0gSlNPTi5wYXJzZShzeW50aGVzaXplZCk7XG4gICAgICBleHBlY3Qoc3RhY2tDb25maWcucmVzb3VyY2UpLnRvQmVEZWZpbmVkKCk7XG4gICAgfSk7XG4gIH0pO1xufSk7XG4iXX0=
|
|
@@ -206,7 +206,7 @@ class LogAnalyticsWorkspace extends azapi_resource_1.AzapiResource {
|
|
|
206
206
|
}
|
|
207
207
|
exports.LogAnalyticsWorkspace = LogAnalyticsWorkspace;
|
|
208
208
|
_a = JSII_RTTI_SYMBOL_1;
|
|
209
|
-
LogAnalyticsWorkspace[_a] = { fqn: "@microsoft/terraform-cdk-constructs.LogAnalyticsWorkspace", version: "1.
|
|
209
|
+
LogAnalyticsWorkspace[_a] = { fqn: "@microsoft/terraform-cdk-constructs.LogAnalyticsWorkspace", version: "1.10.0" };
|
|
210
210
|
(() => {
|
|
211
211
|
azapi_resource_1.AzapiResource.registerSchemas(log_analytics_workspace_schemas_1.LOG_ANALYTICS_WORKSPACE_TYPE, log_analytics_workspace_schemas_1.ALL_LOG_ANALYTICS_WORKSPACE_VERSIONS);
|
|
212
212
|
})();
|
|
@@ -219,7 +219,7 @@ class MetricAlert extends azapi_resource_1.AzapiResource {
|
|
|
219
219
|
}
|
|
220
220
|
exports.MetricAlert = MetricAlert;
|
|
221
221
|
_a = JSII_RTTI_SYMBOL_1;
|
|
222
|
-
MetricAlert[_a] = { fqn: "@microsoft/terraform-cdk-constructs.MetricAlert", version: "1.
|
|
222
|
+
MetricAlert[_a] = { fqn: "@microsoft/terraform-cdk-constructs.MetricAlert", version: "1.10.0" };
|
|
223
223
|
(() => {
|
|
224
224
|
azapi_resource_1.AzapiResource.registerSchemas(metric_alert_schemas_1.METRIC_ALERT_TYPE, metric_alert_schemas_1.ALL_METRIC_ALERT_VERSIONS);
|
|
225
225
|
})();
|
|
@@ -206,7 +206,7 @@ class NetworkInterface extends azapi_resource_1.AzapiResource {
|
|
|
206
206
|
}
|
|
207
207
|
exports.NetworkInterface = NetworkInterface;
|
|
208
208
|
_a = JSII_RTTI_SYMBOL_1;
|
|
209
|
-
NetworkInterface[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkInterface", version: "1.
|
|
209
|
+
NetworkInterface[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkInterface", version: "1.10.0" };
|
|
210
210
|
(() => {
|
|
211
211
|
azapi_resource_1.AzapiResource.registerSchemas(network_interface_schemas_1.NETWORK_INTERFACE_TYPE, network_interface_schemas_1.ALL_NETWORK_INTERFACE_VERSIONS);
|
|
212
212
|
})();
|
|
@@ -219,7 +219,7 @@ class NetworkSecurityGroup extends azapi_resource_1.AzapiResource {
|
|
|
219
219
|
}
|
|
220
220
|
exports.NetworkSecurityGroup = NetworkSecurityGroup;
|
|
221
221
|
_a = JSII_RTTI_SYMBOL_1;
|
|
222
|
-
NetworkSecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkSecurityGroup", version: "1.
|
|
222
|
+
NetworkSecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkSecurityGroup", version: "1.10.0" };
|
|
223
223
|
(() => {
|
|
224
224
|
azapi_resource_1.AzapiResource.registerSchemas(network_security_group_schemas_1.NETWORK_SECURITY_GROUP_TYPE, network_security_group_schemas_1.ALL_NETWORK_SECURITY_GROUP_VERSIONS);
|
|
225
225
|
})();
|
|
@@ -180,7 +180,7 @@ class NetworkWatcher extends azapi_resource_1.AzapiResource {
|
|
|
180
180
|
}
|
|
181
181
|
exports.NetworkWatcher = NetworkWatcher;
|
|
182
182
|
_a = JSII_RTTI_SYMBOL_1;
|
|
183
|
-
NetworkWatcher[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkWatcher", version: "1.
|
|
183
|
+
NetworkWatcher[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkWatcher", version: "1.10.0" };
|
|
184
184
|
(() => {
|
|
185
185
|
azapi_resource_1.AzapiResource.registerSchemas(network_watcher_schemas_1.NETWORK_WATCHER_TYPE, network_watcher_schemas_1.ALL_NETWORK_WATCHER_VERSIONS);
|
|
186
186
|
})();
|
|
@@ -236,7 +236,7 @@ class PolicyAssignment extends azapi_resource_1.AzapiResource {
|
|
|
236
236
|
}
|
|
237
237
|
exports.PolicyAssignment = PolicyAssignment;
|
|
238
238
|
_a = JSII_RTTI_SYMBOL_1;
|
|
239
|
-
PolicyAssignment[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyAssignment", version: "1.
|
|
239
|
+
PolicyAssignment[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyAssignment", version: "1.10.0" };
|
|
240
240
|
(() => {
|
|
241
241
|
azapi_resource_1.AzapiResource.registerSchemas(policy_assignment_schemas_1.POLICY_ASSIGNMENT_TYPE, policy_assignment_schemas_1.ALL_POLICY_ASSIGNMENT_VERSIONS);
|
|
242
242
|
})();
|
|
@@ -260,7 +260,7 @@ class PolicyDefinition extends azapi_resource_1.AzapiResource {
|
|
|
260
260
|
}
|
|
261
261
|
exports.PolicyDefinition = PolicyDefinition;
|
|
262
262
|
_a = JSII_RTTI_SYMBOL_1;
|
|
263
|
-
PolicyDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyDefinition", version: "1.
|
|
263
|
+
PolicyDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicyDefinition", version: "1.10.0" };
|
|
264
264
|
(() => {
|
|
265
265
|
azapi_resource_1.AzapiResource.registerSchemas(policy_definition_schemas_1.POLICY_DEFINITION_TYPE, policy_definition_schemas_1.ALL_POLICY_DEFINITION_VERSIONS);
|
|
266
266
|
})();
|
|
@@ -248,7 +248,7 @@ class PolicySetDefinition extends azapi_resource_1.AzapiResource {
|
|
|
248
248
|
}
|
|
249
249
|
exports.PolicySetDefinition = PolicySetDefinition;
|
|
250
250
|
_a = JSII_RTTI_SYMBOL_1;
|
|
251
|
-
PolicySetDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicySetDefinition", version: "1.
|
|
251
|
+
PolicySetDefinition[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PolicySetDefinition", version: "1.10.0" };
|
|
252
252
|
(() => {
|
|
253
253
|
azapi_resource_1.AzapiResource.registerSchemas(policy_set_definition_schemas_1.POLICY_SET_DEFINITION_TYPE, policy_set_definition_schemas_1.ALL_POLICY_SET_DEFINITION_VERSIONS);
|
|
254
254
|
})();
|
|
@@ -257,7 +257,7 @@ class PrivateDnsZone extends azapi_resource_1.AzapiResource {
|
|
|
257
257
|
}
|
|
258
258
|
exports.PrivateDnsZone = PrivateDnsZone;
|
|
259
259
|
_a = JSII_RTTI_SYMBOL_1;
|
|
260
|
-
PrivateDnsZone[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsZone", version: "1.
|
|
260
|
+
PrivateDnsZone[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsZone", version: "1.10.0" };
|
|
261
261
|
// Static initializer runs once when the class is first loaded
|
|
262
262
|
(() => {
|
|
263
263
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_zone_schemas_1.PRIVATE_DNS_ZONE_TYPE, private_dns_zone_schemas_1.ALL_PRIVATE_DNS_ZONE_VERSIONS);
|
|
@@ -104,7 +104,7 @@ class PrivateDnsARecord extends azapi_resource_1.AzapiResource {
|
|
|
104
104
|
}
|
|
105
105
|
exports.PrivateDnsARecord = PrivateDnsARecord;
|
|
106
106
|
_a = JSII_RTTI_SYMBOL_1;
|
|
107
|
-
PrivateDnsARecord[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsARecord", version: "1.
|
|
107
|
+
PrivateDnsARecord[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsARecord", version: "1.10.0" };
|
|
108
108
|
(() => {
|
|
109
109
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_A_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_A_RECORD_VERSIONS);
|
|
110
110
|
})();
|
|
@@ -190,7 +190,7 @@ class PrivateDnsAaaaRecord extends azapi_resource_1.AzapiResource {
|
|
|
190
190
|
}
|
|
191
191
|
exports.PrivateDnsAaaaRecord = PrivateDnsAaaaRecord;
|
|
192
192
|
_b = JSII_RTTI_SYMBOL_1;
|
|
193
|
-
PrivateDnsAaaaRecord[_b] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsAaaaRecord", version: "1.
|
|
193
|
+
PrivateDnsAaaaRecord[_b] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsAaaaRecord", version: "1.10.0" };
|
|
194
194
|
(() => {
|
|
195
195
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_AAAA_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_AAAA_RECORD_VERSIONS);
|
|
196
196
|
})();
|
|
@@ -275,7 +275,7 @@ class PrivateDnsCnameRecord extends azapi_resource_1.AzapiResource {
|
|
|
275
275
|
}
|
|
276
276
|
exports.PrivateDnsCnameRecord = PrivateDnsCnameRecord;
|
|
277
277
|
_c = JSII_RTTI_SYMBOL_1;
|
|
278
|
-
PrivateDnsCnameRecord[_c] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsCnameRecord", version: "1.
|
|
278
|
+
PrivateDnsCnameRecord[_c] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsCnameRecord", version: "1.10.0" };
|
|
279
279
|
(() => {
|
|
280
280
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_CNAME_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_CNAME_RECORD_VERSIONS);
|
|
281
281
|
})();
|
|
@@ -363,7 +363,7 @@ class PrivateDnsMxRecord extends azapi_resource_1.AzapiResource {
|
|
|
363
363
|
}
|
|
364
364
|
exports.PrivateDnsMxRecord = PrivateDnsMxRecord;
|
|
365
365
|
_d = JSII_RTTI_SYMBOL_1;
|
|
366
|
-
PrivateDnsMxRecord[_d] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsMxRecord", version: "1.
|
|
366
|
+
PrivateDnsMxRecord[_d] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsMxRecord", version: "1.10.0" };
|
|
367
367
|
(() => {
|
|
368
368
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_MX_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_MX_RECORD_VERSIONS);
|
|
369
369
|
})();
|
|
@@ -447,7 +447,7 @@ class PrivateDnsPtrRecord extends azapi_resource_1.AzapiResource {
|
|
|
447
447
|
}
|
|
448
448
|
exports.PrivateDnsPtrRecord = PrivateDnsPtrRecord;
|
|
449
449
|
_e = JSII_RTTI_SYMBOL_1;
|
|
450
|
-
PrivateDnsPtrRecord[_e] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsPtrRecord", version: "1.
|
|
450
|
+
PrivateDnsPtrRecord[_e] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsPtrRecord", version: "1.10.0" };
|
|
451
451
|
(() => {
|
|
452
452
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_PTR_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_PTR_RECORD_VERSIONS);
|
|
453
453
|
})();
|
|
@@ -558,7 +558,7 @@ class PrivateDnsSoaRecord extends azapi_resource_1.AzapiResource {
|
|
|
558
558
|
}
|
|
559
559
|
exports.PrivateDnsSoaRecord = PrivateDnsSoaRecord;
|
|
560
560
|
_f = JSII_RTTI_SYMBOL_1;
|
|
561
|
-
PrivateDnsSoaRecord[_f] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsSoaRecord", version: "1.
|
|
561
|
+
PrivateDnsSoaRecord[_f] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsSoaRecord", version: "1.10.0" };
|
|
562
562
|
(() => {
|
|
563
563
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_SOA_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_SOA_RECORD_VERSIONS);
|
|
564
564
|
})();
|
|
@@ -648,7 +648,7 @@ class PrivateDnsSrvRecord extends azapi_resource_1.AzapiResource {
|
|
|
648
648
|
}
|
|
649
649
|
exports.PrivateDnsSrvRecord = PrivateDnsSrvRecord;
|
|
650
650
|
_g = JSII_RTTI_SYMBOL_1;
|
|
651
|
-
PrivateDnsSrvRecord[_g] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsSrvRecord", version: "1.
|
|
651
|
+
PrivateDnsSrvRecord[_g] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsSrvRecord", version: "1.10.0" };
|
|
652
652
|
(() => {
|
|
653
653
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_SRV_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_SRV_RECORD_VERSIONS);
|
|
654
654
|
})();
|
|
@@ -732,7 +732,7 @@ class PrivateDnsTxtRecord extends azapi_resource_1.AzapiResource {
|
|
|
732
732
|
}
|
|
733
733
|
exports.PrivateDnsTxtRecord = PrivateDnsTxtRecord;
|
|
734
734
|
_h = JSII_RTTI_SYMBOL_1;
|
|
735
|
-
PrivateDnsTxtRecord[_h] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsTxtRecord", version: "1.
|
|
735
|
+
PrivateDnsTxtRecord[_h] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsTxtRecord", version: "1.10.0" };
|
|
736
736
|
(() => {
|
|
737
737
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_record_schemas_1.PRIVATE_DNS_TXT_RECORD_TYPE, private_dns_record_schemas_1.ALL_PRIVATE_DNS_TXT_RECORD_VERSIONS);
|
|
738
738
|
})();
|
|
@@ -243,7 +243,7 @@ class PrivateDnsZoneLink extends azapi_resource_1.AzapiResource {
|
|
|
243
243
|
}
|
|
244
244
|
exports.PrivateDnsZoneLink = PrivateDnsZoneLink;
|
|
245
245
|
_a = JSII_RTTI_SYMBOL_1;
|
|
246
|
-
PrivateDnsZoneLink[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsZoneLink", version: "1.
|
|
246
|
+
PrivateDnsZoneLink[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PrivateDnsZoneLink", version: "1.10.0" };
|
|
247
247
|
(() => {
|
|
248
248
|
azapi_resource_1.AzapiResource.registerSchemas(private_dns_zone_link_schemas_1.PRIVATE_DNS_ZONE_LINK_TYPE, private_dns_zone_link_schemas_1.ALL_PRIVATE_DNS_ZONE_LINK_VERSIONS);
|
|
249
249
|
})();
|
|
@@ -238,7 +238,7 @@ class PublicIPAddress extends azapi_resource_1.AzapiResource {
|
|
|
238
238
|
}
|
|
239
239
|
exports.PublicIPAddress = PublicIPAddress;
|
|
240
240
|
_a = JSII_RTTI_SYMBOL_1;
|
|
241
|
-
PublicIPAddress[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PublicIPAddress", version: "1.
|
|
241
|
+
PublicIPAddress[_a] = { fqn: "@microsoft/terraform-cdk-constructs.PublicIPAddress", version: "1.10.0" };
|
|
242
242
|
(() => {
|
|
243
243
|
azapi_resource_1.AzapiResource.registerSchemas(public_ip_address_schemas_1.PUBLIC_IP_ADDRESS_TYPE, public_ip_address_schemas_1.ALL_PUBLIC_IP_ADDRESS_VERSIONS);
|
|
244
244
|
})();
|
|
@@ -194,7 +194,7 @@ class ResourceGroup extends azapi_resource_1.AzapiResource {
|
|
|
194
194
|
}
|
|
195
195
|
exports.ResourceGroup = ResourceGroup;
|
|
196
196
|
_a = JSII_RTTI_SYMBOL_1;
|
|
197
|
-
ResourceGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.ResourceGroup", version: "1.
|
|
197
|
+
ResourceGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.ResourceGroup", version: "1.10.0" };
|
|
198
198
|
// Static initializer runs once when the class is first loaded
|
|
199
199
|
(() => {
|
|
200
200
|
azapi_resource_1.AzapiResource.registerSchemas(resource_group_schemas_1.RESOURCE_GROUP_TYPE, resource_group_schemas_1.ALL_RESOURCE_GROUP_VERSIONS);
|