@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.
Files changed (121) hide show
  1. package/.jsii +46476 -27231
  2. package/API.md +68443 -28286
  3. package/lib/azure-actiongroup/lib/action-group.js +1 -1
  4. package/lib/azure-activitylogalert/lib/activity-log-alert.js +1 -1
  5. package/lib/azure-aks/lib/aks-cluster.js +1 -1
  6. package/lib/azure-diagnosticsettings/lib/diagnostic-settings.js +1 -1
  7. package/lib/azure-dnsforwardingruleset/lib/dns-forwarding-ruleset.js +1 -1
  8. package/lib/azure-dnsforwardingruleset/lib/forwarding-rule.js +1 -1
  9. package/lib/azure-dnsforwardingruleset/lib/virtual-network-link.js +1 -1
  10. package/lib/azure-dnsresolver/lib/dns-resolver.js +1 -1
  11. package/lib/azure-dnsresolver/lib/inbound-endpoint.js +1 -1
  12. package/lib/azure-dnsresolver/lib/outbound-endpoint.js +1 -1
  13. package/lib/azure-dnszone/lib/dns-zone.js +1 -1
  14. package/lib/azure-dnszone/lib/index.d.ts +1 -0
  15. package/lib/azure-dnszone/lib/index.js +2 -1
  16. package/lib/azure-dnszone/lib/records/dns-record-schemas.d.ts +68 -0
  17. package/lib/azure-dnszone/lib/records/dns-record-schemas.js +813 -0
  18. package/lib/azure-dnszone/lib/records/dns-records.d.ts +688 -0
  19. package/lib/azure-dnszone/lib/records/dns-records.js +924 -0
  20. package/lib/azure-dnszone/lib/records/index.d.ts +19 -0
  21. package/lib/azure-dnszone/lib/records/index.js +38 -0
  22. package/lib/azure-dnszone/test/dns-records.integ.d.ts +21 -0
  23. package/lib/azure-dnszone/test/dns-records.integ.js +321 -0
  24. package/lib/azure-dnszone/test/dns-records.spec.d.ts +20 -0
  25. package/lib/azure-dnszone/test/dns-records.spec.js +950 -0
  26. package/lib/azure-loganalyticsworkspace/index.d.ts +6 -0
  27. package/lib/azure-loganalyticsworkspace/index.js +23 -0
  28. package/lib/azure-loganalyticsworkspace/lib/index.d.ts +5 -0
  29. package/lib/azure-loganalyticsworkspace/lib/index.js +22 -0
  30. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.d.ts +51 -0
  31. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace-schemas.js +255 -0
  32. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.d.ts +301 -0
  33. package/lib/azure-loganalyticsworkspace/lib/log-analytics-workspace.js +213 -0
  34. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.d.ts +9 -0
  35. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.integ.js +71 -0
  36. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.d.ts +8 -0
  37. package/lib/azure-loganalyticsworkspace/test/log-analytics-workspace.spec.js +504 -0
  38. package/lib/azure-metricalert/lib/metric-alert.js +1 -1
  39. package/lib/azure-networkinterface/lib/network-interface.js +1 -1
  40. package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
  41. package/lib/azure-networkwatcher/index.d.ts +14 -0
  42. package/lib/azure-networkwatcher/index.js +31 -0
  43. package/lib/azure-networkwatcher/lib/index.d.ts +5 -0
  44. package/lib/azure-networkwatcher/lib/index.js +22 -0
  45. package/lib/azure-networkwatcher/lib/network-watcher-schemas.d.ts +47 -0
  46. package/lib/azure-networkwatcher/lib/network-watcher-schemas.js +167 -0
  47. package/lib/azure-networkwatcher/lib/network-watcher.d.ts +181 -0
  48. package/lib/azure-networkwatcher/lib/network-watcher.js +187 -0
  49. package/lib/azure-networkwatcher/test/network-watcher.integ.d.ts +12 -0
  50. package/lib/azure-networkwatcher/test/network-watcher.integ.js +84 -0
  51. package/lib/azure-networkwatcher/test/network-watcher.spec.d.ts +8 -0
  52. package/lib/azure-networkwatcher/test/network-watcher.spec.js +312 -0
  53. package/lib/azure-policyassignment/lib/policy-assignment.js +1 -1
  54. package/lib/azure-policydefinition/lib/policy-definition.js +1 -1
  55. package/lib/azure-policysetdefinition/index.d.ts +10 -0
  56. package/lib/azure-policysetdefinition/index.js +27 -0
  57. package/lib/azure-policysetdefinition/lib/index.d.ts +5 -0
  58. package/lib/azure-policysetdefinition/lib/index.js +22 -0
  59. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.d.ts +50 -0
  60. package/lib/azure-policysetdefinition/lib/policy-set-definition-schemas.js +255 -0
  61. package/lib/azure-policysetdefinition/lib/policy-set-definition.d.ts +426 -0
  62. package/lib/azure-policysetdefinition/lib/policy-set-definition.js +255 -0
  63. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.d.ts +9 -0
  64. package/lib/azure-policysetdefinition/test/policy-set-definition.integ.js +56 -0
  65. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.d.ts +8 -0
  66. package/lib/azure-policysetdefinition/test/policy-set-definition.spec.js +745 -0
  67. package/lib/azure-privatednszone/lib/index.d.ts +1 -0
  68. package/lib/azure-privatednszone/lib/index.js +2 -1
  69. package/lib/azure-privatednszone/lib/private-dns-zone.d.ts +0 -2
  70. package/lib/azure-privatednszone/lib/private-dns-zone.js +6 -13
  71. package/lib/azure-privatednszone/lib/records/index.d.ts +7 -0
  72. package/lib/azure-privatednszone/lib/records/index.js +26 -0
  73. package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.d.ts +52 -0
  74. package/lib/azure-privatednszone/lib/records/private-dns-record-schemas.js +683 -0
  75. package/lib/azure-privatednszone/lib/records/private-dns-records.d.ts +523 -0
  76. package/lib/azure-privatednszone/lib/records/private-dns-records.js +739 -0
  77. package/lib/azure-privatednszone/test/private-dns-records.integ.d.ts +19 -0
  78. package/lib/azure-privatednszone/test/private-dns-records.integ.js +245 -0
  79. package/lib/azure-privatednszone/test/private-dns-records.spec.d.ts +18 -0
  80. package/lib/azure-privatednszone/test/private-dns-records.spec.js +756 -0
  81. package/lib/azure-privatednszone/test/private-dns-zone.spec.js +5 -5
  82. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
  83. package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
  84. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  85. package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
  86. package/lib/azure-roledefinition/lib/role-definition.js +1 -1
  87. package/lib/azure-storageaccount/lib/storage-account.js +1 -1
  88. package/lib/azure-subnet/lib/subnet.js +1 -1
  89. package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
  90. package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
  91. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway-schemas.js +2 -2
  92. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.d.ts +4 -2
  93. package/lib/azure-virtualnetworkgateway/lib/virtual-network-gateway.js +8 -5
  94. package/lib/azure-virtualnetworkgateway/test/virtual-network-gateway.spec.js +109 -1
  95. package/lib/azure-virtualnetworkgatewayconnection/lib/virtual-network-gateway-connection.js +1 -1
  96. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  97. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +1 -1
  98. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +1 -1
  99. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  100. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  101. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  102. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  103. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  104. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +1 -1
  105. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  106. package/lib/core-azure/lib/azapi/azapi-resource.js +4 -4
  107. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  108. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  109. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  110. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  111. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  112. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  113. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  114. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  115. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  116. package/lib/index.d.ts +23 -0
  117. package/lib/index.js +25 -2
  118. package/lib/testing/index.js +2 -2
  119. package/lib/testing/lib/cleanup.js +1 -1
  120. package/lib/testing/lib/metadata.js +1 -1
  121. package/package.json +1 -1
@@ -0,0 +1,301 @@
1
+ /**
2
+ * Unified Azure Log Analytics Workspace implementation using AzapiResource framework
3
+ *
4
+ * This class provides a version-aware implementation for Azure Log Analytics Workspace
5
+ * that automatically handles version management, schema validation, and property
6
+ * transformation across all supported API versions.
7
+ *
8
+ * Supported API Versions:
9
+ * - 2023-09-01 (Active, Latest)
10
+ * - 2022-10-01 (Active, Backward Compatibility)
11
+ *
12
+ * Features:
13
+ * - Automatic latest version resolution when no version is specified
14
+ * - Explicit version pinning for stability requirements
15
+ * - Schema-driven validation and transformation
16
+ * - Full JSII compliance for multi-language support
17
+ * - Configurable data retention, SKU, and workspace capping
18
+ * - Public network access controls
19
+ * - Workspace features configuration
20
+ */
21
+ import * as cdktf from "cdktf";
22
+ import { Construct } from "constructs";
23
+ import { AzapiResource, AzapiResourceProps } from "../../core-azure/lib/azapi/azapi-resource";
24
+ import { ApiSchema } from "../../core-azure/lib/version-manager/interfaces/version-interfaces";
25
+ /**
26
+ * SKU configuration for Log Analytics Workspace
27
+ */
28
+ export interface LogAnalyticsWorkspaceSku {
29
+ /**
30
+ * SKU name for the Log Analytics Workspace
31
+ *
32
+ * Available options:
33
+ * - "Free" - Free tier (limited to 500MB/day, 7 day retention)
34
+ * - "Standard" - Standard tier (legacy)
35
+ * - "Premium" - Premium tier (legacy)
36
+ * - "PerNode" - Per node pricing (legacy, for OMS customers)
37
+ * - "PerGB2018" - Pay-as-you-go pricing based on data ingestion
38
+ * - "Standalone" - Standalone tier (legacy)
39
+ * - "CapacityReservation" - Commitment tier with reserved capacity
40
+ *
41
+ * @defaultValue "PerGB2018"
42
+ */
43
+ readonly name: "Free" | "Standard" | "Premium" | "PerNode" | "PerGB2018" | "Standalone" | "CapacityReservation";
44
+ /**
45
+ * Capacity reservation level in GB per day
46
+ * Only applicable when SKU name is "CapacityReservation"
47
+ * Valid values: 100, 200, 300, 400, 500, 1000, 2000, 5000
48
+ */
49
+ readonly capacityReservationLevel?: number;
50
+ }
51
+ /**
52
+ * Workspace capping configuration for daily data ingestion limits
53
+ */
54
+ export interface LogAnalyticsWorkspaceCapping {
55
+ /**
56
+ * Daily volume cap in GB
57
+ * A value of -1 means no cap
58
+ */
59
+ readonly dailyQuotaGb: number;
60
+ }
61
+ /**
62
+ * Workspace features configuration
63
+ */
64
+ export interface LogAnalyticsWorkspaceFeatures {
65
+ /**
66
+ * Flag indicating whether data export is enabled
67
+ */
68
+ readonly enableDataExport?: boolean;
69
+ /**
70
+ * Flag indicating whether data should be immediately purged after 30 days
71
+ * instead of the configured retention period
72
+ */
73
+ readonly immediatePurgeDataOn30Days?: boolean;
74
+ /**
75
+ * Flag indicating whether log access using AADIAM is disabled
76
+ */
77
+ readonly disableLocalAuth?: boolean;
78
+ /**
79
+ * Flag indicating whether cluster resource permissions are enabled
80
+ */
81
+ readonly enableLogAccessUsingOnlyResourcePermissions?: boolean;
82
+ }
83
+ /**
84
+ * Managed identity configuration for the workspace
85
+ */
86
+ export interface LogAnalyticsWorkspaceIdentity {
87
+ /**
88
+ * Type of managed identity
89
+ */
90
+ readonly type: "SystemAssigned" | "UserAssigned" | "SystemAssigned,UserAssigned" | "None";
91
+ /**
92
+ * User-assigned identity resource IDs
93
+ * Required when type includes UserAssigned
94
+ */
95
+ readonly userAssignedIdentities?: {
96
+ [key: string]: any;
97
+ };
98
+ }
99
+ /**
100
+ * Properties for the unified Azure Log Analytics Workspace
101
+ *
102
+ * Extends AzapiResourceProps with Log Analytics Workspace specific properties
103
+ */
104
+ export interface LogAnalyticsWorkspaceProps extends AzapiResourceProps {
105
+ /**
106
+ * Resource Group ID where the workspace will be created
107
+ * The workspace will be created as a child of this resource group
108
+ */
109
+ readonly resourceGroupId: string;
110
+ /**
111
+ * Data retention period in days
112
+ *
113
+ * Values between 30 and 730 are supported for pay-as-you-go pricing.
114
+ * Free tier is limited to 7 days.
115
+ *
116
+ * @defaultValue 30
117
+ */
118
+ readonly retentionInDays?: number;
119
+ /**
120
+ * SKU configuration for the workspace
121
+ *
122
+ * Determines pricing tier and capabilities of the workspace.
123
+ *
124
+ * @defaultValue { name: "PerGB2018" }
125
+ */
126
+ readonly sku?: LogAnalyticsWorkspaceSku;
127
+ /**
128
+ * Daily volume cap for data ingestion
129
+ *
130
+ * When the daily cap is reached, data ingestion stops until the next day.
131
+ * A value of dailyQuotaGb: -1 means no cap.
132
+ */
133
+ readonly workspaceCapping?: LogAnalyticsWorkspaceCapping;
134
+ /**
135
+ * Public network access for data ingestion
136
+ *
137
+ * Controls whether data can be ingested over the public internet.
138
+ *
139
+ * @defaultValue "Enabled"
140
+ */
141
+ readonly publicNetworkAccessForIngestion?: "Enabled" | "Disabled";
142
+ /**
143
+ * Public network access for querying data
144
+ *
145
+ * Controls whether queries can be executed over the public internet.
146
+ *
147
+ * @defaultValue "Enabled"
148
+ */
149
+ readonly publicNetworkAccessForQuery?: "Enabled" | "Disabled";
150
+ /**
151
+ * Workspace features configuration
152
+ *
153
+ * Enables or disables specific workspace features like data export,
154
+ * immediate purge, and local authentication.
155
+ */
156
+ readonly features?: LogAnalyticsWorkspaceFeatures;
157
+ /**
158
+ * Whether customer-managed keys are required for saved searches and alerts
159
+ *
160
+ * When enabled, all saved searches and alerts must use customer-managed keys.
161
+ */
162
+ readonly forceCmkForQuery?: boolean;
163
+ /**
164
+ * Resource ID of the default Data Collection Rule
165
+ *
166
+ * Associates a default DCR with the workspace for data collection.
167
+ * Only available in API version 2023-09-01 and later.
168
+ */
169
+ readonly defaultDataCollectionRuleResourceId?: string;
170
+ /**
171
+ * Managed identity configuration for the workspace
172
+ *
173
+ * Enables managed identity authentication for the workspace.
174
+ */
175
+ readonly identity?: LogAnalyticsWorkspaceIdentity;
176
+ }
177
+ /**
178
+ * Properties for the Log Analytics Workspace request body
179
+ */
180
+ export interface LogAnalyticsWorkspaceBodyProperties {
181
+ readonly retentionInDays?: number;
182
+ readonly sku?: LogAnalyticsWorkspaceSku;
183
+ readonly workspaceCapping?: LogAnalyticsWorkspaceCapping;
184
+ readonly publicNetworkAccessForIngestion?: string;
185
+ readonly publicNetworkAccessForQuery?: string;
186
+ readonly features?: LogAnalyticsWorkspaceFeatures;
187
+ readonly forceCmkForQuery?: boolean;
188
+ readonly defaultDataCollectionRuleResourceId?: string;
189
+ }
190
+ /**
191
+ * The resource body interface for Azure Log Analytics Workspace API calls
192
+ */
193
+ export interface LogAnalyticsWorkspaceBody {
194
+ readonly properties: LogAnalyticsWorkspaceBodyProperties;
195
+ readonly identity?: LogAnalyticsWorkspaceIdentity;
196
+ }
197
+ /**
198
+ * Unified Azure Log Analytics Workspace implementation
199
+ *
200
+ * This class provides a single, version-aware implementation that automatically handles version
201
+ * resolution, schema validation, and property transformation while maintaining full JSII compliance.
202
+ *
203
+ * Log Analytics Workspace is the central destination for log data from Azure resources,
204
+ * applications, and on-premises infrastructure. It enables querying, analysis, and
205
+ * visualization of log data using Kusto Query Language (KQL).
206
+ *
207
+ * @example
208
+ * // Basic Log Analytics Workspace with default settings:
209
+ * const workspace = new LogAnalyticsWorkspace(this, "my-workspace", {
210
+ * name: "my-log-analytics",
211
+ * location: "eastus",
212
+ * resourceGroupId: resourceGroup.id,
213
+ * });
214
+ *
215
+ * @example
216
+ * // Log Analytics Workspace with custom retention and SKU:
217
+ * const workspace = new LogAnalyticsWorkspace(this, "production-workspace", {
218
+ * name: "production-logs",
219
+ * location: "eastus",
220
+ * resourceGroupId: resourceGroup.id,
221
+ * retentionInDays: 90,
222
+ * sku: {
223
+ * name: "PerGB2018"
224
+ * },
225
+ * publicNetworkAccessForIngestion: "Enabled",
226
+ * publicNetworkAccessForQuery: "Enabled",
227
+ * tags: {
228
+ * environment: "production"
229
+ * }
230
+ * });
231
+ *
232
+ * @example
233
+ * // Log Analytics Workspace with capacity reservation:
234
+ * const workspace = new LogAnalyticsWorkspace(this, "high-volume-workspace", {
235
+ * name: "high-volume-logs",
236
+ * location: "eastus",
237
+ * resourceGroupId: resourceGroup.id,
238
+ * retentionInDays: 365,
239
+ * sku: {
240
+ * name: "CapacityReservation",
241
+ * capacityReservationLevel: 500
242
+ * },
243
+ * workspaceCapping: {
244
+ * dailyQuotaGb: 100
245
+ * }
246
+ * });
247
+ *
248
+ * @stability stable
249
+ */
250
+ export declare class LogAnalyticsWorkspace extends AzapiResource {
251
+ /**
252
+ * The input properties for this Log Analytics Workspace instance
253
+ */
254
+ readonly props: LogAnalyticsWorkspaceProps;
255
+ readonly idOutput: cdktf.TerraformOutput;
256
+ readonly nameOutput: cdktf.TerraformOutput;
257
+ readonly workspaceIdOutput: cdktf.TerraformOutput;
258
+ readonly customerIdOutput: cdktf.TerraformOutput;
259
+ /**
260
+ * Creates a new Azure Log Analytics Workspace using the AzapiResource framework
261
+ *
262
+ * The constructor automatically handles version resolution, schema registration,
263
+ * validation, and resource creation.
264
+ *
265
+ * @param scope - The scope in which to define this construct
266
+ * @param id - The unique identifier for this instance
267
+ * @param props - Configuration properties for the Log Analytics Workspace
268
+ */
269
+ constructor(scope: Construct, id: string, props: LogAnalyticsWorkspaceProps);
270
+ /**
271
+ * Gets the default API version to use when no explicit version is specified
272
+ * Returns the latest stable version as the default
273
+ */
274
+ protected defaultVersion(): string;
275
+ /**
276
+ * Gets the Azure resource type for Log Analytics Workspace
277
+ */
278
+ protected resourceType(): string;
279
+ /**
280
+ * Gets the API schema for the resolved version
281
+ * Uses the framework's schema resolution to get the appropriate schema
282
+ */
283
+ protected apiSchema(): ApiSchema;
284
+ /**
285
+ * Indicates that this resource type requires a location
286
+ */
287
+ protected requiresLocation(): boolean;
288
+ /**
289
+ * Creates the resource body for the Azure API call
290
+ * Transforms the input properties into the JSON format expected by Azure REST API
291
+ */
292
+ protected createResourceBody(props: any): any;
293
+ /**
294
+ * Resolves the parent resource ID for Log Analytics Workspace
295
+ * Log Analytics Workspace is a top-level resource within a resource group
296
+ *
297
+ * @param props - The resource properties
298
+ * @returns The parent resource ID (the resource group)
299
+ */
300
+ protected resolveParentId(props: any): string;
301
+ }
@@ -0,0 +1,213 @@
1
+ "use strict";
2
+ var _a;
3
+ Object.defineProperty(exports, "__esModule", { value: true });
4
+ exports.LogAnalyticsWorkspace = void 0;
5
+ const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
6
+ /**
7
+ * Unified Azure Log Analytics Workspace implementation using AzapiResource framework
8
+ *
9
+ * This class provides a version-aware implementation for Azure Log Analytics Workspace
10
+ * that automatically handles version management, schema validation, and property
11
+ * transformation across all supported API versions.
12
+ *
13
+ * Supported API Versions:
14
+ * - 2023-09-01 (Active, Latest)
15
+ * - 2022-10-01 (Active, Backward Compatibility)
16
+ *
17
+ * Features:
18
+ * - Automatic latest version resolution when no version is specified
19
+ * - Explicit version pinning for stability requirements
20
+ * - Schema-driven validation and transformation
21
+ * - Full JSII compliance for multi-language support
22
+ * - Configurable data retention, SKU, and workspace capping
23
+ * - Public network access controls
24
+ * - Workspace features configuration
25
+ */
26
+ const cdktf = require("cdktf");
27
+ const log_analytics_workspace_schemas_1 = require("./log-analytics-workspace-schemas");
28
+ const azapi_resource_1 = require("../../core-azure/lib/azapi/azapi-resource");
29
+ /**
30
+ * Unified Azure Log Analytics Workspace implementation
31
+ *
32
+ * This class provides a single, version-aware implementation that automatically handles version
33
+ * resolution, schema validation, and property transformation while maintaining full JSII compliance.
34
+ *
35
+ * Log Analytics Workspace is the central destination for log data from Azure resources,
36
+ * applications, and on-premises infrastructure. It enables querying, analysis, and
37
+ * visualization of log data using Kusto Query Language (KQL).
38
+ *
39
+ * @example
40
+ * // Basic Log Analytics Workspace with default settings:
41
+ * const workspace = new LogAnalyticsWorkspace(this, "my-workspace", {
42
+ * name: "my-log-analytics",
43
+ * location: "eastus",
44
+ * resourceGroupId: resourceGroup.id,
45
+ * });
46
+ *
47
+ * @example
48
+ * // Log Analytics Workspace with custom retention and SKU:
49
+ * const workspace = new LogAnalyticsWorkspace(this, "production-workspace", {
50
+ * name: "production-logs",
51
+ * location: "eastus",
52
+ * resourceGroupId: resourceGroup.id,
53
+ * retentionInDays: 90,
54
+ * sku: {
55
+ * name: "PerGB2018"
56
+ * },
57
+ * publicNetworkAccessForIngestion: "Enabled",
58
+ * publicNetworkAccessForQuery: "Enabled",
59
+ * tags: {
60
+ * environment: "production"
61
+ * }
62
+ * });
63
+ *
64
+ * @example
65
+ * // Log Analytics Workspace with capacity reservation:
66
+ * const workspace = new LogAnalyticsWorkspace(this, "high-volume-workspace", {
67
+ * name: "high-volume-logs",
68
+ * location: "eastus",
69
+ * resourceGroupId: resourceGroup.id,
70
+ * retentionInDays: 365,
71
+ * sku: {
72
+ * name: "CapacityReservation",
73
+ * capacityReservationLevel: 500
74
+ * },
75
+ * workspaceCapping: {
76
+ * dailyQuotaGb: 100
77
+ * }
78
+ * });
79
+ *
80
+ * @stability stable
81
+ */
82
+ class LogAnalyticsWorkspace extends azapi_resource_1.AzapiResource {
83
+ /**
84
+ * Creates a new Azure Log Analytics Workspace using the AzapiResource framework
85
+ *
86
+ * The constructor automatically handles version resolution, schema registration,
87
+ * validation, and resource creation.
88
+ *
89
+ * @param scope - The scope in which to define this construct
90
+ * @param id - The unique identifier for this instance
91
+ * @param props - Configuration properties for the Log Analytics Workspace
92
+ */
93
+ constructor(scope, id, props) {
94
+ // Validate retention days if provided
95
+ if (props.retentionInDays !== undefined) {
96
+ if (props.retentionInDays < 30 || props.retentionInDays > 730) {
97
+ throw new Error("retentionInDays must be between 30 and 730 days");
98
+ }
99
+ }
100
+ // Validate capacity reservation level if CapacityReservation SKU is used
101
+ if (props.sku?.name === "CapacityReservation") {
102
+ const validLevels = [100, 200, 300, 400, 500, 1000, 2000, 5000];
103
+ if (props.sku.capacityReservationLevel === undefined ||
104
+ !validLevels.includes(props.sku.capacityReservationLevel)) {
105
+ throw new Error(`capacityReservationLevel must be one of ${validLevels.join(", ")} when using CapacityReservation SKU`);
106
+ }
107
+ }
108
+ super(scope, id, props);
109
+ this.props = props;
110
+ // Create Terraform outputs for easy access and referencing from other resources
111
+ this.idOutput = new cdktf.TerraformOutput(this, "id", {
112
+ value: this.id,
113
+ description: "The ID of the Log Analytics Workspace",
114
+ });
115
+ this.nameOutput = new cdktf.TerraformOutput(this, "name", {
116
+ value: `\${${this.terraformResource.fqn}.name}`,
117
+ description: "The name of the Log Analytics Workspace",
118
+ });
119
+ this.workspaceIdOutput = new cdktf.TerraformOutput(this, "workspace_id", {
120
+ value: `\${${this.terraformResource.fqn}.output.properties.customerId}`,
121
+ description: "The unique identifier (workspace ID) of the Log Analytics Workspace",
122
+ });
123
+ this.customerIdOutput = new cdktf.TerraformOutput(this, "customer_id", {
124
+ value: `\${${this.terraformResource.fqn}.output.properties.customerId}`,
125
+ description: "The customer ID (same as workspace ID) of the Log Analytics Workspace",
126
+ });
127
+ // Override logical IDs
128
+ this.idOutput.overrideLogicalId("id");
129
+ this.nameOutput.overrideLogicalId("name");
130
+ this.workspaceIdOutput.overrideLogicalId("workspace_id");
131
+ this.customerIdOutput.overrideLogicalId("customer_id");
132
+ }
133
+ // =============================================================================
134
+ // REQUIRED ABSTRACT METHODS FROM AzapiResource
135
+ // =============================================================================
136
+ /**
137
+ * Gets the default API version to use when no explicit version is specified
138
+ * Returns the latest stable version as the default
139
+ */
140
+ defaultVersion() {
141
+ return "2023-09-01";
142
+ }
143
+ /**
144
+ * Gets the Azure resource type for Log Analytics Workspace
145
+ */
146
+ resourceType() {
147
+ return log_analytics_workspace_schemas_1.LOG_ANALYTICS_WORKSPACE_TYPE;
148
+ }
149
+ /**
150
+ * Gets the API schema for the resolved version
151
+ * Uses the framework's schema resolution to get the appropriate schema
152
+ */
153
+ apiSchema() {
154
+ return this.resolveSchema();
155
+ }
156
+ /**
157
+ * Indicates that this resource type requires a location
158
+ */
159
+ requiresLocation() {
160
+ return true;
161
+ }
162
+ /**
163
+ * Creates the resource body for the Azure API call
164
+ * Transforms the input properties into the JSON format expected by Azure REST API
165
+ */
166
+ createResourceBody(props) {
167
+ const typedProps = props;
168
+ const body = {
169
+ properties: {
170
+ retentionInDays: typedProps.retentionInDays ?? 30,
171
+ sku: typedProps.sku ?? { name: "PerGB2018" },
172
+ publicNetworkAccessForIngestion: typedProps.publicNetworkAccessForIngestion ?? "Enabled",
173
+ publicNetworkAccessForQuery: typedProps.publicNetworkAccessForQuery ?? "Enabled",
174
+ },
175
+ };
176
+ // Add optional properties only if specified
177
+ if (typedProps.workspaceCapping) {
178
+ body.properties.workspaceCapping = typedProps.workspaceCapping;
179
+ }
180
+ if (typedProps.features) {
181
+ body.properties.features = typedProps.features;
182
+ }
183
+ if (typedProps.forceCmkForQuery !== undefined) {
184
+ body.properties.forceCmkForQuery = typedProps.forceCmkForQuery;
185
+ }
186
+ if (typedProps.defaultDataCollectionRuleResourceId) {
187
+ body.properties.defaultDataCollectionRuleResourceId =
188
+ typedProps.defaultDataCollectionRuleResourceId;
189
+ }
190
+ // Add identity at the top level if specified
191
+ if (typedProps.identity) {
192
+ body.identity = typedProps.identity;
193
+ }
194
+ return body;
195
+ }
196
+ /**
197
+ * Resolves the parent resource ID for Log Analytics Workspace
198
+ * Log Analytics Workspace is a top-level resource within a resource group
199
+ *
200
+ * @param props - The resource properties
201
+ * @returns The parent resource ID (the resource group)
202
+ */
203
+ resolveParentId(props) {
204
+ return props.resourceGroupId;
205
+ }
206
+ }
207
+ exports.LogAnalyticsWorkspace = LogAnalyticsWorkspace;
208
+ _a = JSII_RTTI_SYMBOL_1;
209
+ LogAnalyticsWorkspace[_a] = { fqn: "@microsoft/terraform-cdk-constructs.LogAnalyticsWorkspace", version: "1.9.0" };
210
+ (() => {
211
+ azapi_resource_1.AzapiResource.registerSchemas(log_analytics_workspace_schemas_1.LOG_ANALYTICS_WORKSPACE_TYPE, log_analytics_workspace_schemas_1.ALL_LOG_ANALYTICS_WORKSPACE_VERSIONS);
212
+ })();
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"log-analytics-workspace.js","sourceRoot":"","sources":["../../../src/azure-loganalyticsworkspace/lib/log-analytics-workspace.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Unified Azure Log Analytics Workspace implementation using AzapiResource framework\n *\n * This class provides a version-aware implementation for Azure Log Analytics Workspace\n * that automatically handles version management, schema validation, and property\n * transformation across all supported API versions.\n *\n * Supported API Versions:\n * - 2023-09-01 (Active, Latest)\n * - 2022-10-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 * - Configurable data retention, SKU, and workspace capping\n * - Public network access controls\n * - Workspace features configuration\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ALL_LOG_ANALYTICS_WORKSPACE_VERSIONS,\n  LOG_ANALYTICS_WORKSPACE_TYPE,\n} from \"./log-analytics-workspace-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 * SKU configuration for Log Analytics Workspace\n */\nexport interface LogAnalyticsWorkspaceSku {\n  /**\n   * SKU name for the Log Analytics Workspace\n   *\n   * Available options:\n   * - \"Free\" - Free tier (limited to 500MB/day, 7 day retention)\n   * - \"Standard\" - Standard tier (legacy)\n   * - \"Premium\" - Premium tier (legacy)\n   * - \"PerNode\" - Per node pricing (legacy, for OMS customers)\n   * - \"PerGB2018\" - Pay-as-you-go pricing based on data ingestion\n   * - \"Standalone\" - Standalone tier (legacy)\n   * - \"CapacityReservation\" - Commitment tier with reserved capacity\n   *\n   * @defaultValue \"PerGB2018\"\n   */\n  readonly name:\n    | \"Free\"\n    | \"Standard\"\n    | \"Premium\"\n    | \"PerNode\"\n    | \"PerGB2018\"\n    | \"Standalone\"\n    | \"CapacityReservation\";\n\n  /**\n   * Capacity reservation level in GB per day\n   * Only applicable when SKU name is \"CapacityReservation\"\n   * Valid values: 100, 200, 300, 400, 500, 1000, 2000, 5000\n   */\n  readonly capacityReservationLevel?: number;\n}\n\n/**\n * Workspace capping configuration for daily data ingestion limits\n */\nexport interface LogAnalyticsWorkspaceCapping {\n  /**\n   * Daily volume cap in GB\n   * A value of -1 means no cap\n   */\n  readonly dailyQuotaGb: number;\n}\n\n/**\n * Workspace features configuration\n */\nexport interface LogAnalyticsWorkspaceFeatures {\n  /**\n   * Flag indicating whether data export is enabled\n   */\n  readonly enableDataExport?: boolean;\n\n  /**\n   * Flag indicating whether data should be immediately purged after 30 days\n   * instead of the configured retention period\n   */\n  readonly immediatePurgeDataOn30Days?: boolean;\n\n  /**\n   * Flag indicating whether log access using AADIAM is disabled\n   */\n  readonly disableLocalAuth?: boolean;\n\n  /**\n   * Flag indicating whether cluster resource permissions are enabled\n   */\n  readonly enableLogAccessUsingOnlyResourcePermissions?: boolean;\n}\n\n/**\n * Managed identity configuration for the workspace\n */\nexport interface LogAnalyticsWorkspaceIdentity {\n  /**\n   * Type of managed identity\n   */\n  readonly type:\n    | \"SystemAssigned\"\n    | \"UserAssigned\"\n    | \"SystemAssigned,UserAssigned\"\n    | \"None\";\n\n  /**\n   * User-assigned identity resource IDs\n   * Required when type includes UserAssigned\n   */\n  readonly userAssignedIdentities?: { [key: string]: any };\n}\n\n/**\n * Properties for the unified Azure Log Analytics Workspace\n *\n * Extends AzapiResourceProps with Log Analytics Workspace specific properties\n */\nexport interface LogAnalyticsWorkspaceProps extends AzapiResourceProps {\n  /**\n   * Resource Group ID where the workspace will be created\n   * The workspace will be created as a child of this resource group\n   */\n  readonly resourceGroupId: string;\n\n  /**\n   * Data retention period in days\n   *\n   * Values between 30 and 730 are supported for pay-as-you-go pricing.\n   * Free tier is limited to 7 days.\n   *\n   * @defaultValue 30\n   */\n  readonly retentionInDays?: number;\n\n  /**\n   * SKU configuration for the workspace\n   *\n   * Determines pricing tier and capabilities of the workspace.\n   *\n   * @defaultValue { name: \"PerGB2018\" }\n   */\n  readonly sku?: LogAnalyticsWorkspaceSku;\n\n  /**\n   * Daily volume cap for data ingestion\n   *\n   * When the daily cap is reached, data ingestion stops until the next day.\n   * A value of dailyQuotaGb: -1 means no cap.\n   */\n  readonly workspaceCapping?: LogAnalyticsWorkspaceCapping;\n\n  /**\n   * Public network access for data ingestion\n   *\n   * Controls whether data can be ingested over the public internet.\n   *\n   * @defaultValue \"Enabled\"\n   */\n  readonly publicNetworkAccessForIngestion?: \"Enabled\" | \"Disabled\";\n\n  /**\n   * Public network access for querying data\n   *\n   * Controls whether queries can be executed over the public internet.\n   *\n   * @defaultValue \"Enabled\"\n   */\n  readonly publicNetworkAccessForQuery?: \"Enabled\" | \"Disabled\";\n\n  /**\n   * Workspace features configuration\n   *\n   * Enables or disables specific workspace features like data export,\n   * immediate purge, and local authentication.\n   */\n  readonly features?: LogAnalyticsWorkspaceFeatures;\n\n  /**\n   * Whether customer-managed keys are required for saved searches and alerts\n   *\n   * When enabled, all saved searches and alerts must use customer-managed keys.\n   */\n  readonly forceCmkForQuery?: boolean;\n\n  /**\n   * Resource ID of the default Data Collection Rule\n   *\n   * Associates a default DCR with the workspace for data collection.\n   * Only available in API version 2023-09-01 and later.\n   */\n  readonly defaultDataCollectionRuleResourceId?: string;\n\n  /**\n   * Managed identity configuration for the workspace\n   *\n   * Enables managed identity authentication for the workspace.\n   */\n  readonly identity?: LogAnalyticsWorkspaceIdentity;\n}\n\n/**\n * Properties for the Log Analytics Workspace request body\n */\nexport interface LogAnalyticsWorkspaceBodyProperties {\n  readonly retentionInDays?: number;\n  readonly sku?: LogAnalyticsWorkspaceSku;\n  readonly workspaceCapping?: LogAnalyticsWorkspaceCapping;\n  readonly publicNetworkAccessForIngestion?: string;\n  readonly publicNetworkAccessForQuery?: string;\n  readonly features?: LogAnalyticsWorkspaceFeatures;\n  readonly forceCmkForQuery?: boolean;\n  readonly defaultDataCollectionRuleResourceId?: string;\n}\n\n/**\n * The resource body interface for Azure Log Analytics Workspace API calls\n */\nexport interface LogAnalyticsWorkspaceBody {\n  readonly properties: LogAnalyticsWorkspaceBodyProperties;\n  readonly identity?: LogAnalyticsWorkspaceIdentity;\n}\n\n/**\n * Unified Azure Log Analytics Workspace 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 * Log Analytics Workspace is the central destination for log data from Azure resources,\n * applications, and on-premises infrastructure. It enables querying, analysis, and\n * visualization of log data using Kusto Query Language (KQL).\n *\n * @example\n * // Basic Log Analytics Workspace with default settings:\n * const workspace = new LogAnalyticsWorkspace(this, \"my-workspace\", {\n *   name: \"my-log-analytics\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n * });\n *\n * @example\n * // Log Analytics Workspace with custom retention and SKU:\n * const workspace = new LogAnalyticsWorkspace(this, \"production-workspace\", {\n *   name: \"production-logs\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   retentionInDays: 90,\n *   sku: {\n *     name: \"PerGB2018\"\n *   },\n *   publicNetworkAccessForIngestion: \"Enabled\",\n *   publicNetworkAccessForQuery: \"Enabled\",\n *   tags: {\n *     environment: \"production\"\n *   }\n * });\n *\n * @example\n * // Log Analytics Workspace with capacity reservation:\n * const workspace = new LogAnalyticsWorkspace(this, \"high-volume-workspace\", {\n *   name: \"high-volume-logs\",\n *   location: \"eastus\",\n *   resourceGroupId: resourceGroup.id,\n *   retentionInDays: 365,\n *   sku: {\n *     name: \"CapacityReservation\",\n *     capacityReservationLevel: 500\n *   },\n *   workspaceCapping: {\n *     dailyQuotaGb: 100\n *   }\n * });\n *\n * @stability stable\n */\nexport class LogAnalyticsWorkspace extends AzapiResource {\n  static {\n    AzapiResource.registerSchemas(\n      LOG_ANALYTICS_WORKSPACE_TYPE,\n      ALL_LOG_ANALYTICS_WORKSPACE_VERSIONS,\n    );\n  }\n\n  /**\n   * The input properties for this Log Analytics Workspace instance\n   */\n  public readonly props: LogAnalyticsWorkspaceProps;\n\n  // Output properties for easy access and referencing\n  public readonly idOutput: cdktf.TerraformOutput;\n  public readonly nameOutput: cdktf.TerraformOutput;\n  public readonly workspaceIdOutput: cdktf.TerraformOutput;\n  public readonly customerIdOutput: cdktf.TerraformOutput;\n\n  /**\n   * Creates a new Azure Log Analytics Workspace using the AzapiResource framework\n   *\n   * The constructor automatically handles version resolution, schema registration,\n   * validation, and resource creation.\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 Log Analytics Workspace\n   */\n  constructor(scope: Construct, id: string, props: LogAnalyticsWorkspaceProps) {\n    // Validate retention days if provided\n    if (props.retentionInDays !== undefined) {\n      if (props.retentionInDays < 30 || props.retentionInDays > 730) {\n        throw new Error(\"retentionInDays must be between 30 and 730 days\");\n      }\n    }\n\n    // Validate capacity reservation level if CapacityReservation SKU is used\n    if (props.sku?.name === \"CapacityReservation\") {\n      const validLevels = [100, 200, 300, 400, 500, 1000, 2000, 5000];\n      if (\n        props.sku.capacityReservationLevel === undefined ||\n        !validLevels.includes(props.sku.capacityReservationLevel)\n      ) {\n        throw new Error(\n          `capacityReservationLevel must be one of ${validLevels.join(\", \")} when using CapacityReservation SKU`,\n        );\n      }\n    }\n\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 Log Analytics Workspace\",\n    });\n\n    this.nameOutput = new cdktf.TerraformOutput(this, \"name\", {\n      value: `\\${${this.terraformResource.fqn}.name}`,\n      description: \"The name of the Log Analytics Workspace\",\n    });\n\n    this.workspaceIdOutput = new cdktf.TerraformOutput(this, \"workspace_id\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.customerId}`,\n      description:\n        \"The unique identifier (workspace ID) of the Log Analytics Workspace\",\n    });\n\n    this.customerIdOutput = new cdktf.TerraformOutput(this, \"customer_id\", {\n      value: `\\${${this.terraformResource.fqn}.output.properties.customerId}`,\n      description:\n        \"The customer ID (same as workspace ID) of the Log Analytics Workspace\",\n    });\n\n    // Override logical IDs\n    this.idOutput.overrideLogicalId(\"id\");\n    this.nameOutput.overrideLogicalId(\"name\");\n    this.workspaceIdOutput.overrideLogicalId(\"workspace_id\");\n    this.customerIdOutput.overrideLogicalId(\"customer_id\");\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 \"2023-09-01\";\n  }\n\n  /**\n   * Gets the Azure resource type for Log Analytics Workspace\n   */\n  protected resourceType(): string {\n    return LOG_ANALYTICS_WORKSPACE_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   * Transforms the input properties into the JSON format expected by Azure REST API\n   */\n  protected createResourceBody(props: any): any {\n    const typedProps = props as LogAnalyticsWorkspaceProps;\n\n    const body: any = {\n      properties: {\n        retentionInDays: typedProps.retentionInDays ?? 30,\n        sku: typedProps.sku ?? { name: \"PerGB2018\" },\n        publicNetworkAccessForIngestion:\n          typedProps.publicNetworkAccessForIngestion ?? \"Enabled\",\n        publicNetworkAccessForQuery:\n          typedProps.publicNetworkAccessForQuery ?? \"Enabled\",\n      },\n    };\n\n    // Add optional properties only if specified\n    if (typedProps.workspaceCapping) {\n      body.properties.workspaceCapping = typedProps.workspaceCapping;\n    }\n\n    if (typedProps.features) {\n      body.properties.features = typedProps.features;\n    }\n\n    if (typedProps.forceCmkForQuery !== undefined) {\n      body.properties.forceCmkForQuery = typedProps.forceCmkForQuery;\n    }\n\n    if (typedProps.defaultDataCollectionRuleResourceId) {\n      body.properties.defaultDataCollectionRuleResourceId =\n        typedProps.defaultDataCollectionRuleResourceId;\n    }\n\n    // Add identity at the top level if specified\n    if (typedProps.identity) {\n      body.identity = typedProps.identity;\n    }\n\n    return body;\n  }\n\n  /**\n   * Resolves the parent resource ID for Log Analytics Workspace\n   * Log Analytics Workspace 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 LogAnalyticsWorkspaceProps).resourceGroupId;\n  }\n}\n"]}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Integration test for Azure Log Analytics Workspace
3
+ *
4
+ * This test demonstrates basic usage of the LogAnalyticsWorkspace construct
5
+ * and validates deployment, idempotency, and cleanup.
6
+ *
7
+ * Run with: npm run integration:nostream
8
+ */
9
+ import "cdktf/lib/testing/adapters/jest";
@@ -0,0 +1,71 @@
1
+ "use strict";
2
+ /**
3
+ * Integration test for Azure Log Analytics Workspace
4
+ *
5
+ * This test demonstrates basic usage of the LogAnalyticsWorkspace construct
6
+ * and validates deployment, idempotency, and cleanup.
7
+ *
8
+ * Run with: npm run integration:nostream
9
+ */
10
+ Object.defineProperty(exports, "__esModule", { value: true });
11
+ const cdktf_1 = require("cdktf");
12
+ require("cdktf/lib/testing/adapters/jest");
13
+ const azure_resourcegroup_1 = require("../../azure-resourcegroup");
14
+ const provider_1 = require("../../core-azure/lib/azapi/providers-azapi/provider");
15
+ const testing_1 = require("../../testing");
16
+ const log_analytics_workspace_1 = require("../lib/log-analytics-workspace");
17
+ /**
18
+ * Example stack demonstrating Log Analytics Workspace usage
19
+ */
20
+ class LogAnalyticsWorkspaceExampleStack extends cdktf_1.TerraformStack {
21
+ constructor(scope, id) {
22
+ super(scope, id);
23
+ // Configure AZAPI provider
24
+ new provider_1.AzapiProvider(this, "azapi", {});
25
+ // Create a resource group
26
+ const resourceGroup = new azure_resourcegroup_1.ResourceGroup(this, "example-rg", {
27
+ name: "law-example-rg",
28
+ location: "eastus",
29
+ tags: {
30
+ environment: "example",
31
+ purpose: "integration-test",
32
+ },
33
+ });
34
+ // Example 1: Basic Log Analytics Workspace
35
+ new log_analytics_workspace_1.LogAnalyticsWorkspace(this, "basic-workspace", {
36
+ name: "law-basic-example",
37
+ location: resourceGroup.props.location,
38
+ resourceGroupId: resourceGroup.id,
39
+ tags: {
40
+ example: "basic",
41
+ },
42
+ });
43
+ // Example 2: Log Analytics Workspace with specific version
44
+ new log_analytics_workspace_1.LogAnalyticsWorkspace(this, "versioned-workspace", {
45
+ name: "law-versioned-example",
46
+ location: resourceGroup.props.location,
47
+ resourceGroupId: resourceGroup.id,
48
+ retentionInDays: 60,
49
+ sku: {
50
+ name: "PerGB2018",
51
+ },
52
+ apiVersion: "2023-09-01",
53
+ tags: {
54
+ example: "versioned",
55
+ },
56
+ });
57
+ }
58
+ }
59
+ describe("Log Analytics Workspace Integration Test", () => {
60
+ it("should deploy, validate idempotency, and cleanup Log Analytics Workspace resources", () => {
61
+ const app = cdktf_1.Testing.app();
62
+ const stack = new LogAnalyticsWorkspaceExampleStack(app, "test-log-analytics-workspace");
63
+ const synthesized = cdktf_1.Testing.fullSynth(stack);
64
+ // This will:
65
+ // 1. Run terraform apply to deploy resources
66
+ // 2. Run terraform plan to check idempotency (no changes expected)
67
+ // 3. Run terraform destroy to cleanup resources
68
+ (0, testing_1.TerraformApplyCheckAndDestroy)(synthesized);
69
+ }, 600000); // 10 minute timeout for deployment and cleanup
70
+ });
71
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9nLWFuYWx5dGljcy13b3Jrc3BhY2UuaW50ZWcuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXp1cmUtbG9nYW5hbHl0aWNzd29ya3NwYWNlL3Rlc3QvbG9nLWFuYWx5dGljcy13b3Jrc3BhY2UuaW50ZWcudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBOzs7Ozs7O0dBT0c7O0FBRUgsaUNBQWdEO0FBRWhELDJDQUF5QztBQUN6QyxtRUFBMEQ7QUFDMUQsa0ZBQW9GO0FBQ3BGLDJDQUE4RDtBQUM5RCw0RUFBdUU7QUFFdkU7O0dBRUc7QUFDSCxNQUFNLGlDQUFrQyxTQUFRLHNCQUFjO0lBQzVELFlBQVksS0FBZ0IsRUFBRSxFQUFVO1FBQ3RDLEtBQUssQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFakIsMkJBQTJCO1FBQzNCLElBQUksd0JBQWEsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1FBRXJDLDBCQUEwQjtRQUMxQixNQUFNLGFBQWEsR0FBRyxJQUFJLG1DQUFhLENBQUMsSUFBSSxFQUFFLFlBQVksRUFBRTtZQUMxRCxJQUFJLEVBQUUsZ0JBQWdCO1lBQ3RCLFFBQVEsRUFBRSxRQUFRO1lBQ2xCLElBQUksRUFBRTtnQkFDSixXQUFXLEVBQUUsU0FBUztnQkFDdEIsT0FBTyxFQUFFLGtCQUFrQjthQUM1QjtTQUNGLENBQUMsQ0FBQztRQUVILDJDQUEyQztRQUMzQyxJQUFJLCtDQUFxQixDQUFDLElBQUksRUFBRSxpQkFBaUIsRUFBRTtZQUNqRCxJQUFJLEVBQUUsbUJBQW1CO1lBQ3pCLFFBQVEsRUFBRSxhQUFhLENBQUMsS0FBSyxDQUFDLFFBQVM7WUFDdkMsZUFBZSxFQUFFLGFBQWEsQ0FBQyxFQUFFO1lBQ2pDLElBQUksRUFBRTtnQkFDSixPQUFPLEVBQUUsT0FBTzthQUNqQjtTQUNGLENBQUMsQ0FBQztRQUVILDJEQUEyRDtRQUMzRCxJQUFJLCtDQUFxQixDQUFDLElBQUksRUFBRSxxQkFBcUIsRUFBRTtZQUNyRCxJQUFJLEVBQUUsdUJBQXVCO1lBQzdCLFFBQVEsRUFBRSxhQUFhLENBQUMsS0FBSyxDQUFDLFFBQVM7WUFDdkMsZUFBZSxFQUFFLGFBQWEsQ0FBQyxFQUFFO1lBQ2pDLGVBQWUsRUFBRSxFQUFFO1lBQ25CLEdBQUcsRUFBRTtnQkFDSCxJQUFJLEVBQUUsV0FBVzthQUNsQjtZQUNELFVBQVUsRUFBRSxZQUFZO1lBQ3hCLElBQUksRUFBRTtnQkFDSixPQUFPLEVBQUUsV0FBVzthQUNyQjtTQUNGLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRjtBQUVELFFBQVEsQ0FBQywwQ0FBMEMsRUFBRSxHQUFHLEVBQUU7SUFDeEQsRUFBRSxDQUFDLG9GQUFvRixFQUFFLEdBQUcsRUFBRTtRQUM1RixNQUFNLEdBQUcsR0FBRyxlQUFPLENBQUMsR0FBRyxFQUFFLENBQUM7UUFDMUIsTUFBTSxLQUFLLEdBQUcsSUFBSSxpQ0FBaUMsQ0FDakQsR0FBRyxFQUNILDhCQUE4QixDQUMvQixDQUFDO1FBQ0YsTUFBTSxXQUFXLEdBQUcsZUFBTyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUU3QyxhQUFhO1FBQ2IsNkNBQTZDO1FBQzdDLG1FQUFtRTtRQUNuRSxnREFBZ0Q7UUFDaEQsSUFBQSx1Q0FBNkIsRUFBQyxXQUFXLENBQUMsQ0FBQztJQUM3QyxDQUFDLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQywrQ0FBK0M7QUFDN0QsQ0FBQyxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEludGVncmF0aW9uIHRlc3QgZm9yIEF6dXJlIExvZyBBbmFseXRpY3MgV29ya3NwYWNlXG4gKlxuICogVGhpcyB0ZXN0IGRlbW9uc3RyYXRlcyBiYXNpYyB1c2FnZSBvZiB0aGUgTG9nQW5hbHl0aWNzV29ya3NwYWNlIGNvbnN0cnVjdFxuICogYW5kIHZhbGlkYXRlcyBkZXBsb3ltZW50LCBpZGVtcG90ZW5jeSwgYW5kIGNsZWFudXAuXG4gKlxuICogUnVuIHdpdGg6IG5wbSBydW4gaW50ZWdyYXRpb246bm9zdHJlYW1cbiAqL1xuXG5pbXBvcnQgeyBUZXN0aW5nLCBUZXJyYWZvcm1TdGFjayB9IGZyb20gXCJjZGt0ZlwiO1xuaW1wb3J0IHsgQ29uc3RydWN0IH0gZnJvbSBcImNvbnN0cnVjdHNcIjtcbmltcG9ydCBcImNka3RmL2xpYi90ZXN0aW5nL2FkYXB0ZXJzL2plc3RcIjtcbmltcG9ydCB7IFJlc291cmNlR3JvdXAgfSBmcm9tIFwiLi4vLi4vYXp1cmUtcmVzb3VyY2Vncm91cFwiO1xuaW1wb3J0IHsgQXphcGlQcm92aWRlciB9IGZyb20gXCIuLi8uLi9jb3JlLWF6dXJlL2xpYi9hemFwaS9wcm92aWRlcnMtYXphcGkvcHJvdmlkZXJcIjtcbmltcG9ydCB7IFRlcnJhZm9ybUFwcGx5Q2hlY2tBbmREZXN0cm95IH0gZnJvbSBcIi4uLy4uL3Rlc3RpbmdcIjtcbmltcG9ydCB7IExvZ0FuYWx5dGljc1dvcmtzcGFjZSB9IGZyb20gXCIuLi9saWIvbG9nLWFuYWx5dGljcy13b3Jrc3BhY2VcIjtcblxuLyoqXG4gKiBFeGFtcGxlIHN0YWNrIGRlbW9uc3RyYXRpbmcgTG9nIEFuYWx5dGljcyBXb3Jrc3BhY2UgdXNhZ2VcbiAqL1xuY2xhc3MgTG9nQW5hbHl0aWNzV29ya3NwYWNlRXhhbXBsZVN0YWNrIGV4dGVuZHMgVGVycmFmb3JtU3RhY2sge1xuICBjb25zdHJ1Y3RvcihzY29wZTogQ29uc3RydWN0LCBpZDogc3RyaW5nKSB7XG4gICAgc3VwZXIoc2NvcGUsIGlkKTtcblxuICAgIC8vIENvbmZpZ3VyZSBBWkFQSSBwcm92aWRlclxuICAgIG5ldyBBemFwaVByb3ZpZGVyKHRoaXMsIFwiYXphcGlcIiwge30pO1xuXG4gICAgLy8gQ3JlYXRlIGEgcmVzb3VyY2UgZ3JvdXBcbiAgICBjb25zdCByZXNvdXJjZUdyb3VwID0gbmV3IFJlc291cmNlR3JvdXAodGhpcywgXCJleGFtcGxlLXJnXCIsIHtcbiAgICAgIG5hbWU6IFwibGF3LWV4YW1wbGUtcmdcIixcbiAgICAgIGxvY2F0aW9uOiBcImVhc3R1c1wiLFxuICAgICAgdGFnczoge1xuICAgICAgICBlbnZpcm9ubWVudDogXCJleGFtcGxlXCIsXG4gICAgICAgIHB1cnBvc2U6IFwiaW50ZWdyYXRpb24tdGVzdFwiLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vIEV4YW1wbGUgMTogQmFzaWMgTG9nIEFuYWx5dGljcyBXb3Jrc3BhY2VcbiAgICBuZXcgTG9nQW5hbHl0aWNzV29ya3NwYWNlKHRoaXMsIFwiYmFzaWMtd29ya3NwYWNlXCIsIHtcbiAgICAgIG5hbWU6IFwibGF3LWJhc2ljLWV4YW1wbGVcIixcbiAgICAgIGxvY2F0aW9uOiByZXNvdXJjZUdyb3VwLnByb3BzLmxvY2F0aW9uISxcbiAgICAgIHJlc291cmNlR3JvdXBJZDogcmVzb3VyY2VHcm91cC5pZCxcbiAgICAgIHRhZ3M6IHtcbiAgICAgICAgZXhhbXBsZTogXCJiYXNpY1wiLFxuICAgICAgfSxcbiAgICB9KTtcblxuICAgIC8vIEV4YW1wbGUgMjogTG9nIEFuYWx5dGljcyBXb3Jrc3BhY2Ugd2l0aCBzcGVjaWZpYyB2ZXJzaW9uXG4gICAgbmV3IExvZ0FuYWx5dGljc1dvcmtzcGFjZSh0aGlzLCBcInZlcnNpb25lZC13b3Jrc3BhY2VcIiwge1xuICAgICAgbmFtZTogXCJsYXctdmVyc2lvbmVkLWV4YW1wbGVcIixcbiAgICAgIGxvY2F0aW9uOiByZXNvdXJjZUdyb3VwLnByb3BzLmxvY2F0aW9uISxcbiAgICAgIHJlc291cmNlR3JvdXBJZDogcmVzb3VyY2VHcm91cC5pZCxcbiAgICAgIHJldGVudGlvbkluRGF5czogNjAsXG4gICAgICBza3U6IHtcbiAgICAgICAgbmFtZTogXCJQZXJHQjIwMThcIixcbiAgICAgIH0sXG4gICAgICBhcGlWZXJzaW9uOiBcIjIwMjMtMDktMDFcIixcbiAgICAgIHRhZ3M6IHtcbiAgICAgICAgZXhhbXBsZTogXCJ2ZXJzaW9uZWRcIixcbiAgICAgIH0sXG4gICAgfSk7XG4gIH1cbn1cblxuZGVzY3JpYmUoXCJMb2cgQW5hbHl0aWNzIFdvcmtzcGFjZSBJbnRlZ3JhdGlvbiBUZXN0XCIsICgpID0+IHtcbiAgaXQoXCJzaG91bGQgZGVwbG95LCB2YWxpZGF0ZSBpZGVtcG90ZW5jeSwgYW5kIGNsZWFudXAgTG9nIEFuYWx5dGljcyBXb3Jrc3BhY2UgcmVzb3VyY2VzXCIsICgpID0+IHtcbiAgICBjb25zdCBhcHAgPSBUZXN0aW5nLmFwcCgpO1xuICAgIGNvbnN0IHN0YWNrID0gbmV3IExvZ0FuYWx5dGljc1dvcmtzcGFjZUV4YW1wbGVTdGFjayhcbiAgICAgIGFwcCxcbiAgICAgIFwidGVzdC1sb2ctYW5hbHl0aWNzLXdvcmtzcGFjZVwiLFxuICAgICk7XG4gICAgY29uc3Qgc3ludGhlc2l6ZWQgPSBUZXN0aW5nLmZ1bGxTeW50aChzdGFjayk7XG5cbiAgICAvLyBUaGlzIHdpbGw6XG4gICAgLy8gMS4gUnVuIHRlcnJhZm9ybSBhcHBseSB0byBkZXBsb3kgcmVzb3VyY2VzXG4gICAgLy8gMi4gUnVuIHRlcnJhZm9ybSBwbGFuIHRvIGNoZWNrIGlkZW1wb3RlbmN5IChubyBjaGFuZ2VzIGV4cGVjdGVkKVxuICAgIC8vIDMuIFJ1biB0ZXJyYWZvcm0gZGVzdHJveSB0byBjbGVhbnVwIHJlc291cmNlc1xuICAgIFRlcnJhZm9ybUFwcGx5Q2hlY2tBbmREZXN0cm95KHN5bnRoZXNpemVkKTtcbiAgfSwgNjAwMDAwKTsgLy8gMTAgbWludXRlIHRpbWVvdXQgZm9yIGRlcGxveW1lbnQgYW5kIGNsZWFudXBcbn0pO1xuIl19
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Comprehensive tests for the LogAnalyticsWorkspace implementation
3
+ *
4
+ * This test suite validates the LogAnalyticsWorkspace 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 {};