{
  "description": "Generator information:\n- Generated from: /sql/resource-manager/Microsoft.Sql/stable/2021-11-01/Servers.json\n- ARM URI: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Sql/servers/{serverName}",
  "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": {
        "administratorLogin": {
          "description": "AdministratorLogin: Administrator username for the server. Once created it cannot be changed.",
          "type": "string"
        },
        "administratorLoginPassword": {
          "description": "AdministratorLoginPassword: The administrator login password (required for server creation).",
          "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
        },
        "administrators": {
          "description": "Administrators: The Azure Active Directory administrator of the server.",
          "properties": {
            "administratorType": {
              "description": "AdministratorType: Type of the sever administrator.",
              "enum": [
                "ActiveDirectory"
              ],
              "type": "string"
            },
            "azureADOnlyAuthentication": {
              "description": "AzureADOnlyAuthentication: Azure Active Directory only Authentication enabled.",
              "type": "boolean"
            },
            "login": {
              "description": "Login: Login name of the server administrator.",
              "type": "string"
            },
            "principalType": {
              "description": "PrincipalType: Principal Type of the sever administrator.",
              "enum": [
                "Application",
                "Group",
                "User"
              ],
              "type": "string"
            },
            "sid": {
              "description": "Sid: SID (object ID) of the server administrator.",
              "pattern": "^[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}$",
              "type": "string"
            },
            "tenantId": {
              "description": "TenantId: Tenant ID of the administrator.",
              "pattern": "^[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}$",
              "type": "string"
            }
          },
          "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"
        },
        "federatedClientId": {
          "description": "FederatedClientId: The Client id used for cross tenant CMK scenario",
          "pattern": "^[0-9a-fA-F]{8}(-[0-9a-fA-F]{4}){3}-[0-9a-fA-F]{12}$",
          "type": "string"
        },
        "identity": {
          "description": "Identity: The Azure Active Directory identity of the server.",
          "properties": {
            "type": {
              "description": "Type: The identity type. Set this to 'SystemAssigned' in order to automatically create and assign an Azure Active\nDirectory principal for the resource.",
              "enum": [
                "None",
                "SystemAssigned",
                "SystemAssigned,UserAssigned",
                "UserAssigned"
              ],
              "type": "string"
            },
            "userAssignedIdentities": {
              "description": "UserAssignedIdentities: The resource ids of the user assigned identities to use",
              "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"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "keyId": {
          "description": "KeyId: A CMK URI of the key to use for encryption.",
          "type": "string"
        },
        "location": {
          "description": "Location: Resource location.",
          "type": "string"
        },
        "minimalTlsVersion": {
          "description": "MinimalTlsVersion: Minimal TLS version. Allowed values: '1.0', '1.1', '1.2'",
          "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"
            },
            "configMaps": {
              "description": "ConfigMaps: configures where to place operator written ConfigMaps.",
              "properties": {
                "fullyQualifiedDomainName": {
                  "description": "FullyQualifiedDomainName: indicates where the FullyQualifiedDomainName config map should be placed. If omitted, no\nconfig map will be created.",
                  "properties": {
                    "key": {
                      "description": "Key is the key in the ConfigMap being referenced",
                      "type": "string"
                    },
                    "name": {
                      "description": "Name is the name of the Kubernetes ConfigMap to write to.\nThe ConfigMap will be created in the same namespace as the resource.",
                      "type": "string"
                    }
                  },
                  "required": [
                    "key",
                    "name"
                  ],
                  "type": "object",
                  "additionalProperties": false
                }
              },
              "type": "object",
              "additionalProperties": false
            },
            "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 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
        },
        "primaryUserAssignedIdentityReference": {
          "description": "PrimaryUserAssignedIdentityReference: The resource id of a user assigned identity to be used by default.",
          "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
        },
        "publicNetworkAccess": {
          "description": "PublicNetworkAccess: Whether or not public endpoint access is allowed for this server.  Value is optional but if passed\nin, must be 'Enabled' or 'Disabled'",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "type": "string"
        },
        "restrictOutboundNetworkAccess": {
          "description": "RestrictOutboundNetworkAccess: Whether or not to restrict outbound network access for this server.  Value is optional\nbut if passed in, must be 'Enabled' or 'Disabled'",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "type": "string"
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        },
        "version": {
          "description": "Version: The version of the server.",
          "type": "string"
        }
      },
      "required": [
        "location",
        "owner"
      ],
      "type": "object",
      "additionalProperties": false
    },
    "status": {
      "description": "An Azure SQL Database server.",
      "properties": {
        "administratorLogin": {
          "description": "AdministratorLogin: Administrator username for the server. Once created it cannot be changed.",
          "type": "string"
        },
        "administrators": {
          "description": "Administrators: The Azure Active Directory administrator of the server.",
          "properties": {
            "administratorType": {
              "description": "AdministratorType: Type of the sever administrator.",
              "type": "string"
            },
            "azureADOnlyAuthentication": {
              "description": "AzureADOnlyAuthentication: Azure Active Directory only Authentication enabled.",
              "type": "boolean"
            },
            "login": {
              "description": "Login: Login name of the server administrator.",
              "type": "string"
            },
            "principalType": {
              "description": "PrincipalType: Principal Type of the sever administrator.",
              "type": "string"
            },
            "sid": {
              "description": "Sid: SID (object ID) of the server administrator.",
              "type": "string"
            },
            "tenantId": {
              "description": "TenantId: Tenant ID of the administrator.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "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"
        },
        "federatedClientId": {
          "description": "FederatedClientId: The Client id used for cross tenant CMK scenario",
          "type": "string"
        },
        "fullyQualifiedDomainName": {
          "description": "FullyQualifiedDomainName: The fully qualified domain name of the server.",
          "type": "string"
        },
        "id": {
          "description": "Id: Resource ID.",
          "type": "string"
        },
        "identity": {
          "description": "Identity: The Azure Active Directory identity of the server.",
          "properties": {
            "principalId": {
              "description": "PrincipalId: The Azure Active Directory principal id.",
              "type": "string"
            },
            "tenantId": {
              "description": "TenantId: The Azure Active Directory tenant id.",
              "type": "string"
            },
            "type": {
              "description": "Type: The identity type. Set this to 'SystemAssigned' in order to automatically create and assign an Azure Active\nDirectory principal for the resource.",
              "type": "string"
            },
            "userAssignedIdentities": {
              "additionalProperties": {
                "description": "Azure Active Directory identity configuration for a resource.",
                "properties": {
                  "clientId": {
                    "description": "ClientId: The Azure Active Directory client id.",
                    "type": "string"
                  },
                  "principalId": {
                    "description": "PrincipalId: The Azure Active Directory principal id.",
                    "type": "string"
                  }
                },
                "type": "object",
                "additionalProperties": false
              },
              "description": "UserAssignedIdentities: The resource ids of the user assigned identities to use",
              "type": "object"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "keyId": {
          "description": "KeyId: A CMK URI of the key to use for encryption.",
          "type": "string"
        },
        "kind": {
          "description": "Kind: Kind of sql server. This is metadata used for the Azure portal experience.",
          "type": "string"
        },
        "location": {
          "description": "Location: Resource location.",
          "type": "string"
        },
        "minimalTlsVersion": {
          "description": "MinimalTlsVersion: Minimal TLS version. Allowed values: '1.0', '1.1', '1.2'",
          "type": "string"
        },
        "name": {
          "description": "Name: Resource name.",
          "type": "string"
        },
        "primaryUserAssignedIdentityId": {
          "description": "PrimaryUserAssignedIdentityId: The resource id of a user assigned identity to be used by default.",
          "type": "string"
        },
        "privateEndpointConnections": {
          "description": "PrivateEndpointConnections: List of private endpoint connections on a server",
          "items": {
            "description": "A private endpoint connection under a server",
            "properties": {
              "id": {
                "description": "Id: Resource ID.",
                "type": "string"
              },
              "properties": {
                "description": "Properties: Private endpoint connection properties",
                "properties": {
                  "groupIds": {
                    "description": "GroupIds: Group IDs.",
                    "items": {
                      "type": "string"
                    },
                    "type": "array"
                  },
                  "privateEndpoint": {
                    "description": "PrivateEndpoint: Private endpoint which the connection belongs to.",
                    "properties": {
                      "id": {
                        "description": "Id: Resource id of the private endpoint.",
                        "type": "string"
                      }
                    },
                    "type": "object",
                    "additionalProperties": false
                  },
                  "privateLinkServiceConnectionState": {
                    "description": "PrivateLinkServiceConnectionState: Connection state of the private endpoint connection.",
                    "properties": {
                      "actionsRequired": {
                        "description": "ActionsRequired: The actions required for private link service connection.",
                        "type": "string"
                      },
                      "description": {
                        "description": "Description: The private link service connection description.",
                        "type": "string"
                      },
                      "status": {
                        "description": "Status: The private link service connection status.",
                        "type": "string"
                      }
                    },
                    "type": "object",
                    "additionalProperties": false
                  },
                  "provisioningState": {
                    "description": "ProvisioningState: State of the private endpoint connection.",
                    "type": "string"
                  }
                },
                "type": "object",
                "additionalProperties": false
              },
              "additionalProperties": false
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "publicNetworkAccess": {
          "description": "PublicNetworkAccess: Whether or not public endpoint access is allowed for this server.  Value is optional but if passed\nin, must be 'Enabled' or 'Disabled'",
          "type": "string"
        },
        "restrictOutboundNetworkAccess": {
          "description": "RestrictOutboundNetworkAccess: Whether or not to restrict outbound network access for this server.  Value is optional\nbut if passed in, must be 'Enabled' or 'Disabled'",
          "type": "string"
        },
        "state": {
          "description": "State: The state of the server.",
          "type": "string"
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        },
        "type": {
          "description": "Type: Resource type.",
          "type": "string"
        },
        "version": {
          "description": "Version: The version of the server.",
          "type": "string"
        },
        "workspaceFeature": {
          "description": "WorkspaceFeature: Whether or not existing server has a workspace created and if it allows connection from workspace",
          "type": "string"
        }
      },
      "type": "object",
      "additionalProperties": false
    }
  },
  "type": "object"
}
