@microsoft/terraform-cdk-constructs 1.7.1 → 1.9.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.jsii +46476 -27231
- package/API.md +68443 -28286
- package/lib/azure-actiongroup/lib/action-group.js +1 -1
- package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
- package/lib/azure-aks/lib/aks-cluster.js +1 -1
- package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
- package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
- package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
- package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
- package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
- package/lib/azure-dnszone/lib/dns-zone.js +1 -1
- package/lib/azure-dnszone/lib/index.d.ts +1 -0
- package/lib/azure-dnszone/lib/index.js +2 -1
- package/lib/azure-dnszone/lib/records/dns-record-schemas.d.ts +68 -0
- package/lib/azure-dnszone/lib/records/dns-record-schemas.js +813 -0
- package/lib/azure-dnszone/lib/records/dns-records.d.ts +688 -0
- package/lib/azure-dnszone/lib/records/dns-records.js +924 -0
- package/lib/azure-dnszone/lib/records/index.d.ts +19 -0
- package/lib/azure-dnszone/lib/records/index.js +38 -0
- package/lib/azure-dnszone/test/dns-records.integ.d.ts +21 -0
- package/lib/azure-dnszone/test/dns-records.integ.js +321 -0
- package/lib/azure-dnszone/test/dns-records.spec.d.ts +20 -0
- package/lib/azure-dnszone/test/dns-records.spec.js +950 -0
- package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
- package/lib/azure-loganalyticsworkspace/index.js +23 -0
- package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
- package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
- package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
- package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
- package/lib/azure-metricalert/lib/metric-alert.js +1 -1
- package/lib/azure-networkinterface/lib/network-interface.js +1 -1
- package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
- package/lib/azure-networkwatcher/index.d.ts +14 -0
- package/lib/azure-networkwatcher/index.js +31 -0
- package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
- package/lib/azure-networkwatcher/lib/index.js +22 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
- package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
- package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
- package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
- package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
- package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
- package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
- package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
- package/lib/azure-policysetdefinition/index.d.ts +10 -0
- package/lib/azure-policysetdefinition/index.js +27 -0
- package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
- package/lib/azure-policysetdefinition/lib/index.js +22 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
- package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
- package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
- package/lib/azure-privatednszone/lib/index.d.ts +1 -0
- package/lib/azure-privatednszone/lib/index.js +2 -1
- package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +0 -2
- package/lib/azure-privatednszone/lib/private-dns-zone.js +6 -13
- package/lib/azure-privatednszone/lib/records/index.d.ts +7 -0
- package/lib/azure-privatednszone/lib/records/index.js +26 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.d.ts +52 -0
- package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.js +683 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +523 -0
- package/lib/azure-privatednszone/lib/records/private-dns-records.js +739 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +19 -0
- package/lib/azure-privatednszone/test/private-dns-records.integ.js +245 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.d.ts +18 -0
- package/lib/azure-privatednszone/test/private-dns-records.spec.js +756 -0
- package/lib/azure-privatednszone/test/private-dns-zone.spec.js +5 -5
- package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
- package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
- package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
- package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
- package/lib/azure-roledefinition/lib/role-definition.js +1 -1
- package/lib/azure-storageaccount/lib/storage-account.js +1 -1
- package/lib/azure-subnet/lib/subnet.js +1 -1
- package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
- package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
- package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
- package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
- package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
- package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
- package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
- package/lib/core-azure/lib/azapi/azapi-resource.js +4 -4
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
- package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
- package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
- package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
- package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
- package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
- package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
- package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
- package/lib/index.d.ts +23 -0
- package/lib/index.js +25 -2
- package/lib/testing/index.js +2 -2
- package/lib/testing/lib/cleanup.js +1 -1
- package/lib/testing/lib/metadata.js +1 -1
- package/package.json +1 -1
|
@@ -219,7 +219,7 @@ class NetworkSecurityGroup extends azapi_resource_1.AzapiResource {
|
|
|
219
219
|
}
|
|
220
220
|
exports.NetworkSecurityGroup = NetworkSecurityGroup;
|
|
221
221
|
_a = JSII_RTTI_SYMBOL_1;
|
|
222
|
-
NetworkSecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkSecurityGroup", version: "1.
|
|
222
|
+
NetworkSecurityGroup[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkSecurityGroup", version: "1.9.0" };
|
|
223
223
|
(() => {
|
|
224
224
|
azapi_resource_1.AzapiResource.registerSchemas(network_security_group_schemas_1.NETWORK_SECURITY_GROUP_TYPE, network_security_group_schemas_1.ALL_NETWORK_SECURITY_GROUP_VERSIONS);
|
|
225
225
|
})();
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Azure Network Watcher module
|
|
3
|
+
*
|
|
4
|
+
* This module provides constructs for creating and managing Azure Network Watchers.
|
|
5
|
+
*
|
|
6
|
+
* Network Watcher is a regional service that provides network monitoring and diagnostic
|
|
7
|
+
* tools in Azure. It enables you to monitor and diagnose conditions at a network scenario
|
|
8
|
+
* level in, to, and from Azure.
|
|
9
|
+
*
|
|
10
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
11
|
+
* If you need Network Watcher functionality in multiple regions, you must create
|
|
12
|
+
* a separate Network Watcher for each region.
|
|
13
|
+
*/
|
|
14
|
+
export * from "./lib";
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure Network Watcher module
|
|
4
|
+
*
|
|
5
|
+
* This module provides constructs for creating and managing Azure Network Watchers.
|
|
6
|
+
*
|
|
7
|
+
* Network Watcher is a regional service that provides network monitoring and diagnostic
|
|
8
|
+
* tools in Azure. It enables you to monitor and diagnose conditions at a network scenario
|
|
9
|
+
* level in, to, and from Azure.
|
|
10
|
+
*
|
|
11
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
12
|
+
* If you need Network Watcher functionality in multiple regions, you must create
|
|
13
|
+
* a separate Network Watcher for each region.
|
|
14
|
+
*/
|
|
15
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
16
|
+
if (k2 === undefined) k2 = k;
|
|
17
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
18
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
19
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
20
|
+
}
|
|
21
|
+
Object.defineProperty(o, k2, desc);
|
|
22
|
+
}) : (function(o, m, k, k2) {
|
|
23
|
+
if (k2 === undefined) k2 = k;
|
|
24
|
+
o[k2] = m[k];
|
|
25
|
+
}));
|
|
26
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
27
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
28
|
+
};
|
|
29
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
30
|
+
__exportStar(require("./lib"), exports);
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYXp1cmUtbmV0d29ya3dhdGNoZXIvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7Ozs7Ozs7R0FZRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILHdDQUFzQiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQXp1cmUgTmV0d29yayBXYXRjaGVyIG1vZHVsZVxuICpcbiAqIFRoaXMgbW9kdWxlIHByb3ZpZGVzIGNvbnN0cnVjdHMgZm9yIGNyZWF0aW5nIGFuZCBtYW5hZ2luZyBBenVyZSBOZXR3b3JrIFdhdGNoZXJzLlxuICpcbiAqIE5ldHdvcmsgV2F0Y2hlciBpcyBhIHJlZ2lvbmFsIHNlcnZpY2UgdGhhdCBwcm92aWRlcyBuZXR3b3JrIG1vbml0b3JpbmcgYW5kIGRpYWdub3N0aWNcbiAqIHRvb2xzIGluIEF6dXJlLiBJdCBlbmFibGVzIHlvdSB0byBtb25pdG9yIGFuZCBkaWFnbm9zZSBjb25kaXRpb25zIGF0IGEgbmV0d29yayBzY2VuYXJpb1xuICogbGV2ZWwgaW4sIHRvLCBhbmQgZnJvbSBBenVyZS5cbiAqXG4gKiBJTVBPUlRBTlQ6IEF6dXJlIG9ubHkgYWxsb3dzIG9uZSBOZXR3b3JrIFdhdGNoZXIgcGVyIHN1YnNjcmlwdGlvbiBwZXIgcmVnaW9uLlxuICogSWYgeW91IG5lZWQgTmV0d29yayBXYXRjaGVyIGZ1bmN0aW9uYWxpdHkgaW4gbXVsdGlwbGUgcmVnaW9ucywgeW91IG11c3QgY3JlYXRlXG4gKiBhIHNlcGFyYXRlIE5ldHdvcmsgV2F0Y2hlciBmb3IgZWFjaCByZWdpb24uXG4gKi9cblxuZXhwb3J0ICogZnJvbSBcIi4vbGliXCI7XG4iXX0=
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Azure Network Watcher construct exports
|
|
4
|
+
*/
|
|
5
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
6
|
+
if (k2 === undefined) k2 = k;
|
|
7
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
8
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
9
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
10
|
+
}
|
|
11
|
+
Object.defineProperty(o, k2, desc);
|
|
12
|
+
}) : (function(o, m, k, k2) {
|
|
13
|
+
if (k2 === undefined) k2 = k;
|
|
14
|
+
o[k2] = m[k];
|
|
15
|
+
}));
|
|
16
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
17
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
18
|
+
};
|
|
19
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
20
|
+
__exportStar(require("./network-watcher-schemas"), exports);
|
|
21
|
+
__exportStar(require("./network-watcher"), exports);
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXp1cmUtbmV0d29ya3dhdGNoZXIvbGliL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7R0FFRzs7Ozs7Ozs7Ozs7Ozs7OztBQUVILDREQUEwQztBQUMxQyxvREFBa0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEF6dXJlIE5ldHdvcmsgV2F0Y2hlciBjb25zdHJ1Y3QgZXhwb3J0c1xuICovXG5cbmV4cG9ydCAqIGZyb20gXCIuL25ldHdvcmstd2F0Y2hlci1zY2hlbWFzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9uZXR3b3JrLXdhdGNoZXJcIjtcbiJdfQ==
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* API schemas for Azure Network Watcher across all supported versions
|
|
3
|
+
*
|
|
4
|
+
* This file defines the complete API schemas for Microsoft.Network/networkWatchers
|
|
5
|
+
* across all supported API versions. The schemas are used by the AzapiResource
|
|
6
|
+
* framework for validation, transformation, and version management.
|
|
7
|
+
*
|
|
8
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
9
|
+
* Network Watcher is primarily used as a dependency for other Network Watcher features like:
|
|
10
|
+
* - Flow Logs
|
|
11
|
+
* - Connection Monitor
|
|
12
|
+
* - Packet Capture
|
|
13
|
+
* - Network Diagnostic Tools
|
|
14
|
+
*/
|
|
15
|
+
import { ApiSchema, VersionConfig } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
16
|
+
/**
|
|
17
|
+
* API Schema for Network Watcher version 2024-01-01
|
|
18
|
+
*
|
|
19
|
+
* This is the latest stable version for Network Watcher.
|
|
20
|
+
* Network Watcher is a relatively simple resource - it primarily serves as
|
|
21
|
+
* an anchor for Network Watcher features in a region.
|
|
22
|
+
*/
|
|
23
|
+
export declare const NETWORK_WATCHER_SCHEMA_2024_01_01: ApiSchema;
|
|
24
|
+
/**
|
|
25
|
+
* API Schema for Network Watcher version 2023-11-01
|
|
26
|
+
*
|
|
27
|
+
* This is a stable version for backward compatibility.
|
|
28
|
+
* Network Watcher API is very stable with minimal changes between versions.
|
|
29
|
+
*/
|
|
30
|
+
export declare const NETWORK_WATCHER_SCHEMA_2023_11_01: ApiSchema;
|
|
31
|
+
/**
|
|
32
|
+
* Version configuration for Network Watcher 2024-01-01
|
|
33
|
+
*/
|
|
34
|
+
export declare const NETWORK_WATCHER_VERSION_2024_01_01: VersionConfig;
|
|
35
|
+
/**
|
|
36
|
+
* Version configuration for Network Watcher 2023-11-01
|
|
37
|
+
*/
|
|
38
|
+
export declare const NETWORK_WATCHER_VERSION_2023_11_01: VersionConfig;
|
|
39
|
+
/**
|
|
40
|
+
* All supported Network Watcher versions for registration
|
|
41
|
+
* Ordered with latest stable version first
|
|
42
|
+
*/
|
|
43
|
+
export declare const ALL_NETWORK_WATCHER_VERSIONS: VersionConfig[];
|
|
44
|
+
/**
|
|
45
|
+
* Resource type constant
|
|
46
|
+
*/
|
|
47
|
+
export declare const NETWORK_WATCHER_TYPE = "Microsoft.Network/networkWatchers";
|
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* API schemas for Azure Network Watcher across all supported versions
|
|
4
|
+
*
|
|
5
|
+
* This file defines the complete API schemas for Microsoft.Network/networkWatchers
|
|
6
|
+
* across all supported API versions. The schemas are used by the AzapiResource
|
|
7
|
+
* framework for validation, transformation, and version management.
|
|
8
|
+
*
|
|
9
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
10
|
+
* Network Watcher is primarily used as a dependency for other Network Watcher features like:
|
|
11
|
+
* - Flow Logs
|
|
12
|
+
* - Connection Monitor
|
|
13
|
+
* - Packet Capture
|
|
14
|
+
* - Network Diagnostic Tools
|
|
15
|
+
*/
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
exports.NETWORK_WATCHER_TYPE = exports.ALL_NETWORK_WATCHER_VERSIONS = exports.NETWORK_WATCHER_VERSION_2023_11_01 = exports.NETWORK_WATCHER_VERSION_2024_01_01 = exports.NETWORK_WATCHER_SCHEMA_2023_11_01 = exports.NETWORK_WATCHER_SCHEMA_2024_01_01 = void 0;
|
|
18
|
+
const version_interfaces_1 = require("../../core-azure/lib/version-manager/interfaces/version-interfaces");
|
|
19
|
+
// =============================================================================
|
|
20
|
+
// COMMON PROPERTY DEFINITIONS
|
|
21
|
+
// =============================================================================
|
|
22
|
+
/**
|
|
23
|
+
* Common property definitions shared across all Network Watcher versions
|
|
24
|
+
*
|
|
25
|
+
* Network Watcher is a relatively simple resource with minimal properties.
|
|
26
|
+
* It primarily serves as an anchor for Network Watcher features (Flow Logs,
|
|
27
|
+
* Connection Monitor, Packet Capture, etc.) in a specific region.
|
|
28
|
+
*/
|
|
29
|
+
const COMMON_NETWORK_WATCHER_PROPERTIES = {
|
|
30
|
+
name: {
|
|
31
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
32
|
+
required: true,
|
|
33
|
+
description: "Name of the Network Watcher",
|
|
34
|
+
validation: [
|
|
35
|
+
{
|
|
36
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
37
|
+
message: "Name is required",
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
ruleType: version_interfaces_1.ValidationRuleType.PATTERN_MATCH,
|
|
41
|
+
value: "^[a-zA-Z0-9][a-zA-Z0-9_.-]{0,78}[a-zA-Z0-9_]$",
|
|
42
|
+
message: "Network Watcher name must be 1-80 characters, start with a letter or number, end with a letter, number, or underscore, and contain only letters, numbers, underscores, periods, and hyphens",
|
|
43
|
+
},
|
|
44
|
+
],
|
|
45
|
+
},
|
|
46
|
+
location: {
|
|
47
|
+
dataType: version_interfaces_1.PropertyType.STRING,
|
|
48
|
+
required: true,
|
|
49
|
+
description: "Azure region where the Network Watcher will be created. Note: Only one Network Watcher per region per subscription is allowed.",
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
// =============================================================================
|
|
53
|
+
// VERSION-SPECIFIC SCHEMAS
|
|
54
|
+
// =============================================================================
|
|
55
|
+
/**
|
|
56
|
+
* API Schema for Network Watcher version 2024-01-01
|
|
57
|
+
*
|
|
58
|
+
* This is the latest stable version for Network Watcher.
|
|
59
|
+
* Network Watcher is a relatively simple resource - it primarily serves as
|
|
60
|
+
* an anchor for Network Watcher features in a region.
|
|
61
|
+
*/
|
|
62
|
+
exports.NETWORK_WATCHER_SCHEMA_2024_01_01 = {
|
|
63
|
+
resourceType: "Microsoft.Network/networkWatchers",
|
|
64
|
+
version: "2024-01-01",
|
|
65
|
+
properties: {
|
|
66
|
+
...COMMON_NETWORK_WATCHER_PROPERTIES,
|
|
67
|
+
},
|
|
68
|
+
required: ["name", "location"],
|
|
69
|
+
optional: [],
|
|
70
|
+
deprecated: [],
|
|
71
|
+
transformationRules: {},
|
|
72
|
+
validationRules: [
|
|
73
|
+
{
|
|
74
|
+
property: "name",
|
|
75
|
+
rules: [
|
|
76
|
+
{
|
|
77
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
78
|
+
message: "Name is required for Network Watcher",
|
|
79
|
+
},
|
|
80
|
+
],
|
|
81
|
+
},
|
|
82
|
+
],
|
|
83
|
+
};
|
|
84
|
+
/**
|
|
85
|
+
* API Schema for Network Watcher version 2023-11-01
|
|
86
|
+
*
|
|
87
|
+
* This is a stable version for backward compatibility.
|
|
88
|
+
* Network Watcher API is very stable with minimal changes between versions.
|
|
89
|
+
*/
|
|
90
|
+
exports.NETWORK_WATCHER_SCHEMA_2023_11_01 = {
|
|
91
|
+
resourceType: "Microsoft.Network/networkWatchers",
|
|
92
|
+
version: "2023-11-01",
|
|
93
|
+
properties: {
|
|
94
|
+
...COMMON_NETWORK_WATCHER_PROPERTIES,
|
|
95
|
+
},
|
|
96
|
+
required: ["name", "location"],
|
|
97
|
+
optional: [],
|
|
98
|
+
deprecated: [],
|
|
99
|
+
transformationRules: {},
|
|
100
|
+
validationRules: [
|
|
101
|
+
{
|
|
102
|
+
property: "name",
|
|
103
|
+
rules: [
|
|
104
|
+
{
|
|
105
|
+
ruleType: version_interfaces_1.ValidationRuleType.REQUIRED,
|
|
106
|
+
message: "Name is required for Network Watcher",
|
|
107
|
+
},
|
|
108
|
+
],
|
|
109
|
+
},
|
|
110
|
+
],
|
|
111
|
+
};
|
|
112
|
+
// =============================================================================
|
|
113
|
+
// VERSION CONFIGURATIONS
|
|
114
|
+
// =============================================================================
|
|
115
|
+
/**
|
|
116
|
+
* Version configuration for Network Watcher 2024-01-01
|
|
117
|
+
*/
|
|
118
|
+
exports.NETWORK_WATCHER_VERSION_2024_01_01 = {
|
|
119
|
+
version: "2024-01-01",
|
|
120
|
+
schema: exports.NETWORK_WATCHER_SCHEMA_2024_01_01,
|
|
121
|
+
supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
|
|
122
|
+
releaseDate: "2024-01-01",
|
|
123
|
+
deprecationDate: undefined,
|
|
124
|
+
sunsetDate: undefined,
|
|
125
|
+
breakingChanges: [],
|
|
126
|
+
migrationGuide: "/docs/network-watcher/migration-2024-01-01",
|
|
127
|
+
changeLog: [
|
|
128
|
+
{
|
|
129
|
+
changeType: "updated",
|
|
130
|
+
description: "Latest stable API version",
|
|
131
|
+
breaking: false,
|
|
132
|
+
},
|
|
133
|
+
],
|
|
134
|
+
};
|
|
135
|
+
/**
|
|
136
|
+
* Version configuration for Network Watcher 2023-11-01
|
|
137
|
+
*/
|
|
138
|
+
exports.NETWORK_WATCHER_VERSION_2023_11_01 = {
|
|
139
|
+
version: "2023-11-01",
|
|
140
|
+
schema: exports.NETWORK_WATCHER_SCHEMA_2023_11_01,
|
|
141
|
+
supportLevel: version_interfaces_1.VersionSupportLevel.ACTIVE,
|
|
142
|
+
releaseDate: "2023-11-01",
|
|
143
|
+
deprecationDate: undefined,
|
|
144
|
+
sunsetDate: undefined,
|
|
145
|
+
breakingChanges: [],
|
|
146
|
+
migrationGuide: "/docs/network-watcher/migration-2023-11-01",
|
|
147
|
+
changeLog: [
|
|
148
|
+
{
|
|
149
|
+
changeType: "updated",
|
|
150
|
+
description: "Stable API version for backward compatibility",
|
|
151
|
+
breaking: false,
|
|
152
|
+
},
|
|
153
|
+
],
|
|
154
|
+
};
|
|
155
|
+
/**
|
|
156
|
+
* All supported Network Watcher versions for registration
|
|
157
|
+
* Ordered with latest stable version first
|
|
158
|
+
*/
|
|
159
|
+
exports.ALL_NETWORK_WATCHER_VERSIONS = [
|
|
160
|
+
exports.NETWORK_WATCHER_VERSION_2024_01_01,
|
|
161
|
+
exports.NETWORK_WATCHER_VERSION_2023_11_01,
|
|
162
|
+
];
|
|
163
|
+
/**
|
|
164
|
+
* Resource type constant
|
|
165
|
+
*/
|
|
166
|
+
exports.NETWORK_WATCHER_TYPE = "Microsoft.Network/networkWatchers";
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-watcher-schemas.js","sourceRoot":"","sources":["../../../src/azure-networkwatcher/lib/network-watcher-schemas.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * API schemas for Azure Network Watcher across all supported versions\n *\n * This file defines the complete API schemas for Microsoft.Network/networkWatchers\n * across all supported API versions. The schemas are used by the AzapiResource\n * framework for validation, transformation, and version management.\n *\n * IMPORTANT: Azure only allows one Network Watcher per subscription per region.\n * Network Watcher is primarily used as a dependency for other Network Watcher features like:\n * - Flow Logs\n * - Connection Monitor\n * - Packet Capture\n * - Network Diagnostic Tools\n */\n\nimport {\n  ApiSchema,\n  PropertyDefinition,\n  PropertyType,\n  ValidationRuleType,\n  VersionConfig,\n  VersionSupportLevel,\n} from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n// =============================================================================\n// COMMON PROPERTY DEFINITIONS\n// =============================================================================\n\n/**\n * Common property definitions shared across all Network Watcher versions\n *\n * Network Watcher is a relatively simple resource with minimal properties.\n * It primarily serves as an anchor for Network Watcher features (Flow Logs,\n * Connection Monitor, Packet Capture, etc.) in a specific region.\n */\nconst COMMON_NETWORK_WATCHER_PROPERTIES: {\n  [key: string]: PropertyDefinition;\n} = {\n  name: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description: \"Name of the Network Watcher\",\n    validation: [\n      {\n        ruleType: ValidationRuleType.REQUIRED,\n        message: \"Name is required\",\n      },\n      {\n        ruleType: ValidationRuleType.PATTERN_MATCH,\n        value: \"^[a-zA-Z0-9][a-zA-Z0-9_.-]{0,78}[a-zA-Z0-9_]$\",\n        message:\n          \"Network Watcher name must be 1-80 characters, start with a letter or number, end with a letter, number, or underscore, and contain only letters, numbers, underscores, periods, and hyphens\",\n      },\n    ],\n  },\n  location: {\n    dataType: PropertyType.STRING,\n    required: true,\n    description:\n      \"Azure region where the Network Watcher will be created. Note: Only one Network Watcher per region per subscription is allowed.\",\n  },\n};\n\n// =============================================================================\n// VERSION-SPECIFIC SCHEMAS\n// =============================================================================\n\n/**\n * API Schema for Network Watcher version 2024-01-01\n *\n * This is the latest stable version for Network Watcher.\n * Network Watcher is a relatively simple resource - it primarily serves as\n * an anchor for Network Watcher features in a region.\n */\nexport const NETWORK_WATCHER_SCHEMA_2024_01_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/networkWatchers\",\n  version: \"2024-01-01\",\n  properties: {\n    ...COMMON_NETWORK_WATCHER_PROPERTIES,\n  },\n  required: [\"name\", \"location\"],\n  optional: [],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"name\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Name is required for Network Watcher\",\n        },\n      ],\n    },\n  ],\n};\n\n/**\n * API Schema for Network Watcher version 2023-11-01\n *\n * This is a stable version for backward compatibility.\n * Network Watcher API is very stable with minimal changes between versions.\n */\nexport const NETWORK_WATCHER_SCHEMA_2023_11_01: ApiSchema = {\n  resourceType: \"Microsoft.Network/networkWatchers\",\n  version: \"2023-11-01\",\n  properties: {\n    ...COMMON_NETWORK_WATCHER_PROPERTIES,\n  },\n  required: [\"name\", \"location\"],\n  optional: [],\n  deprecated: [],\n  transformationRules: {},\n  validationRules: [\n    {\n      property: \"name\",\n      rules: [\n        {\n          ruleType: ValidationRuleType.REQUIRED,\n          message: \"Name is required for Network Watcher\",\n        },\n      ],\n    },\n  ],\n};\n\n// =============================================================================\n// VERSION CONFIGURATIONS\n// =============================================================================\n\n/**\n * Version configuration for Network Watcher 2024-01-01\n */\nexport const NETWORK_WATCHER_VERSION_2024_01_01: VersionConfig = {\n  version: \"2024-01-01\",\n  schema: NETWORK_WATCHER_SCHEMA_2024_01_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2024-01-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/network-watcher/migration-2024-01-01\",\n  changeLog: [\n    {\n      changeType: \"updated\",\n      description: \"Latest stable API version\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * Version configuration for Network Watcher 2023-11-01\n */\nexport const NETWORK_WATCHER_VERSION_2023_11_01: VersionConfig = {\n  version: \"2023-11-01\",\n  schema: NETWORK_WATCHER_SCHEMA_2023_11_01,\n  supportLevel: VersionSupportLevel.ACTIVE,\n  releaseDate: \"2023-11-01\",\n  deprecationDate: undefined,\n  sunsetDate: undefined,\n  breakingChanges: [],\n  migrationGuide: \"/docs/network-watcher/migration-2023-11-01\",\n  changeLog: [\n    {\n      changeType: \"updated\",\n      description: \"Stable API version for backward compatibility\",\n      breaking: false,\n    },\n  ],\n};\n\n/**\n * All supported Network Watcher versions for registration\n * Ordered with latest stable version first\n */\nexport const ALL_NETWORK_WATCHER_VERSIONS: VersionConfig[] = [\n  NETWORK_WATCHER_VERSION_2024_01_01,\n  NETWORK_WATCHER_VERSION_2023_11_01,\n];\n\n/**\n * Resource type constant\n */\nexport const NETWORK_WATCHER_TYPE = \"Microsoft.Network/networkWatchers\";\n"]}
|
|
@@ -0,0 +1,181 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Unified Azure Network Watcher implementation using AzapiResource framework
|
|
3
|
+
*
|
|
4
|
+
* This class provides a version-aware implementation for Azure Network Watcher
|
|
5
|
+
* that automatically handles version management, schema validation, and property
|
|
6
|
+
* transformation across all supported API versions.
|
|
7
|
+
*
|
|
8
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
9
|
+
* If you attempt to create a Network Watcher in a region where one already exists,
|
|
10
|
+
* the deployment will fail.
|
|
11
|
+
*
|
|
12
|
+
* Supported API Versions:
|
|
13
|
+
* - 2024-01-01 (Active, Latest)
|
|
14
|
+
* - 2023-11-01 (Active, Backward Compatibility)
|
|
15
|
+
*
|
|
16
|
+
* Features:
|
|
17
|
+
* - Automatic latest version resolution when no version is specified
|
|
18
|
+
* - Explicit version pinning for stability requirements
|
|
19
|
+
* - Schema-driven validation and transformation
|
|
20
|
+
* - Full JSII compliance for multi-language support
|
|
21
|
+
*
|
|
22
|
+
* Network Watcher is primarily used as a dependency for other Network Watcher features:
|
|
23
|
+
* - Flow Logs
|
|
24
|
+
* - Connection Monitor
|
|
25
|
+
* - Packet Capture
|
|
26
|
+
* - Network Diagnostic Tools
|
|
27
|
+
*/
|
|
28
|
+
import * as cdktf from "cdktf";
|
|
29
|
+
import { Construct } from "constructs";
|
|
30
|
+
import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
|
|
31
|
+
import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
|
|
32
|
+
/**
|
|
33
|
+
* Properties for the unified Azure Network Watcher
|
|
34
|
+
*
|
|
35
|
+
* Extends AzapiResourceProps with Network Watcher specific properties.
|
|
36
|
+
*
|
|
37
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
38
|
+
* Attempting to create multiple Network Watchers in the same region will fail.
|
|
39
|
+
*/
|
|
40
|
+
export interface NetworkWatcherProps extends AzapiResourceProps {
|
|
41
|
+
/**
|
|
42
|
+
* Resource Group ID where the Network Watcher will be created
|
|
43
|
+
*
|
|
44
|
+
* The Network Watcher will be created as a child of this resource group.
|
|
45
|
+
* It's recommended to use a dedicated resource group for Network Watchers,
|
|
46
|
+
* as Azure automatically creates one named "NetworkWatcherRG" when certain
|
|
47
|
+
* network features are used.
|
|
48
|
+
*/
|
|
49
|
+
readonly resourceGroupId: string;
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* The resource body interface for Azure Network Watcher API calls
|
|
53
|
+
*
|
|
54
|
+
* Network Watcher is a simple resource with minimal properties.
|
|
55
|
+
* The properties block is typically empty.
|
|
56
|
+
*/
|
|
57
|
+
export interface NetworkWatcherBody {
|
|
58
|
+
readonly properties: {
|
|
59
|
+
[key: string]: any;
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Unified Azure Network Watcher implementation
|
|
64
|
+
*
|
|
65
|
+
* This class provides a single, version-aware implementation that automatically handles version
|
|
66
|
+
* resolution, schema validation, and property transformation while maintaining full JSII compliance.
|
|
67
|
+
*
|
|
68
|
+
* Network Watcher is a regional service that provides tools to monitor, diagnose, and gain
|
|
69
|
+
* insights into your network health and performance in Azure. It serves as the anchor for
|
|
70
|
+
* Network Watcher features like Flow Logs, Connection Monitor, and Packet Capture.
|
|
71
|
+
*
|
|
72
|
+
* IMPORTANT CONSTRAINT: Azure only allows one Network Watcher per subscription per region.
|
|
73
|
+
* If you need Network Watcher functionality in multiple regions, you must create a separate
|
|
74
|
+
* Network Watcher for each region.
|
|
75
|
+
*
|
|
76
|
+
* @example
|
|
77
|
+
* // Basic Network Watcher:
|
|
78
|
+
* const networkWatcher = new NetworkWatcher(this, "network-watcher", {
|
|
79
|
+
* name: "nw-eastus",
|
|
80
|
+
* location: "eastus",
|
|
81
|
+
* resourceGroupId: resourceGroup.id,
|
|
82
|
+
* });
|
|
83
|
+
*
|
|
84
|
+
* @example
|
|
85
|
+
* // Network Watcher with specific API version:
|
|
86
|
+
* const networkWatcher = new NetworkWatcher(this, "network-watcher", {
|
|
87
|
+
* name: "nw-westus2",
|
|
88
|
+
* location: "westus2",
|
|
89
|
+
* resourceGroupId: resourceGroup.id,
|
|
90
|
+
* apiVersion: "2024-01-01",
|
|
91
|
+
* tags: {
|
|
92
|
+
* environment: "production",
|
|
93
|
+
* },
|
|
94
|
+
* });
|
|
95
|
+
*
|
|
96
|
+
* @example
|
|
97
|
+
* // Network Watcher for use with Flow Logs:
|
|
98
|
+
* const networkWatcher = new NetworkWatcher(this, "network-watcher", {
|
|
99
|
+
* name: "NetworkWatcher_eastus",
|
|
100
|
+
* location: "eastus",
|
|
101
|
+
* resourceGroupId: networkWatcherRg.id,
|
|
102
|
+
* });
|
|
103
|
+
*
|
|
104
|
+
* // Then use it with NSG Flow Logs
|
|
105
|
+
* const flowLog = new NsgFlowLog(this, "flow-log", {
|
|
106
|
+
* networkWatcherId: networkWatcher.id,
|
|
107
|
+
* // ... other properties
|
|
108
|
+
* });
|
|
109
|
+
*
|
|
110
|
+
* @stability stable
|
|
111
|
+
*/
|
|
112
|
+
export declare class NetworkWatcher extends AzapiResource {
|
|
113
|
+
/**
|
|
114
|
+
* The input properties for this Network Watcher instance
|
|
115
|
+
*/
|
|
116
|
+
readonly props: NetworkWatcherProps;
|
|
117
|
+
/**
|
|
118
|
+
* Terraform output for the Network Watcher resource ID
|
|
119
|
+
*/
|
|
120
|
+
readonly idOutput: cdktf.TerraformOutput;
|
|
121
|
+
/**
|
|
122
|
+
* Terraform output for the Network Watcher name
|
|
123
|
+
*/
|
|
124
|
+
readonly nameOutput: cdktf.TerraformOutput;
|
|
125
|
+
/**
|
|
126
|
+
* Terraform output for the Network Watcher location
|
|
127
|
+
*/
|
|
128
|
+
readonly locationOutput: cdktf.TerraformOutput;
|
|
129
|
+
/**
|
|
130
|
+
* Terraform output for the Network Watcher provisioning state
|
|
131
|
+
*/
|
|
132
|
+
readonly provisioningStateOutput: cdktf.TerraformOutput;
|
|
133
|
+
/**
|
|
134
|
+
* Creates a new Azure Network Watcher using the AzapiResource framework
|
|
135
|
+
*
|
|
136
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
137
|
+
* validation, and resource creation.
|
|
138
|
+
*
|
|
139
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
140
|
+
* Attempting to create a Network Watcher in a region where one already exists
|
|
141
|
+
* will result in a deployment error.
|
|
142
|
+
*
|
|
143
|
+
* @param scope - The scope in which to define this construct
|
|
144
|
+
* @param id - The unique identifier for this instance
|
|
145
|
+
* @param props - Configuration properties for the Network Watcher
|
|
146
|
+
*/
|
|
147
|
+
constructor(scope: Construct, id: string, props: NetworkWatcherProps);
|
|
148
|
+
/**
|
|
149
|
+
* Gets the default API version to use when no explicit version is specified
|
|
150
|
+
* Returns the latest stable version as the default
|
|
151
|
+
*/
|
|
152
|
+
protected defaultVersion(): string;
|
|
153
|
+
/**
|
|
154
|
+
* Gets the Azure resource type for Network Watcher
|
|
155
|
+
*/
|
|
156
|
+
protected resourceType(): string;
|
|
157
|
+
/**
|
|
158
|
+
* Gets the API schema for the resolved version
|
|
159
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
160
|
+
*/
|
|
161
|
+
protected apiSchema(): ApiSchema;
|
|
162
|
+
/**
|
|
163
|
+
* Indicates that this resource type requires a location
|
|
164
|
+
*/
|
|
165
|
+
protected requiresLocation(): boolean;
|
|
166
|
+
/**
|
|
167
|
+
* Creates the resource body for the Azure API call
|
|
168
|
+
*
|
|
169
|
+
* Network Watcher is a simple resource with an empty properties block.
|
|
170
|
+
* All configuration is handled at the resource level (name, location, tags).
|
|
171
|
+
*/
|
|
172
|
+
protected createResourceBody(_props: any): any;
|
|
173
|
+
/**
|
|
174
|
+
* Resolves the parent resource ID for Network Watcher
|
|
175
|
+
* Network Watcher is a top-level resource within a resource group
|
|
176
|
+
*
|
|
177
|
+
* @param props - The resource properties
|
|
178
|
+
* @returns The parent resource ID (the resource group)
|
|
179
|
+
*/
|
|
180
|
+
protected resolveParentId(props: any): string;
|
|
181
|
+
}
|