@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
@@ -11,11 +11,57 @@ const network_1 = require("../../azure-virtualnetwork/lib/network");
11
11
  const lib_1 = require("../../core-azure/lib");
12
12
  class LinuxCluster extends lib_1.AzureResource {
13
13
  /**
14
- * Constructs a new instance of the AzureLinuxVirtualMachine class.
14
+ * Represents a Linux Virtual Machine Scale Set (VMSS) within Microsoft Azure.
15
15
  *
16
- * @param scope - The scope in which this construct is defined.
17
- * @param id - The ID of this construct.
18
- * @param props - The properties for defining a Linux Virtual Machine.
16
+ * This class is designed to provision and manage a scale set of Linux virtual machines, providing capabilities such as
17
+ * auto-scaling, high availability, and simplified management. It supports detailed configurations like VM size, operating
18
+ * system image, network settings, and administrative credentials. Additional functionalities include custom data scripts,
19
+ * SSH configurations, and optional features like managed identity and boot diagnostics.
20
+ *
21
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.
22
+ * @param id - The unique identifier for this instance of the Linux cluster, used within the scope for reference.
23
+ * @param props - Configuration properties for the Linux VM Scale Set, derived from the LinuxClusterProps interface. These include:
24
+ * - `location`: The geographic location where the scale set will be hosted (e.g., "eastus").
25
+ * - `name`: The name of the scale set, which must be unique within the resource group.
26
+ * - `resourceGroup`: The ResourceGroup within which the scale set will be created.
27
+ * - `sku`: The size specification of the VMs (e.g., "Standard_B2s").
28
+ * - `adminUsername`: The administrator username for the VMs.
29
+ * - `adminPassword`: The administrator password for the VMs.
30
+ * - `adminSshKey`: SSH keys for secure access to the VMs.
31
+ * - `zones`: The availability zones for deploying the VMs.
32
+ * - `identity`: Managed identity settings for accessing other Azure services.
33
+ * - `sourceImageReference`: A reference to the specific Linux image to be used for the VMs.
34
+ * - `sourceImageId`: The identifier for a custom image to use for the VMs.
35
+ * - `tags`: Key-value pairs for resource tagging.
36
+ * - `osDisk`: Configuration for the VMs' operating system disks.
37
+ * - `subnet`: Specifies the subnet within which the VMs will be placed.
38
+ * - `publicIPAddress`: Method used to allocate public IP addresses to the VMs.
39
+ * - `customData`: Scripts or commands passed to the VMs at startup.
40
+ * - `instances`: The number of VM instances in the scale set.
41
+ * - `upgradePolicyMode`: The upgrade policy mode for the VMSS.
42
+ * - `overprovision`: Specifies if the VMSS should be overprovisioned to maintain capacity during updates.
43
+ * - `scaleInPolicy`: The scale-in policy for the VMSS.
44
+ * - `bootDiagnosticsStorageURI`: URI for storage where VMSS boot diagnostics are collected.
45
+ * - `enableSshAzureADLogin`: Option to enable Azure AD login for SSH on the VMs.
46
+ *
47
+ * Example usage:
48
+ * ```typescript
49
+ * const linuxCluster = new LinuxCluster(this, 'MyLinuxCluster', {
50
+ * resourceGroup: myResourceGroup,
51
+ * name: 'myCluster',
52
+ * sku: 'Standard_DS1_v2',
53
+ * adminUsername: 'adminuser',
54
+ * adminSshKey: [{ publicKey: 'ssh-rsa AAAAB...' }],
55
+ * sourceImageReference: { publisher: 'Canonical', offer: 'UbuntuServer', sku: '18.04-LTS', version: 'latest' },
56
+ * osDisk: { caching: 'ReadWrite', storageAccountType: 'Standard_LRS' },
57
+ * subnet: mySubnet,
58
+ * instances: 3,
59
+ * tags: { environment: 'production' }
60
+ * });
61
+ * ```
62
+ * This class initializes a Linux VM Scale Set with the specified configurations, handling details like VM creation,
63
+ * scaling policies, network setup, OS installation, and security settings, providing a robust and scalable infrastructure
64
+ * for hosting cloud-based Linux applications.
19
65
  */
20
66
  constructor(scope, id, props) {
21
67
  super(scope, id);
@@ -88,14 +134,58 @@ class LinuxCluster extends lib_1.AzureResource {
88
134
  }
89
135
  exports.LinuxCluster = LinuxCluster;
90
136
  _a = JSII_RTTI_SYMBOL_1;
91
- LinuxCluster[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualmachinescaleset.LinuxCluster", version: "0.0.3-pre.6" };
137
+ LinuxCluster[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualmachinescaleset.LinuxCluster", version: "0.0.3-pre.7" };
92
138
  class WindowsCluster extends lib_1.AzureResource {
93
139
  /**
94
- * Constructs a new instance of the AzureWindowsVirtualMachine class.
140
+ * Represents a Windows Virtual Machine Scale Set (VMSS) within Microsoft Azure.
141
+ *
142
+ * This class provides a way to deploy and manage a scale set of Windows virtual machines, allowing for configurations such as
143
+ * auto-scaling, high availability, and simplified patch management. It supports detailed specifications including
144
+ * VM size, the operating system image, network settings, and administrative credentials. Additional capabilities include
145
+ * custom data scripts, automatic OS updates, and optional features like managed identity and boot diagnostics.
146
+ *
147
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.
148
+ * @param id - The unique identifier for this instance of the Windows cluster, used within the scope for reference.
149
+ * @param props - Configuration properties for the Windows VM Scale Set, derived from the WindowsClusterProps interface. These include:
150
+ * - `location`: The geographic location where the scale set will be hosted (e.g., "eastus").
151
+ * - `name`: The name of the scale set, which must be unique within the resource group.
152
+ * - `resourceGroup`: The ResourceGroup within which the scale set will be created.
153
+ * - `sku`: The size specification of the VMs (e.g., "Standard_B2s").
154
+ * - `adminUsername`: The administrator username for the VMs.
155
+ * - `adminPassword`: The administrator password for the VMs.
156
+ * - `zones`: The availability zones for deploying the VMs.
157
+ * - `instances`: The number of VM instances in the scale set.
158
+ * - `sourceImageReference`: A reference to the specific Windows image to be used for the VMs.
159
+ * - `sourceImageId`: The identifier for a custom image to use for the VMs.
160
+ * - `tags`: Key-value pairs for resource tagging.
161
+ * - `osDisk`: Configuration for the VMs' operating system disks.
162
+ * - `subnet`: Specifies the subnet within which the VMs will be placed.
163
+ * - `publicIPAddress`: Method used to allocate public IP addresses to the VMs.
164
+ * - `customData`: Scripts or commands passed to the VMs at startup.
165
+ * - `upgradePolicyMode`: The upgrade policy mode for the VMSS.
166
+ * - `overprovision`: Specifies if the VMSS should be overprovisioned to maintain capacity during updates.
167
+ * - `scaleInPolicy`: The scale-in policy for the VMSS.
168
+ * - `bootDiagnosticsStorageURI`: URI for storage where VMSS boot diagnostics are collected.
169
+ * - `enableSshAzureADLogin`: Option to enable Azure AD login for SSH on the VMs.
95
170
  *
96
- * @param scope - The scope in which this construct is defined.
97
- * @param id - The ID of this construct.
98
- * @param props - The properties for defining a Windows Virtual Machine.
171
+ * Example usage:
172
+ * ```typescript
173
+ * const windowsCluster = new WindowsCluster(this, 'MyWindowsCluster', {
174
+ * resourceGroup: myResourceGroup,
175
+ * name: 'myCluster',
176
+ * sku: 'Standard_DS1_v2',
177
+ * adminUsername: 'adminuser',
178
+ * adminPassword: 'securepassword123',
179
+ * sourceImageReference: { publisher: 'MicrosoftWindowsServer', offer: 'WindowsServer', sku: '2019-Datacenter', version: 'latest' },
180
+ * osDisk: { caching: 'ReadWrite', storageAccountType: 'Standard_LRS' },
181
+ * subnet: mySubnet,
182
+ * instances: 3,
183
+ * tags: { environment: 'production' }
184
+ * });
185
+ * ```
186
+ * This class initializes a Windows VM Scale Set with the specified configurations, handling details like VM creation,
187
+ * scaling policies, network setup, OS installation, and security settings, providing a robust and scalable infrastructure
188
+ * for hosting cloud-based Windows applications.
99
189
  */
100
190
  constructor(scope, id, props) {
101
191
  super(scope, id);
@@ -170,5 +260,5 @@ class WindowsCluster extends lib_1.AzureResource {
170
260
  }
171
261
  exports.WindowsCluster = WindowsCluster;
172
262
  _b = JSII_RTTI_SYMBOL_1;
173
- WindowsCluster[_b] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualmachinescaleset.WindowsCluster", version: "0.0.3-pre.6" };
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["../../../src/azure-virtualmachinescaleset/lib/cluster.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  LinuxVirtualMachineSourceImageReference,\n  LinuxVirtualMachineOsDisk,\n  LinuxVirtualMachineAdminSshKey,\n  LinuxVirtualMachineIdentity,\n} from \"@cdktf/provider-azurerm/lib/linux-virtual-machine\";\nimport {\n  LinuxVirtualMachineScaleSet,\n  LinuxVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress,\n} from \"@cdktf/provider-azurerm/lib/linux-virtual-machine-scale-set\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Subnet } from \"@cdktf/provider-azurerm/lib/subnet\";\nimport { VirtualMachineScaleSetExtensionA } from \"@cdktf/provider-azurerm/lib/virtual-machine-scale-set-extension\";\nimport {\n  WindowsVirtualMachineOsDisk,\n  WindowsVirtualMachineSourceImageReference,\n} from \"@cdktf/provider-azurerm/lib/windows-virtual-machine\";\nimport {\n  WindowsVirtualMachineScaleSet,\n  WindowsVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress,\n} from \"@cdktf/provider-azurerm/lib/windows-virtual-machine-scale-set\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  WindowsImageReferences,\n  LinuxImageReferences,\n} from \"../../azure-virtualmachine\";\nimport { Network } from \"../../azure-virtualnetwork/lib/network\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\nexport interface LinuxClusterProps {\n  /**\n   * The Azure location where the virtual machine scale set should be created.\n   * @default \"eastus\"\n   */\n  readonly location?: string;\n\n  /**\n   * The name of the virtual machine scale set.\n   * @default - Uses the name derived from the construct path.\n   */\n  readonly name?: string;\n\n  /**\n   * The admin username for the virtual machine.\n   */\n  readonly adminUsername?: string;\n\n  /**\n   * The admin password for the virtual machine.\n   */\n  readonly adminPassword?: string;\n\n  /**\n   * The name of the resource group in which the virtual machine scale set will be created.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The size of the virtual machines in the scale set.\n   * @default \"Standard_B2s\"\n   */\n  readonly sku?: string;\n\n  /**\n   * Custom data to pass to the virtual machines upon creation.\n   */\n  readonly userData?: string;\n\n  /**\n   * An array of SSH keys for the admin user.\n   */\n  readonly adminSshKey?: LinuxVirtualMachineAdminSshKey[] | cdktf.IResolvable;\n\n  /**\n   * The availability zone(s) in which the VMs should be placed.\n   */\n  readonly zones?: string[];\n\n  /**\n   * Managed identity settings for the VMs.\n   */\n  readonly identity?: LinuxVirtualMachineIdentity;\n\n  /**\n   * The source image reference for the virtual machines.\n   * @default - Uses a default Ubuntu image.\n   */\n  readonly sourceImageReference?: LinuxVirtualMachineSourceImageReference;\n\n  /**\n   * The ID of the source image for the virtual machines.\n   */\n  readonly sourceImageId?: string;\n\n  /**\n   * Tags to apply to the virtual machine scale set.\n   */\n  readonly tags?: { [key: string]: string };\n\n  /**\n   * The OS disk configuration for the virtual machines.\n   * @default - Uses a disk with caching set to \"ReadWrite\" and storage account type \"Standard_LRS\".\n   */\n  readonly osDisk?: LinuxVirtualMachineOsDisk;\n\n  /**\n   * The subnet in which the virtual machines will be placed.\n   */\n  readonly subnet?: Subnet;\n\n  /**\n   * The allocation method for the public IP.\n   */\n  readonly publicIPAddress?: LinuxVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress[];\n\n  /**\n   * Custom data to pass to the virtual machines upon creation.\n   */\n  readonly customData?: string;\n\n  /**\n   * The number of VM instances in the scale set.\n   * @default 2\n   */\n  readonly instances?: number;\n\n  /**\n   * Specifies the scale set's upgrade policy settings.\n   */\n  readonly upgradePolicyMode?: string;\n\n  /**\n   * Specifies if the VMSS should be overprovisioned.\n   * @default true\n   */\n  readonly overprovision?: boolean;\n\n  /**\n   * Specifies the scale-in policy for the VMSS.\n   */\n  readonly scaleInPolicy?: string;\n\n  /**\n   * Boot diagnostics settings for the VMSS.\n   */\n  readonly bootDiagnosticsStorageURI?: string;\n\n  /**\n   * Enable SSH Azure AD Login, required managed identity to be set.\n   * @default false\n   */\n  readonly enableSshAzureADLogin?: boolean;\n}\n\nexport class LinuxCluster extends AzureResource {\n  public readonly props: LinuxClusterProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  public readonly name: string;\n  public readonly fqn: string;\n\n  /**\n   * Constructs a new instance of the AzureLinuxVirtualMachine 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 for defining a Linux Virtual Machine.\n   */\n\n  constructor(scope: Construct, id: string, props: LinuxClusterProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    const pathName = this.node.path.split(\"/\")[0];\n\n    const defaults = {\n      name: props.name || pathName,\n      adminUsername: props.adminUsername || `admin${pathName}`,\n      location: props.location || \"eastus\",\n      sku: props.sku || \"Standard_B2s\",\n      instances: props.instances || 1,\n      osDisk: props.osDisk || {\n        caching: \"ReadWrite\",\n        storageAccountType: \"Standard_LRS\",\n      },\n      sourceImageReference:\n        props.sourceImageReference || LinuxImageReferences.ubuntuServer2204LTS,\n      subnet:\n        props.subnet ||\n        new Network(this, \"vnet\", {\n          resourceGroup: props.resourceGroup,\n        }).subnets.default,\n    };\n\n    const azurermLinuxVirtualMachineScaleSet = new LinuxVirtualMachineScaleSet(\n      this,\n      \"vmss\",\n      {\n        ...defaults,\n        resourceGroupName: props.resourceGroup.name,\n        adminPassword: props.adminPassword,\n        disablePasswordAuthentication: props.adminPassword ? false : true,\n        tags: props.tags,\n        networkInterface: [\n          {\n            name: `nic-${defaults.name}`,\n            primary: true,\n            ipConfiguration: [\n              {\n                name: \"internal\",\n                subnetId: defaults.subnet.id,\n                primary: true,\n                publicIpAddress: props.publicIPAddress,\n              },\n            ],\n          },\n        ],\n        osDisk: {\n          ...defaults.osDisk,\n        },\n        sourceImageId: props.sourceImageId,\n        customData: props.customData\n          ? Buffer.from(props.customData).toString(\"base64\")\n          : undefined,\n        userData: props.userData\n          ? Buffer.from(props.userData).toString(\"base64\")\n          : undefined,\n        adminSshKey: props.adminSshKey,\n        identity: props.identity,\n      },\n    );\n\n    this.id = azurermLinuxVirtualMachineScaleSet.id;\n    this.name = azurermLinuxVirtualMachineScaleSet.name;\n    this.fqn = azurermLinuxVirtualMachineScaleSet.fqn;\n\n    // Enable SSH Azure AD Login if specified\n    if (props.enableSshAzureADLogin) {\n      new VirtualMachineScaleSetExtensionA(this, \"AADSSHlogin\", {\n        name: \"AADSSHLoginForLinux\",\n        virtualMachineScaleSetId: this.id,\n        publisher: \"Microsoft.Azure.ActiveDirectory\",\n        type: \"AADSSHLoginForLinux\",\n        typeHandlerVersion: \"1.0\",\n      });\n    }\n  }\n}\n\nexport interface WindowsClusterProps {\n  /**\n   * The Azure location where the virtual machine should be created.\n   * @default \"eastus\"\n   */\n  readonly location?: string;\n\n  /**\n   * The name of the virtual machine.\n   * @default - Uses the name derived from the construct path.\n   */\n  readonly name?: string;\n\n  /**\n   * The name of the resource group in which the virtual machine will be created.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The size of the virtual machine.\n   * @default \"Standard_B2s\"\n   */\n  readonly sku?: string;\n\n  /**\n   * The admin username for the virtual machine.\n   */\n  readonly adminUsername: string;\n\n  /**\n   * The admin password for the virtual machine.\n   */\n  readonly adminPassword: string;\n\n  /**\n   * The availability zone(s) in which the VMs should be placed.\n   */\n  readonly zones?: string[];\n\n  /**\n   * The number of VM instances in the scale set.\n   * @default 2\n   */\n  readonly instances?: number;\n\n  /**\n   * The source image reference for the virtual machine.\n   * @default - Uses WindowsServer2022DatacenterCore.\n   */\n  readonly sourceImageReference?: WindowsVirtualMachineSourceImageReference;\n\n  /**\n   * The ID of the source image for the virtual machine.\n   */\n  readonly sourceImageId?: string;\n\n  /**\n   * Tags to apply to the virtual machine.\n   */\n  readonly tags?: { [key: string]: string };\n\n  /**\n   * The OS disk configuration for the virtual machine.\n   * @default - Uses a disk with caching set to \"ReadWrite\" and storage account type \"Standard_LRS\".\n   */\n  readonly osDisk?: WindowsVirtualMachineOsDisk;\n\n  /**\n   * The subnet in which the virtual machine will be placed.\n   * @default - Uses the default subnet from a new virtual network.\n   */\n  readonly subnet?: Subnet;\n\n  /**\n   * The allocation method for the public IP.\n   */\n  readonly publicIPAddress?: WindowsVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress[];\n\n  /**\n   * Specifies the scale set's upgrade policy settings.\n   */\n  readonly upgradePolicyMode?: string;\n\n  /**\n   * Custom data to pass to the virtual machine upon creation.\n   */\n  readonly customData?: string;\n\n  /**\n   * Custom data to bootstrap the virtual machine. Automatically triggers Azure Custom Script extension to deploy code in custom data.\n   */\n  readonly boostrapCustomData?: string;\n\n  /**\n   * Bootdiagnostics settings for the VM.\n   */\n  readonly bootDiagnosticsStorageURI?: string;\n\n  /**\n   * Specifies if the VMSS should be overprovisioned.\n   * @default true\n   */\n  readonly overprovision?: boolean;\n\n  /**\n   * Specifies the scale-in policy for the VMSS.\n   */\n  readonly scaleInPolicy?: string;\n}\n\nexport class WindowsCluster extends AzureResource {\n  readonly props: WindowsClusterProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  public readonly name: string;\n\n  /**\n   * Constructs a new instance of the AzureWindowsVirtualMachine 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 for defining a Windows Virtual Machine.\n   */\n  constructor(scope: Construct, id: string, props: WindowsClusterProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    const pathName = this.node.path.split(\"/\")[0];\n\n    // Default configurations for the virtual machine.\n    const defaults = {\n      name: props.name || this.node.path.split(\"/\")[0],\n      adminUsername: props.adminUsername || `admin${pathName}`,\n      location: props.location || \"eastus\",\n      sku: props.sku || \"Standard_B2s\",\n      instances: props.instances || 1,\n      osDisk: props.osDisk || {\n        caching: \"ReadWrite\",\n        storageAccountType: \"Standard_LRS\",\n      },\n      sourceImageReference:\n        props.sourceImageReference ||\n        WindowsImageReferences.windowsServer2022DatacenterCore,\n      subnet:\n        props.subnet ||\n        new Network(this, \"vnet\", {\n          resourceGroup: props.resourceGroup,\n        }).subnets.default,\n    };\n\n    // Base64 encode custom data if provided.\n    const customData = props.customData || props.boostrapCustomData;\n    const base64CustomData = customData\n      ? Buffer.from(customData).toString(\"base64\")\n      : undefined;\n\n    // Create the Windows Virtual Machine.\n    const azurermWindowsVirtualMachine = new WindowsVirtualMachineScaleSet(\n      this,\n      \"vmss\",\n      {\n        ...defaults,\n        resourceGroupName: props.resourceGroup.name,\n        adminUsername: props.adminUsername,\n        adminPassword: props.adminPassword,\n        tags: props.tags,\n        networkInterface: [\n          {\n            name: `nic-${defaults.name}`,\n            primary: true,\n            ipConfiguration: [\n              {\n                name: \"internal\",\n                subnetId: defaults.subnet.id,\n                primary: true,\n                publicIpAddress: props.publicIPAddress,\n              },\n            ],\n          },\n        ],\n        osDisk: {\n          ...defaults.osDisk,\n        },\n        sourceImageId: props.sourceImageId,\n        customData: base64CustomData,\n        bootDiagnostics: { storageAccountUri: props.bootDiagnosticsStorageURI },\n      },\n    );\n\n    this.id = azurermWindowsVirtualMachine.id;\n    this.name = azurermWindowsVirtualMachine.name;\n\n    // Bootstrap VM with custom script extension if bootstrap custom data is provided.\n    if (props.boostrapCustomData) {\n      new VirtualMachineScaleSetExtensionA(this, \"script-ext\", {\n        name: `${this.name}-script-ext`,\n        virtualMachineScaleSetId: this.id,\n        publisher: \"Microsoft.Compute\",\n        type: \"CustomScriptExtension\",\n        typeHandlerVersion: \"1.10\",\n        protectedSettings:\n          '{\"commandToExecute\": \"rename  C:\\\\\\\\AzureData\\\\\\\\CustomData.bin  postdeploy.ps1 & powershell -ExecutionPolicy Unrestricted -File C:\\\\\\\\AzureData\\\\\\\\postdeploy.ps1\"}',\n      });\n    }\n  }\n}\n"]}
263
+ WindowsCluster[_b] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualmachinescaleset.WindowsCluster", version: "0.0.3-pre.7" };
264
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["../../../src/azure-virtualmachinescaleset/lib/cluster.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  LinuxVirtualMachineSourceImageReference,\n  LinuxVirtualMachineOsDisk,\n  LinuxVirtualMachineAdminSshKey,\n  LinuxVirtualMachineIdentity,\n} from \"@cdktf/provider-azurerm/lib/linux-virtual-machine\";\nimport {\n  LinuxVirtualMachineScaleSet,\n  LinuxVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress,\n} from \"@cdktf/provider-azurerm/lib/linux-virtual-machine-scale-set\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Subnet } from \"@cdktf/provider-azurerm/lib/subnet\";\nimport { VirtualMachineScaleSetExtensionA } from \"@cdktf/provider-azurerm/lib/virtual-machine-scale-set-extension\";\nimport {\n  WindowsVirtualMachineOsDisk,\n  WindowsVirtualMachineSourceImageReference,\n} from \"@cdktf/provider-azurerm/lib/windows-virtual-machine\";\nimport {\n  WindowsVirtualMachineScaleSet,\n  WindowsVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress,\n} from \"@cdktf/provider-azurerm/lib/windows-virtual-machine-scale-set\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  WindowsImageReferences,\n  LinuxImageReferences,\n} from \"../../azure-virtualmachine\";\nimport { Network } from \"../../azure-virtualnetwork/lib/network\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\nexport interface LinuxClusterProps {\n  /**\n   * The Azure location where the virtual machine scale set should be created.\n   * @default \"eastus\"\n   */\n  readonly location?: string;\n\n  /**\n   * The name of the virtual machine scale set.\n   * @default - Uses the name derived from the construct path.\n   */\n  readonly name?: string;\n\n  /**\n   * The admin username for the virtual machine.\n   */\n  readonly adminUsername?: string;\n\n  /**\n   * The admin password for the virtual machine.\n   */\n  readonly adminPassword?: string;\n\n  /**\n   * The name of the resource group in which the virtual machine scale set will be created.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The size of the virtual machines in the scale set.\n   * @default \"Standard_B2s\"\n   */\n  readonly sku?: string;\n\n  /**\n   * Custom data to pass to the virtual machines upon creation.\n   */\n  readonly userData?: string;\n\n  /**\n   * An array of SSH keys for the admin user.\n   */\n  readonly adminSshKey?: LinuxVirtualMachineAdminSshKey[] | cdktf.IResolvable;\n\n  /**\n   * The availability zone(s) in which the VMs should be placed.\n   */\n  readonly zones?: string[];\n\n  /**\n   * Managed identity settings for the VMs.\n   */\n  readonly identity?: LinuxVirtualMachineIdentity;\n\n  /**\n   * The source image reference for the virtual machines.\n   * @default - Uses a default Ubuntu image.\n   */\n  readonly sourceImageReference?: LinuxVirtualMachineSourceImageReference;\n\n  /**\n   * The ID of the source image for the virtual machines.\n   */\n  readonly sourceImageId?: string;\n\n  /**\n   * Tags to apply to the virtual machine scale set.\n   */\n  readonly tags?: { [key: string]: string };\n\n  /**\n   * The OS disk configuration for the virtual machines.\n   * @default - Uses a disk with caching set to \"ReadWrite\" and storage account type \"Standard_LRS\".\n   */\n  readonly osDisk?: LinuxVirtualMachineOsDisk;\n\n  /**\n   * The subnet in which the virtual machines will be placed.\n   */\n  readonly subnet?: Subnet;\n\n  /**\n   * The allocation method for the public IP.\n   */\n  readonly publicIPAddress?: LinuxVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress[];\n\n  /**\n   * Custom data to pass to the virtual machines upon creation.\n   */\n  readonly customData?: string;\n\n  /**\n   * The number of VM instances in the scale set.\n   * @default 2\n   */\n  readonly instances?: number;\n\n  /**\n   * Specifies the scale set's upgrade policy settings.\n   */\n  readonly upgradePolicyMode?: string;\n\n  /**\n   * Specifies if the VMSS should be overprovisioned.\n   * @default true\n   */\n  readonly overprovision?: boolean;\n\n  /**\n   * Specifies the scale-in policy for the VMSS.\n   */\n  readonly scaleInPolicy?: string;\n\n  /**\n   * Boot diagnostics settings for the VMSS.\n   */\n  readonly bootDiagnosticsStorageURI?: string;\n\n  /**\n   * Enable SSH Azure AD Login, required managed identity to be set.\n   * @default false\n   */\n  readonly enableSshAzureADLogin?: boolean;\n}\n\nexport class LinuxCluster extends AzureResource {\n  public readonly props: LinuxClusterProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  public readonly name: string;\n  public readonly fqn: string;\n\n  /**\n   * Represents a Linux Virtual Machine Scale Set (VMSS) within Microsoft Azure.\n   *\n   * This class is designed to provision and manage a scale set of Linux virtual machines, providing capabilities such as\n   * auto-scaling, high availability, and simplified management. It supports detailed configurations like VM size, operating\n   * system image, network settings, and administrative credentials. Additional functionalities include custom data scripts,\n   * SSH configurations, and optional features like managed identity and boot diagnostics.\n   *\n   * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.\n   * @param id - The unique identifier for this instance of the Linux cluster, used within the scope for reference.\n   * @param props - Configuration properties for the Linux VM Scale Set, derived from the LinuxClusterProps interface. These include:\n   *                - `location`: The geographic location where the scale set will be hosted (e.g., \"eastus\").\n   *                - `name`: The name of the scale set, which must be unique within the resource group.\n   *                - `resourceGroup`: The ResourceGroup within which the scale set will be created.\n   *                - `sku`: The size specification of the VMs (e.g., \"Standard_B2s\").\n   *                - `adminUsername`: The administrator username for the VMs.\n   *                - `adminPassword`: The administrator password for the VMs.\n   *                - `adminSshKey`: SSH keys for secure access to the VMs.\n   *                - `zones`: The availability zones for deploying the VMs.\n   *                - `identity`: Managed identity settings for accessing other Azure services.\n   *                - `sourceImageReference`: A reference to the specific Linux image to be used for the VMs.\n   *                - `sourceImageId`: The identifier for a custom image to use for the VMs.\n   *                - `tags`: Key-value pairs for resource tagging.\n   *                - `osDisk`: Configuration for the VMs' operating system disks.\n   *                - `subnet`: Specifies the subnet within which the VMs will be placed.\n   *                - `publicIPAddress`: Method used to allocate public IP addresses to the VMs.\n   *                - `customData`: Scripts or commands passed to the VMs at startup.\n   *                - `instances`: The number of VM instances in the scale set.\n   *                - `upgradePolicyMode`: The upgrade policy mode for the VMSS.\n   *                - `overprovision`: Specifies if the VMSS should be overprovisioned to maintain capacity during updates.\n   *                - `scaleInPolicy`: The scale-in policy for the VMSS.\n   *                - `bootDiagnosticsStorageURI`: URI for storage where VMSS boot diagnostics are collected.\n   *                - `enableSshAzureADLogin`: Option to enable Azure AD login for SSH on the VMs.\n   *\n   * Example usage:\n   * ```typescript\n   * const linuxCluster = new LinuxCluster(this, 'MyLinuxCluster', {\n   *   resourceGroup: myResourceGroup,\n   *   name: 'myCluster',\n   *   sku: 'Standard_DS1_v2',\n   *   adminUsername: 'adminuser',\n   *   adminSshKey: [{ publicKey: 'ssh-rsa AAAAB...' }],\n   *   sourceImageReference: { publisher: 'Canonical', offer: 'UbuntuServer', sku: '18.04-LTS', version: 'latest' },\n   *   osDisk: { caching: 'ReadWrite', storageAccountType: 'Standard_LRS' },\n   *   subnet: mySubnet,\n   *   instances: 3,\n   *   tags: { environment: 'production' }\n   * });\n   * ```\n   * This class initializes a Linux VM Scale Set with the specified configurations, handling details like VM creation,\n   * scaling policies, network setup, OS installation, and security settings, providing a robust and scalable infrastructure\n   * for hosting cloud-based Linux applications.\n   */\n  constructor(scope: Construct, id: string, props: LinuxClusterProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    const pathName = this.node.path.split(\"/\")[0];\n\n    const defaults = {\n      name: props.name || pathName,\n      adminUsername: props.adminUsername || `admin${pathName}`,\n      location: props.location || \"eastus\",\n      sku: props.sku || \"Standard_B2s\",\n      instances: props.instances || 1,\n      osDisk: props.osDisk || {\n        caching: \"ReadWrite\",\n        storageAccountType: \"Standard_LRS\",\n      },\n      sourceImageReference:\n        props.sourceImageReference || LinuxImageReferences.ubuntuServer2204LTS,\n      subnet:\n        props.subnet ||\n        new Network(this, \"vnet\", {\n          resourceGroup: props.resourceGroup,\n        }).subnets.default,\n    };\n\n    const azurermLinuxVirtualMachineScaleSet = new LinuxVirtualMachineScaleSet(\n      this,\n      \"vmss\",\n      {\n        ...defaults,\n        resourceGroupName: props.resourceGroup.name,\n        adminPassword: props.adminPassword,\n        disablePasswordAuthentication: props.adminPassword ? false : true,\n        tags: props.tags,\n        networkInterface: [\n          {\n            name: `nic-${defaults.name}`,\n            primary: true,\n            ipConfiguration: [\n              {\n                name: \"internal\",\n                subnetId: defaults.subnet.id,\n                primary: true,\n                publicIpAddress: props.publicIPAddress,\n              },\n            ],\n          },\n        ],\n        osDisk: {\n          ...defaults.osDisk,\n        },\n        sourceImageId: props.sourceImageId,\n        customData: props.customData\n          ? Buffer.from(props.customData).toString(\"base64\")\n          : undefined,\n        userData: props.userData\n          ? Buffer.from(props.userData).toString(\"base64\")\n          : undefined,\n        adminSshKey: props.adminSshKey,\n        identity: props.identity,\n      },\n    );\n\n    this.id = azurermLinuxVirtualMachineScaleSet.id;\n    this.name = azurermLinuxVirtualMachineScaleSet.name;\n    this.fqn = azurermLinuxVirtualMachineScaleSet.fqn;\n\n    // Enable SSH Azure AD Login if specified\n    if (props.enableSshAzureADLogin) {\n      new VirtualMachineScaleSetExtensionA(this, \"AADSSHlogin\", {\n        name: \"AADSSHLoginForLinux\",\n        virtualMachineScaleSetId: this.id,\n        publisher: \"Microsoft.Azure.ActiveDirectory\",\n        type: \"AADSSHLoginForLinux\",\n        typeHandlerVersion: \"1.0\",\n      });\n    }\n  }\n}\n\nexport interface WindowsClusterProps {\n  /**\n   * The Azure location where the virtual machine should be created.\n   * @default \"eastus\"\n   */\n  readonly location?: string;\n\n  /**\n   * The name of the virtual machine.\n   * @default - Uses the name derived from the construct path.\n   */\n  readonly name?: string;\n\n  /**\n   * The name of the resource group in which the virtual machine will be created.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * The size of the virtual machine.\n   * @default \"Standard_B2s\"\n   */\n  readonly sku?: string;\n\n  /**\n   * The admin username for the virtual machine.\n   */\n  readonly adminUsername: string;\n\n  /**\n   * The admin password for the virtual machine.\n   */\n  readonly adminPassword: string;\n\n  /**\n   * The availability zone(s) in which the VMs should be placed.\n   */\n  readonly zones?: string[];\n\n  /**\n   * The number of VM instances in the scale set.\n   * @default 2\n   */\n  readonly instances?: number;\n\n  /**\n   * The source image reference for the virtual machine.\n   * @default - Uses WindowsServer2022DatacenterCore.\n   */\n  readonly sourceImageReference?: WindowsVirtualMachineSourceImageReference;\n\n  /**\n   * The ID of the source image for the virtual machine.\n   */\n  readonly sourceImageId?: string;\n\n  /**\n   * Tags to apply to the virtual machine.\n   */\n  readonly tags?: { [key: string]: string };\n\n  /**\n   * The OS disk configuration for the virtual machine.\n   * @default - Uses a disk with caching set to \"ReadWrite\" and storage account type \"Standard_LRS\".\n   */\n  readonly osDisk?: WindowsVirtualMachineOsDisk;\n\n  /**\n   * The subnet in which the virtual machine will be placed.\n   * @default - Uses the default subnet from a new virtual network.\n   */\n  readonly subnet?: Subnet;\n\n  /**\n   * The allocation method for the public IP.\n   */\n  readonly publicIPAddress?: WindowsVirtualMachineScaleSetNetworkInterfaceIpConfigurationPublicIpAddress[];\n\n  /**\n   * Specifies the scale set's upgrade policy settings.\n   */\n  readonly upgradePolicyMode?: string;\n\n  /**\n   * Custom data to pass to the virtual machine upon creation.\n   */\n  readonly customData?: string;\n\n  /**\n   * Custom data to bootstrap the virtual machine. Automatically triggers Azure Custom Script extension to deploy code in custom data.\n   */\n  readonly boostrapCustomData?: string;\n\n  /**\n   * Bootdiagnostics settings for the VM.\n   */\n  readonly bootDiagnosticsStorageURI?: string;\n\n  /**\n   * Specifies if the VMSS should be overprovisioned.\n   * @default true\n   */\n  readonly overprovision?: boolean;\n\n  /**\n   * Specifies the scale-in policy for the VMSS.\n   */\n  readonly scaleInPolicy?: string;\n}\n\nexport class WindowsCluster extends AzureResource {\n  readonly props: WindowsClusterProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  public readonly name: string;\n\n  /**\n   * Represents a Windows Virtual Machine Scale Set (VMSS) within Microsoft Azure.\n   *\n   * This class provides a way to deploy and manage a scale set of Windows virtual machines, allowing for configurations such as\n   * auto-scaling, high availability, and simplified patch management. It supports detailed specifications including\n   * VM size, the operating system image, network settings, and administrative credentials. Additional capabilities include\n   * custom data scripts, automatic OS updates, and optional features like managed identity and boot diagnostics.\n   *\n   * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.\n   * @param id - The unique identifier for this instance of the Windows cluster, used within the scope for reference.\n   * @param props - Configuration properties for the Windows VM Scale Set, derived from the WindowsClusterProps interface. These include:\n   *                - `location`: The geographic location where the scale set will be hosted (e.g., \"eastus\").\n   *                - `name`: The name of the scale set, which must be unique within the resource group.\n   *                - `resourceGroup`: The ResourceGroup within which the scale set will be created.\n   *                - `sku`: The size specification of the VMs (e.g., \"Standard_B2s\").\n   *                - `adminUsername`: The administrator username for the VMs.\n   *                - `adminPassword`: The administrator password for the VMs.\n   *                - `zones`: The availability zones for deploying the VMs.\n   *                - `instances`: The number of VM instances in the scale set.\n   *                - `sourceImageReference`: A reference to the specific Windows image to be used for the VMs.\n   *                - `sourceImageId`: The identifier for a custom image to use for the VMs.\n   *                - `tags`: Key-value pairs for resource tagging.\n   *                - `osDisk`: Configuration for the VMs' operating system disks.\n   *                - `subnet`: Specifies the subnet within which the VMs will be placed.\n   *                - `publicIPAddress`: Method used to allocate public IP addresses to the VMs.\n   *                - `customData`: Scripts or commands passed to the VMs at startup.\n   *                - `upgradePolicyMode`: The upgrade policy mode for the VMSS.\n   *                - `overprovision`: Specifies if the VMSS should be overprovisioned to maintain capacity during updates.\n   *                - `scaleInPolicy`: The scale-in policy for the VMSS.\n   *                - `bootDiagnosticsStorageURI`: URI for storage where VMSS boot diagnostics are collected.\n   *                - `enableSshAzureADLogin`: Option to enable Azure AD login for SSH on the VMs.\n   *\n   * Example usage:\n   * ```typescript\n   * const windowsCluster = new WindowsCluster(this, 'MyWindowsCluster', {\n   *   resourceGroup: myResourceGroup,\n   *   name: 'myCluster',\n   *   sku: 'Standard_DS1_v2',\n   *   adminUsername: 'adminuser',\n   *   adminPassword: 'securepassword123',\n   *   sourceImageReference: { publisher: 'MicrosoftWindowsServer', offer: 'WindowsServer', sku: '2019-Datacenter', version: 'latest' },\n   *   osDisk: { caching: 'ReadWrite', storageAccountType: 'Standard_LRS' },\n   *   subnet: mySubnet,\n   *   instances: 3,\n   *   tags: { environment: 'production' }\n   * });\n   * ```\n   * This class initializes a Windows VM Scale Set with the specified configurations, handling details like VM creation,\n   * scaling policies, network setup, OS installation, and security settings, providing a robust and scalable infrastructure\n   * for hosting cloud-based Windows applications.\n   */\n  constructor(scope: Construct, id: string, props: WindowsClusterProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    const pathName = this.node.path.split(\"/\")[0];\n\n    // Default configurations for the virtual machine.\n    const defaults = {\n      name: props.name || this.node.path.split(\"/\")[0],\n      adminUsername: props.adminUsername || `admin${pathName}`,\n      location: props.location || \"eastus\",\n      sku: props.sku || \"Standard_B2s\",\n      instances: props.instances || 1,\n      osDisk: props.osDisk || {\n        caching: \"ReadWrite\",\n        storageAccountType: \"Standard_LRS\",\n      },\n      sourceImageReference:\n        props.sourceImageReference ||\n        WindowsImageReferences.windowsServer2022DatacenterCore,\n      subnet:\n        props.subnet ||\n        new Network(this, \"vnet\", {\n          resourceGroup: props.resourceGroup,\n        }).subnets.default,\n    };\n\n    // Base64 encode custom data if provided.\n    const customData = props.customData || props.boostrapCustomData;\n    const base64CustomData = customData\n      ? Buffer.from(customData).toString(\"base64\")\n      : undefined;\n\n    // Create the Windows Virtual Machine.\n    const azurermWindowsVirtualMachine = new WindowsVirtualMachineScaleSet(\n      this,\n      \"vmss\",\n      {\n        ...defaults,\n        resourceGroupName: props.resourceGroup.name,\n        adminUsername: props.adminUsername,\n        adminPassword: props.adminPassword,\n        tags: props.tags,\n        networkInterface: [\n          {\n            name: `nic-${defaults.name}`,\n            primary: true,\n            ipConfiguration: [\n              {\n                name: \"internal\",\n                subnetId: defaults.subnet.id,\n                primary: true,\n                publicIpAddress: props.publicIPAddress,\n              },\n            ],\n          },\n        ],\n        osDisk: {\n          ...defaults.osDisk,\n        },\n        sourceImageId: props.sourceImageId,\n        customData: base64CustomData,\n        bootDiagnostics: { storageAccountUri: props.bootDiagnosticsStorageURI },\n      },\n    );\n\n    this.id = azurermWindowsVirtualMachine.id;\n    this.name = azurermWindowsVirtualMachine.name;\n\n    // Bootstrap VM with custom script extension if bootstrap custom data is provided.\n    if (props.boostrapCustomData) {\n      new VirtualMachineScaleSetExtensionA(this, \"script-ext\", {\n        name: `${this.name}-script-ext`,\n        virtualMachineScaleSetId: this.id,\n        publisher: \"Microsoft.Compute\",\n        type: \"CustomScriptExtension\",\n        typeHandlerVersion: \"1.10\",\n        protectedSettings:\n          '{\"commandToExecute\": \"rename  C:\\\\\\\\AzureData\\\\\\\\CustomData.bin  postdeploy.ps1 & powershell -ExecutionPolicy Unrestricted -File C:\\\\\\\\AzureData\\\\\\\\postdeploy.ps1\"}',\n      });\n    }\n  }\n}\n"]}
@@ -56,6 +56,67 @@ export declare class Network extends AzureResource {
56
56
  readonly subnets: {
57
57
  [name: string]: Subnet;
58
58
  };
59
+ /**
60
+ * Represents an Azure Virtual Network (VNet) within Microsoft Azure.
61
+ *
62
+ * This class is responsible for the creation and management of a virtual network, which provides an isolated environment
63
+ * where Azure resources, such as VMs and databases, can securely communicate with each other, the internet, and on-premises
64
+ * networks. It supports configurations such as multiple address spaces and subnets, enabling complex networking scenarios.
65
+ *
66
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.
67
+ * @param id - The unique identifier for this instance of the network, used within the scope for reference.
68
+ * @param props - Configuration properties for the Azure Virtual Network, derived from the NetworkProps interface. These include:
69
+ * - `resourceGroup`: The ResourceGroup within which the virtual network will be created.
70
+ * - `name`: Optional. The name of the virtual network. If not provided, a default name will be assigned.
71
+ * - `location`: Optional. The Azure region where the virtual network will be deployed. Defaults to the resource group's region.
72
+ * - `addressSpace`: Optional. A list of CIDR blocks that define the address spaces of the virtual network.
73
+ * - `subnets`: Optional. An array of subnets to be created within the virtual network, each defined by a name and a CIDR block.
74
+ *
75
+ * Example usage:
76
+ * ```typescript
77
+ * const network = new Network(this, 'MyVirtualNetwork', {
78
+ * resourceGroup: myResourceGroup,
79
+ * name: 'myVNet',
80
+ * location: 'West US',
81
+ * addressSpace: ['10.0.0.0/16'],
82
+ * subnets: [{ name: 'subnet1', addressPrefixes: ['10.0.1.0/24'] }]
83
+ * });
84
+ * ```
85
+ * This class initializes a virtual network with the specified configurations and handles the provisioning of subnets
86
+ * within the network, providing a foundational networking layer for hosting cloud resources.
87
+ */
59
88
  constructor(scope: Construct, id: string, props: NetworkProps);
89
+ /**
90
+ * Establishes a peering connection between this virtual network and another remote virtual network.
91
+ *
92
+ * This method configures a two-way peering connection, allowing resources in both virtual networks to communicate
93
+ * seamlessly. It sets up peering settings such as network access, traffic forwarding, and gateway transit based on
94
+ * provided configurations.
95
+ *
96
+ * @param remoteVirtualNetwork - The remote virtual network with which to establish a peering connection.
97
+ * @param localPeerSettings - Optional settings applied from this virtual network to the remote virtual network.
98
+ * Controls aspects like virtual network access, traffic forwarding, and use of gateways.
99
+ * @param remotePeerSettings - Optional settings applied from the remote virtual network to this virtual network.
100
+ * Allows customization of how the remote network interacts with this one.
101
+ *
102
+ * Example usage:
103
+ * ```typescript
104
+ * // Assuming 'this' is a reference to a local virtual network instance.
105
+ * const partnerVNet = new Network(this, 'PartnerVNet', { ... });
106
+ * this.addVnetPeering(partnerVNet, {
107
+ * allowVirtualNetworkAccess: true,
108
+ * allowForwardedTraffic: false,
109
+ * allowGatewayTransit: true,
110
+ * useRemoteGateways: false
111
+ * }, {
112
+ * allowVirtualNetworkAccess: true,
113
+ * allowForwardedTraffic: true,
114
+ * allowGatewayTransit: false,
115
+ * useRemoteGateways: false
116
+ * });
117
+ * ```
118
+ * This method invokes the `Peer` class to create a peering between 'this' virtual network and 'partnerVNet'.
119
+ * The settings control traffic behavior and access permissions in both directions of the peering.
120
+ */
60
121
  addVnetPeering(remoteVirtualNetwork: Network, localPeerSettings?: PeerSettings, remotePeerSettings?: PeerSettings): void;
61
122
  }
@@ -8,6 +8,35 @@ const virtual_network_1 = require("@cdktf/provider-azurerm/lib/virtual-network")
8
8
  const peering_1 = require("./peering");
9
9
  const lib_1 = require("../../core-azure/lib");
10
10
  class Network extends lib_1.AzureResource {
11
+ /**
12
+ * Represents an Azure Virtual Network (VNet) within Microsoft Azure.
13
+ *
14
+ * This class is responsible for the creation and management of a virtual network, which provides an isolated environment
15
+ * where Azure resources, such as VMs and databases, can securely communicate with each other, the internet, and on-premises
16
+ * networks. It supports configurations such as multiple address spaces and subnets, enabling complex networking scenarios.
17
+ *
18
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.
19
+ * @param id - The unique identifier for this instance of the network, used within the scope for reference.
20
+ * @param props - Configuration properties for the Azure Virtual Network, derived from the NetworkProps interface. These include:
21
+ * - `resourceGroup`: The ResourceGroup within which the virtual network will be created.
22
+ * - `name`: Optional. The name of the virtual network. If not provided, a default name will be assigned.
23
+ * - `location`: Optional. The Azure region where the virtual network will be deployed. Defaults to the resource group's region.
24
+ * - `addressSpace`: Optional. A list of CIDR blocks that define the address spaces of the virtual network.
25
+ * - `subnets`: Optional. An array of subnets to be created within the virtual network, each defined by a name and a CIDR block.
26
+ *
27
+ * Example usage:
28
+ * ```typescript
29
+ * const network = new Network(this, 'MyVirtualNetwork', {
30
+ * resourceGroup: myResourceGroup,
31
+ * name: 'myVNet',
32
+ * location: 'West US',
33
+ * addressSpace: ['10.0.0.0/16'],
34
+ * subnets: [{ name: 'subnet1', addressPrefixes: ['10.0.1.0/24'] }]
35
+ * });
36
+ * ```
37
+ * This class initializes a virtual network with the specified configurations and handles the provisioning of subnets
38
+ * within the network, providing a foundational networking layer for hosting cloud resources.
39
+ */
11
40
  constructor(scope, id, props) {
12
41
  super(scope, id);
13
42
  this.subnets = {}; // Map of subnet name to Subnet object
@@ -43,7 +72,38 @@ class Network extends lib_1.AzureResource {
43
72
  this.subnets[subnetConfig.name] = subnet; // Populate the subnetsMap
44
73
  }
45
74
  }
46
- // Create Vnet Peering Method
75
+ /**
76
+ * Establishes a peering connection between this virtual network and another remote virtual network.
77
+ *
78
+ * This method configures a two-way peering connection, allowing resources in both virtual networks to communicate
79
+ * seamlessly. It sets up peering settings such as network access, traffic forwarding, and gateway transit based on
80
+ * provided configurations.
81
+ *
82
+ * @param remoteVirtualNetwork - The remote virtual network with which to establish a peering connection.
83
+ * @param localPeerSettings - Optional settings applied from this virtual network to the remote virtual network.
84
+ * Controls aspects like virtual network access, traffic forwarding, and use of gateways.
85
+ * @param remotePeerSettings - Optional settings applied from the remote virtual network to this virtual network.
86
+ * Allows customization of how the remote network interacts with this one.
87
+ *
88
+ * Example usage:
89
+ * ```typescript
90
+ * // Assuming 'this' is a reference to a local virtual network instance.
91
+ * const partnerVNet = new Network(this, 'PartnerVNet', { ... });
92
+ * this.addVnetPeering(partnerVNet, {
93
+ * allowVirtualNetworkAccess: true,
94
+ * allowForwardedTraffic: false,
95
+ * allowGatewayTransit: true,
96
+ * useRemoteGateways: false
97
+ * }, {
98
+ * allowVirtualNetworkAccess: true,
99
+ * allowForwardedTraffic: true,
100
+ * allowGatewayTransit: false,
101
+ * useRemoteGateways: false
102
+ * });
103
+ * ```
104
+ * This method invokes the `Peer` class to create a peering between 'this' virtual network and 'partnerVNet'.
105
+ * The settings control traffic behavior and access permissions in both directions of the peering.
106
+ */
47
107
  addVnetPeering(remoteVirtualNetwork, localPeerSettings, remotePeerSettings) {
48
108
  const vnetPeerProps = {
49
109
  virtualNetwork: this,
@@ -56,5 +116,5 @@ class Network extends lib_1.AzureResource {
56
116
  }
57
117
  exports.Network = Network;
58
118
  _a = JSII_RTTI_SYMBOL_1;
59
- Network[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualnetwork.Network", version: "0.0.3-pre.6" };
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29yay5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9henVyZS12aXJ0dWFsbmV0d29yay9saWIvbmV0d29yay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUNBLCtEQUE0RDtBQUM1RCxpRkFBNkU7QUFFN0UsdUNBQTBEO0FBQzFELDhDQUFxRDtBQW9EckQsTUFBYSxPQUFRLFNBQVEsbUJBQWE7SUFReEMsWUFBWSxLQUFnQixFQUFFLEVBQVUsRUFBRSxLQUFtQjtRQUMzRCxLQUFLLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBSEgsWUFBTyxHQUErQixFQUFFLENBQUMsQ0FBQyxzQ0FBc0M7UUFLOUYsSUFBSSxDQUFDLEtBQUssR0FBRyxLQUFLLENBQUM7UUFFbkIsTUFBTSxRQUFRLEdBQUc7WUFDZixJQUFJLEVBQUUsS0FBSyxDQUFDLElBQUksSUFBSSxRQUFRLElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRTtZQUMxRCxRQUFRLEVBQUUsS0FBSyxDQUFDLFFBQVEsSUFBSSxRQUFRO1lBQ3BDLFlBQVksRUFBRSxLQUFLLENBQUMsWUFBWSxJQUFJLENBQUMsYUFBYSxDQUFDO1lBQ25ELE9BQU8sRUFBRSxLQUFLLENBQUMsT0FBTyxJQUFJO2dCQUN4QjtvQkFDRSxJQUFJLEVBQUUsU0FBUztvQkFDZixlQUFlLEVBQUUsQ0FBQyxhQUFhLENBQUM7aUJBQ2pDO2FBQ0Y7U0FDRixDQUFDO1FBRUYsMkJBQTJCO1FBQzNCLE1BQU0sSUFBSSxHQUFHLElBQUksZ0NBQWMsQ0FBQyxJQUFJLEVBQUUsTUFBTSxFQUFFO1lBQzVDLEdBQUcsUUFBUTtZQUNYLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSTtTQUM1QyxDQUFDLENBQUM7UUFFSCxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUM7UUFDdEIsSUFBSSxDQUFDLEVBQUUsR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQ2xCLElBQUksQ0FBQyxhQUFhLEdBQUcsS0FBSyxDQUFDLGFBQWEsQ0FBQztRQUN6QyxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQztRQUUzQiw0Q0FBNEM7UUFDNUMsS0FBSyxNQUFNLFlBQVksSUFBSSxRQUFRLENBQUMsT0FBTyxFQUFFO1lBQzNDLE1BQU0sTUFBTSxHQUFHLElBQUksZUFBTSxDQUFDLElBQUksRUFBRSxZQUFZLENBQUMsSUFBSSxFQUFFO2dCQUNqRCxJQUFJLEVBQUUsWUFBWSxDQUFDLElBQUk7Z0JBQ3ZCLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxhQUFhLENBQUMsSUFBSTtnQkFDM0Msa0JBQWtCLEVBQUUsSUFBSSxDQUFDLElBQUk7Z0JBQzdCLGVBQWUsRUFBRSxZQUFZLENBQUMsZUFBZTthQUM5QyxDQUFDLENBQUM7WUFFSCxJQUFJLENBQUMsT0FBTyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxNQUFNLENBQUMsQ0FBQywwQkFBMEI7U0FDckU7SUFDSCxDQUFDO0lBRUQsNkJBQTZCO0lBQ3RCLGNBQWMsQ0FDbkIsb0JBQTZCLEVBQzdCLGlCQUFnQyxFQUNoQyxrQkFBaUM7UUFFakMsTUFBTSxhQUFhLEdBQWM7WUFDL0IsY0FBYyxFQUFFLElBQUk7WUFDcEIsb0JBQW9CLEVBQUUsb0JBQW9CO1lBQzFDLHFCQUFxQixFQUFFLGlCQUFpQjtZQUN4QyxxQkFBcUIsRUFBRSxrQkFBa0I7U0FDMUMsQ0FBQztRQUNGLElBQUksY0FBSSxDQUFDLElBQUksRUFBRSxvQkFBb0IsQ0FBQyxFQUFFLEVBQUUsYUFBYSxDQUFDLENBQUM7SUFDekQsQ0FBQzs7QUE5REgsMEJBK0RDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUmVzb3VyY2VHcm91cCB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvcmVzb3VyY2UtZ3JvdXBcIjtcbmltcG9ydCB7IFN1Ym5ldCB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvc3VibmV0XCI7XG5pbXBvcnQgeyBWaXJ0dWFsTmV0d29yayB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvdmlydHVhbC1uZXR3b3JrXCI7XG5pbXBvcnQgeyBDb25zdHJ1Y3QgfSBmcm9tIFwiY29uc3RydWN0c1wiO1xuaW1wb3J0IHsgUGVlclByb3BzLCBQZWVyLCBQZWVyU2V0dGluZ3MgfSBmcm9tIFwiLi9wZWVyaW5nXCI7XG5pbXBvcnQgeyBBenVyZVJlc291cmNlIH0gZnJvbSBcIi4uLy4uL2NvcmUtYXp1cmUvbGliXCI7XG5cbi8qKlxuICogQ29uZmlndXJhdGlvbiBwcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhIHN1Ym5ldCB3aXRoaW4gYW4gQXp1cmUgVmlydHVhbCBOZXR3b3JrLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFN1Ym5ldENvbmZpZyB7XG4gIC8qKlxuICAgKiBUaGUgbmFtZSBvZiB0aGUgc3VibmV0LiBUaGlzIG5hbWUgbXVzdCBiZSB1bmlxdWUgd2l0aGluIHRoZSBjb250ZXh0IG9mIHRoZSB2aXJ0dWFsIG5ldHdvcmsuXG4gICAqL1xuICByZWFkb25seSBuYW1lOiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIEEgbGlzdCBvZiBhZGRyZXNzIHByZWZpeGVzIGZvciB0aGUgc3VibmV0LiBUaGVzZSBhcmUgZXhwcmVzc2VkIGluIENJRFIgbm90YXRpb24uXG4gICAqIEZvciBleGFtcGxlLCAnMTkyLjE2OC4xLjAvMjQnIHRvIGRlZmluZSBhIHN1Ym5ldCB3aXRoIGEgcmFuZ2Ugb2YgSVAgYWRkcmVzc2VzLlxuICAgKi9cbiAgcmVhZG9ubHkgYWRkcmVzc1ByZWZpeGVzOiBzdHJpbmdbXTtcbn1cblxuLyoqXG4gKiBQcm9wZXJ0aWVzIGZvciBkZWZpbmluZyBhbiBBenVyZSBWaXJ0dWFsIE5ldHdvcmsuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgTmV0d29ya1Byb3BzIHtcbiAgLyoqXG4gICAqIFRoZSBuYW1lIG9mIHRoZSByZXNvdXJjZSBncm91cCB1bmRlciB3aGljaCB0aGUgdmlydHVhbCBuZXR3b3JrIHdpbGwgYmUgY3JlYXRlZC5cbiAgICovXG4gIHJlYWRvbmx5IHJlc291cmNlR3JvdXA6IFJlc291cmNlR3JvdXA7XG5cbiAgLyoqXG4gICAqIE9wdGlvbmFsOiBUaGUgbmFtZSBvZiB0aGUgdmlydHVhbCBuZXR3b3JrLiBNdXN0IGJlIHVuaXF1ZSB3aXRoaW4gdGhlIHJlc291cmNlIGdyb3VwLlxuICAgKiBJZiBub3QgcHJvdmlkZWQsIGEgZGVmYXVsdCBuYW1lIHdpbGwgYmUgYXNzaWduZWQuXG4gICAqL1xuICByZWFkb25seSBuYW1lPzogc3RyaW5nO1xuXG4gIC8qKlxuICAgKiBPcHRpb25hbDogVGhlIEF6dXJlIHJlZ2lvbiBpbiB3aGljaCB0byBjcmVhdGUgdGhlIHZpcnR1YWwgbmV0d29yaywgZS5nLiwgJ0Vhc3QgVVMnLCAnV2VzdCBFdXJvcGUnLlxuICAgKiBJZiBub3Qgc3BlY2lmaWVkLCB0aGUgcmVnaW9uIG9mIHRoZSByZXNvdXJjZSBncm91cCB3aWxsIGJlIHVzZWQuXG4gICAqL1xuICByZWFkb25seSBsb2NhdGlvbj86IHN0cmluZztcblxuICAvKipcbiAgICogT3B0aW9uYWw6IEEgbGlzdCBvZiBhZGRyZXNzIHNwYWNlcyBmb3IgdGhlIHZpcnR1YWwgbmV0d29yaywgc3BlY2lmaWVkIGluIENJRFIgbm90YXRpb24uXG4gICAqIEZvciBleGFtcGxlLCBbJzEwLjAuMC4wLzE2J10gZGVmaW5lcyBhIHNpbmdsZSBhZGRyZXNzIHNwYWNlLiBNdWx0aXBsZSBhZGRyZXNzIHNwYWNlcyBjYW4gYmUgcHJvdmlkZWQuXG4gICAqL1xuICByZWFkb25seSBhZGRyZXNzU3BhY2U/OiBzdHJpbmdbXTtcblxuICAvKipcbiAgICogT3B0aW9uYWw6IEFuIGFycmF5IG9mIHN1Ym5ldCBjb25maWd1cmF0aW9ucyB0byBiZSBjcmVhdGVkIHdpdGhpbiB0aGUgdmlydHVhbCBuZXR3b3JrLlxuICAgKiBFYWNoIHN1Ym5ldCBpcyBkZWZpbmVkIGJ5IGl0cyBuYW1lIGFuZCBhZGRyZXNzIHByZWZpeChlcykuXG4gICAqL1xuICByZWFkb25seSBzdWJuZXRzPzogU3VibmV0Q29uZmlnW107XG59XG5cbmV4cG9ydCBjbGFzcyBOZXR3b3JrIGV4dGVuZHMgQXp1cmVSZXNvdXJjZSB7XG4gIHJlYWRvbmx5IHByb3BzOiBOZXR3b3JrUHJvcHM7XG4gIHB1YmxpYyByZWFkb25seSBuYW1lOiBzdHJpbmc7XG4gIHB1YmxpYyByZXNvdXJjZUdyb3VwOiBSZXNvdXJjZUdyb3VwO1xuICBwdWJsaWMgaWQ6IHN0cmluZztcbiAgcHVibGljIHJlYWRvbmx5IHZpcnR1YWxOZXR3b3JrOiBWaXJ0dWFsTmV0d29yaztcbiAgcHVibGljIHJlYWRvbmx5IHN1Ym5ldHM6IHsgW25hbWU6IHN0cmluZ106IFN1Ym5ldCB9ID0ge307IC8vIE1hcCBvZiBzdWJuZXQgbmFtZSB0byBTdWJuZXQgb2JqZWN0XG5cbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgaWQ6IHN0cmluZywgcHJvcHM6IE5ldHdvcmtQcm9wcykge1xuICAgIHN1cGVyKHNjb3BlLCBpZCk7XG5cbiAgICB0aGlzLnByb3BzID0gcHJvcHM7XG5cbiAgICBjb25zdCBkZWZhdWx0cyA9IHtcbiAgICAgIG5hbWU6IHByb3BzLm5hbWUgfHwgYHZuZXQtJHt0aGlzLm5vZGUucGF0aC5zcGxpdChcIi9cIilbMF19YCxcbiAgICAgIGxvY2F0aW9uOiBwcm9wcy5sb2NhdGlvbiB8fCBcImVhc3R1c1wiLFxuICAgICAgYWRkcmVzc1NwYWNlOiBwcm9wcy5hZGRyZXNzU3BhY2UgfHwgW1wiMTAuMC4wLjAvMTZcIl0sXG4gICAgICBzdWJuZXRzOiBwcm9wcy5zdWJuZXRzIHx8IFtcbiAgICAgICAge1xuICAgICAgICAgIG5hbWU6IFwiZGVmYXVsdFwiLFxuICAgICAgICAgIGFkZHJlc3NQcmVmaXhlczogW1wiMTAuMS4wLjAvMjRcIl0sXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH07XG5cbiAgICAvLyBDcmVhdGUgYSB2aXJ0dWFsIG5ldHdvcmtcbiAgICBjb25zdCB2bmV0ID0gbmV3IFZpcnR1YWxOZXR3b3JrKHRoaXMsIFwidm5ldFwiLCB7XG4gICAgICAuLi5kZWZhdWx0cyxcbiAgICAgIHJlc291cmNlR3JvdXBOYW1lOiBwcm9wcy5yZXNvdXJjZUdyb3VwLm5hbWUsXG4gICAgfSk7XG5cbiAgICB0aGlzLm5hbWUgPSB2bmV0Lm5hbWU7XG4gICAgdGhpcy5pZCA9IHZuZXQuaWQ7XG4gICAgdGhpcy5yZXNvdXJjZUdyb3VwID0gcHJvcHMucmVzb3VyY2VHcm91cDtcbiAgICB0aGlzLnZpcnR1YWxOZXR3b3JrID0gdm5ldDtcblxuICAgIC8vIENyZWF0ZSBzdWJuZXRzIHdpdGhpbiB0aGUgdmlydHVhbCBuZXR3b3JrXG4gICAgZm9yIChjb25zdCBzdWJuZXRDb25maWcgb2YgZGVmYXVsdHMuc3VibmV0cykge1xuICAgICAgY29uc3Qgc3VibmV0ID0gbmV3IFN1Ym5ldCh0aGlzLCBzdWJuZXRDb25maWcubmFtZSwge1xuICAgICAgICBuYW1lOiBzdWJuZXRDb25maWcubmFtZSxcbiAgICAgICAgcmVzb3VyY2VHcm91cE5hbWU6IHByb3BzLnJlc291cmNlR3JvdXAubmFtZSxcbiAgICAgICAgdmlydHVhbE5ldHdvcmtOYW1lOiB2bmV0Lm5hbWUsXG4gICAgICAgIGFkZHJlc3NQcmVmaXhlczogc3VibmV0Q29uZmlnLmFkZHJlc3NQcmVmaXhlcyxcbiAgICAgIH0pO1xuXG4gICAgICB0aGlzLnN1Ym5ldHNbc3VibmV0Q29uZmlnLm5hbWVdID0gc3VibmV0OyAvLyBQb3B1bGF0ZSB0aGUgc3VibmV0c01hcFxuICAgIH1cbiAgfVxuXG4gIC8vIENyZWF0ZSBWbmV0IFBlZXJpbmcgTWV0aG9kXG4gIHB1YmxpYyBhZGRWbmV0UGVlcmluZyhcbiAgICByZW1vdGVWaXJ0dWFsTmV0d29yazogTmV0d29yayxcbiAgICBsb2NhbFBlZXJTZXR0aW5ncz86IFBlZXJTZXR0aW5ncyxcbiAgICByZW1vdGVQZWVyU2V0dGluZ3M/OiBQZWVyU2V0dGluZ3MsXG4gICkge1xuICAgIGNvbnN0IHZuZXRQZWVyUHJvcHM6IFBlZXJQcm9wcyA9IHtcbiAgICAgIHZpcnR1YWxOZXR3b3JrOiB0aGlzLFxuICAgICAgcmVtb3RlVmlydHVhbE5ldHdvcms6IHJlbW90ZVZpcnR1YWxOZXR3b3JrLFxuICAgICAgbG9jYWxUb1JlbW90ZVNldHRpbmdzOiBsb2NhbFBlZXJTZXR0aW5ncyxcbiAgICAgIHJlbW90ZVRvTG9jYWxTZXR0aW5nczogcmVtb3RlUGVlclNldHRpbmdzLFxuICAgIH07XG4gICAgbmV3IFBlZXIodGhpcywgcmVtb3RlVmlydHVhbE5ldHdvcmsuaWQsIHZuZXRQZWVyUHJvcHMpO1xuICB9XG59XG4iXX0=
119
+ Network[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualnetwork.Network", version: "0.0.3-pre.7" };
120
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network.js","sourceRoot":"","sources":["../../../src/azure-virtualnetwork/lib/network.ts"],"names":[],"mappings":";;;;;AACA,+DAA4D;AAC5D,iFAA6E;AAE7E,uCAA0D;AAC1D,8CAAqD;AAoDrD,MAAa,OAAQ,SAAQ,mBAAa;IAOxC;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA4BG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAAmB;QAC3D,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QA/BH,YAAO,GAA+B,EAAE,CAAC,CAAC,sCAAsC;QAiC9F,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,MAAM,QAAQ,GAAG;YACf,IAAI,EAAE,KAAK,CAAC,IAAI,IAAI,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE;YAC1D,QAAQ,EAAE,KAAK,CAAC,QAAQ,IAAI,QAAQ;YACpC,YAAY,EAAE,KAAK,CAAC,YAAY,IAAI,CAAC,aAAa,CAAC;YACnD,OAAO,EAAE,KAAK,CAAC,OAAO,IAAI;gBACxB;oBACE,IAAI,EAAE,SAAS;oBACf,eAAe,EAAE,CAAC,aAAa,CAAC;iBACjC;aACF;SACF,CAAC;QAEF,2BAA2B;QAC3B,MAAM,IAAI,GAAG,IAAI,gCAAc,CAAC,IAAI,EAAE,MAAM,EAAE;YAC5C,GAAG,QAAQ;YACX,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC,IAAI;SAC5C,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,IAAI,CAAC,EAAE,GAAG,IAAI,CAAC,EAAE,CAAC;QAClB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,aAAa,CAAC;QACzC,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAE3B,4CAA4C;QAC5C,KAAK,MAAM,YAAY,IAAI,QAAQ,CAAC,OAAO,EAAE;YAC3C,MAAM,MAAM,GAAG,IAAI,eAAM,CAAC,IAAI,EAAE,YAAY,CAAC,IAAI,EAAE;gBACjD,IAAI,EAAE,YAAY,CAAC,IAAI;gBACvB,iBAAiB,EAAE,KAAK,CAAC,aAAa,CAAC,IAAI;gBAC3C,kBAAkB,EAAE,IAAI,CAAC,IAAI;gBAC7B,eAAe,EAAE,YAAY,CAAC,eAAe;aAC9C,CAAC,CAAC;YAEH,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,CAAC,0BAA0B;SACrE;IACH,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACI,cAAc,CACnB,oBAA6B,EAC7B,iBAAgC,EAChC,kBAAiC;QAEjC,MAAM,aAAa,GAAc;YAC/B,cAAc,EAAE,IAAI;YACpB,oBAAoB,EAAE,oBAAoB;YAC1C,qBAAqB,EAAE,iBAAiB;YACxC,qBAAqB,EAAE,kBAAkB;SAC1C,CAAC;QACF,IAAI,cAAI,CAAC,IAAI,EAAE,oBAAoB,CAAC,EAAE,EAAE,aAAa,CAAC,CAAC;IACzD,CAAC;;AAzHH,0BA0HC","sourcesContent":["import { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport { Subnet } from \"@cdktf/provider-azurerm/lib/subnet\";\nimport { VirtualNetwork } from \"@cdktf/provider-azurerm/lib/virtual-network\";\nimport { Construct } from \"constructs\";\nimport { PeerProps, Peer, PeerSettings } from \"./peering\";\nimport { AzureResource } from \"../../core-azure/lib\";\n\n/**\n * Configuration properties for defining a subnet within an Azure Virtual Network.\n */\nexport interface SubnetConfig {\n  /**\n   * The name of the subnet. This name must be unique within the context of the virtual network.\n   */\n  readonly name: string;\n\n  /**\n   * A list of address prefixes for the subnet. These are expressed in CIDR notation.\n   * For example, '192.168.1.0/24' to define a subnet with a range of IP addresses.\n   */\n  readonly addressPrefixes: string[];\n}\n\n/**\n * Properties for defining an Azure Virtual Network.\n */\nexport interface NetworkProps {\n  /**\n   * The name of the resource group under which the virtual network will be created.\n   */\n  readonly resourceGroup: ResourceGroup;\n\n  /**\n   * Optional: The name of the virtual network. Must be unique within the resource group.\n   * If not provided, a default name will be assigned.\n   */\n  readonly name?: string;\n\n  /**\n   * Optional: The Azure region in which to create the virtual network, e.g., 'East US', 'West Europe'.\n   * If not specified, the region of the resource group will be used.\n   */\n  readonly location?: string;\n\n  /**\n   * Optional: A list of address spaces for the virtual network, specified in CIDR notation.\n   * For example, ['10.0.0.0/16'] defines a single address space. Multiple address spaces can be provided.\n   */\n  readonly addressSpace?: string[];\n\n  /**\n   * Optional: An array of subnet configurations to be created within the virtual network.\n   * Each subnet is defined by its name and address prefix(es).\n   */\n  readonly subnets?: SubnetConfig[];\n}\n\nexport class Network extends AzureResource {\n  readonly props: NetworkProps;\n  public readonly name: string;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n  public readonly virtualNetwork: VirtualNetwork;\n  public readonly subnets: { [name: string]: Subnet } = {}; // Map of subnet name to Subnet object\n  /**\n   * Represents an Azure Virtual Network (VNet) within Microsoft Azure.\n   *\n   * This class is responsible for the creation and management of a virtual network, which provides an isolated environment\n   * where Azure resources, such as VMs and databases, can securely communicate with each other, the internet, and on-premises\n   * networks. It supports configurations such as multiple address spaces and subnets, enabling complex networking scenarios.\n   *\n   * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.\n   * @param id - The unique identifier for this instance of the network, used within the scope for reference.\n   * @param props - Configuration properties for the Azure Virtual Network, derived from the NetworkProps interface. These include:\n   *                - `resourceGroup`: The ResourceGroup within which the virtual network will be created.\n   *                - `name`: Optional. The name of the virtual network. If not provided, a default name will be assigned.\n   *                - `location`: Optional. The Azure region where the virtual network will be deployed. Defaults to the resource group's region.\n   *                - `addressSpace`: Optional. A list of CIDR blocks that define the address spaces of the virtual network.\n   *                - `subnets`: Optional. An array of subnets to be created within the virtual network, each defined by a name and a CIDR block.\n   *\n   * Example usage:\n   * ```typescript\n   * const network = new Network(this, 'MyVirtualNetwork', {\n   *   resourceGroup: myResourceGroup,\n   *   name: 'myVNet',\n   *   location: 'West US',\n   *   addressSpace: ['10.0.0.0/16'],\n   *   subnets: [{ name: 'subnet1', addressPrefixes: ['10.0.1.0/24'] }]\n   * });\n   * ```\n   * This class initializes a virtual network with the specified configurations and handles the provisioning of subnets\n   * within the network, providing a foundational networking layer for hosting cloud resources.\n   */\n  constructor(scope: Construct, id: string, props: NetworkProps) {\n    super(scope, id);\n\n    this.props = props;\n\n    const defaults = {\n      name: props.name || `vnet-${this.node.path.split(\"/\")[0]}`,\n      location: props.location || \"eastus\",\n      addressSpace: props.addressSpace || [\"10.0.0.0/16\"],\n      subnets: props.subnets || [\n        {\n          name: \"default\",\n          addressPrefixes: [\"10.1.0.0/24\"],\n        },\n      ],\n    };\n\n    // Create a virtual network\n    const vnet = new VirtualNetwork(this, \"vnet\", {\n      ...defaults,\n      resourceGroupName: props.resourceGroup.name,\n    });\n\n    this.name = vnet.name;\n    this.id = vnet.id;\n    this.resourceGroup = props.resourceGroup;\n    this.virtualNetwork = vnet;\n\n    // Create subnets within the virtual network\n    for (const subnetConfig of defaults.subnets) {\n      const subnet = new Subnet(this, subnetConfig.name, {\n        name: subnetConfig.name,\n        resourceGroupName: props.resourceGroup.name,\n        virtualNetworkName: vnet.name,\n        addressPrefixes: subnetConfig.addressPrefixes,\n      });\n\n      this.subnets[subnetConfig.name] = subnet; // Populate the subnetsMap\n    }\n  }\n\n  /**\n   * Establishes a peering connection between this virtual network and another remote virtual network.\n   *\n   * This method configures a two-way peering connection, allowing resources in both virtual networks to communicate\n   * seamlessly. It sets up peering settings such as network access, traffic forwarding, and gateway transit based on\n   * provided configurations.\n   *\n   * @param remoteVirtualNetwork - The remote virtual network with which to establish a peering connection.\n   * @param localPeerSettings - Optional settings applied from this virtual network to the remote virtual network.\n   *                             Controls aspects like virtual network access, traffic forwarding, and use of gateways.\n   * @param remotePeerSettings - Optional settings applied from the remote virtual network to this virtual network.\n   *                             Allows customization of how the remote network interacts with this one.\n   *\n   * Example usage:\n   * ```typescript\n   * // Assuming 'this' is a reference to a local virtual network instance.\n   * const partnerVNet = new Network(this, 'PartnerVNet', { ... });\n   * this.addVnetPeering(partnerVNet, {\n   *   allowVirtualNetworkAccess: true,\n   *   allowForwardedTraffic: false,\n   *   allowGatewayTransit: true,\n   *   useRemoteGateways: false\n   * }, {\n   *   allowVirtualNetworkAccess: true,\n   *   allowForwardedTraffic: true,\n   *   allowGatewayTransit: false,\n   *   useRemoteGateways: false\n   * });\n   * ```\n   * This method invokes the `Peer` class to create a peering between 'this' virtual network and 'partnerVNet'.\n   * The settings control traffic behavior and access permissions in both directions of the peering.\n   */\n  public addVnetPeering(\n    remoteVirtualNetwork: Network,\n    localPeerSettings?: PeerSettings,\n    remotePeerSettings?: PeerSettings,\n  ) {\n    const vnetPeerProps: PeerProps = {\n      virtualNetwork: this,\n      remoteVirtualNetwork: remoteVirtualNetwork,\n      localToRemoteSettings: localPeerSettings,\n      remoteToLocalSettings: remotePeerSettings,\n    };\n    new Peer(this, remoteVirtualNetwork.id, vnetPeerProps);\n  }\n}\n"]}
@@ -47,5 +47,44 @@ export interface PeerProps {
47
47
  readonly remoteToLocalSettings: PeerSettings | undefined;
48
48
  }
49
49
  export declare class Peer extends Construct {
50
+ /**
51
+ * Represents a Virtual Network Peering within Microsoft Azure.
52
+ *
53
+ * This class facilitates the peering between two virtual networks, allowing resources in either network to communicate
54
+ * with each other as if they were within the same network. It supports advanced configurations such as traffic forwarding,
55
+ * gateway transit, and access settings. This peering does not require a VPN gateway and offers low-latency, high-bandwidth
56
+ * connections between resources in different virtual networks.
57
+ *
58
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.
59
+ * @param name - The unique name for this instance of the network peering.
60
+ * @param props - Configuration properties for the network peering, derived from the PeerProps interface. These include:
61
+ * - `virtualNetwork`: The local virtual network object.
62
+ * - `remoteVirtualNetwork`: The remote virtual network object.
63
+ * - `localToRemoteSettings`: Configuration settings applied from the local virtual network to the remote virtual network.
64
+ * - `remoteToLocalSettings`: Configuration settings applied from the remote virtual network to the local virtual network.
65
+ *
66
+ * Example usage:
67
+ * ```typescript
68
+ * const vnetPeering = new Peer(this, 'VNetPeering', {
69
+ * virtualNetwork: myVNet,
70
+ * remoteVirtualNetwork: partnerVNet,
71
+ * localToRemoteSettings: {
72
+ * allowVirtualNetworkAccess: true,
73
+ * allowForwardedTraffic: false,
74
+ * allowGatewayTransit: false,
75
+ * useRemoteGateways: false
76
+ * },
77
+ * remoteToLocalSettings: {
78
+ * allowVirtualNetworkAccess: true,
79
+ * allowForwardedTraffic: true,
80
+ * allowGatewayTransit: false,
81
+ * useRemoteGateways: false
82
+ * }
83
+ * });
84
+ * ```
85
+ * This class initializes a VNet peering with the specified configurations, enabling direct connectivity between
86
+ * the specified virtual networks. It manages the creation and configuration of network peering settings, ensuring
87
+ * that both VNets are appropriately linked and configured according to the defined properties.
88
+ */
50
89
  constructor(scope: Construct, name: string, props: PeerProps);
51
90
  }
@@ -6,6 +6,45 @@ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
6
  const virtual_network_peering_1 = require("@cdktf/provider-azurerm/lib/virtual-network-peering");
7
7
  const constructs_1 = require("constructs");
8
8
  class Peer extends constructs_1.Construct {
9
+ /**
10
+ * Represents a Virtual Network Peering within Microsoft Azure.
11
+ *
12
+ * This class facilitates the peering between two virtual networks, allowing resources in either network to communicate
13
+ * with each other as if they were within the same network. It supports advanced configurations such as traffic forwarding,
14
+ * gateway transit, and access settings. This peering does not require a VPN gateway and offers low-latency, high-bandwidth
15
+ * connections between resources in different virtual networks.
16
+ *
17
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) application.
18
+ * @param name - The unique name for this instance of the network peering.
19
+ * @param props - Configuration properties for the network peering, derived from the PeerProps interface. These include:
20
+ * - `virtualNetwork`: The local virtual network object.
21
+ * - `remoteVirtualNetwork`: The remote virtual network object.
22
+ * - `localToRemoteSettings`: Configuration settings applied from the local virtual network to the remote virtual network.
23
+ * - `remoteToLocalSettings`: Configuration settings applied from the remote virtual network to the local virtual network.
24
+ *
25
+ * Example usage:
26
+ * ```typescript
27
+ * const vnetPeering = new Peer(this, 'VNetPeering', {
28
+ * virtualNetwork: myVNet,
29
+ * remoteVirtualNetwork: partnerVNet,
30
+ * localToRemoteSettings: {
31
+ * allowVirtualNetworkAccess: true,
32
+ * allowForwardedTraffic: false,
33
+ * allowGatewayTransit: false,
34
+ * useRemoteGateways: false
35
+ * },
36
+ * remoteToLocalSettings: {
37
+ * allowVirtualNetworkAccess: true,
38
+ * allowForwardedTraffic: true,
39
+ * allowGatewayTransit: false,
40
+ * useRemoteGateways: false
41
+ * }
42
+ * });
43
+ * ```
44
+ * This class initializes a VNet peering with the specified configurations, enabling direct connectivity between
45
+ * the specified virtual networks. It manages the creation and configuration of network peering settings, ensuring
46
+ * that both VNets are appropriately linked and configured according to the defined properties.
47
+ */
9
48
  constructor(scope, name, props) {
10
49
  super(scope, name);
11
50
  const localtoRemotePeerName = props.virtualNetwork.name + "to" + props.remoteVirtualNetwork.name;
@@ -28,5 +67,5 @@ class Peer extends constructs_1.Construct {
28
67
  }
29
68
  exports.Peer = Peer;
30
69
  _a = JSII_RTTI_SYMBOL_1;
31
- Peer[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualnetwork.Peer", version: "0.0.3-pre.6" };
32
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVlcmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9henVyZS12aXJ0dWFsbmV0d29yay9saWIvcGVlcmluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGlHQUE0RjtBQUM1RiwyQ0FBdUM7QUF5RHZDLE1BQWEsSUFBSyxTQUFRLHNCQUFTO0lBQ2pDLFlBQVksS0FBZ0IsRUFBRSxJQUFZLEVBQUUsS0FBZ0I7UUFDMUQsS0FBSyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVuQixNQUFNLHFCQUFxQixHQUN6QixLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksR0FBRyxJQUFJLEdBQUcsS0FBSyxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQztRQUVyRSxJQUFJLCtDQUFxQixDQUFDLElBQUksRUFBRSx1QkFBdUIsRUFBRTtZQUN2RCxJQUFJLEVBQUUscUJBQXFCO1lBQzNCLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLElBQUk7WUFDMUQsa0JBQWtCLEVBQUUsS0FBSyxDQUFDLGNBQWMsQ0FBQyxJQUFJO1lBQzdDLHNCQUFzQixFQUFFLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxFQUFFO1lBQ3JELEdBQUcsS0FBSyxDQUFDLHFCQUFxQjtTQUMvQixDQUFDLENBQUM7UUFFSCxNQUFNLHFCQUFxQixHQUN6QixLQUFLLENBQUMsb0JBQW9CLENBQUMsSUFBSSxHQUFHLElBQUksR0FBRyxLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztRQUVyRSxJQUFJLCtDQUFxQixDQUFDLElBQUksRUFBRSx1QkFBdUIsRUFBRTtZQUN2RCxJQUFJLEVBQUUscUJBQXFCO1lBQzNCLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxhQUFhLENBQUMsSUFBSTtZQUNoRSxrQkFBa0IsRUFBRSxLQUFLLENBQUMsb0JBQW9CLENBQUMsSUFBSTtZQUNuRCxzQkFBc0IsRUFBRSxLQUFLLENBQUMsY0FBYyxDQUFDLEVBQUU7WUFDL0MsR0FBRyxLQUFLLENBQUMscUJBQXFCO1NBQy9CLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBekJILG9CQTBCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZpcnR1YWxOZXR3b3JrUGVlcmluZyB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvdmlydHVhbC1uZXR3b3JrLXBlZXJpbmdcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgeyBOZXR3b3JrIH0gZnJvbSBcIi4vbmV0d29ya1wiO1xuXG4vKipcbiAqIEludGVyZmFjZSBkZWZpbmluZyB0aGUgc2V0dGluZ3MgZm9yIHBlZXIgY29ubmVjdGlvbnMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUGVlclNldHRpbmdzIHtcbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHZpcnR1YWwgbmV0d29yayBhY2Nlc3MgaXMgYWxsb3dlZC5cbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgYWxsb3dWaXJ0dWFsTmV0d29ya0FjY2Vzcz86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIGZvcndhcmRlZCB0cmFmZmljIGlzIGFsbG93ZWQuXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBhbGxvd0ZvcndhcmRlZFRyYWZmaWM/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciBnYXRld2F5IHRyYW5zaXQgaXMgYWxsb3dlZC5cbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IGFsbG93R2F0ZXdheVRyYW5zaXQ/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0byB1c2UgcmVtb3RlIGdhdGV3YXlzLlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgdXNlUmVtb3RlR2F0ZXdheXM/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIEludGVyZmFjZSBkZWZpbmluZyB0aGUgcHJvcGVydGllcyBmb3IgdmlydHVhbCBuZXR3b3JrIHBlZXJpbmdzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBlZXJQcm9wcyB7XG4gIC8qKlxuICAgKiBJRCBvZiB0aGUgbG9jYWwgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgdmlydHVhbE5ldHdvcms6IE5ldHdvcms7XG5cbiAgLyoqXG4gICAqIElEIG9mIHRoZSByZW1vdGUgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgcmVtb3RlVmlydHVhbE5ldHdvcms6IE5ldHdvcms7XG5cbiAgLyoqXG4gICAqIFNldHRpbmdzIGFwcGxpZWQgZnJvbSB0aGUgbG9jYWwgdmlydHVhbCBuZXR3b3JrIHRvIHRoZSByZW1vdGUgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgbG9jYWxUb1JlbW90ZVNldHRpbmdzOiBQZWVyU2V0dGluZ3MgfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIFNldHRpbmdzIGFwcGxpZWQgZnJvbSB0aGUgcmVtb3RlIHZpcnR1YWwgbmV0d29yayB0byB0aGUgbG9jYWwgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgcmVtb3RlVG9Mb2NhbFNldHRpbmdzOiBQZWVyU2V0dGluZ3MgfCB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBjbGFzcyBQZWVyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgY29uc3RydWN0b3Ioc2NvcGU6IENvbnN0cnVjdCwgbmFtZTogc3RyaW5nLCBwcm9wczogUGVlclByb3BzKSB7XG4gICAgc3VwZXIoc2NvcGUsIG5hbWUpO1xuXG4gICAgY29uc3QgbG9jYWx0b1JlbW90ZVBlZXJOYW1lID1cbiAgICAgIHByb3BzLnZpcnR1YWxOZXR3b3JrLm5hbWUgKyBcInRvXCIgKyBwcm9wcy5yZW1vdGVWaXJ0dWFsTmV0d29yay5uYW1lO1xuXG4gICAgbmV3IFZpcnR1YWxOZXR3b3JrUGVlcmluZyh0aGlzLCBcIlZOZXRQZWVyTG9jYWx0b1JlbW90ZVwiLCB7XG4gICAgICBuYW1lOiBsb2NhbHRvUmVtb3RlUGVlck5hbWUsXG4gICAgICByZXNvdXJjZUdyb3VwTmFtZTogcHJvcHMudmlydHVhbE5ldHdvcmsucmVzb3VyY2VHcm91cC5uYW1lLFxuICAgICAgdmlydHVhbE5ldHdvcmtOYW1lOiBwcm9wcy52aXJ0dWFsTmV0d29yay5uYW1lLFxuICAgICAgcmVtb3RlVmlydHVhbE5ldHdvcmtJZDogcHJvcHMucmVtb3RlVmlydHVhbE5ldHdvcmsuaWQsXG4gICAgICAuLi5wcm9wcy5sb2NhbFRvUmVtb3RlU2V0dGluZ3MsXG4gICAgfSk7XG5cbiAgICBjb25zdCByZW1vdGVUb0xvY2FsUGVlck5hbWUgPVxuICAgICAgcHJvcHMucmVtb3RlVmlydHVhbE5ldHdvcmsubmFtZSArIFwidG9cIiArIHByb3BzLnZpcnR1YWxOZXR3b3JrLm5hbWU7XG5cbiAgICBuZXcgVmlydHVhbE5ldHdvcmtQZWVyaW5nKHRoaXMsIFwiVk5ldFBlZXJSZW1vdGV0b0xvY2FsXCIsIHtcbiAgICAgIG5hbWU6IHJlbW90ZVRvTG9jYWxQZWVyTmFtZSxcbiAgICAgIHJlc291cmNlR3JvdXBOYW1lOiBwcm9wcy5yZW1vdGVWaXJ0dWFsTmV0d29yay5yZXNvdXJjZUdyb3VwLm5hbWUsXG4gICAgICB2aXJ0dWFsTmV0d29ya05hbWU6IHByb3BzLnJlbW90ZVZpcnR1YWxOZXR3b3JrLm5hbWUsXG4gICAgICByZW1vdGVWaXJ0dWFsTmV0d29ya0lkOiBwcm9wcy52aXJ0dWFsTmV0d29yay5pZCxcbiAgICAgIC4uLnByb3BzLnJlbW90ZVRvTG9jYWxTZXR0aW5ncyxcbiAgICB9KTtcbiAgfVxufVxuIl19
70
+ Peer[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_virtualnetwork.Peer", version: "0.0.3-pre.7" };
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGVlcmluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9henVyZS12aXJ0dWFsbmV0d29yay9saWIvcGVlcmluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQUFBLGlHQUE0RjtBQUM1RiwyQ0FBdUM7QUF5RHZDLE1BQWEsSUFBSyxTQUFRLHNCQUFTO0lBQ2pDOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztPQXNDRztJQUNILFlBQVksS0FBZ0IsRUFBRSxJQUFZLEVBQUUsS0FBZ0I7UUFDMUQsS0FBSyxDQUFDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQztRQUVuQixNQUFNLHFCQUFxQixHQUN6QixLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksR0FBRyxJQUFJLEdBQUcsS0FBSyxDQUFDLG9CQUFvQixDQUFDLElBQUksQ0FBQztRQUVyRSxJQUFJLCtDQUFxQixDQUFDLElBQUksRUFBRSx1QkFBdUIsRUFBRTtZQUN2RCxJQUFJLEVBQUUscUJBQXFCO1lBQzNCLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLElBQUk7WUFDMUQsa0JBQWtCLEVBQUUsS0FBSyxDQUFDLGNBQWMsQ0FBQyxJQUFJO1lBQzdDLHNCQUFzQixFQUFFLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxFQUFFO1lBQ3JELEdBQUcsS0FBSyxDQUFDLHFCQUFxQjtTQUMvQixDQUFDLENBQUM7UUFFSCxNQUFNLHFCQUFxQixHQUN6QixLQUFLLENBQUMsb0JBQW9CLENBQUMsSUFBSSxHQUFHLElBQUksR0FBRyxLQUFLLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQztRQUVyRSxJQUFJLCtDQUFxQixDQUFDLElBQUksRUFBRSx1QkFBdUIsRUFBRTtZQUN2RCxJQUFJLEVBQUUscUJBQXFCO1lBQzNCLGlCQUFpQixFQUFFLEtBQUssQ0FBQyxvQkFBb0IsQ0FBQyxhQUFhLENBQUMsSUFBSTtZQUNoRSxrQkFBa0IsRUFBRSxLQUFLLENBQUMsb0JBQW9CLENBQUMsSUFBSTtZQUNuRCxzQkFBc0IsRUFBRSxLQUFLLENBQUMsY0FBYyxDQUFDLEVBQUU7WUFDL0MsR0FBRyxLQUFLLENBQUMscUJBQXFCO1NBQy9CLENBQUMsQ0FBQztJQUNMLENBQUM7O0FBaEVILG9CQWlFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFZpcnR1YWxOZXR3b3JrUGVlcmluZyB9IGZyb20gXCJAY2RrdGYvcHJvdmlkZXItYXp1cmVybS9saWIvdmlydHVhbC1uZXR3b3JrLXBlZXJpbmdcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgeyBOZXR3b3JrIH0gZnJvbSBcIi4vbmV0d29ya1wiO1xuXG4vKipcbiAqIEludGVyZmFjZSBkZWZpbmluZyB0aGUgc2V0dGluZ3MgZm9yIHBlZXIgY29ubmVjdGlvbnMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgUGVlclNldHRpbmdzIHtcbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIHZpcnR1YWwgbmV0d29yayBhY2Nlc3MgaXMgYWxsb3dlZC5cbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgcmVhZG9ubHkgYWxsb3dWaXJ0dWFsTmV0d29ya0FjY2Vzcz86IGJvb2xlYW47XG5cbiAgLyoqXG4gICAqIEluZGljYXRlcyB3aGV0aGVyIGZvcndhcmRlZCB0cmFmZmljIGlzIGFsbG93ZWQuXG4gICAqIEBkZWZhdWx0IGZhbHNlXG4gICAqL1xuICByZWFkb25seSBhbGxvd0ZvcndhcmRlZFRyYWZmaWM/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciBnYXRld2F5IHRyYW5zaXQgaXMgYWxsb3dlZC5cbiAgICogQGRlZmF1bHQgZmFsc2VcbiAgICovXG4gIHJlYWRvbmx5IGFsbG93R2F0ZXdheVRyYW5zaXQ/OiBib29sZWFuO1xuXG4gIC8qKlxuICAgKiBJbmRpY2F0ZXMgd2hldGhlciB0byB1c2UgcmVtb3RlIGdhdGV3YXlzLlxuICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgKi9cbiAgcmVhZG9ubHkgdXNlUmVtb3RlR2F0ZXdheXM/OiBib29sZWFuO1xufVxuXG4vKipcbiAqIEludGVyZmFjZSBkZWZpbmluZyB0aGUgcHJvcGVydGllcyBmb3IgdmlydHVhbCBuZXR3b3JrIHBlZXJpbmdzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFBlZXJQcm9wcyB7XG4gIC8qKlxuICAgKiBJRCBvZiB0aGUgbG9jYWwgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgdmlydHVhbE5ldHdvcms6IE5ldHdvcms7XG5cbiAgLyoqXG4gICAqIElEIG9mIHRoZSByZW1vdGUgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgcmVtb3RlVmlydHVhbE5ldHdvcms6IE5ldHdvcms7XG5cbiAgLyoqXG4gICAqIFNldHRpbmdzIGFwcGxpZWQgZnJvbSB0aGUgbG9jYWwgdmlydHVhbCBuZXR3b3JrIHRvIHRoZSByZW1vdGUgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgbG9jYWxUb1JlbW90ZVNldHRpbmdzOiBQZWVyU2V0dGluZ3MgfCB1bmRlZmluZWQ7XG5cbiAgLyoqXG4gICAqIFNldHRpbmdzIGFwcGxpZWQgZnJvbSB0aGUgcmVtb3RlIHZpcnR1YWwgbmV0d29yayB0byB0aGUgbG9jYWwgdmlydHVhbCBuZXR3b3JrLlxuICAgKi9cbiAgcmVhZG9ubHkgcmVtb3RlVG9Mb2NhbFNldHRpbmdzOiBQZWVyU2V0dGluZ3MgfCB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBjbGFzcyBQZWVyIGV4dGVuZHMgQ29uc3RydWN0IHtcbiAgLyoqXG4gICAqIFJlcHJlc2VudHMgYSBWaXJ0dWFsIE5ldHdvcmsgUGVlcmluZyB3aXRoaW4gTWljcm9zb2Z0IEF6dXJlLlxuICAgKlxuICAgKiBUaGlzIGNsYXNzIGZhY2lsaXRhdGVzIHRoZSBwZWVyaW5nIGJldHdlZW4gdHdvIHZpcnR1YWwgbmV0d29ya3MsIGFsbG93aW5nIHJlc291cmNlcyBpbiBlaXRoZXIgbmV0d29yayB0byBjb21tdW5pY2F0ZVxuICAgKiB3aXRoIGVhY2ggb3RoZXIgYXMgaWYgdGhleSB3ZXJlIHdpdGhpbiB0aGUgc2FtZSBuZXR3b3JrLiBJdCBzdXBwb3J0cyBhZHZhbmNlZCBjb25maWd1cmF0aW9ucyBzdWNoIGFzIHRyYWZmaWMgZm9yd2FyZGluZyxcbiAgICogZ2F0ZXdheSB0cmFuc2l0LCBhbmQgYWNjZXNzIHNldHRpbmdzLiBUaGlzIHBlZXJpbmcgZG9lcyBub3QgcmVxdWlyZSBhIFZQTiBnYXRld2F5IGFuZCBvZmZlcnMgbG93LWxhdGVuY3ksIGhpZ2gtYmFuZHdpZHRoXG4gICAqIGNvbm5lY3Rpb25zIGJldHdlZW4gcmVzb3VyY2VzIGluIGRpZmZlcmVudCB2aXJ0dWFsIG5ldHdvcmtzLlxuICAgKlxuICAgKiBAcGFyYW0gc2NvcGUgLSBUaGUgc2NvcGUgaW4gd2hpY2ggdG8gZGVmaW5lIHRoaXMgY29uc3RydWN0LCB0eXBpY2FsbHkgcmVwcmVzZW50aW5nIHRoZSBDbG91ZCBEZXZlbG9wbWVudCBLaXQgKENESykgYXBwbGljYXRpb24uXG4gICAqIEBwYXJhbSBuYW1lIC0gVGhlIHVuaXF1ZSBuYW1lIGZvciB0aGlzIGluc3RhbmNlIG9mIHRoZSBuZXR3b3JrIHBlZXJpbmcuXG4gICAqIEBwYXJhbSBwcm9wcyAtIENvbmZpZ3VyYXRpb24gcHJvcGVydGllcyBmb3IgdGhlIG5ldHdvcmsgcGVlcmluZywgZGVyaXZlZCBmcm9tIHRoZSBQZWVyUHJvcHMgaW50ZXJmYWNlLiBUaGVzZSBpbmNsdWRlOlxuICAgKiAgICAgICAgICAgICAgICAtIGB2aXJ0dWFsTmV0d29ya2A6IFRoZSBsb2NhbCB2aXJ0dWFsIG5ldHdvcmsgb2JqZWN0LlxuICAgKiAgICAgICAgICAgICAgICAtIGByZW1vdGVWaXJ0dWFsTmV0d29ya2A6IFRoZSByZW1vdGUgdmlydHVhbCBuZXR3b3JrIG9iamVjdC5cbiAgICogICAgICAgICAgICAgICAgLSBgbG9jYWxUb1JlbW90ZVNldHRpbmdzYDogQ29uZmlndXJhdGlvbiBzZXR0aW5ncyBhcHBsaWVkIGZyb20gdGhlIGxvY2FsIHZpcnR1YWwgbmV0d29yayB0byB0aGUgcmVtb3RlIHZpcnR1YWwgbmV0d29yay5cbiAgICogICAgICAgICAgICAgICAgLSBgcmVtb3RlVG9Mb2NhbFNldHRpbmdzYDogQ29uZmlndXJhdGlvbiBzZXR0aW5ncyBhcHBsaWVkIGZyb20gdGhlIHJlbW90ZSB2aXJ0dWFsIG5ldHdvcmsgdG8gdGhlIGxvY2FsIHZpcnR1YWwgbmV0d29yay5cbiAgICpcbiAgICogRXhhbXBsZSB1c2FnZTpcbiAgICogYGBgdHlwZXNjcmlwdFxuICAgKiBjb25zdCB2bmV0UGVlcmluZyA9IG5ldyBQZWVyKHRoaXMsICdWTmV0UGVlcmluZycsIHtcbiAgICogICB2aXJ0dWFsTmV0d29yazogbXlWTmV0LFxuICAgKiAgIHJlbW90ZVZpcnR1YWxOZXR3b3JrOiBwYXJ0bmVyVk5ldCxcbiAgICogICBsb2NhbFRvUmVtb3RlU2V0dGluZ3M6IHtcbiAgICogICAgIGFsbG93VmlydHVhbE5ldHdvcmtBY2Nlc3M6IHRydWUsXG4gICAqICAgICBhbGxvd0ZvcndhcmRlZFRyYWZmaWM6IGZhbHNlLFxuICAgKiAgICAgYWxsb3dHYXRld2F5VHJhbnNpdDogZmFsc2UsXG4gICAqICAgICB1c2VSZW1vdGVHYXRld2F5czogZmFsc2VcbiAgICogICB9LFxuICAgKiAgIHJlbW90ZVRvTG9jYWxTZXR0aW5nczoge1xuICAgKiAgICAgYWxsb3dWaXJ0dWFsTmV0d29ya0FjY2VzczogdHJ1ZSxcbiAgICogICAgIGFsbG93Rm9yd2FyZGVkVHJhZmZpYzogdHJ1ZSxcbiAgICogICAgIGFsbG93R2F0ZXdheVRyYW5zaXQ6IGZhbHNlLFxuICAgKiAgICAgdXNlUmVtb3RlR2F0ZXdheXM6IGZhbHNlXG4gICAqICAgfVxuICAgKiB9KTtcbiAgICogYGBgXG4gICAqIFRoaXMgY2xhc3MgaW5pdGlhbGl6ZXMgYSBWTmV0IHBlZXJpbmcgd2l0aCB0aGUgc3BlY2lmaWVkIGNvbmZpZ3VyYXRpb25zLCBlbmFibGluZyBkaXJlY3QgY29ubmVjdGl2aXR5IGJldHdlZW5cbiAgICogdGhlIHNwZWNpZmllZCB2aXJ0dWFsIG5ldHdvcmtzLiBJdCBtYW5hZ2VzIHRoZSBjcmVhdGlvbiBhbmQgY29uZmlndXJhdGlvbiBvZiBuZXR3b3JrIHBlZXJpbmcgc2V0dGluZ3MsIGVuc3VyaW5nXG4gICAqIHRoYXQgYm90aCBWTmV0cyBhcmUgYXBwcm9wcmlhdGVseSBsaW5rZWQgYW5kIGNvbmZpZ3VyZWQgYWNjb3JkaW5nIHRvIHRoZSBkZWZpbmVkIHByb3BlcnRpZXMuXG4gICAqL1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBuYW1lOiBzdHJpbmcsIHByb3BzOiBQZWVyUHJvcHMpIHtcbiAgICBzdXBlcihzY29wZSwgbmFtZSk7XG5cbiAgICBjb25zdCBsb2NhbHRvUmVtb3RlUGVlck5hbWUgPVxuICAgICAgcHJvcHMudmlydHVhbE5ldHdvcmsubmFtZSArIFwidG9cIiArIHByb3BzLnJlbW90ZVZpcnR1YWxOZXR3b3JrLm5hbWU7XG5cbiAgICBuZXcgVmlydHVhbE5ldHdvcmtQZWVyaW5nKHRoaXMsIFwiVk5ldFBlZXJMb2NhbHRvUmVtb3RlXCIsIHtcbiAgICAgIG5hbWU6IGxvY2FsdG9SZW1vdGVQZWVyTmFtZSxcbiAgICAgIHJlc291cmNlR3JvdXBOYW1lOiBwcm9wcy52aXJ0dWFsTmV0d29yay5yZXNvdXJjZUdyb3VwLm5hbWUsXG4gICAgICB2aXJ0dWFsTmV0d29ya05hbWU6IHByb3BzLnZpcnR1YWxOZXR3b3JrLm5hbWUsXG4gICAgICByZW1vdGVWaXJ0dWFsTmV0d29ya0lkOiBwcm9wcy5yZW1vdGVWaXJ0dWFsTmV0d29yay5pZCxcbiAgICAgIC4uLnByb3BzLmxvY2FsVG9SZW1vdGVTZXR0aW5ncyxcbiAgICB9KTtcblxuICAgIGNvbnN0IHJlbW90ZVRvTG9jYWxQZWVyTmFtZSA9XG4gICAgICBwcm9wcy5yZW1vdGVWaXJ0dWFsTmV0d29yay5uYW1lICsgXCJ0b1wiICsgcHJvcHMudmlydHVhbE5ldHdvcmsubmFtZTtcblxuICAgIG5ldyBWaXJ0dWFsTmV0d29ya1BlZXJpbmcodGhpcywgXCJWTmV0UGVlclJlbW90ZXRvTG9jYWxcIiwge1xuICAgICAgbmFtZTogcmVtb3RlVG9Mb2NhbFBlZXJOYW1lLFxuICAgICAgcmVzb3VyY2VHcm91cE5hbWU6IHByb3BzLnJlbW90ZVZpcnR1YWxOZXR3b3JrLnJlc291cmNlR3JvdXAubmFtZSxcbiAgICAgIHZpcnR1YWxOZXR3b3JrTmFtZTogcHJvcHMucmVtb3RlVmlydHVhbE5ldHdvcmsubmFtZSxcbiAgICAgIHJlbW90ZVZpcnR1YWxOZXR3b3JrSWQ6IHByb3BzLnZpcnR1YWxOZXR3b3JrLmlkLFxuICAgICAgLi4ucHJvcHMucmVtb3RlVG9Mb2NhbFNldHRpbmdzLFxuICAgIH0pO1xuICB9XG59XG4iXX0=