@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
|
@@ -9,6 +9,39 @@ const log_analytics_workspace_1 = require("@cdktf/provider-azurerm/lib/log-analy
|
|
|
9
9
|
const cdktf = require("cdktf");
|
|
10
10
|
const lib_1 = require("../../core-azure/lib");
|
|
11
11
|
class AppInsights extends lib_1.AzureResource {
|
|
12
|
+
/**
|
|
13
|
+
* Constructs a new Azure Application Insights resource.
|
|
14
|
+
*
|
|
15
|
+
* @param scope - The scope in which to define this construct.
|
|
16
|
+
* @param id - The ID of this construct.
|
|
17
|
+
* @param props - The properties for configuring the Azure Application Insights. The properties include:
|
|
18
|
+
* - `name`: Required. Unique name for the Application Insights resource within Azure.
|
|
19
|
+
* - `location`: Required. Azure Region for deployment.
|
|
20
|
+
* - `resourceGroup`: Required. Reference to the Azure Resource Group for deployment.
|
|
21
|
+
* - `retentionInDays`: Optional. Number of days to retain data. Default is 90 days.
|
|
22
|
+
* - `tags`: Optional. Tags for resource management.
|
|
23
|
+
* - `applicationType`: Required. The type of application (e.g., web, other).
|
|
24
|
+
* - `dailyDataCapInGb`: Optional. Daily data cap in gigabytes.
|
|
25
|
+
* - `dailyDataCapNotificationDisabled`: Optional. Flag to disable notifications when the daily data cap is reached.
|
|
26
|
+
* - `workspaceId`: Optional. ID of the Log Analytics Workspace to associate with Application Insights. If not provided, a new workspace is created automatically.
|
|
27
|
+
*
|
|
28
|
+
* Example usage:
|
|
29
|
+
* ```typescript
|
|
30
|
+
* new AppInsights(this, 'myAppInsights', {
|
|
31
|
+
* name: 'myAppInsightsResource',
|
|
32
|
+
* location: 'West US',
|
|
33
|
+
* resourceGroup: resourceGroup,
|
|
34
|
+
* retentionInDays: 120,
|
|
35
|
+
* tags: {
|
|
36
|
+
* "environment": "production"
|
|
37
|
+
* },
|
|
38
|
+
* applicationType: 'web',
|
|
39
|
+
* dailyDataCapInGb: 10,
|
|
40
|
+
* dailyDataCapNotificationDisabled: true,
|
|
41
|
+
* workspaceId: 'existing-workspace-id'
|
|
42
|
+
* });
|
|
43
|
+
* ```
|
|
44
|
+
*/
|
|
12
45
|
constructor(scope, id, props) {
|
|
13
46
|
super(scope, id);
|
|
14
47
|
this.props = props;
|
|
@@ -52,7 +85,23 @@ class AppInsights extends lib_1.AzureResource {
|
|
|
52
85
|
cdktfTerraformOutputAppiIKey.overrideLogicalId("instrumentation_key");
|
|
53
86
|
cdktfTerraformOutputAppiConnectStr.overrideLogicalId("connection_string");
|
|
54
87
|
}
|
|
55
|
-
|
|
88
|
+
/**
|
|
89
|
+
* Saves the Application Insights instrumentation key to an Azure Key Vault.
|
|
90
|
+
*
|
|
91
|
+
* This method creates a new secret in the specified Azure Key Vault with the
|
|
92
|
+
* instrumentation key of the Application Insights resource. This enables secure storage
|
|
93
|
+
* and management of the instrumentation key, facilitating secure access across various
|
|
94
|
+
* Azure services.
|
|
95
|
+
*
|
|
96
|
+
* @param keyVaultId - The unique identifier of the Azure Key Vault where the secret will be stored.
|
|
97
|
+
* @param keyVaultSecretName - The name of the secret within the Key Vault. Defaults to 'instrumentation-key'.
|
|
98
|
+
* This name can be used to retrieve the secret in client applications.
|
|
99
|
+
*
|
|
100
|
+
* Example usage:
|
|
101
|
+
* ```typescript
|
|
102
|
+
* appInsightsInstance.saveIKeyToKeyVault('my-key-vault-id');
|
|
103
|
+
* ```
|
|
104
|
+
*/
|
|
56
105
|
saveIKeyToKeyVault(keyVaultId, keyVaultSecretName = "instrumentation-key") {
|
|
57
106
|
new key_vault_secret_1.KeyVaultSecret(this, keyVaultSecretName, {
|
|
58
107
|
keyVaultId: keyVaultId,
|
|
@@ -81,5 +130,5 @@ class AppInsights extends lib_1.AzureResource {
|
|
|
81
130
|
}
|
|
82
131
|
exports.AppInsights = AppInsights;
|
|
83
132
|
_a = JSII_RTTI_SYMBOL_1;
|
|
84
|
-
AppInsights[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_applicationinsights.AppInsights", version: "0.0.3-pre.
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"appinsights.js","sourceRoot":"","sources":["../../../src/azure-applicationinsights/lib/appinsights.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationInsights } from \"@cdktf/provider-azurerm/lib/application-insights\";\nimport { KeyVaultSecret } from \"@cdktf/provider-azurerm/lib/key-vault-secret\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\n// Construct\n/**\n * Properties for the resource group\n */\n\nexport interface AppInsightsProps {\n  /**\n   * The Azure Region to deploy.\n   */\n  readonly location: string;\n  /**\n   * The name of the Application Insights resource.\n   */\n  readonly name: string;\n  /**\n   * The name of the Azure Resource Group to deploy to.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The number of days of retention.\n   * Possible values are 30, 60, 90, 120, 180, 270, 365, 550 or 730. Defaults to 90.\n   * @default 90\n   */\n  readonly retentionInDays?: number;\n  /**\n   * The tags to assign to the Application Insights resource.\n   */\n  readonly tags?: { [key: string]: string };\n  /**\n   * The Application type.\n   */\n  readonly applicationType: string;\n  /**\n   * The Application Insights daily data cap in GB.\n   */\n  readonly dailyDataCapInGb?: number;\n  /**\n   * The Application Insights daily data cap notifications disabled.\n   */\n  readonly dailyDataCapNotificationDisabled?: boolean;\n  /**\n   * The id of the Log Analytics Workspace.\n   * @default - If no workspace id is provided, a new one will be created automatically\n   * in the same resource group. The name will be the same as the Application Insights\n   * resource with a \"-la\" suffix.\n   */\n  readonly workspaceId?: string;\n}\n\nexport class AppInsights extends AzureResource {\n  readonly props: AppInsightsProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  private readonly instrumentationKey: string;\n\n  constructor(scope: Construct, id: string, props: AppInsightsProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    const azurermApplicationInsightsAppinsights = new ApplicationInsights(\n      this,\n      \"appinsights\",\n      {\n        location: props.location,\n        name: props.name,\n        resourceGroupName: props.resourceGroup.name,\n        tags: props.tags,\n        applicationType: props.applicationType,\n        dailyDataCapInGb: props.dailyDataCapInGb,\n        dailyDataCapNotificationsDisabled:\n          props.dailyDataCapNotificationDisabled,\n        retentionInDays: props.retentionInDays,\n        workspaceId: this.setupLogAnalytics(props),\n      },\n    );\n\n    this.instrumentationKey =\n      azurermApplicationInsightsAppinsights.instrumentationKey;\n    this.id = azurermApplicationInsightsAppinsights.id;\n\n    // Terraform Outputs\n    const cdktfTerraformOutputAppiID = new cdktf.TerraformOutput(this, \"id\", {\n      value: azurermApplicationInsightsAppinsights.id,\n    });\n    const cdktfTerraformOutputAppiName = new cdktf.TerraformOutput(\n      this,\n      \"name\",\n      {\n        value: azurermApplicationInsightsAppinsights.name,\n      },\n    );\n    const cdktfTerraformOutputAppiAppId = new cdktf.TerraformOutput(\n      this,\n      \"app_id\",\n      {\n        value: azurermApplicationInsightsAppinsights.appId,\n      },\n    );\n    const cdktfTerraformOutputAppiIKey = new cdktf.TerraformOutput(\n      this,\n      \"instrumentation_key\",\n      {\n        value: azurermApplicationInsightsAppinsights.instrumentationKey,\n        sensitive: true,\n      },\n    );\n    const cdktfTerraformOutputAppiConnectStr = new cdktf.TerraformOutput(\n      this,\n      \"connection_string\",\n      {\n        value: azurermApplicationInsightsAppinsights.connectionString,\n        sensitive: true,\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    cdktfTerraformOutputAppiID.overrideLogicalId(\"id\");\n    cdktfTerraformOutputAppiName.overrideLogicalId(\"name\");\n    cdktfTerraformOutputAppiAppId.overrideLogicalId(\"app_id\");\n    cdktfTerraformOutputAppiIKey.overrideLogicalId(\"instrumentation_key\");\n    cdktfTerraformOutputAppiConnectStr.overrideLogicalId(\"connection_string\");\n  }\n\n  // Save Instrumentation Key to Key Vault\n  public saveIKeyToKeyVault(\n    keyVaultId: string,\n    keyVaultSecretName: string = \"instrumentation-key\",\n  ) {\n    new KeyVaultSecret(this, keyVaultSecretName, {\n      keyVaultId: keyVaultId,\n      name: keyVaultSecretName,\n      value: this.instrumentationKey,\n    });\n  }\n\n  private setupLogAnalytics(props: AppInsightsProps): string {\n    if (cdktf.canInspect(props.workspaceId)) {\n      // Use the provided Log Analytics Workspace\n      return props.workspaceId!;\n    } else {\n      // Create a new Log Analytics Workspace\n      const logAnalyticsWorkspace = new LogAnalyticsWorkspace(\n        this,\n        \"log_analytics\",\n        {\n          location: props.location,\n          name: `${props.name}-la`,\n          resourceGroupName: props.resourceGroup.name,\n          sku: \"PerGB2018\",\n          retentionInDays: props.retentionInDays,\n          tags: props.tags,\n        },\n      );\n      return logAnalyticsWorkspace.id;\n    }\n  }\n}\n"]}
|
|
133
|
+
AppInsights[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_applicationinsights.AppInsights", version: "0.0.3-pre.7" };
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"appinsights.js","sourceRoot":"","sources":["../../../src/azure-applicationinsights/lib/appinsights.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationInsights } from \"@cdktf/provider-azurerm/lib/application-insights\";\nimport { KeyVaultSecret } from \"@cdktf/provider-azurerm/lib/key-vault-secret\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\n// Construct\n/**\n * Properties for the resource group\n */\n\nexport interface AppInsightsProps {\n  /**\n   * The Azure Region to deploy.\n   */\n  readonly location: string;\n  /**\n   * The name of the Application Insights resource.\n   */\n  readonly name: string;\n  /**\n   * The name of the Azure Resource Group to deploy to.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The number of days of retention.\n   * Possible values are 30, 60, 90, 120, 180, 270, 365, 550 or 730. Defaults to 90.\n   * @default 90\n   */\n  readonly retentionInDays?: number;\n  /**\n   * The tags to assign to the Application Insights resource.\n   */\n  readonly tags?: { [key: string]: string };\n  /**\n   * The Application type.\n   */\n  readonly applicationType: string;\n  /**\n   * The Application Insights daily data cap in GB.\n   */\n  readonly dailyDataCapInGb?: number;\n  /**\n   * The Application Insights daily data cap notifications disabled.\n   */\n  readonly dailyDataCapNotificationDisabled?: boolean;\n  /**\n   * The id of the Log Analytics Workspace.\n   * @default - If no workspace id is provided, a new one will be created automatically\n   * in the same resource group. The name will be the same as the Application Insights\n   * resource with a \"-la\" suffix.\n   */\n  readonly workspaceId?: string;\n}\n\nexport class AppInsights extends AzureResource {\n  readonly props: AppInsightsProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  private readonly instrumentationKey: string;\n\n  /**\n   * Constructs a new Azure Application Insights resource.\n   *\n   * @param scope - The scope in which to define this construct.\n   * @param id - The ID of this construct.\n   * @param props - The properties for configuring the Azure Application Insights. The properties include:\n   *                - `name`: Required. Unique name for the Application Insights resource within Azure.\n   *                - `location`: Required. Azure Region for deployment.\n   *                - `resourceGroup`: Required. Reference to the Azure Resource Group for deployment.\n   *                - `retentionInDays`: Optional. Number of days to retain data. Default is 90 days.\n   *                - `tags`: Optional. Tags for resource management.\n   *                - `applicationType`: Required. The type of application (e.g., web, other).\n   *                - `dailyDataCapInGb`: Optional. Daily data cap in gigabytes.\n   *                - `dailyDataCapNotificationDisabled`: Optional. Flag to disable notifications when the daily data cap is reached.\n   *                - `workspaceId`: Optional. ID of the Log Analytics Workspace to associate with Application Insights. If not provided, a new workspace is created automatically.\n   *\n   * Example usage:\n   * ```typescript\n   * new AppInsights(this, 'myAppInsights', {\n   *   name: 'myAppInsightsResource',\n   *   location: 'West US',\n   *   resourceGroup: resourceGroup,\n   *   retentionInDays: 120,\n   *   tags: {\n   *     \"environment\": \"production\"\n   *   },\n   *   applicationType: 'web',\n   *   dailyDataCapInGb: 10,\n   *   dailyDataCapNotificationDisabled: true,\n   *   workspaceId: 'existing-workspace-id'\n   * });\n   * ```\n   */\n\n  constructor(scope: Construct, id: string, props: AppInsightsProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    const azurermApplicationInsightsAppinsights = new ApplicationInsights(\n      this,\n      \"appinsights\",\n      {\n        location: props.location,\n        name: props.name,\n        resourceGroupName: props.resourceGroup.name,\n        tags: props.tags,\n        applicationType: props.applicationType,\n        dailyDataCapInGb: props.dailyDataCapInGb,\n        dailyDataCapNotificationsDisabled:\n          props.dailyDataCapNotificationDisabled,\n        retentionInDays: props.retentionInDays,\n        workspaceId: this.setupLogAnalytics(props),\n      },\n    );\n\n    this.instrumentationKey =\n      azurermApplicationInsightsAppinsights.instrumentationKey;\n    this.id = azurermApplicationInsightsAppinsights.id;\n\n    // Terraform Outputs\n    const cdktfTerraformOutputAppiID = new cdktf.TerraformOutput(this, \"id\", {\n      value: azurermApplicationInsightsAppinsights.id,\n    });\n    const cdktfTerraformOutputAppiName = new cdktf.TerraformOutput(\n      this,\n      \"name\",\n      {\n        value: azurermApplicationInsightsAppinsights.name,\n      },\n    );\n    const cdktfTerraformOutputAppiAppId = new cdktf.TerraformOutput(\n      this,\n      \"app_id\",\n      {\n        value: azurermApplicationInsightsAppinsights.appId,\n      },\n    );\n    const cdktfTerraformOutputAppiIKey = new cdktf.TerraformOutput(\n      this,\n      \"instrumentation_key\",\n      {\n        value: azurermApplicationInsightsAppinsights.instrumentationKey,\n        sensitive: true,\n      },\n    );\n    const cdktfTerraformOutputAppiConnectStr = new cdktf.TerraformOutput(\n      this,\n      \"connection_string\",\n      {\n        value: azurermApplicationInsightsAppinsights.connectionString,\n        sensitive: true,\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    cdktfTerraformOutputAppiID.overrideLogicalId(\"id\");\n    cdktfTerraformOutputAppiName.overrideLogicalId(\"name\");\n    cdktfTerraformOutputAppiAppId.overrideLogicalId(\"app_id\");\n    cdktfTerraformOutputAppiIKey.overrideLogicalId(\"instrumentation_key\");\n    cdktfTerraformOutputAppiConnectStr.overrideLogicalId(\"connection_string\");\n  }\n\n  /**\n   * Saves the Application Insights instrumentation key to an Azure Key Vault.\n   *\n   * This method creates a new secret in the specified Azure Key Vault with the\n   * instrumentation key of the Application Insights resource. This enables secure storage\n   * and management of the instrumentation key, facilitating secure access across various\n   * Azure services.\n   *\n   * @param keyVaultId - The unique identifier of the Azure Key Vault where the secret will be stored.\n   * @param keyVaultSecretName - The name of the secret within the Key Vault. Defaults to 'instrumentation-key'.\n   *                             This name can be used to retrieve the secret in client applications.\n   *\n   * Example usage:\n   * ```typescript\n   * appInsightsInstance.saveIKeyToKeyVault('my-key-vault-id');\n   * ```\n   */\n  public saveIKeyToKeyVault(\n    keyVaultId: string,\n    keyVaultSecretName: string = \"instrumentation-key\",\n  ) {\n    new KeyVaultSecret(this, keyVaultSecretName, {\n      keyVaultId: keyVaultId,\n      name: keyVaultSecretName,\n      value: this.instrumentationKey,\n    });\n  }\n\n  private setupLogAnalytics(props: AppInsightsProps): string {\n    if (cdktf.canInspect(props.workspaceId)) {\n      // Use the provided Log Analytics Workspace\n      return props.workspaceId!;\n    } else {\n      // Create a new Log Analytics Workspace\n      const logAnalyticsWorkspace = new LogAnalyticsWorkspace(\n        this,\n        \"log_analytics\",\n        {\n          location: props.location,\n          name: `${props.name}-la`,\n          resourceGroupName: props.resourceGroup.name,\n          sku: \"PerGB2018\",\n          retentionInDays: props.retentionInDays,\n          tags: props.tags,\n        },\n      );\n      return logAnalyticsWorkspace.id;\n    }\n  }\n}\n"]}
|
|
@@ -37,5 +37,34 @@ export declare class Registry extends AzureResource {
|
|
|
37
37
|
readonly props: RegistryProps;
|
|
38
38
|
resourceGroup: ResourceGroup;
|
|
39
39
|
id: string;
|
|
40
|
+
/**
|
|
41
|
+
* Constructs a new Azure Container Registry (ACR).
|
|
42
|
+
*
|
|
43
|
+
* This class creates an Azure Container Registry instance, which is a managed Docker registry service based on the Docker Registry 2.0 specification.
|
|
44
|
+
* This service enables you to store and manage container images across all types of Azure deployments, you can also use it to build, store, and manage images for all types of container deployments.
|
|
45
|
+
*
|
|
46
|
+
* @param scope - The scope in which to define this construct, typically used for managing lifecycles and creation order.
|
|
47
|
+
* @param id - The unique identifier for this construct instance.
|
|
48
|
+
* @param props - The properties for configuring the Azure Container Registry. The properties include:
|
|
49
|
+
* - `location`: Required. The Azure region where the registry will be deployed.
|
|
50
|
+
* - `name`: Required. The name of the Container Registry.
|
|
51
|
+
* - `resourceGroup`: Required. The Azure Resource Group in which to deploy the registry.
|
|
52
|
+
* - `sku`: Optional. The SKU of the Container Registry (e.g., Basic, Standard, Premium). Determines the features available.
|
|
53
|
+
* - `tags`: Optional. Tags for resource management.
|
|
54
|
+
* - `adminEnabled`: Optional. Specifies whether the admin user is enabled for the registry. Defaults to false if not set.
|
|
55
|
+
* - `geoReplicationLocations`: Optional. Specifies additional Azure regions where the registry should be geo-replicated.
|
|
56
|
+
*
|
|
57
|
+
* Example usage:
|
|
58
|
+
* ```typescript
|
|
59
|
+
* new Registry(this, 'myRegistry', {
|
|
60
|
+
* location: 'West US',
|
|
61
|
+
* name: 'myContainerRegistry',
|
|
62
|
+
* resourceGroup: resourceGroup,
|
|
63
|
+
* sku: 'Premium',
|
|
64
|
+
* adminEnabled: true,
|
|
65
|
+
* geoReplicationLocations: ['East US', 'West Europe']
|
|
66
|
+
* });
|
|
67
|
+
* ```
|
|
68
|
+
*/
|
|
40
69
|
constructor(scope: Construct, id: string, props: RegistryProps);
|
|
41
70
|
}
|
|
@@ -7,6 +7,35 @@ const container_registry_1 = require("@cdktf/provider-azurerm/lib/container-regi
|
|
|
7
7
|
const cdktf = require("cdktf");
|
|
8
8
|
const lib_1 = require("../../core-azure/lib");
|
|
9
9
|
class Registry extends lib_1.AzureResource {
|
|
10
|
+
/**
|
|
11
|
+
* Constructs a new Azure Container Registry (ACR).
|
|
12
|
+
*
|
|
13
|
+
* This class creates an Azure Container Registry instance, which is a managed Docker registry service based on the Docker Registry 2.0 specification.
|
|
14
|
+
* This service enables you to store and manage container images across all types of Azure deployments, you can also use it to build, store, and manage images for all types of container deployments.
|
|
15
|
+
*
|
|
16
|
+
* @param scope - The scope in which to define this construct, typically used for managing lifecycles and creation order.
|
|
17
|
+
* @param id - The unique identifier for this construct instance.
|
|
18
|
+
* @param props - The properties for configuring the Azure Container Registry. The properties include:
|
|
19
|
+
* - `location`: Required. The Azure region where the registry will be deployed.
|
|
20
|
+
* - `name`: Required. The name of the Container Registry.
|
|
21
|
+
* - `resourceGroup`: Required. The Azure Resource Group in which to deploy the registry.
|
|
22
|
+
* - `sku`: Optional. The SKU of the Container Registry (e.g., Basic, Standard, Premium). Determines the features available.
|
|
23
|
+
* - `tags`: Optional. Tags for resource management.
|
|
24
|
+
* - `adminEnabled`: Optional. Specifies whether the admin user is enabled for the registry. Defaults to false if not set.
|
|
25
|
+
* - `geoReplicationLocations`: Optional. Specifies additional Azure regions where the registry should be geo-replicated.
|
|
26
|
+
*
|
|
27
|
+
* Example usage:
|
|
28
|
+
* ```typescript
|
|
29
|
+
* new Registry(this, 'myRegistry', {
|
|
30
|
+
* location: 'West US',
|
|
31
|
+
* name: 'myContainerRegistry',
|
|
32
|
+
* resourceGroup: resourceGroup,
|
|
33
|
+
* sku: 'Premium',
|
|
34
|
+
* adminEnabled: true,
|
|
35
|
+
* geoReplicationLocations: ['East US', 'West Europe']
|
|
36
|
+
* });
|
|
37
|
+
* ```
|
|
38
|
+
*/
|
|
10
39
|
constructor(scope, id, props) {
|
|
11
40
|
super(scope, id);
|
|
12
41
|
this.props = props;
|
|
@@ -43,5 +72,5 @@ class Registry extends lib_1.AzureResource {
|
|
|
43
72
|
}
|
|
44
73
|
exports.Registry = Registry;
|
|
45
74
|
_a = JSII_RTTI_SYMBOL_1;
|
|
46
|
-
Registry[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_containerregistry.Registry", version: "0.0.3-pre.
|
|
47
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
75
|
+
Registry[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_containerregistry.Registry", version: "0.0.3-pre.7" };
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../../src/azure-containerregistry/lib/registry.ts"],"names":[],"mappings":";;;;;AAAA,uFAAmF;AAEnF,+BAA+B;AAE/B,8CAAqD;AAiCrD,MAAa,QAAS,SAAQ,mBAAa;IAKzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA4BG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAoB;QAC5D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QAEzC,yBAAyB;QACzB,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,IAAI,OAAO,CAAC;QACjC,MAAM,aAAa,GAAG,KAAK,CAAC,YAAY,IAAI,KAAK,CAAC;QAClD,MAAM,wBAAwB,GAAG,KAAK,CAAC,uBAAuB,IAAI,EAAE,CAAC;QAErE,MAAM,wBAAwB,GAAG,IAAI,sCAAiB,CAAC,IAAI,EAAE,KAAK,EAAE;YAClE,QAAQ,EAAE,KAAK,CAAC,QAAQ;YACxB,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC,IAAI;YAC3C,GAAG,EAAE,GAAG;YACR,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,YAAY,EAAE,aAAa;YAC3B,eAAe,EAAE,wBAAwB;SAC1C,CAAC,CAAC;QAEH,IAAI,CAAC,EAAE,GAAG,wBAAwB,CAAC,EAAE,CAAC;QAEtC,oBAAoB;QACpB,MAAM,yBAAyB,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACtE,KAAK,EAAE,wBAAwB,CAAC,EAAE;SACnC,CAAC,CAAC;QAEH,MAAM,2BAA2B,GAAG,IAAI,KAAK,CAAC,eAAe,CAC3D,IAAI,EACJ,yBAAyB,EACzB;YACE,KAAK,EAAE,wBAAwB,CAAC,IAAI;SACrC,CACF,CAAC;QAEF,MAAM,kCAAkC,GAAG,IAAI,KAAK,CAAC,eAAe,CAClE,IAAI,EACJ,cAAc,EACd;YACE,KAAK,EAAE,wBAAwB,CAAC,WAAW;SAC5C,CACF,CAAC;QAEF,gIAAgI;QAChI,yBAAyB,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QAClD,2BAA2B,CAAC,iBAAiB,CAAC,yBAAyB,CAAC,CAAC;QACzE,kCAAkC,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC;IACvE,CAAC;;AAlFH,4BAmFC","sourcesContent":["import { ContainerRegistry } from \"@cdktf/provider-azurerm/lib/container-registry\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\nexport interface RegistryProps {\n  /**\n   * The Azure Region to deploy.\n   */\n  readonly location: string;\n  /**\n   * The name of the Log Analytics Workspace.\n   */\n  readonly name: string;\n  /**\n   * The name of the Azure Resource Group.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The SKU of the Log Analytics Workspace.\n   */\n  readonly sku?: string;\n  /**\n   * The tags to assign to the Resource Group.\n   */\n  readonly tags?: { [key: string]: string };\n  /**\n   * Create enable Admin user.\n   */\n  readonly adminEnabled?: boolean;\n  /**\n   * Specify the locations to configure replication.\n   */\n  readonly geoReplicationLocations?: any;\n}\n\nexport class Registry extends AzureResource {\n  public readonly props: RegistryProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n\n  /**\n   * Constructs a new Azure Container Registry (ACR).\n   *\n   * This class creates an Azure Container Registry instance, which is a managed Docker registry service based on the Docker Registry 2.0 specification.\n   * This service enables you to store and manage container images across all types of Azure deployments, you can also use it to build, store, and manage images for all types of container deployments.\n   *\n   * @param scope - The scope in which to define this construct, typically used for managing lifecycles and creation order.\n   * @param id - The unique identifier for this construct instance.\n   * @param props - The properties for configuring the Azure Container Registry. The properties include:\n   *                - `location`: Required. The Azure region where the registry will be deployed.\n   *                - `name`: Required. The name of the Container Registry.\n   *                - `resourceGroup`: Required. The Azure Resource Group in which to deploy the registry.\n   *                - `sku`: Optional. The SKU of the Container Registry (e.g., Basic, Standard, Premium). Determines the features available.\n   *                - `tags`: Optional. Tags for resource management.\n   *                - `adminEnabled`: Optional. Specifies whether the admin user is enabled for the registry. Defaults to false if not set.\n   *                - `geoReplicationLocations`: Optional. Specifies additional Azure regions where the registry should be geo-replicated.\n   *\n   * Example usage:\n   * ```typescript\n   * new Registry(this, 'myRegistry', {\n   *   location: 'West US',\n   *   name: 'myContainerRegistry',\n   *   resourceGroup: resourceGroup,\n   *   sku: 'Premium',\n   *   adminEnabled: true,\n   *   geoReplicationLocations: ['East US', 'West Europe']\n   * });\n   * ```\n   */\n  constructor(scope: Construct, id: string, props: RegistryProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Provide default values\n    const sku = props.sku ?? \"Basic\";\n    const admin_enabled = props.adminEnabled ?? false;\n    const georeplication_locations = props.geoReplicationLocations ?? [];\n\n    const azurermContainerRegistry = new ContainerRegistry(this, \"acr\", {\n      location: props.location,\n      name: props.name,\n      resourceGroupName: props.resourceGroup.name,\n      sku: sku,\n      tags: props.tags,\n      adminEnabled: admin_enabled,\n      georeplications: georeplication_locations,\n    });\n\n    this.id = azurermContainerRegistry.id;\n\n    // Terraform Outputs\n    const cdktfTerraformOutputACRid = new cdktf.TerraformOutput(this, \"id\", {\n      value: azurermContainerRegistry.id,\n    });\n\n    const cdktfTerraformOutputACRName = new cdktf.TerraformOutput(\n      this,\n      \"container_registry_name\",\n      {\n        value: azurermContainerRegistry.name,\n      },\n    );\n\n    const cdktfTerraformOutputACRloginserver = new cdktf.TerraformOutput(\n      this,\n      \"login_server\",\n      {\n        value: azurermContainerRegistry.loginServer,\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    cdktfTerraformOutputACRid.overrideLogicalId(\"id\");\n    cdktfTerraformOutputACRName.overrideLogicalId(\"container_registry_name\");\n    cdktfTerraformOutputACRloginserver.overrideLogicalId(\"login_server\");\n  }\n}\n"]}
|
|
@@ -9,6 +9,56 @@ export declare class DataLake extends AzureResource {
|
|
|
9
9
|
resourceGroup: ResourceGroup;
|
|
10
10
|
readonly filesystems: Map<string, DataLakeFilesystem>;
|
|
11
11
|
readonly storageAccount: sa.Account;
|
|
12
|
+
/**
|
|
13
|
+
* Represents an Azure Data Lake storage account, managing the storage and retrieval of data in a scalable, secure manner.
|
|
14
|
+
*
|
|
15
|
+
* This class encapsulates the properties and functionality of an Azure Data Lake, which is built on top of Azure Blob storage
|
|
16
|
+
* with enhanced capabilities to handle big data analytics efficiently. The Data Lake enables batch and real-time data processing
|
|
17
|
+
* and collaboration for analytics purposes. It provides a centralized place to store structured or unstructured data from multiple
|
|
18
|
+
* sources so that it can be processed and analyzed.
|
|
19
|
+
*
|
|
20
|
+
* Properties:
|
|
21
|
+
* - `accountReplicationType`: Specifies the type of data replication for durability and availability. Options include locally redundant storage (LRS),
|
|
22
|
+
* geo-redundant storage (GRS), and read-access geo-redundant storage (RAGRS).
|
|
23
|
+
* - `accountTier`: Defines the performance tier (e.g., Standard, Premium) that affects the type of hardware used for the storage account.
|
|
24
|
+
* - `location`: The Azure region where the storage account is located, influencing where data is stored geographically.
|
|
25
|
+
* - `name`: A unique name for the storage account within Azure.
|
|
26
|
+
* - `resourceGroup`: The resource group under which the storage account is categorized and billed.
|
|
27
|
+
* - `tags`: Key-value pairs for resource categorization and operational management.
|
|
28
|
+
* - `enableHttpsTrafficOnly`: Enforces HTTPS for data transfer, enhancing security by encrypting data in transit.
|
|
29
|
+
* - `identity`: Managed Service Identity configuration for Azure Active Directory authentication management.
|
|
30
|
+
* - `accessTier`: Specifies the data access tier (Hot, Cool) affecting cost and retrieval speeds.
|
|
31
|
+
* - `isHnsEnabled`: Indicates if the Hierarchical Namespace is enabled, required for Azure Data Lake Storage Gen2.
|
|
32
|
+
* - `minTlsVersion`: The minimum version of TLS required for securing connections, enhancing data security.
|
|
33
|
+
* - `publicNetworkAccessEnabled`: Controls whether the storage account is accessible from the public internet.
|
|
34
|
+
* - `accountKind`: Specifies the kind of storage account, which can influence supported features and pricing.
|
|
35
|
+
*
|
|
36
|
+
* @param scope - The scope in which this construct is defined, typically representing the cloud development kit (CDK) stack.
|
|
37
|
+
* @param id - The unique identifier for this construct.
|
|
38
|
+
* @param props - Properties for configuring the Data Lake, including location, name, security settings, etc.
|
|
39
|
+
*/
|
|
12
40
|
constructor(scope: Construct, id: string, props: any);
|
|
41
|
+
/**
|
|
42
|
+
* Creates a new Data Lake Gen2 filesystem within the specified storage account.
|
|
43
|
+
*
|
|
44
|
+
* This method initializes a new filesystem in Azure Data Lake Storage Gen2, allowing for the storage of hierarchical data structures.
|
|
45
|
+
* Each filesystem can contain multiple directories and files, organized in a hierarchical manner. This method ensures that the filesystem
|
|
46
|
+
* name is unique within the storage account to prevent naming conflicts.
|
|
47
|
+
*
|
|
48
|
+
* @param name - The name of the new filesystem to create. This name must be unique within the storage account.
|
|
49
|
+
* @param props - Configuration properties for the new filesystem, including metadata, encryption settings, and more.
|
|
50
|
+
* @returns The newly created DataLakeFilesystem instance.
|
|
51
|
+
* @throws Error if a filesystem with the same name already exists in the storage account.
|
|
52
|
+
*
|
|
53
|
+
* Example usage:
|
|
54
|
+
* ```typescript
|
|
55
|
+
* const filesystemConfig = {
|
|
56
|
+
* properties: { property1: 'value1' }, // Example properties
|
|
57
|
+
* defaultEncryptionScope: 'myEncryptionScope'
|
|
58
|
+
* };
|
|
59
|
+
* const newFilesystem = storageAccount.addDataLakeFilesystem('myNewFilesystem', filesystemConfig);
|
|
60
|
+
* ```
|
|
61
|
+
* This example creates a new filesystem named 'myNewFilesystem' with specified properties and encryption scope.
|
|
62
|
+
*/
|
|
13
63
|
addDataLakeFilesystem(name: string, props: DataLakeFilesystemConfig): DataLakeFilesystem;
|
|
14
64
|
}
|
|
@@ -5,6 +5,34 @@ const filesystem_1 = require("./filesystem");
|
|
|
5
5
|
const sa = require("../../azure-storageaccount");
|
|
6
6
|
const core_azure_1 = require("../../core-azure");
|
|
7
7
|
class DataLake extends core_azure_1.AzureResource {
|
|
8
|
+
/**
|
|
9
|
+
* Represents an Azure Data Lake storage account, managing the storage and retrieval of data in a scalable, secure manner.
|
|
10
|
+
*
|
|
11
|
+
* This class encapsulates the properties and functionality of an Azure Data Lake, which is built on top of Azure Blob storage
|
|
12
|
+
* with enhanced capabilities to handle big data analytics efficiently. The Data Lake enables batch and real-time data processing
|
|
13
|
+
* and collaboration for analytics purposes. It provides a centralized place to store structured or unstructured data from multiple
|
|
14
|
+
* sources so that it can be processed and analyzed.
|
|
15
|
+
*
|
|
16
|
+
* Properties:
|
|
17
|
+
* - `accountReplicationType`: Specifies the type of data replication for durability and availability. Options include locally redundant storage (LRS),
|
|
18
|
+
* geo-redundant storage (GRS), and read-access geo-redundant storage (RAGRS).
|
|
19
|
+
* - `accountTier`: Defines the performance tier (e.g., Standard, Premium) that affects the type of hardware used for the storage account.
|
|
20
|
+
* - `location`: The Azure region where the storage account is located, influencing where data is stored geographically.
|
|
21
|
+
* - `name`: A unique name for the storage account within Azure.
|
|
22
|
+
* - `resourceGroup`: The resource group under which the storage account is categorized and billed.
|
|
23
|
+
* - `tags`: Key-value pairs for resource categorization and operational management.
|
|
24
|
+
* - `enableHttpsTrafficOnly`: Enforces HTTPS for data transfer, enhancing security by encrypting data in transit.
|
|
25
|
+
* - `identity`: Managed Service Identity configuration for Azure Active Directory authentication management.
|
|
26
|
+
* - `accessTier`: Specifies the data access tier (Hot, Cool) affecting cost and retrieval speeds.
|
|
27
|
+
* - `isHnsEnabled`: Indicates if the Hierarchical Namespace is enabled, required for Azure Data Lake Storage Gen2.
|
|
28
|
+
* - `minTlsVersion`: The minimum version of TLS required for securing connections, enhancing data security.
|
|
29
|
+
* - `publicNetworkAccessEnabled`: Controls whether the storage account is accessible from the public internet.
|
|
30
|
+
* - `accountKind`: Specifies the kind of storage account, which can influence supported features and pricing.
|
|
31
|
+
*
|
|
32
|
+
* @param scope - The scope in which this construct is defined, typically representing the cloud development kit (CDK) stack.
|
|
33
|
+
* @param id - The unique identifier for this construct.
|
|
34
|
+
* @param props - Properties for configuring the Data Lake, including location, name, security settings, etc.
|
|
35
|
+
*/
|
|
8
36
|
constructor(scope, id, props) {
|
|
9
37
|
super(scope, id);
|
|
10
38
|
this.filesystems = new Map();
|
|
@@ -24,6 +52,28 @@ class DataLake extends core_azure_1.AzureResource {
|
|
|
24
52
|
resourceGroup: this.resourceGroup,
|
|
25
53
|
});
|
|
26
54
|
}
|
|
55
|
+
/**
|
|
56
|
+
* Creates a new Data Lake Gen2 filesystem within the specified storage account.
|
|
57
|
+
*
|
|
58
|
+
* This method initializes a new filesystem in Azure Data Lake Storage Gen2, allowing for the storage of hierarchical data structures.
|
|
59
|
+
* Each filesystem can contain multiple directories and files, organized in a hierarchical manner. This method ensures that the filesystem
|
|
60
|
+
* name is unique within the storage account to prevent naming conflicts.
|
|
61
|
+
*
|
|
62
|
+
* @param name - The name of the new filesystem to create. This name must be unique within the storage account.
|
|
63
|
+
* @param props - Configuration properties for the new filesystem, including metadata, encryption settings, and more.
|
|
64
|
+
* @returns The newly created DataLakeFilesystem instance.
|
|
65
|
+
* @throws Error if a filesystem with the same name already exists in the storage account.
|
|
66
|
+
*
|
|
67
|
+
* Example usage:
|
|
68
|
+
* ```typescript
|
|
69
|
+
* const filesystemConfig = {
|
|
70
|
+
* properties: { property1: 'value1' }, // Example properties
|
|
71
|
+
* defaultEncryptionScope: 'myEncryptionScope'
|
|
72
|
+
* };
|
|
73
|
+
* const newFilesystem = storageAccount.addDataLakeFilesystem('myNewFilesystem', filesystemConfig);
|
|
74
|
+
* ```
|
|
75
|
+
* This example creates a new filesystem named 'myNewFilesystem' with specified properties and encryption scope.
|
|
76
|
+
*/
|
|
27
77
|
addDataLakeFilesystem(name, props) {
|
|
28
78
|
if (this.filesystems.has(name)) {
|
|
29
79
|
throw new Error(`Filesystem '${name}' already exists.`);
|
|
@@ -39,4 +89,4 @@ class DataLake extends core_azure_1.AzureResource {
|
|
|
39
89
|
}
|
|
40
90
|
}
|
|
41
91
|
exports.DataLake = DataLake;
|
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datalake.js","sourceRoot":"","sources":["../../../src/azure-datalake/lib/datalake.ts"],"names":[],"mappings":";;;AAGA,6CAA4E;AAC5E,iDAAiD;AACjD,iDAAiD;AAEjD,MAAa,QAAS,SAAQ,0BAAa;IAOzC;;;;;;;;;;;;;;;;;;;;;;;;;;;OA2BG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAU;QAClD,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,IAAI,CAAC,WAAW,GAAG,IAAI,GAAG,EAA8B,CAAC;QACzD,iBAAiB;QACjB,IAAI,CAAC,KAAK,GAAG;YACX,IAAI,EAAE,cAAc;YACpB,QAAQ,EAAE,QAAQ;YAClB,GAAG,KAAK;SACT,CAAC;QAEF,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QACpD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC;QAEjD,IAAI,CAAC,cAAc,GAAG,IAAI,EAAE,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,GAAG,gBAAgB,EAAE;YACjE,GAAG,IAAI,CAAC,KAAK;YACb,WAAW,EAAE,UAAU;YACvB,WAAW,EAAE,WAAW;YACxB,YAAY,EAAE,IAAI;YAClB,aAAa,EAAE,IAAI,CAAC,aAAa;SAClC,CAAC,CAAC;IACL,CAAC;IACD;;;;;;;;;;;;;;;;;;;;;OAqBG;IACI,qBAAqB,CAC1B,IAAY,EACZ,KAA+B;QAE/B,IAAI,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,eAAe,IAAI,mBAAmB,CAAC,CAAC;SACzD;QAED,IAAI,MAAM,GAAwC;YAChD,IAAI,EAAE,IAAI;YACV,gBAAgB,EAAE,IAAI,CAAC,cAAc,CAAC,EAAE;YACxC,GAAG,KAAK;SACT,CAAC;QAEF,MAAM,aAAa,GAAG,IAAI,+BAAkB,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;QAEjE,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,aAAa,CAAC,CAAC;QAC1C,OAAO,aAAa,CAAC;IACvB,CAAC;CACF;AAjGD,4BAiGC","sourcesContent":["import { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { StorageDataLakeGen2FilesystemConfig } from \"@cdktf/provider-azurerm/lib/storage-data-lake-gen2-filesystem\";\nimport { Construct } from \"constructs\";\nimport { DataLakeFilesystem, DataLakeFilesystemConfig } from \"./filesystem\";\nimport * as sa from \"../../azure-storageaccount\";\nimport { AzureResource } from \"../../core-azure\";\n\nexport class DataLake extends AzureResource {\n  readonly props: any;\n  public resourceGroupName: string;\n  public resourceGroup: ResourceGroup;\n  public readonly filesystems: Map<string, DataLakeFilesystem>;\n\n  public readonly storageAccount: sa.Account;\n  /**\n   * Represents an Azure Data Lake storage account, managing the storage and retrieval of data in a scalable, secure manner.\n   *\n   * This class encapsulates the properties and functionality of an Azure Data Lake, which is built on top of Azure Blob storage\n   * with enhanced capabilities to handle big data analytics efficiently. The Data Lake enables batch and real-time data processing\n   * and collaboration for analytics purposes. It provides a centralized place to store structured or unstructured data from multiple\n   * sources so that it can be processed and analyzed.\n   *\n   * Properties:\n   * - `accountReplicationType`: Specifies the type of data replication for durability and availability. Options include locally redundant storage (LRS),\n   *   geo-redundant storage (GRS), and read-access geo-redundant storage (RAGRS).\n   * - `accountTier`: Defines the performance tier (e.g., Standard, Premium) that affects the type of hardware used for the storage account.\n   * - `location`: The Azure region where the storage account is located, influencing where data is stored geographically.\n   * - `name`: A unique name for the storage account within Azure.\n   * - `resourceGroup`: The resource group under which the storage account is categorized and billed.\n   * - `tags`: Key-value pairs for resource categorization and operational management.\n   * - `enableHttpsTrafficOnly`: Enforces HTTPS for data transfer, enhancing security by encrypting data in transit.\n   * - `identity`: Managed Service Identity configuration for Azure Active Directory authentication management.\n   * - `accessTier`: Specifies the data access tier (Hot, Cool) affecting cost and retrieval speeds.\n   * - `isHnsEnabled`: Indicates if the Hierarchical Namespace is enabled, required for Azure Data Lake Storage Gen2.\n   * - `minTlsVersion`: The minimum version of TLS required for securing connections, enhancing data security.\n   * - `publicNetworkAccessEnabled`: Controls whether the storage account is accessible from the public internet.\n   * - `accountKind`: Specifies the kind of storage account, which can influence supported features and pricing.\n   *\n   * @param scope - The scope in which this construct is defined, typically representing the cloud development kit (CDK) stack.\n   * @param id - The unique identifier for this construct.\n   * @param props - Properties for configuring the Data Lake, including location, name, security settings, etc.\n   */\n  constructor(scope: Construct, id: string, props: any) {\n    super(scope, id);\n    this.filesystems = new Map<string, DataLakeFilesystem>();\n    // Default values\n    this.props = {\n      name: \"test42348808\",\n      location: \"eastus\",\n      ...props,\n    };\n\n    this.resourceGroup = this.setupResourceGroup(props);\n    this.resourceGroupName = this.resourceGroup.name;\n\n    this.storageAccount = new sa.Account(scope, id + \"storageAccount\", {\n      ...this.props,\n      accountTier: \"Standard\",\n      accountKind: \"StorageV2\",\n      isHnsEnabled: true,\n      resourceGroup: this.resourceGroup,\n    });\n  }\n  /**\n   * Creates a new Data Lake Gen2 filesystem within the specified storage account.\n   *\n   * This method initializes a new filesystem in Azure Data Lake Storage Gen2, allowing for the storage of hierarchical data structures.\n   * Each filesystem can contain multiple directories and files, organized in a hierarchical manner. This method ensures that the filesystem\n   * name is unique within the storage account to prevent naming conflicts.\n   *\n   * @param name - The name of the new filesystem to create. This name must be unique within the storage account.\n   * @param props - Configuration properties for the new filesystem, including metadata, encryption settings, and more.\n   * @returns The newly created DataLakeFilesystem instance.\n   * @throws Error if a filesystem with the same name already exists in the storage account.\n   *\n   * Example usage:\n   * ```typescript\n   * const filesystemConfig = {\n   *   properties: { property1: 'value1' },  // Example properties\n   *   defaultEncryptionScope: 'myEncryptionScope'\n   * };\n   * const newFilesystem = storageAccount.addDataLakeFilesystem('myNewFilesystem', filesystemConfig);\n   * ```\n   * This example creates a new filesystem named 'myNewFilesystem' with specified properties and encryption scope.\n   */\n  public addDataLakeFilesystem(\n    name: string,\n    props: DataLakeFilesystemConfig,\n  ): DataLakeFilesystem {\n    if (this.filesystems.has(name)) {\n      throw new Error(`Filesystem '${name}' already exists.`);\n    }\n\n    var config: StorageDataLakeGen2FilesystemConfig = {\n      name: name,\n      storageAccountId: this.storageAccount.id,\n      ...props,\n    };\n\n    const newFilesystem = new DataLakeFilesystem(this, name, config);\n\n    this.filesystems.set(name, newFilesystem);\n    return newFilesystem;\n  }\n}\n"]}
|
|
@@ -14,6 +14,57 @@ export declare class DataLakeFilesystem extends Construct {
|
|
|
14
14
|
readonly filesystem: StorageDataLakeGen2Filesystem;
|
|
15
15
|
readonly paths: Map<string, DataLakePath>;
|
|
16
16
|
private storageAccountId;
|
|
17
|
+
/**
|
|
18
|
+
* Represents a filesystem within Azure Data Lake Storage Gen2.
|
|
19
|
+
*
|
|
20
|
+
* This class manages the lifecycle and configuration of a filesystem in Azure Data Lake Gen2, which is used to store directories and files
|
|
21
|
+
* in a hierarchical structure. This class allows for the creation, configuration, and management of access controls and properties associated with a filesystem.
|
|
22
|
+
*
|
|
23
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
24
|
+
* @param id - The unique identifier for this instance of the filesystem.
|
|
25
|
+
* @param props - Configuration properties for the Data Lake Gen2 filesystem. These properties may include:
|
|
26
|
+
* - `name`: The name of the filesystem.
|
|
27
|
+
* - `storageAccountId`: The ID of the Azure Storage account that hosts the filesystem.
|
|
28
|
+
* - `defaultEncryptionScope`: Specifies the default encryption scope for the filesystem.
|
|
29
|
+
* - `properties`: A dictionary of strings representing properties to associate with the filesystem.
|
|
30
|
+
* - `ace`: An array of access control expressions to define permissions within the filesystem.
|
|
31
|
+
*
|
|
32
|
+
* Example usage:
|
|
33
|
+
* ```typescript
|
|
34
|
+
* const dataLakeFilesystem = new StorageDataLakeGen2Filesystem(this, 'myFilesystem', {
|
|
35
|
+
* name: 'mydatafilesystem',
|
|
36
|
+
* storageAccountId: 'storage_account_id',
|
|
37
|
+
* defaultEncryptionScope: 'my-encryption-scope',
|
|
38
|
+
* properties: {
|
|
39
|
+
* property1: 'value1',
|
|
40
|
+
* property2: 'value2'
|
|
41
|
+
* }
|
|
42
|
+
* });
|
|
43
|
+
* ```
|
|
44
|
+
* This class initializes a filesystem with specified configurations such as name, storage account ID, and optional properties like encryption scope and custom properties.
|
|
45
|
+
*/
|
|
17
46
|
constructor(scope: Construct, id: string, props: StorageDataLakeGen2FilesystemConfig);
|
|
47
|
+
/**
|
|
48
|
+
* Adds a new directory or file path to the existing Data Lake Gen2 filesystem.
|
|
49
|
+
*
|
|
50
|
+
* This method allows for the creation of a new path, which can be either a directory or a file, within the defined filesystem in Azure Data Lake Gen2.
|
|
51
|
+
* Each path is configured with optional properties and access controls, making it possible to finely tune the permissions and settings for data stored at this path.
|
|
52
|
+
*
|
|
53
|
+
* @param name - The name of the new path to create within the filesystem. This name must be unique within the filesystem.
|
|
54
|
+
* @param props - Configuration properties for the new path, including access controls, ownership details, and other relevant settings.
|
|
55
|
+
* @returns The newly created DataLakePath instance representing the path within the filesystem.
|
|
56
|
+
* @throws Error if a path with the same name already exists in the filesystem.
|
|
57
|
+
*
|
|
58
|
+
* Example usage:
|
|
59
|
+
* ```typescript
|
|
60
|
+
* const pathConfig = {
|
|
61
|
+
* group: 'dataGroup',
|
|
62
|
+
* owner: 'dataOwner',
|
|
63
|
+
* ace: [{ id: 'ace1', type: 'user', permissions: 'rwx' }]
|
|
64
|
+
* };
|
|
65
|
+
* const newPath = dataLakeFilesystem.addDataLakePath('newDataPath', pathConfig);
|
|
66
|
+
* ```
|
|
67
|
+
* This example demonstrates adding a new path 'newDataPath' to the filesystem with specified group, owner, and access control entries.
|
|
68
|
+
*/
|
|
18
69
|
addDataLakePath(name: string, props: DataLakePathConfig): DataLakePath;
|
|
19
70
|
}
|
|
@@ -5,6 +5,35 @@ const storage_data_lake_gen2_filesystem_1 = require("@cdktf/provider-azurerm/lib
|
|
|
5
5
|
const constructs_1 = require("constructs");
|
|
6
6
|
const path_1 = require("./path");
|
|
7
7
|
class DataLakeFilesystem extends constructs_1.Construct {
|
|
8
|
+
/**
|
|
9
|
+
* Represents a filesystem within Azure Data Lake Storage Gen2.
|
|
10
|
+
*
|
|
11
|
+
* This class manages the lifecycle and configuration of a filesystem in Azure Data Lake Gen2, which is used to store directories and files
|
|
12
|
+
* in a hierarchical structure. This class allows for the creation, configuration, and management of access controls and properties associated with a filesystem.
|
|
13
|
+
*
|
|
14
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
15
|
+
* @param id - The unique identifier for this instance of the filesystem.
|
|
16
|
+
* @param props - Configuration properties for the Data Lake Gen2 filesystem. These properties may include:
|
|
17
|
+
* - `name`: The name of the filesystem.
|
|
18
|
+
* - `storageAccountId`: The ID of the Azure Storage account that hosts the filesystem.
|
|
19
|
+
* - `defaultEncryptionScope`: Specifies the default encryption scope for the filesystem.
|
|
20
|
+
* - `properties`: A dictionary of strings representing properties to associate with the filesystem.
|
|
21
|
+
* - `ace`: An array of access control expressions to define permissions within the filesystem.
|
|
22
|
+
*
|
|
23
|
+
* Example usage:
|
|
24
|
+
* ```typescript
|
|
25
|
+
* const dataLakeFilesystem = new StorageDataLakeGen2Filesystem(this, 'myFilesystem', {
|
|
26
|
+
* name: 'mydatafilesystem',
|
|
27
|
+
* storageAccountId: 'storage_account_id',
|
|
28
|
+
* defaultEncryptionScope: 'my-encryption-scope',
|
|
29
|
+
* properties: {
|
|
30
|
+
* property1: 'value1',
|
|
31
|
+
* property2: 'value2'
|
|
32
|
+
* }
|
|
33
|
+
* });
|
|
34
|
+
* ```
|
|
35
|
+
* This class initializes a filesystem with specified configurations such as name, storage account ID, and optional properties like encryption scope and custom properties.
|
|
36
|
+
*/
|
|
8
37
|
constructor(scope, id, props) {
|
|
9
38
|
super(scope, id);
|
|
10
39
|
this.name = id;
|
|
@@ -12,6 +41,28 @@ class DataLakeFilesystem extends constructs_1.Construct {
|
|
|
12
41
|
this.storageAccountId = props.storageAccountId;
|
|
13
42
|
this.filesystem = new storage_data_lake_gen2_filesystem_1.StorageDataLakeGen2Filesystem(this, id, props);
|
|
14
43
|
}
|
|
44
|
+
/**
|
|
45
|
+
* Adds a new directory or file path to the existing Data Lake Gen2 filesystem.
|
|
46
|
+
*
|
|
47
|
+
* This method allows for the creation of a new path, which can be either a directory or a file, within the defined filesystem in Azure Data Lake Gen2.
|
|
48
|
+
* Each path is configured with optional properties and access controls, making it possible to finely tune the permissions and settings for data stored at this path.
|
|
49
|
+
*
|
|
50
|
+
* @param name - The name of the new path to create within the filesystem. This name must be unique within the filesystem.
|
|
51
|
+
* @param props - Configuration properties for the new path, including access controls, ownership details, and other relevant settings.
|
|
52
|
+
* @returns The newly created DataLakePath instance representing the path within the filesystem.
|
|
53
|
+
* @throws Error if a path with the same name already exists in the filesystem.
|
|
54
|
+
*
|
|
55
|
+
* Example usage:
|
|
56
|
+
* ```typescript
|
|
57
|
+
* const pathConfig = {
|
|
58
|
+
* group: 'dataGroup',
|
|
59
|
+
* owner: 'dataOwner',
|
|
60
|
+
* ace: [{ id: 'ace1', type: 'user', permissions: 'rwx' }]
|
|
61
|
+
* };
|
|
62
|
+
* const newPath = dataLakeFilesystem.addDataLakePath('newDataPath', pathConfig);
|
|
63
|
+
* ```
|
|
64
|
+
* This example demonstrates adding a new path 'newDataPath' to the filesystem with specified group, owner, and access control entries.
|
|
65
|
+
*/
|
|
15
66
|
addDataLakePath(name, props) {
|
|
16
67
|
if (this.paths.has(name)) {
|
|
17
68
|
throw new Error(`Filesystem '${name}' already exists.`);
|
|
@@ -29,4 +80,4 @@ class DataLakeFilesystem extends constructs_1.Construct {
|
|
|
29
80
|
}
|
|
30
81
|
}
|
|
31
82
|
exports.DataLakeFilesystem = DataLakeFilesystem;
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmlsZXN5c3RlbS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9henVyZS1kYXRhbGFrZS9saWIvZmlsZXN5c3RlbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxxSEFJdUU7QUFFdkUsMkNBQXVDO0FBQ3ZDLGlDQUEwRDtBQVMxRCxNQUFhLGtCQUFtQixTQUFRLHNCQUFTO0lBTy9DOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O09BNEJHO0lBQ0gsWUFDRSxLQUFnQixFQUNoQixFQUFVLEVBQ1YsS0FBMEM7UUFFMUMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNqQixJQUFJLENBQUMsSUFBSSxHQUFHLEVBQUUsQ0FBQztRQUNmLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxHQUFHLEVBQXdCLENBQUM7UUFDN0MsSUFBSSxDQUFDLGdCQUFnQixHQUFHLEtBQUssQ0FBQyxnQkFBZ0IsQ0FBQztRQUMvQyxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksaUVBQTZCLENBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBRUQ7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztPQXFCRztJQUNJLGVBQWUsQ0FDcEIsSUFBWSxFQUNaLEtBQXlCO1FBRXpCLElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxlQUFlLElBQUksbUJBQW1CLENBQUMsQ0FBQztTQUN6RDtRQUVELElBQUksTUFBTSxHQUFrQztZQUMxQyxjQUFjLEVBQUUsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJO1lBQ3BDLGdCQUFnQixFQUFFLElBQUksQ0FBQyxnQkFBZ0I7WUFDdkMsSUFBSSxFQUFFLElBQUk7WUFDVixRQUFRLEVBQUUsV0FBVztZQUNyQixHQUFHLEtBQUs7U0FDVCxDQUFDO1FBRUYsTUFBTSxPQUFPLEdBQUcsSUFBSSxtQkFBWSxDQUFDLElBQUksRUFBRSxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUM7UUFFckQsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQzlCLE9BQU8sT0FBTyxDQUFDO0lBQ2pCLENBQUM7Q0FDRjtBQTNGRCxnREEyRkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBTdG9yYWdlRGF0YUxha2VHZW4yRmlsZXN5c3RlbSxcbiAgU3RvcmFnZURhdGFMYWtlR2VuMkZpbGVzeXN0ZW1Db25maWcsXG4gIFN0b3JhZ2VEYXRhTGFrZUdlbjJGaWxlc3lzdGVtQWNlLFxufSBmcm9tIFwiQGNka3RmL3Byb3ZpZGVyLWF6dXJlcm0vbGliL3N0b3JhZ2UtZGF0YS1sYWtlLWdlbjItZmlsZXN5c3RlbVwiO1xuaW1wb3J0IHsgU3RvcmFnZURhdGFMYWtlR2VuMlBhdGhDb25maWcgfSBmcm9tIFwiQGNka3RmL3Byb3ZpZGVyLWF6dXJlcm0vbGliL3N0b3JhZ2UtZGF0YS1sYWtlLWdlbjItcGF0aFwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCB7IERhdGFMYWtlUGF0aCwgRGF0YUxha2VQYXRoQ29uZmlnIH0gZnJvbSBcIi4vcGF0aFwiO1xuXG5leHBvcnQgaW50ZXJmYWNlIERhdGFMYWtlRmlsZXN5c3RlbUNvbmZpZyB7XG4gIHJlYWRvbmx5IGdyb3VwPzogc3RyaW5nO1xuICByZWFkb25seSBvd25lcj86IHN0cmluZztcbiAgcmVhZG9ubHkgcHJvcGVydGllcz86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIHJlYWRvbmx5IGFjZT86IFN0b3JhZ2VEYXRhTGFrZUdlbjJGaWxlc3lzdGVtQWNlW107XG59XG5cbmV4cG9ydCBjbGFzcyBEYXRhTGFrZUZpbGVzeXN0ZW0gZXh0ZW5kcyBDb25zdHJ1Y3Qge1xuICBwdWJsaWMgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgZmlsZXN5c3RlbTogU3RvcmFnZURhdGFMYWtlR2VuMkZpbGVzeXN0ZW07XG4gIHB1YmxpYyByZWFkb25seSBwYXRoczogTWFwPHN0cmluZywgRGF0YUxha2VQYXRoPjtcblxuICBwcml2YXRlIHN0b3JhZ2VBY2NvdW50SWQ6IHN0cmluZztcblxuICAvKipcbiAgICogUmVwcmVzZW50cyBhIGZpbGVzeXN0ZW0gd2l0aGluIEF6dXJlIERhdGEgTGFrZSBTdG9yYWdlIEdlbjIuXG4gICAqXG4gICAqIFRoaXMgY2xhc3MgbWFuYWdlcyB0aGUgbGlmZWN5Y2xlIGFuZCBjb25maWd1cmF0aW9uIG9mIGEgZmlsZXN5c3RlbSBpbiBBenVyZSBEYXRhIExha2UgR2VuMiwgd2hpY2ggaXMgdXNlZCB0byBzdG9yZSBkaXJlY3RvcmllcyBhbmQgZmlsZXNcbiAgICogaW4gYSBoaWVyYXJjaGljYWwgc3RydWN0dXJlLiBUaGlzIGNsYXNzIGFsbG93cyBmb3IgdGhlIGNyZWF0aW9uLCBjb25maWd1cmF0aW9uLCBhbmQgbWFuYWdlbWVudCBvZiBhY2Nlc3MgY29udHJvbHMgYW5kIHByb3BlcnRpZXMgYXNzb2NpYXRlZCB3aXRoIGEgZmlsZXN5c3RlbS5cbiAgICpcbiAgICogQHBhcmFtIHNjb3BlIC0gVGhlIHNjb3BlIGluIHdoaWNoIHRvIGRlZmluZSB0aGlzIGNvbnN0cnVjdCwgdHlwaWNhbGx5IHJlcHJlc2VudGluZyB0aGUgQ2xvdWQgRGV2ZWxvcG1lbnQgS2l0IChDREspIHN0YWNrLlxuICAgKiBAcGFyYW0gaWQgLSBUaGUgdW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoaXMgaW5zdGFuY2Ugb2YgdGhlIGZpbGVzeXN0ZW0uXG4gICAqIEBwYXJhbSBwcm9wcyAtIENvbmZpZ3VyYXRpb24gcHJvcGVydGllcyBmb3IgdGhlIERhdGEgTGFrZSBHZW4yIGZpbGVzeXN0ZW0uIFRoZXNlIHByb3BlcnRpZXMgbWF5IGluY2x1ZGU6XG4gICAqICAgICAgICAgICAgICAgIC0gYG5hbWVgOiBUaGUgbmFtZSBvZiB0aGUgZmlsZXN5c3RlbS5cbiAgICogICAgICAgICAgICAgICAgLSBgc3RvcmFnZUFjY291bnRJZGA6IFRoZSBJRCBvZiB0aGUgQXp1cmUgU3RvcmFnZSBhY2NvdW50IHRoYXQgaG9zdHMgdGhlIGZpbGVzeXN0ZW0uXG4gICAqICAgICAgICAgICAgICAgIC0gYGRlZmF1bHRFbmNyeXB0aW9uU2NvcGVgOiBTcGVjaWZpZXMgdGhlIGRlZmF1bHQgZW5jcnlwdGlvbiBzY29wZSBmb3IgdGhlIGZpbGVzeXN0ZW0uXG4gICAqICAgICAgICAgICAgICAgIC0gYHByb3BlcnRpZXNgOiBBIGRpY3Rpb25hcnkgb2Ygc3RyaW5ncyByZXByZXNlbnRpbmcgcHJvcGVydGllcyB0byBhc3NvY2lhdGUgd2l0aCB0aGUgZmlsZXN5c3RlbS5cbiAgICogICAgICAgICAgICAgICAgLSBgYWNlYDogQW4gYXJyYXkgb2YgYWNjZXNzIGNvbnRyb2wgZXhwcmVzc2lvbnMgdG8gZGVmaW5lIHBlcm1pc3Npb25zIHdpdGhpbiB0aGUgZmlsZXN5c3RlbS5cbiAgICpcbiAgICogRXhhbXBsZSB1c2FnZTpcbiAgICogYGBgdHlwZXNjcmlwdFxuICAgKiBjb25zdCBkYXRhTGFrZUZpbGVzeXN0ZW0gPSBuZXcgU3RvcmFnZURhdGFMYWtlR2VuMkZpbGVzeXN0ZW0odGhpcywgJ215RmlsZXN5c3RlbScsIHtcbiAgICogICBuYW1lOiAnbXlkYXRhZmlsZXN5c3RlbScsXG4gICAqICAgc3RvcmFnZUFjY291bnRJZDogJ3N0b3JhZ2VfYWNjb3VudF9pZCcsXG4gICAqICAgZGVmYXVsdEVuY3J5cHRpb25TY29wZTogJ215LWVuY3J5cHRpb24tc2NvcGUnLFxuICAgKiAgIHByb3BlcnRpZXM6IHtcbiAgICogICAgIHByb3BlcnR5MTogJ3ZhbHVlMScsXG4gICAqICAgICBwcm9wZXJ0eTI6ICd2YWx1ZTInXG4gICAqICAgfVxuICAgKiB9KTtcbiAgICogYGBgXG4gICAqIFRoaXMgY2xhc3MgaW5pdGlhbGl6ZXMgYSBmaWxlc3lzdGVtIHdpdGggc3BlY2lmaWVkIGNvbmZpZ3VyYXRpb25zIHN1Y2ggYXMgbmFtZSwgc3RvcmFnZSBhY2NvdW50IElELCBhbmQgb3B0aW9uYWwgcHJvcGVydGllcyBsaWtlIGVuY3J5cHRpb24gc2NvcGUgYW5kIGN1c3RvbSBwcm9wZXJ0aWVzLlxuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgc2NvcGU6IENvbnN0cnVjdCxcbiAgICBpZDogc3RyaW5nLFxuICAgIHByb3BzOiBTdG9yYWdlRGF0YUxha2VHZW4yRmlsZXN5c3RlbUNvbmZpZyxcbiAgKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcbiAgICB0aGlzLm5hbWUgPSBpZDtcbiAgICB0aGlzLnBhdGhzID0gbmV3IE1hcDxzdHJpbmcsIERhdGFMYWtlUGF0aD4oKTtcbiAgICB0aGlzLnN0b3JhZ2VBY2NvdW50SWQgPSBwcm9wcy5zdG9yYWdlQWNjb3VudElkO1xuICAgIHRoaXMuZmlsZXN5c3RlbSA9IG5ldyBTdG9yYWdlRGF0YUxha2VHZW4yRmlsZXN5c3RlbSh0aGlzLCBpZCwgcHJvcHMpO1xuICB9XG5cbiAgLyoqXG4gICAqIEFkZHMgYSBuZXcgZGlyZWN0b3J5IG9yIGZpbGUgcGF0aCB0byB0aGUgZXhpc3RpbmcgRGF0YSBMYWtlIEdlbjIgZmlsZXN5c3RlbS5cbiAgICpcbiAgICogVGhpcyBtZXRob2QgYWxsb3dzIGZvciB0aGUgY3JlYXRpb24gb2YgYSBuZXcgcGF0aCwgd2hpY2ggY2FuIGJlIGVpdGhlciBhIGRpcmVjdG9yeSBvciBhIGZpbGUsIHdpdGhpbiB0aGUgZGVmaW5lZCBmaWxlc3lzdGVtIGluIEF6dXJlIERhdGEgTGFrZSBHZW4yLlxuICAgKiBFYWNoIHBhdGggaXMgY29uZmlndXJlZCB3aXRoIG9wdGlvbmFsIHByb3BlcnRpZXMgYW5kIGFjY2VzcyBjb250cm9scywgbWFraW5nIGl0IHBvc3NpYmxlIHRvIGZpbmVseSB0dW5lIHRoZSBwZXJtaXNzaW9ucyBhbmQgc2V0dGluZ3MgZm9yIGRhdGEgc3RvcmVkIGF0IHRoaXMgcGF0aC5cbiAgICpcbiAgICogQHBhcmFtIG5hbWUgLSBUaGUgbmFtZSBvZiB0aGUgbmV3IHBhdGggdG8gY3JlYXRlIHdpdGhpbiB0aGUgZmlsZXN5c3RlbS4gVGhpcyBuYW1lIG11c3QgYmUgdW5pcXVlIHdpdGhpbiB0aGUgZmlsZXN5c3RlbS5cbiAgICogQHBhcmFtIHByb3BzIC0gQ29uZmlndXJhdGlvbiBwcm9wZXJ0aWVzIGZvciB0aGUgbmV3IHBhdGgsIGluY2x1ZGluZyBhY2Nlc3MgY29udHJvbHMsIG93bmVyc2hpcCBkZXRhaWxzLCBhbmQgb3RoZXIgcmVsZXZhbnQgc2V0dGluZ3MuXG4gICAqIEByZXR1cm5zIFRoZSBuZXdseSBjcmVhdGVkIERhdGFMYWtlUGF0aCBpbnN0YW5jZSByZXByZXNlbnRpbmcgdGhlIHBhdGggd2l0aGluIHRoZSBmaWxlc3lzdGVtLlxuICAgKiBAdGhyb3dzIEVycm9yIGlmIGEgcGF0aCB3aXRoIHRoZSBzYW1lIG5hbWUgYWxyZWFkeSBleGlzdHMgaW4gdGhlIGZpbGVzeXN0ZW0uXG4gICAqXG4gICAqIEV4YW1wbGUgdXNhZ2U6XG4gICAqIGBgYHR5cGVzY3JpcHRcbiAgICogY29uc3QgcGF0aENvbmZpZyA9IHtcbiAgICogICBncm91cDogJ2RhdGFHcm91cCcsXG4gICAqICAgb3duZXI6ICdkYXRhT3duZXInLFxuICAgKiAgIGFjZTogW3sgaWQ6ICdhY2UxJywgdHlwZTogJ3VzZXInLCBwZXJtaXNzaW9uczogJ3J3eCcgfV1cbiAgICogfTtcbiAgICogY29uc3QgbmV3UGF0aCA9IGRhdGFMYWtlRmlsZXN5c3RlbS5hZGREYXRhTGFrZVBhdGgoJ25ld0RhdGFQYXRoJywgcGF0aENvbmZpZyk7XG4gICAqIGBgYFxuICAgKiBUaGlzIGV4YW1wbGUgZGVtb25zdHJhdGVzIGFkZGluZyBhIG5ldyBwYXRoICduZXdEYXRhUGF0aCcgdG8gdGhlIGZpbGVzeXN0ZW0gd2l0aCBzcGVjaWZpZWQgZ3JvdXAsIG93bmVyLCBhbmQgYWNjZXNzIGNvbnRyb2wgZW50cmllcy5cbiAgICovXG4gIHB1YmxpYyBhZGREYXRhTGFrZVBhdGgoXG4gICAgbmFtZTogc3RyaW5nLFxuICAgIHByb3BzOiBEYXRhTGFrZVBhdGhDb25maWcsXG4gICk6IERhdGFMYWtlUGF0aCB7XG4gICAgaWYgKHRoaXMucGF0aHMuaGFzKG5hbWUpKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYEZpbGVzeXN0ZW0gJyR7bmFtZX0nIGFscmVhZHkgZXhpc3RzLmApO1xuICAgIH1cblxuICAgIHZhciBjb25maWc6IFN0b3JhZ2VEYXRhTGFrZUdlbjJQYXRoQ29uZmlnID0ge1xuICAgICAgZmlsZXN5c3RlbU5hbWU6IHRoaXMuZmlsZXN5c3RlbS5uYW1lLFxuICAgICAgc3RvcmFnZUFjY291bnRJZDogdGhpcy5zdG9yYWdlQWNjb3VudElkLFxuICAgICAgcGF0aDogbmFtZSxcbiAgICAgIHJlc291cmNlOiBcImRpcmVjdG9yeVwiLFxuICAgICAgLi4ucHJvcHMsXG4gICAgfTtcblxuICAgIGNvbnN0IG5ld1BhdGggPSBuZXcgRGF0YUxha2VQYXRoKHRoaXMsIG5hbWUsIGNvbmZpZyk7XG5cbiAgICB0aGlzLnBhdGhzLnNldChuYW1lLCBuZXdQYXRoKTtcbiAgICByZXR1cm4gbmV3UGF0aDtcbiAgfVxufVxuIl19
|
|
@@ -8,5 +8,42 @@ export interface DataLakePathConfig {
|
|
|
8
8
|
export declare class DataLakePath extends Construct {
|
|
9
9
|
readonly name: string;
|
|
10
10
|
readonly filesystem: StorageDataLakeGen2Path;
|
|
11
|
+
/**
|
|
12
|
+
* Manages a specific path within an Azure Data Lake Storage Gen2 filesystem.
|
|
13
|
+
*
|
|
14
|
+
* This class provides functionality to configure and manage a data path within a Data Lake Gen2 filesystem,
|
|
15
|
+
* such as directories and files, with access control settings. It is used to create and manage the structure
|
|
16
|
+
* and security settings of data stored in Azure Data Lake Storage Gen2.
|
|
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 Data Lake path. Typically, this is the name of the path.
|
|
20
|
+
* @param props - Configuration properties for the Data Lake Gen2 path. These properties may include:
|
|
21
|
+
* - `filesystemName`: The name of the filesystem within which this path is defined.
|
|
22
|
+
* - `path`: The specific path within the filesystem. This could represent a file or a directory.
|
|
23
|
+
* - `storageAccountId`: The ID of the Azure Storage account that hosts the filesystem.
|
|
24
|
+
* - `ace`: An array of access control expressions to define permissions for the path.
|
|
25
|
+
* - `owner`: The owner of the path for access control purposes.
|
|
26
|
+
* - `group`: The owning group for the path for access control purposes.
|
|
27
|
+
* - `resource`: Type of the resource, typically a file or directory.
|
|
28
|
+
*
|
|
29
|
+
* Example usage:
|
|
30
|
+
* ```typescript
|
|
31
|
+
* const dataLakePath = new DataLakePath(this, 'myDataPath', {
|
|
32
|
+
* filesystemName: 'myfilesystem',
|
|
33
|
+
* path: 'path/to/directory',
|
|
34
|
+
* storageAccountId: 'storage_account_id',
|
|
35
|
+
* owner: 'owner_id',
|
|
36
|
+
* group: 'group_id',
|
|
37
|
+
* ace: [{
|
|
38
|
+
* id: 'user_id',
|
|
39
|
+
* type: 'user',
|
|
40
|
+
* permissions: 'rwx',
|
|
41
|
+
* }],
|
|
42
|
+
* resource: 'directory'
|
|
43
|
+
* });
|
|
44
|
+
* ```
|
|
45
|
+
* This setup creates and manages a directory or a file path within a specified Data Lake Gen2 filesystem,
|
|
46
|
+
* applying the necessary permissions and access controls as configured.
|
|
47
|
+
*/
|
|
11
48
|
constructor(scope: Construct, id: string, props: StorageDataLakeGen2PathConfig);
|
|
12
49
|
}
|