@microsoft/terraform-cdk-constructs 1.3.0 → 1.4.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 (76) hide show
  1. package/.jsii +22673 -19618
  2. package/API.md +25592 -20586
  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-metricalert/lib/metric-alert.js +1 -1
  15. package/lib/azure-networkinterface/lib/network-interface.js +1 -1
  16. package/lib/azure-networksecuritygroup/lib/network-security-group.js +1 -1
  17. package/lib/azure-policyassignment/lib/policy-assignment.d.ts +7 -0
  18. package/lib/azure-policyassignment/lib/policy-assignment.js +11 -2
  19. package/lib/azure-policydefinition/lib/policy-definition.d.ts +21 -0
  20. package/lib/azure-policydefinition/lib/policy-definition.js +40 -3
  21. package/lib/azure-policydefinition/test/policy-definition.spec.js +211 -1
  22. package/lib/azure-privatednszone/lib/private-dns-zone.js +1 -1
  23. package/lib/azure-privatednszonelink/lib/private-dns-zone-link.js +1 -1
  24. package/lib/azure-publicipaddress/lib/public-ip-address.js +1 -1
  25. package/lib/azure-resourcegroup/lib/resource-group.js +1 -1
  26. package/lib/azure-roleassignment/lib/role-assignment.js +1 -1
  27. package/lib/azure-roledefinition/lib/role-definition.js +1 -1
  28. package/lib/azure-storageaccount/lib/storage-account.js +1 -1
  29. package/lib/azure-subnet/lib/subnet.js +1 -1
  30. package/lib/azure-virtualmachine/lib/virtual-machine.js +1 -1
  31. package/lib/azure-virtualnetwork/lib/virtual-network.js +1 -1
  32. package/lib/azure-virtualnetworkmanager/lib/connectivity-configuration.js +1 -1
  33. package/lib/azure-virtualnetworkmanager/lib/index.d.ts +5 -0
  34. package/lib/azure-virtualnetworkmanager/lib/index.js +6 -1
  35. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.d.ts +24 -0
  36. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-schemas.js +169 -0
  37. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.d.ts +32 -0
  38. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr-schemas.js +206 -0
  39. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.d.ts +170 -0
  40. package/lib/azure-virtualnetworkmanager/lib/ipam-pool-static-cidr.js +214 -0
  41. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.d.ts +175 -0
  42. package/lib/azure-virtualnetworkmanager/lib/ipam-pool.js +206 -0
  43. package/lib/azure-virtualnetworkmanager/lib/network-group-static-member.js +1 -1
  44. package/lib/azure-virtualnetworkmanager/lib/network-group.js +1 -1
  45. package/lib/azure-virtualnetworkmanager/lib/security-admin-configuration.js +1 -1
  46. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule-collection.js +1 -1
  47. package/lib/azure-virtualnetworkmanager/lib/security-admin-rule.js +1 -1
  48. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.d.ts +225 -0
  49. package/lib/azure-virtualnetworkmanager/lib/utils/cidr-validator.js +389 -0
  50. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.d.ts +56 -0
  51. package/lib/azure-virtualnetworkmanager/lib/virtual-network-manager.js +29 -2
  52. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.d.ts +6 -0
  53. package/lib/azure-virtualnetworkmanager/test/cidr-validator.spec.js +292 -0
  54. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.d.ts +6 -0
  55. package/lib/azure-virtualnetworkmanager/test/ipam-pool-static-cidr.spec.js +430 -0
  56. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.d.ts +6 -0
  57. package/lib/azure-virtualnetworkmanager/test/ipam-pool.spec.js +372 -0
  58. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.d.ts +2 -1
  59. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.integ.js +30 -3
  60. package/lib/azure-virtualnetworkmanager/test/virtual-network-manager.spec.js +105 -1
  61. package/lib/azure-vmss/lib/virtual-machine-scale-set.js +1 -1
  62. package/lib/core-azure/lib/azapi/azapi-resource.d.ts +28 -0
  63. package/lib/core-azure/lib/azapi/azapi-resource.js +60 -10
  64. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-client-config/index.js +2 -2
  65. package/lib/core-azure/lib/azapi/providers-azapi/data-azapi-resource/index.js +5 -5
  66. package/lib/core-azure/lib/azapi/providers-azapi/provider/index.js +1 -1
  67. package/lib/core-azure/lib/azapi/providers-azapi/resource/index.js +5 -5
  68. package/lib/core-azure/lib/azapi/providers-azapi/resource-action/index.js +3 -3
  69. package/lib/core-azure/lib/azapi/providers-azapi/update-resource/index.js +3 -3
  70. package/lib/core-azure/lib/azapi/schema-mapper/schema-mapper.js +1 -1
  71. package/lib/core-azure/lib/version-manager/api-version-manager.js +1 -1
  72. package/lib/core-azure/lib/version-manager/interfaces/version-interfaces.js +7 -7
  73. package/lib/testing/index.js +2 -2
  74. package/lib/testing/lib/cleanup.js +1 -1
  75. package/lib/testing/lib/metadata.js +1 -1
  76. package/package.json +1 -1
@@ -469,7 +469,7 @@ class VirtualMachineScaleSet extends azapi_resource_1.AzapiResource {
469
469
  }
470
470
  exports.VirtualMachineScaleSet = VirtualMachineScaleSet;
471
471
  _a = JSII_RTTI_SYMBOL_1;
472
- VirtualMachineScaleSet[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualMachineScaleSet", version: "1.3.0" };
472
+ VirtualMachineScaleSet[_a] = { fqn: "@microsoft/terraform-cdk-constructs.VirtualMachineScaleSet", version: "1.4.0" };
473
473
  (() => {
474
474
  // Register Network Interface schemas first (dependency)
475
475
  azapi_resource_1.AzapiResource.registerSchemas(network_interface_schemas_1.NETWORK_INTERFACE_TYPE, network_interface_schemas_1.ALL_NETWORK_INTERFACE_VERSIONS);
@@ -410,6 +410,12 @@ export declare abstract class AzapiResource extends Construct {
410
410
  * @returns Parent resource or undefined
411
411
  */
412
412
  protected parentResourceForLocation(): AzapiResource | undefined;
413
+ /**
414
+ * Override in child classes to indicate if the resource type supports tags
415
+ * Some Azure resources (e.g., Policy Definitions, Policy Assignments) do not support tags
416
+ * @returns true if the resource supports tags (default), false otherwise
417
+ */
418
+ protected supportsTags(): boolean;
413
419
  /**
414
420
  * Resolves location using template method pattern
415
421
  * Priority: props.location > parent location > default location > validation
@@ -530,6 +536,27 @@ export declare abstract class AzapiResource extends Construct {
530
536
  * @param config - The monitoring configuration from props
531
537
  */
532
538
  protected createMonitoringResources(config: MonitoringConfig): Promise<void>;
539
+ /**
540
+ * Allows child classes to customize the ResourceConfig before resource creation
541
+ *
542
+ * Override this method to add resource-specific configuration like:
543
+ * - schemaValidationEnabled: false (for resources with complex nested structures)
544
+ * - ignoreMissingProperty: true (for resources with dynamic/unknown properties)
545
+ * - ignoreNullProperty: true (for resources that should skip null values)
546
+ *
547
+ * @param config - The base ResourceConfig that will be used to create the resource
548
+ * @returns The potentially modified ResourceConfig
549
+ *
550
+ * @example
551
+ * protected customizeResourceConfig(config: ResourceConfig): ResourceConfig {
552
+ * return {
553
+ * ...config,
554
+ * schemaValidationEnabled: false,
555
+ * ignoreMissingProperty: true,
556
+ * };
557
+ * }
558
+ */
559
+ protected customizeResourceConfig(config: any): any;
533
560
  /**
534
561
  * Creates the underlying AZAPI Terraform resource using the generated provider classes
535
562
  *
@@ -593,6 +620,7 @@ export declare abstract class AzapiResource extends Construct {
593
620
  *
594
621
  * @param key - The tag key
595
622
  * @param value - The tag value
623
+ * @throws Error if the resource type does not support tags
596
624
  */
597
625
  addTag(key: string, value: string): void;
598
626
  /**
@@ -162,9 +162,19 @@ class AzapiResource extends constructs_1.Construct {
162
162
  this._versionManager = new resource_version_manager_1.ResourceVersionManager(this._resourceType, this.defaultVersion());
163
163
  this.resolvedApiVersion = this._versionManager.resolveApiVersion(props.apiVersion);
164
164
  this.apiVersion = this.resolvedApiVersion;
165
- // Step 3.5: Initialize tags from props
165
+ // Step 3.5: Initialize tags from props only if this resource type supports tags
166
166
  // This creates a mutable copy separate from the readonly props
167
- this._tags = { ...(props.tags || {}) };
167
+ // Some resources like Policy Definitions don't support tags
168
+ if (this.supportsTags()) {
169
+ this._tags = { ...(props.tags || {}) };
170
+ }
171
+ else {
172
+ this._tags = {};
173
+ // Warn if user tried to set tags on a resource that doesn't support them
174
+ if (props.tags && Object.keys(props.tags).length > 0) {
175
+ console.warn(`Warning: Tags were specified for ${this.resourceType()} but this resource type does not support tags. Tags will be ignored.`);
176
+ }
177
+ }
168
178
  // Step 4: Load the schema and version configuration using the version manager
169
179
  this.schema = this._versionManager.schemaForVersion(this.resolvedApiVersion);
170
180
  const versionConfig = this._versionManager.versionConfig(this.resolvedApiVersion);
@@ -223,6 +233,14 @@ class AzapiResource extends constructs_1.Construct {
223
233
  parentResourceForLocation() {
224
234
  return undefined;
225
235
  }
236
+ /**
237
+ * Override in child classes to indicate if the resource type supports tags
238
+ * Some Azure resources (e.g., Policy Definitions, Policy Assignments) do not support tags
239
+ * @returns true if the resource supports tags (default), false otherwise
240
+ */
241
+ supportsTags() {
242
+ return true;
243
+ }
226
244
  /**
227
245
  * Resolves location using template method pattern
228
246
  * Priority: props.location > parent location > default location > validation
@@ -554,6 +572,30 @@ class AzapiResource extends constructs_1.Construct {
554
572
  // =============================================================================
555
573
  // RESOURCE MANAGEMENT METHODS (from AzapiResource)
556
574
  // =============================================================================
575
+ /**
576
+ * Allows child classes to customize the ResourceConfig before resource creation
577
+ *
578
+ * Override this method to add resource-specific configuration like:
579
+ * - schemaValidationEnabled: false (for resources with complex nested structures)
580
+ * - ignoreMissingProperty: true (for resources with dynamic/unknown properties)
581
+ * - ignoreNullProperty: true (for resources that should skip null values)
582
+ *
583
+ * @param config - The base ResourceConfig that will be used to create the resource
584
+ * @returns The potentially modified ResourceConfig
585
+ *
586
+ * @example
587
+ * protected customizeResourceConfig(config: ResourceConfig): ResourceConfig {
588
+ * return {
589
+ * ...config,
590
+ * schemaValidationEnabled: false,
591
+ * ignoreMissingProperty: true,
592
+ * };
593
+ * }
594
+ */
595
+ customizeResourceConfig(config) {
596
+ // Default implementation: no customization
597
+ return config;
598
+ }
557
599
  /**
558
600
  * Creates the underlying AZAPI Terraform resource using the generated provider classes
559
601
  *
@@ -594,19 +636,23 @@ class AzapiResource extends constructs_1.Construct {
594
636
  if (parentResource?.terraformResource) {
595
637
  combinedDependsOn.push(parentResource.terraformResource);
596
638
  }
597
- const config = {
639
+ // Build the base configuration
640
+ let config = {
598
641
  type: `${this._resourceType}@${this.apiVersion}`,
599
642
  name: name,
600
643
  parentId: parentId,
601
644
  body: bodyWithoutTags,
602
645
  ...(!isChildResource && location && !properties.location && { location }),
603
- // Add tags at the top level if they exist
604
- // Tags are passed as a separate parameter and added here to ensure they're in the
605
- // initial Terraform configuration, providing proper idempotency
606
- ...(tags && Object.keys(tags).length > 0 && { tags }),
646
+ // Add tags at the top level only if this resource type supports tags
647
+ // Some resources like Policy Definitions don't support tags
648
+ ...(this.supportsTags() &&
649
+ tags &&
650
+ Object.keys(tags).length > 0 && { tags }),
607
651
  // Add depends_on for explicit dependencies and parent resource
608
652
  ...(combinedDependsOn.length > 0 && { dependsOn: combinedDependsOn }),
609
653
  };
654
+ // Allow child classes to customize the configuration
655
+ config = this.customizeResourceConfig(config);
610
656
  // Create the AZAPI resource using the generated provider class
611
657
  return new resource_1.Resource(this, "resource", config);
612
658
  }
@@ -688,8 +734,12 @@ class AzapiResource extends constructs_1.Construct {
688
734
  *
689
735
  * @param key - The tag key
690
736
  * @param value - The tag value
737
+ * @throws Error if the resource type does not support tags
691
738
  */
692
739
  addTag(key, value) {
740
+ if (!this.supportsTags()) {
741
+ throw new Error(`Cannot add tags to ${this.resourceType()}: this resource type does not support tags`);
742
+ }
693
743
  this._tags[key] = value;
694
744
  }
695
745
  /**
@@ -716,7 +766,7 @@ class AzapiResource extends constructs_1.Construct {
716
766
  }
717
767
  exports.AzapiResource = AzapiResource;
718
768
  _a = JSII_RTTI_SYMBOL_1;
719
- AzapiResource[_a] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiResource", version: "1.3.0" };
769
+ AzapiResource[_a] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiResource", version: "1.4.0" };
720
770
  /**
721
771
  * AZAPI-based role assignment construct
722
772
  */
@@ -739,5 +789,5 @@ class AzapiRoleAssignment extends constructs_1.Construct {
739
789
  }
740
790
  exports.AzapiRoleAssignment = AzapiRoleAssignment;
741
791
  _b = JSII_RTTI_SYMBOL_1;
742
- AzapiRoleAssignment[_b] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiRoleAssignment", version: "1.3.0" };
743
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azapi-resource.js","sourceRoot":"","sources":["../../../../src/core-azure/lib/azapi/azapi-resource.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * AzapiResource - A unified framework for version-aware Azure resource management\n *\n * This abstract base class provides a self-contained unified framework approach\n * for Azure resource management with automatic version management, schema-driven\n * property transformation, and migration analysis capabilities.\n *\n * Key Features:\n * - Automatic latest version resolution when no version is specified\n * - Support for explicit version pinning for stability\n * - Schema-driven property transformation between versions\n * - Migration analysis and deprecation warnings\n * - Built-in role assignment and diagnostic settings support\n * - JSII-compliant design for multi-language support\n *\n * This class replaces the previous dual-class approach (AzapiResource + AzapiResource)\n * with a single, self-contained implementation that handles all resource management needs.\n *\n * @packageDocumentation\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { DataAzapiClientConfig } from \"./providers-azapi/data-azapi-client-config\";\nimport { Resource, ResourceConfig } from \"./providers-azapi/resource\";\nimport { ResourceSchemaValidator } from \"./resource-schema-validator\";\nimport { ResourceVersionManager } from \"./resource-version-manager\";\n\n// Type-only imports to avoid circular dependencies\nimport type { ActionGroupProps } from \"../../../azure-actiongroup/lib/action-group\";\nimport type { ActivityLogAlertProps } from \"../../../azure-activitylogalert/lib/activity-log-alert\";\nimport type { DiagnosticSettingsProps } from \"../../../azure-diagnosticsettings/lib/diagnostic-settings\";\nimport type { MetricAlertProps } from \"../../../azure-metricalert/lib/metric-alert\";\nimport { ApiVersionManager } from \"../version-manager/api-version-manager\";\nimport {\n  ApiSchema,\n  VersionConfig,\n  ValidationResult,\n  MigrationAnalysis,\n} from \"../version-manager/interfaces/version-interfaces\";\n\n/**\n * Retention policy configuration\n */\nexport interface RetentionPolicyConfig {\n  readonly enabled: boolean;\n  readonly days: number;\n}\n\n/**\n * Log configuration for diagnostic settings\n */\nexport interface DiagnosticLogConfig {\n  readonly category?: string;\n  readonly categoryGroup?: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Metric configuration for diagnostic settings\n */\nexport interface DiagnosticMetricConfig {\n  /** Metric category name (used in newer API versions) */\n  readonly category?: string;\n  /** Time grain for metrics in ISO 8601 duration format (used in API version 2016-09-01, e.g., \"PT1M\") */\n  readonly timeGrain?: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Monitoring configuration for Azure resources\n *\n * Provides integrated monitoring capabilities including diagnostic settings,\n * metric alerts, and activity log alerts. All monitoring is optional and\n * disabled by default.\n */\nexport interface MonitoringConfig {\n  /**\n   * Whether monitoring is enabled\n   * @defaultValue true\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * Diagnostic settings configuration\n   * Uses the full DiagnosticSettings construct for consistency\n   */\n  readonly diagnosticSettings?: DiagnosticSettingsProps;\n\n  /**\n   * Action groups to create for this resource\n   * Creates new ActionGroup instances as child constructs\n   */\n  readonly actionGroups?: ActionGroupProps[];\n\n  /**\n   * Metric alerts configuration\n   * Creates MetricAlert instances scoped to this resource\n   */\n  readonly metricAlerts?: MetricAlertProps[];\n\n  /**\n   * Activity log alerts configuration\n   * Creates ActivityLogAlert instances for this resource's operations\n   */\n  readonly activityLogAlerts?: ActivityLogAlertProps[];\n}\n\n/**\n * Properties for versioned Azure resources\n *\n * Combines base resource properties with version management capabilities\n * and advanced configuration options for the unified framework.\n */\nexport interface AzapiResourceProps extends cdktf.TerraformMetaArguments {\n  /**\n   * The name of the resource\n   */\n  readonly name?: string;\n\n  /**\n   * The location where the resource should be created\n   *\n   * @remarks\n   * Location handling varies by resource type:\n   * - **Top-level resources**: Most require an explicit location (e.g., \"eastus\", \"westus\")\n   * - **Global resources**: Some use \"global\" as location (e.g., Private DNS Zones)\n   * - **Child resources**: Inherit location from parent and should NOT set this property\n   *\n   * Each resource type may provide its own default through the `resolveLocation()` method.\n   * If no location is specified and no default exists, resource creation may fail.\n   *\n   * @example\n   * // Explicit location for most resources\n   * location: \"eastus\"\n   *\n   * @example\n   * // Global resource (Private DNS Zone)\n   * location: \"global\"\n   *\n   * @example\n   * // Child resource (Subnet) - do not set location\n   * // location: undefined (inherited from parent Virtual Network)\n   *\n   * @defaultValue Varies by resource type - see specific resource documentation\n   */\n  readonly location?: string;\n\n  /**\n   * Tags to apply to the resource\n   */\n  readonly tags?: Record<string, string>;\n  /**\n   * Explicit API version to use for this resource\n   *\n   * If not specified, the latest active version will be automatically resolved.\n   * Use this for version pinning when stability is required over latest features.\n   *\n   * @example \"2024-11-01\"\n   * @defaultValue Latest active version from ApiVersionManager\n   */\n  readonly apiVersion?: string;\n\n  /**\n   * Whether to enable migration analysis warnings\n   *\n   * When true, the framework will analyze the current version for deprecation\n   * status and provide migration recommendations in the deployment output.\n   *\n   * @defaultValue true\n   */\n  readonly enableMigrationAnalysis?: boolean;\n\n  /**\n   * Whether to validate properties against the schema\n   *\n   * When true, all properties will be validated against the API schema before\n   * resource creation. Validation errors will cause deployment failures.\n   *\n   * @defaultValue true\n   */\n  readonly enableValidation?: boolean;\n\n  /**\n   * Whether to apply property transformations automatically\n   *\n   * When true, properties will be automatically transformed according to the\n   * target schema's transformation rules. This enables backward compatibility.\n   *\n   * @defaultValue true\n   */\n  readonly enableTransformation?: boolean;\n\n  /**\n   * Monitoring configuration for this resource\n   *\n   * Enables integrated monitoring with diagnostic settings, metric alerts,\n   * and activity log alerts. All monitoring is optional and disabled by default.\n   *\n   * @example\n   * monitoring: {\n   *   enabled: true,\n   *   diagnosticSettings: {\n   *     workspaceId: logAnalytics.id,\n   *     metrics: ['AllMetrics'],\n   *     logs: ['AuditLogs']\n   *   },\n   *   metricAlerts: [{\n   *     name: 'high-cpu-alert',\n   *     severity: 2,\n   *     scopes: [], // Automatically set to this resource\n   *     criteria: { ... },\n   *     actions: [{ actionGroupId: actionGroup.id }]\n   *   }]\n   * }\n   */\n  readonly monitoring?: MonitoringConfig;\n}\n\n/**\n * Abstract base class for version-aware Azure resource management\n *\n * AzapiResource provides a unified framework for creating Azure resources\n * with automatic version management, schema validation, property transformation,\n * and migration analysis. It extends the existing AzapiResource class while\n * maintaining full backward compatibility.\n *\n * This class implements the core framework that enables:\n * - Automatic resolution of the latest API version when none is specified\n * - Explicit version pinning for environments requiring stability\n * - Schema-driven property validation and transformation\n * - Migration analysis with breaking change detection\n * - Deprecation warnings and upgrade recommendations\n *\n * Subclasses must implement the abstract methods to provide resource-specific\n * configuration while the framework handles all version management complexity.\n *\n * @example Basic usage with automatic version resolution:\n * class MyResource extends AzapiResource {\n *   protected getDefaultVersion(): string {\n *     return \"2024-11-01\"; // fallback if no versions registered\n *   }\n *\n *   protected getResourceType(): string {\n *     return \"Microsoft.Resources/resourceGroups\";\n *   }\n *\n *   protected getApiSchema(): ApiSchema {\n *     return this.resolveSchema();\n *   }\n *\n *   protected createResourceBody(props: any): any {\n *     return { location: props.location, tags: props.tags || {} };\n *   }\n * }\n *\n * @example Usage with explicit version pinning:\n * new MyResource(this, \"resource\", {\n *   name: \"my-resource\",\n *   location: \"eastus\",\n *   apiVersion: \"2024-01-01\" // Pin to specific version\n * });\n *\n * @stability stable\n */\nexport abstract class AzapiResource extends Construct {\n  /**\n   * Static helper for child classes to register their schemas in static initializers\n   *\n   * This method should be called in a static initializer block of each child class\n   * to register all supported API versions and their schemas with the ApiVersionManager.\n   * The static block runs once when the class is first loaded, ensuring schemas are\n   * registered before any instances are created.\n   *\n   * @param resourceType - The Azure resource type (e.g., \"Microsoft.Network/virtualNetworks\")\n   * @param versions - Array of version configurations containing schemas\n   *\n   * @example\n   * static {\n   *   AzapiResource.registerSchemas(\n   *     \"Microsoft.Network/virtualNetworks\",\n   *     ALL_VIRTUAL_NETWORK_VERSIONS\n   *   );\n   * }\n   */\n  protected static registerSchemas(\n    resourceType: string,\n    versions: VersionConfig[],\n  ): void {\n    ApiVersionManager.instance().registerResourceType(resourceType, versions);\n  }\n\n  /**\n   * The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   * @internal\n   */\n  protected _resourceType!: string;\n\n  /**\n   * The API version to use for this resource\n   */\n  protected apiVersion: string;\n\n  /**\n   * The underlying AZAPI Terraform resource\n   */\n  protected terraformResource!: cdktf.TerraformResource;\n\n  /**\n   * The name of the resource\n   */\n  public readonly name: string;\n\n  /**\n   * The location of the resource (optional - not all resources have a location)\n   * Child resources typically inherit location from their parent\n   */\n  public readonly location?: string;\n\n  /**\n   * The Azure resource ID\n   *\n   * This property is automatically derived from the underlying Terraform resource.\n   * Child classes no longer need to implement this property.\n   */\n  public get id(): string {\n    return `\\${${this.terraformResource.fqn}.id}`;\n  }\n\n  /**\n   * The resolved API version being used for this resource instance\n   *\n   * This is the actual version that will be used for the Azure API call,\n   * either explicitly specified in props or automatically resolved to\n   * the latest active version.\n   */\n  public resolvedApiVersion: string;\n\n  /**\n   * The API schema for the resolved version\n   *\n   * Contains the complete schema definition including properties, validation\n   * rules, and transformation mappings for the resolved API version.\n   */\n  public schema!: ApiSchema;\n\n  /**\n   * The version configuration for the resolved version\n   *\n   * Contains lifecycle information, breaking changes, and migration metadata\n   * for the resolved API version.\n   */\n  public versionConfig!: VersionConfig;\n\n  /**\n   * Validation results for the resource properties\n   *\n   * Available after construction if validation is enabled. Contains detailed\n   * information about any validation errors or warnings.\n   */\n  public validationResult?: ValidationResult;\n\n  /**\n   * Migration analysis results\n   *\n   * Available after construction if migration analysis is enabled and a\n   * previous version can be determined for comparison.\n   */\n  public migrationAnalysis?: MigrationAnalysis;\n\n  // Framework components\n  private readonly _apiVersionManager: ApiVersionManager;\n  private _versionManager!: ResourceVersionManager;\n  private _schemaValidator!: ResourceSchemaValidator;\n\n  /**\n   * Internal mutable tags storage separate from input props\n   * Combines props.tags with dynamically added tags via addTag()\n   */\n  private _tags: { [key: string]: string };\n\n  // Monitoring resources (protected for subclass access)\n  protected readonly monitoringActionGroups: Construct[] = [];\n  protected readonly monitoringMetricAlerts: Construct[] = [];\n  protected readonly monitoringActivityLogAlerts: Construct[] = [];\n\n  /**\n   * Creates a new AzapiResource instance\n   *\n   * The constructor handles all framework initialization including version resolution,\n   * schema loading, property validation, transformation, and migration analysis.\n   * It maintains full backward compatibility with the AzapiResource constructor.\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 resource\n   */\n  constructor(scope: Construct, id: string, props: AzapiResourceProps = {}) {\n    // Initialize the base Construct\n    super(scope, id);\n\n    // Initialize basic properties that don't require abstract methods\n    // Use props.name if provided, otherwise fall back to construct ID\n    // This supports both explicit naming and automatic ID-based naming\n    this.name = this.resolveName(props);\n    this.location = this.resolveLocation(props);\n\n    // Initialize the API version manager\n    this._apiVersionManager = ApiVersionManager.instance();\n\n    // Initialize tags storage with empty object (will be populated in initialize())\n    this._tags = {};\n\n    // Note: We cannot initialize version manager here because it requires\n    // calling abstract methods (resourceType() and defaultVersion())\n    // which are not yet available in the base constructor.\n    // Version resolution is deferred to initialize() method.\n\n    // Step 1: Resolve the API version to use (doesn't call abstract methods yet)\n    // This is a placeholder that will be properly set in initialize()\n    this.resolvedApiVersion = props.apiVersion || \"\";\n    this.apiVersion = this.resolvedApiVersion;\n\n    // Step 2: Call initialize() to complete initialization after child class is ready\n    this.initialize(props);\n  }\n\n  /**\n   * Protected initialization method called after the constructor completes\n   *\n   * This method is called at the end of the constructor to perform initialization\n   * that requires calling abstract methods. Child classes can override this method\n   * if they need to extend initialization logic, but they MUST call super.initialize(props).\n   *\n   * @param props - Configuration properties for the resource\n   */\n  protected initialize(props: AzapiResourceProps): void {\n    // Step 2: Set required abstract properties (now safe to call abstract methods)\n    this._resourceType = this.resourceType();\n\n    // Step 3: Initialize the version manager and resolve the API version\n    this._versionManager = new ResourceVersionManager(\n      this._resourceType,\n      this.defaultVersion(),\n    );\n    this.resolvedApiVersion = this._versionManager.resolveApiVersion(\n      props.apiVersion,\n    );\n    this.apiVersion = this.resolvedApiVersion;\n\n    // Step 3.5: Initialize tags from props\n    // This creates a mutable copy separate from the readonly props\n    this._tags = { ...(props.tags || {}) };\n\n    // Step 4: Load the schema and version configuration using the version manager\n    this.schema = this._versionManager.schemaForVersion(\n      this.resolvedApiVersion,\n    );\n    const versionConfig = this._versionManager.versionConfig(\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Version configuration not found for ${this.resourceType()}@${this.resolvedApiVersion}. ` +\n          `Please ensure the version is registered with the ApiVersionManager.`,\n      );\n    }\n    this.versionConfig = versionConfig;\n\n    // Step 5: Initialize the schema validator\n    this._schemaValidator = new ResourceSchemaValidator(this.schema);\n\n    // Step 6: Process properties through the framework pipeline\n    const processedProps = this._processProperties(props);\n\n    // Step 7: Perform validation if enabled\n    if (props.enableValidation !== false) {\n      this.validationResult =\n        this._schemaValidator.validateProps(processedProps);\n      if (!this.validationResult.valid) {\n        throw new Error(\n          `Property validation failed for ${this.resourceType()}:\\n` +\n            this._schemaValidator\n              .formatValidationErrors(this.validationResult)\n              .join(\"\\n\"),\n        );\n      }\n    }\n\n    // Step 8: Perform migration analysis if enabled\n    if (props.enableMigrationAnalysis !== false) {\n      this.migrationAnalysis = this._performMigrationAnalysis();\n    }\n\n    // Step 9: Create the Azure resource\n    this._createAzureResource(processedProps);\n\n    // Step 10: Create monitoring resources if configured\n    // Note: Monitoring resources are created lazily to avoid circular dependencies\n    if (props.monitoring) {\n      void this.createMonitoringResources(props.monitoring);\n    }\n\n    // Step 11: Log warnings and migration guidance\n    this._logFrameworkMessages();\n  }\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   *\n   * This method should return a sensible default version that can be used\n   * as a fallback if the ApiVersionManager doesn't have any versions registered\n   * for this resource type.\n   *\n   * @returns The default API version string (e.g., \"2024-11-01\")\n   */\n  protected abstract defaultVersion(): string;\n\n  /**\n   * Gets the Azure resource type for this resource\n   *\n   * This method should return the full Azure resource type identifier that\n   * will be used for API calls and version management.\n   *\n   * @returns The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   */\n  protected abstract resourceType(): string;\n\n  /**\n   * Gets the API schema for the resolved version\n   *\n   * This method should return the complete API schema for the resolved version,\n   * including all property definitions, validation rules, and transformation\n   * mappings. Use the resolveSchema() helper method for standard schema resolution.\n   *\n   * @returns The API schema for the resolved version\n   */\n  protected abstract apiSchema(): ApiSchema;\n\n  /**\n   * Creates the resource body for the Azure API call\n   *\n   * This method should transform the input properties into the JSON body format\n   * expected by the Azure REST API for the resolved version. The framework will\n   * have already applied any necessary property transformations and validation.\n   *\n   * @param props - The processed and validated properties for the resource\n   * @returns The resource body object to send to Azure API\n   */\n  protected abstract createResourceBody(props: any): any;\n\n  /**\n   * Override in child classes to provide default location\n   * @returns Default location or undefined\n   */\n  protected defaultLocation(): string | undefined {\n    return undefined;\n  }\n\n  /**\n   * Override in child classes to indicate if location is required\n   * @returns true if location is mandatory for this resource type\n   */\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  /**\n   * Override in child classes to specify parent resource for location inheritance\n   * @returns Parent resource or undefined\n   */\n  protected parentResourceForLocation(): AzapiResource | undefined {\n    return undefined;\n  }\n\n  /**\n   * Resolves location using template method pattern\n   * Priority: props.location > parent location > default location > validation\n   */\n  protected resolveLocation(props: AzapiResourceProps): string | undefined {\n    // 1. Explicit location in props\n    if (props.location) {\n      return props.location;\n    }\n\n    // 2. Inherit from parent resource\n    const parent = this.parentResourceForLocation();\n    if (parent && parent.location) {\n      return parent.location;\n    }\n\n    // 3. Use child class default\n    const defaultLoc = this.defaultLocation();\n    if (defaultLoc) {\n      return defaultLoc;\n    }\n\n    // 4. Validate if required\n    if (this.requiresLocation()) {\n      throw new Error(\n        `Location is required for ${this.resourceType()} but was not provided ` +\n          `and could not be inherited from parent resource.`,\n      );\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Resolves the name for this resource\n   *\n   * This method centralizes name resolution logic. By default, it uses the\n   * provided name or falls back to the construct ID.\n   *\n   * @param props - The resource properties\n   * @returns The resolved resource name\n   */\n  protected resolveName(props: AzapiResourceProps): string {\n    return props.name || this.node.id;\n  }\n\n  /**\n   * Helper method for standard schema resolution\n   *\n   * Subclasses can use this method to resolve the schema for the current version\n   * from the ApiVersionManager. This provides a standard implementation that\n   * most resources can use without custom logic.\n   *\n   * @returns The API schema for the resolved version\n   * @throws Error if the schema cannot be resolved\n   */\n  protected resolveSchema(): ApiSchema {\n    const versionConfig = this._apiVersionManager.versionConfig(\n      this.resourceType(),\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Cannot resolve schema: version configuration not found for ` +\n          `${this.resourceType()}@${this.resolvedApiVersion}`,\n      );\n    }\n\n    return versionConfig.schema;\n  }\n\n  /**\n   * Gets the latest available version for this resource type\n   *\n   * This method provides access to the latest version resolution logic\n   * for use in subclasses or external tooling.\n   *\n   * @returns The latest available version, or undefined if none found\n   */\n  public latestVersion(): string | undefined {\n    return this._versionManager\n      ? this._versionManager.latestVersion()\n      : this._apiVersionManager.latestVersion(this.resourceType());\n  }\n\n  /**\n   * Gets all supported versions for this resource type\n   *\n   * This method provides access to the version registry for use in\n   * subclasses or external tooling.\n   *\n   * @returns Array of supported version strings, sorted by release date\n   */\n  public supportedVersions(): string[] {\n    return this._versionManager\n      ? this._versionManager.supportedVersions()\n      : this._apiVersionManager.supportedVersions(this.resourceType());\n  }\n\n  /**\n   * Analyzes migration from current version to a target version\n   *\n   * This method enables external tools to analyze migration requirements\n   * between versions for planning and automation purposes.\n   *\n   * @param targetVersion - The target version to analyze migration to\n   * @returns Detailed migration analysis results\n   */\n  public analyzeMigrationTo(targetVersion: string): MigrationAnalysis {\n    return this._apiVersionManager.analyzeMigration(\n      this.resourceType(),\n      this.resolvedApiVersion,\n      targetVersion,\n    );\n  }\n  // =============================================================================\n  // PRIVATE IMPLEMENTATION METHODS\n  // =============================================================================\n\n  /**\n   * Processes properties through the framework pipeline\n   */\n  private _processProperties(props: AzapiResourceProps): any {\n    let processedProps = { ...props };\n\n    // Ensure name is set before processing\n    // This is critical for validation to work correctly\n    if (!processedProps.name) {\n      processedProps.name = this.resolveName(props);\n    }\n\n    // Apply default values from the schema using the validator\n    processedProps = this._schemaValidator.applyDefaults(processedProps);\n\n    // Apply property transformations if enabled\n    if (props.enableTransformation !== false) {\n      // For transformation, we would need a source schema, but since we're not\n      // migrating from a different version in this context, we'll skip transformation\n      // This would be used when upgrading from one version to another\n    }\n\n    return processedProps;\n  }\n\n  /**\n   * Performs migration analysis for the current version\n   */\n  private _performMigrationAnalysis(): MigrationAnalysis | undefined {\n    // Check if the current version is deprecated using the version manager\n    if (this._versionManager.isDeprecated(this.resolvedApiVersion)) {\n      const latestVersion = this._versionManager.latestVersion();\n      if (latestVersion && latestVersion !== this.resolvedApiVersion) {\n        return this._apiVersionManager.analyzeMigration(\n          this.resourceType(),\n          this.resolvedApiVersion,\n          latestVersion,\n        );\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Creates the underlying Azure resource\n   */\n  private _createAzureResource(props: any): void {\n    // Ensure name is set in props for validation\n    const propsWithName = {\n      ...props,\n      name: props.name || this.resolveName(props),\n    };\n\n    // Create the resource body using the subclass implementation\n    const resourceBody = this.createResourceBody(propsWithName);\n\n    // Determine the parent ID using the overrideable method\n    const parentId = this.resolveParentId(propsWithName);\n\n    // Find parent AzapiResource construct if parent ID references a resource\n    const parentResource = this._findParentAzapiResource(parentId);\n\n    // Create the AZAPI resource using the base class method\n    const resourceName = this.resolveName(props);\n    this.terraformResource = this.createAzapiResource(\n      resourceBody,\n      parentId,\n      resourceName,\n      this.location,\n      parentResource,\n      propsWithName.dependsOn,\n      this._tags, // Pass tags directly instead of extracting from body\n    );\n  }\n\n  /**\n   * Finds the parent AzapiResource construct if the parentId references a resource\n   * Returns undefined if parentId is a static string or parent not found\n   * @private\n   */\n  private _findParentAzapiResource(\n    parentId: string,\n  ): AzapiResource | undefined {\n    // Check if the parent is a string interpolation referencing another resource\n    // Pattern: ${azapi_resource.resource_name_HASH.id} or ${construct.fqn}.id\n    if (!parentId.includes(\"${\")) {\n      return undefined; // Parent is a static string ID, not a resource reference\n    }\n\n    // Try to find the parent AzapiResource in the construct tree\n    // We need to search the entire tree to find the matching parent\n    const root = this._findRoot();\n    return this._findParentResource(root, parentId);\n  }\n\n  /**\n   * Finds the root of the construct tree\n   * @private\n   */\n  private _findRoot(): Construct {\n    let current: Construct = this;\n    while (current.node.scope) {\n      current = current.node.scope;\n    }\n    return current;\n  }\n\n  /**\n   * Recursively searches for a parent resource by matching parentId patterns\n   * Enhanced to better handle Terraform interpolation syntax\n   * @private\n   */\n  private _findParentResource(\n    scope: Construct,\n    parentId: string,\n  ): AzapiResource | undefined {\n    // Check all children of this scope\n    for (const child of scope.node.children) {\n      if (\n        child instanceof AzapiResource &&\n        child !== this &&\n        child.terraformResource\n      ) {\n        const childFqn = child.terraformResource.fqn;\n\n        // Match if the child's FQN appears anywhere in the parentId string\n        // This handles cases like: ${azapi_resource.dns-resolver_resource_F1517BE4.id}\n        // where childFqn would be: azapi_resource.dns-resolver_resource_F1517BE4\n        if (parentId.includes(childFqn)) {\n          return child;\n        }\n      }\n\n      // Recursively search in child's subtree\n      const found = this._findParentResource(child, parentId);\n      if (found) {\n        return found;\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Resolves the parent resource ID for this resource.\n   *\n   * Override this method in child resource classes (like Subnet) that need\n   * custom parent ID resolution logic. By default, this delegates to the\n   * private _determineParentId method which handles standard resource types.\n   *\n   * @param props - The resource properties\n   * @returns The parent resource ID\n   */\n  protected resolveParentId(props: any): string {\n    return this._determineParentId(props);\n  }\n\n  /**\n   * Determines the parent ID for the resource (internal implementation)\n   *\n   * This method provides the default parent ID resolution logic.\n   * Resource-specific logic should be implemented in the overrideable resolveParentId() method.\n   *\n   * Default behavior:\n   * - If resourceGroupId is provided in props, use it\n   * - Otherwise, default to subscription scope\n   */\n  private _determineParentId(props: any): string {\n    // If resource group ID is provided, use it as parent\n    if (props.resourceGroupId) {\n      return props.resourceGroupId;\n    }\n\n    // Default to subscription scope for resources without explicit parent\n    const clientConfig = new DataAzapiClientConfig(\n      this,\n      \"client_config_default\",\n      {},\n    );\n    return `/subscriptions/\\${${clientConfig.fqn}.subscription_id}`;\n  }\n\n  /**\n   * Logs framework messages including warnings and migration guidance\n   */\n  private _logFrameworkMessages(): void {\n    // ANSI color codes for terminal output\n    const RED = \"\\x1b[31m\";\n    const YELLOW = \"\\x1b[33m\";\n    const RESET = \"\\x1b[0m\";\n    const BOLD = \"\\x1b[1m\";\n\n    // Log deprecation warnings using the version manager\n    if (\n      this._versionManager.isDeprecated(this.resolvedApiVersion) &&\n      !this._versionManager.isSunset(this.resolvedApiVersion)\n    ) {\n      console.warn(\n        `${YELLOW}⚠️  API version ${this.resolvedApiVersion} for ${this.resourceType()} is deprecated. ` +\n          `Consider upgrading to the latest version: ${this.latestVersion()}${RESET}`,\n      );\n    }\n\n    if (this._versionManager.isSunset(this.resolvedApiVersion)) {\n      console.error(\n        `${RED}${BOLD}🚨 API version ${this.resolvedApiVersion} for ${this.resourceType()} has reached sunset. ` +\n          `Immediate migration to ${this.latestVersion()} is required.${RESET}`,\n      );\n    }\n\n    // Log migration analysis results\n    if (this.migrationAnalysis && !this.migrationAnalysis.compatible) {\n      console.warn(\n        `${YELLOW}Migration from ${this.migrationAnalysis.fromVersion} to ${this.migrationAnalysis.toVersion} ` +\n          `has ${this.migrationAnalysis.breakingChanges.length} breaking changes. ` +\n          `Estimated effort: ${this.migrationAnalysis.estimatedEffort}${RESET}`,\n      );\n    }\n\n    // Log validation warnings\n    if (this.validationResult?.warnings.length) {\n      this.validationResult.warnings.forEach((warning) => {\n        console.warn(\n          `${YELLOW}Property validation warning: ${warning}${RESET}`,\n        );\n      });\n    }\n  }\n\n  // =============================================================================\n  // MONITORING INTEGRATION METHODS\n  // =============================================================================\n\n  /**\n   * Creates monitoring resources based on the monitoring configuration\n   *\n   * This method is called automatically during construction if monitoring is configured.\n   * It creates action groups, metric alerts, and activity log alerts as child constructs.\n   *\n   * Protected to allow subclasses to override or extend monitoring behavior.\n   *\n   * @param config - The monitoring configuration from props\n   */\n  protected async createMonitoringResources(\n    config: MonitoringConfig,\n  ): Promise<void> {\n    // Skip if monitoring is explicitly disabled\n    if (config.enabled === false) {\n      return;\n    }\n\n    // Create diagnostic settings using dynamic import to avoid circular dependency\n    if (config.diagnosticSettings) {\n      const { DiagnosticSettings } = await import(\n        \"../../../azure-diagnosticsettings/lib/diagnostic-settings\"\n      );\n      new DiagnosticSettings(this, \"monitoring-diagnostic-settings\", {\n        ...config.diagnosticSettings,\n        targetResourceId: this.resourceId,\n      });\n    }\n\n    // Create action groups using dynamic import\n    if (config.actionGroups && config.actionGroups.length > 0) {\n      const { ActionGroup } = await import(\n        \"../../../azure-actiongroup/lib/action-group\"\n      );\n      config.actionGroups.forEach((actionGroupProps, index) => {\n        const actionGroup = new ActionGroup(\n          this,\n          `monitoring-action-group-${index}`,\n          actionGroupProps,\n        );\n        this.monitoringActionGroups.push(actionGroup);\n      });\n    }\n\n    // Create metric alerts using dynamic import\n    if (config.metricAlerts && config.metricAlerts.length > 0) {\n      const { MetricAlert } = await import(\n        \"../../../azure-metricalert/lib/metric-alert\"\n      );\n      config.metricAlerts.forEach((metricAlertProps, index) => {\n        // If scopes not provided, default to this resource\n        const propsWithScope: MetricAlertProps = {\n          ...metricAlertProps,\n          scopes: metricAlertProps.scopes || [this.resourceId],\n        };\n\n        const metricAlert = new MetricAlert(\n          this,\n          `monitoring-metric-alert-${index}`,\n          propsWithScope,\n        );\n        this.monitoringMetricAlerts.push(metricAlert);\n      });\n    }\n\n    // Create activity log alerts using dynamic import\n    if (config.activityLogAlerts && config.activityLogAlerts.length > 0) {\n      const { ActivityLogAlert } = await import(\n        \"../../../azure-activitylogalert/lib/activity-log-alert\"\n      );\n      config.activityLogAlerts.forEach((activityLogAlertProps, index) => {\n        // If scopes not provided, default to this resource\n        const propsWithScope: ActivityLogAlertProps = {\n          ...activityLogAlertProps,\n          scopes: activityLogAlertProps.scopes || [this.resourceId],\n        };\n\n        const activityLogAlert = new ActivityLogAlert(\n          this,\n          `monitoring-activity-log-alert-${index}`,\n          propsWithScope,\n        );\n        this.monitoringActivityLogAlerts.push(activityLogAlert);\n      });\n    }\n  }\n\n  // =============================================================================\n  // RESOURCE MANAGEMENT METHODS (from AzapiResource)\n  // =============================================================================\n\n  /**\n   * Creates the underlying AZAPI Terraform resource using the generated provider classes\n   *\n   * @param properties - The properties object to send to the Azure API (should include location if needed)\n   * @param parentId - The parent resource ID (e.g., subscription or resource group)\n   * @param name - The name of the resource\n   * @param location - The location of the resource (optional, only for top-level resources without location in body)\n   * @param parentResource - The parent resource for dependency tracking\n   * @param dependsOn - Explicit dependencies for this resource\n   * @param tags - Tags to apply to the resource (passed separately from body for proper idempotency)\n   * @returns The created AZAPI resource\n   */\n  protected createAzapiResource(\n    properties: Record<string, any>,\n    parentId: string,\n    name: string,\n    location?: string,\n    parentResource?: AzapiResource,\n    dependsOn?: cdktf.ITerraformDependable[],\n    tags?: Record<string, string>,\n  ): cdktf.TerraformResource {\n    // Determine if this is a child resource by counting path segments\n    // Child resources have multiple segments (e.g., \"Microsoft.Network/virtualNetworks/subnets\")\n    // Top-level resources have one segment (e.g., \"Microsoft.Network/virtualNetworks\")\n    const resourceTypeParts = this._resourceType.split(\"/\");\n    const isChildResource = resourceTypeParts.length > 2;\n\n    // Remove tags from properties to avoid duplicate specification error\n    // The AZAPI provider requires tags at the top level only, not in the body\n    // This prevents: \"can't specify both the argument 'tags' and 'tags' in the argument 'body'\"\n    // Tags are now passed as a separate parameter for better clarity and idempotency\n    const bodyWithoutTags = { ...properties };\n    delete bodyWithoutTags.tags;\n\n    // Build the configuration object for the generated AZAPI Resource class\n    // Add location only if:\n    // 1. This is a top-level resource (not a child resource)\n    // 2. Location is provided as parameter\n    // 3. Location is not already in the body\n    // Child resources inherit location from their parent and should not specify it\n\n    // Combine dependsOn arrays: explicit dependencies + parent resource dependency\n    const combinedDependsOn: cdktf.ITerraformDependable[] = [];\n    if (dependsOn && dependsOn.length > 0) {\n      combinedDependsOn.push(...dependsOn);\n    }\n\n    // CRITICAL: Always add parent dependency when parent_id contains interpolations\n    // This ensures proper destroy-time ordering even if parent detection fails\n    if (parentResource?.terraformResource) {\n      combinedDependsOn.push(parentResource.terraformResource);\n    }\n\n    const config: ResourceConfig = {\n      type: `${this._resourceType}@${this.apiVersion}`,\n      name: name,\n      parentId: parentId,\n      body: bodyWithoutTags,\n      ...(!isChildResource && location && !properties.location && { location }),\n      // Add tags at the top level if they exist\n      // Tags are passed as a separate parameter and added here to ensure they're in the\n      // initial Terraform configuration, providing proper idempotency\n      ...(tags && Object.keys(tags).length > 0 && { tags }),\n      // Add depends_on for explicit dependencies and parent resource\n      ...(combinedDependsOn.length > 0 && { dependsOn: combinedDependsOn }),\n    };\n\n    // Create the AZAPI resource using the generated provider class\n    return new Resource(this, \"resource\", config);\n  }\n\n  /**\n   * Creates an AZAPI data source for reading existing resources\n   *\n   * @param resourceId - The full resource ID\n   * @returns The created Terraform data source\n   */\n  protected createAzapiDataSource(\n    resourceId: string,\n  ): cdktf.TerraformDataSource {\n    const dataSource = new cdktf.TerraformDataSource(this, \"data\", {\n      terraformResourceType: \"azapi_resource\",\n      terraformGeneratorMetadata: {\n        providerName: \"azapi\",\n      },\n    });\n\n    dataSource.addOverride(\"type\", this._resourceType);\n    dataSource.addOverride(\"resource_id\", resourceId);\n\n    return dataSource;\n  }\n\n  /**\n   * Updates the resource with new properties\n   *\n   * @param properties - The new properties to apply\n   */\n  protected updateAzapiResource(properties: Record<string, any>): void {\n    if (this.terraformResource) {\n      this.terraformResource.addOverride(\"body\", properties);\n    }\n  }\n\n  /**\n   * Gets the full resource ID\n   */\n  public get resourceId(): string {\n    return this.terraformResource?.fqn || this.id;\n  }\n\n  /**\n   * Gets the underlying Terraform resource for use in dependency declarations\n   * This allows explicit dependency management between resources\n   */\n  public get resource(): cdktf.TerraformResource {\n    return this.terraformResource;\n  }\n\n  /**\n   * Gets the resource as a Terraform output value\n   */\n  public get output(): cdktf.TerraformOutput {\n    return new cdktf.TerraformOutput(this, \"output\", {\n      value: this.terraformResource?.fqn,\n    });\n  }\n\n  /**\n   * Adds an access role assignment for a specified Azure AD object\n   *\n   * Note: This method creates role assignments using AZAPI instead of AzureRM provider.\n   *\n   * @param objectId - The unique identifier of the Azure AD object\n   * @param roleDefinitionName - The name of the Azure RBAC role to be assigned\n   */\n  public addAccess(objectId: string, roleDefinitionName: string): void {\n    new AzapiRoleAssignment(this, `rbac-${objectId}-${roleDefinitionName}`, {\n      objectId: objectId,\n      roleDefinitionName: roleDefinitionName,\n      scope: this.resourceId,\n    });\n  }\n\n  /**\n   * Adds a tag to this resource. The tag will be included in the Azure resource.\n   *\n   * This method provides proper immutability by storing tags separately from props.\n   * Tags added via this method are combined with tags from props and included in\n   * the deployed Azure resource.\n   *\n   * **Important:** In CDK for Terraform, tags should ideally be set during resource\n   * construction via props. While this method allows adding tags after construction,\n   * those tags are only included if added before the Terraform configuration is\n   * synthesized. For best results, add all tags via props or call addTag() in the\n   * same scope where the resource is created.\n   *\n   * @param key - The tag key\n   * @param value - The tag value\n   */\n  public addTag(key: string, value: string): void {\n    this._tags[key] = value;\n  }\n\n  /**\n   * All tags on this resource (readonly view)\n   *\n   * This getter provides convenient access to all tags including those from props\n   * and those added dynamically via addTag(). Returns a copy to maintain immutability.\n   */\n  public get tags(): { [key: string]: string } {\n    return { ...this._tags };\n  }\n\n  /**\n   * Protected method to retrieve all tags for use in createResourceBody implementations\n   *\n   * Subclasses should use this method when creating resource bodies to ensure\n   * all tags (from props and addTag()) are included in the Azure resource.\n   * Uses a non-getter name to avoid JSII conflicts with the tags property.\n   *\n   * @returns Object containing all tags\n   */\n  protected allTags(): { [key: string]: string } {\n    return { ...this._tags };\n  }\n}\n\n// =============================================================================\n// HELPER CLASSES AND INTERFACES\n// =============================================================================\n\n/**\n * Properties for AZAPI role assignment\n */\nexport interface AzapiRoleAssignmentProps {\n  readonly objectId: string;\n  readonly roleDefinitionName: string;\n  readonly scope: string;\n}\n\n/**\n * AZAPI-based role assignment construct\n */\nexport class AzapiRoleAssignment extends Construct {\n  constructor(scope: Construct, id: string, props: AzapiRoleAssignmentProps) {\n    super(scope, id);\n\n    const properties = {\n      principalId: props.objectId,\n      roleDefinitionId: `[subscriptionResourceId('Microsoft.Authorization/roleDefinitions', roleDefinitionId('${props.roleDefinitionName}'))]`,\n      scope: props.scope,\n    };\n\n    const config: ResourceConfig = {\n      type: \"Microsoft.Authorization/roleAssignments\",\n      name: \"[guid()]\",\n      parentId: props.scope,\n      body: properties,\n    };\n    new Resource(this, \"role-assignment\", config);\n  }\n}\n"]}
792
+ AzapiRoleAssignment[_b] = { fqn: "@microsoft/terraform-cdk-constructs.AzapiRoleAssignment", version: "1.4.0" };
793
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"azapi-resource.js","sourceRoot":"","sources":["../../../../src/core-azure/lib/azapi/azapi-resource.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * AzapiResource - A unified framework for version-aware Azure resource management\n *\n * This abstract base class provides a self-contained unified framework approach\n * for Azure resource management with automatic version management, schema-driven\n * property transformation, and migration analysis capabilities.\n *\n * Key Features:\n * - Automatic latest version resolution when no version is specified\n * - Support for explicit version pinning for stability\n * - Schema-driven property transformation between versions\n * - Migration analysis and deprecation warnings\n * - Built-in role assignment and diagnostic settings support\n * - JSII-compliant design for multi-language support\n *\n * This class replaces the previous dual-class approach (AzapiResource + AzapiResource)\n * with a single, self-contained implementation that handles all resource management needs.\n *\n * @packageDocumentation\n */\n\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { DataAzapiClientConfig } from \"./providers-azapi/data-azapi-client-config\";\nimport { Resource, ResourceConfig } from \"./providers-azapi/resource\";\nimport { ResourceSchemaValidator } from \"./resource-schema-validator\";\nimport { ResourceVersionManager } from \"./resource-version-manager\";\n\n// Type-only imports to avoid circular dependencies\nimport type { ActionGroupProps } from \"../../../azure-actiongroup/lib/action-group\";\nimport type { ActivityLogAlertProps } from \"../../../azure-activitylogalert/lib/activity-log-alert\";\nimport type { DiagnosticSettingsProps } from \"../../../azure-diagnosticsettings/lib/diagnostic-settings\";\nimport type { MetricAlertProps } from \"../../../azure-metricalert/lib/metric-alert\";\nimport { ApiVersionManager } from \"../version-manager/api-version-manager\";\nimport {\n  ApiSchema,\n  VersionConfig,\n  ValidationResult,\n  MigrationAnalysis,\n} from \"../version-manager/interfaces/version-interfaces\";\n\n/**\n * Retention policy configuration\n */\nexport interface RetentionPolicyConfig {\n  readonly enabled: boolean;\n  readonly days: number;\n}\n\n/**\n * Log configuration for diagnostic settings\n */\nexport interface DiagnosticLogConfig {\n  readonly category?: string;\n  readonly categoryGroup?: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Metric configuration for diagnostic settings\n */\nexport interface DiagnosticMetricConfig {\n  /** Metric category name (used in newer API versions) */\n  readonly category?: string;\n  /** Time grain for metrics in ISO 8601 duration format (used in API version 2016-09-01, e.g., \"PT1M\") */\n  readonly timeGrain?: string;\n  readonly enabled: boolean;\n  readonly retentionPolicy?: RetentionPolicyConfig;\n}\n\n/**\n * Monitoring configuration for Azure resources\n *\n * Provides integrated monitoring capabilities including diagnostic settings,\n * metric alerts, and activity log alerts. All monitoring is optional and\n * disabled by default.\n */\nexport interface MonitoringConfig {\n  /**\n   * Whether monitoring is enabled\n   * @defaultValue true\n   */\n  readonly enabled?: boolean;\n\n  /**\n   * Diagnostic settings configuration\n   * Uses the full DiagnosticSettings construct for consistency\n   */\n  readonly diagnosticSettings?: DiagnosticSettingsProps;\n\n  /**\n   * Action groups to create for this resource\n   * Creates new ActionGroup instances as child constructs\n   */\n  readonly actionGroups?: ActionGroupProps[];\n\n  /**\n   * Metric alerts configuration\n   * Creates MetricAlert instances scoped to this resource\n   */\n  readonly metricAlerts?: MetricAlertProps[];\n\n  /**\n   * Activity log alerts configuration\n   * Creates ActivityLogAlert instances for this resource's operations\n   */\n  readonly activityLogAlerts?: ActivityLogAlertProps[];\n}\n\n/**\n * Properties for versioned Azure resources\n *\n * Combines base resource properties with version management capabilities\n * and advanced configuration options for the unified framework.\n */\nexport interface AzapiResourceProps extends cdktf.TerraformMetaArguments {\n  /**\n   * The name of the resource\n   */\n  readonly name?: string;\n\n  /**\n   * The location where the resource should be created\n   *\n   * @remarks\n   * Location handling varies by resource type:\n   * - **Top-level resources**: Most require an explicit location (e.g., \"eastus\", \"westus\")\n   * - **Global resources**: Some use \"global\" as location (e.g., Private DNS Zones)\n   * - **Child resources**: Inherit location from parent and should NOT set this property\n   *\n   * Each resource type may provide its own default through the `resolveLocation()` method.\n   * If no location is specified and no default exists, resource creation may fail.\n   *\n   * @example\n   * // Explicit location for most resources\n   * location: \"eastus\"\n   *\n   * @example\n   * // Global resource (Private DNS Zone)\n   * location: \"global\"\n   *\n   * @example\n   * // Child resource (Subnet) - do not set location\n   * // location: undefined (inherited from parent Virtual Network)\n   *\n   * @defaultValue Varies by resource type - see specific resource documentation\n   */\n  readonly location?: string;\n\n  /**\n   * Tags to apply to the resource\n   */\n  readonly tags?: Record<string, string>;\n  /**\n   * Explicit API version to use for this resource\n   *\n   * If not specified, the latest active version will be automatically resolved.\n   * Use this for version pinning when stability is required over latest features.\n   *\n   * @example \"2024-11-01\"\n   * @defaultValue Latest active version from ApiVersionManager\n   */\n  readonly apiVersion?: string;\n\n  /**\n   * Whether to enable migration analysis warnings\n   *\n   * When true, the framework will analyze the current version for deprecation\n   * status and provide migration recommendations in the deployment output.\n   *\n   * @defaultValue true\n   */\n  readonly enableMigrationAnalysis?: boolean;\n\n  /**\n   * Whether to validate properties against the schema\n   *\n   * When true, all properties will be validated against the API schema before\n   * resource creation. Validation errors will cause deployment failures.\n   *\n   * @defaultValue true\n   */\n  readonly enableValidation?: boolean;\n\n  /**\n   * Whether to apply property transformations automatically\n   *\n   * When true, properties will be automatically transformed according to the\n   * target schema's transformation rules. This enables backward compatibility.\n   *\n   * @defaultValue true\n   */\n  readonly enableTransformation?: boolean;\n\n  /**\n   * Monitoring configuration for this resource\n   *\n   * Enables integrated monitoring with diagnostic settings, metric alerts,\n   * and activity log alerts. All monitoring is optional and disabled by default.\n   *\n   * @example\n   * monitoring: {\n   *   enabled: true,\n   *   diagnosticSettings: {\n   *     workspaceId: logAnalytics.id,\n   *     metrics: ['AllMetrics'],\n   *     logs: ['AuditLogs']\n   *   },\n   *   metricAlerts: [{\n   *     name: 'high-cpu-alert',\n   *     severity: 2,\n   *     scopes: [], // Automatically set to this resource\n   *     criteria: { ... },\n   *     actions: [{ actionGroupId: actionGroup.id }]\n   *   }]\n   * }\n   */\n  readonly monitoring?: MonitoringConfig;\n}\n\n/**\n * Abstract base class for version-aware Azure resource management\n *\n * AzapiResource provides a unified framework for creating Azure resources\n * with automatic version management, schema validation, property transformation,\n * and migration analysis. It extends the existing AzapiResource class while\n * maintaining full backward compatibility.\n *\n * This class implements the core framework that enables:\n * - Automatic resolution of the latest API version when none is specified\n * - Explicit version pinning for environments requiring stability\n * - Schema-driven property validation and transformation\n * - Migration analysis with breaking change detection\n * - Deprecation warnings and upgrade recommendations\n *\n * Subclasses must implement the abstract methods to provide resource-specific\n * configuration while the framework handles all version management complexity.\n *\n * @example Basic usage with automatic version resolution:\n * class MyResource extends AzapiResource {\n *   protected getDefaultVersion(): string {\n *     return \"2024-11-01\"; // fallback if no versions registered\n *   }\n *\n *   protected getResourceType(): string {\n *     return \"Microsoft.Resources/resourceGroups\";\n *   }\n *\n *   protected getApiSchema(): ApiSchema {\n *     return this.resolveSchema();\n *   }\n *\n *   protected createResourceBody(props: any): any {\n *     return { location: props.location, tags: props.tags || {} };\n *   }\n * }\n *\n * @example Usage with explicit version pinning:\n * new MyResource(this, \"resource\", {\n *   name: \"my-resource\",\n *   location: \"eastus\",\n *   apiVersion: \"2024-01-01\" // Pin to specific version\n * });\n *\n * @stability stable\n */\nexport abstract class AzapiResource extends Construct {\n  /**\n   * Static helper for child classes to register their schemas in static initializers\n   *\n   * This method should be called in a static initializer block of each child class\n   * to register all supported API versions and their schemas with the ApiVersionManager.\n   * The static block runs once when the class is first loaded, ensuring schemas are\n   * registered before any instances are created.\n   *\n   * @param resourceType - The Azure resource type (e.g., \"Microsoft.Network/virtualNetworks\")\n   * @param versions - Array of version configurations containing schemas\n   *\n   * @example\n   * static {\n   *   AzapiResource.registerSchemas(\n   *     \"Microsoft.Network/virtualNetworks\",\n   *     ALL_VIRTUAL_NETWORK_VERSIONS\n   *   );\n   * }\n   */\n  protected static registerSchemas(\n    resourceType: string,\n    versions: VersionConfig[],\n  ): void {\n    ApiVersionManager.instance().registerResourceType(resourceType, versions);\n  }\n\n  /**\n   * The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   * @internal\n   */\n  protected _resourceType!: string;\n\n  /**\n   * The API version to use for this resource\n   */\n  protected apiVersion: string;\n\n  /**\n   * The underlying AZAPI Terraform resource\n   */\n  protected terraformResource!: cdktf.TerraformResource;\n\n  /**\n   * The name of the resource\n   */\n  public readonly name: string;\n\n  /**\n   * The location of the resource (optional - not all resources have a location)\n   * Child resources typically inherit location from their parent\n   */\n  public readonly location?: string;\n\n  /**\n   * The Azure resource ID\n   *\n   * This property is automatically derived from the underlying Terraform resource.\n   * Child classes no longer need to implement this property.\n   */\n  public get id(): string {\n    return `\\${${this.terraformResource.fqn}.id}`;\n  }\n\n  /**\n   * The resolved API version being used for this resource instance\n   *\n   * This is the actual version that will be used for the Azure API call,\n   * either explicitly specified in props or automatically resolved to\n   * the latest active version.\n   */\n  public resolvedApiVersion: string;\n\n  /**\n   * The API schema for the resolved version\n   *\n   * Contains the complete schema definition including properties, validation\n   * rules, and transformation mappings for the resolved API version.\n   */\n  public schema!: ApiSchema;\n\n  /**\n   * The version configuration for the resolved version\n   *\n   * Contains lifecycle information, breaking changes, and migration metadata\n   * for the resolved API version.\n   */\n  public versionConfig!: VersionConfig;\n\n  /**\n   * Validation results for the resource properties\n   *\n   * Available after construction if validation is enabled. Contains detailed\n   * information about any validation errors or warnings.\n   */\n  public validationResult?: ValidationResult;\n\n  /**\n   * Migration analysis results\n   *\n   * Available after construction if migration analysis is enabled and a\n   * previous version can be determined for comparison.\n   */\n  public migrationAnalysis?: MigrationAnalysis;\n\n  // Framework components\n  private readonly _apiVersionManager: ApiVersionManager;\n  private _versionManager!: ResourceVersionManager;\n  private _schemaValidator!: ResourceSchemaValidator;\n\n  /**\n   * Internal mutable tags storage separate from input props\n   * Combines props.tags with dynamically added tags via addTag()\n   */\n  private _tags: { [key: string]: string };\n\n  // Monitoring resources (protected for subclass access)\n  protected readonly monitoringActionGroups: Construct[] = [];\n  protected readonly monitoringMetricAlerts: Construct[] = [];\n  protected readonly monitoringActivityLogAlerts: Construct[] = [];\n\n  /**\n   * Creates a new AzapiResource instance\n   *\n   * The constructor handles all framework initialization including version resolution,\n   * schema loading, property validation, transformation, and migration analysis.\n   * It maintains full backward compatibility with the AzapiResource constructor.\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 resource\n   */\n  constructor(scope: Construct, id: string, props: AzapiResourceProps = {}) {\n    // Initialize the base Construct\n    super(scope, id);\n\n    // Initialize basic properties that don't require abstract methods\n    // Use props.name if provided, otherwise fall back to construct ID\n    // This supports both explicit naming and automatic ID-based naming\n    this.name = this.resolveName(props);\n    this.location = this.resolveLocation(props);\n\n    // Initialize the API version manager\n    this._apiVersionManager = ApiVersionManager.instance();\n\n    // Initialize tags storage with empty object (will be populated in initialize())\n    this._tags = {};\n\n    // Note: We cannot initialize version manager here because it requires\n    // calling abstract methods (resourceType() and defaultVersion())\n    // which are not yet available in the base constructor.\n    // Version resolution is deferred to initialize() method.\n\n    // Step 1: Resolve the API version to use (doesn't call abstract methods yet)\n    // This is a placeholder that will be properly set in initialize()\n    this.resolvedApiVersion = props.apiVersion || \"\";\n    this.apiVersion = this.resolvedApiVersion;\n\n    // Step 2: Call initialize() to complete initialization after child class is ready\n    this.initialize(props);\n  }\n\n  /**\n   * Protected initialization method called after the constructor completes\n   *\n   * This method is called at the end of the constructor to perform initialization\n   * that requires calling abstract methods. Child classes can override this method\n   * if they need to extend initialization logic, but they MUST call super.initialize(props).\n   *\n   * @param props - Configuration properties for the resource\n   */\n  protected initialize(props: AzapiResourceProps): void {\n    // Step 2: Set required abstract properties (now safe to call abstract methods)\n    this._resourceType = this.resourceType();\n\n    // Step 3: Initialize the version manager and resolve the API version\n    this._versionManager = new ResourceVersionManager(\n      this._resourceType,\n      this.defaultVersion(),\n    );\n    this.resolvedApiVersion = this._versionManager.resolveApiVersion(\n      props.apiVersion,\n    );\n    this.apiVersion = this.resolvedApiVersion;\n\n    // Step 3.5: Initialize tags from props only if this resource type supports tags\n    // This creates a mutable copy separate from the readonly props\n    // Some resources like Policy Definitions don't support tags\n    if (this.supportsTags()) {\n      this._tags = { ...(props.tags || {}) };\n    } else {\n      this._tags = {};\n      // Warn if user tried to set tags on a resource that doesn't support them\n      if (props.tags && Object.keys(props.tags).length > 0) {\n        console.warn(\n          `Warning: Tags were specified for ${this.resourceType()} but this resource type does not support tags. Tags will be ignored.`,\n        );\n      }\n    }\n\n    // Step 4: Load the schema and version configuration using the version manager\n    this.schema = this._versionManager.schemaForVersion(\n      this.resolvedApiVersion,\n    );\n    const versionConfig = this._versionManager.versionConfig(\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Version configuration not found for ${this.resourceType()}@${this.resolvedApiVersion}. ` +\n          `Please ensure the version is registered with the ApiVersionManager.`,\n      );\n    }\n    this.versionConfig = versionConfig;\n\n    // Step 5: Initialize the schema validator\n    this._schemaValidator = new ResourceSchemaValidator(this.schema);\n\n    // Step 6: Process properties through the framework pipeline\n    const processedProps = this._processProperties(props);\n\n    // Step 7: Perform validation if enabled\n    if (props.enableValidation !== false) {\n      this.validationResult =\n        this._schemaValidator.validateProps(processedProps);\n      if (!this.validationResult.valid) {\n        throw new Error(\n          `Property validation failed for ${this.resourceType()}:\\n` +\n            this._schemaValidator\n              .formatValidationErrors(this.validationResult)\n              .join(\"\\n\"),\n        );\n      }\n    }\n\n    // Step 8: Perform migration analysis if enabled\n    if (props.enableMigrationAnalysis !== false) {\n      this.migrationAnalysis = this._performMigrationAnalysis();\n    }\n\n    // Step 9: Create the Azure resource\n    this._createAzureResource(processedProps);\n\n    // Step 10: Create monitoring resources if configured\n    // Note: Monitoring resources are created lazily to avoid circular dependencies\n    if (props.monitoring) {\n      void this.createMonitoringResources(props.monitoring);\n    }\n\n    // Step 11: Log warnings and migration guidance\n    this._logFrameworkMessages();\n  }\n\n  /**\n   * Gets the default API version to use when no explicit version is specified\n   *\n   * This method should return a sensible default version that can be used\n   * as a fallback if the ApiVersionManager doesn't have any versions registered\n   * for this resource type.\n   *\n   * @returns The default API version string (e.g., \"2024-11-01\")\n   */\n  protected abstract defaultVersion(): string;\n\n  /**\n   * Gets the Azure resource type for this resource\n   *\n   * This method should return the full Azure resource type identifier that\n   * will be used for API calls and version management.\n   *\n   * @returns The Azure resource type (e.g., \"Microsoft.Resources/resourceGroups\")\n   */\n  protected abstract resourceType(): string;\n\n  /**\n   * Gets the API schema for the resolved version\n   *\n   * This method should return the complete API schema for the resolved version,\n   * including all property definitions, validation rules, and transformation\n   * mappings. Use the resolveSchema() helper method for standard schema resolution.\n   *\n   * @returns The API schema for the resolved version\n   */\n  protected abstract apiSchema(): ApiSchema;\n\n  /**\n   * Creates the resource body for the Azure API call\n   *\n   * This method should transform the input properties into the JSON body format\n   * expected by the Azure REST API for the resolved version. The framework will\n   * have already applied any necessary property transformations and validation.\n   *\n   * @param props - The processed and validated properties for the resource\n   * @returns The resource body object to send to Azure API\n   */\n  protected abstract createResourceBody(props: any): any;\n\n  /**\n   * Override in child classes to provide default location\n   * @returns Default location or undefined\n   */\n  protected defaultLocation(): string | undefined {\n    return undefined;\n  }\n\n  /**\n   * Override in child classes to indicate if location is required\n   * @returns true if location is mandatory for this resource type\n   */\n  protected requiresLocation(): boolean {\n    return false;\n  }\n\n  /**\n   * Override in child classes to specify parent resource for location inheritance\n   * @returns Parent resource or undefined\n   */\n  protected parentResourceForLocation(): AzapiResource | undefined {\n    return undefined;\n  }\n\n  /**\n   * Override in child classes to indicate if the resource type supports tags\n   * Some Azure resources (e.g., Policy Definitions, Policy Assignments) do not support tags\n   * @returns true if the resource supports tags (default), false otherwise\n   */\n  protected supportsTags(): boolean {\n    return true;\n  }\n\n  /**\n   * Resolves location using template method pattern\n   * Priority: props.location > parent location > default location > validation\n   */\n  protected resolveLocation(props: AzapiResourceProps): string | undefined {\n    // 1. Explicit location in props\n    if (props.location) {\n      return props.location;\n    }\n\n    // 2. Inherit from parent resource\n    const parent = this.parentResourceForLocation();\n    if (parent && parent.location) {\n      return parent.location;\n    }\n\n    // 3. Use child class default\n    const defaultLoc = this.defaultLocation();\n    if (defaultLoc) {\n      return defaultLoc;\n    }\n\n    // 4. Validate if required\n    if (this.requiresLocation()) {\n      throw new Error(\n        `Location is required for ${this.resourceType()} but was not provided ` +\n          `and could not be inherited from parent resource.`,\n      );\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Resolves the name for this resource\n   *\n   * This method centralizes name resolution logic. By default, it uses the\n   * provided name or falls back to the construct ID.\n   *\n   * @param props - The resource properties\n   * @returns The resolved resource name\n   */\n  protected resolveName(props: AzapiResourceProps): string {\n    return props.name || this.node.id;\n  }\n\n  /**\n   * Helper method for standard schema resolution\n   *\n   * Subclasses can use this method to resolve the schema for the current version\n   * from the ApiVersionManager. This provides a standard implementation that\n   * most resources can use without custom logic.\n   *\n   * @returns The API schema for the resolved version\n   * @throws Error if the schema cannot be resolved\n   */\n  protected resolveSchema(): ApiSchema {\n    const versionConfig = this._apiVersionManager.versionConfig(\n      this.resourceType(),\n      this.resolvedApiVersion,\n    );\n\n    if (!versionConfig) {\n      throw new Error(\n        `Cannot resolve schema: version configuration not found for ` +\n          `${this.resourceType()}@${this.resolvedApiVersion}`,\n      );\n    }\n\n    return versionConfig.schema;\n  }\n\n  /**\n   * Gets the latest available version for this resource type\n   *\n   * This method provides access to the latest version resolution logic\n   * for use in subclasses or external tooling.\n   *\n   * @returns The latest available version, or undefined if none found\n   */\n  public latestVersion(): string | undefined {\n    return this._versionManager\n      ? this._versionManager.latestVersion()\n      : this._apiVersionManager.latestVersion(this.resourceType());\n  }\n\n  /**\n   * Gets all supported versions for this resource type\n   *\n   * This method provides access to the version registry for use in\n   * subclasses or external tooling.\n   *\n   * @returns Array of supported version strings, sorted by release date\n   */\n  public supportedVersions(): string[] {\n    return this._versionManager\n      ? this._versionManager.supportedVersions()\n      : this._apiVersionManager.supportedVersions(this.resourceType());\n  }\n\n  /**\n   * Analyzes migration from current version to a target version\n   *\n   * This method enables external tools to analyze migration requirements\n   * between versions for planning and automation purposes.\n   *\n   * @param targetVersion - The target version to analyze migration to\n   * @returns Detailed migration analysis results\n   */\n  public analyzeMigrationTo(targetVersion: string): MigrationAnalysis {\n    return this._apiVersionManager.analyzeMigration(\n      this.resourceType(),\n      this.resolvedApiVersion,\n      targetVersion,\n    );\n  }\n  // =============================================================================\n  // PRIVATE IMPLEMENTATION METHODS\n  // =============================================================================\n\n  /**\n   * Processes properties through the framework pipeline\n   */\n  private _processProperties(props: AzapiResourceProps): any {\n    let processedProps = { ...props };\n\n    // Ensure name is set before processing\n    // This is critical for validation to work correctly\n    if (!processedProps.name) {\n      processedProps.name = this.resolveName(props);\n    }\n\n    // Apply default values from the schema using the validator\n    processedProps = this._schemaValidator.applyDefaults(processedProps);\n\n    // Apply property transformations if enabled\n    if (props.enableTransformation !== false) {\n      // For transformation, we would need a source schema, but since we're not\n      // migrating from a different version in this context, we'll skip transformation\n      // This would be used when upgrading from one version to another\n    }\n\n    return processedProps;\n  }\n\n  /**\n   * Performs migration analysis for the current version\n   */\n  private _performMigrationAnalysis(): MigrationAnalysis | undefined {\n    // Check if the current version is deprecated using the version manager\n    if (this._versionManager.isDeprecated(this.resolvedApiVersion)) {\n      const latestVersion = this._versionManager.latestVersion();\n      if (latestVersion && latestVersion !== this.resolvedApiVersion) {\n        return this._apiVersionManager.analyzeMigration(\n          this.resourceType(),\n          this.resolvedApiVersion,\n          latestVersion,\n        );\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Creates the underlying Azure resource\n   */\n  private _createAzureResource(props: any): void {\n    // Ensure name is set in props for validation\n    const propsWithName = {\n      ...props,\n      name: props.name || this.resolveName(props),\n    };\n\n    // Create the resource body using the subclass implementation\n    const resourceBody = this.createResourceBody(propsWithName);\n\n    // Determine the parent ID using the overrideable method\n    const parentId = this.resolveParentId(propsWithName);\n\n    // Find parent AzapiResource construct if parent ID references a resource\n    const parentResource = this._findParentAzapiResource(parentId);\n\n    // Create the AZAPI resource using the base class method\n    const resourceName = this.resolveName(props);\n    this.terraformResource = this.createAzapiResource(\n      resourceBody,\n      parentId,\n      resourceName,\n      this.location,\n      parentResource,\n      propsWithName.dependsOn,\n      this._tags, // Pass tags directly instead of extracting from body\n    );\n  }\n\n  /**\n   * Finds the parent AzapiResource construct if the parentId references a resource\n   * Returns undefined if parentId is a static string or parent not found\n   * @private\n   */\n  private _findParentAzapiResource(\n    parentId: string,\n  ): AzapiResource | undefined {\n    // Check if the parent is a string interpolation referencing another resource\n    // Pattern: ${azapi_resource.resource_name_HASH.id} or ${construct.fqn}.id\n    if (!parentId.includes(\"${\")) {\n      return undefined; // Parent is a static string ID, not a resource reference\n    }\n\n    // Try to find the parent AzapiResource in the construct tree\n    // We need to search the entire tree to find the matching parent\n    const root = this._findRoot();\n    return this._findParentResource(root, parentId);\n  }\n\n  /**\n   * Finds the root of the construct tree\n   * @private\n   */\n  private _findRoot(): Construct {\n    let current: Construct = this;\n    while (current.node.scope) {\n      current = current.node.scope;\n    }\n    return current;\n  }\n\n  /**\n   * Recursively searches for a parent resource by matching parentId patterns\n   * Enhanced to better handle Terraform interpolation syntax\n   * @private\n   */\n  private _findParentResource(\n    scope: Construct,\n    parentId: string,\n  ): AzapiResource | undefined {\n    // Check all children of this scope\n    for (const child of scope.node.children) {\n      if (\n        child instanceof AzapiResource &&\n        child !== this &&\n        child.terraformResource\n      ) {\n        const childFqn = child.terraformResource.fqn;\n\n        // Match if the child's FQN appears anywhere in the parentId string\n        // This handles cases like: ${azapi_resource.dns-resolver_resource_F1517BE4.id}\n        // where childFqn would be: azapi_resource.dns-resolver_resource_F1517BE4\n        if (parentId.includes(childFqn)) {\n          return child;\n        }\n      }\n\n      // Recursively search in child's subtree\n      const found = this._findParentResource(child, parentId);\n      if (found) {\n        return found;\n      }\n    }\n\n    return undefined;\n  }\n\n  /**\n   * Resolves the parent resource ID for this resource.\n   *\n   * Override this method in child resource classes (like Subnet) that need\n   * custom parent ID resolution logic. By default, this delegates to the\n   * private _determineParentId method which handles standard resource types.\n   *\n   * @param props - The resource properties\n   * @returns The parent resource ID\n   */\n  protected resolveParentId(props: any): string {\n    return this._determineParentId(props);\n  }\n\n  /**\n   * Determines the parent ID for the resource (internal implementation)\n   *\n   * This method provides the default parent ID resolution logic.\n   * Resource-specific logic should be implemented in the overrideable resolveParentId() method.\n   *\n   * Default behavior:\n   * - If resourceGroupId is provided in props, use it\n   * - Otherwise, default to subscription scope\n   */\n  private _determineParentId(props: any): string {\n    // If resource group ID is provided, use it as parent\n    if (props.resourceGroupId) {\n      return props.resourceGroupId;\n    }\n\n    // Default to subscription scope for resources without explicit parent\n    const clientConfig = new DataAzapiClientConfig(\n      this,\n      \"client_config_default\",\n      {},\n    );\n    return `/subscriptions/\\${${clientConfig.fqn}.subscription_id}`;\n  }\n\n  /**\n   * Logs framework messages including warnings and migration guidance\n   */\n  private _logFrameworkMessages(): void {\n    // ANSI color codes for terminal output\n    const RED = \"\\x1b[31m\";\n    const YELLOW = \"\\x1b[33m\";\n    const RESET = \"\\x1b[0m\";\n    const BOLD = \"\\x1b[1m\";\n\n    // Log deprecation warnings using the version manager\n    if (\n      this._versionManager.isDeprecated(this.resolvedApiVersion) &&\n      !this._versionManager.isSunset(this.resolvedApiVersion)\n    ) {\n      console.warn(\n        `${YELLOW}⚠️  API version ${this.resolvedApiVersion} for ${this.resourceType()} is deprecated. ` +\n          `Consider upgrading to the latest version: ${this.latestVersion()}${RESET}`,\n      );\n    }\n\n    if (this._versionManager.isSunset(this.resolvedApiVersion)) {\n      console.error(\n        `${RED}${BOLD}🚨 API version ${this.resolvedApiVersion} for ${this.resourceType()} has reached sunset. ` +\n          `Immediate migration to ${this.latestVersion()} is required.${RESET}`,\n      );\n    }\n\n    // Log migration analysis results\n    if (this.migrationAnalysis && !this.migrationAnalysis.compatible) {\n      console.warn(\n        `${YELLOW}Migration from ${this.migrationAnalysis.fromVersion} to ${this.migrationAnalysis.toVersion} ` +\n          `has ${this.migrationAnalysis.breakingChanges.length} breaking changes. ` +\n          `Estimated effort: ${this.migrationAnalysis.estimatedEffort}${RESET}`,\n      );\n    }\n\n    // Log validation warnings\n    if (this.validationResult?.warnings.length) {\n      this.validationResult.warnings.forEach((warning) => {\n        console.warn(\n          `${YELLOW}Property validation warning: ${warning}${RESET}`,\n        );\n      });\n    }\n  }\n\n  // =============================================================================\n  // MONITORING INTEGRATION METHODS\n  // =============================================================================\n\n  /**\n   * Creates monitoring resources based on the monitoring configuration\n   *\n   * This method is called automatically during construction if monitoring is configured.\n   * It creates action groups, metric alerts, and activity log alerts as child constructs.\n   *\n   * Protected to allow subclasses to override or extend monitoring behavior.\n   *\n   * @param config - The monitoring configuration from props\n   */\n  protected async createMonitoringResources(\n    config: MonitoringConfig,\n  ): Promise<void> {\n    // Skip if monitoring is explicitly disabled\n    if (config.enabled === false) {\n      return;\n    }\n\n    // Create diagnostic settings using dynamic import to avoid circular dependency\n    if (config.diagnosticSettings) {\n      const { DiagnosticSettings } = await import(\n        \"../../../azure-diagnosticsettings/lib/diagnostic-settings\"\n      );\n      new DiagnosticSettings(this, \"monitoring-diagnostic-settings\", {\n        ...config.diagnosticSettings,\n        targetResourceId: this.resourceId,\n      });\n    }\n\n    // Create action groups using dynamic import\n    if (config.actionGroups && config.actionGroups.length > 0) {\n      const { ActionGroup } = await import(\n        \"../../../azure-actiongroup/lib/action-group\"\n      );\n      config.actionGroups.forEach((actionGroupProps, index) => {\n        const actionGroup = new ActionGroup(\n          this,\n          `monitoring-action-group-${index}`,\n          actionGroupProps,\n        );\n        this.monitoringActionGroups.push(actionGroup);\n      });\n    }\n\n    // Create metric alerts using dynamic import\n    if (config.metricAlerts && config.metricAlerts.length > 0) {\n      const { MetricAlert } = await import(\n        \"../../../azure-metricalert/lib/metric-alert\"\n      );\n      config.metricAlerts.forEach((metricAlertProps, index) => {\n        // If scopes not provided, default to this resource\n        const propsWithScope: MetricAlertProps = {\n          ...metricAlertProps,\n          scopes: metricAlertProps.scopes || [this.resourceId],\n        };\n\n        const metricAlert = new MetricAlert(\n          this,\n          `monitoring-metric-alert-${index}`,\n          propsWithScope,\n        );\n        this.monitoringMetricAlerts.push(metricAlert);\n      });\n    }\n\n    // Create activity log alerts using dynamic import\n    if (config.activityLogAlerts && config.activityLogAlerts.length > 0) {\n      const { ActivityLogAlert } = await import(\n        \"../../../azure-activitylogalert/lib/activity-log-alert\"\n      );\n      config.activityLogAlerts.forEach((activityLogAlertProps, index) => {\n        // If scopes not provided, default to this resource\n        const propsWithScope: ActivityLogAlertProps = {\n          ...activityLogAlertProps,\n          scopes: activityLogAlertProps.scopes || [this.resourceId],\n        };\n\n        const activityLogAlert = new ActivityLogAlert(\n          this,\n          `monitoring-activity-log-alert-${index}`,\n          propsWithScope,\n        );\n        this.monitoringActivityLogAlerts.push(activityLogAlert);\n      });\n    }\n  }\n\n  // =============================================================================\n  // RESOURCE MANAGEMENT METHODS (from AzapiResource)\n  // =============================================================================\n\n  /**\n   * Allows child classes to customize the ResourceConfig before resource creation\n   *\n   * Override this method to add resource-specific configuration like:\n   * - schemaValidationEnabled: false (for resources with complex nested structures)\n   * - ignoreMissingProperty: true (for resources with dynamic/unknown properties)\n   * - ignoreNullProperty: true (for resources that should skip null values)\n   *\n   * @param config - The base ResourceConfig that will be used to create the resource\n   * @returns The potentially modified ResourceConfig\n   *\n   * @example\n   * protected customizeResourceConfig(config: ResourceConfig): ResourceConfig {\n   *   return {\n   *     ...config,\n   *     schemaValidationEnabled: false,\n   *     ignoreMissingProperty: true,\n   *   };\n   * }\n   */\n  protected customizeResourceConfig(config: any): any {\n    // Default implementation: no customization\n    return config;\n  }\n\n  /**\n   * Creates the underlying AZAPI Terraform resource using the generated provider classes\n   *\n   * @param properties - The properties object to send to the Azure API (should include location if needed)\n   * @param parentId - The parent resource ID (e.g., subscription or resource group)\n   * @param name - The name of the resource\n   * @param location - The location of the resource (optional, only for top-level resources without location in body)\n   * @param parentResource - The parent resource for dependency tracking\n   * @param dependsOn - Explicit dependencies for this resource\n   * @param tags - Tags to apply to the resource (passed separately from body for proper idempotency)\n   * @returns The created AZAPI resource\n   */\n  protected createAzapiResource(\n    properties: Record<string, any>,\n    parentId: string,\n    name: string,\n    location?: string,\n    parentResource?: AzapiResource,\n    dependsOn?: cdktf.ITerraformDependable[],\n    tags?: Record<string, string>,\n  ): cdktf.TerraformResource {\n    // Determine if this is a child resource by counting path segments\n    // Child resources have multiple segments (e.g., \"Microsoft.Network/virtualNetworks/subnets\")\n    // Top-level resources have one segment (e.g., \"Microsoft.Network/virtualNetworks\")\n    const resourceTypeParts = this._resourceType.split(\"/\");\n    const isChildResource = resourceTypeParts.length > 2;\n\n    // Remove tags from properties to avoid duplicate specification error\n    // The AZAPI provider requires tags at the top level only, not in the body\n    // This prevents: \"can't specify both the argument 'tags' and 'tags' in the argument 'body'\"\n    // Tags are now passed as a separate parameter for better clarity and idempotency\n    const bodyWithoutTags = { ...properties };\n    delete bodyWithoutTags.tags;\n\n    // Build the configuration object for the generated AZAPI Resource class\n    // Add location only if:\n    // 1. This is a top-level resource (not a child resource)\n    // 2. Location is provided as parameter\n    // 3. Location is not already in the body\n    // Child resources inherit location from their parent and should not specify it\n\n    // Combine dependsOn arrays: explicit dependencies + parent resource dependency\n    const combinedDependsOn: cdktf.ITerraformDependable[] = [];\n    if (dependsOn && dependsOn.length > 0) {\n      combinedDependsOn.push(...dependsOn);\n    }\n\n    // CRITICAL: Always add parent dependency when parent_id contains interpolations\n    // This ensures proper destroy-time ordering even if parent detection fails\n    if (parentResource?.terraformResource) {\n      combinedDependsOn.push(parentResource.terraformResource);\n    }\n\n    // Build the base configuration\n    let config: ResourceConfig = {\n      type: `${this._resourceType}@${this.apiVersion}`,\n      name: name,\n      parentId: parentId,\n      body: bodyWithoutTags,\n      ...(!isChildResource && location && !properties.location && { location }),\n      // Add tags at the top level only if this resource type supports tags\n      // Some resources like Policy Definitions don't support tags\n      ...(this.supportsTags() &&\n        tags &&\n        Object.keys(tags).length > 0 && { tags }),\n      // Add depends_on for explicit dependencies and parent resource\n      ...(combinedDependsOn.length > 0 && { dependsOn: combinedDependsOn }),\n    };\n\n    // Allow child classes to customize the configuration\n    config = this.customizeResourceConfig(config);\n\n    // Create the AZAPI resource using the generated provider class\n    return new Resource(this, \"resource\", config);\n  }\n\n  /**\n   * Creates an AZAPI data source for reading existing resources\n   *\n   * @param resourceId - The full resource ID\n   * @returns The created Terraform data source\n   */\n  protected createAzapiDataSource(\n    resourceId: string,\n  ): cdktf.TerraformDataSource {\n    const dataSource = new cdktf.TerraformDataSource(this, \"data\", {\n      terraformResourceType: \"azapi_resource\",\n      terraformGeneratorMetadata: {\n        providerName: \"azapi\",\n      },\n    });\n\n    dataSource.addOverride(\"type\", this._resourceType);\n    dataSource.addOverride(\"resource_id\", resourceId);\n\n    return dataSource;\n  }\n\n  /**\n   * Updates the resource with new properties\n   *\n   * @param properties - The new properties to apply\n   */\n  protected updateAzapiResource(properties: Record<string, any>): void {\n    if (this.terraformResource) {\n      this.terraformResource.addOverride(\"body\", properties);\n    }\n  }\n\n  /**\n   * Gets the full resource ID\n   */\n  public get resourceId(): string {\n    return this.terraformResource?.fqn || this.id;\n  }\n\n  /**\n   * Gets the underlying Terraform resource for use in dependency declarations\n   * This allows explicit dependency management between resources\n   */\n  public get resource(): cdktf.TerraformResource {\n    return this.terraformResource;\n  }\n\n  /**\n   * Gets the resource as a Terraform output value\n   */\n  public get output(): cdktf.TerraformOutput {\n    return new cdktf.TerraformOutput(this, \"output\", {\n      value: this.terraformResource?.fqn,\n    });\n  }\n\n  /**\n   * Adds an access role assignment for a specified Azure AD object\n   *\n   * Note: This method creates role assignments using AZAPI instead of AzureRM provider.\n   *\n   * @param objectId - The unique identifier of the Azure AD object\n   * @param roleDefinitionName - The name of the Azure RBAC role to be assigned\n   */\n  public addAccess(objectId: string, roleDefinitionName: string): void {\n    new AzapiRoleAssignment(this, `rbac-${objectId}-${roleDefinitionName}`, {\n      objectId: objectId,\n      roleDefinitionName: roleDefinitionName,\n      scope: this.resourceId,\n    });\n  }\n\n  /**\n   * Adds a tag to this resource. The tag will be included in the Azure resource.\n   *\n   * This method provides proper immutability by storing tags separately from props.\n   * Tags added via this method are combined with tags from props and included in\n   * the deployed Azure resource.\n   *\n   * **Important:** In CDK for Terraform, tags should ideally be set during resource\n   * construction via props. While this method allows adding tags after construction,\n   * those tags are only included if added before the Terraform configuration is\n   * synthesized. For best results, add all tags via props or call addTag() in the\n   * same scope where the resource is created.\n   *\n   * @param key - The tag key\n   * @param value - The tag value\n   * @throws Error if the resource type does not support tags\n   */\n  public addTag(key: string, value: string): void {\n    if (!this.supportsTags()) {\n      throw new Error(\n        `Cannot add tags to ${this.resourceType()}: this resource type does not support tags`,\n      );\n    }\n    this._tags[key] = value;\n  }\n\n  /**\n   * All tags on this resource (readonly view)\n   *\n   * This getter provides convenient access to all tags including those from props\n   * and those added dynamically via addTag(). Returns a copy to maintain immutability.\n   */\n  public get tags(): { [key: string]: string } {\n    return { ...this._tags };\n  }\n\n  /**\n   * Protected method to retrieve all tags for use in createResourceBody implementations\n   *\n   * Subclasses should use this method when creating resource bodies to ensure\n   * all tags (from props and addTag()) are included in the Azure resource.\n   * Uses a non-getter name to avoid JSII conflicts with the tags property.\n   *\n   * @returns Object containing all tags\n   */\n  protected allTags(): { [key: string]: string } {\n    return { ...this._tags };\n  }\n}\n\n// =============================================================================\n// HELPER CLASSES AND INTERFACES\n// =============================================================================\n\n/**\n * Properties for AZAPI role assignment\n */\nexport interface AzapiRoleAssignmentProps {\n  readonly objectId: string;\n  readonly roleDefinitionName: string;\n  readonly scope: string;\n}\n\n/**\n * AZAPI-based role assignment construct\n */\nexport class AzapiRoleAssignment extends Construct {\n  constructor(scope: Construct, id: string, props: AzapiRoleAssignmentProps) {\n    super(scope, id);\n\n    const properties = {\n      principalId: props.objectId,\n      roleDefinitionId: `[subscriptionResourceId('Microsoft.Authorization/roleDefinitions', roleDefinitionId('${props.roleDefinitionName}'))]`,\n      scope: props.scope,\n    };\n\n    const config: ResourceConfig = {\n      type: \"Microsoft.Authorization/roleAssignments\",\n      name: \"[guid()]\",\n      parentId: props.scope,\n      body: properties,\n    };\n    new Resource(this, \"role-assignment\", config);\n  }\n}\n"]}
@@ -88,7 +88,7 @@ class DataAzapiClientConfigTimeoutsOutputReference extends cdktf.ComplexObject {
88
88
  }
89
89
  exports.DataAzapiClientConfigTimeoutsOutputReference = DataAzapiClientConfigTimeoutsOutputReference;
90
90
  _a = JSII_RTTI_SYMBOL_1;
91
- DataAzapiClientConfigTimeoutsOutputReference[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiClientConfigTimeoutsOutputReference", version: "1.3.0" };
91
+ DataAzapiClientConfigTimeoutsOutputReference[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiClientConfigTimeoutsOutputReference", version: "1.4.0" };
92
92
  /**
93
93
  * Represents a {@link https://registry.terraform.io/providers/azure/azapi/2.7.0/docs/data-sources/client_config azapi_client_config}
94
94
  */
@@ -195,7 +195,7 @@ class DataAzapiClientConfig extends cdktf.TerraformDataSource {
195
195
  }
196
196
  exports.DataAzapiClientConfig = DataAzapiClientConfig;
197
197
  _b = JSII_RTTI_SYMBOL_1;
198
- DataAzapiClientConfig[_b] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiClientConfig", version: "1.3.0" };
198
+ DataAzapiClientConfig[_b] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiClientConfig", version: "1.4.0" };
199
199
  // =================
200
200
  // STATIC PROPERTIES
201
201
  // =================
@@ -72,7 +72,7 @@ class DataAzapiResourceIdentityOutputReference extends cdktf.ComplexObject {
72
72
  }
73
73
  exports.DataAzapiResourceIdentityOutputReference = DataAzapiResourceIdentityOutputReference;
74
74
  _a = JSII_RTTI_SYMBOL_1;
75
- DataAzapiResourceIdentityOutputReference[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceIdentityOutputReference", version: "1.3.0" };
75
+ DataAzapiResourceIdentityOutputReference[_a] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceIdentityOutputReference", version: "1.4.0" };
76
76
  class DataAzapiResourceIdentityList extends cdktf.ComplexList {
77
77
  /**
78
78
  * @param terraformResource The parent resource
@@ -94,7 +94,7 @@ class DataAzapiResourceIdentityList extends cdktf.ComplexList {
94
94
  }
95
95
  exports.DataAzapiResourceIdentityList = DataAzapiResourceIdentityList;
96
96
  _b = JSII_RTTI_SYMBOL_1;
97
- DataAzapiResourceIdentityList[_b] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceIdentityList", version: "1.3.0" };
97
+ DataAzapiResourceIdentityList[_b] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceIdentityList", version: "1.4.0" };
98
98
  function dataAzapiResourceRetryToTerraform(struct) {
99
99
  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
100
100
  return struct;
@@ -278,7 +278,7 @@ class DataAzapiResourceRetryOutputReference extends cdktf.ComplexObject {
278
278
  }
279
279
  exports.DataAzapiResourceRetryOutputReference = DataAzapiResourceRetryOutputReference;
280
280
  _c = JSII_RTTI_SYMBOL_1;
281
- DataAzapiResourceRetryOutputReference[_c] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceRetryOutputReference", version: "1.3.0" };
281
+ DataAzapiResourceRetryOutputReference[_c] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceRetryOutputReference", version: "1.4.0" };
282
282
  function dataAzapiResourceTimeoutsToTerraform(struct) {
283
283
  if (!cdktf.canInspect(struct) || cdktf.Tokenization.isResolvable(struct)) {
284
284
  return struct;
@@ -361,7 +361,7 @@ class DataAzapiResourceTimeoutsOutputReference extends cdktf.ComplexObject {
361
361
  }
362
362
  exports.DataAzapiResourceTimeoutsOutputReference = DataAzapiResourceTimeoutsOutputReference;
363
363
  _d = JSII_RTTI_SYMBOL_1;
364
- DataAzapiResourceTimeoutsOutputReference[_d] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceTimeoutsOutputReference", version: "1.3.0" };
364
+ DataAzapiResourceTimeoutsOutputReference[_d] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResourceTimeoutsOutputReference", version: "1.4.0" };
365
365
  /**
366
366
  * Represents a {@link https://registry.terraform.io/providers/azure/azapi/2.7.0/docs/data-sources/resource azapi_resource}
367
367
  */
@@ -663,7 +663,7 @@ class DataAzapiResource extends cdktf.TerraformDataSource {
663
663
  }
664
664
  exports.DataAzapiResource = DataAzapiResource;
665
665
  _e = JSII_RTTI_SYMBOL_1;
666
- DataAzapiResource[_e] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResource", version: "1.3.0" };
666
+ DataAzapiResource[_e] = { fqn: "@microsoft/terraform-cdk-constructs.DataAzapiResource", version: "1.4.0" };
667
667
  // =================
668
668
  // STATIC PROPERTIES
669
669
  // =================