{
  "description": "Generator information:\n- Generated from: /synapse/resource-manager/Microsoft.Synapse/stable/2021-06-01/bigDataPool.json\n- ARM URI: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Synapse/workspaces/{workspaceName}/bigDataPools/{bigDataPoolName}",
  "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": {
        "autoPause": {
          "description": "AutoPause: Auto-pausing properties",
          "properties": {
            "delayInMinutes": {
              "description": "DelayInMinutes: Number of minutes of idle time before the Big Data pool is automatically paused.",
              "type": "integer"
            },
            "enabled": {
              "description": "Enabled: Whether auto-pausing is enabled for the Big Data pool.",
              "type": "boolean"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "autoScale": {
          "description": "AutoScale: Auto-scaling properties",
          "properties": {
            "enabled": {
              "description": "Enabled: Whether automatic scaling is enabled for the Big Data pool.",
              "type": "boolean"
            },
            "maxNodeCount": {
              "description": "MaxNodeCount: The maximum number of nodes the Big Data pool can support.",
              "type": "integer"
            },
            "minNodeCount": {
              "description": "MinNodeCount: The minimum number of nodes the Big Data pool can support.",
              "type": "integer"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "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.",
          "type": "string"
        },
        "cacheSize": {
          "description": "CacheSize: The cache size",
          "type": "integer"
        },
        "customLibraries": {
          "description": "CustomLibraries: List of custom libraries/packages associated with the spark pool.",
          "items": {
            "description": "Library/package information of a Big Data pool powered by Apache Spark",
            "properties": {
              "containerName": {
                "description": "ContainerName: Storage blob container name.",
                "type": "string"
              },
              "name": {
                "description": "Name: Name of the library.",
                "type": "string"
              },
              "path": {
                "description": "Path: Storage blob path of library.",
                "type": "string"
              },
              "type": {
                "description": "Type: Type of the library.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "defaultSparkLogFolder": {
          "description": "DefaultSparkLogFolder: The default folder where Spark logs will be written.",
          "type": "string"
        },
        "dynamicExecutorAllocation": {
          "description": "DynamicExecutorAllocation: Dynamic Executor Allocation",
          "properties": {
            "enabled": {
              "description": "Enabled: Indicates whether Dynamic Executor Allocation is enabled or not.",
              "type": "boolean"
            },
            "maxExecutors": {
              "description": "MaxExecutors: The maximum number of executors alloted",
              "type": "integer"
            },
            "minExecutors": {
              "description": "MinExecutors: The minimum number of executors alloted",
              "type": "integer"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "isAutotuneEnabled": {
          "description": "IsAutotuneEnabled: Whether autotune is required or not.",
          "type": "boolean"
        },
        "isComputeIsolationEnabled": {
          "description": "IsComputeIsolationEnabled: Whether compute isolation is required or not.",
          "type": "boolean"
        },
        "libraryRequirements": {
          "description": "LibraryRequirements: Library version requirements",
          "properties": {
            "content": {
              "description": "Content: The library requirements.",
              "type": "string"
            },
            "filename": {
              "description": "Filename: The filename of the library requirements file.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "location": {
          "description": "Location: The geo-location where the resource lives",
          "type": "string"
        },
        "nodeCount": {
          "description": "NodeCount: The number of nodes in the Big Data pool.",
          "type": "integer"
        },
        "nodeSize": {
          "description": "NodeSize: The level of compute power that each node in the Big Data pool has.",
          "enum": [
            "Large",
            "Medium",
            "None",
            "Small",
            "XLarge",
            "XXLarge",
            "XXXLarge"
          ],
          "type": "string"
        },
        "nodeSizeFamily": {
          "description": "NodeSizeFamily: The kind of nodes that the Big Data pool provides.",
          "enum": [
            "HardwareAcceleratedFPGA",
            "HardwareAcceleratedGPU",
            "MemoryOptimized",
            "None"
          ],
          "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
        },
        "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 synapse.azure.com/Workspace 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
        },
        "provisioningState": {
          "description": "ProvisioningState: The state of the Big Data pool.",
          "type": "string"
        },
        "sessionLevelPackagesEnabled": {
          "description": "SessionLevelPackagesEnabled: Whether session level packages enabled.",
          "type": "boolean"
        },
        "sparkConfigProperties": {
          "description": "SparkConfigProperties: Spark configuration file to specify additional properties",
          "properties": {
            "configurationType": {
              "description": "ConfigurationType: The type of the spark config properties file.",
              "enum": [
                "Artifact",
                "File"
              ],
              "type": "string"
            },
            "content": {
              "description": "Content: The spark config properties.",
              "type": "string"
            },
            "filename": {
              "description": "Filename: The filename of the spark config properties file.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "sparkEventsFolder": {
          "description": "SparkEventsFolder: The Spark events folder",
          "type": "string"
        },
        "sparkVersion": {
          "description": "SparkVersion: The Apache Spark version.",
          "type": "string"
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        }
      },
      "required": [
        "location",
        "owner"
      ],
      "type": "object",
      "additionalProperties": false
    },
    "status": {
      "properties": {
        "autoPause": {
          "description": "AutoPause: Auto-pausing properties",
          "properties": {
            "delayInMinutes": {
              "description": "DelayInMinutes: Number of minutes of idle time before the Big Data pool is automatically paused.",
              "type": "integer"
            },
            "enabled": {
              "description": "Enabled: Whether auto-pausing is enabled for the Big Data pool.",
              "type": "boolean"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "autoScale": {
          "description": "AutoScale: Auto-scaling properties",
          "properties": {
            "enabled": {
              "description": "Enabled: Whether automatic scaling is enabled for the Big Data pool.",
              "type": "boolean"
            },
            "maxNodeCount": {
              "description": "MaxNodeCount: The maximum number of nodes the Big Data pool can support.",
              "type": "integer"
            },
            "minNodeCount": {
              "description": "MinNodeCount: The minimum number of nodes the Big Data pool can support.",
              "type": "integer"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "cacheSize": {
          "description": "CacheSize: The cache size",
          "type": "integer"
        },
        "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"
        },
        "creationDate": {
          "description": "CreationDate: The time when the Big Data pool was created.",
          "type": "string"
        },
        "customLibraries": {
          "description": "CustomLibraries: List of custom libraries/packages associated with the spark pool.",
          "items": {
            "description": "Library/package information of a Big Data pool powered by Apache Spark",
            "properties": {
              "containerName": {
                "description": "ContainerName: Storage blob container name.",
                "type": "string"
              },
              "creatorId": {
                "description": "CreatorId: Creator Id of the library/package.",
                "type": "string"
              },
              "name": {
                "description": "Name: Name of the library.",
                "type": "string"
              },
              "path": {
                "description": "Path: Storage blob path of library.",
                "type": "string"
              },
              "provisioningStatus": {
                "description": "ProvisioningStatus: Provisioning status of the library/package.",
                "type": "string"
              },
              "type": {
                "description": "Type: Type of the library.",
                "type": "string"
              },
              "uploadedTimestamp": {
                "description": "UploadedTimestamp: The last update time of the library.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "defaultSparkLogFolder": {
          "description": "DefaultSparkLogFolder: The default folder where Spark logs will be written.",
          "type": "string"
        },
        "dynamicExecutorAllocation": {
          "description": "DynamicExecutorAllocation: Dynamic Executor Allocation",
          "properties": {
            "enabled": {
              "description": "Enabled: Indicates whether Dynamic Executor Allocation is enabled or not.",
              "type": "boolean"
            },
            "maxExecutors": {
              "description": "MaxExecutors: The maximum number of executors alloted",
              "type": "integer"
            },
            "minExecutors": {
              "description": "MinExecutors: The minimum number of executors alloted",
              "type": "integer"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "id": {
          "description": "Id: Fully qualified resource ID for the resource. Ex -\n/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/{resourceProviderNamespace}/{resourceType}/{resourceName}",
          "type": "string"
        },
        "isAutotuneEnabled": {
          "description": "IsAutotuneEnabled: Whether autotune is required or not.",
          "type": "boolean"
        },
        "isComputeIsolationEnabled": {
          "description": "IsComputeIsolationEnabled: Whether compute isolation is required or not.",
          "type": "boolean"
        },
        "lastSucceededTimestamp": {
          "description": "LastSucceededTimestamp: The time when the Big Data pool was updated successfully.",
          "type": "string"
        },
        "libraryRequirements": {
          "description": "LibraryRequirements: Library version requirements",
          "properties": {
            "content": {
              "description": "Content: The library requirements.",
              "type": "string"
            },
            "filename": {
              "description": "Filename: The filename of the library requirements file.",
              "type": "string"
            },
            "time": {
              "description": "Time: The last update time of the library requirements file.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "location": {
          "description": "Location: The geo-location where the resource lives",
          "type": "string"
        },
        "name": {
          "description": "Name: The name of the resource",
          "type": "string"
        },
        "nodeCount": {
          "description": "NodeCount: The number of nodes in the Big Data pool.",
          "type": "integer"
        },
        "nodeSize": {
          "description": "NodeSize: The level of compute power that each node in the Big Data pool has.",
          "type": "string"
        },
        "nodeSizeFamily": {
          "description": "NodeSizeFamily: The kind of nodes that the Big Data pool provides.",
          "type": "string"
        },
        "provisioningState": {
          "description": "ProvisioningState: The state of the Big Data pool.",
          "type": "string"
        },
        "sessionLevelPackagesEnabled": {
          "description": "SessionLevelPackagesEnabled: Whether session level packages enabled.",
          "type": "boolean"
        },
        "sparkConfigProperties": {
          "description": "SparkConfigProperties: Spark configuration file to specify additional properties",
          "properties": {
            "configurationType": {
              "description": "ConfigurationType: The type of the spark config properties file.",
              "type": "string"
            },
            "content": {
              "description": "Content: The spark config properties.",
              "type": "string"
            },
            "filename": {
              "description": "Filename: The filename of the spark config properties file.",
              "type": "string"
            },
            "time": {
              "description": "Time: The last update time of the spark config properties file.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "sparkEventsFolder": {
          "description": "SparkEventsFolder: The Spark events folder",
          "type": "string"
        },
        "sparkVersion": {
          "description": "SparkVersion: The Apache Spark version.",
          "type": "string"
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        },
        "type": {
          "description": "Type: The type of the resource. E.g. \"Microsoft.Compute/virtualMachines\" or \"Microsoft.Storage/storageAccounts\"",
          "type": "string"
        }
      },
      "type": "object",
      "additionalProperties": false
    }
  },
  "type": "object"
}
