@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
|
@@ -0,0 +1,187 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var _a;
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.NetworkWatcher = void 0;
|
|
5
|
+
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
|
|
6
|
+
/**
|
|
7
|
+
* Unified Azure Network Watcher implementation using AzapiResource framework
|
|
8
|
+
*
|
|
9
|
+
* This class provides a version-aware implementation for Azure Network Watcher
|
|
10
|
+
* that automatically handles version management, schema validation, and property
|
|
11
|
+
* transformation across all supported API versions.
|
|
12
|
+
*
|
|
13
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
14
|
+
* If you attempt to create a Network Watcher in a region where one already exists,
|
|
15
|
+
* the deployment will fail.
|
|
16
|
+
*
|
|
17
|
+
* Supported API Versions:
|
|
18
|
+
* - 2024-01-01 (Active, Latest)
|
|
19
|
+
* - 2023-11-01 (Active, Backward Compatibility)
|
|
20
|
+
*
|
|
21
|
+
* Features:
|
|
22
|
+
* - Automatic latest version resolution when no version is specified
|
|
23
|
+
* - Explicit version pinning for stability requirements
|
|
24
|
+
* - Schema-driven validation and transformation
|
|
25
|
+
* - Full JSII compliance for multi-language support
|
|
26
|
+
*
|
|
27
|
+
* Network Watcher is primarily used as a dependency for other Network Watcher features:
|
|
28
|
+
* - Flow Logs
|
|
29
|
+
* - Connection Monitor
|
|
30
|
+
* - Packet Capture
|
|
31
|
+
* - Network Diagnostic Tools
|
|
32
|
+
*/
|
|
33
|
+
const cdktf = require("cdktf");
|
|
34
|
+
const network_watcher_schemas_1 = require("./network-watcher-schemas");
|
|
35
|
+
const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
|
|
36
|
+
/**
|
|
37
|
+
* Unified Azure Network Watcher implementation
|
|
38
|
+
*
|
|
39
|
+
* This class provides a single, version-aware implementation that automatically handles version
|
|
40
|
+
* resolution, schema validation, and property transformation while maintaining full JSII compliance.
|
|
41
|
+
*
|
|
42
|
+
* Network Watcher is a regional service that provides tools to monitor, diagnose, and gain
|
|
43
|
+
* insights into your network health and performance in Azure. It serves as the anchor for
|
|
44
|
+
* Network Watcher features like Flow Logs, Connection Monitor, and Packet Capture.
|
|
45
|
+
*
|
|
46
|
+
* IMPORTANT CONSTRAINT: Azure only allows one Network Watcher per subscription per region.
|
|
47
|
+
* If you need Network Watcher functionality in multiple regions, you must create a separate
|
|
48
|
+
* Network Watcher for each region.
|
|
49
|
+
*
|
|
50
|
+
* @example
|
|
51
|
+
* // Basic Network Watcher:
|
|
52
|
+
* const networkWatcher = new NetworkWatcher(this, "network-watcher", {
|
|
53
|
+
* name: "nw-eastus",
|
|
54
|
+
* location: "eastus",
|
|
55
|
+
* resourceGroupId: resourceGroup.id,
|
|
56
|
+
* });
|
|
57
|
+
*
|
|
58
|
+
* @example
|
|
59
|
+
* // Network Watcher with specific API version:
|
|
60
|
+
* const networkWatcher = new NetworkWatcher(this, "network-watcher", {
|
|
61
|
+
* name: "nw-westus2",
|
|
62
|
+
* location: "westus2",
|
|
63
|
+
* resourceGroupId: resourceGroup.id,
|
|
64
|
+
* apiVersion: "2024-01-01",
|
|
65
|
+
* tags: {
|
|
66
|
+
* environment: "production",
|
|
67
|
+
* },
|
|
68
|
+
* });
|
|
69
|
+
*
|
|
70
|
+
* @example
|
|
71
|
+
* // Network Watcher for use with Flow Logs:
|
|
72
|
+
* const networkWatcher = new NetworkWatcher(this, "network-watcher", {
|
|
73
|
+
* name: "NetworkWatcher_eastus",
|
|
74
|
+
* location: "eastus",
|
|
75
|
+
* resourceGroupId: networkWatcherRg.id,
|
|
76
|
+
* });
|
|
77
|
+
*
|
|
78
|
+
* // Then use it with NSG Flow Logs
|
|
79
|
+
* const flowLog = new NsgFlowLog(this, "flow-log", {
|
|
80
|
+
* networkWatcherId: networkWatcher.id,
|
|
81
|
+
* // ... other properties
|
|
82
|
+
* });
|
|
83
|
+
*
|
|
84
|
+
* @stability stable
|
|
85
|
+
*/
|
|
86
|
+
class NetworkWatcher extends azapi_resource_1.AzapiResource {
|
|
87
|
+
/**
|
|
88
|
+
* Creates a new Azure Network Watcher using the AzapiResource framework
|
|
89
|
+
*
|
|
90
|
+
* The constructor automatically handles version resolution, schema registration,
|
|
91
|
+
* validation, and resource creation.
|
|
92
|
+
*
|
|
93
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
94
|
+
* Attempting to create a Network Watcher in a region where one already exists
|
|
95
|
+
* will result in a deployment error.
|
|
96
|
+
*
|
|
97
|
+
* @param scope - The scope in which to define this construct
|
|
98
|
+
* @param id - The unique identifier for this instance
|
|
99
|
+
* @param props - Configuration properties for the Network Watcher
|
|
100
|
+
*/
|
|
101
|
+
constructor(scope, id, props) {
|
|
102
|
+
super(scope, id, props);
|
|
103
|
+
this.props = props;
|
|
104
|
+
// Create Terraform outputs for easy access and referencing from other resources
|
|
105
|
+
this.idOutput = new cdktf.TerraformOutput(this, "id", {
|
|
106
|
+
value: this.id,
|
|
107
|
+
description: "The ID of the Network Watcher",
|
|
108
|
+
});
|
|
109
|
+
this.nameOutput = new cdktf.TerraformOutput(this, "name", {
|
|
110
|
+
value: `\${${this.terraformResource.fqn}.name}`,
|
|
111
|
+
description: "The name of the Network Watcher",
|
|
112
|
+
});
|
|
113
|
+
this.locationOutput = new cdktf.TerraformOutput(this, "location", {
|
|
114
|
+
value: `\${${this.terraformResource.fqn}.output.location}`,
|
|
115
|
+
description: "The location of the Network Watcher",
|
|
116
|
+
});
|
|
117
|
+
this.provisioningStateOutput = new cdktf.TerraformOutput(this, "provisioning_state", {
|
|
118
|
+
value: `\${${this.terraformResource.fqn}.output.properties.provisioningState}`,
|
|
119
|
+
description: "The provisioning state of the Network Watcher",
|
|
120
|
+
});
|
|
121
|
+
// Override logical IDs
|
|
122
|
+
this.idOutput.overrideLogicalId("id");
|
|
123
|
+
this.nameOutput.overrideLogicalId("name");
|
|
124
|
+
this.locationOutput.overrideLogicalId("location");
|
|
125
|
+
this.provisioningStateOutput.overrideLogicalId("provisioning_state");
|
|
126
|
+
}
|
|
127
|
+
// =============================================================================
|
|
128
|
+
// REQUIRED ABSTRACT METHODS FROM AzapiResource
|
|
129
|
+
// =============================================================================
|
|
130
|
+
/**
|
|
131
|
+
* Gets the default API version to use when no explicit version is specified
|
|
132
|
+
* Returns the latest stable version as the default
|
|
133
|
+
*/
|
|
134
|
+
defaultVersion() {
|
|
135
|
+
return "2024-01-01";
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Gets the Azure resource type for Network Watcher
|
|
139
|
+
*/
|
|
140
|
+
resourceType() {
|
|
141
|
+
return network_watcher_schemas_1.NETWORK_WATCHER_TYPE;
|
|
142
|
+
}
|
|
143
|
+
/**
|
|
144
|
+
* Gets the API schema for the resolved version
|
|
145
|
+
* Uses the framework's schema resolution to get the appropriate schema
|
|
146
|
+
*/
|
|
147
|
+
apiSchema() {
|
|
148
|
+
return this.resolveSchema();
|
|
149
|
+
}
|
|
150
|
+
/**
|
|
151
|
+
* Indicates that this resource type requires a location
|
|
152
|
+
*/
|
|
153
|
+
requiresLocation() {
|
|
154
|
+
return true;
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Creates the resource body for the Azure API call
|
|
158
|
+
*
|
|
159
|
+
* Network Watcher is a simple resource with an empty properties block.
|
|
160
|
+
* All configuration is handled at the resource level (name, location, tags).
|
|
161
|
+
*/
|
|
162
|
+
createResourceBody(_props) {
|
|
163
|
+
// Network Watcher has an empty properties block
|
|
164
|
+
// The resource is configured primarily through name, location, and tags
|
|
165
|
+
const body = {
|
|
166
|
+
properties: {},
|
|
167
|
+
};
|
|
168
|
+
return body;
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Resolves the parent resource ID for Network Watcher
|
|
172
|
+
* Network Watcher is a top-level resource within a resource group
|
|
173
|
+
*
|
|
174
|
+
* @param props - The resource properties
|
|
175
|
+
* @returns The parent resource ID (the resource group)
|
|
176
|
+
*/
|
|
177
|
+
resolveParentId(props) {
|
|
178
|
+
return props.resourceGroupId;
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
exports.NetworkWatcher = NetworkWatcher;
|
|
182
|
+
_a = JSII_RTTI_SYMBOL_1;
|
|
183
|
+
NetworkWatcher[_a] = { fqn: "@microsoft/terraform-cdk-constructs.NetworkWatcher", version: "1.9.0" };
|
|
184
|
+
(() => {
|
|
185
|
+
azapi_resource_1.AzapiResource.registerSchemas(network_watcher_schemas_1.NETWORK_WATCHER_TYPE, network_watcher_schemas_1.ALL_NETWORK_WATCHER_VERSIONS);
|
|
186
|
+
})();
|
|
187
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"network-watcher.js","sourceRoot":"","sources":["../../../src/azure-networkwatcher/lib/network-watcher.ts"],"names":[],"mappings":";;;;;AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AAEH,+BAA+B;AAE/B,uEAGmC;AACnC,8EAGmD;AAiCnD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAiDG;AACH,MAAa,cAAe,SAAQ,8BAAa;IAkC/C;;;;;;;;;;;;;OAaG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,KAA0B;QAClE,KAAK,CAAC,KAAK,EAAE,EAAE,EAAE,KAAK,CAAC,CAAC;QAExB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAEnB,gFAAgF;QAChF,IAAI,CAAC,QAAQ,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,IAAI,EAAE;YACpD,KAAK,EAAE,IAAI,CAAC,EAAE;YACd,WAAW,EAAE,+BAA+B;SAC7C,CAAC,CAAC;QAEH,IAAI,CAAC,UAAU,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,MAAM,EAAE;YACxD,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,QAAQ;YAC/C,WAAW,EAAE,iCAAiC;SAC/C,CAAC,CAAC;QAEH,IAAI,CAAC,cAAc,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE;YAChE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,mBAAmB;YAC1D,WAAW,EAAE,qCAAqC;SACnD,CAAC,CAAC;QAEH,IAAI,CAAC,uBAAuB,GAAG,IAAI,KAAK,CAAC,eAAe,CACtD,IAAI,EACJ,oBAAoB,EACpB;YACE,KAAK,EAAE,MAAM,IAAI,CAAC,iBAAiB,CAAC,GAAG,uCAAuC;YAC9E,WAAW,EAAE,+CAA+C;SAC7D,CACF,CAAC;QAEF,uBAAuB;QACvB,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC;QAC1C,IAAI,CAAC,cAAc,CAAC,iBAAiB,CAAC,UAAU,CAAC,CAAC;QAClD,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,CAAC;IACvE,CAAC;IAED,gFAAgF;IAChF,+CAA+C;IAC/C,gFAAgF;IAEhF;;;OAGG;IACO,cAAc;QACtB,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACO,YAAY;QACpB,OAAO,8CAAoB,CAAC;IAC9B,CAAC;IAED;;;OAGG;IACO,SAAS;QACjB,OAAO,IAAI,CAAC,aAAa,EAAE,CAAC;IAC9B,CAAC;IAED;;OAEG;IACO,gBAAgB;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;OAKG;IACO,kBAAkB,CAAC,MAAW;QACtC,gDAAgD;QAChD,wEAAwE;QACxE,MAAM,IAAI,GAAQ;YAChB,UAAU,EAAE,EAAE;SACf,CAAC;QAEF,OAAO,IAAI,CAAC;IACd,CAAC;IAED;;;;;;OAMG;IACO,eAAe,CAAC,KAAU;QAClC,OAAQ,KAA6B,CAAC,eAAe,CAAC;IACxD,CAAC;;AAhJH,wCAiJC;;;AAhJC;IACE,8BAAa,CAAC,eAAe,CAC3B,8CAAoB,EACpB,sDAA4B,CAC7B,CAAC;AACJ,CAAC,GAAA,CAAA","sourcesContent":["/**\n * Unified Azure Network Watcher implementation using AzapiResource framework\n *\n * This class provides a version-aware implementation for Azure Network Watcher\n * that automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * IMPORTANT: Azure only allows one Network Watcher per subscription per region.\n * If you attempt to create a Network Watcher in a region where one already exists,\n * the deployment will fail.\n *\n * Supported API Versions:\n * - 2024-01-01 (Active, Latest)\n * - 2023-11-01 (Active, Backward Compatibility)\n *\n * Features:\n * - Automatic latest version resolution when no version is specified\n * - Explicit version pinning for stability requirements\n * - Schema-driven validation and transformation\n * - Full JSII compliance for multi-language support\n *\n * Network Watcher is primarily used as a dependency for other Network Watcher features:\n * - Flow Logs\n * - Connection Monitor\n * - Packet Capture\n * - Network Diagnostic Tools\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_NETWORK_WATCHER_VERSIONS,\n  NETWORK_WATCHER_TYPE,\n} from \"./network-watcher-schemas\";\nimport {\n  AzapiResource,\n  AzapiResourceProps,\n} from \"../../core-azure/lib/azapi/azapi-resource\";\nimport { ApiSchema } from \"../../core-azure/lib/version-manager/interfaces/version-interfaces\";\n\n/**\n * Properties for the unified Azure Network Watcher\n *\n * Extends AzapiResourceProps with Network Watcher specific properties.\n *\n * IMPORTANT: Azure only allows one Network Watcher per subscription per region.\n * Attempting to create multiple Network Watchers in the same region will fail.\n */\nexport interface NetworkWatcherProps extends AzapiResourceProps {\n  /**\n   * Resource Group ID where the Network Watcher will be created\n   *\n   * The Network Watcher will be created as a child of this resource group.\n   * It's recommended to use a dedicated resource group for Network Watchers,\n   * as Azure automatically creates one named \"NetworkWatcherRG\" when certain\n   * network features are used.\n   */\n  readonly resourceGroupId: string;\n}\n\n/**\n * The resource body interface for Azure Network Watcher API calls\n *\n * Network Watcher is a simple resource with minimal properties.\n * The properties block is typically empty.\n */\nexport interface NetworkWatcherBody {\n  readonly properties: { [key: string]: any };\n}\n\n/**\n * Unified Azure Network Watcher implementation\n *\n * This class provides a single, version-aware implementation that automatically handles version\n * resolution, schema validation, and property transformation while maintaining full JSII compliance.\n *\n * Network Watcher is a regional service that provides tools to monitor, diagnose, and gain\n * insights into your network health and performance in Azure. It serves as the anchor for\n * Network Watcher features like Flow Logs, Connection Monitor, and Packet Capture.\n *\n * IMPORTANT CONSTRAINT: Azure only allows one Network Watcher per subscription per region.\n * If you need Network Watcher functionality in multiple regions, you must create a separate\n * Network Watcher for each region.\n *\n * @example\n * // Basic Network Watcher:\n * const networkWatcher = new NetworkWatcher(this, \"network-watcher\", {\n *   name: \"nw-eastus\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n * });\n *\n * @example\n * // Network Watcher with specific API version:\n * const networkWatcher = new NetworkWatcher(this, \"network-watcher\", {\n *   name: \"nw-westus2\",\n *   location: \"westus2\",\n *   resourceGroupId: resourceGroup.id,\n *   apiVersion: \"2024-01-01\",\n *   tags: {\n *     environment: \"production\",\n *   },\n * });\n *\n * @example\n * // Network Watcher for use with Flow Logs:\n * const networkWatcher = new NetworkWatcher(this, \"network-watcher\", {\n *   name: \"NetworkWatcher_eastus\",\n *   location: \"eastus\",\n *   resourceGroupId: networkWatcherRg.id,\n * });\n *\n * // Then use it with NSG Flow Logs\n * const flowLog = new NsgFlowLog(this, \"flow-log\", {\n *   networkWatcherId: networkWatcher.id,\n *   // ... other properties\n * });\n *\n * @stability stable\n */\nexport class NetworkWatcher extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      NETWORK_WATCHER_TYPE,\n      ALL_NETWORK_WATCHER_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Network Watcher instance\n   */\n  public readonly props: NetworkWatcherProps;\n\n  // Output properties for easy access and referencing\n  /**\n   * Terraform output for the Network Watcher resource ID\n   */\n  public readonly idOutput: cdktf.TerraformOutput;\n\n  /**\n   * Terraform output for the Network Watcher name\n   */\n  public readonly nameOutput: cdktf.TerraformOutput;\n\n  /**\n   * Terraform output for the Network Watcher location\n   */\n  public readonly locationOutput: cdktf.TerraformOutput;\n\n  /**\n   * Terraform output for the Network Watcher provisioning state\n   */\n  public readonly provisioningStateOutput: cdktf.TerraformOutput;\n\n  /**\n   * Creates a new Azure Network Watcher using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation.\n   *\n   * IMPORTANT: Azure only allows one Network Watcher per subscription per region.\n   * Attempting to create a Network Watcher in a region where one already exists\n   * will result in a deployment error.\n   *\n   * @param scope - The scope in which to define this construct\n   * @param id - The unique identifier for this instance\n   * @param props - Configuration properties for the Network Watcher\n   */\n  constructor(scope: Construct, id: string, props: NetworkWatcherProps) {\n    super(scope, id, props);\n\n    this.props = props;\n\n    // Create Terraform outputs for easy access and referencing from other resources\n    this.idOutput = new cdktf.TerraformOutput(this, \"id\", {\n      value: this.id,\n      description: \"The ID of the Network Watcher\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Network Watcher\",\n    });\n\n    this.locationOutput = new cdktf.TerraformOutput(this, \"location\", {\n      value: `\\${${this.terraformResource.fqn}.output.location}`,\n      description: \"The location of the Network Watcher\",\n    });\n\n    this.provisioningStateOutput = new cdktf.TerraformOutput(\n      this,\n      \"provisioning_state\",\n      {\n        value: `\\${${this.terraformResource.fqn}.output.properties.provisioningState}`,\n        description: \"The provisioning state of the Network Watcher\",\n      },\n    );\n\n    // Override logical IDs\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.locationOutput.overrideLogicalId(\"location\");\n    this.provisioningStateOutput.overrideLogicalId(\"provisioning_state\");\n  }\n\n  // =============================================================================\n  // REQUIRED ABSTRACT METHODS FROM AzapiResource\n  // =============================================================================\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   * Returns the latest stable version as the default\n   */\n  protected defaultVersion(): string {\n    return \"2024-01-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Network Watcher\n   */\n  protected resourceType(): string {\n    return NETWORK_WATCHER_TYPE;\n  }\n\n  /**\n   * Gets the API schema for the resolved version\n   * Uses the framework's schema resolution to get the appropriate schema\n   */\n  protected apiSchema(): ApiSchema {\n    return this.resolveSchema();\n  }\n\n  /**\n   * Indicates that this resource type requires a location\n   */\n  protected requiresLocation(): boolean {\n    return true;\n  }\n\n  /**\n   * Creates the resource body for the Azure API call\n   *\n   * Network Watcher is a simple resource with an empty properties block.\n   * All configuration is handled at the resource level (name, location, tags).\n   */\n  protected createResourceBody(_props: any): any {\n    // Network Watcher has an empty properties block\n    // The resource is configured primarily through name, location, and tags\n    const body: any = {\n      properties: {},\n    };\n\n    return body;\n  }\n\n  /**\n   * Resolves the parent resource ID for Network Watcher\n   * Network Watcher is a top-level resource within a resource group\n   *\n   * @param props - The resource properties\n   * @returns The parent resource ID (the resource group)\n   */\n  protected resolveParentId(props: any): string {\n    return (props as NetworkWatcherProps).resourceGroupId;\n  }\n}\n"]}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Integration test for Azure Network Watcher
|
|
3
|
+
*
|
|
4
|
+
* This test demonstrates basic usage of the NetworkWatcher construct
|
|
5
|
+
* and validates deployment, idempotency, and cleanup.
|
|
6
|
+
*
|
|
7
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
8
|
+
* If a Network Watcher already exists in the test region, this test will fail.
|
|
9
|
+
*
|
|
10
|
+
* Run with: npm run integration:nostream
|
|
11
|
+
*/
|
|
12
|
+
import "cdktf/lib/testing/adapters/jest";
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Integration test for Azure Network Watcher
|
|
4
|
+
*
|
|
5
|
+
* This test demonstrates basic usage of the NetworkWatcher construct
|
|
6
|
+
* and validates deployment, idempotency, and cleanup.
|
|
7
|
+
*
|
|
8
|
+
* IMPORTANT: Azure only allows one Network Watcher per subscription per region.
|
|
9
|
+
* If a Network Watcher already exists in the test region, this test will fail.
|
|
10
|
+
*
|
|
11
|
+
* Run with: npm run integration:nostream
|
|
12
|
+
*/
|
|
13
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
14
|
+
const cdktf_1 = require("cdktf");
|
|
15
|
+
require("cdktf/lib/testing/adapters/jest");
|
|
16
|
+
const azure_resourcegroup_1 = require("../../azure-resourcegroup");
|
|
17
|
+
const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
|
|
18
|
+
const testing_1 = require("../../testing");
|
|
19
|
+
const network_watcher_1 = require("../lib/network-watcher");
|
|
20
|
+
/**
|
|
21
|
+
* Example stack demonstrating Network Watcher usage
|
|
22
|
+
*
|
|
23
|
+
* Note: This example creates a dedicated resource group for the Network Watcher.
|
|
24
|
+
* In practice, Azure often uses a resource group named "NetworkWatcherRG" for
|
|
25
|
+
* automatically provisioned Network Watchers.
|
|
26
|
+
*/
|
|
27
|
+
class NetworkWatcherExampleStack extends cdktf_1.TerraformStack {
|
|
28
|
+
constructor(scope, id) {
|
|
29
|
+
super(scope, id);
|
|
30
|
+
// Configure AZAPI provider
|
|
31
|
+
new provider_1.AzapiProvider(this, "azapi", {});
|
|
32
|
+
// Create a resource group for Network Watcher
|
|
33
|
+
// Note: Azure typically uses NetworkWatcherRG for auto-provisioned Network Watchers
|
|
34
|
+
// Using northeurope to avoid conflict with existing Network Watchers
|
|
35
|
+
const resourceGroup = new azure_resourcegroup_1.ResourceGroup(this, "example-rg", {
|
|
36
|
+
name: "nw-example-rg",
|
|
37
|
+
location: "northeurope",
|
|
38
|
+
tags: {
|
|
39
|
+
environment: "example",
|
|
40
|
+
purpose: "integration-test",
|
|
41
|
+
},
|
|
42
|
+
});
|
|
43
|
+
// Example 1: Basic Network Watcher
|
|
44
|
+
// Note: Only one Network Watcher per region per subscription is allowed
|
|
45
|
+
new network_watcher_1.NetworkWatcher(this, "basic-network-watcher", {
|
|
46
|
+
name: "nw-basic-example",
|
|
47
|
+
location: resourceGroup.props.location,
|
|
48
|
+
resourceGroupId: resourceGroup.id,
|
|
49
|
+
tags: {
|
|
50
|
+
example: "basic",
|
|
51
|
+
},
|
|
52
|
+
});
|
|
53
|
+
// Example 2: Network Watcher with specific version
|
|
54
|
+
// Using a different construct ID but same region (this is for demonstration only -
|
|
55
|
+
// in practice, you should only have one Network Watcher per region)
|
|
56
|
+
// This example shows version pinning but would fail if deployed alongside Example 1
|
|
57
|
+
// since both use the same region.
|
|
58
|
+
// Uncomment for testing version pinning in a different region:
|
|
59
|
+
/*
|
|
60
|
+
new NetworkWatcher(this, "versioned-network-watcher", {
|
|
61
|
+
name: "nw-versioned-example",
|
|
62
|
+
location: "westus2", // Different region
|
|
63
|
+
resourceGroupId: resourceGroup.id,
|
|
64
|
+
apiVersion: "2024-01-01",
|
|
65
|
+
tags: {
|
|
66
|
+
example: "versioned",
|
|
67
|
+
},
|
|
68
|
+
});
|
|
69
|
+
*/
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
describe("Network Watcher Integration Test", () => {
|
|
73
|
+
it("should deploy, validate idempotency, and cleanup Network Watcher resources", () => {
|
|
74
|
+
const app = cdktf_1.Testing.app();
|
|
75
|
+
const stack = new NetworkWatcherExampleStack(app, "test-network-watcher");
|
|
76
|
+
const synthesized = cdktf_1.Testing.fullSynth(stack);
|
|
77
|
+
// This will:
|
|
78
|
+
// 1. Run terraform apply to deploy resources
|
|
79
|
+
// 2. Run terraform plan to check idempotency (no changes expected)
|
|
80
|
+
// 3. Run terraform destroy to cleanup resources
|
|
81
|
+
(0, testing_1.TerraformApplyCheckAndDestroy)(synthesized);
|
|
82
|
+
}, 600000); // 10 minute timeout for deployment and cleanup
|
|
83
|
+
});
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmV0d29yay13YXRjaGVyLmludGVnLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2F6dXJlLW5ldHdvcmt3YXRjaGVyL3Rlc3QvbmV0d29yay13YXRjaGVyLmludGVnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQTs7Ozs7Ozs7OztHQVVHOztBQUVILGlDQUFnRDtBQUVoRCwyQ0FBeUM7QUFDekMsbUVBQTBEO0FBQzFELGtGQUFvRjtBQUNwRiwyQ0FBOEQ7QUFDOUQsNERBQXdEO0FBRXhEOzs7Ozs7R0FNRztBQUNILE1BQU0sMEJBQTJCLFNBQVEsc0JBQWM7SUFDckQsWUFBWSxLQUFnQixFQUFFLEVBQVU7UUFDdEMsS0FBSyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztRQUVqQiwyQkFBMkI7UUFDM0IsSUFBSSx3QkFBYSxDQUFDLElBQUksRUFBRSxPQUFPLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFckMsOENBQThDO1FBQzlDLG9GQUFvRjtRQUNwRixxRUFBcUU7UUFDckUsTUFBTSxhQUFhLEdBQUcsSUFBSSxtQ0FBYSxDQUFDLElBQUksRUFBRSxZQUFZLEVBQUU7WUFDMUQsSUFBSSxFQUFFLGVBQWU7WUFDckIsUUFBUSxFQUFFLGFBQWE7WUFDdkIsSUFBSSxFQUFFO2dCQUNKLFdBQVcsRUFBRSxTQUFTO2dCQUN0QixPQUFPLEVBQUUsa0JBQWtCO2FBQzVCO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsbUNBQW1DO1FBQ25DLHdFQUF3RTtRQUN4RSxJQUFJLGdDQUFjLENBQUMsSUFBSSxFQUFFLHVCQUF1QixFQUFFO1lBQ2hELElBQUksRUFBRSxrQkFBa0I7WUFDeEIsUUFBUSxFQUFFLGFBQWEsQ0FBQyxLQUFLLENBQUMsUUFBUztZQUN2QyxlQUFlLEVBQUUsYUFBYSxDQUFDLEVBQUU7WUFDakMsSUFBSSxFQUFFO2dCQUNKLE9BQU8sRUFBRSxPQUFPO2FBQ2pCO1NBQ0YsQ0FBQyxDQUFDO1FBRUgsbURBQW1EO1FBQ25ELG1GQUFtRjtRQUNuRixvRUFBb0U7UUFDcEUsb0ZBQW9GO1FBQ3BGLGtDQUFrQztRQUNsQywrREFBK0Q7UUFDL0Q7Ozs7Ozs7Ozs7VUFVRTtJQUNKLENBQUM7Q0FDRjtBQUVELFFBQVEsQ0FBQyxrQ0FBa0MsRUFBRSxHQUFHLEVBQUU7SUFDaEQsRUFBRSxDQUFDLDRFQUE0RSxFQUFFLEdBQUcsRUFBRTtRQUNwRixNQUFNLEdBQUcsR0FBRyxlQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDMUIsTUFBTSxLQUFLLEdBQUcsSUFBSSwwQkFBMEIsQ0FBQyxHQUFHLEVBQUUsc0JBQXNCLENBQUMsQ0FBQztRQUMxRSxNQUFNLFdBQVcsR0FBRyxlQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBRTdDLGFBQWE7UUFDYiw2Q0FBNkM7UUFDN0MsbUVBQW1FO1FBQ25FLGdEQUFnRDtRQUNoRCxJQUFBLHVDQUE2QixFQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzdDLENBQUMsRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDLCtDQUErQztBQUM3RCxDQUFDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogSW50ZWdyYXRpb24gdGVzdCBmb3IgQXp1cmUgTmV0d29yayBXYXRjaGVyXG4gKlxuICogVGhpcyB0ZXN0IGRlbW9uc3RyYXRlcyBiYXNpYyB1c2FnZSBvZiB0aGUgTmV0d29ya1dhdGNoZXIgY29uc3RydWN0XG4gKiBhbmQgdmFsaWRhdGVzIGRlcGxveW1lbnQsIGlkZW1wb3RlbmN5LCBhbmQgY2xlYW51cC5cbiAqXG4gKiBJTVBPUlRBTlQ6IEF6dXJlIG9ubHkgYWxsb3dzIG9uZSBOZXR3b3JrIFdhdGNoZXIgcGVyIHN1YnNjcmlwdGlvbiBwZXIgcmVnaW9uLlxuICogSWYgYSBOZXR3b3JrIFdhdGNoZXIgYWxyZWFkeSBleGlzdHMgaW4gdGhlIHRlc3QgcmVnaW9uLCB0aGlzIHRlc3Qgd2lsbCBmYWlsLlxuICpcbiAqIFJ1biB3aXRoOiBucG0gcnVuIGludGVncmF0aW9uOm5vc3RyZWFtXG4gKi9cblxuaW1wb3J0IHsgVGVzdGluZywgVGVycmFmb3JtU3RhY2sgfSBmcm9tIFwiY2RrdGZcIjtcbmltcG9ydCB7IENvbnN0cnVjdCB9IGZyb20gXCJjb25zdHJ1Y3RzXCI7XG5pbXBvcnQgXCJjZGt0Zi9saWIvdGVzdGluZy9hZGFwdGVycy9qZXN0XCI7XG5pbXBvcnQgeyBSZXNvdXJjZUdyb3VwIH0gZnJvbSBcIi4uLy4uL2F6dXJlLXJlc291cmNlZ3JvdXBcIjtcbmltcG9ydCB7IEF6YXBpUHJvdmlkZXIgfSBmcm9tIFwiLi4vLi4vY29yZS1henVyZS9saWIvYXphcGkvcHJvdmlkZXJzLWF6YXBpL3Byb3ZpZGVyXCI7XG5pbXBvcnQgeyBUZXJyYWZvcm1BcHBseUNoZWNrQW5kRGVzdHJveSB9IGZyb20gXCIuLi8uLi90ZXN0aW5nXCI7XG5pbXBvcnQgeyBOZXR3b3JrV2F0Y2hlciB9IGZyb20gXCIuLi9saWIvbmV0d29yay13YXRjaGVyXCI7XG5cbi8qKlxuICogRXhhbXBsZSBzdGFjayBkZW1vbnN0cmF0aW5nIE5ldHdvcmsgV2F0Y2hlciB1c2FnZVxuICpcbiAqIE5vdGU6IFRoaXMgZXhhbXBsZSBjcmVhdGVzIGEgZGVkaWNhdGVkIHJlc291cmNlIGdyb3VwIGZvciB0aGUgTmV0d29yayBXYXRjaGVyLlxuICogSW4gcHJhY3RpY2UsIEF6dXJlIG9mdGVuIHVzZXMgYSByZXNvdXJjZSBncm91cCBuYW1lZCBcIk5ldHdvcmtXYXRjaGVyUkdcIiBmb3JcbiAqIGF1dG9tYXRpY2FsbHkgcHJvdmlzaW9uZWQgTmV0d29yayBXYXRjaGVycy5cbiAqL1xuY2xhc3MgTmV0d29ya1dhdGNoZXJFeGFtcGxlU3RhY2sgZXh0ZW5kcyBUZXJyYWZvcm1TdGFjayB7XG4gIGNvbnN0cnVjdG9yKHNjb3BlOiBDb25zdHJ1Y3QsIGlkOiBzdHJpbmcpIHtcbiAgICBzdXBlcihzY29wZSwgaWQpO1xuXG4gICAgLy8gQ29uZmlndXJlIEFaQVBJIHByb3ZpZGVyXG4gICAgbmV3IEF6YXBpUHJvdmlkZXIodGhpcywgXCJhemFwaVwiLCB7fSk7XG5cbiAgICAvLyBDcmVhdGUgYSByZXNvdXJjZSBncm91cCBmb3IgTmV0d29yayBXYXRjaGVyXG4gICAgLy8gTm90ZTogQXp1cmUgdHlwaWNhbGx5IHVzZXMgTmV0d29ya1dhdGNoZXJSRyBmb3IgYXV0by1wcm92aXNpb25lZCBOZXR3b3JrIFdhdGNoZXJzXG4gICAgLy8gVXNpbmcgbm9ydGhldXJvcGUgdG8gYXZvaWQgY29uZmxpY3Qgd2l0aCBleGlzdGluZyBOZXR3b3JrIFdhdGNoZXJzXG4gICAgY29uc3QgcmVzb3VyY2VHcm91cCA9IG5ldyBSZXNvdXJjZUdyb3VwKHRoaXMsIFwiZXhhbXBsZS1yZ1wiLCB7XG4gICAgICBuYW1lOiBcIm53LWV4YW1wbGUtcmdcIixcbiAgICAgIGxvY2F0aW9uOiBcIm5vcnRoZXVyb3BlXCIsXG4gICAgICB0YWdzOiB7XG4gICAgICAgIGVudmlyb25tZW50OiBcImV4YW1wbGVcIixcbiAgICAgICAgcHVycG9zZTogXCJpbnRlZ3JhdGlvbi10ZXN0XCIsXG4gICAgICB9LFxuICAgIH0pO1xuXG4gICAgLy8gRXhhbXBsZSAxOiBCYXNpYyBOZXR3b3JrIFdhdGNoZXJcbiAgICAvLyBOb3RlOiBPbmx5IG9uZSBOZXR3b3JrIFdhdGNoZXIgcGVyIHJlZ2lvbiBwZXIgc3Vic2NyaXB0aW9uIGlzIGFsbG93ZWRcbiAgICBuZXcgTmV0d29ya1dhdGNoZXIodGhpcywgXCJiYXNpYy1uZXR3b3JrLXdhdGNoZXJcIiwge1xuICAgICAgbmFtZTogXCJudy1iYXNpYy1leGFtcGxlXCIsXG4gICAgICBsb2NhdGlvbjogcmVzb3VyY2VHcm91cC5wcm9wcy5sb2NhdGlvbiEsXG4gICAgICByZXNvdXJjZUdyb3VwSWQ6IHJlc291cmNlR3JvdXAuaWQsXG4gICAgICB0YWdzOiB7XG4gICAgICAgIGV4YW1wbGU6IFwiYmFzaWNcIixcbiAgICAgIH0sXG4gICAgfSk7XG5cbiAgICAvLyBFeGFtcGxlIDI6IE5ldHdvcmsgV2F0Y2hlciB3aXRoIHNwZWNpZmljIHZlcnNpb25cbiAgICAvLyBVc2luZyBhIGRpZmZlcmVudCBjb25zdHJ1Y3QgSUQgYnV0IHNhbWUgcmVnaW9uICh0aGlzIGlzIGZvciBkZW1vbnN0cmF0aW9uIG9ubHkgLVxuICAgIC8vIGluIHByYWN0aWNlLCB5b3Ugc2hvdWxkIG9ubHkgaGF2ZSBvbmUgTmV0d29yayBXYXRjaGVyIHBlciByZWdpb24pXG4gICAgLy8gVGhpcyBleGFtcGxlIHNob3dzIHZlcnNpb24gcGlubmluZyBidXQgd291bGQgZmFpbCBpZiBkZXBsb3llZCBhbG9uZ3NpZGUgRXhhbXBsZSAxXG4gICAgLy8gc2luY2UgYm90aCB1c2UgdGhlIHNhbWUgcmVnaW9uLlxuICAgIC8vIFVuY29tbWVudCBmb3IgdGVzdGluZyB2ZXJzaW9uIHBpbm5pbmcgaW4gYSBkaWZmZXJlbnQgcmVnaW9uOlxuICAgIC8qXG4gICAgbmV3IE5ldHdvcmtXYXRjaGVyKHRoaXMsIFwidmVyc2lvbmVkLW5ldHdvcmstd2F0Y2hlclwiLCB7XG4gICAgICBuYW1lOiBcIm53LXZlcnNpb25lZC1leGFtcGxlXCIsXG4gICAgICBsb2NhdGlvbjogXCJ3ZXN0dXMyXCIsICAvLyBEaWZmZXJlbnQgcmVnaW9uXG4gICAgICByZXNvdXJjZUdyb3VwSWQ6IHJlc291cmNlR3JvdXAuaWQsXG4gICAgICBhcGlWZXJzaW9uOiBcIjIwMjQtMDEtMDFcIixcbiAgICAgIHRhZ3M6IHtcbiAgICAgICAgZXhhbXBsZTogXCJ2ZXJzaW9uZWRcIixcbiAgICAgIH0sXG4gICAgfSk7XG4gICAgKi9cbiAgfVxufVxuXG5kZXNjcmliZShcIk5ldHdvcmsgV2F0Y2hlciBJbnRlZ3JhdGlvbiBUZXN0XCIsICgpID0+IHtcbiAgaXQoXCJzaG91bGQgZGVwbG95LCB2YWxpZGF0ZSBpZGVtcG90ZW5jeSwgYW5kIGNsZWFudXAgTmV0d29yayBXYXRjaGVyIHJlc291cmNlc1wiLCAoKSA9PiB7XG4gICAgY29uc3QgYXBwID0gVGVzdGluZy5hcHAoKTtcbiAgICBjb25zdCBzdGFjayA9IG5ldyBOZXR3b3JrV2F0Y2hlckV4YW1wbGVTdGFjayhhcHAsIFwidGVzdC1uZXR3b3JrLXdhdGNoZXJcIik7XG4gICAgY29uc3Qgc3ludGhlc2l6ZWQgPSBUZXN0aW5nLmZ1bGxTeW50aChzdGFjayk7XG5cbiAgICAvLyBUaGlzIHdpbGw6XG4gICAgLy8gMS4gUnVuIHRlcnJhZm9ybSBhcHBseSB0byBkZXBsb3kgcmVzb3VyY2VzXG4gICAgLy8gMi4gUnVuIHRlcnJhZm9ybSBwbGFuIHRvIGNoZWNrIGlkZW1wb3RlbmN5IChubyBjaGFuZ2VzIGV4cGVjdGVkKVxuICAgIC8vIDMuIFJ1biB0ZXJyYWZvcm0gZGVzdHJveSB0byBjbGVhbnVwIHJlc291cmNlc1xuICAgIFRlcnJhZm9ybUFwcGx5Q2hlY2tBbmREZXN0cm95KHN5bnRoZXNpemVkKTtcbiAgfSwgNjAwMDAwKTsgLy8gMTAgbWludXRlIHRpbWVvdXQgZm9yIGRlcGxveW1lbnQgYW5kIGNsZWFudXBcbn0pO1xuIl19
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Comprehensive tests for the NetworkWatcher implementation
|
|
3
|
+
*
|
|
4
|
+
* This test suite validates the NetworkWatcher class using the AzapiResource framework.
|
|
5
|
+
* Tests cover automatic version resolution, explicit version pinning, schema validation,
|
|
6
|
+
* property configurations, and resource creation.
|
|
7
|
+
*/
|
|
8
|
+
export {};
|