@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
package/README.md
CHANGED
|
@@ -1,32 +1,126 @@
|
|
|
1
|
-
# Terraform
|
|
1
|
+
# Azure Terraform CDK Constructs
|
|
2
|
+
Welcome to the Azure Terraform CDK Constructs project! This library offers a comprehensive suite of L2 Constructs designed to simplify and enhance the experience of building and managing Azure infrastructure with the Cloud Development Kit for Terraform (CDKTF).
|
|
2
3
|
|
|
3
|
-
|
|
4
|
+
## Benefits of Using L2 Constructs
|
|
4
5
|
|
|
6
|
+
With L2 Constructs, you get the following benefits:
|
|
5
7
|
|
|
8
|
+
- **Abstraction**: Higher-level abstractions over Azure resources make your infrastructure code more declarative and easier to understand.
|
|
9
|
+
- **Reusability**: Encapsulate common patterns and best practices in your infrastructure code, promoting reusability across different projects and teams.
|
|
10
|
+
- **Rapid Development**: Accelerate your cloud development process with pre-built constructs that have been tested for common use cases, allowing you to focus on your unique application logic.
|
|
11
|
+
- **Direct IDE Integration**: Access detailed documentation directly within your Integrated Development Environment (IDE), streamlining your development workflow: 
|
|
6
12
|
|
|
7
|
-
## Using the Libraries
|
|
8
13
|
|
|
9
|
-
|
|
14
|
+
## Quick Example
|
|
10
15
|
|
|
11
|
-
|
|
16
|
+
This is a quick example that showcases the simplicity and power of L2 Constructs. We'll create a storage account, add a container to it, and then upload a blob—all with a few lines of intuitive, object-oriented code:
|
|
12
17
|
|
|
13
18
|
```typescript
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
const
|
|
17
|
-
name:
|
|
18
|
-
location:
|
|
19
|
-
resourceGroup: 'my-resource-group',
|
|
20
|
-
size: 'Standard_D2s_v3',
|
|
21
|
-
osDisk: {
|
|
22
|
-
storageAccountType: 'Standard_LRS',
|
|
23
|
-
diskSizeGB: 128,
|
|
24
|
-
},
|
|
25
|
-
adminUsername: 'admin',
|
|
26
|
-
adminPassword: 'password',
|
|
19
|
+
|
|
20
|
+
// Create a new instance of a storage account as an object
|
|
21
|
+
const sa = new azcdk.azure_storageaccount.Account(stack, "storageaccount", {
|
|
22
|
+
name: "testStorageAccount",
|
|
23
|
+
location: "eastus",
|
|
27
24
|
});
|
|
25
|
+
|
|
26
|
+
// Add a container to the storage account by calling a method on the storage account object
|
|
27
|
+
const container = sa.addContainer("testcontainer");
|
|
28
|
+
|
|
29
|
+
// Add a blob to the container by calling a method on the container object
|
|
30
|
+
// The path "../../../test.txt" points to the source file to be uploaded as a blob
|
|
31
|
+
container.addBlob("testblob.txt", "../../../test.txt");
|
|
32
|
+
```
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
|
|
36
|
+
## Getting Started
|
|
37
|
+
|
|
38
|
+
This guide will walk you through the process of using the Azure L2 Constructs to define and provision infrastructure on Azure.
|
|
39
|
+
|
|
40
|
+
### Prerequisites
|
|
41
|
+
Make sure you have Node.js and npm installed on your machine. These will be used to install the CDK for Terraform and Azure provider packages.
|
|
42
|
+
|
|
43
|
+
### Installation
|
|
44
|
+
|
|
45
|
+
First, install the CDK for Terraform CLI globally using npm:
|
|
46
|
+
|
|
47
|
+
```sh
|
|
48
|
+
npm install -g cdktf-cli
|
|
49
|
+
```
|
|
50
|
+
|
|
51
|
+
Next, initialize a new CDK for Terraform project with TypeScript template:
|
|
52
|
+
```sh
|
|
53
|
+
cdktf init --template="TypeScript" --local
|
|
54
|
+
```
|
|
55
|
+
Install the AzureRM provider for CDKTF:
|
|
56
|
+
|
|
57
|
+
```sh
|
|
58
|
+
npm install @cdktf/provider-azurerm
|
|
28
59
|
```
|
|
29
60
|
|
|
61
|
+
Then, add the Microsoft Terraform CDK constructs for Azure:
|
|
62
|
+
|
|
63
|
+
```sh
|
|
64
|
+
npm install @micrsoft/terraform-cdk-constructs
|
|
65
|
+
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+
### Example 1: Creating a Storage Account
|
|
70
|
+
Now let's create a simple Azure storage account. The following TypeScript snippet defines a storage account resource using the CDKTF:
|
|
71
|
+
|
|
72
|
+
```typescript
|
|
73
|
+
// Import necessary modules and classes
|
|
74
|
+
import * as azcdk from "@microsoft/terraform-cdk-constructs";
|
|
75
|
+
import { Construct } from 'constructs';
|
|
76
|
+
import { App, TerraformStack } from 'cdktf';
|
|
77
|
+
import { AzurermProvider } from "@cdktf/provider-azurerm/lib/provider";
|
|
78
|
+
|
|
79
|
+
// Define a new Terraform stack
|
|
80
|
+
class AzureAppInfra extends TerraformStack {
|
|
81
|
+
constructor(scope: Construct, name: string) {
|
|
82
|
+
super(scope, name);
|
|
83
|
+
|
|
84
|
+
// Initialize Azure provider
|
|
85
|
+
new AzurermProvider(this, "azureFeature", { features: {} });
|
|
86
|
+
|
|
87
|
+
// Create a new Azure storage account with the specified name and location
|
|
88
|
+
new azcdk.azure_storageaccount.Account(this, "storageaccount", {
|
|
89
|
+
name: "test42348808",
|
|
90
|
+
location: "eastus",
|
|
91
|
+
});
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
// Initialize the CDK app and synthesize Terraform configurations
|
|
96
|
+
const app = new App();
|
|
97
|
+
new AzureAppInfra(app, 'cdk');
|
|
98
|
+
app.synth();
|
|
99
|
+
```
|
|
100
|
+
After defining your infrastructure, generate the Terraform configuration files:
|
|
101
|
+
```sh
|
|
102
|
+
cdktf synth
|
|
103
|
+
```
|
|
104
|
+
Finally, deploy your infrastructure to Azure:
|
|
105
|
+
|
|
106
|
+
```sh
|
|
107
|
+
cdktf deploy
|
|
108
|
+
```
|
|
109
|
+
## Supported Languages
|
|
110
|
+
|
|
111
|
+
Currently, our CDK L2 constructs are available in the following languages:
|
|
112
|
+
|
|
113
|
+
| Language | Status |
|
|
114
|
+
|------------|--------------|
|
|
115
|
+
| TypeScript | Available |
|
|
116
|
+
| Python | Coming soon |
|
|
117
|
+
| Java | Coming soon |
|
|
118
|
+
| Go | Coming soon |
|
|
119
|
+
| C# | Coming soon |
|
|
120
|
+
|
|
121
|
+
Stay tuned for updates as we work to expand support to other popular programming languages!
|
|
122
|
+
|
|
123
|
+
|
|
30
124
|
## Contributing
|
|
31
125
|
|
|
32
126
|
This project welcomes contributions and suggestions. Most contributions require you to agree to a
|
|
Binary file
|
|
@@ -6,5 +6,44 @@ export declare class ActionGroup extends AzureResource {
|
|
|
6
6
|
readonly props: model.ActionGroupProps;
|
|
7
7
|
resourceGroup: ResourceGroup;
|
|
8
8
|
id: string;
|
|
9
|
+
/**
|
|
10
|
+
* Manages an Azure Monitor Action Group, which is used to trigger actions or notifications based on alerts or conditions met within Azure Monitor.
|
|
11
|
+
*
|
|
12
|
+
* An Action Group in Azure Monitor defines a collection of individual actions that are triggered when the conditions of an associated alert rule are met. Actions can include sending emails, triggering Azure Functions, calling webhooks, and more. This class allows for configuring and managing these actions, making it essential for setting up comprehensive monitoring and response systems in Azure applications.
|
|
13
|
+
*
|
|
14
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
15
|
+
* @param id - The unique identifier for this instance of the Action Group.
|
|
16
|
+
* @param props - Configuration properties for the Action Group. These properties may include:
|
|
17
|
+
* - `name`: The name of the Action Group.
|
|
18
|
+
* - `resourceGroup`: The resource group under which the Action Group is created.
|
|
19
|
+
* - `shortName`: A shorter name for the Action Group used in notifications.
|
|
20
|
+
* - `enabled`: Specifies if the Action Group is active. Defaults to true.
|
|
21
|
+
* - `location`: The Azure region where the Action Group is hosted. Defaults to global.
|
|
22
|
+
* - `tags`: A dictionary of tags to apply to the Action Group for resource management.
|
|
23
|
+
* - Receivers: Configurations for various types of notifications (e.g., email, SMS, webhook).
|
|
24
|
+
*
|
|
25
|
+
* Example usage:
|
|
26
|
+
* ```typescript
|
|
27
|
+
* const actionGroup = new ActionGroup(this, 'myActionGroup', {
|
|
28
|
+
* name: 'criticalAlertsGroup',
|
|
29
|
+
* resourceGroup: myResourceGroup,
|
|
30
|
+
* shortName: 'Alerts',
|
|
31
|
+
* location: 'East US',
|
|
32
|
+
* emailReceivers: [{
|
|
33
|
+
* name: 'admin',
|
|
34
|
+
* emailAddress: 'admin@example.com'
|
|
35
|
+
* }],
|
|
36
|
+
* smsReceivers: [{
|
|
37
|
+
* name: 'adminSms',
|
|
38
|
+
* countryCode: '1',
|
|
39
|
+
* phoneNumber: '5551234567'
|
|
40
|
+
* }],
|
|
41
|
+
* tags: {
|
|
42
|
+
* environment: 'production'
|
|
43
|
+
* }
|
|
44
|
+
* });
|
|
45
|
+
* ```
|
|
46
|
+
* This setup creates an Action Group that sends email and SMS notifications when triggered by an alert.
|
|
47
|
+
*/
|
|
9
48
|
constructor(scope: Construct, id: string, props: model.ActionGroupProps);
|
|
10
49
|
}
|
|
@@ -6,6 +6,45 @@ const cdktf = require("cdktf");
|
|
|
6
6
|
const lib_1 = require("../../core-azure/lib");
|
|
7
7
|
const model = require("../model");
|
|
8
8
|
class ActionGroup extends lib_1.AzureResource {
|
|
9
|
+
/**
|
|
10
|
+
* Manages an Azure Monitor Action Group, which is used to trigger actions or notifications based on alerts or conditions met within Azure Monitor.
|
|
11
|
+
*
|
|
12
|
+
* An Action Group in Azure Monitor defines a collection of individual actions that are triggered when the conditions of an associated alert rule are met. Actions can include sending emails, triggering Azure Functions, calling webhooks, and more. This class allows for configuring and managing these actions, making it essential for setting up comprehensive monitoring and response systems in Azure applications.
|
|
13
|
+
*
|
|
14
|
+
* @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
|
|
15
|
+
* @param id - The unique identifier for this instance of the Action Group.
|
|
16
|
+
* @param props - Configuration properties for the Action Group. These properties may include:
|
|
17
|
+
* - `name`: The name of the Action Group.
|
|
18
|
+
* - `resourceGroup`: The resource group under which the Action Group is created.
|
|
19
|
+
* - `shortName`: A shorter name for the Action Group used in notifications.
|
|
20
|
+
* - `enabled`: Specifies if the Action Group is active. Defaults to true.
|
|
21
|
+
* - `location`: The Azure region where the Action Group is hosted. Defaults to global.
|
|
22
|
+
* - `tags`: A dictionary of tags to apply to the Action Group for resource management.
|
|
23
|
+
* - Receivers: Configurations for various types of notifications (e.g., email, SMS, webhook).
|
|
24
|
+
*
|
|
25
|
+
* Example usage:
|
|
26
|
+
* ```typescript
|
|
27
|
+
* const actionGroup = new ActionGroup(this, 'myActionGroup', {
|
|
28
|
+
* name: 'criticalAlertsGroup',
|
|
29
|
+
* resourceGroup: myResourceGroup,
|
|
30
|
+
* shortName: 'Alerts',
|
|
31
|
+
* location: 'East US',
|
|
32
|
+
* emailReceivers: [{
|
|
33
|
+
* name: 'admin',
|
|
34
|
+
* emailAddress: 'admin@example.com'
|
|
35
|
+
* }],
|
|
36
|
+
* smsReceivers: [{
|
|
37
|
+
* name: 'adminSms',
|
|
38
|
+
* countryCode: '1',
|
|
39
|
+
* phoneNumber: '5551234567'
|
|
40
|
+
* }],
|
|
41
|
+
* tags: {
|
|
42
|
+
* environment: 'production'
|
|
43
|
+
* }
|
|
44
|
+
* });
|
|
45
|
+
* ```
|
|
46
|
+
* This setup creates an Action Group that sends email and SMS notifications when triggered by an alert.
|
|
47
|
+
*/
|
|
9
48
|
constructor(scope, id, props) {
|
|
10
49
|
super(scope, id);
|
|
11
50
|
this.props = props;
|
|
@@ -43,4 +82,4 @@ class ActionGroup extends lib_1.AzureResource {
|
|
|
43
82
|
}
|
|
44
83
|
}
|
|
45
84
|
exports.ActionGroup = ActionGroup;
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"actiongroup.js","sourceRoot":"","sources":["../../../src/azure-actiongroup/lib/actiongroup.ts"],"names":[],"mappings":";;;AAAA,2FAAsF;AAEtF,+BAA+B;AAE/B,8CAAqD;AACrD,kCAAkC;AAElC,MAAa,WAAY,SAAQ,mBAAa;IAI5C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAsCG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA6B;QACrE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QAEjB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QAEzC;;WAEG;QACH,MAAM,QAAQ,GAAG;YACf,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI,IAAI;YAC9B,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,QAAQ;YACpC,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,EAAE;SACvB,CAAC;QAEF,uDAAuD;QACvD,MAAM,yBAAyB,GAAG,IAAI,yCAAkB,CACtD,IAAI,EACJ,aAAa,EACb;YACE,GAAG,QAAQ;YACX,IAAI,EAAE,KAAK,CAAC,IAAI;YAChB,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC,IAAI;YAC3C,SAAS,EAAE,KAAK,CAAC,SAAS;YAC1B,eAAe,EAAE,KAAK,CAAC,UAAU,CAC/B,KAAK,CAAC,4CAA4C,EAClD,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC;YAE9B,aAAa,EAAE,KAAK,CAAC,UAAU,CAC7B,KAAK,CAAC,0CAA0C,EAChD,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC;YAE5B,aAAa,EAAE,KAAK,CAAC,UAAU,CAC7B,KAAK,CAAC,0CAA0C,EAChD,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC;YAE5B,WAAW,EAAE,KAAK,CAAC,UAAU,CAC3B,KAAK,CAAC,wCAAwC,EAC9C,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC;YAE1B,eAAe,EAAE,KAAK,CAAC,UAAU,CAC/B,KAAK,CAAC,4CAA4C,EAClD,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC;YAE9B,gBAAgB,EAAE,KAAK,CAAC,UAAU,CAChC,KAAK,CAAC,6CAA6C,EACnD,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC;YAE/B,oBAAoB,EAAE,KAAK,CAAC,UAAU,CACpC,KAAK,CAAC,iDAAiD,EACvD,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC;YAEnC,gBAAgB,EAAE,KAAK,CAAC,UAAU,CAChC,KAAK,CAAC,6CAA6C,EACnD,IAAI,CACL,CAAC,IAAI,CAAC,KAAK,CAAC,iBAAiB,CAAC;SAChC,CACF,CAAC;QAEF,oBAAoB;QACpB,IAAI,CAAC,EAAE,GAAG,yBAAyB,CAAC,EAAE,CAAC;QAEvC,MAAM,iCAAiC,GAAG,IAAI,KAAK,CAAC,eAAe,CACjE,IAAI,EACJ,IAAI,EACJ;YACE,KAAK,EAAE,yBAAyB,CAAC,EAAE;SACpC,CACF,CAAC;QAEF,gIAAgI;QAChI,iCAAiC,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IAC5D,CAAC;CACF;AA3HD,kCA2HC","sourcesContent":["import { MonitorActionGroup } from \"@cdktf/provider-azurerm/lib/monitor-action-group\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { AzureResource } from \"../../core-azure/lib\";\nimport * as model from \"../model\";\n\nexport class ActionGroup extends AzureResource {\n  readonly props: model.ActionGroupProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  /**\n   * Manages an Azure Monitor Action Group, which is used to trigger actions or notifications based on alerts or conditions met within Azure Monitor.\n   *\n   * An Action Group in Azure Monitor defines a collection of individual actions that are triggered when the conditions of an associated alert rule are met. Actions can include sending emails, triggering Azure Functions, calling webhooks, and more. This class allows for configuring and managing these actions, making it essential for setting up comprehensive monitoring and response systems in Azure applications.\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 Action Group.\n   * @param props - Configuration properties for the Action Group. These properties may include:\n   *                - `name`: The name of the Action Group.\n   *                - `resourceGroup`: The resource group under which the Action Group is created.\n   *                - `shortName`: A shorter name for the Action Group used in notifications.\n   *                - `enabled`: Specifies if the Action Group is active. Defaults to true.\n   *                - `location`: The Azure region where the Action Group is hosted. Defaults to global.\n   *                - `tags`: A dictionary of tags to apply to the Action Group for resource management.\n   *                - Receivers: Configurations for various types of notifications (e.g., email, SMS, webhook).\n   *\n   * Example usage:\n   * ```typescript\n   * const actionGroup = new ActionGroup(this, 'myActionGroup', {\n   *   name: 'criticalAlertsGroup',\n   *   resourceGroup: myResourceGroup,\n   *   shortName: 'Alerts',\n   *   location: 'East US',\n   *   emailReceivers: [{\n   *     name: 'admin',\n   *     emailAddress: 'admin@example.com'\n   *   }],\n   *   smsReceivers: [{\n   *     name: 'adminSms',\n   *     countryCode: '1',\n   *     phoneNumber: '5551234567'\n   *   }],\n   *   tags: {\n   *     environment: 'production'\n   *   }\n   * });\n   * ```\n   * This setup creates an Action Group that sends email and SMS notifications when triggered by an alert.\n   */\n  constructor(scope: Construct, id: string, props: model.ActionGroupProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    /**\n     * Define default values.\n     */\n    const defaults = {\n      enabled: props.enabled ?? true,\n      location: props.location ?? \"global\",\n      tags: props.tags ?? {},\n    };\n\n    // Create the Action Group with the provided properties\n    const azurermMonitorActionGroup = new MonitorActionGroup(\n      this,\n      \"actiongroup\",\n      {\n        ...defaults,\n        name: props.name,\n        resourceGroupName: props.resourceGroup.name,\n        shortName: props.shortName,\n        armRoleReceiver: cdktf.listMapper(\n          model.monitorActionGroupArmRoleReceiverToTerraform,\n          true,\n        )(this.props.armRoleReceivers),\n\n        emailReceiver: cdktf.listMapper(\n          model.monitorActionGroupEmailReceiverToTerraform,\n          true,\n        )(this.props.emailReceivers),\n\n        voiceReceiver: cdktf.listMapper(\n          model.monitorActionGroupVoiceReceiverToTerraform,\n          true,\n        )(this.props.voiceReceivers),\n\n        smsReceiver: cdktf.listMapper(\n          model.monitorActionGroupSmsReceiverToTerraform,\n          true,\n        )(this.props.smsReceivers),\n\n        webhookReceiver: cdktf.listMapper(\n          model.monitorActionGroupWebhookReceiverToTerraform,\n          true,\n        )(this.props.webhookReceivers),\n\n        eventHubReceiver: cdktf.listMapper(\n          model.monitorActionGroupEventHubReceiverToTerraform,\n          true,\n        )(this.props.eventHubReceivers),\n\n        azureAppPushReceiver: cdktf.listMapper(\n          model.monitorActionGroupAzureAppPushReceiverToTerraform,\n          true,\n        )(this.props.azureAppPushReceivers),\n\n        logicAppReceiver: cdktf.listMapper(\n          model.monitorActionGroupLogicAppReceiverToTerraform,\n          true,\n        )(this.props.logicAppReceivers),\n      },\n    );\n\n    // Terraform Outputs\n    this.id = azurermMonitorActionGroup.id;\n\n    const cdktfTerraformOutputActionGroupId = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: azurermMonitorActionGroup.id,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputActionGroupId.overrideLogicalId(\"id\");\n  }\n}\n"]}
|
|
@@ -168,5 +168,81 @@ export interface IGatewayProps {
|
|
|
168
168
|
export declare class Gateway extends AzureResource {
|
|
169
169
|
resourceGroup: ResourceGroup;
|
|
170
170
|
id: string;
|
|
171
|
+
/**
|
|
172
|
+
* Constructs a new Azure Application Gateway.
|
|
173
|
+
*
|
|
174
|
+
* @param scope - The scope in which to define this construct.
|
|
175
|
+
* @param id - The ID of this construct.
|
|
176
|
+
* @param props - The properties for configuring the Azure Application Gateway. The properties include:
|
|
177
|
+
* - `name`: Required. Unique name for the Application Gateway within Azure.
|
|
178
|
+
* - `location`: Required. Azure Region for deployment.
|
|
179
|
+
* - `resourceGroup`: Required. Reference to the resource group for deployment.
|
|
180
|
+
* - `skuTier`: Required. SKU tier of the Application Gateway (e.g., Standard, WAF).
|
|
181
|
+
* - `skuSize`: Required. Size of the SKU for the Application Gateway.
|
|
182
|
+
* - `capacity`: Required. Capacity (instance count) of the Application Gateway.
|
|
183
|
+
* - `backendAddressPools`: Required. Backend address pools for the Application Gateway.
|
|
184
|
+
* - `backendHttpSettings`: Required. Backend HTTP settings for the Application Gateway.
|
|
185
|
+
* - `httpListeners`: Required. HTTP listeners for the Application Gateway.
|
|
186
|
+
* - `requestRoutingRules`: Required. Request routing rules for the Application Gateway.
|
|
187
|
+
* - `publicIpAddress`: Optional. Public IP address for the frontend.
|
|
188
|
+
* - `privateIpAddress`: Optional. Private IP address for the frontend.
|
|
189
|
+
* - `privateIpAddressAllocation`: Optional. Allocation method for the private IP (Static, Dynamic).
|
|
190
|
+
* - `frontendPorts`: Optional. Frontend ports for the Application Gateway.
|
|
191
|
+
* - `subnet`: Optional. Subnet for the Application Gateway.
|
|
192
|
+
* - `enableHttp2`: Optional. Flag to enable HTTP2.
|
|
193
|
+
* - `fipsEnabled`: Optional. Flag to enable FIPS-compliant algorithms.
|
|
194
|
+
* - `firewallPolicyId`: Optional. ID of the firewall policy.
|
|
195
|
+
* - `forceFirewallPolicyAssociation`: Optional. Flag to enforce association of the firewall policy.
|
|
196
|
+
* - `tags`: Optional. Tags for resource management.
|
|
197
|
+
* - Additional optional properties as described in `IGatewayProps` interface.
|
|
198
|
+
*
|
|
199
|
+
* Example usage:
|
|
200
|
+
* ```typescript
|
|
201
|
+
* new Gateway(this, 'appGateway1', {
|
|
202
|
+
* name: 'gatewayEast',
|
|
203
|
+
* resourceGroup: resourceGroup,
|
|
204
|
+
location: "eastus",
|
|
205
|
+
skuTier: "Standard_v2",
|
|
206
|
+
skuSize: "Standard_v2",
|
|
207
|
+
capacity: 2,
|
|
208
|
+
publicIpAddress: publicIp,
|
|
209
|
+
subnet: subnet,
|
|
210
|
+
backendAddressPools: [
|
|
211
|
+
{ name: "backend-address-pool-1" },
|
|
212
|
+
{
|
|
213
|
+
name: "backend-address-pool-2",
|
|
214
|
+
ipAddresses: ["10.1.0.4", "10.1.0.5", "10.1.0.6"],
|
|
215
|
+
},
|
|
216
|
+
],
|
|
217
|
+
httpListeners: [
|
|
218
|
+
{
|
|
219
|
+
name: "http-listener",
|
|
220
|
+
frontendPortName: "80",
|
|
221
|
+
frontendIpConfigurationName: "Public-frontend-ip-configuration",
|
|
222
|
+
protocol: "Http",
|
|
223
|
+
},
|
|
224
|
+
],
|
|
225
|
+
backendHttpSettings: [
|
|
226
|
+
{
|
|
227
|
+
name: "backend-http-setting",
|
|
228
|
+
port: 80,
|
|
229
|
+
protocol: "Http",
|
|
230
|
+
requestTimeout: 20,
|
|
231
|
+
cookieBasedAffinity: "Disabled",
|
|
232
|
+
},
|
|
233
|
+
],
|
|
234
|
+
requestRoutingRules: [
|
|
235
|
+
{
|
|
236
|
+
name: "request-routing-rule-1",
|
|
237
|
+
httpListenerName: "http-listener",
|
|
238
|
+
priority: 1,
|
|
239
|
+
backendAddressPoolName: "backend-address-pool-1",
|
|
240
|
+
backendHttpSettingsName: "backend-http-setting",
|
|
241
|
+
ruleType: "Basic",
|
|
242
|
+
},
|
|
243
|
+
],
|
|
244
|
+
* });
|
|
245
|
+
* ```
|
|
246
|
+
*/
|
|
171
247
|
constructor(scope: Construct, id: string, props: IGatewayProps);
|
|
172
248
|
}
|
|
@@ -10,6 +10,82 @@ const vnet = require("../../azure-virtualnetwork");
|
|
|
10
10
|
const core_azure_1 = require("../../core-azure");
|
|
11
11
|
// Define the class for Azure Application Gateway
|
|
12
12
|
class Gateway extends core_azure_1.AzureResource {
|
|
13
|
+
/**
|
|
14
|
+
* Constructs a new Azure Application Gateway.
|
|
15
|
+
*
|
|
16
|
+
* @param scope - The scope in which to define this construct.
|
|
17
|
+
* @param id - The ID of this construct.
|
|
18
|
+
* @param props - The properties for configuring the Azure Application Gateway. The properties include:
|
|
19
|
+
* - `name`: Required. Unique name for the Application Gateway within Azure.
|
|
20
|
+
* - `location`: Required. Azure Region for deployment.
|
|
21
|
+
* - `resourceGroup`: Required. Reference to the resource group for deployment.
|
|
22
|
+
* - `skuTier`: Required. SKU tier of the Application Gateway (e.g., Standard, WAF).
|
|
23
|
+
* - `skuSize`: Required. Size of the SKU for the Application Gateway.
|
|
24
|
+
* - `capacity`: Required. Capacity (instance count) of the Application Gateway.
|
|
25
|
+
* - `backendAddressPools`: Required. Backend address pools for the Application Gateway.
|
|
26
|
+
* - `backendHttpSettings`: Required. Backend HTTP settings for the Application Gateway.
|
|
27
|
+
* - `httpListeners`: Required. HTTP listeners for the Application Gateway.
|
|
28
|
+
* - `requestRoutingRules`: Required. Request routing rules for the Application Gateway.
|
|
29
|
+
* - `publicIpAddress`: Optional. Public IP address for the frontend.
|
|
30
|
+
* - `privateIpAddress`: Optional. Private IP address for the frontend.
|
|
31
|
+
* - `privateIpAddressAllocation`: Optional. Allocation method for the private IP (Static, Dynamic).
|
|
32
|
+
* - `frontendPorts`: Optional. Frontend ports for the Application Gateway.
|
|
33
|
+
* - `subnet`: Optional. Subnet for the Application Gateway.
|
|
34
|
+
* - `enableHttp2`: Optional. Flag to enable HTTP2.
|
|
35
|
+
* - `fipsEnabled`: Optional. Flag to enable FIPS-compliant algorithms.
|
|
36
|
+
* - `firewallPolicyId`: Optional. ID of the firewall policy.
|
|
37
|
+
* - `forceFirewallPolicyAssociation`: Optional. Flag to enforce association of the firewall policy.
|
|
38
|
+
* - `tags`: Optional. Tags for resource management.
|
|
39
|
+
* - Additional optional properties as described in `IGatewayProps` interface.
|
|
40
|
+
*
|
|
41
|
+
* Example usage:
|
|
42
|
+
* ```typescript
|
|
43
|
+
* new Gateway(this, 'appGateway1', {
|
|
44
|
+
* name: 'gatewayEast',
|
|
45
|
+
* resourceGroup: resourceGroup,
|
|
46
|
+
location: "eastus",
|
|
47
|
+
skuTier: "Standard_v2",
|
|
48
|
+
skuSize: "Standard_v2",
|
|
49
|
+
capacity: 2,
|
|
50
|
+
publicIpAddress: publicIp,
|
|
51
|
+
subnet: subnet,
|
|
52
|
+
backendAddressPools: [
|
|
53
|
+
{ name: "backend-address-pool-1" },
|
|
54
|
+
{
|
|
55
|
+
name: "backend-address-pool-2",
|
|
56
|
+
ipAddresses: ["10.1.0.4", "10.1.0.5", "10.1.0.6"],
|
|
57
|
+
},
|
|
58
|
+
],
|
|
59
|
+
httpListeners: [
|
|
60
|
+
{
|
|
61
|
+
name: "http-listener",
|
|
62
|
+
frontendPortName: "80",
|
|
63
|
+
frontendIpConfigurationName: "Public-frontend-ip-configuration",
|
|
64
|
+
protocol: "Http",
|
|
65
|
+
},
|
|
66
|
+
],
|
|
67
|
+
backendHttpSettings: [
|
|
68
|
+
{
|
|
69
|
+
name: "backend-http-setting",
|
|
70
|
+
port: 80,
|
|
71
|
+
protocol: "Http",
|
|
72
|
+
requestTimeout: 20,
|
|
73
|
+
cookieBasedAffinity: "Disabled",
|
|
74
|
+
},
|
|
75
|
+
],
|
|
76
|
+
requestRoutingRules: [
|
|
77
|
+
{
|
|
78
|
+
name: "request-routing-rule-1",
|
|
79
|
+
httpListenerName: "http-listener",
|
|
80
|
+
priority: 1,
|
|
81
|
+
backendAddressPoolName: "backend-address-pool-1",
|
|
82
|
+
backendHttpSettingsName: "backend-http-setting",
|
|
83
|
+
ruleType: "Basic",
|
|
84
|
+
},
|
|
85
|
+
],
|
|
86
|
+
* });
|
|
87
|
+
* ```
|
|
88
|
+
*/
|
|
13
89
|
constructor(scope, id, props) {
|
|
14
90
|
super(scope, id);
|
|
15
91
|
// Define the identity
|
|
@@ -119,5 +195,5 @@ class Gateway extends core_azure_1.AzureResource {
|
|
|
119
195
|
}
|
|
120
196
|
exports.Gateway = Gateway;
|
|
121
197
|
_a = JSII_RTTI_SYMBOL_1;
|
|
122
|
-
Gateway[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_applicationgateway.Gateway", version: "0.0.3-pre.
|
|
123
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gateway.js","sourceRoot":"","sources":["../../../src/azure-applicationgateway/lib/gateway.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationGateway } from \"@cdktf/provider-azurerm/lib/application-gateway\";\nimport * as azapgw from \"@cdktf/provider-azurerm/lib/application-gateway\";\nimport { KeyVault } from \"@cdktf/provider-azurerm/lib/key-vault\";\nimport { KeyVaultAccessPolicyA } from \"@cdktf/provider-azurerm/lib/key-vault-access-policy\";\nimport { PublicIp } from \"@cdktf/provider-azurerm/lib/public-ip\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Subnet } from \"@cdktf/provider-azurerm/lib/subnet\";\nimport { UserAssignedIdentity } from \"@cdktf/provider-azurerm/lib/user-assigned-identity\";\nimport { Construct } from \"constructs\";\nimport * as vnet from \"../../azure-virtualnetwork\";\nimport { AzureResource } from \"../../core-azure\";\n\n// Define the interface for Application Gateway properties\nexport interface IGatewayProps {\n  /**\n   * Optional public IP address for the frontend of the Application Gateway.\n   */\n  publicIpAddress?: PublicIp;\n\n  /**\n   * Optional private IP address for the frontend of the Application Gateway.\n   */\n  privateIpAddress?: string;\n\n  /**\n   * Allocation method for the private IP address (e.g., Static, Dynamic).\n   */\n  privateIpAddressAllocation?: string;\n\n  /**\n   * The name of the Application Gateway.\n   */\n  readonly name: string;\n\n  /**\n   * The location where the Application Gateway will be deployed (e.g., region).\n   */\n  readonly location: string;\n\n  /**\n   * The resource group under which the Application Gateway will be deployed.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The SKU tier of the Application Gateway (e.g., Standard, WAF).\n   */\n  readonly skuTier: string;\n\n  /**\n   * The size of the SKU for the Application Gateway.\n   */\n  readonly skuSize: string;\n\n  /**\n   * The capacity (instance count) of the Application Gateway.\n   */\n  readonly capacity: number;\n\n  /**\n   * The backend address pools for the Application Gateway.\n   */\n  readonly backendAddressPools: azapgw.ApplicationGatewayBackendAddressPool[];\n\n  /**\n   * The backend HTTP settings for the Application Gateway.\n   */\n  readonly backendHttpSettings: azapgw.ApplicationGatewayBackendHttpSettings[];\n\n  /**\n   * Optional frontend ports for the Application Gateway.\n   */\n  readonly frontendPorts?: azapgw.ApplicationGatewayFrontendPort[];\n\n  /**\n   * The HTTP listeners for the Application Gateway.\n   */\n  readonly httpListeners: azapgw.ApplicationGatewayHttpListener[];\n\n  /**\n   * The request routing rules for the Application Gateway.\n   */\n  readonly requestRoutingRules: azapgw.ApplicationGatewayRequestRoutingRule[];\n\n  /**\n   * Optional subnet for the Application Gateway.\n   */\n  readonly subnet?: Subnet;\n\n  /**\n   * Optional tenant ID for use with Key Vault, if applicable.\n   */\n  readonly tenantId?: string;\n\n  /**\n   * Flag to enable HTTP2.\n   */\n  readonly enableHttp2?: boolean;\n\n  /**\n   * Flag to enable FIPS-compliant algorithms.\n   */\n  readonly fipsEnabled?: boolean;\n\n  /**\n   * Optional ID of the firewall policy.\n   */\n  readonly firewallPolicyId?: string;\n\n  /**\n   * Flag to enforce association of the firewall policy.\n   */\n  readonly forceFirewallPolicyAssociation?: boolean;\n\n  /**\n   * Optional tags for the Application Gateway resource.\n   */\n  readonly tags?: { [key: string]: string };\n\n  /**\n   * Optional availability zones for the Application Gateway.\n   */\n  readonly zones?: string[];\n\n  /**\n   * Optional Key Vault resource for storing SSL certificates.\n   */\n  readonly keyVault?: KeyVault;\n\n  /**\n   * Optional authentication certificates for mutual authentication.\n   */\n  readonly authenticationCertificate?: azapgw.ApplicationGatewayAuthenticationCertificate[];\n\n  /**\n   * Optional autoscale configuration for dynamically adjusting the capacity of the Application Gateway.\n   */\n  readonly autoscaleConfiguration?: azapgw.ApplicationGatewayAutoscaleConfiguration;\n\n  /**\n   * Optional custom error configurations to specify custom error pages.\n   */\n  readonly customErrorConfiguration?: azapgw.ApplicationGatewayCustomErrorConfiguration[];\n\n  /**\n   * Optional identity for the Application Gateway, used for accessing other Azure resources.\n   */\n  readonly identity?: azapgw.ApplicationGatewayIdentity;\n\n  /**\n   * Optional configurations for enabling Private Link on the Application Gateway.\n   */\n  readonly privateLinkConfiguration?: azapgw.ApplicationGatewayPrivateLinkConfiguration[];\n\n  /**\n   * Optional probes for health checks of the backend HTTP settings.\n   */\n  readonly probe?: azapgw.ApplicationGatewayProbe[];\n\n  /**\n   * Optional configurations for redirect rules.\n   */\n  readonly redirectConfiguration?: azapgw.ApplicationGatewayRedirectConfiguration[];\n\n  /**\n   * Optional rewrite rule sets for modifying HTTP request and response headers and bodies.\n   */\n  readonly rewriteRuleSet?: azapgw.ApplicationGatewayRewriteRuleSet[];\n\n  /**\n   * Optional SSL certificates for enabling HTTPS on the Application Gateway.\n   */\n  readonly sslCertificate?: azapgw.ApplicationGatewaySslCertificate[];\n\n  /**\n   * Optional SSL policy configurations, defining the protocol and cipher suites used.\n   */\n  readonly sslPolicy?: azapgw.ApplicationGatewaySslPolicy;\n\n  /**\n   * Optional SSL profiles for managing SSL termination and policy settings.\n   */\n  readonly sslProfile?: azapgw.ApplicationGatewaySslProfile[];\n\n  /**\n   * Optional timeout settings for the Application Gateway resources.\n   */\n  readonly timeouts?: azapgw.ApplicationGatewayTimeouts;\n\n  /**\n   * Optional trusted client certificates for mutual authentication.\n   */\n  readonly trustedClientCertificate?: azapgw.ApplicationGatewayTrustedClientCertificate[];\n\n  /**\n   * Optional trusted root certificates for backend authentication.\n   */\n  readonly trustedRootCertificate?: azapgw.ApplicationGatewayTrustedRootCertificate[];\n\n  /**\n   * Optional URL path map for routing based on URL paths.\n   */\n  readonly urlPathMap?: azapgw.ApplicationGatewayUrlPathMap[];\n\n  /**\n   * Optional Web Application Firewall (WAF) configuration to provide enhanced security.\n   */\n  readonly wafConfiguration?: azapgw.ApplicationGatewayWafConfiguration;\n}\n\n// Define the class for Azure Application Gateway\nexport class Gateway extends AzureResource {\n  public resourceGroup: ResourceGroup;\n  public id: string;\n\n  constructor(scope: Construct, id: string, props: IGatewayProps) {\n    super(scope, id);\n\n    // Define the identity\n    let identity;\n\n    // Check if Azure Key Vault is used and no identity is provided\n    if (props.keyVault && !props.identity) {\n      // Create a managed identity and add it to identityIds\n      const managedIdentity = new UserAssignedIdentity(\n        this,\n        \"ManagedIdentity\",\n        {\n          name: `mi-${props.name}`,\n          resourceGroupName: props.resourceGroup.name,\n          location: props.location,\n        },\n      );\n\n      identity = {\n        identityIds: [managedIdentity.id],\n        type: \"UserAssigned\",\n      };\n\n      new KeyVaultAccessPolicyA(this, \"policy\", {\n        keyVaultId: props.keyVault.id,\n        tenantId: props.tenantId || \"\",\n        objectId: managedIdentity.principalId,\n        secretPermissions: [\"Get\", \"List\"],\n      });\n    }\n\n    const defaults = {\n      subnetId:\n        props.subnet?.id ||\n        new vnet.Network(this, \"vnet\", {\n          resourceGroup: props.resourceGroup,\n        }).subnets.default.id,\n      identity: props.identity || identity,\n    };\n\n    // WAF configuration\n    let wafConfiguration = props.wafConfiguration\n      ? {\n          enabled: props.wafConfiguration.enabled,\n          firewallMode: props.wafConfiguration.firewallMode || \"Detection\",\n          ruleSetVersion: props.wafConfiguration.ruleSetVersion || \"3.0\",\n        }\n      : undefined;\n\n    // Dynamically create frontend IP configurations\n    let frontendIpConfigs = [];\n\n    // Public IP configuration\n    if (props.publicIpAddress) {\n      frontendIpConfigs.push({\n        name: \"Public-frontend-ip-configuration\",\n        publicIpAddressId: props.publicIpAddress.id,\n      });\n    }\n\n    // Private IP configuration\n    if (props.privateIpAddress || props.privateIpAddressAllocation) {\n      frontendIpConfigs.push({\n        name: \"Private-frontend-ip-configuration\",\n        subnetId: defaults.subnetId,\n        privateIpAddress: props.privateIpAddress,\n        privateIpAddressAllocation: props.privateIpAddressAllocation,\n      });\n    }\n\n    // Set default frontend ports if not provided\n    const defaultFrontendPorts = [\n      { name: \"80\", port: 80 },\n      { name: \"443\", port: 443 },\n    ];\n\n    const frontendPorts =\n      props.frontendPorts && props.frontendPorts.length > 0\n        ? props.frontendPorts\n        : defaultFrontendPorts;\n\n    // Create the Application Gateway\n    const apgw = new ApplicationGateway(this, \"ApplicationGateway\", {\n      name: props.name,\n      resourceGroupName: props.resourceGroup.name,\n      location: props.location,\n      sslCertificate: props.sslCertificate,\n      sslPolicy: props.sslPolicy,\n      sslProfile: props.sslProfile,\n      authenticationCertificate: props.authenticationCertificate,\n      autoscaleConfiguration: props.autoscaleConfiguration,\n      customErrorConfiguration: props.customErrorConfiguration,\n      redirectConfiguration: props.redirectConfiguration,\n      rewriteRuleSet: props.rewriteRuleSet,\n      privateLinkConfiguration: props.privateLinkConfiguration,\n      wafConfiguration: wafConfiguration,\n      sku: {\n        name: props.skuSize,\n        tier: props.skuTier,\n        capacity: props.capacity,\n      },\n      gatewayIpConfiguration: [\n        {\n          subnetId: defaults.subnetId,\n          name: `${props.name}-configuration`,\n        },\n      ],\n      frontendPort: frontendPorts,\n      frontendIpConfiguration: frontendIpConfigs,\n      backendAddressPool: props.backendAddressPools,\n      backendHttpSettings: props.backendHttpSettings,\n      httpListener: props.httpListeners,\n      urlPathMap: props.urlPathMap,\n      trustedRootCertificate: props.trustedRootCertificate,\n      requestRoutingRule: props.requestRoutingRules,\n      probe: props.probe,\n      identity: defaults.identity,\n      zones: props.zones,\n      tags: props.tags,\n    });\n\n    this.id = apgw.id;\n    this.resourceGroup = props.resourceGroup;\n  }\n}\n"]}
|
|
198
|
+
Gateway[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_applicationgateway.Gateway", version: "0.0.3-pre.7" };
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gateway.js","sourceRoot":"","sources":["../../../src/azure-applicationgateway/lib/gateway.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApplicationGateway } from \"@cdktf/provider-azurerm/lib/application-gateway\";\nimport * as azapgw from \"@cdktf/provider-azurerm/lib/application-gateway\";\nimport { KeyVault } from \"@cdktf/provider-azurerm/lib/key-vault\";\nimport { KeyVaultAccessPolicyA } from \"@cdktf/provider-azurerm/lib/key-vault-access-policy\";\nimport { PublicIp } from \"@cdktf/provider-azurerm/lib/public-ip\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Subnet } from \"@cdktf/provider-azurerm/lib/subnet\";\nimport { UserAssignedIdentity } from \"@cdktf/provider-azurerm/lib/user-assigned-identity\";\nimport { Construct } from \"constructs\";\nimport * as vnet from \"../../azure-virtualnetwork\";\nimport { AzureResource } from \"../../core-azure\";\n\n// Define the interface for Application Gateway properties\nexport interface IGatewayProps {\n  /**\n   * Optional public IP address for the frontend of the Application Gateway.\n   */\n  publicIpAddress?: PublicIp;\n\n  /**\n   * Optional private IP address for the frontend of the Application Gateway.\n   */\n  privateIpAddress?: string;\n\n  /**\n   * Allocation method for the private IP address (e.g., Static, Dynamic).\n   */\n  privateIpAddressAllocation?: string;\n\n  /**\n   * The name of the Application Gateway.\n   */\n  readonly name: string;\n\n  /**\n   * The location where the Application Gateway will be deployed (e.g., region).\n   */\n  readonly location: string;\n\n  /**\n   * The resource group under which the Application Gateway will be deployed.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The SKU tier of the Application Gateway (e.g., Standard, WAF).\n   */\n  readonly skuTier: string;\n\n  /**\n   * The size of the SKU for the Application Gateway.\n   */\n  readonly skuSize: string;\n\n  /**\n   * The capacity (instance count) of the Application Gateway.\n   */\n  readonly capacity: number;\n\n  /**\n   * The backend address pools for the Application Gateway.\n   */\n  readonly backendAddressPools: azapgw.ApplicationGatewayBackendAddressPool[];\n\n  /**\n   * The backend HTTP settings for the Application Gateway.\n   */\n  readonly backendHttpSettings: azapgw.ApplicationGatewayBackendHttpSettings[];\n\n  /**\n   * Optional frontend ports for the Application Gateway.\n   */\n  readonly frontendPorts?: azapgw.ApplicationGatewayFrontendPort[];\n\n  /**\n   * The HTTP listeners for the Application Gateway.\n   */\n  readonly httpListeners: azapgw.ApplicationGatewayHttpListener[];\n\n  /**\n   * The request routing rules for the Application Gateway.\n   */\n  readonly requestRoutingRules: azapgw.ApplicationGatewayRequestRoutingRule[];\n\n  /**\n   * Optional subnet for the Application Gateway.\n   */\n  readonly subnet?: Subnet;\n\n  /**\n   * Optional tenant ID for use with Key Vault, if applicable.\n   */\n  readonly tenantId?: string;\n\n  /**\n   * Flag to enable HTTP2.\n   */\n  readonly enableHttp2?: boolean;\n\n  /**\n   * Flag to enable FIPS-compliant algorithms.\n   */\n  readonly fipsEnabled?: boolean;\n\n  /**\n   * Optional ID of the firewall policy.\n   */\n  readonly firewallPolicyId?: string;\n\n  /**\n   * Flag to enforce association of the firewall policy.\n   */\n  readonly forceFirewallPolicyAssociation?: boolean;\n\n  /**\n   * Optional tags for the Application Gateway resource.\n   */\n  readonly tags?: { [key: string]: string };\n\n  /**\n   * Optional availability zones for the Application Gateway.\n   */\n  readonly zones?: string[];\n\n  /**\n   * Optional Key Vault resource for storing SSL certificates.\n   */\n  readonly keyVault?: KeyVault;\n\n  /**\n   * Optional authentication certificates for mutual authentication.\n   */\n  readonly authenticationCertificate?: azapgw.ApplicationGatewayAuthenticationCertificate[];\n\n  /**\n   * Optional autoscale configuration for dynamically adjusting the capacity of the Application Gateway.\n   */\n  readonly autoscaleConfiguration?: azapgw.ApplicationGatewayAutoscaleConfiguration;\n\n  /**\n   * Optional custom error configurations to specify custom error pages.\n   */\n  readonly customErrorConfiguration?: azapgw.ApplicationGatewayCustomErrorConfiguration[];\n\n  /**\n   * Optional identity for the Application Gateway, used for accessing other Azure resources.\n   */\n  readonly identity?: azapgw.ApplicationGatewayIdentity;\n\n  /**\n   * Optional configurations for enabling Private Link on the Application Gateway.\n   */\n  readonly privateLinkConfiguration?: azapgw.ApplicationGatewayPrivateLinkConfiguration[];\n\n  /**\n   * Optional probes for health checks of the backend HTTP settings.\n   */\n  readonly probe?: azapgw.ApplicationGatewayProbe[];\n\n  /**\n   * Optional configurations for redirect rules.\n   */\n  readonly redirectConfiguration?: azapgw.ApplicationGatewayRedirectConfiguration[];\n\n  /**\n   * Optional rewrite rule sets for modifying HTTP request and response headers and bodies.\n   */\n  readonly rewriteRuleSet?: azapgw.ApplicationGatewayRewriteRuleSet[];\n\n  /**\n   * Optional SSL certificates for enabling HTTPS on the Application Gateway.\n   */\n  readonly sslCertificate?: azapgw.ApplicationGatewaySslCertificate[];\n\n  /**\n   * Optional SSL policy configurations, defining the protocol and cipher suites used.\n   */\n  readonly sslPolicy?: azapgw.ApplicationGatewaySslPolicy;\n\n  /**\n   * Optional SSL profiles for managing SSL termination and policy settings.\n   */\n  readonly sslProfile?: azapgw.ApplicationGatewaySslProfile[];\n\n  /**\n   * Optional timeout settings for the Application Gateway resources.\n   */\n  readonly timeouts?: azapgw.ApplicationGatewayTimeouts;\n\n  /**\n   * Optional trusted client certificates for mutual authentication.\n   */\n  readonly trustedClientCertificate?: azapgw.ApplicationGatewayTrustedClientCertificate[];\n\n  /**\n   * Optional trusted root certificates for backend authentication.\n   */\n  readonly trustedRootCertificate?: azapgw.ApplicationGatewayTrustedRootCertificate[];\n\n  /**\n   * Optional URL path map for routing based on URL paths.\n   */\n  readonly urlPathMap?: azapgw.ApplicationGatewayUrlPathMap[];\n\n  /**\n   * Optional Web Application Firewall (WAF) configuration to provide enhanced security.\n   */\n  readonly wafConfiguration?: azapgw.ApplicationGatewayWafConfiguration;\n}\n\n// Define the class for Azure Application Gateway\nexport class Gateway extends AzureResource {\n  public resourceGroup: ResourceGroup;\n  public id: string;\n\n  /**\n   * Constructs a new Azure Application Gateway.\n   *\n   * @param scope - The scope in which to define this construct.\n   * @param id - The ID of this construct.\n   * @param props - The properties for configuring the Azure Application Gateway. The properties include:\n   *                - `name`: Required. Unique name for the Application Gateway within Azure.\n   *                - `location`: Required. Azure Region for deployment.\n   *                - `resourceGroup`: Required. Reference to the resource group for deployment.\n   *                - `skuTier`: Required. SKU tier of the Application Gateway (e.g., Standard, WAF).\n   *                - `skuSize`: Required. Size of the SKU for the Application Gateway.\n   *                - `capacity`: Required. Capacity (instance count) of the Application Gateway.\n   *                - `backendAddressPools`: Required. Backend address pools for the Application Gateway.\n   *                - `backendHttpSettings`: Required. Backend HTTP settings for the Application Gateway.\n   *                - `httpListeners`: Required. HTTP listeners for the Application Gateway.\n   *                - `requestRoutingRules`: Required. Request routing rules for the Application Gateway.\n   *                - `publicIpAddress`: Optional. Public IP address for the frontend.\n   *                - `privateIpAddress`: Optional. Private IP address for the frontend.\n   *                - `privateIpAddressAllocation`: Optional. Allocation method for the private IP (Static, Dynamic).\n   *                - `frontendPorts`: Optional. Frontend ports for the Application Gateway.\n   *                - `subnet`: Optional. Subnet for the Application Gateway.\n   *                - `enableHttp2`: Optional. Flag to enable HTTP2.\n   *                - `fipsEnabled`: Optional. Flag to enable FIPS-compliant algorithms.\n   *                - `firewallPolicyId`: Optional. ID of the firewall policy.\n   *                - `forceFirewallPolicyAssociation`: Optional. Flag to enforce association of the firewall policy.\n   *                - `tags`: Optional. Tags for resource management.\n   *                - Additional optional properties as described in `IGatewayProps` interface.\n   *\n   * Example usage:\n   * ```typescript\n   * new Gateway(this, 'appGateway1', {\n   *   name: 'gatewayEast',\n   *   resourceGroup: resourceGroup,\n      location: \"eastus\",\n      skuTier: \"Standard_v2\",\n      skuSize: \"Standard_v2\",\n      capacity: 2,\n      publicIpAddress: publicIp,\n      subnet: subnet,\n      backendAddressPools: [\n        { name: \"backend-address-pool-1\" },\n        {\n          name: \"backend-address-pool-2\",\n          ipAddresses: [\"10.1.0.4\", \"10.1.0.5\", \"10.1.0.6\"],\n        },\n      ],\n      httpListeners: [\n        {\n          name: \"http-listener\",\n          frontendPortName: \"80\",\n          frontendIpConfigurationName: \"Public-frontend-ip-configuration\",\n          protocol: \"Http\",\n        },\n      ],\n      backendHttpSettings: [\n        {\n          name: \"backend-http-setting\",\n          port: 80,\n          protocol: \"Http\",\n          requestTimeout: 20,\n          cookieBasedAffinity: \"Disabled\",\n        },\n      ],\n      requestRoutingRules: [\n        {\n          name: \"request-routing-rule-1\",\n          httpListenerName: \"http-listener\",\n          priority: 1,\n          backendAddressPoolName: \"backend-address-pool-1\",\n          backendHttpSettingsName: \"backend-http-setting\",\n          ruleType: \"Basic\",\n        },\n      ],\n   * });\n   * ```\n   */\n\n  constructor(scope: Construct, id: string, props: IGatewayProps) {\n    super(scope, id);\n\n    // Define the identity\n    let identity;\n\n    // Check if Azure Key Vault is used and no identity is provided\n    if (props.keyVault && !props.identity) {\n      // Create a managed identity and add it to identityIds\n      const managedIdentity = new UserAssignedIdentity(\n        this,\n        \"ManagedIdentity\",\n        {\n          name: `mi-${props.name}`,\n          resourceGroupName: props.resourceGroup.name,\n          location: props.location,\n        },\n      );\n\n      identity = {\n        identityIds: [managedIdentity.id],\n        type: \"UserAssigned\",\n      };\n\n      new KeyVaultAccessPolicyA(this, \"policy\", {\n        keyVaultId: props.keyVault.id,\n        tenantId: props.tenantId || \"\",\n        objectId: managedIdentity.principalId,\n        secretPermissions: [\"Get\", \"List\"],\n      });\n    }\n\n    const defaults = {\n      subnetId:\n        props.subnet?.id ||\n        new vnet.Network(this, \"vnet\", {\n          resourceGroup: props.resourceGroup,\n        }).subnets.default.id,\n      identity: props.identity || identity,\n    };\n\n    // WAF configuration\n    let wafConfiguration = props.wafConfiguration\n      ? {\n          enabled: props.wafConfiguration.enabled,\n          firewallMode: props.wafConfiguration.firewallMode || \"Detection\",\n          ruleSetVersion: props.wafConfiguration.ruleSetVersion || \"3.0\",\n        }\n      : undefined;\n\n    // Dynamically create frontend IP configurations\n    let frontendIpConfigs = [];\n\n    // Public IP configuration\n    if (props.publicIpAddress) {\n      frontendIpConfigs.push({\n        name: \"Public-frontend-ip-configuration\",\n        publicIpAddressId: props.publicIpAddress.id,\n      });\n    }\n\n    // Private IP configuration\n    if (props.privateIpAddress || props.privateIpAddressAllocation) {\n      frontendIpConfigs.push({\n        name: \"Private-frontend-ip-configuration\",\n        subnetId: defaults.subnetId,\n        privateIpAddress: props.privateIpAddress,\n        privateIpAddressAllocation: props.privateIpAddressAllocation,\n      });\n    }\n\n    // Set default frontend ports if not provided\n    const defaultFrontendPorts = [\n      { name: \"80\", port: 80 },\n      { name: \"443\", port: 443 },\n    ];\n\n    const frontendPorts =\n      props.frontendPorts && props.frontendPorts.length > 0\n        ? props.frontendPorts\n        : defaultFrontendPorts;\n\n    // Create the Application Gateway\n    const apgw = new ApplicationGateway(this, \"ApplicationGateway\", {\n      name: props.name,\n      resourceGroupName: props.resourceGroup.name,\n      location: props.location,\n      sslCertificate: props.sslCertificate,\n      sslPolicy: props.sslPolicy,\n      sslProfile: props.sslProfile,\n      authenticationCertificate: props.authenticationCertificate,\n      autoscaleConfiguration: props.autoscaleConfiguration,\n      customErrorConfiguration: props.customErrorConfiguration,\n      redirectConfiguration: props.redirectConfiguration,\n      rewriteRuleSet: props.rewriteRuleSet,\n      privateLinkConfiguration: props.privateLinkConfiguration,\n      wafConfiguration: wafConfiguration,\n      sku: {\n        name: props.skuSize,\n        tier: props.skuTier,\n        capacity: props.capacity,\n      },\n      gatewayIpConfiguration: [\n        {\n          subnetId: defaults.subnetId,\n          name: `${props.name}-configuration`,\n        },\n      ],\n      frontendPort: frontendPorts,\n      frontendIpConfiguration: frontendIpConfigs,\n      backendAddressPool: props.backendAddressPools,\n      backendHttpSettings: props.backendHttpSettings,\n      httpListener: props.httpListeners,\n      urlPathMap: props.urlPathMap,\n      trustedRootCertificate: props.trustedRootCertificate,\n      requestRoutingRule: props.requestRoutingRules,\n      probe: props.probe,\n      identity: defaults.identity,\n      zones: props.zones,\n      tags: props.tags,\n    });\n\n    this.id = apgw.id;\n    this.resourceGroup = props.resourceGroup;\n  }\n}\n"]}
|
|
@@ -54,7 +54,57 @@ export declare class AppInsights extends AzureResource {
|
|
|
54
54
|
resourceGroup: ResourceGroup;
|
|
55
55
|
id: string;
|
|
56
56
|
private readonly instrumentationKey;
|
|
57
|
+
/**
|
|
58
|
+
* Constructs a new Azure Application Insights resource.
|
|
59
|
+
*
|
|
60
|
+
* @param scope - The scope in which to define this construct.
|
|
61
|
+
* @param id - The ID of this construct.
|
|
62
|
+
* @param props - The properties for configuring the Azure Application Insights. The properties include:
|
|
63
|
+
* - `name`: Required. Unique name for the Application Insights resource within Azure.
|
|
64
|
+
* - `location`: Required. Azure Region for deployment.
|
|
65
|
+
* - `resourceGroup`: Required. Reference to the Azure Resource Group for deployment.
|
|
66
|
+
* - `retentionInDays`: Optional. Number of days to retain data. Default is 90 days.
|
|
67
|
+
* - `tags`: Optional. Tags for resource management.
|
|
68
|
+
* - `applicationType`: Required. The type of application (e.g., web, other).
|
|
69
|
+
* - `dailyDataCapInGb`: Optional. Daily data cap in gigabytes.
|
|
70
|
+
* - `dailyDataCapNotificationDisabled`: Optional. Flag to disable notifications when the daily data cap is reached.
|
|
71
|
+
* - `workspaceId`: Optional. ID of the Log Analytics Workspace to associate with Application Insights. If not provided, a new workspace is created automatically.
|
|
72
|
+
*
|
|
73
|
+
* Example usage:
|
|
74
|
+
* ```typescript
|
|
75
|
+
* new AppInsights(this, 'myAppInsights', {
|
|
76
|
+
* name: 'myAppInsightsResource',
|
|
77
|
+
* location: 'West US',
|
|
78
|
+
* resourceGroup: resourceGroup,
|
|
79
|
+
* retentionInDays: 120,
|
|
80
|
+
* tags: {
|
|
81
|
+
* "environment": "production"
|
|
82
|
+
* },
|
|
83
|
+
* applicationType: 'web',
|
|
84
|
+
* dailyDataCapInGb: 10,
|
|
85
|
+
* dailyDataCapNotificationDisabled: true,
|
|
86
|
+
* workspaceId: 'existing-workspace-id'
|
|
87
|
+
* });
|
|
88
|
+
* ```
|
|
89
|
+
*/
|
|
57
90
|
constructor(scope: Construct, id: string, props: AppInsightsProps);
|
|
91
|
+
/**
|
|
92
|
+
* Saves the Application Insights instrumentation key to an Azure Key Vault.
|
|
93
|
+
*
|
|
94
|
+
* This method creates a new secret in the specified Azure Key Vault with the
|
|
95
|
+
* instrumentation key of the Application Insights resource. This enables secure storage
|
|
96
|
+
* and management of the instrumentation key, facilitating secure access across various
|
|
97
|
+
* Azure services.
|
|
98
|
+
*
|
|
99
|
+
* @param keyVaultId - The unique identifier of the Azure Key Vault where the secret will be stored.
|
|
100
|
+
* @param keyVaultSecretName - The name of the secret within the Key Vault. Defaults to 'instrumentation-key'.
|
|
101
|
+
* This name can be used to retrieve the secret in client applications.
|
|
102
|
+
*
|
|
103
|
+
* Example usage:
|
|
104
|
+
* ```typescript
|
|
105
|
+
* appInsightsInstance.saveIKeyToKeyVault('my-key-vault-id');
|
|
106
|
+
* ```
|
|
107
|
+
*/
|
|
58
108
|
saveIKeyToKeyVault(keyVaultId: string, keyVaultSecretName?: string): void;
|
|
59
109
|
private setupLogAnalytics;
|
|
60
110
|
}
|