{
  "description": "Generator information:\n- Generated from: /azure-kusto/resource-manager/Microsoft.Kusto/stable/2023-08-15/kusto.json\n- ARM URI: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Kusto/clusters/{clusterName}",
  "properties": {
    "apiVersion": {
      "description": "APIVersion defines the versioned schema of this representation of an object.\nServers should convert recognized schemas to the latest internal value, and\nmay reject unrecognized values.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#resources",
      "type": "string"
    },
    "kind": {
      "description": "Kind is a string value representing the REST resource this object represents.\nServers may infer this from the endpoint the client submits requests to.\nCannot be updated.\nIn CamelCase.\nMore info: https://git.k8s.io/community/contributors/devel/sig-architecture/api-conventions.md#types-kinds",
      "type": "string"
    },
    "metadata": {
      "type": "object"
    },
    "spec": {
      "properties": {
        "acceptedAudiences": {
          "description": "AcceptedAudiences: The cluster's accepted audiences.",
          "items": {
            "description": "Represents an accepted audience trusted by the cluster.",
            "properties": {
              "value": {
                "description": "Value: GUID or valid URL representing an accepted audience.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "allowedFqdnList": {
          "description": "AllowedFqdnList: List of allowed FQDNs(Fully Qualified Domain Name) for egress from Cluster.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "allowedIpRangeList": {
          "description": "AllowedIpRangeList: The list of ips in the format of CIDR allowed to connect to the cluster.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "azureName": {
          "description": "AzureName: The name of the resource in Azure. This is often the same as the name of the resource in Kubernetes but it\ndoesn't have to be.",
          "pattern": "^.*$",
          "type": "string"
        },
        "enableAutoStop": {
          "description": "EnableAutoStop: A boolean value that indicates if the cluster could be automatically stopped (due to lack of data or no\nactivity for many days).",
          "type": "boolean"
        },
        "enableDiskEncryption": {
          "description": "EnableDiskEncryption: A boolean value that indicates if the cluster's disks are encrypted.",
          "type": "boolean"
        },
        "enableDoubleEncryption": {
          "description": "EnableDoubleEncryption: A boolean value that indicates if double encryption is enabled.",
          "type": "boolean"
        },
        "enablePurge": {
          "description": "EnablePurge: A boolean value that indicates if the purge operations are enabled.",
          "type": "boolean"
        },
        "enableStreamingIngest": {
          "description": "EnableStreamingIngest: A boolean value that indicates if the streaming ingest is enabled.",
          "type": "boolean"
        },
        "engineType": {
          "description": "EngineType: The engine type",
          "enum": [
            "V2",
            "V3"
          ],
          "type": "string"
        },
        "identity": {
          "description": "Identity: The identity of the cluster, if configured.",
          "properties": {
            "type": {
              "description": "Type: The type of managed identity used. The type 'SystemAssigned, UserAssigned' includes both an implicitly created\nidentity and a set of user-assigned identities. The type 'None' will remove all identities.",
              "enum": [
                "None",
                "SystemAssigned",
                "SystemAssigned, UserAssigned",
                "UserAssigned"
              ],
              "type": "string"
            },
            "userAssignedIdentities": {
              "description": "UserAssignedIdentities: The list of user identities associated with the Kusto cluster. The user identity dictionary key\nreferences will be ARM resource ids in the form:\n'/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'.",
              "items": {
                "description": "Information about the user assigned identity for the resource",
                "properties": {
                  "reference": {
                    "description": "ResourceReference represents a resource reference, either to a Kubernetes resource or directly to an Azure resource via ARMID",
                    "properties": {
                      "armId": {
                        "description": "ARMID is a string of the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}.\nThe /resourcegroups/{resourceGroupName} bit is optional as some resources are scoped at the subscription level\nARMID is mutually exclusive with Group, Kind, Namespace and Name.",
                        "pattern": "(?i)(^(/subscriptions/([^/]+)(/resourcegroups/([^/]+))?)?/providers/([^/]+)/([^/]+/[^/]+)(/([^/]+/[^/]+))*$|^/subscriptions/([^/]+)(/resourcegroups/([^/]+))?$)",
                        "type": "string"
                      },
                      "group": {
                        "description": "Group is the Kubernetes group of the resource.",
                        "type": "string"
                      },
                      "kind": {
                        "description": "Kind is the Kubernetes kind of the resource.",
                        "type": "string"
                      },
                      "name": {
                        "description": "Name is the Kubernetes name of the resource.",
                        "type": "string"
                      }
                    },
                    "type": "object",
                    "additionalProperties": false
                  }
                },
                "type": "object",
                "additionalProperties": false
              },
              "type": "array"
            }
          },
          "required": [
            "type"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "keyVaultProperties": {
          "description": "KeyVaultProperties: KeyVault properties for the cluster encryption.",
          "properties": {
            "keyName": {
              "description": "KeyName: The name of the key vault key.",
              "type": "string"
            },
            "keyVaultUri": {
              "description": "KeyVaultUri: The Uri of the key vault.",
              "type": "string"
            },
            "keyVersion": {
              "description": "KeyVersion: The version of the key vault key.",
              "type": "string"
            },
            "userIdentityReference": {
              "description": "UserIdentityReference: The user assigned identity (ARM resource id) that has access to the key.",
              "properties": {
                "armId": {
                  "description": "ARMID is a string of the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}.\nThe /resourcegroups/{resourceGroupName} bit is optional as some resources are scoped at the subscription level\nARMID is mutually exclusive with Group, Kind, Namespace and Name.",
                  "pattern": "(?i)(^(/subscriptions/([^/]+)(/resourcegroups/([^/]+))?)?/providers/([^/]+)/([^/]+/[^/]+)(/([^/]+/[^/]+))*$|^/subscriptions/([^/]+)(/resourcegroups/([^/]+))?$)",
                  "type": "string"
                },
                "group": {
                  "description": "Group is the Kubernetes group of the resource.",
                  "type": "string"
                },
                "kind": {
                  "description": "Kind is the Kubernetes kind of the resource.",
                  "type": "string"
                },
                "name": {
                  "description": "Name is the Kubernetes name of the resource.",
                  "type": "string"
                }
              },
              "type": "object",
              "additionalProperties": false
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "languageExtensions": {
          "description": "LanguageExtensions: List of the cluster's language extensions.",
          "properties": {
            "value": {
              "description": "Value: The list of language extensions.",
              "items": {
                "description": "The language extension object.",
                "properties": {
                  "languageExtensionCustomImageName": {
                    "description": "LanguageExtensionCustomImageName: The language extension custom image name.",
                    "type": "string"
                  },
                  "languageExtensionImageName": {
                    "description": "LanguageExtensionImageName: The language extension image name.",
                    "enum": [
                      "Python3_10_8",
                      "Python3_10_8_DL",
                      "Python3_6_5",
                      "PythonCustomImage",
                      "R"
                    ],
                    "type": "string"
                  },
                  "languageExtensionName": {
                    "description": "LanguageExtensionName: The language extension name.",
                    "enum": [
                      "PYTHON",
                      "R"
                    ],
                    "type": "string"
                  }
                },
                "type": "object",
                "additionalProperties": false
              },
              "type": "array"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "location": {
          "description": "Location: The geo-location where the resource lives",
          "type": "string"
        },
        "operatorSpec": {
          "description": "OperatorSpec: The specification for configuring operator behavior. This field is interpreted by the operator and not\npassed directly to Azure",
          "properties": {
            "configMapExpressions": {
              "description": "ConfigMapExpressions: configures where to place operator written dynamic ConfigMaps (created with CEL expressions).",
              "items": {
                "description": "DestinationExpression is a CEL expression and a destination to store the result in. The destination may\nbe a secret or a configmap. The value of the expression is stored at the specified location in\nthe destination.",
                "properties": {
                  "key": {
                    "description": "Key is the key in the ConfigMap or Secret being written to. If the CEL expression in Value returns a string\nthis is required to identify what key to write to. If the CEL expression in Value returns a map[string]string\nKey must not be set, instead the keys written will be determined dynamically based on the keys of the resulting\nmap[string]string.",
                    "type": "string"
                  },
                  "name": {
                    "description": "Name is the name of the Kubernetes configmap or secret to write to.\nThe configmap or secret will be created in the same namespace as the resource.",
                    "type": "string"
                  },
                  "value": {
                    "description": "Value is a CEL expression. The CEL expression may return a string or a map[string]string. For more information\non CEL in ASO see https://azure.github.io/azure-service-operator/guide/expressions/",
                    "type": "string"
                  }
                },
                "required": [
                  "name",
                  "value"
                ],
                "type": "object",
                "additionalProperties": false
              },
              "type": "array"
            },
            "secretExpressions": {
              "description": "SecretExpressions: configures where to place operator written dynamic secrets (created with CEL expressions).",
              "items": {
                "description": "DestinationExpression is a CEL expression and a destination to store the result in. The destination may\nbe a secret or a configmap. The value of the expression is stored at the specified location in\nthe destination.",
                "properties": {
                  "key": {
                    "description": "Key is the key in the ConfigMap or Secret being written to. If the CEL expression in Value returns a string\nthis is required to identify what key to write to. If the CEL expression in Value returns a map[string]string\nKey must not be set, instead the keys written will be determined dynamically based on the keys of the resulting\nmap[string]string.",
                    "type": "string"
                  },
                  "name": {
                    "description": "Name is the name of the Kubernetes configmap or secret to write to.\nThe configmap or secret will be created in the same namespace as the resource.",
                    "type": "string"
                  },
                  "value": {
                    "description": "Value is a CEL expression. The CEL expression may return a string or a map[string]string. For more information\non CEL in ASO see https://azure.github.io/azure-service-operator/guide/expressions/",
                    "type": "string"
                  }
                },
                "required": [
                  "name",
                  "value"
                ],
                "type": "object",
                "additionalProperties": false
              },
              "type": "array"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "optimizedAutoscale": {
          "description": "OptimizedAutoscale: Optimized auto scale definition.",
          "properties": {
            "isEnabled": {
              "description": "IsEnabled: A boolean value that indicate if the optimized autoscale feature is enabled or not.",
              "type": "boolean"
            },
            "maximum": {
              "description": "Maximum: Maximum allowed instances count.",
              "type": "integer"
            },
            "minimum": {
              "description": "Minimum: Minimum allowed instances count.",
              "type": "integer"
            },
            "version": {
              "description": "Version: The version of the template defined, for instance 1.",
              "type": "integer"
            }
          },
          "required": [
            "isEnabled",
            "maximum",
            "minimum",
            "version"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "owner": {
          "description": "Owner: The owner of the resource. The owner controls where the resource goes when it is deployed. The owner also\ncontrols the resources lifecycle. When the owner is deleted the resource will also be deleted. Owner is expected to be a\nreference to a resources.azure.com/ResourceGroup resource",
          "properties": {
            "armId": {
              "pattern": "(?i)(^(/subscriptions/([^/]+)(/resourcegroups/([^/]+))?)?/providers/([^/]+)/([^/]+/[^/]+)(/([^/]+/[^/]+))*$|^/subscriptions/([^/]+)(/resourcegroups/([^/]+))?$)",
              "type": "string"
            },
            "name": {
              "description": "This is the name of the Kubernetes resource to reference.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "publicIPType": {
          "description": "PublicIPType: Indicates what public IP type to create - IPv4 (default), or DualStack (both IPv4 and IPv6)",
          "enum": [
            "DualStack",
            "IPv4"
          ],
          "type": "string"
        },
        "publicNetworkAccess": {
          "description": "PublicNetworkAccess: Public network access to the cluster is enabled by default. When disabled, only private endpoint\nconnection to the cluster is allowed",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "type": "string"
        },
        "restrictOutboundNetworkAccess": {
          "description": "RestrictOutboundNetworkAccess: Whether or not to restrict outbound network access.  Value is optional but if passed in,\nmust be 'Enabled' or 'Disabled'",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "type": "string"
        },
        "sku": {
          "description": "Sku: The SKU of the cluster.",
          "properties": {
            "capacity": {
              "description": "Capacity: The number of instances of the cluster.",
              "type": "integer"
            },
            "name": {
              "description": "Name: SKU name.",
              "enum": [
                "Dev(No SLA)_Standard_D11_v2",
                "Dev(No SLA)_Standard_E2a_v4",
                "Standard_D11_v2",
                "Standard_D12_v2",
                "Standard_D13_v2",
                "Standard_D14_v2",
                "Standard_D16d_v5",
                "Standard_D32d_v4",
                "Standard_D32d_v5",
                "Standard_DS13_v2+1TB_PS",
                "Standard_DS13_v2+2TB_PS",
                "Standard_DS14_v2+3TB_PS",
                "Standard_DS14_v2+4TB_PS",
                "Standard_E16a_v4",
                "Standard_E16ads_v5",
                "Standard_E16as_v4+3TB_PS",
                "Standard_E16as_v4+4TB_PS",
                "Standard_E16as_v5+3TB_PS",
                "Standard_E16as_v5+4TB_PS",
                "Standard_E16d_v4",
                "Standard_E16d_v5",
                "Standard_E16s_v4+3TB_PS",
                "Standard_E16s_v4+4TB_PS",
                "Standard_E16s_v5+3TB_PS",
                "Standard_E16s_v5+4TB_PS",
                "Standard_E2a_v4",
                "Standard_E2ads_v5",
                "Standard_E2d_v4",
                "Standard_E2d_v5",
                "Standard_E4a_v4",
                "Standard_E4ads_v5",
                "Standard_E4d_v4",
                "Standard_E4d_v5",
                "Standard_E64i_v3",
                "Standard_E80ids_v4",
                "Standard_E8a_v4",
                "Standard_E8ads_v5",
                "Standard_E8as_v4+1TB_PS",
                "Standard_E8as_v4+2TB_PS",
                "Standard_E8as_v5+1TB_PS",
                "Standard_E8as_v5+2TB_PS",
                "Standard_E8d_v4",
                "Standard_E8d_v5",
                "Standard_E8s_v4+1TB_PS",
                "Standard_E8s_v4+2TB_PS",
                "Standard_E8s_v5+1TB_PS",
                "Standard_E8s_v5+2TB_PS",
                "Standard_EC16ads_v5",
                "Standard_EC16as_v5+3TB_PS",
                "Standard_EC16as_v5+4TB_PS",
                "Standard_EC8ads_v5",
                "Standard_EC8as_v5+1TB_PS",
                "Standard_EC8as_v5+2TB_PS",
                "Standard_L16as_v3",
                "Standard_L16s",
                "Standard_L16s_v2",
                "Standard_L16s_v3",
                "Standard_L32as_v3",
                "Standard_L32s_v3",
                "Standard_L4s",
                "Standard_L8as_v3",
                "Standard_L8s",
                "Standard_L8s_v2",
                "Standard_L8s_v3"
              ],
              "type": "string"
            },
            "tier": {
              "description": "Tier: SKU tier.",
              "enum": [
                "Basic",
                "Standard"
              ],
              "type": "string"
            }
          },
          "required": [
            "name",
            "tier"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        },
        "trustedExternalTenants": {
          "description": "TrustedExternalTenants: The cluster's external tenants.",
          "items": {
            "description": "Represents a tenant ID that is trusted by the cluster.",
            "properties": {
              "value": {
                "description": "Value: GUID representing an external tenant.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "virtualClusterGraduationProperties": {
          "description": "VirtualClusterGraduationProperties: Virtual Cluster graduation properties",
          "properties": {
            "key": {
              "description": "Key is the key in the Kubernetes secret being referenced",
              "type": "string"
            },
            "name": {
              "description": "Name is the name of the Kubernetes secret being referenced.\nThe secret must be in the same namespace as the resource",
              "type": "string"
            }
          },
          "required": [
            "key",
            "name"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "virtualNetworkConfiguration": {
          "description": "VirtualNetworkConfiguration: Virtual network definition.",
          "properties": {
            "dataManagementPublicIpReference": {
              "description": "DataManagementPublicIpReference: Data management's service public IP address resource id.",
              "properties": {
                "armId": {
                  "description": "ARMID is a string of the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}.\nThe /resourcegroups/{resourceGroupName} bit is optional as some resources are scoped at the subscription level\nARMID is mutually exclusive with Group, Kind, Namespace and Name.",
                  "pattern": "(?i)(^(/subscriptions/([^/]+)(/resourcegroups/([^/]+))?)?/providers/([^/]+)/([^/]+/[^/]+)(/([^/]+/[^/]+))*$|^/subscriptions/([^/]+)(/resourcegroups/([^/]+))?$)",
                  "type": "string"
                },
                "group": {
                  "description": "Group is the Kubernetes group of the resource.",
                  "type": "string"
                },
                "kind": {
                  "description": "Kind is the Kubernetes kind of the resource.",
                  "type": "string"
                },
                "name": {
                  "description": "Name is the Kubernetes name of the resource.",
                  "type": "string"
                }
              },
              "type": "object",
              "additionalProperties": false
            },
            "enginePublicIpReference": {
              "description": "EnginePublicIpReference: Engine service's public IP address resource id.",
              "properties": {
                "armId": {
                  "description": "ARMID is a string of the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}.\nThe /resourcegroups/{resourceGroupName} bit is optional as some resources are scoped at the subscription level\nARMID is mutually exclusive with Group, Kind, Namespace and Name.",
                  "pattern": "(?i)(^(/subscriptions/([^/]+)(/resourcegroups/([^/]+))?)?/providers/([^/]+)/([^/]+/[^/]+)(/([^/]+/[^/]+))*$|^/subscriptions/([^/]+)(/resourcegroups/([^/]+))?$)",
                  "type": "string"
                },
                "group": {
                  "description": "Group is the Kubernetes group of the resource.",
                  "type": "string"
                },
                "kind": {
                  "description": "Kind is the Kubernetes kind of the resource.",
                  "type": "string"
                },
                "name": {
                  "description": "Name is the Kubernetes name of the resource.",
                  "type": "string"
                }
              },
              "type": "object",
              "additionalProperties": false
            },
            "state": {
              "description": "State: When enabled, the cluster is deployed into the configured subnet, when disabled it will be removed from the\nsubnet.",
              "enum": [
                "Disabled",
                "Enabled"
              ],
              "type": "string"
            },
            "subnetReference": {
              "description": "SubnetReference: The subnet resource id.",
              "properties": {
                "armId": {
                  "description": "ARMID is a string of the form /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}.\nThe /resourcegroups/{resourceGroupName} bit is optional as some resources are scoped at the subscription level\nARMID is mutually exclusive with Group, Kind, Namespace and Name.",
                  "pattern": "(?i)(^(/subscriptions/([^/]+)(/resourcegroups/([^/]+))?)?/providers/([^/]+)/([^/]+/[^/]+)(/([^/]+/[^/]+))*$|^/subscriptions/([^/]+)(/resourcegroups/([^/]+))?$)",
                  "type": "string"
                },
                "group": {
                  "description": "Group is the Kubernetes group of the resource.",
                  "type": "string"
                },
                "kind": {
                  "description": "Kind is the Kubernetes kind of the resource.",
                  "type": "string"
                },
                "name": {
                  "description": "Name is the Kubernetes name of the resource.",
                  "type": "string"
                }
              },
              "type": "object",
              "additionalProperties": false
            }
          },
          "required": [
            "dataManagementPublicIpReference",
            "enginePublicIpReference",
            "subnetReference"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "zones": {
          "description": "Zones: The availability zones of the cluster.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "required": [
        "location",
        "owner",
        "sku"
      ],
      "type": "object",
      "additionalProperties": false
    },
    "status": {
      "description": "Class representing a Kusto cluster.",
      "properties": {
        "acceptedAudiences": {
          "description": "AcceptedAudiences: The cluster's accepted audiences.",
          "items": {
            "description": "Represents an accepted audience trusted by the cluster.",
            "properties": {
              "value": {
                "description": "Value: GUID or valid URL representing an accepted audience.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "allowedFqdnList": {
          "description": "AllowedFqdnList: List of allowed FQDNs(Fully Qualified Domain Name) for egress from Cluster.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "allowedIpRangeList": {
          "description": "AllowedIpRangeList: The list of ips in the format of CIDR allowed to connect to the cluster.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "conditions": {
          "description": "Conditions: The observed state of the resource",
          "items": {
            "description": "Condition defines an extension to status (an observation) of a resource",
            "properties": {
              "lastTransitionTime": {
                "description": "LastTransitionTime is the last time the condition transitioned from one status to another.",
                "format": "date-time",
                "type": "string"
              },
              "message": {
                "description": "Message is a human readable message indicating details about the transition. This field may be empty.",
                "type": "string"
              },
              "observedGeneration": {
                "description": "ObservedGeneration is the .metadata.generation that the condition was set based upon. For instance, if\n.metadata.generation is currently 12, but the .status.condition[x].observedGeneration is 9, the condition is out of date\nwith respect to the current state of the instance.",
                "format": "int64",
                "type": "integer"
              },
              "reason": {
                "description": "Reason for the condition's last transition.\nReasons are upper CamelCase (PascalCase) with no spaces. A reason is always provided, this field will not be empty.",
                "type": "string"
              },
              "severity": {
                "description": "Severity with which to treat failures of this type of condition.\nFor conditions which have positive polarity (Status == True is their normal/healthy state), this will be omitted when Status == True\nFor conditions which have negative polarity (Status == False is their normal/healthy state), this will be omitted when Status == False.\nThis is omitted in all cases when Status == Unknown",
                "type": "string"
              },
              "status": {
                "description": "Status of the condition, one of True, False, or Unknown.",
                "type": "string"
              },
              "type": {
                "description": "Type of condition.",
                "type": "string"
              }
            },
            "required": [
              "lastTransitionTime",
              "reason",
              "status",
              "type"
            ],
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "dataIngestionUri": {
          "description": "DataIngestionUri: The cluster data ingestion URI.",
          "type": "string"
        },
        "enableAutoStop": {
          "description": "EnableAutoStop: A boolean value that indicates if the cluster could be automatically stopped (due to lack of data or no\nactivity for many days).",
          "type": "boolean"
        },
        "enableDiskEncryption": {
          "description": "EnableDiskEncryption: A boolean value that indicates if the cluster's disks are encrypted.",
          "type": "boolean"
        },
        "enableDoubleEncryption": {
          "description": "EnableDoubleEncryption: A boolean value that indicates if double encryption is enabled.",
          "type": "boolean"
        },
        "enablePurge": {
          "description": "EnablePurge: A boolean value that indicates if the purge operations are enabled.",
          "type": "boolean"
        },
        "enableStreamingIngest": {
          "description": "EnableStreamingIngest: A boolean value that indicates if the streaming ingest is enabled.",
          "type": "boolean"
        },
        "engineType": {
          "description": "EngineType: The engine type",
          "type": "string"
        },
        "etag": {
          "description": "Etag: A unique read-only string that changes whenever the resource is updated.",
          "type": "string"
        },
        "id": {
          "description": "Id: Fully qualified resource ID for the resource. Ex -\n/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}",
          "type": "string"
        },
        "identity": {
          "description": "Identity: The identity of the cluster, if configured.",
          "properties": {
            "principalId": {
              "description": "PrincipalId: The principal ID of resource identity.",
              "type": "string"
            },
            "tenantId": {
              "description": "TenantId: The tenant ID of resource.",
              "type": "string"
            },
            "type": {
              "description": "Type: The type of managed identity used. The type 'SystemAssigned, UserAssigned' includes both an implicitly created\nidentity and a set of user-assigned identities. The type 'None' will remove all identities.",
              "type": "string"
            },
            "userAssignedIdentities": {
              "additionalProperties": {
                "properties": {
                  "clientId": {
                    "description": "ClientId: The client id of user assigned identity.",
                    "type": "string"
                  },
                  "principalId": {
                    "description": "PrincipalId: The principal id of user assigned identity.",
                    "type": "string"
                  }
                },
                "type": "object",
                "additionalProperties": false
              },
              "description": "UserAssignedIdentities: The list of user identities associated with the Kusto cluster. The user identity dictionary key\nreferences will be ARM resource ids in the form:\n'/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.ManagedIdentity/userAssignedIdentities/{identityName}'.",
              "type": "object"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "keyVaultProperties": {
          "description": "KeyVaultProperties: KeyVault properties for the cluster encryption.",
          "properties": {
            "keyName": {
              "description": "KeyName: The name of the key vault key.",
              "type": "string"
            },
            "keyVaultUri": {
              "description": "KeyVaultUri: The Uri of the key vault.",
              "type": "string"
            },
            "keyVersion": {
              "description": "KeyVersion: The version of the key vault key.",
              "type": "string"
            },
            "userIdentity": {
              "description": "UserIdentity: The user assigned identity (ARM resource id) that has access to the key.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "languageExtensions": {
          "description": "LanguageExtensions: List of the cluster's language extensions.",
          "properties": {
            "value": {
              "description": "Value: The list of language extensions.",
              "items": {
                "description": "The language extension object.",
                "properties": {
                  "languageExtensionCustomImageName": {
                    "description": "LanguageExtensionCustomImageName: The language extension custom image name.",
                    "type": "string"
                  },
                  "languageExtensionImageName": {
                    "description": "LanguageExtensionImageName: The language extension image name.",
                    "type": "string"
                  },
                  "languageExtensionName": {
                    "description": "LanguageExtensionName: The language extension name.",
                    "type": "string"
                  }
                },
                "type": "object",
                "additionalProperties": false
              },
              "type": "array"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "location": {
          "description": "Location: The geo-location where the resource lives",
          "type": "string"
        },
        "migrationCluster": {
          "description": "MigrationCluster: Properties of the peer cluster involved in a migration to/from this cluster.",
          "properties": {
            "dataIngestionUri": {
              "description": "DataIngestionUri: The public data ingestion URL of the cluster.",
              "type": "string"
            },
            "id": {
              "description": "Id: The resource ID of the cluster.",
              "type": "string"
            },
            "role": {
              "description": "Role: The role of the cluster in the migration process.",
              "type": "string"
            },
            "uri": {
              "description": "Uri: The public URL of the cluster.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "name": {
          "description": "Name: The name of the resource",
          "type": "string"
        },
        "optimizedAutoscale": {
          "description": "OptimizedAutoscale: Optimized auto scale definition.",
          "properties": {
            "isEnabled": {
              "description": "IsEnabled: A boolean value that indicate if the optimized autoscale feature is enabled or not.",
              "type": "boolean"
            },
            "maximum": {
              "description": "Maximum: Maximum allowed instances count.",
              "type": "integer"
            },
            "minimum": {
              "description": "Minimum: Minimum allowed instances count.",
              "type": "integer"
            },
            "version": {
              "description": "Version: The version of the template defined, for instance 1.",
              "type": "integer"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "privateEndpointConnections": {
          "description": "PrivateEndpointConnections: A list of private endpoint connections.",
          "items": {
            "description": "A private endpoint connection",
            "properties": {
              "id": {
                "description": "Id: Fully qualified resource ID for the resource. Ex -\n/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "provisioningState": {
          "description": "ProvisioningState: The provisioned state of the resource.",
          "type": "string"
        },
        "publicIPType": {
          "description": "PublicIPType: Indicates what public IP type to create - IPv4 (default), or DualStack (both IPv4 and IPv6)",
          "type": "string"
        },
        "publicNetworkAccess": {
          "description": "PublicNetworkAccess: Public network access to the cluster is enabled by default. When disabled, only private endpoint\nconnection to the cluster is allowed",
          "type": "string"
        },
        "restrictOutboundNetworkAccess": {
          "description": "RestrictOutboundNetworkAccess: Whether or not to restrict outbound network access.  Value is optional but if passed in,\nmust be 'Enabled' or 'Disabled'",
          "type": "string"
        },
        "sku": {
          "description": "Sku: The SKU of the cluster.",
          "properties": {
            "capacity": {
              "description": "Capacity: The number of instances of the cluster.",
              "type": "integer"
            },
            "name": {
              "description": "Name: SKU name.",
              "type": "string"
            },
            "tier": {
              "description": "Tier: SKU tier.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "state": {
          "description": "State: The state of the resource.",
          "type": "string"
        },
        "stateReason": {
          "description": "StateReason: The reason for the cluster's current state.",
          "type": "string"
        },
        "systemData": {
          "description": "SystemData: Metadata pertaining to creation and last modification of the resource.",
          "properties": {
            "createdAt": {
              "description": "CreatedAt: The timestamp of resource creation (UTC).",
              "type": "string"
            },
            "createdBy": {
              "description": "CreatedBy: The identity that created the resource.",
              "type": "string"
            },
            "createdByType": {
              "description": "CreatedByType: The type of identity that created the resource.",
              "type": "string"
            },
            "lastModifiedAt": {
              "description": "LastModifiedAt: The timestamp of resource last modification (UTC)",
              "type": "string"
            },
            "lastModifiedBy": {
              "description": "LastModifiedBy: The identity that last modified the resource.",
              "type": "string"
            },
            "lastModifiedByType": {
              "description": "LastModifiedByType: The type of identity that last modified the resource.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        },
        "trustedExternalTenants": {
          "description": "TrustedExternalTenants: The cluster's external tenants.",
          "items": {
            "description": "Represents a tenant ID that is trusted by the cluster.",
            "properties": {
              "value": {
                "description": "Value: GUID representing an external tenant.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "type": {
          "description": "Type: The type of the resource. E.g. \"Microsoft.Compute/virtualMachines\" or \"Microsoft.Storage/storageAccounts\"",
          "type": "string"
        },
        "uri": {
          "description": "Uri: The cluster URI.",
          "type": "string"
        },
        "virtualNetworkConfiguration": {
          "description": "VirtualNetworkConfiguration: Virtual network definition.",
          "properties": {
            "dataManagementPublicIpId": {
              "description": "DataManagementPublicIpId: Data management's service public IP address resource id.",
              "type": "string"
            },
            "enginePublicIpId": {
              "description": "EnginePublicIpId: Engine service's public IP address resource id.",
              "type": "string"
            },
            "state": {
              "description": "State: When enabled, the cluster is deployed into the configured subnet, when disabled it will be removed from the\nsubnet.",
              "type": "string"
            },
            "subnetId": {
              "description": "SubnetId: The subnet resource id.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "zones": {
          "description": "Zones: The availability zones of the cluster.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "type": "object",
      "additionalProperties": false
    }
  },
  "type": "object"
}
