@microsoft/terraform-cdk-constructs 0.0.3-pre.6 → 0.0.3-pre.7
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 +909 -306
- package/API.md +2488 -255
- package/README.md +112 -18
- package/docs/images/ide-documentation.png +0 -0
- package/lib/azure-actiongroup/lib/actiongroup.d.ts +39 -0
- package/lib/azure-actiongroup/lib/actiongroup.js +40 -1
- package/lib/azure-applicationgateway/lib/gateway.d.ts +76 -0
- package/lib/azure-applicationgateway/lib/gateway.js +78 -2
- package/lib/azure-applicationinsights/lib/appinsights.d.ts +50 -0
- package/lib/azure-applicationinsights/lib/appinsights.js +52 -3
- package/lib/azure-containerregistry/lib/registry.d.ts +29 -0
- package/lib/azure-containerregistry/lib/registry.js +31 -2
- package/lib/azure-datalake/lib/datalake.d.ts +50 -0
- package/lib/azure-datalake/lib/datalake.js +51 -1
- package/lib/azure-datalake/lib/filesystem.d.ts +51 -0
- package/lib/azure-datalake/lib/filesystem.js +52 -1
- package/lib/azure-datalake/lib/path.d.ts +37 -0
- package/lib/azure-datalake/lib/path.js +38 -1
- package/lib/azure-eventhub/lib/authorization.d.ts +30 -0
- package/lib/azure-eventhub/lib/authorization.js +32 -2
- package/lib/azure-eventhub/lib/cluster.d.ts +29 -0
- package/lib/azure-eventhub/lib/cluster.js +31 -2
- package/lib/azure-eventhub/lib/consumer.d.ts +28 -0
- package/lib/azure-eventhub/lib/consumer.js +30 -2
- package/lib/azure-eventhub/lib/instance.d.ts +118 -0
- package/lib/azure-eventhub/lib/instance.js +120 -2
- package/lib/azure-eventhub/lib/kusto-connection.d.ts +41 -0
- package/lib/azure-eventhub/lib/kusto-connection.js +43 -2
- package/lib/azure-eventhub/lib/namespace.d.ts +74 -0
- package/lib/azure-eventhub/lib/namespace.js +76 -3
- package/lib/azure-functionapp/lib/functionapplinux.js +1 -1
- package/lib/azure-keyvault/lib/certificate.d.ts +96 -2
- package/lib/azure-keyvault/lib/certificate.js +55 -3
- package/lib/azure-keyvault/lib/key.d.ts +36 -0
- package/lib/azure-keyvault/lib/key.js +38 -2
- package/lib/azure-keyvault/lib/policy.d.ts +30 -0
- package/lib/azure-keyvault/lib/policy.js +32 -2
- package/lib/azure-keyvault/lib/secret.d.ts +31 -0
- package/lib/azure-keyvault/lib/secret.js +33 -2
- package/lib/azure-keyvault/lib/vault.d.ts +188 -0
- package/lib/azure-keyvault/lib/vault.js +191 -7
- package/lib/azure-kubernetes/lib/cluster.d.ts +25 -4
- package/lib/azure-kubernetes/lib/cluster.js +27 -6
- package/lib/azure-kusto/lib/cluster.d.ts +53 -0
- package/lib/azure-kusto/lib/cluster.js +55 -2
- package/lib/azure-kusto/lib/compute-specification.js +1 -1
- package/lib/azure-kusto/lib/database.d.ts +103 -0
- package/lib/azure-kusto/lib/database.js +105 -2
- package/lib/azure-loganalytics/lib/workspace.d.ts +47 -0
- package/lib/azure-loganalytics/lib/workspace.js +49 -2
- package/lib/azure-metricalert/lib/metric-alert.d.ts +43 -4
- package/lib/azure-metricalert/lib/metric-alert.js +45 -6
- package/lib/azure-networksecuritygroup/lib/preconfigured-rules.js +1 -1
- package/lib/azure-networksecuritygroup/lib/securitygroup.d.ts +92 -0
- package/lib/azure-networksecuritygroup/lib/securitygroup.js +95 -5
- package/lib/azure-queryrulealert/lib/query-rule-alert.d.ts +35 -4
- package/lib/azure-queryrulealert/lib/query-rule-alert.js +37 -6
- package/lib/azure-resourcegroup/lib/resource-group.d.ts +28 -0
- package/lib/azure-resourcegroup/lib/resource-group.js +30 -2
- package/lib/azure-storageaccount/lib/account.d.ts +75 -48
- package/lib/azure-storageaccount/lib/account.js +77 -50
- package/lib/azure-storageaccount/lib/container.d.ts +94 -12
- package/lib/azure-storageaccount/lib/container.js +97 -15
- package/lib/azure-storageaccount/lib/fileshare.d.ts +36 -0
- package/lib/azure-storageaccount/lib/fileshare.js +39 -3
- package/lib/azure-storageaccount/lib/queue.d.ts +29 -0
- package/lib/azure-storageaccount/lib/queue.js +31 -2
- package/lib/azure-storageaccount/lib/table.d.ts +32 -0
- package/lib/azure-storageaccount/lib/table.js +34 -2
- package/lib/azure-virtualmachine/lib/image-references.js +2 -2
- package/lib/azure-virtualmachine/lib/vm.d.ts +84 -8
- package/lib/azure-virtualmachine/lib/vm.js +87 -11
- package/lib/azure-virtualmachinescaleset/lib/cluster.d.ts +98 -8
- package/lib/azure-virtualmachinescaleset/lib/cluster.js +101 -11
- package/lib/azure-virtualnetwork/lib/network.d.ts +61 -0
- package/lib/azure-virtualnetwork/lib/network.js +63 -3
- package/lib/azure-virtualnetwork/lib/peering.d.ts +39 -0
- package/lib/azure-virtualnetwork/lib/peering.js +41 -2
- package/lib/core-azure/lib/diagsettings.d.ts +37 -0
- package/lib/core-azure/lib/diagsettings.js +39 -2
- package/lib/core-azure/lib/rbac.d.ts +22 -4
- package/lib/core-azure/lib/rbac.js +24 -6
- package/lib/core-azure/lib/resource.d.ts +45 -0
- package/lib/core-azure/lib/resource.js +48 -4
- package/package.json +1 -1
|
@@ -11,6 +11,32 @@ const policy_1 = require("./policy");
|
|
|
11
11
|
const secret_1 = require("./secret");
|
|
12
12
|
const lib_1 = require("../../core-azure/lib");
|
|
13
13
|
class Vault extends lib_1.AzureResource {
|
|
14
|
+
/**
|
|
15
|
+
* Constructs a new Azure Key Vault resource.
|
|
16
|
+
*
|
|
17
|
+
* This class creates and configures an Azure Key Vault, a secure store for managing secrets, keys, certificates, and other sensitive data.
|
|
18
|
+
* It supports advanced configurations such as access policies, network rules, and data retention policies.
|
|
19
|
+
*
|
|
20
|
+
* @param scope - The scope in which to define this construct, usually representing the Cloud Development Kit (CDK) stack.
|
|
21
|
+
* @param id - The unique identifier for this instance of the Key Vault.
|
|
22
|
+
* @param props - The properties for creating the Key Vault as defined in VaultProps. These include settings for location, SKU, tenant ID, etc.
|
|
23
|
+
*
|
|
24
|
+
* Example usage:
|
|
25
|
+
* ```typescript
|
|
26
|
+
* new Vault(this, 'MyKeyVault', {
|
|
27
|
+
* name: 'mySecureVault',
|
|
28
|
+
* location: 'East US',
|
|
29
|
+
* resourceGroup: myResourceGroup,
|
|
30
|
+
* sku: 'premium',
|
|
31
|
+
* tenantId: 'my-tenant-id',
|
|
32
|
+
* softDeleteRetentionDays: 90,
|
|
33
|
+
* purgeProtection: true,
|
|
34
|
+
* tags: {
|
|
35
|
+
* project: 'My Application'
|
|
36
|
+
* }
|
|
37
|
+
* });
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
14
40
|
constructor(scope, id, props) {
|
|
15
41
|
super(scope, id);
|
|
16
42
|
this.accessPolicies = [];
|
|
@@ -45,7 +71,11 @@ class Vault extends lib_1.AzureResource {
|
|
|
45
71
|
/*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/
|
|
46
72
|
cdktfTerraformOutputKeyVaultname.overrideLogicalId("key_vault_name");
|
|
47
73
|
}
|
|
48
|
-
|
|
74
|
+
/**
|
|
75
|
+
* Grants read-only access to secrets stored in the Key Vault to a specified Azure AD group.
|
|
76
|
+
*
|
|
77
|
+
* @param azureAdGroupId - The Azure Active Directory group ID that will receive read access to secrets.
|
|
78
|
+
*/
|
|
49
79
|
grantSecretReaderAccess(azureAdGroupId) {
|
|
50
80
|
const policyProps = {
|
|
51
81
|
keyVaultId: this,
|
|
@@ -56,6 +86,11 @@ class Vault extends lib_1.AzureResource {
|
|
|
56
86
|
const policy = new policy_1.AccessPolicy(this, `kv_secret_reader_access_${azureAdGroupId}`, policyProps);
|
|
57
87
|
this.accessPolicies.push(policy);
|
|
58
88
|
}
|
|
89
|
+
/**
|
|
90
|
+
* Grants administrative access to secrets stored in the Key Vault to a specified Azure AD group.
|
|
91
|
+
*
|
|
92
|
+
* @param azureAdGroupId - The Azure Active Directory group ID that will receive administrative access to secrets.
|
|
93
|
+
*/
|
|
59
94
|
grantSecretAdminAccess(azureAdGroupId) {
|
|
60
95
|
const policyProps = {
|
|
61
96
|
keyVaultId: this,
|
|
@@ -74,6 +109,11 @@ class Vault extends lib_1.AzureResource {
|
|
|
74
109
|
const policy = new policy_1.AccessPolicy(this, `kv_secret_admin_access_${azureAdGroupId}`, policyProps);
|
|
75
110
|
this.accessPolicies.push(policy);
|
|
76
111
|
}
|
|
112
|
+
/**
|
|
113
|
+
* Grants administrative access to certificates stored in the Key Vault to a specified Azure AD group.
|
|
114
|
+
*
|
|
115
|
+
* @param azureAdGroupId - The Azure Active Directory group ID that will receive administrative access to certificates.
|
|
116
|
+
*/
|
|
77
117
|
grantCertAdminAccess(azureAdGroupId) {
|
|
78
118
|
const policyProps = {
|
|
79
119
|
keyVaultId: this,
|
|
@@ -92,6 +132,11 @@ class Vault extends lib_1.AzureResource {
|
|
|
92
132
|
const policy = new policy_1.AccessPolicy(this, `kv_cert_admin_access_${azureAdGroupId}`, policyProps);
|
|
93
133
|
this.accessPolicies.push(policy);
|
|
94
134
|
}
|
|
135
|
+
/**
|
|
136
|
+
* Grants read-only access to certificates stored in the Key Vault to a specified Azure AD group.
|
|
137
|
+
*
|
|
138
|
+
* @param azureAdGroupId - The Azure Active Directory group ID that will receive read access to certificates.
|
|
139
|
+
*/
|
|
95
140
|
grantCertReaderAccess(azureAdGroupId) {
|
|
96
141
|
const policyProps = {
|
|
97
142
|
keyVaultId: this,
|
|
@@ -102,6 +147,11 @@ class Vault extends lib_1.AzureResource {
|
|
|
102
147
|
const policy = new policy_1.AccessPolicy(this, `kv_cert_reader_access_${azureAdGroupId}`, policyProps);
|
|
103
148
|
this.accessPolicies.push(policy);
|
|
104
149
|
}
|
|
150
|
+
/**
|
|
151
|
+
* Grants administrative access to keys stored in the Key Vault to a specified Azure AD group.
|
|
152
|
+
*
|
|
153
|
+
* @param azureAdGroupId - The Azure Active Directory group ID that will receive administrative access to keys.
|
|
154
|
+
*/
|
|
105
155
|
grantKeyAdminAccess(azureAdGroupId) {
|
|
106
156
|
const policyProps = {
|
|
107
157
|
keyVaultId: this,
|
|
@@ -120,16 +170,27 @@ class Vault extends lib_1.AzureResource {
|
|
|
120
170
|
const policy = new policy_1.AccessPolicy(this, `kv_key_admin_access_${azureAdGroupId}`, policyProps);
|
|
121
171
|
this.accessPolicies.push(policy);
|
|
122
172
|
}
|
|
173
|
+
/**
|
|
174
|
+
* Grants read-only access to keys stored in the Key Vault to a specified Azure AD group.
|
|
175
|
+
*
|
|
176
|
+
* @param azureAdGroupId - The Azure Active Directory group ID that will receive read access to keys.
|
|
177
|
+
*/
|
|
123
178
|
grantKeyReaderAccess(azureAdGroupId) {
|
|
124
179
|
const policyProps = {
|
|
125
180
|
keyVaultId: this,
|
|
126
181
|
tenantId: this.props.tenantId,
|
|
127
182
|
objectId: azureAdGroupId,
|
|
128
|
-
|
|
183
|
+
keyPermissions: ["Get", "List"],
|
|
129
184
|
};
|
|
130
185
|
const policy = new policy_1.AccessPolicy(this, `kv_key_reader_access_${azureAdGroupId}`, policyProps);
|
|
131
186
|
this.accessPolicies.push(policy);
|
|
132
187
|
}
|
|
188
|
+
/**
|
|
189
|
+
* Grants custom access based on specified options to an Azure AD group in the Key Vault.
|
|
190
|
+
*
|
|
191
|
+
* @param azureAdGroupId - The Azure Active Directory group ID that will receive the custom access.
|
|
192
|
+
* @param options - Custom access options specifying various permissions for secrets, keys, certificates, and storage.
|
|
193
|
+
*/
|
|
133
194
|
grantCustomAccess(azureAdGroupId, options) {
|
|
134
195
|
const policyProps = {
|
|
135
196
|
keyVaultId: this,
|
|
@@ -140,7 +201,32 @@ class Vault extends lib_1.AzureResource {
|
|
|
140
201
|
const policy = new policy_1.AccessPolicy(this, `kv_custom_policy_access_${azureAdGroupId}`, policyProps);
|
|
141
202
|
this.accessPolicies.push(policy);
|
|
142
203
|
}
|
|
143
|
-
|
|
204
|
+
/**
|
|
205
|
+
* Creates a new secret within the Azure Key Vault.
|
|
206
|
+
*
|
|
207
|
+
* This method facilitates the storage of sensitive information in the form of a secret within the Key Vault.
|
|
208
|
+
* Secrets are protected items such as passwords, database connection strings, or any other piece of information
|
|
209
|
+
* that needs to be securely stored and accessed. This method allows setting additional properties such as
|
|
210
|
+
* expiration date and content type for better management and compliance.
|
|
211
|
+
*
|
|
212
|
+
* @param keyVaultSecretName - The unique name for the secret within the Key Vault.
|
|
213
|
+
* @param secretValue - The sensitive information or data that needs to be securely stored as a secret.
|
|
214
|
+
* @param expirationDate - Optional. The expiration date of the secret in ISO 8601 format (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ).
|
|
215
|
+
* If provided, the secret will no longer be valid after this date.
|
|
216
|
+
* @param contentType - Optional. A description of the type of information the secret contains (e.g., 'password', 'connectionString').
|
|
217
|
+
* This can be used by applications to handle the secret appropriately.
|
|
218
|
+
*
|
|
219
|
+
* Example usage:
|
|
220
|
+
* ```typescript
|
|
221
|
+
* vault.addSecret(
|
|
222
|
+
* 'myDatabasePassword',
|
|
223
|
+
* 'p@ssw0rd123!',
|
|
224
|
+
* '2030-01-01',
|
|
225
|
+
* 'databasePassword'
|
|
226
|
+
* );
|
|
227
|
+
* ```
|
|
228
|
+
* This method does not return a value. It creates a secret within the Key Vault with the specified properties.
|
|
229
|
+
*/
|
|
144
230
|
addSecret(keyVaultSecretName, secretValue, expirationDate, contentType) {
|
|
145
231
|
const secretProps = {
|
|
146
232
|
keyVaultId: this,
|
|
@@ -152,7 +238,28 @@ class Vault extends lib_1.AzureResource {
|
|
|
152
238
|
};
|
|
153
239
|
new secret_1.Secret(this, keyVaultSecretName, secretProps);
|
|
154
240
|
}
|
|
155
|
-
|
|
241
|
+
/**
|
|
242
|
+
* Creates an RSA cryptographic key within the Azure Key Vault.
|
|
243
|
+
*
|
|
244
|
+
* This method facilitates the creation of an RSA key, which is useful for a variety of cryptographic operations such as
|
|
245
|
+
* encryption, decryption, digital signature verification, and more. The RSA key created by this method is configurable
|
|
246
|
+
* with an optional expiration date and a default key size of 2048 bits. The key operations allowed include decryption,
|
|
247
|
+
* encryption, signing, verifying signatures, and key wrapping/unwrapping.
|
|
248
|
+
*
|
|
249
|
+
* @param keyVaultKeyName - The unique name for the RSA key within the Key Vault.
|
|
250
|
+
* @param expirationDate - Optional. The expiration date of the key in ISO 8601 format (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ).
|
|
251
|
+
* If provided, the key will no longer be valid after this date.
|
|
252
|
+
* @returns A KeyVaultKey object representing the newly created RSA key within the vault.
|
|
253
|
+
*
|
|
254
|
+
* Example usage:
|
|
255
|
+
* ```typescript
|
|
256
|
+
* const rsaKey = vault.addRSAKey(
|
|
257
|
+
* 'myRSAKey',
|
|
258
|
+
* '2030-01-01'
|
|
259
|
+
* );
|
|
260
|
+
* ```
|
|
261
|
+
* This method returns the created KeyVaultKey object, allowing further operations or references to the key.
|
|
262
|
+
*/
|
|
156
263
|
addRSAKey(keyVaultKeyName, expirationDate) {
|
|
157
264
|
const keyProps = {
|
|
158
265
|
keyVaultId: this,
|
|
@@ -166,6 +273,35 @@ class Vault extends lib_1.AzureResource {
|
|
|
166
273
|
const key = new key_1.Key(this, keyVaultKeyName, keyProps);
|
|
167
274
|
return key.vaultKey;
|
|
168
275
|
}
|
|
276
|
+
/**
|
|
277
|
+
* Creates a cryptographic key within the Azure Key Vault.
|
|
278
|
+
*
|
|
279
|
+
* This method allows the creation of a cryptographic key of specified type and size within the Key Vault. The key can be
|
|
280
|
+
* configured with specific operations it can perform, such as encryption, decryption, signing, etc. An optional expiration
|
|
281
|
+
* date can also be set to control the key's lifecycle. This method is flexible, supporting various key types and sizes,
|
|
282
|
+
* making it suitable for a wide range of cryptographic needs.
|
|
283
|
+
*
|
|
284
|
+
* @param keyVaultKeyName - The unique name for the cryptographic key within the Key Vault.
|
|
285
|
+
* @param keyType - The type of cryptographic key to create (e.g., 'RSA', 'EC', 'oct-HSM').
|
|
286
|
+
* @param keySize - The size of the cryptographic key in bits (e.g., 2048, 3072, 4096 for RSA).
|
|
287
|
+
* @param keyOpts - A list of cryptographic operations that the key is allowed to perform. Possible values might include
|
|
288
|
+
* 'encrypt', 'decrypt', 'sign', 'verify', 'wrapKey', 'unwrapKey'.
|
|
289
|
+
* @param expirationDate - Optional. The expiration date of the key in ISO 8601 format (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ).
|
|
290
|
+
* If provided, the key will no longer be valid after this date, aligning with best practices for key management.
|
|
291
|
+
* @returns A KeyVaultKey object representing the newly created cryptographic key within the vault.
|
|
292
|
+
*
|
|
293
|
+
* Example usage:
|
|
294
|
+
* ```typescript
|
|
295
|
+
* const myKey = vault.addKey(
|
|
296
|
+
* 'myKey',
|
|
297
|
+
* 'RSA',
|
|
298
|
+
* 2048,
|
|
299
|
+
* ['encrypt', 'decrypt', 'sign', 'verify'],
|
|
300
|
+
* '2030-12-31'
|
|
301
|
+
* );
|
|
302
|
+
* ```
|
|
303
|
+
* This method returns the created KeyVaultKey object, enabling immediate use within the application for cryptographic operations.
|
|
304
|
+
*/
|
|
169
305
|
addKey(keyVaultKeyName, keyType, keySize, keyOpts, expirationDate) {
|
|
170
306
|
const keyProps = {
|
|
171
307
|
keyVaultId: this,
|
|
@@ -179,7 +315,34 @@ class Vault extends lib_1.AzureResource {
|
|
|
179
315
|
const key = new key_1.Key(this, keyVaultKeyName, keyProps);
|
|
180
316
|
return key.vaultKey;
|
|
181
317
|
}
|
|
182
|
-
|
|
318
|
+
/**
|
|
319
|
+
* Creates a self-signed certificate within the Azure Key Vault.
|
|
320
|
+
*
|
|
321
|
+
* This method facilitates the creation of a self-signed certificate, which is a digital certificate that is signed by
|
|
322
|
+
* its own creator rather than a trusted authority. Self-signed certificates can be useful for testing, internal
|
|
323
|
+
* communications, or any scenario where public trust is not required. The method allows specifying subject details,
|
|
324
|
+
* DNS names for the certificate, and managing its lifecycle with action types and expiry.
|
|
325
|
+
*
|
|
326
|
+
* @param certName - The unique name for the certificate within the Key Vault.
|
|
327
|
+
* @param subject - The subject name of the certificate, typically formatted as an X.500 Distinguished Name (e.g., "CN=example.com").
|
|
328
|
+
* @param dnsNames - An array of DNS names that should be associated with this certificate. This is useful for certificates
|
|
329
|
+
* that need to be valid for multiple hostnames.
|
|
330
|
+
* @param actionType - Optional. Specifies the action to be performed with the certificate, such as 'create' or 'renew'.
|
|
331
|
+
* @param daysBeforeExpiry - Optional. Number of days before expiry when an action should be taken, useful for auto-renewal scenarios.
|
|
332
|
+
* @returns A KeyVaultCertificate object representing the newly created self-signed certificate.
|
|
333
|
+
*
|
|
334
|
+
* Example usage:
|
|
335
|
+
* ```typescript
|
|
336
|
+
* const myCertificate = vault.addSelfSignedCert(
|
|
337
|
+
* 'myCert',
|
|
338
|
+
* 'CN=mydomain.com',
|
|
339
|
+
* ['mydomain.com', 'www.mydomain.com'],
|
|
340
|
+
* 'create',
|
|
341
|
+
* 30
|
|
342
|
+
* );
|
|
343
|
+
* ```
|
|
344
|
+
* This method returns the KeyVaultCertificate object, enabling it to be used immediately within the application or stored for future use.
|
|
345
|
+
*/
|
|
183
346
|
addSelfSignedCert(certName, subject, dnsNames, actionType, daysBeforeExpiry) {
|
|
184
347
|
const keyProps = {
|
|
185
348
|
keyVaultId: this,
|
|
@@ -193,6 +356,27 @@ class Vault extends lib_1.AzureResource {
|
|
|
193
356
|
const cert = new certificate_1.SelfSignedCertificate(this, certName, keyProps);
|
|
194
357
|
return cert.certificate;
|
|
195
358
|
}
|
|
359
|
+
/**
|
|
360
|
+
* Adds a certificate issuer to the Azure Key Vault.
|
|
361
|
+
*
|
|
362
|
+
* This method configures a certificate issuer within the Key Vault, allowing the Key Vault to issue certificates
|
|
363
|
+
* through external providers. Configuring an issuer is essential for enabling automated certificate management
|
|
364
|
+
* processes, such as issuance and renewal, directly through the Key Vault with a specified Certificate Authority (CA).
|
|
365
|
+
*
|
|
366
|
+
* @param name - The unique name for the certificate issuer within the Key Vault.
|
|
367
|
+
* @param provider - The name of the external provider that will issue the certificates, such as 'DigiCert' or 'GlobalSign'.
|
|
368
|
+
*
|
|
369
|
+
* Example usage:
|
|
370
|
+
* ```typescript
|
|
371
|
+
* vault.addCertIssuer(
|
|
372
|
+
* 'myCertIssuer',
|
|
373
|
+
* 'DigiCert'
|
|
374
|
+
* );
|
|
375
|
+
* ```
|
|
376
|
+
* This method configures a certificate issuer but does not return any value. The issuer details, including provider name
|
|
377
|
+
* and any necessary credentials (managed externally or through additional method parameters), are set up in the Key Vault
|
|
378
|
+
* for future certificate operations.
|
|
379
|
+
*/
|
|
196
380
|
addCertIssuer(name, provider) {
|
|
197
381
|
new certificate_1.CertificateIssuer(this, name, {
|
|
198
382
|
name: name,
|
|
@@ -204,5 +388,5 @@ class Vault extends lib_1.AzureResource {
|
|
|
204
388
|
}
|
|
205
389
|
exports.Vault = Vault;
|
|
206
390
|
_a = JSII_RTTI_SYMBOL_1;
|
|
207
|
-
Vault[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_keyvault.Vault", version: "0.0.3-pre.
|
|
208
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vault.js","sourceRoot":"","sources":["../../../src/azure-keyvault/lib/vault.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  KeyVault,\n  KeyVaultNetworkAcls,\n} from \"@cdktf/provider-azurerm/lib/key-vault\";\nimport { KeyVaultCertificate } from \"@cdktf/provider-azurerm/lib/key-vault-certificate\"; // Adjust the import path based on the actual module location.\nimport { KeyVaultKey } from \"@cdktf/provider-azurerm/lib/key-vault-key\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  CertificateIssuer,\n  SelfSignedCertificate,\n  SelfSignedCertificateProps,\n} from \"./certificate\";\nimport { Key, KeyProps } from \"./key\";\nimport { AccessPolicy, AccessPolicyProps } from \"./policy\";\nimport { Secret, SecretProps } from \"./secret\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\nexport interface VaultProps {\n  /**\n   * The name of the Key Vault.\n   */\n  readonly name: string;\n  /**\n   * The Azure Region to deploy the Key Vault.\n   */\n  readonly location: string;\n  /**\n   * The name of the Azure Resource Group.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The tags to assign to the Key Vault.\n   */\n  readonly tags?: { [key: string]: string };\n  /**\n   * The tags to assign to the Key Vault.\n   */\n  readonly sku?: string;\n  /**\n   * The Name of the SKU used for this Key Vault. Possible values are standard and premium.\n   */\n  readonly tenantId: string;\n  /**\n   * The Azure Active Directory tenant ID that should be used for authenticating requests to the key vault.\n   */\n  readonly networkAcls?: KeyVaultNetworkAcls;\n  /**\n   * A map of IP network ACL rules. The key is the IP or IP range in CIDR notation.\n   * The value is a description of that IP range.\n   */\n  readonly purgeProtection?: boolean;\n  /**\n   *  Specifies whether protection against purge is enabled for this Key Vault.\n   * Setting this property to true activates protection against deletion of any active key, secret or certificate in the vault. The setting is effective only if soft delete is also enabled. The default value is false.\n   * Once activated, the property cannot be reverted to false.\n   */\n  readonly softDeleteRetentionDays?: number;\n  /**\n   * The number of days that items should be retained for once soft-deleted.\n   */\n}\n\n/**\n * Options for granting custom access permissions in Azure Key Vault.\n */\nexport interface GrantCustomAccessOptions {\n  /**\n   * Optional: A list of permissions to grant for secrets in the Key Vault.\n   * Example permissions include 'get', 'list', 'set', 'delete', etc.\n   */\n  readonly secretPermissions?: string[];\n\n  /**\n   * Optional: A list of permissions to grant for certificates in the Key Vault.\n   * Example permissions include 'get', 'list', 'create', 'delete', etc.\n   */\n  readonly certificatePermissions?: string[];\n\n  /**\n   * Optional: A list of permissions to grant for keys in the Key Vault.\n   * Example permissions include 'encrypt', 'decrypt', 'wrapKey', 'unwrapKey', etc.\n   */\n  readonly keyPermissions?: string[];\n\n  /**\n   * Optional: A list of permissions to grant for storage accounts in the Key Vault.\n   * Example permissions include 'get', 'list', 'delete', 'set', 'update', etc.\n   */\n  readonly storagePermissions?: string[];\n}\n\nexport class Vault extends AzureResource {\n  readonly props: VaultProps;\n  public keyVault: KeyVault;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  private accessPolicies: AccessPolicy[] = [];\n\n  constructor(scope: Construct, id: string, props: VaultProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Provide default values\n    const purgeProtection = props.purgeProtection ?? true;\n    const sku = props.sku ?? \"standard\";\n    const softDeleteRetentionDays = props.softDeleteRetentionDays ?? 90;\n\n    const azurermKeyVault = new KeyVault(this, \"key_vault\", {\n      name: props.name,\n      location: props.location,\n      resourceGroupName: props.resourceGroup.name,\n      tags: props.tags,\n      skuName: sku,\n      tenantId: props.tenantId,\n      networkAcls: props.networkAcls,\n      purgeProtectionEnabled: purgeProtection,\n      softDeleteRetentionDays: softDeleteRetentionDays,\n    });\n    this.id = azurermKeyVault.id;\n    this.keyVault = azurermKeyVault;\n\n    // Terraform Outputs\n    const cdktfTerraformOutputKeyVaultid = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: azurermKeyVault.id,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputKeyVaultid.overrideLogicalId(\"id\");\n\n    const cdktfTerraformOutputKeyVaultname = new cdktf.TerraformOutput(\n      this,\n      \"key_vault_name\",\n      {\n        value: azurermKeyVault.name,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputKeyVaultname.overrideLogicalId(\"key_vault_name\");\n  }\n\n  // Access Policy Methods\n  public grantSecretReaderAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      secretPermissions: [\"Get\", \"List\"],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_secret_reader_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  public grantSecretAdminAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      secretPermissions: [\n        \"Get\",\n        \"List\",\n        \"Set\",\n        \"Delete\",\n        \"Backup\",\n        \"Restore\",\n        \"Recover\",\n      ],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_secret_admin_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  public grantCertAdminAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      certificatePermissions: [\n        \"Get\",\n        \"List\",\n        \"Set\",\n        \"Delete\",\n        \"Backup\",\n        \"Restore\",\n        \"Recover\",\n      ],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_cert_admin_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  public grantCertReaderAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      certificatePermissions: [\"Get\", \"List\"],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_cert_reader_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  public grantKeyAdminAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      keyPermissions: [\n        \"Get\",\n        \"List\",\n        \"Set\",\n        \"Delete\",\n        \"Backup\",\n        \"Restore\",\n        \"Recover\",\n      ],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_key_admin_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  public grantKeyReaderAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      certificatePermissions: [\"Get\", \"List\"],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_key_reader_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  public grantCustomAccess(\n    azureAdGroupId: string,\n    options: GrantCustomAccessOptions,\n  ) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      ...options,\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_custom_policy_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  // Create Secret Methods\n  public addSecret(\n    keyVaultSecretName: string,\n    secretValue: string,\n    expirationDate?: string,\n    contentType?: string,\n  ) {\n    const secretProps: SecretProps = {\n      keyVaultId: this,\n      name: keyVaultSecretName,\n      value: secretValue,\n      expirationDate: expirationDate,\n      contentType: contentType,\n      accessPolicies: this.accessPolicies,\n    };\n\n    new Secret(this, keyVaultSecretName, secretProps);\n  }\n\n  // Create Key Methods\n  public addRSAKey(\n    keyVaultKeyName: string,\n    expirationDate?: string,\n  ): KeyVaultKey {\n    const keyProps: KeyProps = {\n      keyVaultId: this,\n      name: keyVaultKeyName,\n      keyType: \"RSA\",\n      keySize: 2048,\n      keyOpts: [\"decrypt\", \"encrypt\", \"sign\", \"unwrapKey\", \"verify\", \"wrapKey\"],\n      expires: expirationDate,\n      accessPolicies: this.accessPolicies,\n    };\n\n    const key = new Key(this, keyVaultKeyName, keyProps);\n    return key.vaultKey;\n  }\n\n  public addKey(\n    keyVaultKeyName: string,\n    keyType: string,\n    keySize: number,\n    keyOpts: string[],\n    expirationDate?: string,\n  ): KeyVaultKey {\n    const keyProps: KeyProps = {\n      keyVaultId: this,\n      name: keyVaultKeyName,\n      keyType: keyType,\n      keySize: keySize,\n      keyOpts: keyOpts,\n      expires: expirationDate,\n      accessPolicies: this.accessPolicies,\n    };\n\n    const key = new Key(this, keyVaultKeyName, keyProps);\n    return key.vaultKey;\n  }\n\n  // Create Certificate Methods\n\n  public addSelfSignedCert(\n    certName: string,\n    subject: string,\n    dnsNames: string[],\n    actionType?: string,\n    daysBeforeExpiry?: number,\n  ): KeyVaultCertificate {\n    const keyProps: SelfSignedCertificateProps = {\n      keyVaultId: this,\n      name: certName,\n      subject: subject,\n      dnsNames: dnsNames,\n      actionType: actionType,\n      daysBeforeExpiry: daysBeforeExpiry,\n      accessPolicies: this.accessPolicies,\n    };\n    const cert = new SelfSignedCertificate(this, certName, keyProps);\n    return cert.certificate;\n  }\n\n  public addCertIssuer(name: string, provider: string) {\n    new CertificateIssuer(this, name, {\n      name: name,\n      providerName: provider,\n      keyVaultId: this,\n      accessPolicies: this.accessPolicies,\n    });\n  }\n}\n"]}
|
|
391
|
+
Vault[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_keyvault.Vault", version: "0.0.3-pre.7" };
|
|
392
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vault.js","sourceRoot":"","sources":["../../../src/azure-keyvault/lib/vault.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  KeyVault,\n  KeyVaultNetworkAcls,\n} from \"@cdktf/provider-azurerm/lib/key-vault\";\nimport { KeyVaultCertificate } from \"@cdktf/provider-azurerm/lib/key-vault-certificate\"; // Adjust the import path based on the actual module location.\nimport { KeyVaultKey } from \"@cdktf/provider-azurerm/lib/key-vault-key\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  CertificateIssuer,\n  SelfSignedCertificate,\n  SelfSignedCertificateProps,\n} from \"./certificate\";\nimport { Key, KeyProps } from \"./key\";\nimport { AccessPolicy, AccessPolicyProps } from \"./policy\";\nimport { Secret, SecretProps } from \"./secret\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\nexport interface VaultProps {\n  /**\n   * The name of the Key Vault.\n   */\n  readonly name: string;\n  /**\n   * The Azure Region to deploy the Key Vault.\n   */\n  readonly location: string;\n  /**\n   * The name of the Azure Resource Group.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The tags to assign to the Key Vault.\n   */\n  readonly tags?: { [key: string]: string };\n  /**\n   * The tags to assign to the Key Vault.\n   */\n  readonly sku?: string;\n  /**\n   * The Name of the SKU used for this Key Vault. Possible values are standard and premium.\n   */\n  readonly tenantId: string;\n  /**\n   * The Azure Active Directory tenant ID that should be used for authenticating requests to the key vault.\n   */\n  readonly networkAcls?: KeyVaultNetworkAcls;\n  /**\n   * A map of IP network ACL rules. The key is the IP or IP range in CIDR notation.\n   * The value is a description of that IP range.\n   */\n  readonly purgeProtection?: boolean;\n  /**\n   *  Specifies whether protection against purge is enabled for this Key Vault.\n   * Setting this property to true activates protection against deletion of any active key, secret or certificate in the vault. The setting is effective only if soft delete is also enabled. The default value is false.\n   * Once activated, the property cannot be reverted to false.\n   */\n  readonly softDeleteRetentionDays?: number;\n  /**\n   * The number of days that items should be retained for once soft-deleted.\n   */\n}\n\n/**\n * Options for granting custom access permissions in Azure Key Vault.\n */\nexport interface GrantCustomAccessOptions {\n  /**\n   * Optional: A list of permissions to grant for secrets in the Key Vault.\n   * Example permissions include 'get', 'list', 'set', 'delete', etc.\n   */\n  readonly secretPermissions?: string[];\n\n  /**\n   * Optional: A list of permissions to grant for certificates in the Key Vault.\n   * Example permissions include 'get', 'list', 'create', 'delete', etc.\n   */\n  readonly certificatePermissions?: string[];\n\n  /**\n   * Optional: A list of permissions to grant for keys in the Key Vault.\n   * Example permissions include 'encrypt', 'decrypt', 'wrapKey', 'unwrapKey', etc.\n   */\n  readonly keyPermissions?: string[];\n\n  /**\n   * Optional: A list of permissions to grant for storage accounts in the Key Vault.\n   * Example permissions include 'get', 'list', 'delete', 'set', 'update', etc.\n   */\n  readonly storagePermissions?: string[];\n}\n\nexport class Vault extends AzureResource {\n  readonly props: VaultProps;\n  public keyVault: KeyVault;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  private accessPolicies: AccessPolicy[] = [];\n\n  /**\n   * Constructs a new Azure Key Vault resource.\n   *\n   * This class creates and configures an Azure Key Vault, a secure store for managing secrets, keys, certificates, and other sensitive data.\n   * It supports advanced configurations such as access policies, network rules, and data retention policies.\n   *\n   * @param scope - The scope in which to define this construct, usually representing the Cloud Development Kit (CDK) stack.\n   * @param id - The unique identifier for this instance of the Key Vault.\n   * @param props - The properties for creating the Key Vault as defined in VaultProps. These include settings for location, SKU, tenant ID, etc.\n   *\n   * Example usage:\n   * ```typescript\n   * new Vault(this, 'MyKeyVault', {\n   *   name: 'mySecureVault',\n   *   location: 'East US',\n   *   resourceGroup: myResourceGroup,\n   *   sku: 'premium',\n   *   tenantId: 'my-tenant-id',\n   *   softDeleteRetentionDays: 90,\n   *   purgeProtection: true,\n   *   tags: {\n   *     project: 'My Application'\n   *   }\n   * });\n   * ```\n   */\n  constructor(scope: Construct, id: string, props: VaultProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Provide default values\n    const purgeProtection = props.purgeProtection ?? true;\n    const sku = props.sku ?? \"standard\";\n    const softDeleteRetentionDays = props.softDeleteRetentionDays ?? 90;\n\n    const azurermKeyVault = new KeyVault(this, \"key_vault\", {\n      name: props.name,\n      location: props.location,\n      resourceGroupName: props.resourceGroup.name,\n      tags: props.tags,\n      skuName: sku,\n      tenantId: props.tenantId,\n      networkAcls: props.networkAcls,\n      purgeProtectionEnabled: purgeProtection,\n      softDeleteRetentionDays: softDeleteRetentionDays,\n    });\n    this.id = azurermKeyVault.id;\n    this.keyVault = azurermKeyVault;\n\n    // Terraform Outputs\n    const cdktfTerraformOutputKeyVaultid = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: azurermKeyVault.id,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputKeyVaultid.overrideLogicalId(\"id\");\n\n    const cdktfTerraformOutputKeyVaultname = new cdktf.TerraformOutput(\n      this,\n      \"key_vault_name\",\n      {\n        value: azurermKeyVault.name,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputKeyVaultname.overrideLogicalId(\"key_vault_name\");\n  }\n\n  /**\n   * Grants read-only access to secrets stored in the Key Vault to a specified Azure AD group.\n   *\n   * @param azureAdGroupId - The Azure Active Directory group ID that will receive read access to secrets.\n   */\n  public grantSecretReaderAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      secretPermissions: [\"Get\", \"List\"],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_secret_reader_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  /**\n   * Grants administrative access to secrets stored in the Key Vault to a specified Azure AD group.\n   *\n   * @param azureAdGroupId - The Azure Active Directory group ID that will receive administrative access to secrets.\n   */\n  public grantSecretAdminAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      secretPermissions: [\n        \"Get\",\n        \"List\",\n        \"Set\",\n        \"Delete\",\n        \"Backup\",\n        \"Restore\",\n        \"Recover\",\n      ],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_secret_admin_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  /**\n   * Grants administrative access to certificates stored in the Key Vault to a specified Azure AD group.\n   *\n   * @param azureAdGroupId - The Azure Active Directory group ID that will receive administrative access to certificates.\n   */\n  public grantCertAdminAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      certificatePermissions: [\n        \"Get\",\n        \"List\",\n        \"Set\",\n        \"Delete\",\n        \"Backup\",\n        \"Restore\",\n        \"Recover\",\n      ],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_cert_admin_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  /**\n   * Grants read-only access to certificates stored in the Key Vault to a specified Azure AD group.\n   *\n   * @param azureAdGroupId - The Azure Active Directory group ID that will receive read access to certificates.\n   */\n  public grantCertReaderAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      certificatePermissions: [\"Get\", \"List\"],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_cert_reader_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  /**\n   * Grants administrative access to keys stored in the Key Vault to a specified Azure AD group.\n   *\n   * @param azureAdGroupId - The Azure Active Directory group ID that will receive administrative access to keys.\n   */\n  public grantKeyAdminAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      keyPermissions: [\n        \"Get\",\n        \"List\",\n        \"Set\",\n        \"Delete\",\n        \"Backup\",\n        \"Restore\",\n        \"Recover\",\n      ],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_key_admin_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  /**\n   * Grants read-only access to keys stored in the Key Vault to a specified Azure AD group.\n   *\n   * @param azureAdGroupId - The Azure Active Directory group ID that will receive read access to keys.\n   */\n  public grantKeyReaderAccess(azureAdGroupId: string) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      keyPermissions: [\"Get\", \"List\"],\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_key_reader_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  /**\n   * Grants custom access based on specified options to an Azure AD group in the Key Vault.\n   *\n   * @param azureAdGroupId - The Azure Active Directory group ID that will receive the custom access.\n   * @param options - Custom access options specifying various permissions for secrets, keys, certificates, and storage.\n   */\n  public grantCustomAccess(\n    azureAdGroupId: string,\n    options: GrantCustomAccessOptions,\n  ) {\n    const policyProps: AccessPolicyProps = {\n      keyVaultId: this,\n      tenantId: this.props.tenantId,\n      objectId: azureAdGroupId,\n      ...options,\n    };\n\n    const policy = new AccessPolicy(\n      this,\n      `kv_custom_policy_access_${azureAdGroupId}`,\n      policyProps,\n    );\n    this.accessPolicies.push(policy);\n  }\n\n  /**\n   * Creates a new secret within the Azure Key Vault.\n   *\n   * This method facilitates the storage of sensitive information in the form of a secret within the Key Vault.\n   * Secrets are protected items such as passwords, database connection strings, or any other piece of information\n   * that needs to be securely stored and accessed. This method allows setting additional properties such as\n   * expiration date and content type for better management and compliance.\n   *\n   * @param keyVaultSecretName - The unique name for the secret within the Key Vault.\n   * @param secretValue - The sensitive information or data that needs to be securely stored as a secret.\n   * @param expirationDate - Optional. The expiration date of the secret in ISO 8601 format (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ).\n   *                         If provided, the secret will no longer be valid after this date.\n   * @param contentType - Optional. A description of the type of information the secret contains (e.g., 'password', 'connectionString').\n   *                      This can be used by applications to handle the secret appropriately.\n   *\n   * Example usage:\n   * ```typescript\n   * vault.addSecret(\n   *   'myDatabasePassword',\n   *   'p@ssw0rd123!',\n   *   '2030-01-01',\n   *   'databasePassword'\n   * );\n   * ```\n   * This method does not return a value. It creates a secret within the Key Vault with the specified properties.\n   */\n  public addSecret(\n    keyVaultSecretName: string,\n    secretValue: string,\n    expirationDate?: string,\n    contentType?: string,\n  ) {\n    const secretProps: SecretProps = {\n      keyVaultId: this,\n      name: keyVaultSecretName,\n      value: secretValue,\n      expirationDate: expirationDate,\n      contentType: contentType,\n      accessPolicies: this.accessPolicies,\n    };\n\n    new Secret(this, keyVaultSecretName, secretProps);\n  }\n\n  /**\n   * Creates an RSA cryptographic key within the Azure Key Vault.\n   *\n   * This method facilitates the creation of an RSA key, which is useful for a variety of cryptographic operations such as\n   * encryption, decryption, digital signature verification, and more. The RSA key created by this method is configurable\n   * with an optional expiration date and a default key size of 2048 bits. The key operations allowed include decryption,\n   * encryption, signing, verifying signatures, and key wrapping/unwrapping.\n   *\n   * @param keyVaultKeyName - The unique name for the RSA key within the Key Vault.\n   * @param expirationDate - Optional. The expiration date of the key in ISO 8601 format (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ).\n   *                         If provided, the key will no longer be valid after this date.\n   * @returns A KeyVaultKey object representing the newly created RSA key within the vault.\n   *\n   * Example usage:\n   * ```typescript\n   * const rsaKey = vault.addRSAKey(\n   *   'myRSAKey',\n   *   '2030-01-01'\n   * );\n   * ```\n   * This method returns the created KeyVaultKey object, allowing further operations or references to the key.\n   */\n  public addRSAKey(\n    keyVaultKeyName: string,\n    expirationDate?: string,\n  ): KeyVaultKey {\n    const keyProps: KeyProps = {\n      keyVaultId: this,\n      name: keyVaultKeyName,\n      keyType: \"RSA\",\n      keySize: 2048,\n      keyOpts: [\"decrypt\", \"encrypt\", \"sign\", \"unwrapKey\", \"verify\", \"wrapKey\"],\n      expires: expirationDate,\n      accessPolicies: this.accessPolicies,\n    };\n\n    const key = new Key(this, keyVaultKeyName, keyProps);\n    return key.vaultKey;\n  }\n\n  /**\n   * Creates a cryptographic key within the Azure Key Vault.\n   *\n   * This method allows the creation of a cryptographic key of specified type and size within the Key Vault. The key can be\n   * configured with specific operations it can perform, such as encryption, decryption, signing, etc. An optional expiration\n   * date can also be set to control the key's lifecycle. This method is flexible, supporting various key types and sizes,\n   * making it suitable for a wide range of cryptographic needs.\n   *\n   * @param keyVaultKeyName - The unique name for the cryptographic key within the Key Vault.\n   * @param keyType - The type of cryptographic key to create (e.g., 'RSA', 'EC', 'oct-HSM').\n   * @param keySize - The size of the cryptographic key in bits (e.g., 2048, 3072, 4096 for RSA).\n   * @param keyOpts - A list of cryptographic operations that the key is allowed to perform. Possible values might include\n   *                  'encrypt', 'decrypt', 'sign', 'verify', 'wrapKey', 'unwrapKey'.\n   * @param expirationDate - Optional. The expiration date of the key in ISO 8601 format (YYYY-MM-DD or YYYY-MM-DDTHH:MM:SSZ).\n   *                         If provided, the key will no longer be valid after this date, aligning with best practices for key management.\n   * @returns A KeyVaultKey object representing the newly created cryptographic key within the vault.\n   *\n   * Example usage:\n   * ```typescript\n   * const myKey = vault.addKey(\n   *   'myKey',\n   *   'RSA',\n   *   2048,\n   *   ['encrypt', 'decrypt', 'sign', 'verify'],\n   *   '2030-12-31'\n   * );\n   * ```\n   * This method returns the created KeyVaultKey object, enabling immediate use within the application for cryptographic operations.\n   */\n  public addKey(\n    keyVaultKeyName: string,\n    keyType: string,\n    keySize: number,\n    keyOpts: string[],\n    expirationDate?: string,\n  ): KeyVaultKey {\n    const keyProps: KeyProps = {\n      keyVaultId: this,\n      name: keyVaultKeyName,\n      keyType: keyType,\n      keySize: keySize,\n      keyOpts: keyOpts,\n      expires: expirationDate,\n      accessPolicies: this.accessPolicies,\n    };\n\n    const key = new Key(this, keyVaultKeyName, keyProps);\n    return key.vaultKey;\n  }\n\n  /**\n   * Creates a self-signed certificate within the Azure Key Vault.\n   *\n   * This method facilitates the creation of a self-signed certificate, which is a digital certificate that is signed by\n   * its own creator rather than a trusted authority. Self-signed certificates can be useful for testing, internal\n   * communications, or any scenario where public trust is not required. The method allows specifying subject details,\n   * DNS names for the certificate, and managing its lifecycle with action types and expiry.\n   *\n   * @param certName - The unique name for the certificate within the Key Vault.\n   * @param subject - The subject name of the certificate, typically formatted as an X.500 Distinguished Name (e.g., \"CN=example.com\").\n   * @param dnsNames - An array of DNS names that should be associated with this certificate. This is useful for certificates\n   *                   that need to be valid for multiple hostnames.\n   * @param actionType - Optional. Specifies the action to be performed with the certificate, such as 'create' or 'renew'.\n   * @param daysBeforeExpiry - Optional. Number of days before expiry when an action should be taken, useful for auto-renewal scenarios.\n   * @returns A KeyVaultCertificate object representing the newly created self-signed certificate.\n   *\n   * Example usage:\n   * ```typescript\n   * const myCertificate = vault.addSelfSignedCert(\n   *   'myCert',\n   *   'CN=mydomain.com',\n   *   ['mydomain.com', 'www.mydomain.com'],\n   *   'create',\n   *   30\n   * );\n   * ```\n   * This method returns the KeyVaultCertificate object, enabling it to be used immediately within the application or stored for future use.\n   */\n  public addSelfSignedCert(\n    certName: string,\n    subject: string,\n    dnsNames: string[],\n    actionType?: string,\n    daysBeforeExpiry?: number,\n  ): KeyVaultCertificate {\n    const keyProps: SelfSignedCertificateProps = {\n      keyVaultId: this,\n      name: certName,\n      subject: subject,\n      dnsNames: dnsNames,\n      actionType: actionType,\n      daysBeforeExpiry: daysBeforeExpiry,\n      accessPolicies: this.accessPolicies,\n    };\n    const cert = new SelfSignedCertificate(this, certName, keyProps);\n    return cert.certificate;\n  }\n\n  /**\n   * Adds a certificate issuer to the Azure Key Vault.\n   *\n   * This method configures a certificate issuer within the Key Vault, allowing the Key Vault to issue certificates\n   * through external providers. Configuring an issuer is essential for enabling automated certificate management\n   * processes, such as issuance and renewal, directly through the Key Vault with a specified Certificate Authority (CA).\n   *\n   * @param name - The unique name for the certificate issuer within the Key Vault.\n   * @param provider - The name of the external provider that will issue the certificates, such as 'DigiCert' or 'GlobalSign'.\n   *\n   * Example usage:\n   * ```typescript\n   * vault.addCertIssuer(\n   *   'myCertIssuer',\n   *   'DigiCert'\n   * );\n   * ```\n   * This method configures a certificate issuer but does not return any value. The issuer details, including provider name\n   * and any necessary credentials (managed externally or through additional method parameters), are set up in the Key Vault\n   * for future certificate operations.\n   */\n  public addCertIssuer(name: string, provider: string) {\n    new CertificateIssuer(this, name, {\n      name: name,\n      providerName: provider,\n      keyVaultId: this,\n      accessPolicies: this.accessPolicies,\n    });\n  }\n}\n"]}
|
|
@@ -63,10 +63,31 @@ export declare class Cluster extends AzureResource {
|
|
|
63
63
|
/** The Resource Group associated with the AKS cluster. */
|
|
64
64
|
resourceGroup: ResourceGroup;
|
|
65
65
|
/**
|
|
66
|
-
*
|
|
67
|
-
*
|
|
68
|
-
*
|
|
69
|
-
*
|
|
66
|
+
* Represents an Azure Kubernetes Service (AKS) cluster resource in Azure.
|
|
67
|
+
*
|
|
68
|
+
* This class is responsible for the creation and management of an AKS cluster, allowing for the deployment and orchestration
|
|
69
|
+
* of containerized applications using Kubernetes within the Azure cloud platform.
|
|
70
|
+
*
|
|
71
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
72
|
+
* @param id - The unique identifier for this instance of the AKS cluster.
|
|
73
|
+
* @param props - The properties required to configure the AKS cluster, as defined in the ClusterProps interface.
|
|
74
|
+
*
|
|
75
|
+
* Example usage:
|
|
76
|
+
* ```typescript
|
|
77
|
+
* new Cluster(this, 'MyAKSCluster', {
|
|
78
|
+
* name: 'example-cluster',
|
|
79
|
+
* location: 'East US',
|
|
80
|
+
* defaultNodePool: {
|
|
81
|
+
* vmSize: 'Standard_D2_v3',
|
|
82
|
+
* nodeCount: 3,
|
|
83
|
+
* type: 'VirtualMachineScaleSets'
|
|
84
|
+
* },
|
|
85
|
+
* resourceGroup: existingResourceGroup,
|
|
86
|
+
* tags: {
|
|
87
|
+
* environment: 'production'
|
|
88
|
+
* }
|
|
89
|
+
* });
|
|
90
|
+
* ```
|
|
70
91
|
*/
|
|
71
92
|
constructor(scope: Construct, id: string, props: ClusterProps);
|
|
72
93
|
}
|
|
@@ -10,10 +10,31 @@ const lib_1 = require("../../core-azure/lib");
|
|
|
10
10
|
*/
|
|
11
11
|
class Cluster extends lib_1.AzureResource {
|
|
12
12
|
/**
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
13
|
+
* Represents an Azure Kubernetes Service (AKS) cluster resource in Azure.
|
|
14
|
+
*
|
|
15
|
+
* This class is responsible for the creation and management of an AKS cluster, allowing for the deployment and orchestration
|
|
16
|
+
* of containerized applications using Kubernetes within the Azure cloud platform.
|
|
17
|
+
*
|
|
18
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
19
|
+
* @param id - The unique identifier for this instance of the AKS cluster.
|
|
20
|
+
* @param props - The properties required to configure the AKS cluster, as defined in the ClusterProps interface.
|
|
21
|
+
*
|
|
22
|
+
* Example usage:
|
|
23
|
+
* ```typescript
|
|
24
|
+
* new Cluster(this, 'MyAKSCluster', {
|
|
25
|
+
* name: 'example-cluster',
|
|
26
|
+
* location: 'East US',
|
|
27
|
+
* defaultNodePool: {
|
|
28
|
+
* vmSize: 'Standard_D2_v3',
|
|
29
|
+
* nodeCount: 3,
|
|
30
|
+
* type: 'VirtualMachineScaleSets'
|
|
31
|
+
* },
|
|
32
|
+
* resourceGroup: existingResourceGroup,
|
|
33
|
+
* tags: {
|
|
34
|
+
* environment: 'production'
|
|
35
|
+
* }
|
|
36
|
+
* });
|
|
37
|
+
* ```
|
|
17
38
|
*/
|
|
18
39
|
constructor(scope, id, props) {
|
|
19
40
|
super(scope, id);
|
|
@@ -38,5 +59,5 @@ class Cluster extends lib_1.AzureResource {
|
|
|
38
59
|
}
|
|
39
60
|
exports.Cluster = Cluster;
|
|
40
61
|
_a = JSII_RTTI_SYMBOL_1;
|
|
41
|
-
Cluster[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kubernetes.Cluster", version: "0.0.3-pre.
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
62
|
+
Cluster[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kubernetes.Cluster", version: "0.0.3-pre.7" };
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["../../../src/azure-kubernetes/lib/cluster.ts"],"names":[],"mappings":";;;;;AAAA,uFAKwD;AAGxD,8CAAqD;AA4DrD;;GAEG;AACH,MAAa,OAAQ,SAAQ,mBAAa;IAOxC;;;;;;;;;;;;;;;;;;;;;;;;;;OA0BG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAmB;QAC3D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,8CAA8C;QAC9C,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAEpD,uDAAuD;QACvD,MAAM,GAAG,GAAG,IAAI,sCAAiB,CAAC,IAAI,EAAE,KAAK,EAAE;YAC7C,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,iBAAiB,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI;YAC1C,eAAe,EAAE,KAAK,CAAC,eAAe;YACtC,2BAA2B,EAAE,KAAK,CAAC,2BAA2B;YAC9D,SAAS,EAAE,KAAK,CAAC,IAAI;YACrB,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,6BAA6B,EAAE,IAAI;YACnC,0CAA0C,EACxC,KAAK,CAAC,0CAA0C;YAClD,QAAQ,EAAE,KAAK,CAAC,QAAQ;SACzB,CAAC,CAAC;QAEH,oDAAoD;QACpD,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC;IACnB,CAAC;;AAzDH,0BAiEC","sourcesContent":["import {\n  KubernetesCluster,\n  KubernetesClusterDefaultNodePool,\n  KubernetesClusterIdentity,\n  KubernetesClusterAzureActiveDirectoryRoleBasedAccessControl,\n} from \"@cdktf/provider-azurerm/lib/kubernetes-cluster\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Construct } from \"constructs\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\n/**\n * Interface defining the properties required to create an AKS cluster.\n */\nexport interface ClusterProps {\n  /** The name of the AKS cluster. Must be unique within the Azure region. */\n  readonly name: string;\n\n  /** The Azure region where the AKS cluster will be deployed. */\n  readonly location: string;\n\n  /** Configuration for the default node pool of the AKS cluster. */\n  readonly defaultNodePool: KubernetesClusterDefaultNodePool;\n\n  /**\n   * The Azure Resource Group where the AKS cluster will be deployed.\n   * Optional. If not provided, a new resource group will be created.\n   */\n  readonly resourceGroup?: ResourceGroup;\n\n  /**\n   * The identity used for the AKS cluster. Can be either SystemAssigned or UserAssigned.\n   * Optional.\n   */\n  readonly identity?: KubernetesClusterIdentity;\n\n  /**\n   * Configures integration of Azure Active Directory (AAD) with Kubernetes Role-Based Access Control (RBAC) for the AKS cluster. This feature enables the use of AAD to manage user and group access permissions to the Kubernetes cluster resources, leveraging AAD's robust identity and access management capabilities.\n   *\n   * Utilizing AAD with Kubernetes RBAC provides:\n   * - Enhanced security through AAD's identity protection features.\n   * - Simplified user and group management by leveraging existing AAD definitions.\n   * - Streamlined access control for Kubernetes resources, allowing for the definition of roles and role bindings based on AAD identities.\n   *\n   * This property is optional but highly recommended for clusters where security and access governance are a priority. It allows for finer-grained access control and integrates the cluster's authentication and authorization processes with corporate identity management systems.\n   *\n   * Example configuration might include specifying the AAD tenant details, enabling Azure RBAC for Kubernetes authorization, and optionally defining specific AAD groups for cluster admin roles.\n   */\n  readonly azureActiveDirectoryRoleBasedAccessControl?: KubernetesClusterAzureActiveDirectoryRoleBasedAccessControl;\n\n  /**\n   * A list of IP address ranges that are authorized to access the AKS API server. This enhances the security of your cluster by ensuring that only traffic from these IP ranges can communicate with the Kubernetes API server.\n   *\n   * Specifying this list helps to protect your cluster from unauthorized access attempts. It's a critical security measure for clusters that are exposed to the internet. If you specify an empty array, no IP addresses will be allowed to access the API server, effectively blocking all access. If this property is not defined, all IP addresses are allowed by default, which is not recommended for production environments.\n   *\n   * Example:\n   * apiServerAuthorizedIpRanges: ['203.0.113.0/24', '198.51.100.0/24']\n   *\n   * It's important to configure this property carefully, based on your organization's network policies and access requirements.\n   */\n  readonly apiServerAuthorizedIpRanges?: string[];\n\n  /**\n   * Tags to be applied to the AKS cluster resources for organizational purposes.\n   * Key-value pairs. Optional.\n   */\n  readonly tags?: { [key: string]: string };\n}\n\n/**\n * Class representing the AKS cluster resource.\n */\nexport class Cluster extends AzureResource {\n  /** The unique identifier of the AKS cluster resource. */\n  public id: string;\n\n  /** The Resource Group associated with the AKS cluster. */\n  public resourceGroup: ResourceGroup;\n\n  /**\n   * Represents an Azure Kubernetes Service (AKS) cluster resource in Azure.\n   *\n   * This class is responsible for the creation and management of an AKS cluster, allowing for the deployment and orchestration\n   * of containerized applications using Kubernetes within the Azure cloud platform.\n   *\n   * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.\n   * @param id - The unique identifier for this instance of the AKS cluster.\n   * @param props - The properties required to configure the AKS cluster, as defined in the ClusterProps interface.\n   *\n   * Example usage:\n   * ```typescript\n   * new Cluster(this, 'MyAKSCluster', {\n   *   name: 'example-cluster',\n   *   location: 'East US',\n   *   defaultNodePool: {\n   *     vmSize: 'Standard_D2_v3',\n   *     nodeCount: 3,\n   *     type: 'VirtualMachineScaleSets'\n   *   },\n   *   resourceGroup: existingResourceGroup,\n   *   tags: {\n   *     environment: 'production'\n   *   }\n   * });\n   * ```\n   */\n  constructor(scope: Construct, id: string, props: ClusterProps) {\n    super(scope, id);\n\n    // Setup or reuse the provided resource group.\n    this.resourceGroup = this.setupResourceGroup(props);\n\n    // Create the AKS Cluster with the provided properties.\n    const aks = new KubernetesCluster(this, \"AKS\", {\n      name: props.name,\n      location: props.location,\n      resourceGroupName: this.resourceGroup.name,\n      defaultNodePool: props.defaultNodePool,\n      apiServerAuthorizedIpRanges: props.apiServerAuthorizedIpRanges,\n      dnsPrefix: props.name,\n      tags: props.tags,\n      roleBasedAccessControlEnabled: true,\n      azureActiveDirectoryRoleBasedAccessControl:\n        props.azureActiveDirectoryRoleBasedAccessControl,\n      identity: props.identity,\n    });\n\n    // Assign the AKS cluster ID for external reference.\n    this.id = aks.id;\n  }\n\n  /**\n   * Sets up the Azure Resource Group for the AKS cluster.\n   * If a resource group is not provided in the properties, a new one is created.\n   * @param props The properties provided to configure the AKS cluster.\n   * @returns The Resource Group where the AKS cluster will be deployed.\n   */\n}\n"]}
|
|
@@ -78,6 +78,59 @@ export declare class Cluster extends AzureResource {
|
|
|
78
78
|
id: string;
|
|
79
79
|
resourceGroup: ResourceGroup;
|
|
80
80
|
readonly uri: string;
|
|
81
|
+
/**
|
|
82
|
+
* Represents a Kusto (Azure Data Explorer) cluster in Azure.
|
|
83
|
+
*
|
|
84
|
+
* This class is responsible for the creation and management of a Kusto Cluster, which is a highly scalable and secure
|
|
85
|
+
* analytics service for ingesting, storing, and analyzing large volumes of data. The cluster supports various configurations
|
|
86
|
+
* tailored to the needs of specific data workloads and security requirements.
|
|
87
|
+
*
|
|
88
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
89
|
+
* @param id - The unique identifier for this instance of the cluster.
|
|
90
|
+
* @param kustoProps - The properties required to configure the Kusto cluster, as defined in the ClusterProps interface.
|
|
91
|
+
*
|
|
92
|
+
* Example usage:
|
|
93
|
+
* ```typescript
|
|
94
|
+
* new Cluster(this, 'MyKustoCluster', {
|
|
95
|
+
* name: 'example-cluster',
|
|
96
|
+
* location: 'West US',
|
|
97
|
+
* resourceGroup: myResourceGroup,
|
|
98
|
+
* sku: { tier: 'Standard', name: 'D13_v2', capacity: 2 },
|
|
99
|
+
* tags: {
|
|
100
|
+
* project: 'Data Analytics'
|
|
101
|
+
* }
|
|
102
|
+
* });
|
|
103
|
+
* ```
|
|
104
|
+
*/
|
|
81
105
|
constructor(scope: Construct, id: string, kustoProps: ClusterProps);
|
|
106
|
+
/**
|
|
107
|
+
* Adds a new database to the Azure Kusto Cluster.
|
|
108
|
+
*
|
|
109
|
+
* This method creates a database within the Azure Data Explorer (Kusto) cluster, defined by the properties provided.
|
|
110
|
+
* A database in Kusto serves as a logical group to manage various tables and store data. It is essential for performing
|
|
111
|
+
* data analytics and running queries. The database configuration can include settings like hot cache and soft delete periods,
|
|
112
|
+
* which optimize query performance and manage data lifecycle according to specific requirements.
|
|
113
|
+
*
|
|
114
|
+
* @param databaseProps - The properties required to create the database. These properties should include:
|
|
115
|
+
* - `kusto`: Reference to the Kusto cluster to which the database will be added.
|
|
116
|
+
* - `name`: The name of the database, which must be unique within the cluster.
|
|
117
|
+
* - `hotCachePeriod`: Optional. Specifies the duration that data should be kept in cache for faster query access.
|
|
118
|
+
* - `softDeletePeriod`: Optional. Specifies the duration that data should be retained before it stops being accessible to queries.
|
|
119
|
+
* Both the hot cache and soft delete periods should be specified in ISO 8601 duration format.
|
|
120
|
+
*
|
|
121
|
+
* @returns A `Database` object representing the newly created database within the Kusto cluster.
|
|
122
|
+
*
|
|
123
|
+
* Example usage:
|
|
124
|
+
* ```typescript
|
|
125
|
+
* const myDatabase = myCluster.addDatabase({
|
|
126
|
+
* kusto: myKustoCluster,
|
|
127
|
+
* name: 'OperationalData',
|
|
128
|
+
* hotCachePeriod: 'P14D', // 14 days
|
|
129
|
+
* softDeletePeriod: 'P365D' // 1 year
|
|
130
|
+
* });
|
|
131
|
+
* ```
|
|
132
|
+
* This method facilitates the efficient setup and scaling of databases within an Azure Kusto cluster, allowing
|
|
133
|
+
* for complex data analytics operations across large datasets.
|
|
134
|
+
*/
|
|
82
135
|
addDatabase(databaseProps: DatabaseProps): Database;
|
|
83
136
|
}
|