@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,11 +9,42 @@ const constructs_1 = require("constructs");
|
|
|
9
9
|
const moment = require("moment");
|
|
10
10
|
class QueryRuleAlert extends constructs_1.Construct {
|
|
11
11
|
/**
|
|
12
|
-
*
|
|
12
|
+
* Represents an Azure Monitor Scheduled Query Rule Alert.
|
|
13
13
|
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
14
|
+
* This class is responsible for the creation and management of a Scheduled Query Rule Alert in Azure Monitor.
|
|
15
|
+
* Scheduled Query Rule Alerts execute specified queries at regular intervals over the data collected in Log Analytics
|
|
16
|
+
* Workspaces or Application Insights, and alert based on the results of these queries. These alerts can be used to monitor
|
|
17
|
+
* application health, infrastructure changes, or compliance with certain conditions.
|
|
18
|
+
*
|
|
19
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
20
|
+
* @param id - The unique identifier for this instance of the Scheduled Query Rule Alert.
|
|
21
|
+
* @param props - The properties required to configure the Scheduled Query Rule Alert, as defined in the AzureQueryRuleAlertProps interface.
|
|
22
|
+
* These include:
|
|
23
|
+
* - `name`: The name of the Scheduled Query Rule.
|
|
24
|
+
* - `resourceGroup`: The Azure Resource Group under which the alert will be created.
|
|
25
|
+
* - `location`: The Azure region where the alert will be deployed.
|
|
26
|
+
* - `criteriaQuery`: The query to execute. The results of this query determine whether an alert should be triggered.
|
|
27
|
+
* - `evaluationFrequency`: How often the query should be run.
|
|
28
|
+
* - `windowDuration`: The time period over which data is collected for each execution of the query.
|
|
29
|
+
* - `severity`: The severity of the alert.
|
|
30
|
+
* - `actionActionGroupId`: The action group to invoke when the alert criteria are met.
|
|
31
|
+
* - `enabled`: Indicates whether the alert rule is enabled.
|
|
32
|
+
*
|
|
33
|
+
* Example usage:
|
|
34
|
+
* ```typescript
|
|
35
|
+
* new QueryRuleAlert(this, 'MyAlertRule', {
|
|
36
|
+
* name: 'HighErrorRateAlert',
|
|
37
|
+
* resourceGroup: myResourceGroup,
|
|
38
|
+
* location: 'West US 2',
|
|
39
|
+
* criteriaQuery: 'Heartbeat | summarize AggregatedValue = count() by bin(TimeGenerated, 5m)',
|
|
40
|
+
* evaluationFrequency: 'PT5M',
|
|
41
|
+
* windowDuration: 'PT1H',
|
|
42
|
+
* severity: 3,
|
|
43
|
+
* actionActionGroupId: ['/subscriptions/sub-id/resourceGroups/rg/providers/microsoft.insights/actionGroups/myActionGroup'],
|
|
44
|
+
* enabled: true
|
|
45
|
+
* });
|
|
46
|
+
* ```
|
|
47
|
+
* This class sets up the alert rule and ensures it is ready to trigger actions based on the specified criteria and schedule.
|
|
17
48
|
*/
|
|
18
49
|
constructor(scope, id, props) {
|
|
19
50
|
super(scope, id);
|
|
@@ -170,5 +201,5 @@ class QueryRuleAlert extends constructs_1.Construct {
|
|
|
170
201
|
}
|
|
171
202
|
exports.QueryRuleAlert = QueryRuleAlert;
|
|
172
203
|
_a = JSII_RTTI_SYMBOL_1;
|
|
173
|
-
QueryRuleAlert[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_queryrulealert.QueryRuleAlert", version: "0.0.3-pre.
|
|
174
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-rule-alert.js","sourceRoot":"","sources":["../../../src/azure-queryrulealert/lib/query-rule-alert.ts"],"names":[],"mappings":"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","sourcesContent":["import { MonitorScheduledQueryRulesAlertV2 } from \"@cdktf/provider-azurerm/lib/monitor-scheduled-query-rules-alert-v2\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport * as moment from \"moment\";\n\nexport interface BaseAzureQueryRuleAlertProps {\n  /**\n   * The name of the Monitor Scheduled Query Rule.\n   */\n  readonly name: string;\n  /**\n   * The name of the resource group in which the Monitor Scheduled Query Rule is created.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The location of the Monitor Scheduled Query Rule.\n   */\n  readonly location: string;\n  /**\n   * Specifies the criteria operator.\n   * Possible values are Equal, GreaterThan, GreaterThanOrEqual, LessThan,and LessThanOrEqual.\n   */\n  readonly criteriaOperator: string;\n  /**\n   * The query to run on logs. The results returned by this query are used to populate the alert.\n   */\n  readonly criteriaQuery: string;\n  /**\n   * Specifies the criteria threshold value that activates the alert.\n   */\n  readonly criteriaThreshold: number;\n  /**\n   * The type of aggregation to apply to the data points in aggregation granularity.\n   * Possible values are Average, Count, Maximum, Minimum,and Total.\n   */\n  readonly criteriatimeAggregationMethod: string;\n  /**\n   * Name of the dimension for criteria.\n   */\n  readonly criteriaDimensionName?: string;\n\n  /**\n   * Operator for dimension values. Possible values are Exclude, and Include.\n   */\n  readonly criteriaDimensionOperator?: string;\n\n  /**\n   * List of dimension values. Use a wildcard * to collect all.\n   */\n  readonly criteriaDimensionValues?: string[];\n\n  /**\n   * Specifies the number of violations to trigger an alert.\n   * Should be smaller or equal to number_of_evaluation_periods.\n   * Possible value is integer between 1 and 6.\n   */\n  readonly criteriaFailMinimumFailingPeriodsToTriggerAlert?: number;\n\n  /**\n   * Specifies the number of evaluation periods.\n   * Possible value is integer between 1 and 6.\n   */\n  readonly criteriaFailNumberOfEvaluationPeriods?: number;\n  /**\n   * Specifies the column containing the metric measure number.\n   * criteriaMetricMeasureColumn is required if criteriatimeAggregationMethod is Average, Maximum, Minimum, or Total.\n   * And criteriaMetricMeasureColumn cannot be specified if criteriatimeAggregationMethod is Count.\n   */\n  readonly criteriaMetricMeasureColumn?: string;\n  /**\n   * How often the scheduled query rule is evaluated, represented in ISO 8601 duration format.\n   * Possible values are PT1M, PT5M, PT10M, PT15M, PT30M, PT45M, PT1H, PT2H, PT3H, PT4H, PT5H, PT6H, P1D.\n   */\n  readonly evaluationFrequency: string;\n  /**\n   * Severity of the alert. Should be an integer between 0 and 4. Value of 0 is severest.\n   */\n  readonly severity: number;\n  /**\n   * Specifies the period of time in ISO 8601 duration format on which the Scheduled Query Rule will be executed (bin size).\n   */\n  readonly windowDuration: string;\n  /**\n   * Specifies the action group IDs to trigger when the alert fires.\n   */\n  readonly actionActionGroupId?: string[];\n  /**\n   * Specifies the flag that indicates whether the alert should be automatically resolved or not.\n   * @default false\n   */\n  readonly autoMitigationEnabled?: boolean;\n  /**\n   * Specifies the flag which indicates whether this scheduled query rule check if storage is configured.\n   * @default false\n   */\n  readonly workspaceAlertsStorageEnabled?: boolean;\n  /**\n   * Specifies the description of the scheduled query rule.\n   */\n  readonly description?: string;\n  /**\n   * Specifies the display name of the alert rule.\n   */\n  readonly displayName?: string;\n  /**\n   * Specifies the flag which indicates whether this scheduled query rule is enabled.\n   * @default true\n   */\n  readonly enabled?: boolean;\n  /**\n   * Mute actions for the chosen period of time in ISO 8601 duration format after the alert is fired.\n   * Possible values are PT5M, PT10M, PT15M, PT30M, PT45M, PT1H, PT2H, PT3H, PT4H, PT5H, PT6H, P1D and P2D.\n   */\n  readonly muteActionsAfterAlertDuration?: string;\n  /**\n   * Set this if the alert evaluation period is different from the query time range.\n   * If not specified, the value is window_duration*number_of_evaluation_periods.\n   * Possible values are PT5M, PT10M, PT15M, PT20M, PT30M, PT45M, PT1H, PT2H, PT3H, PT4H, PT5H, PT6H, P1D and P2D.\n   */\n  readonly queryTimeRangeOverride?: string;\n  /**\n   * Specifies the flag which indicates whether the provided query should be validated or not.\n   * @default true\n   */\n  readonly skipQueryValidation?: boolean;\n  /**\n   * A mapping of tags which should be assigned to the Monitor Scheduled Query Rule.\n   */\n  readonly tags?: { [key: string]: string };\n}\n\nexport interface AzureQueryRuleAlertProps extends BaseAzureQueryRuleAlertProps {\n  /**\n   * Specifies the list of resource IDs that this scheduled query rule is scoped to.\n   */\n  readonly scopes: string[];\n}\n\nexport class QueryRuleAlert extends Construct {\n  readonly queryRuleAlertProps: AzureQueryRuleAlertProps;\n  public id: string;\n  public resourceGroup: ResourceGroup;\n\n  /**\n   * Constructs a new instance of the AzureQueryRuleAlert class.\n   *\n   * @param scope - The scope in which this construct is defined.\n   * @param id - The ID of this construct.\n   * @param props - The properties required for Azure Query Rule Alert.\n   */\n  constructor(scope: Construct, id: string, props: AzureQueryRuleAlertProps) {\n    super(scope, id);\n\n    // Properties validation\n    const evaluationFrequencyOption = [\n      \"PT1M\",\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n    ];\n    const windowDurationOption = [\n      \"PT1M\",\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n      \"P2D\",\n    ];\n    const muteActionsAfterAlertDurationOption = [\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n      \"P2D\",\n    ];\n    const queryTimeRangeOverrideOption = [\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT20M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n      \"P2D\",\n    ];\n\n    // Validate evaluationFrequency\n    if (!evaluationFrequencyOption.includes(props.evaluationFrequency)) {\n      throw new Error(\"invalid evaluationFrequency\");\n    }\n    // Validate windowDuration\n    if (!windowDurationOption.includes(props.windowDuration)) {\n      throw new Error(\"invalid windowDuration\");\n    }\n    // Validate muteActionsAfterAlertDuration\n    if (\n      props.muteActionsAfterAlertDuration &&\n      !muteActionsAfterAlertDurationOption.includes(\n        props.muteActionsAfterAlertDuration,\n      )\n    ) {\n      throw new Error(\"invalid muteActionsAfterAlertDuration\");\n    }\n    // Validate queryTimeRangeOverride\n    if (\n      props.queryTimeRangeOverride &&\n      !queryTimeRangeOverrideOption.includes(props.queryTimeRangeOverride)\n    ) {\n      throw new Error(\"invalid queryTimeRangeOverride\");\n    }\n    // The query look back which is windowDuration * numberOfEvaluationPeriods cannot exceed 48 hours.\n    if (props.criteriaFailNumberOfEvaluationPeriods) {\n      const windowDurationHours = moment\n        .duration(props.windowDuration)\n        .asHours();\n      const numberOfEvaluationPeriods =\n        props.criteriaFailNumberOfEvaluationPeriods;\n      if (windowDurationHours * numberOfEvaluationPeriods > 48) {\n        throw new Error(\"queryTimeRangeOverride cannot exceed 48 hours\");\n      }\n    }\n\n    this.queryRuleAlertProps = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Properties with default values\n    const defaults = {\n      autoMitigationEnabled: props.autoMitigationEnabled || false,\n      workspaceAlertsStorageEnabled:\n        props.workspaceAlertsStorageEnabled || false,\n      enabled: props.enabled || true,\n      skipQueryValidation: props.skipQueryValidation || true,\n      metricMeasureColumn: props.criteriaMetricMeasureColumn || undefined,\n    };\n\n    const criteriaFailingPeriods =\n      props.criteriaFailMinimumFailingPeriodsToTriggerAlert !== undefined &&\n      props.criteriaFailNumberOfEvaluationPeriods !== undefined\n        ? {\n            minimumFailingPeriodsToTriggerAlert:\n              props.criteriaFailMinimumFailingPeriodsToTriggerAlert,\n            numberOfEvaluationPeriods:\n              props.criteriaFailNumberOfEvaluationPeriods,\n          }\n        : undefined;\n\n    const dimension =\n      props.criteriaDimensionName &&\n      props.criteriaDimensionOperator &&\n      props.criteriaDimensionValues\n        ? [\n            {\n              name: props.criteriaDimensionName,\n              operator: props.criteriaDimensionOperator,\n              values: props.criteriaDimensionValues,\n            },\n          ]\n        : undefined;\n\n    const azurermMonitorQueryRuleAlert = new MonitorScheduledQueryRulesAlertV2(\n      this,\n      \"queryrulealert\",\n      {\n        ...defaults,\n        name: props.name,\n        resourceGroupName: props.resourceGroup.name,\n        location: props.location,\n        scopes: props.scopes,\n        windowDuration: props.windowDuration,\n        evaluationFrequency: props.evaluationFrequency,\n        severity: props.severity,\n        criteria: [\n          {\n            operator: props.criteriaOperator,\n            query: props.criteriaQuery,\n            threshold: props.criteriaThreshold,\n            timeAggregationMethod: props.criteriatimeAggregationMethod,\n            dimension: dimension,\n            failingPeriods: criteriaFailingPeriods,\n          },\n        ],\n        action: props.actionActionGroupId\n          ? { actionGroups: props.actionActionGroupId }\n          : undefined,\n        tags: props.tags,\n      },\n    );\n\n    // Output\n    this.id = azurermMonitorQueryRuleAlert.id;\n    const cdktfTerraformOutputQueryRuleAlertId = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: azurermMonitorQueryRuleAlert.id,\n      },\n    );\n    cdktfTerraformOutputQueryRuleAlertId.overrideLogicalId(\n      \"query_rule_alert_id\",\n    );\n  }\n}\n"]}
|
|
204
|
+
QueryRuleAlert[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_queryrulealert.QueryRuleAlert", version: "0.0.3-pre.7" };
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-rule-alert.js","sourceRoot":"","sources":["../../../src/azure-queryrulealert/lib/query-rule-alert.ts"],"names":[],"mappings":"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","sourcesContent":["import { MonitorScheduledQueryRulesAlertV2 } from \"@cdktf/provider-azurerm/lib/monitor-scheduled-query-rules-alert-v2\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport * as moment from \"moment\";\n\nexport interface BaseAzureQueryRuleAlertProps {\n  /**\n   * The name of the Monitor Scheduled Query Rule.\n   */\n  readonly name: string;\n  /**\n   * The name of the resource group in which the Monitor Scheduled Query Rule is created.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The location of the Monitor Scheduled Query Rule.\n   */\n  readonly location: string;\n  /**\n   * Specifies the criteria operator.\n   * Possible values are Equal, GreaterThan, GreaterThanOrEqual, LessThan,and LessThanOrEqual.\n   */\n  readonly criteriaOperator: string;\n  /**\n   * The query to run on logs. The results returned by this query are used to populate the alert.\n   */\n  readonly criteriaQuery: string;\n  /**\n   * Specifies the criteria threshold value that activates the alert.\n   */\n  readonly criteriaThreshold: number;\n  /**\n   * The type of aggregation to apply to the data points in aggregation granularity.\n   * Possible values are Average, Count, Maximum, Minimum,and Total.\n   */\n  readonly criteriatimeAggregationMethod: string;\n  /**\n   * Name of the dimension for criteria.\n   */\n  readonly criteriaDimensionName?: string;\n\n  /**\n   * Operator for dimension values. Possible values are Exclude, and Include.\n   */\n  readonly criteriaDimensionOperator?: string;\n\n  /**\n   * List of dimension values. Use a wildcard * to collect all.\n   */\n  readonly criteriaDimensionValues?: string[];\n\n  /**\n   * Specifies the number of violations to trigger an alert.\n   * Should be smaller or equal to number_of_evaluation_periods.\n   * Possible value is integer between 1 and 6.\n   */\n  readonly criteriaFailMinimumFailingPeriodsToTriggerAlert?: number;\n\n  /**\n   * Specifies the number of evaluation periods.\n   * Possible value is integer between 1 and 6.\n   */\n  readonly criteriaFailNumberOfEvaluationPeriods?: number;\n  /**\n   * Specifies the column containing the metric measure number.\n   * criteriaMetricMeasureColumn is required if criteriatimeAggregationMethod is Average, Maximum, Minimum, or Total.\n   * And criteriaMetricMeasureColumn cannot be specified if criteriatimeAggregationMethod is Count.\n   */\n  readonly criteriaMetricMeasureColumn?: string;\n  /**\n   * How often the scheduled query rule is evaluated, represented in ISO 8601 duration format.\n   * Possible values are PT1M, PT5M, PT10M, PT15M, PT30M, PT45M, PT1H, PT2H, PT3H, PT4H, PT5H, PT6H, P1D.\n   */\n  readonly evaluationFrequency: string;\n  /**\n   * Severity of the alert. Should be an integer between 0 and 4. Value of 0 is severest.\n   */\n  readonly severity: number;\n  /**\n   * Specifies the period of time in ISO 8601 duration format on which the Scheduled Query Rule will be executed (bin size).\n   */\n  readonly windowDuration: string;\n  /**\n   * Specifies the action group IDs to trigger when the alert fires.\n   */\n  readonly actionActionGroupId?: string[];\n  /**\n   * Specifies the flag that indicates whether the alert should be automatically resolved or not.\n   * @default false\n   */\n  readonly autoMitigationEnabled?: boolean;\n  /**\n   * Specifies the flag which indicates whether this scheduled query rule check if storage is configured.\n   * @default false\n   */\n  readonly workspaceAlertsStorageEnabled?: boolean;\n  /**\n   * Specifies the description of the scheduled query rule.\n   */\n  readonly description?: string;\n  /**\n   * Specifies the display name of the alert rule.\n   */\n  readonly displayName?: string;\n  /**\n   * Specifies the flag which indicates whether this scheduled query rule is enabled.\n   * @default true\n   */\n  readonly enabled?: boolean;\n  /**\n   * Mute actions for the chosen period of time in ISO 8601 duration format after the alert is fired.\n   * Possible values are PT5M, PT10M, PT15M, PT30M, PT45M, PT1H, PT2H, PT3H, PT4H, PT5H, PT6H, P1D and P2D.\n   */\n  readonly muteActionsAfterAlertDuration?: string;\n  /**\n   * Set this if the alert evaluation period is different from the query time range.\n   * If not specified, the value is window_duration*number_of_evaluation_periods.\n   * Possible values are PT5M, PT10M, PT15M, PT20M, PT30M, PT45M, PT1H, PT2H, PT3H, PT4H, PT5H, PT6H, P1D and P2D.\n   */\n  readonly queryTimeRangeOverride?: string;\n  /**\n   * Specifies the flag which indicates whether the provided query should be validated or not.\n   * @default true\n   */\n  readonly skipQueryValidation?: boolean;\n  /**\n   * A mapping of tags which should be assigned to the Monitor Scheduled Query Rule.\n   */\n  readonly tags?: { [key: string]: string };\n}\n\nexport interface AzureQueryRuleAlertProps extends BaseAzureQueryRuleAlertProps {\n  /**\n   * Specifies the list of resource IDs that this scheduled query rule is scoped to.\n   */\n  readonly scopes: string[];\n}\n\nexport class QueryRuleAlert extends Construct {\n  readonly queryRuleAlertProps: AzureQueryRuleAlertProps;\n  public id: string;\n  public resourceGroup: ResourceGroup;\n\n  /**\n   * Represents an Azure Monitor Scheduled Query Rule Alert.\n   *\n   * This class is responsible for the creation and management of a Scheduled Query Rule Alert in Azure Monitor.\n   * Scheduled Query Rule Alerts execute specified queries at regular intervals over the data collected in Log Analytics\n   * Workspaces or Application Insights, and alert based on the results of these queries. These alerts can be used to monitor\n   * application health, infrastructure changes, or compliance with certain conditions.\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 Scheduled Query Rule Alert.\n   * @param props - The properties required to configure the Scheduled Query Rule Alert, as defined in the AzureQueryRuleAlertProps interface.\n   *                These include:\n   *                - `name`: The name of the Scheduled Query Rule.\n   *                - `resourceGroup`: The Azure Resource Group under which the alert will be created.\n   *                - `location`: The Azure region where the alert will be deployed.\n   *                - `criteriaQuery`: The query to execute. The results of this query determine whether an alert should be triggered.\n   *                - `evaluationFrequency`: How often the query should be run.\n   *                - `windowDuration`: The time period over which data is collected for each execution of the query.\n   *                - `severity`: The severity of the alert.\n   *                - `actionActionGroupId`: The action group to invoke when the alert criteria are met.\n   *                - `enabled`: Indicates whether the alert rule is enabled.\n   *\n   * Example usage:\n   * ```typescript\n   * new QueryRuleAlert(this, 'MyAlertRule', {\n   *   name: 'HighErrorRateAlert',\n   *   resourceGroup: myResourceGroup,\n   *   location: 'West US 2',\n   *   criteriaQuery: 'Heartbeat | summarize AggregatedValue = count() by bin(TimeGenerated, 5m)',\n   *   evaluationFrequency: 'PT5M',\n   *   windowDuration: 'PT1H',\n   *   severity: 3,\n   *   actionActionGroupId: ['/subscriptions/sub-id/resourceGroups/rg/providers/microsoft.insights/actionGroups/myActionGroup'],\n   *   enabled: true\n   * });\n   * ```\n   * This class sets up the alert rule and ensures it is ready to trigger actions based on the specified criteria and schedule.\n   */\n  constructor(scope: Construct, id: string, props: AzureQueryRuleAlertProps) {\n    super(scope, id);\n\n    // Properties validation\n    const evaluationFrequencyOption = [\n      \"PT1M\",\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n    ];\n    const windowDurationOption = [\n      \"PT1M\",\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n      \"P2D\",\n    ];\n    const muteActionsAfterAlertDurationOption = [\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n      \"P2D\",\n    ];\n    const queryTimeRangeOverrideOption = [\n      \"PT5M\",\n      \"PT10M\",\n      \"PT15M\",\n      \"PT20M\",\n      \"PT30M\",\n      \"PT45M\",\n      \"PT1H\",\n      \"PT2H\",\n      \"PT3H\",\n      \"PT4H\",\n      \"PT5H\",\n      \"PT6H\",\n      \"P1D\",\n      \"P2D\",\n    ];\n\n    // Validate evaluationFrequency\n    if (!evaluationFrequencyOption.includes(props.evaluationFrequency)) {\n      throw new Error(\"invalid evaluationFrequency\");\n    }\n    // Validate windowDuration\n    if (!windowDurationOption.includes(props.windowDuration)) {\n      throw new Error(\"invalid windowDuration\");\n    }\n    // Validate muteActionsAfterAlertDuration\n    if (\n      props.muteActionsAfterAlertDuration &&\n      !muteActionsAfterAlertDurationOption.includes(\n        props.muteActionsAfterAlertDuration,\n      )\n    ) {\n      throw new Error(\"invalid muteActionsAfterAlertDuration\");\n    }\n    // Validate queryTimeRangeOverride\n    if (\n      props.queryTimeRangeOverride &&\n      !queryTimeRangeOverrideOption.includes(props.queryTimeRangeOverride)\n    ) {\n      throw new Error(\"invalid queryTimeRangeOverride\");\n    }\n    // The query look back which is windowDuration * numberOfEvaluationPeriods cannot exceed 48 hours.\n    if (props.criteriaFailNumberOfEvaluationPeriods) {\n      const windowDurationHours = moment\n        .duration(props.windowDuration)\n        .asHours();\n      const numberOfEvaluationPeriods =\n        props.criteriaFailNumberOfEvaluationPeriods;\n      if (windowDurationHours * numberOfEvaluationPeriods > 48) {\n        throw new Error(\"queryTimeRangeOverride cannot exceed 48 hours\");\n      }\n    }\n\n    this.queryRuleAlertProps = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Properties with default values\n    const defaults = {\n      autoMitigationEnabled: props.autoMitigationEnabled || false,\n      workspaceAlertsStorageEnabled:\n        props.workspaceAlertsStorageEnabled || false,\n      enabled: props.enabled || true,\n      skipQueryValidation: props.skipQueryValidation || true,\n      metricMeasureColumn: props.criteriaMetricMeasureColumn || undefined,\n    };\n\n    const criteriaFailingPeriods =\n      props.criteriaFailMinimumFailingPeriodsToTriggerAlert !== undefined &&\n      props.criteriaFailNumberOfEvaluationPeriods !== undefined\n        ? {\n            minimumFailingPeriodsToTriggerAlert:\n              props.criteriaFailMinimumFailingPeriodsToTriggerAlert,\n            numberOfEvaluationPeriods:\n              props.criteriaFailNumberOfEvaluationPeriods,\n          }\n        : undefined;\n\n    const dimension =\n      props.criteriaDimensionName &&\n      props.criteriaDimensionOperator &&\n      props.criteriaDimensionValues\n        ? [\n            {\n              name: props.criteriaDimensionName,\n              operator: props.criteriaDimensionOperator,\n              values: props.criteriaDimensionValues,\n            },\n          ]\n        : undefined;\n\n    const azurermMonitorQueryRuleAlert = new MonitorScheduledQueryRulesAlertV2(\n      this,\n      \"queryrulealert\",\n      {\n        ...defaults,\n        name: props.name,\n        resourceGroupName: props.resourceGroup.name,\n        location: props.location,\n        scopes: props.scopes,\n        windowDuration: props.windowDuration,\n        evaluationFrequency: props.evaluationFrequency,\n        severity: props.severity,\n        criteria: [\n          {\n            operator: props.criteriaOperator,\n            query: props.criteriaQuery,\n            threshold: props.criteriaThreshold,\n            timeAggregationMethod: props.criteriatimeAggregationMethod,\n            dimension: dimension,\n            failingPeriods: criteriaFailingPeriods,\n          },\n        ],\n        action: props.actionActionGroupId\n          ? { actionGroups: props.actionActionGroupId }\n          : undefined,\n        tags: props.tags,\n      },\n    );\n\n    // Output\n    this.id = azurermMonitorQueryRuleAlert.id;\n    const cdktfTerraformOutputQueryRuleAlertId = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: azurermMonitorQueryRuleAlert.id,\n      },\n    );\n    cdktfTerraformOutputQueryRuleAlertId.overrideLogicalId(\n      \"query_rule_alert_id\",\n    );\n  }\n}\n"]}
|
|
@@ -34,5 +34,33 @@ export declare class Group extends AzureResource {
|
|
|
34
34
|
id: string;
|
|
35
35
|
readonly location: string;
|
|
36
36
|
readonly name: string;
|
|
37
|
+
/**
|
|
38
|
+
* Represents an Azure Resource Group.
|
|
39
|
+
*
|
|
40
|
+
* This class is responsible for the creation and management of an Azure Resource Group, which is a container that holds
|
|
41
|
+
* related resources for an Azure solution. A resource group includes those resources that you want to manage as a group.
|
|
42
|
+
* You decide how to allocate resources to resource groups based on what makes the most sense for your organization.
|
|
43
|
+
*
|
|
44
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
45
|
+
* @param id - The unique identifier for this instance of the Resource Group.
|
|
46
|
+
* @param props - Optional properties for configuring the Resource Group. These can include:
|
|
47
|
+
* - `location`: The Azure region where the Resource Group will be created.
|
|
48
|
+
* - `name`: The name of the Resource Group, which must be unique within your Azure subscription.
|
|
49
|
+
* - `tags`: A dictionary of tags to apply to the Resource Group for organizational, billing, or other purposes.
|
|
50
|
+
* - `ignoreChanges`: A list of properties which should be ignored if changes are made after initial deployment,
|
|
51
|
+
* useful in certain scenarios where properties are externally managed or should not trigger updates.
|
|
52
|
+
*
|
|
53
|
+
* Example usage:
|
|
54
|
+
* ```typescript
|
|
55
|
+
* new Group(this, 'MyResourceGroup', {
|
|
56
|
+
* location: 'East US',
|
|
57
|
+
* name: 'ApplicationResources',
|
|
58
|
+
* tags: {
|
|
59
|
+
* environment: 'production'
|
|
60
|
+
* }
|
|
61
|
+
* });
|
|
62
|
+
* ```
|
|
63
|
+
* This class sets up the resource group and applies any specified configurations, making it ready to hold other Azure resources.
|
|
64
|
+
*/
|
|
37
65
|
constructor(scope: Construct, id: string, props?: GroupProps);
|
|
38
66
|
}
|
|
@@ -7,6 +7,34 @@ const resource_group_1 = require("@cdktf/provider-azurerm/lib/resource-group");
|
|
|
7
7
|
const cdktf = require("cdktf");
|
|
8
8
|
const lib_1 = require("../../core-azure/lib");
|
|
9
9
|
class Group extends lib_1.AzureResource {
|
|
10
|
+
/**
|
|
11
|
+
* Represents an Azure Resource Group.
|
|
12
|
+
*
|
|
13
|
+
* This class is responsible for the creation and management of an Azure Resource Group, which is a container that holds
|
|
14
|
+
* related resources for an Azure solution. A resource group includes those resources that you want to manage as a group.
|
|
15
|
+
* You decide how to allocate resources to resource groups based on what makes the most sense for your organization.
|
|
16
|
+
*
|
|
17
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
18
|
+
* @param id - The unique identifier for this instance of the Resource Group.
|
|
19
|
+
* @param props - Optional properties for configuring the Resource Group. These can include:
|
|
20
|
+
* - `location`: The Azure region where the Resource Group will be created.
|
|
21
|
+
* - `name`: The name of the Resource Group, which must be unique within your Azure subscription.
|
|
22
|
+
* - `tags`: A dictionary of tags to apply to the Resource Group for organizational, billing, or other purposes.
|
|
23
|
+
* - `ignoreChanges`: A list of properties which should be ignored if changes are made after initial deployment,
|
|
24
|
+
* useful in certain scenarios where properties are externally managed or should not trigger updates.
|
|
25
|
+
*
|
|
26
|
+
* Example usage:
|
|
27
|
+
* ```typescript
|
|
28
|
+
* new Group(this, 'MyResourceGroup', {
|
|
29
|
+
* location: 'East US',
|
|
30
|
+
* name: 'ApplicationResources',
|
|
31
|
+
* tags: {
|
|
32
|
+
* environment: 'production'
|
|
33
|
+
* }
|
|
34
|
+
* });
|
|
35
|
+
* ```
|
|
36
|
+
* This class sets up the resource group and applies any specified configurations, making it ready to hold other Azure resources.
|
|
37
|
+
*/
|
|
10
38
|
constructor(scope, id, props = {}) {
|
|
11
39
|
super(scope, id);
|
|
12
40
|
this.props = props;
|
|
@@ -45,5 +73,5 @@ class Group extends lib_1.AzureResource {
|
|
|
45
73
|
}
|
|
46
74
|
exports.Group = Group;
|
|
47
75
|
_a = JSII_RTTI_SYMBOL_1;
|
|
48
|
-
Group[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_resourcegroup.Group", version: "0.0.3-pre.
|
|
49
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
Group[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_resourcegroup.Group", version: "0.0.3-pre.7" };
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzb3VyY2UtZ3JvdXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXp1cmUtcmVzb3VyY2Vncm91cC9saWIvcmVzb3VyY2UtZ3JvdXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7QUFBQSwrRUFBMkU7QUFDM0UsK0JBQStCO0FBRS9CLDhDQUFxRDtBQTBCckQsTUFBYSxLQUFNLFNBQVEsbUJBQWE7SUFXdEM7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztPQTJCRztJQUNILFlBQVksS0FBZ0IsRUFBRSxFQUFVLEVBQUUsUUFBb0IsRUFBRTtRQUM5RCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRWpCLElBQUksQ0FBQyxLQUFLLEdBQUcsS0FBSyxDQUFDO1FBRW5CLE1BQU0sUUFBUSxHQUFHO1lBQ2YsSUFBSSxFQUFFLEtBQUssQ0FBQyxJQUFJLElBQUksTUFBTSxJQUFJLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDeEQsUUFBUSxFQUFFLEtBQUssQ0FBQyxRQUFRLElBQUksUUFBUTtTQUNyQyxDQUFDO1FBRUYsTUFBTSxzQkFBc0IsR0FBRyxJQUFJLDhCQUFhLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRTtZQUMzRCxHQUFHLFFBQVE7WUFDWCxJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUk7U0FDakIsQ0FBQyxDQUFDO1FBRUgsc0JBQXNCLENBQUMsV0FBVyxDQUFDLFdBQVcsRUFBRTtZQUM5QztnQkFDRSxjQUFjLEVBQUUsS0FBSyxDQUFDLGFBQWEsSUFBSSxFQUFFO2FBQzFDO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLEVBQUUsR0FBRyxzQkFBc0IsQ0FBQyxFQUFFLENBQUM7UUFDcEMsSUFBSSxDQUFDLElBQUksR0FBRyxzQkFBc0IsQ0FBQyxJQUFJLENBQUM7UUFDeEMsSUFBSSxDQUFDLFFBQVEsR0FBRyxzQkFBc0IsQ0FBQyxRQUFRLENBQUM7UUFDaEQsSUFBSSxDQUFDLGFBQWEsR0FBRyxzQkFBc0IsQ0FBQztRQUU1QyxvQkFBb0I7UUFDcEIsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLEtBQUssQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLElBQUksRUFBRTtZQUNwRCxLQUFLLEVBQUUsc0JBQXNCLENBQUMsRUFBRTtTQUNqQyxDQUFDLENBQUM7UUFDSCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksS0FBSyxDQUFDLGVBQWUsQ0FBQyxJQUFJLEVBQUUsVUFBVSxFQUFFO1lBQ2hFLEtBQUssRUFBRSxzQkFBc0IsQ0FBQyxRQUFRO1NBQ3ZDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxLQUFLLENBQUMsZUFBZSxDQUFDLElBQUksRUFBRSxNQUFNLEVBQUU7WUFDeEQsS0FBSyxFQUFFLHNCQUFzQixDQUFDLElBQUk7U0FDbkMsQ0FBQyxDQUFDO1FBRUgsZ0lBQWdJO1FBQ2hJLElBQUksQ0FBQyxjQUFjLENBQUMsaUJBQWlCLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDbEQsSUFBSSxDQUFDLFVBQVUsQ0FBQyxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMxQyxJQUFJLENBQUMsUUFBUSxDQUFDLGlCQUFpQixDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hDLENBQUM7O0FBaEZILHNCQWlGQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlc291cmNlR3JvdXAgfSBmcm9tIFwiQGNka3RmL3Byb3ZpZGVyLWF6dXJlcm0vbGliL3Jlc291cmNlLWdyb3VwXCI7XG5pbXBvcnQgKiBhcyBjZGt0ZiBmcm9tIFwiY2RrdGZcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgeyBBenVyZVJlc291cmNlIH0gZnJvbSBcIi4uLy4uL2NvcmUtYXp1cmUvbGliXCI7XG5cbi8vIENvbnN0cnVjdFxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciB0aGUgcmVzb3VyY2UgZ3JvdXBcbiAqL1xuZXhwb3J0IGludGVyZmFjZSBHcm91cFByb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBBenVyZSBSZWdpb24gdG8gZGVwbG95LlxuICAgKi9cbiAgcmVhZG9ubHkgbG9jYXRpb24/OiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgQXp1cmUgUmVzb3VyY2UgR3JvdXAuXG4gICAqL1xuICByZWFkb25seSBuYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBUaGUgdGFncyB0byBhc3NpZ24gdG8gdGhlIFJlc291cmNlIEdyb3VwLlxuICAgKi9cbiAgcmVhZG9ubHkgdGFncz86IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIC8qKlxuICAgKiBUaGUgbGlmZWN5Y2xlIHJ1bGVzIHRvIGlnbm9yZSBjaGFuZ2VzLlxuICAgKi9cbiAgcmVhZG9ubHkgaWdub3JlQ2hhbmdlcz86IHN0cmluZ1tdO1xufVxuXG5leHBvcnQgY2xhc3MgR3JvdXAgZXh0ZW5kcyBBenVyZVJlc291cmNlIHtcbiAgcHVibGljIHJlc291cmNlR3JvdXA6IFJlc291cmNlR3JvdXA7XG4gIHJlYWRvbmx5IHByb3BzOiBHcm91cFByb3BzO1xuICBpZE91dHB1dDogY2RrdGYuVGVycmFmb3JtT3V0cHV0O1xuICBsb2NhdGlvbk91dHB1dDogY2RrdGYuVGVycmFmb3JtT3V0cHV0O1xuICBuYW1lT3V0cHV0OiBjZGt0Zi5UZXJyYWZvcm1PdXRwdXQ7XG5cbiAgcHVibGljIGlkOiBzdHJpbmc7XG4gIHB1YmxpYyByZWFkb25seSBsb2NhdGlvbjogc3RyaW5nO1xuICBwdWJsaWMgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBSZXByZXNlbnRzIGFuIEF6dXJlIFJlc291cmNlIEdyb3VwLlxuICAgKlxuICAgKiBUaGlzIGNsYXNzIGlzIHJlc3BvbnNpYmxlIGZvciB0aGUgY3JlYXRpb24gYW5kIG1hbmFnZW1lbnQgb2YgYW4gQXp1cmUgUmVzb3VyY2UgR3JvdXAsIHdoaWNoIGlzIGEgY29udGFpbmVyIHRoYXQgaG9sZHNcbiAgICogcmVsYXRlZCByZXNvdXJjZXMgZm9yIGFuIEF6dXJlIHNvbHV0aW9uLiBBIHJlc291cmNlIGdyb3VwIGluY2x1ZGVzIHRob3NlIHJlc291cmNlcyB0aGF0IHlvdSB3YW50IHRvIG1hbmFnZSBhcyBhIGdyb3VwLlxuICAgKiBZb3UgZGVjaWRlIGhvdyB0byBhbGxvY2F0ZSByZXNvdXJjZXMgdG8gcmVzb3VyY2UgZ3JvdXBzIGJhc2VkIG9uIHdoYXQgbWFrZXMgdGhlIG1vc3Qgc2Vuc2UgZm9yIHlvdXIgb3JnYW5pemF0aW9uLlxuICAgKlxuICAgKiBAcGFyYW0gc2NvcGUgLSBUaGUgc2NvcGUgaW4gd2hpY2ggdG8gZGVmaW5lIHRoaXMgY29uc3RydWN0LCB0eXBpY2FsbHkgcmVwcmVzZW50aW5nIHRoZSBDbG91ZCBEZXZlbG9wbWVudCBLaXQgKENESykgc3RhY2suXG4gICAqIEBwYXJhbSBpZCAtIFRoZSB1bmlxdWUgaWRlbnRpZmllciBmb3IgdGhpcyBpbnN0YW5jZSBvZiB0aGUgUmVzb3VyY2UgR3JvdXAuXG4gICAqIEBwYXJhbSBwcm9wcyAtIE9wdGlvbmFsIHByb3BlcnRpZXMgZm9yIGNvbmZpZ3VyaW5nIHRoZSBSZXNvdXJjZSBHcm91cC4gVGhlc2UgY2FuIGluY2x1ZGU6XG4gICAqICAgICAgICAgICAgICAgIC0gYGxvY2F0aW9uYDogVGhlIEF6dXJlIHJlZ2lvbiB3aGVyZSB0aGUgUmVzb3VyY2UgR3JvdXAgd2lsbCBiZSBjcmVhdGVkLlxuICAgKiAgICAgICAgICAgICAgICAtIGBuYW1lYDogVGhlIG5hbWUgb2YgdGhlIFJlc291cmNlIEdyb3VwLCB3aGljaCBtdXN0IGJlIHVuaXF1ZSB3aXRoaW4geW91ciBBenVyZSBzdWJzY3JpcHRpb24uXG4gICAqICAgICAgICAgICAgICAgIC0gYHRhZ3NgOiBBIGRpY3Rpb25hcnkgb2YgdGFncyB0byBhcHBseSB0byB0aGUgUmVzb3VyY2UgR3JvdXAgZm9yIG9yZ2FuaXphdGlvbmFsLCBiaWxsaW5nLCBvciBvdGhlciBwdXJwb3Nlcy5cbiAgICogICAgICAgICAgICAgICAgLSBgaWdub3JlQ2hhbmdlc2A6IEEgbGlzdCBvZiBwcm9wZXJ0aWVzIHdoaWNoIHNob3VsZCBiZSBpZ25vcmVkIGlmIGNoYW5nZXMgYXJlIG1hZGUgYWZ0ZXIgaW5pdGlhbCBkZXBsb3ltZW50LFxuICAgKiAgICAgICAgICAgICAgICAgIHVzZWZ1bCBpbiBjZXJ0YWluIHNjZW5hcmlvcyB3aGVyZSBwcm9wZXJ0aWVzIGFyZSBleHRlcm5hbGx5IG1hbmFnZWQgb3Igc2hvdWxkIG5vdCB0cmlnZ2VyIHVwZGF0ZXMuXG4gICAqXG4gICAqIEV4YW1wbGUgdXNhZ2U6XG4gICAqIGBgYHR5cGVzY3JpcHRcbiAgICogbmV3IEdyb3VwKHRoaXMsICdNeVJlc291cmNlR3JvdXAnLCB7XG4gICAqICAgbG9jYXRpb246ICdFYXN0IFVTJyxcbiAgICogICBuYW1lOiAnQXBwbGljYXRpb25SZXNvdXJjZXMnLFxuICAgKiAgIHRhZ3M6IHtcbiAgICogICAgIGVudmlyb25tZW50OiAncHJvZHVjdGlvbidcbiAgICogICB9XG4gICAqIH0pO1xuICAgKiBgYGBcbiAgICogVGhpcyBjbGFzcyBzZXRzIHVwIHRoZSByZXNvdXJjZSBncm91cCBhbmQgYXBwbGllcyBhbnkgc3BlY2lmaWVkIGNvbmZpZ3VyYXRpb25zLCBtYWtpbmcgaXQgcmVhZHkgdG8gaG9sZCBvdGhlciBBenVyZSByZXNvdXJjZXMuXG4gICAqL1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nLCBwcm9wczogR3JvdXBQcm9wcyA9IHt9KSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIHRoaXMucHJvcHMgPSBwcm9wcztcblxuICAgIGNvbnN0IGRlZmF1bHRzID0ge1xuICAgICAgbmFtZTogcHJvcHMubmFtZSB8fCBgcmctJHt0aGlzLm5vZGUucGF0aC5zcGxpdChcIi9cIilbMF19YCxcbiAgICAgIGxvY2F0aW9uOiBwcm9wcy5sb2NhdGlvbiB8fCBcImVhc3R1c1wiLFxuICAgIH07XG5cbiAgICBjb25zdCBhenVyZXJtUmVzb3VyY2VHcm91cFJnID0gbmV3IFJlc291cmNlR3JvdXAodGhpcywgXCJyZ1wiLCB7XG4gICAgICAuLi5kZWZhdWx0cyxcbiAgICAgIHRhZ3M6IHByb3BzLnRhZ3MsXG4gICAgfSk7XG5cbiAgICBhenVyZXJtUmVzb3VyY2VHcm91cFJnLmFkZE92ZXJyaWRlKFwibGlmZWN5Y2xlXCIsIFtcbiAgICAgIHtcbiAgICAgICAgaWdub3JlX2NoYW5nZXM6IHByb3BzLmlnbm9yZUNoYW5nZXMgfHwgW10sXG4gICAgICB9LFxuICAgIF0pO1xuXG4gICAgdGhpcy5pZCA9IGF6dXJlcm1SZXNvdXJjZUdyb3VwUmcuaWQ7XG4gICAgdGhpcy5uYW1lID0gYXp1cmVybVJlc291cmNlR3JvdXBSZy5uYW1lO1xuICAgIHRoaXMubG9jYXRpb24gPSBhenVyZXJtUmVzb3VyY2VHcm91cFJnLmxvY2F0aW9uO1xuICAgIHRoaXMucmVzb3VyY2VHcm91cCA9IGF6dXJlcm1SZXNvdXJjZUdyb3VwUmc7XG5cbiAgICAvLyBUZXJyYWZvcm0gT3V0cHV0c1xuICAgIHRoaXMuaWRPdXRwdXQgPSBuZXcgY2RrdGYuVGVycmFmb3JtT3V0cHV0KHRoaXMsIFwiaWRcIiwge1xuICAgICAgdmFsdWU6IGF6dXJlcm1SZXNvdXJjZUdyb3VwUmcuaWQsXG4gICAgfSk7XG4gICAgdGhpcy5sb2NhdGlvbk91dHB1dCA9IG5ldyBjZGt0Zi5UZXJyYWZvcm1PdXRwdXQodGhpcywgXCJsb2NhdGlvblwiLCB7XG4gICAgICB2YWx1ZTogYXp1cmVybVJlc291cmNlR3JvdXBSZy5sb2NhdGlvbixcbiAgICB9KTtcbiAgICB0aGlzLm5hbWVPdXRwdXQgPSBuZXcgY2RrdGYuVGVycmFmb3JtT3V0cHV0KHRoaXMsIFwibmFtZVwiLCB7XG4gICAgICB2YWx1ZTogYXp1cmVybVJlc291cmNlR3JvdXBSZy5uYW1lLFxuICAgIH0pO1xuXG4gICAgLypUaGlzIGFsbG93cyB0aGUgVGVycmFmb3JtIHJlc291cmNlIG5hbWUgdG8gbWF0Y2ggdGhlIG9yaWdpbmFsIG5hbWUuIFlvdSBjYW4gcmVtb3ZlIHRoZSBjYWxsIGlmIHlvdSBkb24ndCBuZWVkIHRoZW0gdG8gbWF0Y2guKi9cbiAgICB0aGlzLmxvY2F0aW9uT3V0cHV0Lm92ZXJyaWRlTG9naWNhbElkKFwibG9jYXRpb25cIik7XG4gICAgdGhpcy5uYW1lT3V0cHV0Lm92ZXJyaWRlTG9naWNhbElkKFwibmFtZVwiKTtcbiAgICB0aGlzLmlkT3V0cHV0Lm92ZXJyaWRlTG9naWNhbElkKFwiaWRcIik7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -95,23 +95,6 @@ export interface AccountProps {
|
|
|
95
95
|
*/
|
|
96
96
|
readonly accountKind?: string;
|
|
97
97
|
}
|
|
98
|
-
/**
|
|
99
|
-
* Represents an Azure Storage Account within a Terraform deployment.
|
|
100
|
-
* This class provides methods to easily manage storage resources such as Containers,
|
|
101
|
-
* File Shares, Tables, Queues, and Network Rules.
|
|
102
|
-
*
|
|
103
|
-
* Example usage:
|
|
104
|
-
* ```typescript
|
|
105
|
-
* const storageAccount = new AzureStorageAccount(this, 'storageaccount', {
|
|
106
|
-
* name: 'myStorageAccount',
|
|
107
|
-
* location: 'East US',
|
|
108
|
-
* resourceGroup: myResourceGroup,
|
|
109
|
-
* accountReplicationType: 'LRS',
|
|
110
|
-
* accountTier: 'Standard',
|
|
111
|
-
* // other properties
|
|
112
|
-
* });
|
|
113
|
-
* ```
|
|
114
|
-
*/
|
|
115
98
|
export declare class Account extends AzureResourceWithAlert {
|
|
116
99
|
readonly props: AccountProps;
|
|
117
100
|
id: string;
|
|
@@ -124,23 +107,55 @@ export declare class Account extends AzureResourceWithAlert {
|
|
|
124
107
|
private readonly shares;
|
|
125
108
|
private readonly tables;
|
|
126
109
|
/**
|
|
127
|
-
*
|
|
128
|
-
*
|
|
129
|
-
*
|
|
130
|
-
*
|
|
110
|
+
* Represents an Azure Storage Account within a Terraform deployment.
|
|
111
|
+
*
|
|
112
|
+
* This class is responsible for the creation and management of an Azure Storage Account, which is a scalable and secure service
|
|
113
|
+
* for storing large amounts of unstructured data that can be accessed from anywhere in the world over HTTP or HTTPS. Common uses
|
|
114
|
+
* of the Azure Storage Account include storing of blobs (objects), file shares, tables, and queues. This class provides methods
|
|
115
|
+
* to manage storage resources, configure network rules, and integrate with Azure Active Directory for secure access management.
|
|
116
|
+
*
|
|
117
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
118
|
+
* @param id - The unique identifier for this instance of the storage account.
|
|
119
|
+
* @param props - The properties required to configure the Azure Storage Account, as defined in the AccountProps interface. These include:
|
|
120
|
+
* - `name`: The name of the storage account, which must be unique within the Azure region.
|
|
121
|
+
* - `location`: The Azure region where the storage account will be created.
|
|
122
|
+
* - `resourceGroup`: The Azure Resource Group under which the storage account will be deployed.
|
|
123
|
+
* - `accountReplicationType`: The type of data replication to ensure data durability and availability.
|
|
124
|
+
* - `accountTier`: The performance tier that affects the type of hardware used for the storage account.
|
|
125
|
+
* - `tags`: A dictionary of tags to apply to the storage account for organizational purposes.
|
|
126
|
+
*
|
|
127
|
+
* Example usage:
|
|
128
|
+
* ```typescript
|
|
129
|
+
* const storageAccount = new Account(this, 'MyStorageAccount', {
|
|
130
|
+
* location: 'East US',
|
|
131
|
+
* name: 'myStorageAccount',
|
|
132
|
+
* resourceGroup: myResourceGroup,
|
|
133
|
+
* accountReplicationType: 'LRS',
|
|
134
|
+
* accountTier: 'Standard',
|
|
135
|
+
* enableHttpsTrafficOnly: true,
|
|
136
|
+
* tags: {
|
|
137
|
+
* environment: 'production'
|
|
138
|
+
* }
|
|
139
|
+
* });
|
|
140
|
+
* ```
|
|
141
|
+
* This class sets up the storage account with the specified configurations, handles resource allocation, and applies security
|
|
142
|
+
* settings based on the properties provided.
|
|
131
143
|
*/
|
|
132
144
|
constructor(scope: Construct, id: string, props: AccountProps);
|
|
133
145
|
/**
|
|
134
146
|
* Adds a new container to the storage account.
|
|
135
|
-
* @param name The name of the container.
|
|
136
|
-
* @param containerAccessType The access
|
|
137
|
-
* @param metadata
|
|
138
|
-
* @returns The created
|
|
139
|
-
* @throws Error if a container with the same name already exists.
|
|
147
|
+
* @param name The name of the container. It must be unique within the storage account.
|
|
148
|
+
* @param containerAccessType The level of public access to the container. Defaults to 'private'.
|
|
149
|
+
* @param metadata Optional metadata for the container as key-value pairs.
|
|
150
|
+
* @returns The created Container instance.
|
|
151
|
+
* @throws Error if a container with the same name already exists within the storage account.
|
|
152
|
+
*
|
|
153
|
+
* This method creates a new container within the Azure storage account, allowing for the specification of access
|
|
154
|
+
* level and metadata. If the container already exists, it throws an error to prevent duplication.
|
|
140
155
|
*
|
|
141
156
|
* Example usage:
|
|
142
157
|
* ```typescript
|
|
143
|
-
* const container = storageAccount.addContainer('myContainer', 'private');
|
|
158
|
+
* const container = storageAccount.addContainer('myContainer', 'private', { owner: 'IT' });
|
|
144
159
|
* ```
|
|
145
160
|
*/
|
|
146
161
|
addContainer(name: string, containerAccessType?: string, metadata?: {
|
|
@@ -148,57 +163,69 @@ export declare class Account extends AzureResourceWithAlert {
|
|
|
148
163
|
}): Container;
|
|
149
164
|
/**
|
|
150
165
|
* Adds a new file share to the storage account.
|
|
151
|
-
* @param name The name of the file share.
|
|
152
|
-
* @param props Optional properties for the file share
|
|
153
|
-
* @returns The created
|
|
154
|
-
* @throws Error if a share with the same name already exists.
|
|
166
|
+
* @param name The name of the file share. Must be unique within the storage account.
|
|
167
|
+
* @param props Optional properties for configuring the file share, such as quota and access tier.
|
|
168
|
+
* @returns The created FileShare instance.
|
|
169
|
+
* @throws Error if a file share with the same name already exists.
|
|
170
|
+
*
|
|
171
|
+
* This method facilitates the addition of a file share to the storage account, with optional settings for
|
|
172
|
+
* capacity (quota) and data access frequency (access tier). If a file share with the same name exists, an error is thrown.
|
|
155
173
|
*
|
|
156
174
|
* Example usage:
|
|
157
175
|
* ```typescript
|
|
158
|
-
* const fileShare = storageAccount.
|
|
176
|
+
* const fileShare = storageAccount.addFileShare('myFileShare', { quota: 1024, accessTier: 'Hot' });
|
|
159
177
|
* ```
|
|
160
178
|
*/
|
|
161
179
|
addFileShare(name: string, props?: FileShareProps): FileShare;
|
|
162
180
|
/**
|
|
163
181
|
* Adds a new table to the storage account.
|
|
164
|
-
* @param name The name of the table.
|
|
165
|
-
* @param acl Optional access control list for the table.
|
|
166
|
-
* @returns The created
|
|
182
|
+
* @param name The name of the table. Must be unique within the storage account.
|
|
183
|
+
* @param acl Optional access control list for the table, specifying permissions.
|
|
184
|
+
* @returns The created Table instance.
|
|
167
185
|
* @throws Error if a table with the same name already exists.
|
|
168
186
|
*
|
|
187
|
+
* This method creates a new table within the storage account, optionally allowing for access control configurations.
|
|
188
|
+
* It throws an error if a table with the same name already exists, ensuring uniqueness within the account.
|
|
189
|
+
*
|
|
169
190
|
* Example usage:
|
|
170
191
|
* ```typescript
|
|
171
|
-
* const table = storageAccount.addTable('myTable');
|
|
192
|
+
* const table = storageAccount.addTable('myTable', [{ id: 'policy1', type: 'read' }]);
|
|
172
193
|
* ```
|
|
173
194
|
*/
|
|
174
195
|
addTable(name: string, acl?: StorageTableAcl[]): Table;
|
|
175
196
|
/**
|
|
176
197
|
* Adds a new queue to the storage account.
|
|
177
|
-
* @param name The name of the queue.
|
|
178
|
-
* @param metadata Optional metadata for the queue.
|
|
179
|
-
* @returns The created
|
|
198
|
+
* @param name The name of the queue. Must be unique within the storage account.
|
|
199
|
+
* @param metadata Optional metadata for the queue as key-value pairs.
|
|
200
|
+
* @returns The created Queue instance.
|
|
201
|
+
*
|
|
202
|
+
* This method creates a new queue in the storage account, with optional metadata. It is useful for message queuing
|
|
203
|
+
* in applications, enabling asynchronous task processing and inter-service communication.
|
|
180
204
|
*
|
|
181
205
|
* Example usage:
|
|
182
206
|
* ```typescript
|
|
183
|
-
* const queue = storageAccount.addQueue('myQueue');
|
|
207
|
+
* const queue = storageAccount.addQueue('myQueue', { priority: 'high' });
|
|
184
208
|
* ```
|
|
185
209
|
*/
|
|
186
210
|
addQueue(name: string, metadata?: {
|
|
187
211
|
[key: string]: string;
|
|
188
212
|
}): Queue;
|
|
189
213
|
/**
|
|
190
|
-
* Adds network rules to the storage account.
|
|
191
|
-
* @param props Configuration properties for the network rules.
|
|
192
|
-
* @returns The configured
|
|
214
|
+
* Adds network rules to the storage account to control access based on IP and virtual network settings.
|
|
215
|
+
* @param props Configuration properties for the network rules, including allowed IPs and virtual network subnet IDs.
|
|
216
|
+
* @returns The configured network rules.
|
|
217
|
+
*
|
|
218
|
+
* This method configures network rules for the storage account, specifying which IPs and virtual networks can access
|
|
219
|
+
* the storage resources. It allows detailed control over data security and access management.
|
|
193
220
|
*
|
|
194
221
|
* Example usage:
|
|
195
222
|
* ```typescript
|
|
196
223
|
* storageAccount.addNetworkRules({
|
|
197
|
-
*
|
|
198
|
-
*
|
|
199
|
-
*
|
|
200
|
-
*
|
|
201
|
-
*
|
|
224
|
+
* bypass: ['AzureServices'],
|
|
225
|
+
* defaultAction: 'Deny',
|
|
226
|
+
* ipRules: ['1.2.3.4/32'],
|
|
227
|
+
* virtualNetworkSubnetIds: ['subnetId'],
|
|
228
|
+
* });
|
|
202
229
|
* ```
|
|
203
230
|
*/
|
|
204
231
|
addNetworkRules(props: NetworkRulesProps): StorageAccountNetworkRulesA;
|