@microsoft/terraform-cdk-constructs 0.0.3-pre.6 → 0.0.3-pre.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (85) hide show
  1. package/.jsii +909 -306
  2. package/API.md +2488 -255
  3. package/README.md +112 -18
  4. package/docs/images/ide-documentation.png +0 -0
  5. package/lib/azure-actiongroup/lib/actiongroup.d.ts +39 -0
  6. package/lib/azure-actiongroup/lib/actiongroup.js +40 -1
  7. package/lib/azure-applicationgateway/lib/gateway.d.ts +76 -0
  8. package/lib/azure-applicationgateway/lib/gateway.js +78 -2
  9. package/lib/azure-applicationinsights/lib/appinsights.d.ts +50 -0
  10. package/lib/azure-applicationinsights/lib/appinsights.js +52 -3
  11. package/lib/azure-containerregistry/lib/registry.d.ts +29 -0
  12. package/lib/azure-containerregistry/lib/registry.js +31 -2
  13. package/lib/azure-datalake/lib/datalake.d.ts +50 -0
  14. package/lib/azure-datalake/lib/datalake.js +51 -1
  15. package/lib/azure-datalake/lib/filesystem.d.ts +51 -0
  16. package/lib/azure-datalake/lib/filesystem.js +52 -1
  17. package/lib/azure-datalake/lib/path.d.ts +37 -0
  18. package/lib/azure-datalake/lib/path.js +38 -1
  19. package/lib/azure-eventhub/lib/authorization.d.ts +30 -0
  20. package/lib/azure-eventhub/lib/authorization.js +32 -2
  21. package/lib/azure-eventhub/lib/cluster.d.ts +29 -0
  22. package/lib/azure-eventhub/lib/cluster.js +31 -2
  23. package/lib/azure-eventhub/lib/consumer.d.ts +28 -0
  24. package/lib/azure-eventhub/lib/consumer.js +30 -2
  25. package/lib/azure-eventhub/lib/instance.d.ts +118 -0
  26. package/lib/azure-eventhub/lib/instance.js +120 -2
  27. package/lib/azure-eventhub/lib/kusto-connection.d.ts +41 -0
  28. package/lib/azure-eventhub/lib/kusto-connection.js +43 -2
  29. package/lib/azure-eventhub/lib/namespace.d.ts +74 -0
  30. package/lib/azure-eventhub/lib/namespace.js +76 -3
  31. package/lib/azure-functionapp/lib/functionapplinux.js +1 -1
  32. package/lib/azure-keyvault/lib/certificate.d.ts +96 -2
  33. package/lib/azure-keyvault/lib/certificate.js +55 -3
  34. package/lib/azure-keyvault/lib/key.d.ts +36 -0
  35. package/lib/azure-keyvault/lib/key.js +38 -2
  36. package/lib/azure-keyvault/lib/policy.d.ts +30 -0
  37. package/lib/azure-keyvault/lib/policy.js +32 -2
  38. package/lib/azure-keyvault/lib/secret.d.ts +31 -0
  39. package/lib/azure-keyvault/lib/secret.js +33 -2
  40. package/lib/azure-keyvault/lib/vault.d.ts +188 -0
  41. package/lib/azure-keyvault/lib/vault.js +191 -7
  42. package/lib/azure-kubernetes/lib/cluster.d.ts +25 -4
  43. package/lib/azure-kubernetes/lib/cluster.js +27 -6
  44. package/lib/azure-kusto/lib/cluster.d.ts +53 -0
  45. package/lib/azure-kusto/lib/cluster.js +55 -2
  46. package/lib/azure-kusto/lib/compute-specification.js +1 -1
  47. package/lib/azure-kusto/lib/database.d.ts +103 -0
  48. package/lib/azure-kusto/lib/database.js +105 -2
  49. package/lib/azure-loganalytics/lib/workspace.d.ts +47 -0
  50. package/lib/azure-loganalytics/lib/workspace.js +49 -2
  51. package/lib/azure-metricalert/lib/metric-alert.d.ts +43 -4
  52. package/lib/azure-metricalert/lib/metric-alert.js +45 -6
  53. package/lib/azure-networksecuritygroup/lib/preconfigured-rules.js +1 -1
  54. package/lib/azure-networksecuritygroup/lib/securitygroup.d.ts +92 -0
  55. package/lib/azure-networksecuritygroup/lib/securitygroup.js +95 -5
  56. package/lib/azure-queryrulealert/lib/query-rule-alert.d.ts +35 -4
  57. package/lib/azure-queryrulealert/lib/query-rule-alert.js +37 -6
  58. package/lib/azure-resourcegroup/lib/resource-group.d.ts +28 -0
  59. package/lib/azure-resourcegroup/lib/resource-group.js +30 -2
  60. package/lib/azure-storageaccount/lib/account.d.ts +75 -48
  61. package/lib/azure-storageaccount/lib/account.js +77 -50
  62. package/lib/azure-storageaccount/lib/container.d.ts +94 -12
  63. package/lib/azure-storageaccount/lib/container.js +97 -15
  64. package/lib/azure-storageaccount/lib/fileshare.d.ts +36 -0
  65. package/lib/azure-storageaccount/lib/fileshare.js +39 -3
  66. package/lib/azure-storageaccount/lib/queue.d.ts +29 -0
  67. package/lib/azure-storageaccount/lib/queue.js +31 -2
  68. package/lib/azure-storageaccount/lib/table.d.ts +32 -0
  69. package/lib/azure-storageaccount/lib/table.js +34 -2
  70. package/lib/azure-virtualmachine/lib/image-references.js +2 -2
  71. package/lib/azure-virtualmachine/lib/vm.d.ts +84 -8
  72. package/lib/azure-virtualmachine/lib/vm.js +87 -11
  73. package/lib/azure-virtualmachinescaleset/lib/cluster.d.ts +98 -8
  74. package/lib/azure-virtualmachinescaleset/lib/cluster.js +101 -11
  75. package/lib/azure-virtualnetwork/lib/network.d.ts +61 -0
  76. package/lib/azure-virtualnetwork/lib/network.js +63 -3
  77. package/lib/azure-virtualnetwork/lib/peering.d.ts +39 -0
  78. package/lib/azure-virtualnetwork/lib/peering.js +41 -2
  79. package/lib/core-azure/lib/diagsettings.d.ts +37 -0
  80. package/lib/core-azure/lib/diagsettings.js +39 -2
  81. package/lib/core-azure/lib/rbac.d.ts +22 -4
  82. package/lib/core-azure/lib/rbac.js +24 -6
  83. package/lib/core-azure/lib/resource.d.ts +45 -0
  84. package/lib/core-azure/lib/resource.js +48 -4
  85. package/package.json +1 -1
@@ -9,6 +9,30 @@ const compute_specification_1 = require("./compute-specification");
9
9
  const database_1 = require("./database");
10
10
  const index_1 = require("../../core-azure/lib/index");
11
11
  class Cluster extends index_1.AzureResource {
12
+ /**
13
+ * Represents a Kusto (Azure Data Explorer) cluster in Azure.
14
+ *
15
+ * This class is responsible for the creation and management of a Kusto Cluster, which is a highly scalable and secure
16
+ * analytics service for ingesting, storing, and analyzing large volumes of data. The cluster supports various configurations
17
+ * tailored to the needs of specific data workloads and security requirements.
18
+ *
19
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
20
+ * @param id - The unique identifier for this instance of the cluster.
21
+ * @param kustoProps - The properties required to configure the Kusto cluster, as defined in the ClusterProps interface.
22
+ *
23
+ * Example usage:
24
+ * ```typescript
25
+ * new Cluster(this, 'MyKustoCluster', {
26
+ * name: 'example-cluster',
27
+ * location: 'West US',
28
+ * resourceGroup: myResourceGroup,
29
+ * sku: { tier: 'Standard', name: 'D13_v2', capacity: 2 },
30
+ * tags: {
31
+ * project: 'Data Analytics'
32
+ * }
33
+ * });
34
+ * ```
35
+ */
12
36
  constructor(scope, id, kustoProps) {
13
37
  super(scope, id);
14
38
  this.kustoProps = kustoProps;
@@ -75,11 +99,40 @@ class Cluster extends index_1.AzureResource {
75
99
  cdktfTerraformOutputDataIngestionUri.overrideLogicalId("Kusto_data_ingestion_uri");
76
100
  cdktfTerraformOutputKustoIdentity.overrideLogicalId("Kusto_identity");
77
101
  }
102
+ /**
103
+ * Adds a new database to the Azure Kusto Cluster.
104
+ *
105
+ * This method creates a database within the Azure Data Explorer (Kusto) cluster, defined by the properties provided.
106
+ * A database in Kusto serves as a logical group to manage various tables and store data. It is essential for performing
107
+ * data analytics and running queries. The database configuration can include settings like hot cache and soft delete periods,
108
+ * which optimize query performance and manage data lifecycle according to specific requirements.
109
+ *
110
+ * @param databaseProps - The properties required to create the database. These properties should include:
111
+ * - `kusto`: Reference to the Kusto cluster to which the database will be added.
112
+ * - `name`: The name of the database, which must be unique within the cluster.
113
+ * - `hotCachePeriod`: Optional. Specifies the duration that data should be kept in cache for faster query access.
114
+ * - `softDeletePeriod`: Optional. Specifies the duration that data should be retained before it stops being accessible to queries.
115
+ * Both the hot cache and soft delete periods should be specified in ISO 8601 duration format.
116
+ *
117
+ * @returns A `Database` object representing the newly created database within the Kusto cluster.
118
+ *
119
+ * Example usage:
120
+ * ```typescript
121
+ * const myDatabase = myCluster.addDatabase({
122
+ * kusto: myKustoCluster,
123
+ * name: 'OperationalData',
124
+ * hotCachePeriod: 'P14D', // 14 days
125
+ * softDeletePeriod: 'P365D' // 1 year
126
+ * });
127
+ * ```
128
+ * This method facilitates the efficient setup and scaling of databases within an Azure Kusto cluster, allowing
129
+ * for complex data analytics operations across large datasets.
130
+ */
78
131
  addDatabase(databaseProps) {
79
132
  return new database_1.Database(this, databaseProps.name, databaseProps);
80
133
  }
81
134
  }
82
135
  exports.Cluster = Cluster;
83
136
  _a = JSII_RTTI_SYMBOL_1;
84
- Cluster[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kusto.Cluster", version: "0.0.3-pre.6" };
85
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["../../../src/azure-kusto/lib/cluster.ts"],"names":[],"mappings":"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","sourcesContent":["import { KustoCluster } from \"@cdktf/provider-azurerm/lib/kusto-cluster\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ComputeSpecification,\n  IComputeSpecification,\n} from \"./compute-specification\";\nimport { Database, DatabaseProps } from \"./database\";\nimport { AzureResource } from \"../../core-azure/lib/index\";\n\nexport interface ClusterProps {\n  /**\n   * The Azure Resource Group in which to create the Kusto Cluster.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The name of the Kusto Cluster to create.\n   * Only 4-22 lowercase alphanumeric characters allowed, starting with a letter.\n   */\n  readonly name: string;\n  /**\n   * The SKU of the Kusto Cluster. All the allowed values are defined in the ComputeSpecification class.\n   * @default devtestExtraSmallDv2\n   */\n  readonly sku?: IComputeSpecification;\n  /**\n   * The node count for the cluster.\n   * @default 2\n   */\n  readonly capacity?: number;\n  /**\n   * The type of Managed Service Identity.\n   * @default \"SystemAssigned\"\n   */\n  readonly identityType?: string;\n  /**\n   * A list of User Assigned Managed Identity IDs to be assigned to this Kusto Cluster.\n   */\n  readonly identityIds?: string[];\n  /**\n   * Is the public network access enabled?\n   * @default true\n   */\n  readonly publicNetworkAccessEnabled?: boolean;\n  /**\n   * Specifies if the cluster could be automatically stopped.\n   * (due to lack of data or no activity for many days).\n   * @default true\n   */\n  readonly autoStopEnabled?: boolean;\n  /**\n   * Specifies if the streaming ingest is enabled.\n   * @default true\n   */\n  readonly streamingIngestionEnabled?: boolean;\n  /**\n   * Specifies if the purge operations are enabled.\n   * @default false\n   */\n  readonly purgeEnabled?: boolean;\n  /**\n   * Specifies if the purge operations are enabled. Based on the SKU, the number of zones allowed are different.\n   * @default true\n   */\n  readonly enableZones?: boolean;\n  /**\n   * The minimum number of allowed instances. Must between 0 and 1000.\n   */\n  readonly minimumInstances?: number;\n  /**\n   * The maximum number of allowed instances. Must between 0 and 1000.\n   */\n  readonly maximumInstances?: number;\n  /**\n   * A mapping of tags to assign to the Kusto.\n   */\n  readonly tags?: { [key: string]: string };\n}\n\nexport class Cluster extends AzureResource {\n  readonly kustoProps: ClusterProps;\n  public id: string;\n  public resourceGroup: ResourceGroup;\n  public readonly uri: string;\n\n  constructor(scope: Construct, id: string, kustoProps: ClusterProps) {\n    super(scope, id);\n    this.kustoProps = kustoProps;\n    this.resourceGroup = kustoProps.resourceGroup;\n\n    /**\n     * Define default values.\n     */\n    const sku = kustoProps.sku || ComputeSpecification.devtestExtraSmallDv2;\n    const enableZones = kustoProps.enableZones || true;\n\n    const defaults = {\n      publicNetworkAccessEnabled: kustoProps.publicNetworkAccessEnabled || true,\n      autoStopEnabled: kustoProps.autoStopEnabled || true,\n      streamingIngestionEnabled: kustoProps.streamingIngestionEnabled || true,\n      purgeEnabled: kustoProps.purgeEnabled || false,\n      zones: enableZones ? sku.availibleZones : [],\n      sku: {\n        name: sku.skuName,\n        capacity: kustoProps.capacity || 2,\n      },\n      identity: {\n        type: \"SystemAssigned\",\n        identityIds: [],\n      },\n    };\n\n    /**\n     * Create Kusto Cluster resource.\n     */\n    const azurermKustoCluster = new KustoCluster(this, \"Kusto\", {\n      ...defaults,\n      name: kustoProps.name,\n      location: kustoProps.resourceGroup.location,\n      resourceGroupName: kustoProps.resourceGroup.name,\n      tags: kustoProps.tags,\n    });\n\n    if (kustoProps.identityType) {\n      azurermKustoCluster.addOverride(\"identity\", {\n        type: kustoProps.identityType,\n        identityIds: kustoProps.identityIds,\n      });\n    }\n\n    if (kustoProps.minimumInstances && kustoProps.maximumInstances) {\n      azurermKustoCluster.addOverride(\n        \"minimum_instances\",\n        kustoProps.minimumInstances,\n      );\n      azurermKustoCluster.addOverride(\n        \"maximum_instances\",\n        kustoProps.maximumInstances,\n      );\n    }\n\n    this.id = azurermKustoCluster.id;\n    this.uri = azurermKustoCluster.uri;\n\n    // Outputs\n    const cdktfTerraformOutputKustoId = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_id\",\n      {\n        value: azurermKustoCluster.id,\n      },\n    );\n    const cdktfTerraformOutputKustoUri = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_uri\",\n      {\n        value: azurermKustoCluster.uri,\n      },\n    );\n    const cdktfTerraformOutputDataIngestionUri = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_data_ingestion_uri\",\n      {\n        value: azurermKustoCluster.dataIngestionUri,\n      },\n    );\n    const cdktfTerraformOutputKustoIdentity = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_identity\",\n      {\n        value: azurermKustoCluster.identity,\n        sensitive: true,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputKustoId.overrideLogicalId(\"Kusto_id\");\n    cdktfTerraformOutputKustoUri.overrideLogicalId(\"Kusto_uri\");\n    cdktfTerraformOutputDataIngestionUri.overrideLogicalId(\n      \"Kusto_data_ingestion_uri\",\n    );\n    cdktfTerraformOutputKustoIdentity.overrideLogicalId(\"Kusto_identity\");\n  }\n\n  public addDatabase(databaseProps: DatabaseProps) {\n    return new Database(this, databaseProps.name, databaseProps);\n  }\n}\n"]}
137
+ Cluster[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kusto.Cluster", version: "0.0.3-pre.7" };
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cluster.js","sourceRoot":"","sources":["../../../src/azure-kusto/lib/cluster.ts"],"names":[],"mappings":"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","sourcesContent":["import { KustoCluster } from \"@cdktf/provider-azurerm/lib/kusto-cluster\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport {\n  ComputeSpecification,\n  IComputeSpecification,\n} from \"./compute-specification\";\nimport { Database, DatabaseProps } from \"./database\";\nimport { AzureResource } from \"../../core-azure/lib/index\";\n\nexport interface ClusterProps {\n  /**\n   * The Azure Resource Group in which to create the Kusto Cluster.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The name of the Kusto Cluster to create.\n   * Only 4-22 lowercase alphanumeric characters allowed, starting with a letter.\n   */\n  readonly name: string;\n  /**\n   * The SKU of the Kusto Cluster. All the allowed values are defined in the ComputeSpecification class.\n   * @default devtestExtraSmallDv2\n   */\n  readonly sku?: IComputeSpecification;\n  /**\n   * The node count for the cluster.\n   * @default 2\n   */\n  readonly capacity?: number;\n  /**\n   * The type of Managed Service Identity.\n   * @default \"SystemAssigned\"\n   */\n  readonly identityType?: string;\n  /**\n   * A list of User Assigned Managed Identity IDs to be assigned to this Kusto Cluster.\n   */\n  readonly identityIds?: string[];\n  /**\n   * Is the public network access enabled?\n   * @default true\n   */\n  readonly publicNetworkAccessEnabled?: boolean;\n  /**\n   * Specifies if the cluster could be automatically stopped.\n   * (due to lack of data or no activity for many days).\n   * @default true\n   */\n  readonly autoStopEnabled?: boolean;\n  /**\n   * Specifies if the streaming ingest is enabled.\n   * @default true\n   */\n  readonly streamingIngestionEnabled?: boolean;\n  /**\n   * Specifies if the purge operations are enabled.\n   * @default false\n   */\n  readonly purgeEnabled?: boolean;\n  /**\n   * Specifies if the purge operations are enabled. Based on the SKU, the number of zones allowed are different.\n   * @default true\n   */\n  readonly enableZones?: boolean;\n  /**\n   * The minimum number of allowed instances. Must between 0 and 1000.\n   */\n  readonly minimumInstances?: number;\n  /**\n   * The maximum number of allowed instances. Must between 0 and 1000.\n   */\n  readonly maximumInstances?: number;\n  /**\n   * A mapping of tags to assign to the Kusto.\n   */\n  readonly tags?: { [key: string]: string };\n}\n\nexport class Cluster extends AzureResource {\n  readonly kustoProps: ClusterProps;\n  public id: string;\n  public resourceGroup: ResourceGroup;\n  public readonly uri: string;\n\n  /**\n   * Represents a Kusto (Azure Data Explorer) cluster in Azure.\n   *\n   * This class is responsible for the creation and management of a Kusto Cluster, which is a highly scalable and secure\n   * analytics service for ingesting, storing, and analyzing large volumes of data. The cluster supports various configurations\n   * tailored to the needs of specific data workloads and security requirements.\n   *\n   * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.\n   * @param id - The unique identifier for this instance of the cluster.\n   * @param kustoProps - The properties required to configure the Kusto cluster, as defined in the ClusterProps interface.\n   *\n   * Example usage:\n   * ```typescript\n   * new Cluster(this, 'MyKustoCluster', {\n   *   name: 'example-cluster',\n   *   location: 'West US',\n   *   resourceGroup: myResourceGroup,\n   *   sku: { tier: 'Standard', name: 'D13_v2', capacity: 2 },\n   *   tags: {\n   *     project: 'Data Analytics'\n   *   }\n   * });\n   * ```\n   */\n  constructor(scope: Construct, id: string, kustoProps: ClusterProps) {\n    super(scope, id);\n    this.kustoProps = kustoProps;\n    this.resourceGroup = kustoProps.resourceGroup;\n\n    /**\n     * Define default values.\n     */\n    const sku = kustoProps.sku || ComputeSpecification.devtestExtraSmallDv2;\n    const enableZones = kustoProps.enableZones || true;\n\n    const defaults = {\n      publicNetworkAccessEnabled: kustoProps.publicNetworkAccessEnabled || true,\n      autoStopEnabled: kustoProps.autoStopEnabled || true,\n      streamingIngestionEnabled: kustoProps.streamingIngestionEnabled || true,\n      purgeEnabled: kustoProps.purgeEnabled || false,\n      zones: enableZones ? sku.availibleZones : [],\n      sku: {\n        name: sku.skuName,\n        capacity: kustoProps.capacity || 2,\n      },\n      identity: {\n        type: \"SystemAssigned\",\n        identityIds: [],\n      },\n    };\n\n    /**\n     * Create Kusto Cluster resource.\n     */\n    const azurermKustoCluster = new KustoCluster(this, \"Kusto\", {\n      ...defaults,\n      name: kustoProps.name,\n      location: kustoProps.resourceGroup.location,\n      resourceGroupName: kustoProps.resourceGroup.name,\n      tags: kustoProps.tags,\n    });\n\n    if (kustoProps.identityType) {\n      azurermKustoCluster.addOverride(\"identity\", {\n        type: kustoProps.identityType,\n        identityIds: kustoProps.identityIds,\n      });\n    }\n\n    if (kustoProps.minimumInstances && kustoProps.maximumInstances) {\n      azurermKustoCluster.addOverride(\n        \"minimum_instances\",\n        kustoProps.minimumInstances,\n      );\n      azurermKustoCluster.addOverride(\n        \"maximum_instances\",\n        kustoProps.maximumInstances,\n      );\n    }\n\n    this.id = azurermKustoCluster.id;\n    this.uri = azurermKustoCluster.uri;\n\n    // Outputs\n    const cdktfTerraformOutputKustoId = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_id\",\n      {\n        value: azurermKustoCluster.id,\n      },\n    );\n    const cdktfTerraformOutputKustoUri = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_uri\",\n      {\n        value: azurermKustoCluster.uri,\n      },\n    );\n    const cdktfTerraformOutputDataIngestionUri = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_data_ingestion_uri\",\n      {\n        value: azurermKustoCluster.dataIngestionUri,\n      },\n    );\n    const cdktfTerraformOutputKustoIdentity = new cdktf.TerraformOutput(\n      this,\n      \"Kusto_identity\",\n      {\n        value: azurermKustoCluster.identity,\n        sensitive: true,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputKustoId.overrideLogicalId(\"Kusto_id\");\n    cdktfTerraformOutputKustoUri.overrideLogicalId(\"Kusto_uri\");\n    cdktfTerraformOutputDataIngestionUri.overrideLogicalId(\n      \"Kusto_data_ingestion_uri\",\n    );\n    cdktfTerraformOutputKustoIdentity.overrideLogicalId(\"Kusto_identity\");\n  }\n\n  /**\n   * Adds a new database to the Azure Kusto Cluster.\n   *\n   * This method creates a database within the Azure Data Explorer (Kusto) cluster, defined by the properties provided.\n   * A database in Kusto serves as a logical group to manage various tables and store data. It is essential for performing\n   * data analytics and running queries. The database configuration can include settings like hot cache and soft delete periods,\n   * which optimize query performance and manage data lifecycle according to specific requirements.\n   *\n   * @param databaseProps - The properties required to create the database. These properties should include:\n   *                        - `kusto`: Reference to the Kusto cluster to which the database will be added.\n   *                        - `name`: The name of the database, which must be unique within the cluster.\n   *                        - `hotCachePeriod`: Optional. Specifies the duration that data should be kept in cache for faster query access.\n   *                        - `softDeletePeriod`: Optional. Specifies the duration that data should be retained before it stops being accessible to queries.\n   *                          Both the hot cache and soft delete periods should be specified in ISO 8601 duration format.\n   *\n   * @returns A `Database` object representing the newly created database within the Kusto cluster.\n   *\n   * Example usage:\n   * ```typescript\n   * const myDatabase = myCluster.addDatabase({\n   *   kusto: myKustoCluster,\n   *   name: 'OperationalData',\n   *   hotCachePeriod: 'P14D', // 14 days\n   *   softDeletePeriod: 'P365D' // 1 year\n   * });\n   * ```\n   * This method facilitates the efficient setup and scaling of databases within an Azure Kusto cluster, allowing\n   * for complex data analytics operations across large datasets.\n   */\n  public addDatabase(databaseProps: DatabaseProps) {\n    return new Database(this, databaseProps.name, databaseProps);\n  }\n}\n"]}
@@ -7,7 +7,7 @@ class ComputeSpecification {
7
7
  }
8
8
  exports.ComputeSpecification = ComputeSpecification;
9
9
  _a = JSII_RTTI_SYMBOL_1;
10
- ComputeSpecification[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kusto.ComputeSpecification", version: "0.0.3-pre.6" };
10
+ ComputeSpecification[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kusto.ComputeSpecification", version: "0.0.3-pre.7" };
11
11
  ComputeSpecification.devtestExtraSmallDv2 = {
12
12
  skuName: "Dev(No SLA)_Standard_D11_v2",
13
13
  workload: "dev/test",
@@ -52,8 +52,111 @@ export declare class Database extends Construct {
52
52
  readonly kustoProps: ClusterProps;
53
53
  readonly rg: string;
54
54
  readonly id: string;
55
+ /**
56
+ * Represents a Kusto Database within an Azure Kusto Cluster.
57
+ *
58
+ * This class is responsible for the creation and management of a database in Azure Data Explorer (Kusto),
59
+ * which stores data tables and provides a query engine. A Kusto database is a logical group of tables
60
+ * and is associated with a specific Kusto cluster. The database supports configurations such as
61
+ * hot cache period and soft delete period to optimize performance and data retention according to
62
+ * specific workload requirements.
63
+ *
64
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
65
+ * @param id - The unique identifier for this instance of the Kusto database.
66
+ * @param kustoDbProps - The properties required to configure the Kusto database. These include:
67
+ * - `kusto`: Reference to the Kusto cluster to which the database will belong.
68
+ * - `name`: The name of the database to be created within the Kusto cluster.
69
+ * - `hotCachePeriod`: Optional. Specifies the duration that data should be kept in cache for faster query performance.
70
+ * Expressed in ISO 8601 duration format.
71
+ * - `softDeletePeriod`: Optional. Specifies the duration that data should be retained before it stops being accessible.
72
+ * Expressed in ISO 8601 duration format.
73
+ *
74
+ * Example usage:
75
+ * ```typescript
76
+ * const myDatabase = new Database(this, 'MyKustoDatabase', {
77
+ * kusto: myKustoCluster,
78
+ * name: 'AnalyticsDB',
79
+ * hotCachePeriod: 'P30D', // 30 days
80
+ * softDeletePeriod: 'P365D' // 365 days
81
+ * });
82
+ * ```
83
+ *
84
+ * This class sets up the database configurations and integrates it within the specified Kusto cluster,
85
+ * providing capabilities to manage and query large datasets effectively.
86
+ */
55
87
  constructor(scope: Construct, id: string, kustoDbProps: DatabaseProps);
88
+ /**
89
+ * Adds a database principal assignment in the Kusto cluster, assigning specified access rights to a principal.
90
+ *
91
+ * This method is used to grant access permissions to a specific user, group, or service principal within an Azure Active Directory.
92
+ * These permissions determine the level of access that the principal has over the Kusto database, such as viewing, ingesting, or managing data.
93
+ * The assignment is made by creating a KustoDatabasePrincipalAssignment resource, specifying the principal details and the type of role
94
+ * they should assume.
95
+ *
96
+ * @param kustoDatabaseAccessProps - The properties defining the principal assignment. This includes:
97
+ * - `name`: A unique name identifying this principal assignment.
98
+ * - `tenantId`: The Azure Active Directory tenant ID where the principal resides.
99
+ * - `principalId`: The object ID of the principal (user, group, or service principal) in Azure AD.
100
+ * - `principalType`: The type of principal (e.g., User, Group, App).
101
+ * - `role`: The database role assigned to the principal. Roles can include Admin, User, Viewer, among others.
102
+ *
103
+ * Example usage:
104
+ * ```typescript
105
+ * myDatabase.addPermission({
106
+ * name: 'DataScienceTeamAccess',
107
+ * tenantId: 'tenant-id',
108
+ * principalId: 'principal-id',
109
+ * principalType: 'Group',
110
+ * role: 'Viewer'
111
+ * });
112
+ * ```
113
+ * This method creates a new principal assignment, enabling specified access controls for the principal
114
+ * on the Kusto database based on the role assigned. It is crucial for managing security and access
115
+ * governance within the Kusto environment.
116
+ */
56
117
  addPermission(kustoDatabaseAccessProps: DatabaseAccessProps): void;
118
+ /**
119
+ * Adds a new table to an existing Azure Kusto database.
120
+ *
121
+ * This method creates a table within the specified Kusto database using a given schema. Tables in Kusto store structured data with
122
+ * defined columns and types, which are crucial for storing and querying large datasets efficiently. The method constructs a Kusto
123
+ * Data Explorer control command to create the table and then executes this command within the context of the database.
124
+ *
125
+ * @param tableName - The name of the table to create, which must be unique within the database.
126
+ * @param tableSchema - An array of schema properties defining the columns of the table, including column names and their data types.
127
+ *
128
+ * Example usage:
129
+ * ```typescript
130
+ * myDatabase.addTable('SalesData', [
131
+ * { columnName: 'TransactionId', columnType: 'int' },
132
+ * { columnName: 'TransactionDate', columnType: 'datetime' },
133
+ * { columnName: 'Amount', columnType: 'real' }
134
+ * ]);
135
+ * ```
136
+ * This method constructs the command to create the table and applies it directly within the Kusto database,
137
+ * ensuring the table is ready for data ingestion and querying.
138
+ */
57
139
  addTable(tableName: string, tableSchema: TableSchemaProps[]): void;
140
+ /**
141
+ * Adds and executes a control command or script within the Kusto database.
142
+ *
143
+ * This method facilitates the execution of Kusto Query Language (KQL) scripts or control commands within the specified
144
+ * Kusto database. Scripts can perform a variety of functions, from schema modifications, like adding new tables or altering
145
+ * existing ones, to data management operations, such as data ingestion or cleanup tasks. Each script is executed as a
146
+ * KustoScript resource, which ensures that the script is applied correctly and atomically to the database.
147
+ *
148
+ * @param scriptName - A unique name for the script, which helps in identifying the script resource within the deployment.
149
+ * @param scriptContent - The KQL script or control command to be executed. This should be a valid KQL command string.
150
+ *
151
+ * Example usage:
152
+ * ```typescript
153
+ * myDatabase.addScript('InitializeSalesTable', `
154
+ * .create table SalesData (TransactionId: int, TransactionDate: datetime, Amount: real)
155
+ * .alter-merge table SalesData policy retentionsoftdelete = 365d
156
+ * `);
157
+ * ```
158
+ * This method will create a `KustoScript` resource that encapsulates the command, ensuring it is executed against the
159
+ * database, and is tracked as part of the resource management within Azure.
160
+ */
58
161
  addScript(scriptName: string, scriptContent: string): void;
59
162
  }
@@ -10,6 +10,38 @@ const cdktf = require("cdktf");
10
10
  const constructs_1 = require("constructs");
11
11
  const ts_md5_1 = require("ts-md5");
12
12
  class Database extends constructs_1.Construct {
13
+ /**
14
+ * Represents a Kusto Database within an Azure Kusto Cluster.
15
+ *
16
+ * This class is responsible for the creation and management of a database in Azure Data Explorer (Kusto),
17
+ * which stores data tables and provides a query engine. A Kusto database is a logical group of tables
18
+ * and is associated with a specific Kusto cluster. The database supports configurations such as
19
+ * hot cache period and soft delete period to optimize performance and data retention according to
20
+ * specific workload requirements.
21
+ *
22
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
23
+ * @param id - The unique identifier for this instance of the Kusto database.
24
+ * @param kustoDbProps - The properties required to configure the Kusto database. These include:
25
+ * - `kusto`: Reference to the Kusto cluster to which the database will belong.
26
+ * - `name`: The name of the database to be created within the Kusto cluster.
27
+ * - `hotCachePeriod`: Optional. Specifies the duration that data should be kept in cache for faster query performance.
28
+ * Expressed in ISO 8601 duration format.
29
+ * - `softDeletePeriod`: Optional. Specifies the duration that data should be retained before it stops being accessible.
30
+ * Expressed in ISO 8601 duration format.
31
+ *
32
+ * Example usage:
33
+ * ```typescript
34
+ * const myDatabase = new Database(this, 'MyKustoDatabase', {
35
+ * kusto: myKustoCluster,
36
+ * name: 'AnalyticsDB',
37
+ * hotCachePeriod: 'P30D', // 30 days
38
+ * softDeletePeriod: 'P365D' // 365 days
39
+ * });
40
+ * ```
41
+ *
42
+ * This class sets up the database configurations and integrates it within the specified Kusto cluster,
43
+ * providing capabilities to manage and query large datasets effectively.
44
+ */
13
45
  constructor(scope, id, kustoDbProps) {
14
46
  super(scope, id);
15
47
  this.kustoDbProps = kustoDbProps;
@@ -34,6 +66,35 @@ class Database extends constructs_1.Construct {
34
66
  });
35
67
  cdktfTerraformOutputKustoDbId.overrideLogicalId("id");
36
68
  }
69
+ /**
70
+ * Adds a database principal assignment in the Kusto cluster, assigning specified access rights to a principal.
71
+ *
72
+ * This method is used to grant access permissions to a specific user, group, or service principal within an Azure Active Directory.
73
+ * These permissions determine the level of access that the principal has over the Kusto database, such as viewing, ingesting, or managing data.
74
+ * The assignment is made by creating a KustoDatabasePrincipalAssignment resource, specifying the principal details and the type of role
75
+ * they should assume.
76
+ *
77
+ * @param kustoDatabaseAccessProps - The properties defining the principal assignment. This includes:
78
+ * - `name`: A unique name identifying this principal assignment.
79
+ * - `tenantId`: The Azure Active Directory tenant ID where the principal resides.
80
+ * - `principalId`: The object ID of the principal (user, group, or service principal) in Azure AD.
81
+ * - `principalType`: The type of principal (e.g., User, Group, App).
82
+ * - `role`: The database role assigned to the principal. Roles can include Admin, User, Viewer, among others.
83
+ *
84
+ * Example usage:
85
+ * ```typescript
86
+ * myDatabase.addPermission({
87
+ * name: 'DataScienceTeamAccess',
88
+ * tenantId: 'tenant-id',
89
+ * principalId: 'principal-id',
90
+ * principalType: 'Group',
91
+ * role: 'Viewer'
92
+ * });
93
+ * ```
94
+ * This method creates a new principal assignment, enabling specified access controls for the principal
95
+ * on the Kusto database based on the role assigned. It is crucial for managing security and access
96
+ * governance within the Kusto environment.
97
+ */
37
98
  addPermission(kustoDatabaseAccessProps) {
38
99
  new kusto_database_principal_assignment_1.KustoDatabasePrincipalAssignment(this, `kusto-db-${kustoDatabaseAccessProps.name}-access`, {
39
100
  name: kustoDatabaseAccessProps.name,
@@ -46,6 +107,27 @@ class Database extends constructs_1.Construct {
46
107
  role: kustoDatabaseAccessProps.role,
47
108
  });
48
109
  }
110
+ /**
111
+ * Adds a new table to an existing Azure Kusto database.
112
+ *
113
+ * This method creates a table within the specified Kusto database using a given schema. Tables in Kusto store structured data with
114
+ * defined columns and types, which are crucial for storing and querying large datasets efficiently. The method constructs a Kusto
115
+ * Data Explorer control command to create the table and then executes this command within the context of the database.
116
+ *
117
+ * @param tableName - The name of the table to create, which must be unique within the database.
118
+ * @param tableSchema - An array of schema properties defining the columns of the table, including column names and their data types.
119
+ *
120
+ * Example usage:
121
+ * ```typescript
122
+ * myDatabase.addTable('SalesData', [
123
+ * { columnName: 'TransactionId', columnType: 'int' },
124
+ * { columnName: 'TransactionDate', columnType: 'datetime' },
125
+ * { columnName: 'Amount', columnType: 'real' }
126
+ * ]);
127
+ * ```
128
+ * This method constructs the command to create the table and applies it directly within the Kusto database,
129
+ * ensuring the table is ready for data ingestion and querying.
130
+ */
49
131
  addTable(tableName, tableSchema) {
50
132
  const schemaContent = tableSchema
51
133
  .map((column) => {
@@ -61,6 +143,27 @@ class Database extends constructs_1.Construct {
61
143
  forceAnUpdateWhenValueChanged: ts_md5_1.Md5.hashStr(scriptContent),
62
144
  });
63
145
  }
146
+ /**
147
+ * Adds and executes a control command or script within the Kusto database.
148
+ *
149
+ * This method facilitates the execution of Kusto Query Language (KQL) scripts or control commands within the specified
150
+ * Kusto database. Scripts can perform a variety of functions, from schema modifications, like adding new tables or altering
151
+ * existing ones, to data management operations, such as data ingestion or cleanup tasks. Each script is executed as a
152
+ * KustoScript resource, which ensures that the script is applied correctly and atomically to the database.
153
+ *
154
+ * @param scriptName - A unique name for the script, which helps in identifying the script resource within the deployment.
155
+ * @param scriptContent - The KQL script or control command to be executed. This should be a valid KQL command string.
156
+ *
157
+ * Example usage:
158
+ * ```typescript
159
+ * myDatabase.addScript('InitializeSalesTable', `
160
+ * .create table SalesData (TransactionId: int, TransactionDate: datetime, Amount: real)
161
+ * .alter-merge table SalesData policy retentionsoftdelete = 365d
162
+ * `);
163
+ * ```
164
+ * This method will create a `KustoScript` resource that encapsulates the command, ensuring it is executed against the
165
+ * database, and is tracked as part of the resource management within Azure.
166
+ */
64
167
  addScript(scriptName, scriptContent) {
65
168
  new kusto_script_1.KustoScript(this, `kusto-db-${this.kustoDbProps.name}-script-${scriptName}`, {
66
169
  name: `script-${scriptName}`,
@@ -73,5 +176,5 @@ class Database extends constructs_1.Construct {
73
176
  }
74
177
  exports.Database = Database;
75
178
  _a = JSII_RTTI_SYMBOL_1;
76
- Database[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kusto.Database", version: "0.0.3-pre.6" };
77
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"database.js","sourceRoot":"","sources":["../../../src/azure-kusto/lib/database.ts"],"names":[],"mappings":"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","sourcesContent":["import { KustoDatabase } from \"@cdktf/provider-azurerm/lib/kusto-database\";\nimport { KustoDatabasePrincipalAssignment } from \"@cdktf/provider-azurerm/lib/kusto-database-principal-assignment\";\nimport { KustoScript } from \"@cdktf/provider-azurerm/lib/kusto-script\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { Md5 } from \"ts-md5\";\nimport { ClusterProps, Cluster } from \"./cluster\";\n\nexport interface DatabaseProps {\n  /**\n   * The Azure Kusto cluster to which this database belongs.\n   */\n  readonly kusto: Cluster;\n  /**\n   * The name of the Kusto Database to create.\n   */\n  readonly name: string;\n  /**\n   * The time the data that should be kept in cache for fast queries as ISO 8601 timespan.\n   * Default is unlimited.\n   */\n  readonly hotCachePeriod?: string;\n  /**\n   * The time the data should be kept before it stops being accessible to queries as ISO 8601 timespan.\n   * Default is unlimited.\n   */\n  readonly softDeletePeriod?: string;\n}\n\nexport interface DatabaseAccessProps {\n  /**\n   * The name of the kusto principal assignment.\n   */\n  readonly name: string;\n  /**\n   * The tenant id in which the principal resides.\n   */\n  readonly tenantId: string;\n  /**\n   * The object id of the principal to assign to Kusto Database.\n   */\n  readonly principalId: string;\n  /**\n   * The type of the principal. Valid values include App, Group, User.\n   */\n  readonly principalType: string;\n  /**\n   * The database role assigned to the principal.\n   * Valid values include Admin, Ingestor, Monitor, UnrestrictedViewer, User and Viewer.\n   */\n  readonly role: string;\n}\n\nexport interface TableSchemaProps {\n  readonly columnName: string;\n  readonly columnType: string;\n}\n\nexport class Database extends Construct {\n  public readonly kustoDbProps: DatabaseProps;\n  public readonly kustoProps: ClusterProps;\n  public readonly rg: string;\n  public readonly id: string;\n\n  constructor(scope: Construct, id: string, kustoDbProps: DatabaseProps) {\n    super(scope, id);\n    this.kustoDbProps = kustoDbProps;\n    this.kustoProps = kustoDbProps.kusto.kustoProps;\n    this.rg = kustoDbProps.kusto.kustoProps.resourceGroup.name;\n\n    const kustoDatabase = new KustoDatabase(\n      this,\n      `kusto-db-${this.kustoDbProps.name}`,\n      {\n        name: this.kustoDbProps.name,\n        location: kustoDbProps.kusto.kustoProps.resourceGroup.location,\n        resourceGroupName: kustoDbProps.kusto.kustoProps.resourceGroup.name,\n        clusterName: kustoDbProps.kusto.kustoProps.name,\n      },\n    );\n\n    if (this.kustoDbProps.hotCachePeriod) {\n      kustoDatabase.addOverride(\n        \"hot_cache_period\",\n        this.kustoDbProps.hotCachePeriod,\n      );\n    }\n    if (this.kustoDbProps.softDeletePeriod) {\n      kustoDatabase.addOverride(\n        \"soft_delete_period\",\n        this.kustoDbProps.softDeletePeriod,\n      );\n    }\n\n    // Outputs\n    this.id = kustoDatabase.id;\n    const cdktfTerraformOutputKustoDbId = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: this.id,\n      },\n    );\n    cdktfTerraformOutputKustoDbId.overrideLogicalId(\"id\");\n  }\n\n  public addPermission(kustoDatabaseAccessProps: DatabaseAccessProps) {\n    new KustoDatabasePrincipalAssignment(\n      this,\n      `kusto-db-${kustoDatabaseAccessProps.name}-access`,\n      {\n        name: kustoDatabaseAccessProps.name,\n        resourceGroupName: this.rg,\n        clusterName: this.kustoProps.name,\n        databaseName: this.kustoDbProps.name,\n        tenantId: kustoDatabaseAccessProps.tenantId,\n        principalId: kustoDatabaseAccessProps.principalId,\n        principalType: kustoDatabaseAccessProps.principalType,\n        role: kustoDatabaseAccessProps.role,\n      },\n    );\n  }\n\n  public addTable(tableName: string, tableSchema: TableSchemaProps[]) {\n    const schemaContent = tableSchema\n      .map((column) => {\n        return `${column.columnName}:${column.columnType}`;\n      })\n      .join(\", \");\n    const scriptContent = `.create table ${tableName} ( ${schemaContent} )`;\n\n    new KustoScript(\n      this,\n      `kusto-db-${this.kustoDbProps.name}-table-${tableName}`,\n      {\n        name: tableName,\n        databaseId: this.id,\n        scriptContent: scriptContent,\n        continueOnErrorsEnabled: false,\n        forceAnUpdateWhenValueChanged: Md5.hashStr(scriptContent),\n      },\n    );\n  }\n\n  public addScript(scriptName: string, scriptContent: string) {\n    new KustoScript(\n      this,\n      `kusto-db-${this.kustoDbProps.name}-script-${scriptName}`,\n      {\n        name: `script-${scriptName}`,\n        databaseId: this.id,\n        scriptContent: scriptContent,\n        continueOnErrorsEnabled: false,\n        forceAnUpdateWhenValueChanged: Md5.hashStr(scriptContent),\n      },\n    );\n  }\n}\n"]}
179
+ Database[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_kusto.Database", version: "0.0.3-pre.7" };
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"database.js","sourceRoot":"","sources":["../../../src/azure-kusto/lib/database.ts"],"names":[],"mappings":";;;;;AAAA,+EAA2E;AAC3E,yHAAmH;AACnH,2EAAuE;AACvE,+BAA+B;AAC/B,2CAAuC;AACvC,mCAA6B;AAqD7B,MAAa,QAAS,SAAQ,sBAAS;IAMrC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA+BG;IACH,YAAY,KAAgB,EAAE,EAAU,EAAE,YAA2B;QACnE,KAAK,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;QACjB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAC;QACjC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC;QAChD,IAAI,CAAC,EAAE,GAAG,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI,CAAC;QAE3D,MAAM,aAAa,GAAG,IAAI,8BAAa,CACrC,IAAI,EACJ,YAAY,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,EACpC;YACE,IAAI,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI;YAC5B,QAAQ,EAAE,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,QAAQ;YAC9D,iBAAiB,EAAE,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,IAAI;YACnE,WAAW,EAAE,YAAY,CAAC,KAAK,CAAC,UAAU,CAAC,IAAI;SAChD,CACF,CAAC;QAEF,IAAI,IAAI,CAAC,YAAY,CAAC,cAAc,EAAE;YACpC,aAAa,CAAC,WAAW,CACvB,kBAAkB,EAClB,IAAI,CAAC,YAAY,CAAC,cAAc,CACjC,CAAC;SACH;QACD,IAAI,IAAI,CAAC,YAAY,CAAC,gBAAgB,EAAE;YACtC,aAAa,CAAC,WAAW,CACvB,oBAAoB,EACpB,IAAI,CAAC,YAAY,CAAC,gBAAgB,CACnC,CAAC;SACH;QAED,UAAU;QACV,IAAI,CAAC,EAAE,GAAG,aAAa,CAAC,EAAE,CAAC;QAC3B,MAAM,6BAA6B,GAAG,IAAI,KAAK,CAAC,eAAe,CAC7D,IAAI,EACJ,IAAI,EACJ;YACE,KAAK,EAAE,IAAI,CAAC,EAAE;SACf,CACF,CAAC;QACF,6BAA6B,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;IACxD,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA4BG;IACI,aAAa,CAAC,wBAA6C;QAChE,IAAI,sEAAgC,CAClC,IAAI,EACJ,YAAY,wBAAwB,CAAC,IAAI,SAAS,EAClD;YACE,IAAI,EAAE,wBAAwB,CAAC,IAAI;YACnC,iBAAiB,EAAE,IAAI,CAAC,EAAE;YAC1B,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI;YACjC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI;YACpC,QAAQ,EAAE,wBAAwB,CAAC,QAAQ;YAC3C,WAAW,EAAE,wBAAwB,CAAC,WAAW;YACjD,aAAa,EAAE,wBAAwB,CAAC,aAAa;YACrD,IAAI,EAAE,wBAAwB,CAAC,IAAI;SACpC,CACF,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;;;;;;OAoBG;IACI,QAAQ,CAAC,SAAiB,EAAE,WAA+B;QAChE,MAAM,aAAa,GAAG,WAAW;aAC9B,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE;YACd,OAAO,GAAG,MAAM,CAAC,UAAU,IAAI,MAAM,CAAC,UAAU,EAAE,CAAC;QACrD,CAAC,CAAC;aACD,IAAI,CAAC,IAAI,CAAC,CAAC;QACd,MAAM,aAAa,GAAG,iBAAiB,SAAS,MAAM,aAAa,IAAI,CAAC;QAExE,IAAI,0BAAW,CACb,IAAI,EACJ,YAAY,IAAI,CAAC,YAAY,CAAC,IAAI,UAAU,SAAS,EAAE,EACvD;YACE,IAAI,EAAE,SAAS;YACf,UAAU,EAAE,IAAI,CAAC,EAAE;YACnB,aAAa,EAAE,aAAa;YAC5B,uBAAuB,EAAE,KAAK;YAC9B,6BAA6B,EAAE,YAAG,CAAC,OAAO,CAAC,aAAa,CAAC;SAC1D,CACF,CAAC;IACJ,CAAC;IAED;;;;;;;;;;;;;;;;;;;;OAoBG;IACI,SAAS,CAAC,UAAkB,EAAE,aAAqB;QACxD,IAAI,0BAAW,CACb,IAAI,EACJ,YAAY,IAAI,CAAC,YAAY,CAAC,IAAI,WAAW,UAAU,EAAE,EACzD;YACE,IAAI,EAAE,UAAU,UAAU,EAAE;YAC5B,UAAU,EAAE,IAAI,CAAC,EAAE;YACnB,aAAa,EAAE,aAAa;YAC5B,uBAAuB,EAAE,KAAK;YAC9B,6BAA6B,EAAE,YAAG,CAAC,OAAO,CAAC,aAAa,CAAC;SAC1D,CACF,CAAC;IACJ,CAAC;;AAzMH,4BA0MC","sourcesContent":["import { KustoDatabase } from \"@cdktf/provider-azurerm/lib/kusto-database\";\nimport { KustoDatabasePrincipalAssignment } from \"@cdktf/provider-azurerm/lib/kusto-database-principal-assignment\";\nimport { KustoScript } from \"@cdktf/provider-azurerm/lib/kusto-script\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { Md5 } from \"ts-md5\";\nimport { ClusterProps, Cluster } from \"./cluster\";\n\nexport interface DatabaseProps {\n  /**\n   * The Azure Kusto cluster to which this database belongs.\n   */\n  readonly kusto: Cluster;\n  /**\n   * The name of the Kusto Database to create.\n   */\n  readonly name: string;\n  /**\n   * The time the data that should be kept in cache for fast queries as ISO 8601 timespan.\n   * Default is unlimited.\n   */\n  readonly hotCachePeriod?: string;\n  /**\n   * The time the data should be kept before it stops being accessible to queries as ISO 8601 timespan.\n   * Default is unlimited.\n   */\n  readonly softDeletePeriod?: string;\n}\n\nexport interface DatabaseAccessProps {\n  /**\n   * The name of the kusto principal assignment.\n   */\n  readonly name: string;\n  /**\n   * The tenant id in which the principal resides.\n   */\n  readonly tenantId: string;\n  /**\n   * The object id of the principal to assign to Kusto Database.\n   */\n  readonly principalId: string;\n  /**\n   * The type of the principal. Valid values include App, Group, User.\n   */\n  readonly principalType: string;\n  /**\n   * The database role assigned to the principal.\n   * Valid values include Admin, Ingestor, Monitor, UnrestrictedViewer, User and Viewer.\n   */\n  readonly role: string;\n}\n\nexport interface TableSchemaProps {\n  readonly columnName: string;\n  readonly columnType: string;\n}\n\nexport class Database extends Construct {\n  public readonly kustoDbProps: DatabaseProps;\n  public readonly kustoProps: ClusterProps;\n  public readonly rg: string;\n  public readonly id: string;\n\n  /**\n   * Represents a Kusto Database within an Azure Kusto Cluster.\n   *\n   * This class is responsible for the creation and management of a database in Azure Data Explorer (Kusto),\n   * which stores data tables and provides a query engine. A Kusto database is a logical group of tables\n   * and is associated with a specific Kusto cluster. The database supports configurations such as\n   * hot cache period and soft delete period to optimize performance and data retention according to\n   * specific workload requirements.\n   *\n   * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.\n   * @param id - The unique identifier for this instance of the Kusto database.\n   * @param kustoDbProps - The properties required to configure the Kusto database. These include:\n   *                       - `kusto`: Reference to the Kusto cluster to which the database will belong.\n   *                       - `name`: The name of the database to be created within the Kusto cluster.\n   *                       - `hotCachePeriod`: Optional. Specifies the duration that data should be kept in cache for faster query performance.\n   *                                           Expressed in ISO 8601 duration format.\n   *                       - `softDeletePeriod`: Optional. Specifies the duration that data should be retained before it stops being accessible.\n   *                                             Expressed in ISO 8601 duration format.\n   *\n   * Example usage:\n   * ```typescript\n   * const myDatabase = new Database(this, 'MyKustoDatabase', {\n   *   kusto: myKustoCluster,\n   *   name: 'AnalyticsDB',\n   *   hotCachePeriod: 'P30D',  // 30 days\n   *   softDeletePeriod: 'P365D' // 365 days\n   * });\n   * ```\n   *\n   * This class sets up the database configurations and integrates it within the specified Kusto cluster,\n   * providing capabilities to manage and query large datasets effectively.\n   */\n  constructor(scope: Construct, id: string, kustoDbProps: DatabaseProps) {\n    super(scope, id);\n    this.kustoDbProps = kustoDbProps;\n    this.kustoProps = kustoDbProps.kusto.kustoProps;\n    this.rg = kustoDbProps.kusto.kustoProps.resourceGroup.name;\n\n    const kustoDatabase = new KustoDatabase(\n      this,\n      `kusto-db-${this.kustoDbProps.name}`,\n      {\n        name: this.kustoDbProps.name,\n        location: kustoDbProps.kusto.kustoProps.resourceGroup.location,\n        resourceGroupName: kustoDbProps.kusto.kustoProps.resourceGroup.name,\n        clusterName: kustoDbProps.kusto.kustoProps.name,\n      },\n    );\n\n    if (this.kustoDbProps.hotCachePeriod) {\n      kustoDatabase.addOverride(\n        \"hot_cache_period\",\n        this.kustoDbProps.hotCachePeriod,\n      );\n    }\n    if (this.kustoDbProps.softDeletePeriod) {\n      kustoDatabase.addOverride(\n        \"soft_delete_period\",\n        this.kustoDbProps.softDeletePeriod,\n      );\n    }\n\n    // Outputs\n    this.id = kustoDatabase.id;\n    const cdktfTerraformOutputKustoDbId = new cdktf.TerraformOutput(\n      this,\n      \"id\",\n      {\n        value: this.id,\n      },\n    );\n    cdktfTerraformOutputKustoDbId.overrideLogicalId(\"id\");\n  }\n\n  /**\n   * Adds a database principal assignment in the Kusto cluster, assigning specified access rights to a principal.\n   *\n   * This method is used to grant access permissions to a specific user, group, or service principal within an Azure Active Directory.\n   * These permissions determine the level of access that the principal has over the Kusto database, such as viewing, ingesting, or managing data.\n   * The assignment is made by creating a KustoDatabasePrincipalAssignment resource, specifying the principal details and the type of role\n   * they should assume.\n   *\n   * @param kustoDatabaseAccessProps - The properties defining the principal assignment. This includes:\n   *   - `name`: A unique name identifying this principal assignment.\n   *   - `tenantId`: The Azure Active Directory tenant ID where the principal resides.\n   *   - `principalId`: The object ID of the principal (user, group, or service principal) in Azure AD.\n   *   - `principalType`: The type of principal (e.g., User, Group, App).\n   *   - `role`: The database role assigned to the principal. Roles can include Admin, User, Viewer, among others.\n   *\n   * Example usage:\n   * ```typescript\n   * myDatabase.addPermission({\n   *   name: 'DataScienceTeamAccess',\n   *   tenantId: 'tenant-id',\n   *   principalId: 'principal-id',\n   *   principalType: 'Group',\n   *   role: 'Viewer'\n   * });\n   * ```\n   * This method creates a new principal assignment, enabling specified access controls for the principal\n   * on the Kusto database based on the role assigned. It is crucial for managing security and access\n   * governance within the Kusto environment.\n   */\n  public addPermission(kustoDatabaseAccessProps: DatabaseAccessProps) {\n    new KustoDatabasePrincipalAssignment(\n      this,\n      `kusto-db-${kustoDatabaseAccessProps.name}-access`,\n      {\n        name: kustoDatabaseAccessProps.name,\n        resourceGroupName: this.rg,\n        clusterName: this.kustoProps.name,\n        databaseName: this.kustoDbProps.name,\n        tenantId: kustoDatabaseAccessProps.tenantId,\n        principalId: kustoDatabaseAccessProps.principalId,\n        principalType: kustoDatabaseAccessProps.principalType,\n        role: kustoDatabaseAccessProps.role,\n      },\n    );\n  }\n\n  /**\n   * Adds a new table to an existing Azure Kusto database.\n   *\n   * This method creates a table within the specified Kusto database using a given schema. Tables in Kusto store structured data with\n   * defined columns and types, which are crucial for storing and querying large datasets efficiently. The method constructs a Kusto\n   * Data Explorer control command to create the table and then executes this command within the context of the database.\n   *\n   * @param tableName - The name of the table to create, which must be unique within the database.\n   * @param tableSchema - An array of schema properties defining the columns of the table, including column names and their data types.\n   *\n   * Example usage:\n   * ```typescript\n   * myDatabase.addTable('SalesData', [\n   *   { columnName: 'TransactionId', columnType: 'int' },\n   *   { columnName: 'TransactionDate', columnType: 'datetime' },\n   *   { columnName: 'Amount', columnType: 'real' }\n   * ]);\n   * ```\n   * This method constructs the command to create the table and applies it directly within the Kusto database,\n   * ensuring the table is ready for data ingestion and querying.\n   */\n  public addTable(tableName: string, tableSchema: TableSchemaProps[]) {\n    const schemaContent = tableSchema\n      .map((column) => {\n        return `${column.columnName}:${column.columnType}`;\n      })\n      .join(\", \");\n    const scriptContent = `.create table ${tableName} ( ${schemaContent} )`;\n\n    new KustoScript(\n      this,\n      `kusto-db-${this.kustoDbProps.name}-table-${tableName}`,\n      {\n        name: tableName,\n        databaseId: this.id,\n        scriptContent: scriptContent,\n        continueOnErrorsEnabled: false,\n        forceAnUpdateWhenValueChanged: Md5.hashStr(scriptContent),\n      },\n    );\n  }\n\n  /**\n   * Adds and executes a control command or script within the Kusto database.\n   *\n   * This method facilitates the execution of Kusto Query Language (KQL) scripts or control commands within the specified\n   * Kusto database. Scripts can perform a variety of functions, from schema modifications, like adding new tables or altering\n   * existing ones, to data management operations, such as data ingestion or cleanup tasks. Each script is executed as a\n   * KustoScript resource, which ensures that the script is applied correctly and atomically to the database.\n   *\n   * @param scriptName - A unique name for the script, which helps in identifying the script resource within the deployment.\n   * @param scriptContent - The KQL script or control command to be executed. This should be a valid KQL command string.\n   *\n   * Example usage:\n   * ```typescript\n   * myDatabase.addScript('InitializeSalesTable', `\n   *   .create table SalesData (TransactionId: int, TransactionDate: datetime, Amount: real)\n   *   .alter-merge table SalesData policy retentionsoftdelete = 365d\n   * `);\n   * ```\n   * This method will create a `KustoScript` resource that encapsulates the command, ensuring it is executed against the\n   * database, and is tracked as part of the resource management within Azure.\n   */\n  public addScript(scriptName: string, scriptContent: string) {\n    new KustoScript(\n      this,\n      `kusto-db-${this.kustoDbProps.name}-script-${scriptName}`,\n      {\n        name: `script-${scriptName}`,\n        databaseId: this.id,\n        scriptContent: scriptContent,\n        continueOnErrorsEnabled: false,\n        forceAnUpdateWhenValueChanged: Md5.hashStr(scriptContent),\n      },\n    );\n  }\n}\n"]}
@@ -112,5 +112,52 @@ export declare class Workspace extends AzureResourceWithAlert {
112
112
  readonly props: WorkspaceProps;
113
113
  resourceGroup: ResourceGroup;
114
114
  id: string;
115
+ /**
116
+ * Represents an Azure Log Analytics Workspace.
117
+ *
118
+ * This class is responsible for the creation and configuration of a Log Analytics Workspace in Azure. A Log Analytics Workspace
119
+ * is a unique environment for Azure Monitor data, where data is collected, aggregated, and serves as the administrative boundary.
120
+ * Within a workspace, data is collected from various sources and is used for analysis, visualization, and alerting. Configurations
121
+ * can include data export rules, saved queries, and custom functions to enhance data analytics capabilities.
122
+ *
123
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
124
+ * @param id - The unique identifier for this instance of the Log Analytics workspace.
125
+ * @param props - The properties required to configure the Log Analytics workspace, as defined in the WorkspaceProps interface. These include:
126
+ * - `location`: The Azure region where the workspace will be deployed.
127
+ * - `name`: The name of the workspace, which must be globally unique.
128
+ * - `resourceGroup`: The Azure Resource Group under which the workspace is deployed.
129
+ * - `sku`: Optional. The SKU of the workspace, affecting pricing and features.
130
+ * - `retention`: Optional. The number of days data will be retained in the workspace.
131
+ * - `tags`: Optional. Tags to assign to the workspace for organizational purposes.
132
+ * - `dataExport`: Optional. Configurations for exporting data to other Azure resources.
133
+ * - `functions`: Optional. Custom functions defined within the workspace for query operations.
134
+ * - `queries`: Optional. Saved queries that can be used for data analysis or visualizations.
135
+ *
136
+ * Example usage:
137
+ * ```typescript
138
+ * new Workspace(this, 'MyLogAnalyticsWorkspace', {
139
+ * location: 'East US',
140
+ * name: 'myWorkspace',
141
+ * resourceGroup: myResourceGroup,
142
+ * sku: 'PerGB2018',
143
+ * retention: 60,
144
+ * tags: { department: 'IT' },
145
+ * functions: [{
146
+ * name: 'ErrorCount',
147
+ * displayName: 'Error Count',
148
+ * query: 'AzureActivity | summarize count() by bin(timestamp, 1h), type',
149
+ * functionAlias: 'error_count',
150
+ * functionParameters: 'timestamp, type'
151
+ * }],
152
+ * queries: [{
153
+ * name: 'HighCPUUsage',
154
+ * category: 'Performance',
155
+ * displayName: 'High CPU Usage',
156
+ * query: 'Perf | where CounterName == "% Processor Time" and CounterValue > 80'
157
+ * }]
158
+ * });
159
+ * ```
160
+ * This class sets up the workspace and applies configurations, providing a centralized environment for monitoring and analytics.
161
+ */
115
162
  constructor(scope: Construct, id: string, props: WorkspaceProps);
116
163
  }
@@ -9,6 +9,53 @@ const log_analytics_workspace_1 = require("@cdktf/provider-azurerm/lib/log-analy
9
9
  const cdktf = require("cdktf");
10
10
  const lib_1 = require("../../core-azure/lib");
11
11
  class Workspace extends lib_1.AzureResourceWithAlert {
12
+ /**
13
+ * Represents an Azure Log Analytics Workspace.
14
+ *
15
+ * This class is responsible for the creation and configuration of a Log Analytics Workspace in Azure. A Log Analytics Workspace
16
+ * is a unique environment for Azure Monitor data, where data is collected, aggregated, and serves as the administrative boundary.
17
+ * Within a workspace, data is collected from various sources and is used for analysis, visualization, and alerting. Configurations
18
+ * can include data export rules, saved queries, and custom functions to enhance data analytics capabilities.
19
+ *
20
+ * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.
21
+ * @param id - The unique identifier for this instance of the Log Analytics workspace.
22
+ * @param props - The properties required to configure the Log Analytics workspace, as defined in the WorkspaceProps interface. These include:
23
+ * - `location`: The Azure region where the workspace will be deployed.
24
+ * - `name`: The name of the workspace, which must be globally unique.
25
+ * - `resourceGroup`: The Azure Resource Group under which the workspace is deployed.
26
+ * - `sku`: Optional. The SKU of the workspace, affecting pricing and features.
27
+ * - `retention`: Optional. The number of days data will be retained in the workspace.
28
+ * - `tags`: Optional. Tags to assign to the workspace for organizational purposes.
29
+ * - `dataExport`: Optional. Configurations for exporting data to other Azure resources.
30
+ * - `functions`: Optional. Custom functions defined within the workspace for query operations.
31
+ * - `queries`: Optional. Saved queries that can be used for data analysis or visualizations.
32
+ *
33
+ * Example usage:
34
+ * ```typescript
35
+ * new Workspace(this, 'MyLogAnalyticsWorkspace', {
36
+ * location: 'East US',
37
+ * name: 'myWorkspace',
38
+ * resourceGroup: myResourceGroup,
39
+ * sku: 'PerGB2018',
40
+ * retention: 60,
41
+ * tags: { department: 'IT' },
42
+ * functions: [{
43
+ * name: 'ErrorCount',
44
+ * displayName: 'Error Count',
45
+ * query: 'AzureActivity | summarize count() by bin(timestamp, 1h), type',
46
+ * functionAlias: 'error_count',
47
+ * functionParameters: 'timestamp, type'
48
+ * }],
49
+ * queries: [{
50
+ * name: 'HighCPUUsage',
51
+ * category: 'Performance',
52
+ * displayName: 'High CPU Usage',
53
+ * query: 'Perf | where CounterName == "% Processor Time" and CounterValue > 80'
54
+ * }]
55
+ * });
56
+ * ```
57
+ * This class sets up the workspace and applies configurations, providing a centralized environment for monitoring and analytics.
58
+ */
12
59
  constructor(scope, id, props) {
13
60
  super(scope, id);
14
61
  this.props = props;
@@ -75,5 +122,5 @@ class Workspace extends lib_1.AzureResourceWithAlert {
75
122
  }
76
123
  exports.Workspace = Workspace;
77
124
  _a = JSII_RTTI_SYMBOL_1;
78
- Workspace[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_loganalytics.Workspace", version: "0.0.3-pre.6" };
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace.js","sourceRoot":"","sources":["../../../src/azure-loganalytics/lib/workspace.ts"],"names":[],"mappings":"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","sourcesContent":["import { LogAnalyticsDataExportRule } from \"@cdktf/provider-azurerm/lib/log-analytics-data-export-rule\";\nimport { LogAnalyticsSavedSearch } from \"@cdktf/provider-azurerm/lib/log-analytics-saved-search\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { AzureResourceWithAlert } from \"../../core-azure/lib\";\n\n/**\n * Properties for defining a data export in a Log Analytics Workspace.\n */\nexport interface DataExport {\n  /**\n   * The name of the data export.\n   */\n  readonly name: string;\n\n  /**\n   * The ID of the destination resource for the export.\n   */\n  readonly exportDestinationId: string;\n\n  /**\n   * An array of table names to be included in the data export.\n   */\n  readonly tableNames: string[];\n\n  /**\n   * Indicates whether the data export is enabled.\n   */\n  readonly enabled: boolean;\n}\n\n/**\n * Properties for defining a Log Analytics function.\n */\nexport interface LAFunctions {\n  /**\n   * The name of the function.\n   */\n  readonly name: string;\n\n  /**\n   * The display name for the function.\n   */\n  readonly displayName: string;\n\n  /**\n   * The query that the function will execute.\n   */\n  readonly query: string;\n\n  /**\n   * The alias to be used for the function.\n   */\n  readonly functionAlias: string;\n\n  /**\n   * A list of parameters for the function.\n   */\n  readonly functionParameters: string[];\n}\n\n/**\n * Properties for defining a saved query in a Log Analytics Workspace.\n */\nexport interface Queries {\n  /**\n   * The name of the saved query.\n   */\n  readonly name: string;\n\n  /**\n   * The category of the saved query.\n   */\n  readonly category: string;\n\n  /**\n   * The display name for the saved query.\n   */\n  readonly displayName: string;\n\n  /**\n   * The query string.\n   */\n  readonly query: string;\n}\n\nexport interface WorkspaceProps {\n  /**\n   * The Azure Region to deploy.\n   */\n  readonly location: string;\n  /**\n   * The name of the Log Analytics Workspace.\n   */\n  readonly name: string;\n  /**\n   * The name of the Azure Resource Group.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The SKU of the Log Analytics Workspace.\n   */\n  readonly sku?: string;\n  /**\n   * The number of days of retention. Default is 30.\n   */\n  readonly retention?: number;\n  /**\n   * The tags to assign to the Resource Group.\n   */\n  readonly tags?: { [key: string]: string };\n  /**\n   * Create a DataExport for the Log Analytics Workspace.\n   */\n  readonly dataExport?: DataExport[];\n  /**\n   * A collection of Log Analytic functions.\n   */\n  readonly functions?: LAFunctions[];\n  /**\n   * A collection of log saved log analytics queries.\n   */\n  readonly queries?: Queries[];\n}\n\nexport class Workspace extends AzureResourceWithAlert {\n  readonly props: WorkspaceProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n\n  constructor(scope: Construct, id: string, props: WorkspaceProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Provide default values\n    const sku = props.sku ?? \"PerGB2018\";\n    const retention = props.retention ?? 30;\n\n    const azurermLogAnalyticsWorkspaceLogAnalytics = new LogAnalyticsWorkspace(\n      this,\n      \"log_analytics\",\n      {\n        location: props.location,\n        name: props.name,\n        resourceGroupName: props.resourceGroup.name,\n        retentionInDays: retention,\n        sku: sku,\n        tags: props.tags,\n      },\n    );\n\n    this.id = azurermLogAnalyticsWorkspaceLogAnalytics.id;\n\n    props.dataExport?.forEach((v, k) => {\n      new LogAnalyticsDataExportRule(this, `export-${k}`, {\n        destinationResourceId: v.exportDestinationId,\n        enabled: v.enabled,\n        name: v.name,\n        resourceGroupName: props.resourceGroup.name,\n        tableNames: v.tableNames,\n        workspaceResourceId: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n      });\n    });\n\n    props.functions?.forEach((v, k) => {\n      new LogAnalyticsSavedSearch(this, `function-${k}`, {\n        category: \"Function\",\n        displayName: v.displayName,\n        functionAlias: v.functionAlias,\n        functionParameters: v.functionParameters,\n        logAnalyticsWorkspaceId: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n        name: v.name,\n        query: v.query,\n      });\n    });\n\n    props.queries?.forEach((v, k) => {\n      new LogAnalyticsSavedSearch(this, `function-${k}`, {\n        category: v.category,\n        displayName: v.displayName,\n        functionParameters: [],\n        logAnalyticsWorkspaceId: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n        name: v.name,\n        query: v.query,\n      });\n    });\n\n    // Terraform Outputs\n    const cdktfTerraformOutputLaID = new cdktf.TerraformOutput(\n      this,\n      \"log_analytics_id\",\n      {\n        value: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n      },\n    );\n    const cdktfTerraformOutputLaSharedKey = new cdktf.TerraformOutput(\n      this,\n      \"log_analytics_primary_shared_key\",\n      {\n        value: azurermLogAnalyticsWorkspaceLogAnalytics.primarySharedKey,\n        sensitive: true,\n      },\n    );\n    const cdktfTerraformOutputLaWorkspaceID = new cdktf.TerraformOutput(\n      this,\n      \"log_analytics_workspace_id\",\n      {\n        value: azurermLogAnalyticsWorkspaceLogAnalytics.workspaceId,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputLaID.overrideLogicalId(\"log_analytics_id\");\n    cdktfTerraformOutputLaSharedKey.overrideLogicalId(\n      \"log_analytics_primary_shared_key\",\n    );\n    cdktfTerraformOutputLaWorkspaceID.overrideLogicalId(\n      \"log_analytics_workspace_id\",\n    );\n  }\n}\n"]}
125
+ Workspace[_a] = { fqn: "@microsoft/terraform-cdk-constructs.azure_loganalytics.Workspace", version: "0.0.3-pre.7" };
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workspace.js","sourceRoot":"","sources":["../../../src/azure-loganalytics/lib/workspace.ts"],"names":[],"mappings":"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","sourcesContent":["import { LogAnalyticsDataExportRule } from \"@cdktf/provider-azurerm/lib/log-analytics-data-export-rule\";\nimport { LogAnalyticsSavedSearch } from \"@cdktf/provider-azurerm/lib/log-analytics-saved-search\";\nimport { LogAnalyticsWorkspace } from \"@cdktf/provider-azurerm/lib/log-analytics-workspace\";\nimport { ResourceGroup } from \"@cdktf/provider-azurerm/lib/resource-group\";\nimport * as cdktf from \"cdktf\";\nimport { Construct } from \"constructs\";\nimport { AzureResourceWithAlert } from \"../../core-azure/lib\";\n\n/**\n * Properties for defining a data export in a Log Analytics Workspace.\n */\nexport interface DataExport {\n  /**\n   * The name of the data export.\n   */\n  readonly name: string;\n\n  /**\n   * The ID of the destination resource for the export.\n   */\n  readonly exportDestinationId: string;\n\n  /**\n   * An array of table names to be included in the data export.\n   */\n  readonly tableNames: string[];\n\n  /**\n   * Indicates whether the data export is enabled.\n   */\n  readonly enabled: boolean;\n}\n\n/**\n * Properties for defining a Log Analytics function.\n */\nexport interface LAFunctions {\n  /**\n   * The name of the function.\n   */\n  readonly name: string;\n\n  /**\n   * The display name for the function.\n   */\n  readonly displayName: string;\n\n  /**\n   * The query that the function will execute.\n   */\n  readonly query: string;\n\n  /**\n   * The alias to be used for the function.\n   */\n  readonly functionAlias: string;\n\n  /**\n   * A list of parameters for the function.\n   */\n  readonly functionParameters: string[];\n}\n\n/**\n * Properties for defining a saved query in a Log Analytics Workspace.\n */\nexport interface Queries {\n  /**\n   * The name of the saved query.\n   */\n  readonly name: string;\n\n  /**\n   * The category of the saved query.\n   */\n  readonly category: string;\n\n  /**\n   * The display name for the saved query.\n   */\n  readonly displayName: string;\n\n  /**\n   * The query string.\n   */\n  readonly query: string;\n}\n\nexport interface WorkspaceProps {\n  /**\n   * The Azure Region to deploy.\n   */\n  readonly location: string;\n  /**\n   * The name of the Log Analytics Workspace.\n   */\n  readonly name: string;\n  /**\n   * The name of the Azure Resource Group.\n   */\n  readonly resourceGroup: ResourceGroup;\n  /**\n   * The SKU of the Log Analytics Workspace.\n   */\n  readonly sku?: string;\n  /**\n   * The number of days of retention. Default is 30.\n   */\n  readonly retention?: number;\n  /**\n   * The tags to assign to the Resource Group.\n   */\n  readonly tags?: { [key: string]: string };\n  /**\n   * Create a DataExport for the Log Analytics Workspace.\n   */\n  readonly dataExport?: DataExport[];\n  /**\n   * A collection of Log Analytic functions.\n   */\n  readonly functions?: LAFunctions[];\n  /**\n   * A collection of log saved log analytics queries.\n   */\n  readonly queries?: Queries[];\n}\n\nexport class Workspace extends AzureResourceWithAlert {\n  readonly props: WorkspaceProps;\n  public resourceGroup: ResourceGroup;\n  public id: string;\n\n  /**\n   * Represents an Azure Log Analytics Workspace.\n   *\n   * This class is responsible for the creation and configuration of a Log Analytics Workspace in Azure. A Log Analytics Workspace\n   * is a unique environment for Azure Monitor data, where data is collected, aggregated, and serves as the administrative boundary.\n   * Within a workspace, data is collected from various sources and is used for analysis, visualization, and alerting. Configurations\n   * can include data export rules, saved queries, and custom functions to enhance data analytics capabilities.\n   *\n   * @param scope - The scope in which to define this construct, typically representing the Cloud Development Kit (CDK) stack.\n   * @param id - The unique identifier for this instance of the Log Analytics workspace.\n   * @param props - The properties required to configure the Log Analytics workspace, as defined in the WorkspaceProps interface. These include:\n   *                - `location`: The Azure region where the workspace will be deployed.\n   *                - `name`: The name of the workspace, which must be globally unique.\n   *                - `resourceGroup`: The Azure Resource Group under which the workspace is deployed.\n   *                - `sku`: Optional. The SKU of the workspace, affecting pricing and features.\n   *                - `retention`: Optional. The number of days data will be retained in the workspace.\n   *                - `tags`: Optional. Tags to assign to the workspace for organizational purposes.\n   *                - `dataExport`: Optional. Configurations for exporting data to other Azure resources.\n   *                - `functions`: Optional. Custom functions defined within the workspace for query operations.\n   *                - `queries`: Optional. Saved queries that can be used for data analysis or visualizations.\n   *\n   * Example usage:\n   * ```typescript\n   * new Workspace(this, 'MyLogAnalyticsWorkspace', {\n   *   location: 'East US',\n   *   name: 'myWorkspace',\n   *   resourceGroup: myResourceGroup,\n   *   sku: 'PerGB2018',\n   *   retention: 60,\n   *   tags: { department: 'IT' },\n   *   functions: [{\n   *     name: 'ErrorCount',\n   *     displayName: 'Error Count',\n   *     query: 'AzureActivity | summarize count() by bin(timestamp, 1h), type',\n   *     functionAlias: 'error_count',\n   *     functionParameters: 'timestamp, type'\n   *   }],\n   *   queries: [{\n   *     name: 'HighCPUUsage',\n   *     category: 'Performance',\n   *     displayName: 'High CPU Usage',\n   *     query: 'Perf | where CounterName == \"% Processor Time\" and CounterValue > 80'\n   *   }]\n   * });\n   * ```\n   * This class sets up the workspace and applies configurations, providing a centralized environment for monitoring and analytics.\n   */\n  constructor(scope: Construct, id: string, props: WorkspaceProps) {\n    super(scope, id);\n\n    this.props = props;\n    this.resourceGroup = props.resourceGroup;\n\n    // Provide default values\n    const sku = props.sku ?? \"PerGB2018\";\n    const retention = props.retention ?? 30;\n\n    const azurermLogAnalyticsWorkspaceLogAnalytics = new LogAnalyticsWorkspace(\n      this,\n      \"log_analytics\",\n      {\n        location: props.location,\n        name: props.name,\n        resourceGroupName: props.resourceGroup.name,\n        retentionInDays: retention,\n        sku: sku,\n        tags: props.tags,\n      },\n    );\n\n    this.id = azurermLogAnalyticsWorkspaceLogAnalytics.id;\n\n    props.dataExport?.forEach((v, k) => {\n      new LogAnalyticsDataExportRule(this, `export-${k}`, {\n        destinationResourceId: v.exportDestinationId,\n        enabled: v.enabled,\n        name: v.name,\n        resourceGroupName: props.resourceGroup.name,\n        tableNames: v.tableNames,\n        workspaceResourceId: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n      });\n    });\n\n    props.functions?.forEach((v, k) => {\n      new LogAnalyticsSavedSearch(this, `function-${k}`, {\n        category: \"Function\",\n        displayName: v.displayName,\n        functionAlias: v.functionAlias,\n        functionParameters: v.functionParameters,\n        logAnalyticsWorkspaceId: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n        name: v.name,\n        query: v.query,\n      });\n    });\n\n    props.queries?.forEach((v, k) => {\n      new LogAnalyticsSavedSearch(this, `function-${k}`, {\n        category: v.category,\n        displayName: v.displayName,\n        functionParameters: [],\n        logAnalyticsWorkspaceId: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n        name: v.name,\n        query: v.query,\n      });\n    });\n\n    // Terraform Outputs\n    const cdktfTerraformOutputLaID = new cdktf.TerraformOutput(\n      this,\n      \"log_analytics_id\",\n      {\n        value: azurermLogAnalyticsWorkspaceLogAnalytics.id,\n      },\n    );\n    const cdktfTerraformOutputLaSharedKey = new cdktf.TerraformOutput(\n      this,\n      \"log_analytics_primary_shared_key\",\n      {\n        value: azurermLogAnalyticsWorkspaceLogAnalytics.primarySharedKey,\n        sensitive: true,\n      },\n    );\n    const cdktfTerraformOutputLaWorkspaceID = new cdktf.TerraformOutput(\n      this,\n      \"log_analytics_workspace_id\",\n      {\n        value: azurermLogAnalyticsWorkspaceLogAnalytics.workspaceId,\n      },\n    );\n\n    /*This allows the Terraform resource name to match the original name. You can remove the call if you don't need them to match.*/\n    cdktfTerraformOutputLaID.overrideLogicalId(\"log_analytics_id\");\n    cdktfTerraformOutputLaSharedKey.overrideLogicalId(\n      \"log_analytics_primary_shared_key\",\n    );\n    cdktfTerraformOutputLaWorkspaceID.overrideLogicalId(\n      \"log_analytics_workspace_id\",\n    );\n  }\n}\n"]}