@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.
Files changed (85) hide show
  1. package/.jsii +909 -306
  2. package/API.md +2488 -255
  3. package/README.md +112 -18
  4. package/docs/images/ide-documentation.png +0 -0
  5. package/lib/azure-actiongroup/lib/actiongroup.d.ts +39 -0
  6. package/lib/azure-actiongroup/lib/actiongroup.js +40 -1
  7. package/lib/azure-applicationgateway/lib/gateway.d.ts +76 -0
  8. package/lib/azure-applicationgateway/lib/gateway.js +78 -2
  9. package/lib/azure-applicationinsights/lib/appinsights.d.ts +50 -0
  10. package/lib/azure-applicationinsights/lib/appinsights.js +52 -3
  11. package/lib/azure-containerregistry/lib/registry.d.ts +29 -0
  12. package/lib/azure-containerregistry/lib/registry.js +31 -2
  13. package/lib/azure-datalake/lib/datalake.d.ts +50 -0
  14. package/lib/azure-datalake/lib/datalake.js +51 -1
  15. package/lib/azure-datalake/lib/filesystem.d.ts +51 -0
  16. package/lib/azure-datalake/lib/filesystem.js +52 -1
  17. package/lib/azure-datalake/lib/path.d.ts +37 -0
  18. package/lib/azure-datalake/lib/path.js +38 -1
  19. package/lib/azure-eventhub/lib/authorization.d.ts +30 -0
  20. package/lib/azure-eventhub/lib/authorization.js +32 -2
  21. package/lib/azure-eventhub/lib/cluster.d.ts +29 -0
  22. package/lib/azure-eventhub/lib/cluster.js +31 -2
  23. package/lib/azure-eventhub/lib/consumer.d.ts +28 -0
  24. package/lib/azure-eventhub/lib/consumer.js +30 -2
  25. package/lib/azure-eventhub/lib/instance.d.ts +118 -0
  26. package/lib/azure-eventhub/lib/instance.js +120 -2
  27. package/lib/azure-eventhub/lib/kusto-connection.d.ts +41 -0
  28. package/lib/azure-eventhub/lib/kusto-connection.js +43 -2
  29. package/lib/azure-eventhub/lib/namespace.d.ts +74 -0
  30. package/lib/azure-eventhub/lib/namespace.js +76 -3
  31. package/lib/azure-functionapp/lib/functionapplinux.js +1 -1
  32. package/lib/azure-keyvault/lib/certificate.d.ts +96 -2
  33. package/lib/azure-keyvault/lib/certificate.js +55 -3
  34. package/lib/azure-keyvault/lib/key.d.ts +36 -0
  35. package/lib/azure-keyvault/lib/key.js +38 -2
  36. package/lib/azure-keyvault/lib/policy.d.ts +30 -0
  37. package/lib/azure-keyvault/lib/policy.js +32 -2
  38. package/lib/azure-keyvault/lib/secret.d.ts +31 -0
  39. package/lib/azure-keyvault/lib/secret.js +33 -2
  40. package/lib/azure-keyvault/lib/vault.d.ts +188 -0
  41. package/lib/azure-keyvault/lib/vault.js +191 -7
  42. package/lib/azure-kubernetes/lib/cluster.d.ts +25 -4
  43. package/lib/azure-kubernetes/lib/cluster.js +27 -6
  44. package/lib/azure-kusto/lib/cluster.d.ts +53 -0
  45. package/lib/azure-kusto/lib/cluster.js +55 -2
  46. package/lib/azure-kusto/lib/compute-specification.js +1 -1
  47. package/lib/azure-kusto/lib/database.d.ts +103 -0
  48. package/lib/azure-kusto/lib/database.js +105 -2
  49. package/lib/azure-loganalytics/lib/workspace.d.ts +47 -0
  50. package/lib/azure-loganalytics/lib/workspace.js +49 -2
  51. package/lib/azure-metricalert/lib/metric-alert.d.ts +43 -4
  52. package/lib/azure-metricalert/lib/metric-alert.js +45 -6
  53. package/lib/azure-networksecuritygroup/lib/preconfigured-rules.js +1 -1
  54. package/lib/azure-networksecuritygroup/lib/securitygroup.d.ts +92 -0
  55. package/lib/azure-networksecuritygroup/lib/securitygroup.js +95 -5
  56. package/lib/azure-queryrulealert/lib/query-rule-alert.d.ts +35 -4
  57. package/lib/azure-queryrulealert/lib/query-rule-alert.js +37 -6
  58. package/lib/azure-resourcegroup/lib/resource-group.d.ts +28 -0
  59. package/lib/azure-resourcegroup/lib/resource-group.js +30 -2
  60. package/lib/azure-storageaccount/lib/account.d.ts +75 -48
  61. package/lib/azure-storageaccount/lib/account.js +77 -50
  62. package/lib/azure-storageaccount/lib/container.d.ts +94 -12
  63. package/lib/azure-storageaccount/lib/container.js +97 -15
  64. package/lib/azure-storageaccount/lib/fileshare.d.ts +36 -0
  65. package/lib/azure-storageaccount/lib/fileshare.js +39 -3
  66. package/lib/azure-storageaccount/lib/queue.d.ts +29 -0
  67. package/lib/azure-storageaccount/lib/queue.js +31 -2
  68. package/lib/azure-storageaccount/lib/table.d.ts +32 -0
  69. package/lib/azure-storageaccount/lib/table.js +34 -2
  70. package/lib/azure-virtualmachine/lib/image-references.js +2 -2
  71. package/lib/azure-virtualmachine/lib/vm.d.ts +84 -8
  72. package/lib/azure-virtualmachine/lib/vm.js +87 -11
  73. package/lib/azure-virtualmachinescaleset/lib/cluster.d.ts +98 -8
  74. package/lib/azure-virtualmachinescaleset/lib/cluster.js +101 -11
  75. package/lib/azure-virtualnetwork/lib/network.d.ts +61 -0
  76. package/lib/azure-virtualnetwork/lib/network.js +63 -3
  77. package/lib/azure-virtualnetwork/lib/peering.d.ts +39 -0
  78. package/lib/azure-virtualnetwork/lib/peering.js +41 -2
  79. package/lib/core-azure/lib/diagsettings.d.ts +37 -0
  80. package/lib/core-azure/lib/diagsettings.js +39 -2
  81. package/lib/core-azure/lib/rbac.d.ts +22 -4
  82. package/lib/core-azure/lib/rbac.js +24 -6
  83. package/lib/core-azure/lib/resource.d.ts +45 -0
  84. package/lib/core-azure/lib/resource.js +48 -4
  85. package/package.json +1 -1
@@ -4,11 +4,50 @@ export declare class MetricAlert extends Construct {
4
4
  readonly props: model.IMetricAlertProps;
5
5
  readonly id: string;
6
6
  /**
7
- * Constructs a new instance of the MetricAlert class.
7
+ * Represents a Metric Alert in Azure Monitor, which is used to automatically monitor metrics across Azure services and trigger actions when certain conditions are met.
8
8
  *
9
- * @param scope - The scope in which this construct is defined.
10
- * @param id - The ID of this construct.
11
- * @param props - The properties required for Metric Alert.
9
+ * This class encapsulates the configuration and management of a Metric Alert, allowing users to define alert rules based on the metrics from their Azure resources. Metric Alerts can help in proactively managing the health, performance, and availability of Azure services.
10
+ *
11
+ * Properties:
12
+ * - `name`: The name of the Metric Alert, which must be unique within the resource group.
13
+ * - `description`: Optional. A description of what the Metric Alert monitors and potential impact or remediation.
14
+ * - `enabled`: Indicates whether the alert rule is enabled. Disabled rules will not fire.
15
+ * - `autoMitigate`: Specifies whether the alert should attempt auto-mitigation actions when triggered.
16
+ * - `frequency`: The frequency of evaluation for the alert rule, determining how often the rule is checked.
17
+ * - `severity`: The severity level assigned to the alert. This helps in categorizing the urgency of the alert.
18
+ * - `targetResourceType`: Specifies the type of Azure resource the alert rule applies to, necessary for scoping the alert.
19
+ * - `targetResourceLocation`: Specifies the location of the target resource, required when the alert rule covers resources in multiple locations.
20
+ * - `windowSize`: The period over which data is collected for analysis, which must be greater than the frequency of evaluation.
21
+ * - `tags`: User-defined tags to help organize and identify resources within Azure.
22
+ * - `criteria`: The conditions that trigger the alert. This can be static or dynamic, based on the behavior of the monitored metric over time.
23
+ * - `dynamicCriteria`: Advanced configurations for criteria that dynamically adjust thresholds based on historical data.
24
+ * - `scopes`: The specific resources that the Metric Alert is scoped to monitor.
25
+ * - `resourceGroup`: The Azure Resource Group in which this Metric Alert is defined.
26
+ *
27
+ * Example usage:
28
+ * ```typescript
29
+ * const cpuAlertProps: IMetricAlertProps = {
30
+ * name: 'High CPU Usage Alert',
31
+ * resourceGroup: resourceGroupInstance,
32
+ * scopes: [vm.id],
33
+ * criteria: [
34
+ * {
35
+ * metricName: 'Percentage CPU',
36
+ * operator: 'GreaterThan',
37
+ * threshold: 80,
38
+ * aggregation: 'Average'
39
+ * }
40
+ * ],
41
+ * frequency: 'PT1M',
42
+ * windowSize: 'PT5M',
43
+ * severity: 3,
44
+ * enabled: true
45
+ * };
46
+ *
47
+ * const cpuAlert = new MetricAlert(this, 'cpuUsageAlert', cpuAlertProps);
48
+ * ```
49
+ *
50
+ * This configuration defines a Metric Alert that monitors CPU usage across specified virtual machines, triggering an alert if the CPU usage exceeds 80% over a 5-minute window, evaluated every minute.
12
51
  */
13
52
  constructor(scope: Construct, id: string, props: model.IMetricAlertProps);
14
53
  private ValidatePropsFrequency;
@@ -10,11 +10,50 @@ const moment = require("moment");
10
10
  const model = require("../model");
11
11
  class MetricAlert extends constructs_1.Construct {
12
12
  /**
13
- * Constructs a new instance of the MetricAlert class.
13
+ * Represents a Metric Alert in Azure Monitor, which is used to automatically monitor metrics across Azure services and trigger actions when certain conditions are met.
14
14
  *
15
- * @param scope - The scope in which this construct is defined.
16
- * @param id - The ID of this construct.
17
- * @param props - The properties required for Metric Alert.
15
+ * This class encapsulates the configuration and management of a Metric Alert, allowing users to define alert rules based on the metrics from their Azure resources. Metric Alerts can help in proactively managing the health, performance, and availability of Azure services.
16
+ *
17
+ * Properties:
18
+ * - `name`: The name of the Metric Alert, which must be unique within the resource group.
19
+ * - `description`: Optional. A description of what the Metric Alert monitors and potential impact or remediation.
20
+ * - `enabled`: Indicates whether the alert rule is enabled. Disabled rules will not fire.
21
+ * - `autoMitigate`: Specifies whether the alert should attempt auto-mitigation actions when triggered.
22
+ * - `frequency`: The frequency of evaluation for the alert rule, determining how often the rule is checked.
23
+ * - `severity`: The severity level assigned to the alert. This helps in categorizing the urgency of the alert.
24
+ * - `targetResourceType`: Specifies the type of Azure resource the alert rule applies to, necessary for scoping the alert.
25
+ * - `targetResourceLocation`: Specifies the location of the target resource, required when the alert rule covers resources in multiple locations.
26
+ * - `windowSize`: The period over which data is collected for analysis, which must be greater than the frequency of evaluation.
27
+ * - `tags`: User-defined tags to help organize and identify resources within Azure.
28
+ * - `criteria`: The conditions that trigger the alert. This can be static or dynamic, based on the behavior of the monitored metric over time.
29
+ * - `dynamicCriteria`: Advanced configurations for criteria that dynamically adjust thresholds based on historical data.
30
+ * - `scopes`: The specific resources that the Metric Alert is scoped to monitor.
31
+ * - `resourceGroup`: The Azure Resource Group in which this Metric Alert is defined.
32
+ *
33
+ * Example usage:
34
+ * ```typescript
35
+ * const cpuAlertProps: IMetricAlertProps = {
36
+ * name: 'High CPU Usage Alert',
37
+ * resourceGroup: resourceGroupInstance,
38
+ * scopes: [vm.id],
39
+ * criteria: [
40
+ * {
41
+ * metricName: 'Percentage CPU',
42
+ * operator: 'GreaterThan',
43
+ * threshold: 80,
44
+ * aggregation: 'Average'
45
+ * }
46
+ * ],
47
+ * frequency: 'PT1M',
48
+ * windowSize: 'PT5M',
49
+ * severity: 3,
50
+ * enabled: true
51
+ * };
52
+ *
53
+ * const cpuAlert = new MetricAlert(this, 'cpuUsageAlert', cpuAlertProps);
54
+ * ```
55
+ *
56
+ * This configuration defines a Metric Alert that monitors CPU usage across specified virtual machines, triggering an alert if the CPU usage exceeds 80% over a 5-minute window, evaluated every minute.
18
57
  */
19
58
  constructor(scope, id, props) {
20
59
  super(scope, id);
@@ -85,5 +124,5 @@ class MetricAlert extends constructs_1.Construct {
85
124
  }
86
125
  exports.MetricAlert = MetricAlert;
87
126
  _a = JSII_RTTI_SYMBOL_1;
88
- MetricAlert[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_metricalert.MetricAlert", version: "0.0.3-pre.6" };
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metric-alert.js","sourceRoot":"","sources":["../../../src/azure-metricalert/lib/metric-alert.ts"],"names":[],"mappings":"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","sourcesContent":["import { MonitorMetricAlert } from \"@cdktf/provider-azurerm/lib/monitor-metric-alert\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport * as moment from \"moment\";\nimport * as model from \"../model\";\n\nexport class MetricAlert extends Construct {\n  readonly props: model.IMetricAlertProps;\n  public readonly id: string;\n\n  /**\n   * Constructs a new instance of the MetricAlert 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 Metric Alert.\n   */\n  constructor(scope: Construct, id: string, props: model.IMetricAlertProps) {\n    super(scope, id);\n\n    this.props = props;\n\n    // Setup default values\n    this.props.enabled = props.enabled ?? true;\n    this.props.automitigate = props.automitigate ?? true;\n    this.props.frequency = props.frequency ?? \"PT5M\";\n    this.props.severity = props.severity ?? 3;\n    this.props.windowSize = props.windowSize ?? props.frequency ?? \"PT5M\";\n\n    // Properties validation\n    this.ValidatePropsFrequency();\n    this.ValidatePropsWindowSize();\n    this.ValidatePropsWindowSizeGreaterThanFrequency();\n\n    // Create Metric Alert\n    const metricAlert = new MonitorMetricAlert(this, \"metricAlert\", {\n      name: props.name,\n      resourceGroupName: props.resourceGroup.name,\n      scopes: props.scopes,\n      description: props.description,\n      targetResourceType: props.targetResourceType,\n      targetResourceLocation: props.targetResourceLocation,\n      action: cdktf.listMapper(\n        model.monitorMetricAlertActionToTerraform,\n        true,\n      )(this.props.action),\n      tags: props.tags,\n      enabled: this.props.enabled,\n      autoMitigate: this.props.automitigate,\n      frequency: this.props.frequency,\n      severity: this.props.severity,\n      windowSize: this.props.windowSize,\n      criteria: cdktf.listMapper(\n        model.monitorMetricAlertCriteriaToTerraform,\n        true,\n      )(this.props.criteria),\n      dynamicCriteria: cdktf.listMapper(\n        model.monitorMetricAlertDynamicCriteriaToTerraform,\n        true,\n      )(this.props.dynamicCriteria),\n    });\n\n    // Output properties\n    this.id = metricAlert.id;\n    const cdktfTerraformOutputMetricAlertId = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: metricAlert.id,\n      },\n    );\n    cdktfTerraformOutputMetricAlertId.overrideLogicalId(\"id\");\n  }\n\n  private ValidatePropsFrequency() {\n    const frequencyOptions = [\"PT1M\", \"PT5M\", \"PT15M\", \"PT30M\", \"PT1H\"];\n    if (!frequencyOptions.includes(this.props.frequency ?? \"NotSet\")) {\n      throw new Error(`frequency must be one of ${frequencyOptions}`);\n    }\n  }\n\n  private ValidatePropsWindowSize() {\n    const windowSizeOptions = [\n      \"PT1M\",\n      \"PT5M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT1H\",\n      \"PT6H\",\n      \"PT12H\",\n      \"P1D\",\n    ];\n    if (!windowSizeOptions.includes(this.props.windowSize ?? \"NotSet\")) {\n      throw new Error(`windowSize must be one of ${windowSizeOptions}`);\n    }\n  }\n\n  private ValidatePropsWindowSizeGreaterThanFrequency() {\n    const f = moment.duration(this.props.frequency);\n    const w = moment.duration(this.props.windowSize);\n    if (w < f) {\n      throw new Error(\"windowSize must be greater than frequency\");\n    }\n  }\n}\n"]}
127
+ MetricAlert[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_metricalert.MetricAlert", version: "0.0.3-pre.7" };
128
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"metric-alert.js","sourceRoot":"","sources":["../../../src/azure-metricalert/lib/metric-alert.ts"],"names":[],"mappings":"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","sourcesContent":["import { MonitorMetricAlert } from \"@cdktf/provider-azurerm/lib/monitor-metric-alert\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport * as moment from \"moment\";\nimport * as model from \"../model\";\n\nexport class MetricAlert extends Construct {\n  readonly props: model.IMetricAlertProps;\n  public readonly id: string;\n\n  /**\n   * Represents a Metric Alert in Azure Monitor, which is used to automatically monitor metrics across Azure services and trigger actions when certain conditions are met.\n   *\n   * This class encapsulates the configuration and management of a Metric Alert, allowing users to define alert rules based on the metrics from their Azure resources. Metric Alerts can help in proactively managing the health, performance, and availability of Azure services.\n   *\n   * Properties:\n   * - `name`: The name of the Metric Alert, which must be unique within the resource group.\n   * - `description`: Optional. A description of what the Metric Alert monitors and potential impact or remediation.\n   * - `enabled`: Indicates whether the alert rule is enabled. Disabled rules will not fire.\n   * - `autoMitigate`: Specifies whether the alert should attempt auto-mitigation actions when triggered.\n   * - `frequency`: The frequency of evaluation for the alert rule, determining how often the rule is checked.\n   * - `severity`: The severity level assigned to the alert. This helps in categorizing the urgency of the alert.\n   * - `targetResourceType`: Specifies the type of Azure resource the alert rule applies to, necessary for scoping the alert.\n   * - `targetResourceLocation`: Specifies the location of the target resource, required when the alert rule covers resources in multiple locations.\n   * - `windowSize`: The period over which data is collected for analysis, which must be greater than the frequency of evaluation.\n   * - `tags`: User-defined tags to help organize and identify resources within Azure.\n   * - `criteria`: The conditions that trigger the alert. This can be static or dynamic, based on the behavior of the monitored metric over time.\n   * - `dynamicCriteria`: Advanced configurations for criteria that dynamically adjust thresholds based on historical data.\n   * - `scopes`: The specific resources that the Metric Alert is scoped to monitor.\n   * - `resourceGroup`: The Azure Resource Group in which this Metric Alert is defined.\n   *\n   * Example usage:\n   * ```typescript\n   * const cpuAlertProps: IMetricAlertProps = {\n   *   name: 'High CPU Usage Alert',\n   *   resourceGroup: resourceGroupInstance,\n   *   scopes: [vm.id],\n   *   criteria: [\n   *     {\n   *       metricName: 'Percentage CPU',\n   *       operator: 'GreaterThan',\n   *       threshold: 80,\n   *       aggregation: 'Average'\n   *     }\n   *   ],\n   *   frequency: 'PT1M',\n   *   windowSize: 'PT5M',\n   *   severity: 3,\n   *   enabled: true\n   * };\n   *\n   * const cpuAlert = new MetricAlert(this, 'cpuUsageAlert', cpuAlertProps);\n   * ```\n   *\n   * This configuration defines a Metric Alert that monitors CPU usage across specified virtual machines, triggering an alert if the CPU usage exceeds 80% over a 5-minute window, evaluated every minute.\n   */\n  constructor(scope: Construct, id: string, props: model.IMetricAlertProps) {\n    super(scope, id);\n\n    this.props = props;\n\n    // Setup default values\n    this.props.enabled = props.enabled ?? true;\n    this.props.automitigate = props.automitigate ?? true;\n    this.props.frequency = props.frequency ?? \"PT5M\";\n    this.props.severity = props.severity ?? 3;\n    this.props.windowSize = props.windowSize ?? props.frequency ?? \"PT5M\";\n\n    // Properties validation\n    this.ValidatePropsFrequency();\n    this.ValidatePropsWindowSize();\n    this.ValidatePropsWindowSizeGreaterThanFrequency();\n\n    // Create Metric Alert\n    const metricAlert = new MonitorMetricAlert(this, \"metricAlert\", {\n      name: props.name,\n      resourceGroupName: props.resourceGroup.name,\n      scopes: props.scopes,\n      description: props.description,\n      targetResourceType: props.targetResourceType,\n      targetResourceLocation: props.targetResourceLocation,\n      action: cdktf.listMapper(\n        model.monitorMetricAlertActionToTerraform,\n        true,\n      )(this.props.action),\n      tags: props.tags,\n      enabled: this.props.enabled,\n      autoMitigate: this.props.automitigate,\n      frequency: this.props.frequency,\n      severity: this.props.severity,\n      windowSize: this.props.windowSize,\n      criteria: cdktf.listMapper(\n        model.monitorMetricAlertCriteriaToTerraform,\n        true,\n      )(this.props.criteria),\n      dynamicCriteria: cdktf.listMapper(\n        model.monitorMetricAlertDynamicCriteriaToTerraform,\n        true,\n      )(this.props.dynamicCriteria),\n    });\n\n    // Output properties\n    this.id = metricAlert.id;\n    const cdktfTerraformOutputMetricAlertId = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: metricAlert.id,\n      },\n    );\n    cdktfTerraformOutputMetricAlertId.overrideLogicalId(\"id\");\n  }\n\n  private ValidatePropsFrequency() {\n    const frequencyOptions = [\"PT1M\", \"PT5M\", \"PT15M\", \"PT30M\", \"PT1H\"];\n    if (!frequencyOptions.includes(this.props.frequency ?? \"NotSet\")) {\n      throw new Error(`frequency must be one of ${frequencyOptions}`);\n    }\n  }\n\n  private ValidatePropsWindowSize() {\n    const windowSizeOptions = [\n      \"PT1M\",\n      \"PT5M\",\n      \"PT15M\",\n      \"PT30M\",\n      \"PT1H\",\n      \"PT6H\",\n      \"PT12H\",\n      \"P1D\",\n    ];\n    if (!windowSizeOptions.includes(this.props.windowSize ?? \"NotSet\")) {\n      throw new Error(`windowSize must be one of ${windowSizeOptions}`);\n    }\n  }\n\n  private ValidatePropsWindowSizeGreaterThanFrequency() {\n    const f = moment.duration(this.props.frequency);\n    const w = moment.duration(this.props.windowSize);\n    if (w < f) {\n      throw new Error(\"windowSize must be greater than frequency\");\n    }\n  }\n}\n"]}
@@ -22,7 +22,7 @@ class PreconfiguredRules {
22
22
  }
23
23
  exports.PreconfiguredRules = PreconfiguredRules;
24
24
  _a = JSII_RTTI_SYMBOL_1;
25
- PreconfiguredRules[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_networksecuritygroup.PreconfiguredRules", version: "0.0.3-pre.6" };
25
+ PreconfiguredRules[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_networksecuritygroup.PreconfiguredRules", version: "0.0.3-pre.7" };
26
26
  // Active Directory
27
27
  PreconfiguredRules.activeDirectoryAllowADReplication = {
28
28
  direction: "Inbound",
@@ -70,8 +70,78 @@ export declare class SecurityGroup extends AzureResource {
70
70
  id: string;
71
71
  readonly name: string;
72
72
  resourceGroup: ResourceGroup;
73
+ /**
74
+ * Represents an Azure Network Security Group (NSG).
75
+ *
76
+ * This class is responsible for the creation and management of an Azure Network Security Group, which acts as a virtual firewall
77
+ * for virtual network resources. A Network Security Group contains a list of security rules that allow or deny network traffic
78
+ * to resources connected to Azure Virtual Networks (VNet). Each rule specifies a combination of source and destination, port,
79
+ * and protocol, and an action (allow or deny) based on those combinations. This class allows for detailed configuration of these
80
+ * rules to enforce security policies for inbound and outbound network traffic.
81
+ *
82
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
83
+ * @param id - The unique identifier for this instance of the security group.
84
+ * @param props - The properties required to configure the Network Security Group, as defined in the SecurityGroupProps interface. These include:
85
+ * - `resourceGroup`: The Azure Resource Group under which the NSG will be deployed.
86
+ * - `location`: The Azure region where the NSG will be created.
87
+ * - `name`: The name of the NSG, which must be unique within the resource group.
88
+ * - `rules`: A list of rules that define the security policies for traffic control.
89
+ *
90
+ * Example usage:
91
+ * ```typescript
92
+ * new SecurityGroup(this, 'MySecurityGroup', {
93
+ * resourceGroup: myResourceGroup,
94
+ * location: 'East US',
95
+ * name: 'myNsg',
96
+ * rules: [{
97
+ * name: 'AllowSSH',
98
+ * priority: 100,
99
+ * direction: 'Inbound',
100
+ * access: 'Allow',
101
+ * protocol: 'Tcp',
102
+ * sourcePortRange: '*',
103
+ * destinationPortRange: '22',
104
+ * sourceAddressPrefix: '*',
105
+ * destinationAddressPrefix: '*'
106
+ * }]
107
+ * });
108
+ * ```
109
+ * This class initializes a Network Security Group with specified rules, handling network security management tasks efficiently.
110
+ */
73
111
  constructor(scope: Construct, id: string, props: SecurityGroupProps);
112
+ /**
113
+ * Associates this Network Security Group with a specified subnet.
114
+ *
115
+ * This method facilitates the attachment of the security group to a subnet, applying the security group's rules to all
116
+ * resources within the subnet. This is crucial for managing network access and security policies at the subnet level.
117
+ *
118
+ * @param subnet - The subnet object to which this network security group will be associated.
119
+ *
120
+ * Example usage:
121
+ * ```typescript
122
+ * const mySubnet = { id: 'subnet-123', name: 'SubnetA' };
123
+ * mySecurityGroup.associateToSubnet(mySubnet);
124
+ * ```
125
+ * This operation ensures that the security rules defined in the network security group are enforced on all network interfaces
126
+ * attached to the specified subnet.
127
+ */
74
128
  associateToSubnet(subnet: Subnet): void;
129
+ /**
130
+ * Associates this Network Security Group with a specified network interface.
131
+ *
132
+ * This method attaches the security group to a network interface, applying the security group's rules to the network interface.
133
+ * This allows for fine-grained control of network traffic to and from the specific network interface.
134
+ *
135
+ * @param networkInterface - The network interface object to which this network security group will be associated.
136
+ *
137
+ * Example usage:
138
+ * ```typescript
139
+ * const myNetworkInterface = { id: 'nic-456', name: 'NetworkInterfaceA' };
140
+ * mySecurityGroup.associateToNetworkInterface(myNetworkInterface);
141
+ * ```
142
+ * This operation ensures that the security rules defined in the network security group are applied directly to the specified
143
+ * network interface, controlling access in a more targeted manner.
144
+ */
75
145
  associateToNetworkInterface(networkInterface: NetworkInterface): void;
76
146
  }
77
147
  /**
@@ -94,5 +164,27 @@ export interface SecurityGroupAssociationsProps {
94
164
  readonly networkInterfaceId?: string;
95
165
  }
96
166
  export declare class SecurityGroupAssociations extends Construct {
167
+ /**
168
+ * Manages the associations of Azure Network Security Groups with subnets and network interfaces.
169
+ *
170
+ * This class provides the functionality to associate a network security group with either subnets or network interfaces
171
+ * within the Azure environment. By managing these associations, it helps enforce security rules at both the subnet level
172
+ * and the network interface level, enhancing security configurations and compliance.
173
+ *
174
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
175
+ * @param id - The unique identifier for the association instance.
176
+ * @param props - The properties for the association. Includes the network security group ID and optionally a subnet ID or network interface ID.
177
+ *
178
+ * Example usage:
179
+ * ```typescript
180
+ * new SecurityGroupAssociations(this, 'MyAssociations', {
181
+ * networkSecurityGroupId: 'nsg-123',
182
+ * subnetId: 'subnet-123',
183
+ * networkInterfaceId: 'nic-456',
184
+ * });
185
+ * ```
186
+ * Depending on the properties provided, this class will create the appropriate associations to apply the network security group
187
+ * to the specified subnet or network interface.
188
+ */
97
189
  constructor(scope: Construct, id: string, props: SecurityGroupAssociationsProps);
98
190
  }
@@ -10,6 +10,44 @@ const subnet_network_security_group_association_1 = require("@cdktf/provider-azu
10
10
  const constructs_1 = require("constructs");
11
11
  const lib_1 = require("../../core-azure/lib");
12
12
  class SecurityGroup extends lib_1.AzureResource {
13
+ /**
14
+ * Represents an Azure Network Security Group (NSG).
15
+ *
16
+ * This class is responsible for the creation and management of an Azure Network Security Group, which acts as a virtual firewall
17
+ * for virtual network resources. A Network Security Group contains a list of security rules that allow or deny network traffic
18
+ * to resources connected to Azure Virtual Networks (VNet). Each rule specifies a combination of source and destination, port,
19
+ * and protocol, and an action (allow or deny) based on those combinations. This class allows for detailed configuration of these
20
+ * rules to enforce security policies for inbound and outbound network traffic.
21
+ *
22
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
23
+ * @param id - The unique identifier for this instance of the security group.
24
+ * @param props - The properties required to configure the Network Security Group, as defined in the SecurityGroupProps interface. These include:
25
+ * - `resourceGroup`: The Azure Resource Group under which the NSG will be deployed.
26
+ * - `location`: The Azure region where the NSG will be created.
27
+ * - `name`: The name of the NSG, which must be unique within the resource group.
28
+ * - `rules`: A list of rules that define the security policies for traffic control.
29
+ *
30
+ * Example usage:
31
+ * ```typescript
32
+ * new SecurityGroup(this, 'MySecurityGroup', {
33
+ * resourceGroup: myResourceGroup,
34
+ * location: 'East US',
35
+ * name: 'myNsg',
36
+ * rules: [{
37
+ * name: 'AllowSSH',
38
+ * priority: 100,
39
+ * direction: 'Inbound',
40
+ * access: 'Allow',
41
+ * protocol: 'Tcp',
42
+ * sourcePortRange: '*',
43
+ * destinationPortRange: '22',
44
+ * sourceAddressPrefix: '*',
45
+ * destinationAddressPrefix: '*'
46
+ * }]
47
+ * });
48
+ * ```
49
+ * This class initializes a Network Security Group with specified rules, handling network security management tasks efficiently.
50
+ */
13
51
  constructor(scope, id, props) {
14
52
  super(scope, id);
15
53
  this.props = props;
@@ -39,14 +77,44 @@ class SecurityGroup extends lib_1.AzureResource {
39
77
  this.id = nsg.id;
40
78
  this.name = nsg.name;
41
79
  }
42
- // Method to associate the network security group to a subnet
80
+ /**
81
+ * Associates this Network Security Group with a specified subnet.
82
+ *
83
+ * This method facilitates the attachment of the security group to a subnet, applying the security group's rules to all
84
+ * resources within the subnet. This is crucial for managing network access and security policies at the subnet level.
85
+ *
86
+ * @param subnet - The subnet object to which this network security group will be associated.
87
+ *
88
+ * Example usage:
89
+ * ```typescript
90
+ * const mySubnet = { id: 'subnet-123', name: 'SubnetA' };
91
+ * mySecurityGroup.associateToSubnet(mySubnet);
92
+ * ```
93
+ * This operation ensures that the security rules defined in the network security group are enforced on all network interfaces
94
+ * attached to the specified subnet.
95
+ */
43
96
  associateToSubnet(subnet) {
44
97
  new SecurityGroupAssociations(this, subnet.name, {
45
98
  subnetId: subnet.id,
46
99
  networkSecurityGroupId: this.id,
47
100
  });
48
101
  }
49
- // Method to associate the network security group to a network interface
102
+ /**
103
+ * Associates this Network Security Group with a specified network interface.
104
+ *
105
+ * This method attaches the security group to a network interface, applying the security group's rules to the network interface.
106
+ * This allows for fine-grained control of network traffic to and from the specific network interface.
107
+ *
108
+ * @param networkInterface - The network interface object to which this network security group will be associated.
109
+ *
110
+ * Example usage:
111
+ * ```typescript
112
+ * const myNetworkInterface = { id: 'nic-456', name: 'NetworkInterfaceA' };
113
+ * mySecurityGroup.associateToNetworkInterface(myNetworkInterface);
114
+ * ```
115
+ * This operation ensures that the security rules defined in the network security group are applied directly to the specified
116
+ * network interface, controlling access in a more targeted manner.
117
+ */
50
118
  associateToNetworkInterface(networkInterface) {
51
119
  new SecurityGroupAssociations(this, networkInterface.name, {
52
120
  networkInterfaceId: networkInterface.id,
@@ -56,8 +124,30 @@ class SecurityGroup extends lib_1.AzureResource {
56
124
  }
57
125
  exports.SecurityGroup = SecurityGroup;
58
126
  _a = JSII_RTTI_SYMBOL_1;
59
- SecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_networksecuritygroup.SecurityGroup", version: "0.0.3-pre.6" };
127
+ SecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_networksecuritygroup.SecurityGroup", version: "0.0.3-pre.7" };
60
128
  class SecurityGroupAssociations extends constructs_1.Construct {
129
+ /**
130
+ * Manages the associations of Azure Network Security Groups with subnets and network interfaces.
131
+ *
132
+ * This class provides the functionality to associate a network security group with either subnets or network interfaces
133
+ * within the Azure environment. By managing these associations, it helps enforce security rules at both the subnet level
134
+ * and the network interface level, enhancing security configurations and compliance.
135
+ *
136
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
137
+ * @param id - The unique identifier for the association instance.
138
+ * @param props - The properties for the association. Includes the network security group ID and optionally a subnet ID or network interface ID.
139
+ *
140
+ * Example usage:
141
+ * ```typescript
142
+ * new SecurityGroupAssociations(this, 'MyAssociations', {
143
+ * networkSecurityGroupId: 'nsg-123',
144
+ * subnetId: 'subnet-123',
145
+ * networkInterfaceId: 'nic-456',
146
+ * });
147
+ * ```
148
+ * Depending on the properties provided, this class will create the appropriate associations to apply the network security group
149
+ * to the specified subnet or network interface.
150
+ */
61
151
  constructor(scope, id, props) {
62
152
  super(scope, id);
63
153
  // If subnetId is provided, create a SubnetNetworkSecurityGroupAssociation
@@ -78,5 +168,5 @@ class SecurityGroupAssociations extends constructs_1.Construct {
78
168
  }
79
169
  exports.SecurityGroupAssociations = SecurityGroupAssociations;
80
170
  _b = JSII_RTTI_SYMBOL_1;
81
- SecurityGroupAssociations[_b] = { fqn: "@microsoft/terraform-cdk-constructs.azure_networksecuritygroup.SecurityGroupAssociations", version: "0.0.3-pre.6" };
82
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"securitygroup.js","sourceRoot":"","sources":["../../../src/azure-networksecuritygroup/lib/securitygroup.ts"],"names":[],"mappings":";;;;;AACA,2IAAoI;AACpI,+FAA0F;AAC1F,6FAAwF;AAGxF,qIAA8H;AAC9H,2CAAuC;AACvC,8CAAqD;AA6ErD,MAAa,aAAc,SAAQ,mBAAa;IAM9C,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAyB;QACjE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QAEzC,kCAAkC;QAClC,MAAM,GAAG,GAAG,IAAI,6CAAoB,CAAC,IAAI,EAAE,KAAK,EAAE;YAChD,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC,IAAI;YAC3C,QAAQ,EAAE,KAAK,CAAC,QAAQ;SACzB,CAAC,CAAC;QAEH,0DAA0D;QAC1D,KAAK,MAAM,UAAU,IAAI,KAAK,CAAC,KAAK,EAAE;YACpC,IAAI,2CAAmB,CAAC,IAAI,EAAE,UAAU,CAAC,IAAI,EAAE;gBAC7C,IAAI,EAAE,UAAU,CAAC,IAAI;gBACrB,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC,IAAI;gBAC3C,wBAAwB,EAAE,GAAG,CAAC,IAAI;gBAClC,QAAQ,EAAE,UAAU,CAAC,QAAQ;gBAC7B,SAAS,EAAE,UAAU,CAAC,SAAS;gBAC/B,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,QAAQ,EAAE,UAAU,CAAC,QAAQ;gBAC7B,eAAe,EAAE,UAAU,CAAC,eAAe;gBAC3C,oBAAoB,EAAE,UAAU,CAAC,oBAAoB;gBACrD,mBAAmB,EAAE,UAAU,CAAC,mBAAmB;gBACnD,wBAAwB,EAAE,UAAU,CAAC,wBAAwB;aAC9D,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,EAAE,GAAG,GAAG,CAAC,EAAE,CAAC;QACjB,IAAI,CAAC,IAAI,GAAG,GAAG,CAAC,IAAI,CAAC;IACvB,CAAC;IAED,6DAA6D;IACtD,iBAAiB,CAAC,MAAc;QACrC,IAAI,yBAAyB,CAAC,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE;YAC/C,QAAQ,EAAE,MAAM,CAAC,EAAE;YACnB,sBAAsB,EAAE,IAAI,CAAC,EAAE;SAChC,CAAC,CAAC;IACL,CAAC;IAED,wEAAwE;IACjE,2BAA2B,CAAC,gBAAkC;QACnE,IAAI,yBAAyB,CAAC,IAAI,EAAE,gBAAgB,CAAC,IAAI,EAAE;YACzD,kBAAkB,EAAE,gBAAgB,CAAC,EAAE;YACvC,sBAAsB,EAAE,IAAI,CAAC,EAAE;SAChC,CAAC,CAAC;IACL,CAAC;;AAtDH,sCAuDC;;;AAwBD,MAAa,yBAA0B,SAAQ,sBAAS;IACtD,YACE,KAAgB,EAChB,EAAU,EACV,KAAqC;QAErC,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,0EAA0E;QAC1E,IAAI,KAAK,CAAC,QAAQ,EAAE;YAClB,IAAI,iFAAqC,CAAC,IAAI,EAAE,gBAAgB,EAAE;gBAChE,QAAQ,EAAE,KAAK,CAAC,QAAQ;gBACxB,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;aACrD,CAAC,CAAC;SACJ;QAED,uFAAuF;QACvF,IAAI,KAAK,CAAC,kBAAkB,EAAE;YAC5B,IAAI,uFAAwC,CAAC,IAAI,EAAE,gBAAgB,EAAE;gBACnE,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;gBAC5C,sBAAsB,EAAE,KAAK,CAAC,sBAAsB;aACrD,CAAC,CAAC;SACJ;IACH,CAAC;;AAtBH,8DAuBC","sourcesContent":["import { NetworkInterface } from \"@cdktf/provider-azurerm/lib/network-interface\"; // Import the NetworkInterface class\nimport { NetworkInterfaceSecurityGroupAssociation } from \"@cdktf/provider-azurerm/lib/network-interface-security-group-association\";\nimport { NetworkSecurityGroup } from \"@cdktf/provider-azurerm/lib/network-security-group\";\nimport { NetworkSecurityRule } from \"@cdktf/provider-azurerm/lib/network-security-rule\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Subnet } from \"@cdktf/provider-azurerm/lib/subnet\";\nimport { SubnetNetworkSecurityGroupAssociation } from \"@cdktf/provider-azurerm/lib/subnet-network-security-group-association\";\nimport { Construct } from \"constructs\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\n/**\n * Configuration properties for defining a rule within an Azure Network Security Group.\n */\nexport interface RuleConfig {\n  /**\n   * The name of the security rule.\n   */\n  readonly name: string;\n\n  /**\n   * The priority of the rule. Lower numbers have higher priority. Allowed values are from 100 to 4096.\n   */\n  readonly priority: number;\n\n  /**\n   * The direction of the rule, which can be 'Inbound' or 'Outbound'.\n   */\n  readonly direction: string;\n\n  /**\n   * The access type of the rule, which determines whether the rule permits or denies traffic. Common values are 'Allow' or 'Deny'.\n   */\n  readonly access: string;\n\n  /**\n   * The protocol to which the rule applies, such as 'Tcp', 'Udp', or '*' (for all protocols).\n   */\n  readonly protocol: string;\n\n  /**\n   * The range of source ports to which the rule applies. Can be a single port or a range like '1024-2048'.\n   */\n  readonly sourcePortRange: string;\n\n  /**\n   * The range of destination ports to which the rule applies. Can also be a single port or a range.\n   */\n  readonly destinationPortRange: string;\n\n  /**\n   * The CIDR or source IP range or '*' to match any IP. This is the range of source IPs for which the rule applies.\n   */\n  readonly sourceAddressPrefix: string;\n\n  /**\n   * The CIDR or destination IP range or '*' to match any IP. This specifies the range of destination IPs for which the rule is applicable.\n   */\n  readonly destinationAddressPrefix: string;\n}\n\n/**\n * Properties for defining an Azure Network Security Group.\n */\nexport interface SecurityGroupProps {\n  /**\n   * The name of the resource group under which the network security group will be created.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The Azure region in which to create the network security group, e.g., 'East US', 'West Europe'.\n   */\n  readonly location: string;\n\n  /**\n   * The name of the network security group. Must be unique within the resource group.\n   */\n  readonly name: string;\n\n  /**\n   * An array of rule configurations to be applied to the network security group.\n   */\n  readonly rules: RuleConfig[];\n}\n\nexport class SecurityGroup extends AzureResource {\n  readonly props: SecurityGroupProps;\n  public id: string;\n  public readonly name: string;\n  public resourceGroup: ResourceGroup;\n\n  constructor(scope: Construct, id: string, props: SecurityGroupProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Create a network security group\n    const nsg = new NetworkSecurityGroup(this, \"nsg\", {\n      name: props.name,\n      resourceGroupName: props.resourceGroup.name,\n      location: props.location,\n    });\n\n    // Create security rules within the network security group\n    for (const ruleConfig of props.rules) {\n      new NetworkSecurityRule(this, ruleConfig.name, {\n        name: ruleConfig.name,\n        resourceGroupName: props.resourceGroup.name,\n        networkSecurityGroupName: nsg.name,\n        priority: ruleConfig.priority,\n        direction: ruleConfig.direction,\n        access: ruleConfig.access,\n        protocol: ruleConfig.protocol,\n        sourcePortRange: ruleConfig.sourcePortRange,\n        destinationPortRange: ruleConfig.destinationPortRange,\n        sourceAddressPrefix: ruleConfig.sourceAddressPrefix,\n        destinationAddressPrefix: ruleConfig.destinationAddressPrefix,\n      });\n    }\n\n    this.id = nsg.id;\n    this.name = nsg.name;\n  }\n\n  // Method to associate the network security group to a subnet\n  public associateToSubnet(subnet: Subnet) {\n    new SecurityGroupAssociations(this, subnet.name, {\n      subnetId: subnet.id,\n      networkSecurityGroupId: this.id,\n    });\n  }\n\n  // Method to associate the network security group to a network interface\n  public associateToNetworkInterface(networkInterface: NetworkInterface) {\n    new SecurityGroupAssociations(this, networkInterface.name, {\n      networkInterfaceId: networkInterface.id,\n      networkSecurityGroupId: this.id,\n    });\n  }\n}\n\n/**\n * Properties for associating Azure Network Security Groups with subnets and network interfaces.\n */\nexport interface SecurityGroupAssociationsProps {\n  /**\n   * The ID of the network security group to be associated.\n   */\n  readonly networkSecurityGroupId: string;\n\n  /**\n   * Optional subnet ID to associate with the network security group.\n   * If provided, the security group will be associated with this subnet.\n   */\n  readonly subnetId?: string;\n\n  /**\n   * Optional network interface ID to associate with the network security group.\n   * If provided, the security group will be associated with this network interface.\n   */\n  readonly networkInterfaceId?: string;\n}\n\nexport class SecurityGroupAssociations extends Construct {\n  constructor(\n    scope: Construct,\n    id: string,\n    props: SecurityGroupAssociationsProps,\n  ) {\n    super(scope, id);\n    // If subnetId is provided, create a SubnetNetworkSecurityGroupAssociation\n    if (props.subnetId) {\n      new SubnetNetworkSecurityGroupAssociation(this, \"subassociation\", {\n        subnetId: props.subnetId,\n        networkSecurityGroupId: props.networkSecurityGroupId,\n      });\n    }\n\n    // If networkInterfaceId is provided, create a NetworkInterfaceSecurityGroupAssociation\n    if (props.networkInterfaceId) {\n      new NetworkInterfaceSecurityGroupAssociation(this, \"nicassociation\", {\n        networkInterfaceId: props.networkInterfaceId,\n        networkSecurityGroupId: props.networkSecurityGroupId,\n      });\n    }\n  }\n}\n"]}
171
+ SecurityGroupAssociations[_b] = { fqn: "@microsoft/terraform-cdk-constructs.azure_networksecuritygroup.SecurityGroupAssociations", version: "0.0.3-pre.7" };
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"securitygroup.js","sourceRoot":"","sources":["../../../src/azure-networksecuritygroup/lib/securitygroup.ts"],"names":[],"mappings":"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","sourcesContent":["import { NetworkInterface } from \"@cdktf/provider-azurerm/lib/network-interface\"; // Import the NetworkInterface class\nimport { NetworkInterfaceSecurityGroupAssociation } from \"@cdktf/provider-azurerm/lib/network-interface-security-group-association\";\nimport { NetworkSecurityGroup } from \"@cdktf/provider-azurerm/lib/network-security-group\";\nimport { NetworkSecurityRule } from \"@cdktf/provider-azurerm/lib/network-security-rule\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Subnet } from \"@cdktf/provider-azurerm/lib/subnet\";\nimport { SubnetNetworkSecurityGroupAssociation } from \"@cdktf/provider-azurerm/lib/subnet-network-security-group-association\";\nimport { Construct } from \"constructs\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\n/**\n * Configuration properties for defining a rule within an Azure Network Security Group.\n */\nexport interface RuleConfig {\n  /**\n   * The name of the security rule.\n   */\n  readonly name: string;\n\n  /**\n   * The priority of the rule. Lower numbers have higher priority. Allowed values are from 100 to 4096.\n   */\n  readonly priority: number;\n\n  /**\n   * The direction of the rule, which can be 'Inbound' or 'Outbound'.\n   */\n  readonly direction: string;\n\n  /**\n   * The access type of the rule, which determines whether the rule permits or denies traffic. Common values are 'Allow' or 'Deny'.\n   */\n  readonly access: string;\n\n  /**\n   * The protocol to which the rule applies, such as 'Tcp', 'Udp', or '*' (for all protocols).\n   */\n  readonly protocol: string;\n\n  /**\n   * The range of source ports to which the rule applies. Can be a single port or a range like '1024-2048'.\n   */\n  readonly sourcePortRange: string;\n\n  /**\n   * The range of destination ports to which the rule applies. Can also be a single port or a range.\n   */\n  readonly destinationPortRange: string;\n\n  /**\n   * The CIDR or source IP range or '*' to match any IP. This is the range of source IPs for which the rule applies.\n   */\n  readonly sourceAddressPrefix: string;\n\n  /**\n   * The CIDR or destination IP range or '*' to match any IP. This specifies the range of destination IPs for which the rule is applicable.\n   */\n  readonly destinationAddressPrefix: string;\n}\n\n/**\n * Properties for defining an Azure Network Security Group.\n */\nexport interface SecurityGroupProps {\n  /**\n   * The name of the resource group under which the network security group will be created.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The Azure region in which to create the network security group, e.g., 'East US', 'West Europe'.\n   */\n  readonly location: string;\n\n  /**\n   * The name of the network security group. Must be unique within the resource group.\n   */\n  readonly name: string;\n\n  /**\n   * An array of rule configurations to be applied to the network security group.\n   */\n  readonly rules: RuleConfig[];\n}\n\nexport class SecurityGroup extends AzureResource {\n  readonly props: SecurityGroupProps;\n  public id: string;\n  public readonly name: string;\n  public resourceGroup: ResourceGroup;\n\n  /**\n   * Represents an Azure Network Security Group (NSG).\n   *\n   * This class is responsible for the creation and management of an Azure Network Security Group, which acts as a virtual firewall\n   * for virtual network resources. A Network Security Group contains a list of security rules that allow or deny network traffic\n   * to resources connected to Azure Virtual Networks (VNet). Each rule specifies a combination of source and destination, port,\n   * and protocol, and an action (allow or deny) based on those combinations. This class allows for detailed configuration of these\n   * rules to enforce security policies for inbound and outbound network traffic.\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 security group.\n   * @param props - The properties required to configure the Network Security Group, as defined in the SecurityGroupProps interface. These include:\n   *                - `resourceGroup`: The Azure Resource Group under which the NSG will be deployed.\n   *                - `location`: The Azure region where the NSG will be created.\n   *                - `name`: The name of the NSG, which must be unique within the resource group.\n   *                - `rules`: A list of rules that define the security policies for traffic control.\n   *\n   * Example usage:\n   * ```typescript\n   * new SecurityGroup(this, 'MySecurityGroup', {\n   *   resourceGroup: myResourceGroup,\n   *   location: 'East US',\n   *   name: 'myNsg',\n   *   rules: [{\n   *     name: 'AllowSSH',\n   *     priority: 100,\n   *     direction: 'Inbound',\n   *     access: 'Allow',\n   *     protocol: 'Tcp',\n   *     sourcePortRange: '*',\n   *     destinationPortRange: '22',\n   *     sourceAddressPrefix: '*',\n   *     destinationAddressPrefix: '*'\n   *   }]\n   * });\n   * ```\n   * This class initializes a Network Security Group with specified rules, handling network security management tasks efficiently.\n   */\n  constructor(scope: Construct, id: string, props: SecurityGroupProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Create a network security group\n    const nsg = new NetworkSecurityGroup(this, \"nsg\", {\n      name: props.name,\n      resourceGroupName: props.resourceGroup.name,\n      location: props.location,\n    });\n\n    // Create security rules within the network security group\n    for (const ruleConfig of props.rules) {\n      new NetworkSecurityRule(this, ruleConfig.name, {\n        name: ruleConfig.name,\n        resourceGroupName: props.resourceGroup.name,\n        networkSecurityGroupName: nsg.name,\n        priority: ruleConfig.priority,\n        direction: ruleConfig.direction,\n        access: ruleConfig.access,\n        protocol: ruleConfig.protocol,\n        sourcePortRange: ruleConfig.sourcePortRange,\n        destinationPortRange: ruleConfig.destinationPortRange,\n        sourceAddressPrefix: ruleConfig.sourceAddressPrefix,\n        destinationAddressPrefix: ruleConfig.destinationAddressPrefix,\n      });\n    }\n\n    this.id = nsg.id;\n    this.name = nsg.name;\n  }\n\n  /**\n   * Associates this Network Security Group with a specified subnet.\n   *\n   * This method facilitates the attachment of the security group to a subnet, applying the security group's rules to all\n   * resources within the subnet. This is crucial for managing network access and security policies at the subnet level.\n   *\n   * @param subnet - The subnet object to which this network security group will be associated.\n   *\n   * Example usage:\n   * ```typescript\n   * const mySubnet = { id: 'subnet-123', name: 'SubnetA' };\n   * mySecurityGroup.associateToSubnet(mySubnet);\n   * ```\n   * This operation ensures that the security rules defined in the network security group are enforced on all network interfaces\n   * attached to the specified subnet.\n   */\n  public associateToSubnet(subnet: Subnet) {\n    new SecurityGroupAssociations(this, subnet.name, {\n      subnetId: subnet.id,\n      networkSecurityGroupId: this.id,\n    });\n  }\n\n  /**\n   * Associates this Network Security Group with a specified network interface.\n   *\n   * This method attaches the security group to a network interface, applying the security group's rules to the network interface.\n   * This allows for fine-grained control of network traffic to and from the specific network interface.\n   *\n   * @param networkInterface - The network interface object to which this network security group will be associated.\n   *\n   * Example usage:\n   * ```typescript\n   * const myNetworkInterface = { id: 'nic-456', name: 'NetworkInterfaceA' };\n   * mySecurityGroup.associateToNetworkInterface(myNetworkInterface);\n   * ```\n   * This operation ensures that the security rules defined in the network security group are applied directly to the specified\n   * network interface, controlling access in a more targeted manner.\n   */\n  public associateToNetworkInterface(networkInterface: NetworkInterface) {\n    new SecurityGroupAssociations(this, networkInterface.name, {\n      networkInterfaceId: networkInterface.id,\n      networkSecurityGroupId: this.id,\n    });\n  }\n}\n\n/**\n * Properties for associating Azure Network Security Groups with subnets and network interfaces.\n */\nexport interface SecurityGroupAssociationsProps {\n  /**\n   * The ID of the network security group to be associated.\n   */\n  readonly networkSecurityGroupId: string;\n\n  /**\n   * Optional subnet ID to associate with the network security group.\n   * If provided, the security group will be associated with this subnet.\n   */\n  readonly subnetId?: string;\n\n  /**\n   * Optional network interface ID to associate with the network security group.\n   * If provided, the security group will be associated with this network interface.\n   */\n  readonly networkInterfaceId?: string;\n}\n\nexport class SecurityGroupAssociations extends Construct {\n  /**\n   * Manages the associations of Azure Network Security Groups with subnets and network interfaces.\n   *\n   * This class provides the functionality to associate a network security group with either subnets or network interfaces\n   * within the Azure environment. By managing these associations, it helps enforce security rules at both the subnet level\n   * and the network interface level, enhancing security configurations and compliance.\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 the association instance.\n   * @param props - The properties for the association. Includes the network security group ID and optionally a subnet ID or network interface ID.\n   *\n   * Example usage:\n   * ```typescript\n   * new SecurityGroupAssociations(this, 'MyAssociations', {\n   *   networkSecurityGroupId: 'nsg-123',\n   *   subnetId: 'subnet-123',\n   *   networkInterfaceId: 'nic-456',\n   * });\n   * ```\n   * Depending on the properties provided, this class will create the appropriate associations to apply the network security group\n   * to the specified subnet or network interface.\n   */\n  constructor(\n    scope: Construct,\n    id: string,\n    props: SecurityGroupAssociationsProps,\n  ) {\n    super(scope, id);\n    // If subnetId is provided, create a SubnetNetworkSecurityGroupAssociation\n    if (props.subnetId) {\n      new SubnetNetworkSecurityGroupAssociation(this, \"subassociation\", {\n        subnetId: props.subnetId,\n        networkSecurityGroupId: props.networkSecurityGroupId,\n      });\n    }\n\n    // If networkInterfaceId is provided, create a NetworkInterfaceSecurityGroupAssociation\n    if (props.networkInterfaceId) {\n      new NetworkInterfaceSecurityGroupAssociation(this, \"nicassociation\", {\n        networkInterfaceId: props.networkInterfaceId,\n        networkSecurityGroupId: props.networkSecurityGroupId,\n      });\n    }\n  }\n}\n"]}
@@ -134,11 +134,42 @@ export declare class QueryRuleAlert extends Construct {
134
134
  id: string;
135
135
  resourceGroup: ResourceGroup;
136
136
  /**
137
- * Constructs a new instance of the AzureQueryRuleAlert class.
137
+ * Represents an Azure Monitor Scheduled Query Rule Alert.
138
138
  *
139
- * @param scope - The scope in which this construct is defined.
140
- * @param id - The ID of this construct.
141
- * @param props - The properties required for Azure Query Rule Alert.
139
+ * This class is responsible for the creation and management of a Scheduled Query Rule Alert in Azure Monitor.
140
+ * Scheduled Query Rule Alerts execute specified queries at regular intervals over the data collected in Log Analytics
141
+ * Workspaces or Application Insights, and alert based on the results of these queries. These alerts can be used to monitor
142
+ * application health, infrastructure changes, or compliance with certain conditions.
143
+ *
144
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
145
+ * @param id - The unique identifier for this instance of the Scheduled Query Rule Alert.
146
+ * @param props - The properties required to configure the Scheduled Query Rule Alert, as defined in the AzureQueryRuleAlertProps interface.
147
+ * These include:
148
+ * - `name`: The name of the Scheduled Query Rule.
149
+ * - `resourceGroup`: The Azure Resource Group under which the alert will be created.
150
+ * - `location`: The Azure region where the alert will be deployed.
151
+ * - `criteriaQuery`: The query to execute. The results of this query determine whether an alert should be triggered.
152
+ * - `evaluationFrequency`: How often the query should be run.
153
+ * - `windowDuration`: The time period over which data is collected for each execution of the query.
154
+ * - `severity`: The severity of the alert.
155
+ * - `actionActionGroupId`: The action group to invoke when the alert criteria are met.
156
+ * - `enabled`: Indicates whether the alert rule is enabled.
157
+ *
158
+ * Example usage:
159
+ * ```typescript
160
+ * new QueryRuleAlert(this, 'MyAlertRule', {
161
+ * name: 'HighErrorRateAlert',
162
+ * resourceGroup: myResourceGroup,
163
+ * location: 'West US 2',
164
+ * criteriaQuery: 'Heartbeat | summarize AggregatedValue = count() by bin(TimeGenerated, 5m)',
165
+ * evaluationFrequency: 'PT5M',
166
+ * windowDuration: 'PT1H',
167
+ * severity: 3,
168
+ * actionActionGroupId: ['/subscriptions/sub-id/resourceGroups/rg/providers/microsoft.insights/actionGroups/myActionGroup'],
169
+ * enabled: true
170
+ * });
171
+ * ```
172
+ * This class sets up the alert rule and ensures it is ready to trigger actions based on the specified criteria and schedule.
142
173
  */
143
174
  constructor(scope: Construct, id: string, props: AzureQueryRuleAlertProps);
144
175
  }