{
  "description": "Generator information:\n- Generated from: /redis/resource-manager/Microsoft.Cache/stable/2023-04-01/redis.json\n- ARM URI: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Cache/redis/{name}",
  "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": {
        "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"
        },
        "enableNonSslPort": {
          "description": "EnableNonSslPort: Specifies whether the non-ssl Redis server port (6379) is enabled.",
          "type": "boolean"
        },
        "identity": {
          "description": "Identity: The identity of the resource.",
          "properties": {
            "type": {
              "description": "Type: Type of managed service identity (where both SystemAssigned and UserAssigned types are allowed).",
              "enum": [
                "None",
                "SystemAssigned",
                "SystemAssigned, UserAssigned",
                "UserAssigned"
              ],
              "type": "string"
            },
            "userAssignedIdentities": {
              "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
        },
        "location": {
          "description": "Location: The geo-location where the resource lives",
          "type": "string"
        },
        "minimumTlsVersion": {
          "description": "MinimumTlsVersion: Optional: requires clients to use a specified TLS version (or higher) to connect (e,g, '1.0', '1.1',\n'1.2')",
          "enum": [
            "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"
            },
            "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"
            },
            "secrets": {
              "description": "Secrets: configures where to place Azure generated secrets.",
              "properties": {
                "hostName": {
                  "description": "HostName: indicates where the HostName secret should be placed. If omitted, the secret will not be retrieved from Azure.",
                  "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 to write to.\nThe secret will be created in the same namespace as the resource.",
                      "type": "string"
                    }
                  },
                  "required": [
                    "key",
                    "name"
                  ],
                  "type": "object",
                  "additionalProperties": false
                },
                "port": {
                  "description": "Port: indicates where the Port secret should be placed. If omitted, the secret will not be retrieved from Azure.",
                  "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 to write to.\nThe secret will be created in the same namespace as the resource.",
                      "type": "string"
                    }
                  },
                  "required": [
                    "key",
                    "name"
                  ],
                  "type": "object",
                  "additionalProperties": false
                },
                "primaryKey": {
                  "description": "PrimaryKey: indicates where the PrimaryKey secret should be placed. If omitted, the secret will not be retrieved from\nAzure.",
                  "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 to write to.\nThe secret will be created in the same namespace as the resource.",
                      "type": "string"
                    }
                  },
                  "required": [
                    "key",
                    "name"
                  ],
                  "type": "object",
                  "additionalProperties": false
                },
                "secondaryKey": {
                  "description": "SecondaryKey: indicates where the SecondaryKey secret should be placed. If omitted, the secret will not be retrieved\nfrom Azure.",
                  "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 to write to.\nThe secret will be created in the same namespace as the resource.",
                      "type": "string"
                    }
                  },
                  "required": [
                    "key",
                    "name"
                  ],
                  "type": "object",
                  "additionalProperties": false
                },
                "sslPort": {
                  "description": "SSLPort: indicates where the SSLPort secret should be placed. If omitted, the secret will not be retrieved from Azure.",
                  "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 to write to.\nThe secret will be created in the same namespace as the resource.",
                      "type": "string"
                    }
                  },
                  "required": [
                    "key",
                    "name"
                  ],
                  "type": "object",
                  "additionalProperties": false
                }
              },
              "type": "object",
              "additionalProperties": false
            }
          },
          "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
        },
        "publicNetworkAccess": {
          "description": "PublicNetworkAccess: Whether or not public endpoint access is allowed for this cache.  Value is optional, but if passed\nin, must be 'Enabled' or 'Disabled'. If 'Disabled', private endpoints are the exclusive access method. Default value is\n'Enabled'. Note: This setting is important for caches with private endpoints. It has *no effect* on caches that are\njoined to, or injected into, a virtual network subnet.",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "type": "string"
        },
        "redisConfiguration": {
          "description": "RedisConfiguration: All Redis Settings. Few possible keys:\nrdb-backup-enabled,rdb-storage-connection-string,rdb-backup-frequency,maxmemory-delta,maxmemory-policy,notify-keyspace-events,maxmemory-samples,slowlog-log-slower-than,slowlog-max-len,list-max-ziplist-entries,list-max-ziplist-value,hash-max-ziplist-entries,hash-max-ziplist-value,set-max-intset-entries,zset-max-ziplist-entries,zset-max-ziplist-value\netc.",
          "properties": {
            "aof-backup-enabled": {
              "description": "AofBackupEnabled: Specifies whether the aof backup is enabled",
              "type": "string"
            },
            "aof-storage-connection-string-0": {
              "description": "AofStorageConnectionString0: First storage account connection string",
              "type": "string"
            },
            "aof-storage-connection-string-1": {
              "description": "AofStorageConnectionString1: Second storage account connection string",
              "type": "string"
            },
            "authnotrequired": {
              "description": "Authnotrequired: Specifies whether the authentication is disabled. Setting this property is highly discouraged from\nsecurity point of view.",
              "type": "string"
            },
            "maxfragmentationmemory-reserved": {
              "description": "MaxfragmentationmemoryReserved: Value in megabytes reserved for fragmentation per shard",
              "type": "string"
            },
            "maxmemory-delta": {
              "description": "MaxmemoryDelta: Value in megabytes reserved for non-cache usage per shard e.g. failover.",
              "type": "string"
            },
            "maxmemory-policy": {
              "description": "MaxmemoryPolicy: The eviction strategy used when your data won't fit within its memory limit.",
              "type": "string"
            },
            "maxmemory-reserved": {
              "description": "MaxmemoryReserved: Value in megabytes reserved for non-cache usage per shard e.g. failover.",
              "type": "string"
            },
            "preferred-data-persistence-auth-method": {
              "description": "PreferredDataPersistenceAuthMethod: Preferred auth method to communicate to storage account used for data persistence,\nspecify SAS or ManagedIdentity, default value is SAS",
              "type": "string"
            },
            "rdb-backup-enabled": {
              "description": "RdbBackupEnabled: Specifies whether the rdb backup is enabled",
              "type": "string"
            },
            "rdb-backup-frequency": {
              "description": "RdbBackupFrequency: Specifies the frequency for creating rdb backup in minutes. Valid values: (15, 30, 60, 360, 720,\n1440)",
              "type": "string"
            },
            "rdb-backup-max-snapshot-count": {
              "description": "RdbBackupMaxSnapshotCount: Specifies the maximum number of snapshots for rdb backup",
              "type": "string"
            },
            "rdb-storage-connection-string": {
              "description": "RdbStorageConnectionString: The storage account connection string for storing rdb file",
              "type": "string"
            },
            "storage-subscription-id": {
              "description": "StorageSubscriptionId: SubscriptionId of the storage account for persistence (aof/rdb) using ManagedIdentity.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "redisVersion": {
          "description": "RedisVersion: Redis version. This should be in the form 'major[.minor]' (only 'major' is required) or the value 'latest'\nwhich refers to the latest stable Redis version that is available. Supported versions: 4.0, 6.0 (latest). Default value\nis 'latest'.",
          "type": "string"
        },
        "replicasPerMaster": {
          "description": "ReplicasPerMaster: The number of replicas to be created per primary.",
          "type": "integer"
        },
        "replicasPerPrimary": {
          "description": "ReplicasPerPrimary: The number of replicas to be created per primary.",
          "type": "integer"
        },
        "shardCount": {
          "description": "ShardCount: The number of shards to be created on a Premium Cluster Cache.",
          "type": "integer"
        },
        "sku": {
          "description": "Sku: The SKU of the Redis cache to deploy.",
          "properties": {
            "capacity": {
              "description": "Capacity: The size of the Redis cache to deploy. Valid values: for C (Basic/Standard) family (0, 1, 2, 3, 4, 5, 6), for\nP (Premium) family (1, 2, 3, 4).",
              "type": "integer"
            },
            "family": {
              "description": "Family: The SKU family to use. Valid values: (C, P). (C = Basic/Standard, P = Premium).",
              "enum": [
                "C",
                "P"
              ],
              "type": "string"
            },
            "name": {
              "description": "Name: The type of Redis cache to deploy. Valid values: (Basic, Standard, Premium)",
              "enum": [
                "Basic",
                "Premium",
                "Standard"
              ],
              "type": "string"
            }
          },
          "required": [
            "capacity",
            "family",
            "name"
          ],
          "type": "object",
          "additionalProperties": false
        },
        "staticIP": {
          "description": "StaticIP: Static IP address. Optionally, may be specified when deploying a Redis cache inside an existing Azure Virtual\nNetwork; auto assigned by default.",
          "pattern": "^\\d+\\.\\d+\\.\\d+\\.\\d+$",
          "type": "string"
        },
        "subnetReference": {
          "description": "SubnetReference: The full resource ID of a subnet in a virtual network to deploy the Redis cache in. Example format:\n/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/Microsoft.{Network|ClassicNetwork}/VirtualNetworks/vnet1/subnets/subnet1",
          "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
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        },
        "tenantSettings": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "TenantSettings: A dictionary of tenant settings",
          "type": "object"
        },
        "zones": {
          "description": "Zones: A list of availability zones denoting where the resource needs to come from.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "required": [
        "location",
        "owner",
        "sku"
      ],
      "type": "object",
      "additionalProperties": false
    },
    "status": {
      "properties": {
        "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"
        },
        "enableNonSslPort": {
          "description": "EnableNonSslPort: Specifies whether the non-ssl Redis server port (6379) is enabled.",
          "type": "boolean"
        },
        "hostName": {
          "description": "HostName: Redis host name.",
          "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 resource.",
          "properties": {
            "principalId": {
              "description": "PrincipalId: The service principal ID of the system assigned identity. This property will only be provided for a system\nassigned identity.",
              "type": "string"
            },
            "tenantId": {
              "description": "TenantId: The tenant ID of the system assigned identity. This property will only be provided for a system assigned\nidentity.",
              "type": "string"
            },
            "type": {
              "description": "Type: Type of managed service identity (where both SystemAssigned and UserAssigned types are allowed).",
              "type": "string"
            },
            "userAssignedIdentities": {
              "additionalProperties": {
                "description": "User assigned identity properties",
                "properties": {
                  "clientId": {
                    "description": "ClientId: The client ID of the assigned identity.",
                    "type": "string"
                  },
                  "principalId": {
                    "description": "PrincipalId: The principal ID of the assigned identity.",
                    "type": "string"
                  }
                },
                "type": "object",
                "additionalProperties": false
              },
              "type": "object"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "instances": {
          "description": "Instances: List of the Redis instances associated with the cache",
          "items": {
            "description": "Details of single instance of redis.",
            "properties": {
              "isMaster": {
                "description": "IsMaster: Specifies whether the instance is a primary node.",
                "type": "boolean"
              },
              "isPrimary": {
                "description": "IsPrimary: Specifies whether the instance is a primary node.",
                "type": "boolean"
              },
              "nonSslPort": {
                "description": "NonSslPort: If enableNonSslPort is true, provides Redis instance Non-SSL port.",
                "type": "integer"
              },
              "shardId": {
                "description": "ShardId: If clustering is enabled, the Shard ID of Redis Instance",
                "type": "integer"
              },
              "sslPort": {
                "description": "SslPort: Redis instance SSL port.",
                "type": "integer"
              },
              "zone": {
                "description": "Zone: If the Cache uses availability zones, specifies availability zone where this instance is located.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "linkedServers": {
          "description": "LinkedServers: List of the linked servers associated with the cache",
          "items": {
            "description": "Linked server Id",
            "properties": {
              "id": {
                "description": "Id: Linked server Id.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "location": {
          "description": "Location: The geo-location where the resource lives",
          "type": "string"
        },
        "minimumTlsVersion": {
          "description": "MinimumTlsVersion: Optional: requires clients to use a specified TLS version (or higher) to connect (e,g, '1.0', '1.1',\n'1.2')",
          "type": "string"
        },
        "name": {
          "description": "Name: The name of the resource",
          "type": "string"
        },
        "port": {
          "description": "Port: Redis non-SSL port.",
          "type": "integer"
        },
        "privateEndpointConnections": {
          "description": "PrivateEndpointConnections: List of private endpoint connection associated with the specified redis cache",
          "items": {
            "description": "The Private Endpoint Connection resource.",
            "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: Redis instance provisioning status.",
          "type": "string"
        },
        "publicNetworkAccess": {
          "description": "PublicNetworkAccess: Whether or not public endpoint access is allowed for this cache.  Value is optional, but if passed\nin, must be 'Enabled' or 'Disabled'. If 'Disabled', private endpoints are the exclusive access method. Default value is\n'Enabled'. Note: This setting is important for caches with private endpoints. It has *no effect* on caches that are\njoined to, or injected into, a virtual network subnet.",
          "type": "string"
        },
        "redisConfiguration": {
          "description": "RedisConfiguration: All Redis Settings. Few possible keys:\nrdb-backup-enabled,rdb-storage-connection-string,rdb-backup-frequency,maxmemory-delta,maxmemory-policy,notify-keyspace-events,maxmemory-samples,slowlog-log-slower-than,slowlog-max-len,list-max-ziplist-entries,list-max-ziplist-value,hash-max-ziplist-entries,hash-max-ziplist-value,set-max-intset-entries,zset-max-ziplist-entries,zset-max-ziplist-value\netc.",
          "properties": {
            "aof-backup-enabled": {
              "description": "AofBackupEnabled: Specifies whether the aof backup is enabled",
              "type": "string"
            },
            "aof-storage-connection-string-0": {
              "description": "AofStorageConnectionString0: First storage account connection string",
              "type": "string"
            },
            "aof-storage-connection-string-1": {
              "description": "AofStorageConnectionString1: Second storage account connection string",
              "type": "string"
            },
            "authnotrequired": {
              "description": "Authnotrequired: Specifies whether the authentication is disabled. Setting this property is highly discouraged from\nsecurity point of view.",
              "type": "string"
            },
            "maxclients": {
              "description": "Maxclients: The max clients config",
              "type": "string"
            },
            "maxfragmentationmemory-reserved": {
              "description": "MaxfragmentationmemoryReserved: Value in megabytes reserved for fragmentation per shard",
              "type": "string"
            },
            "maxmemory-delta": {
              "description": "MaxmemoryDelta: Value in megabytes reserved for non-cache usage per shard e.g. failover.",
              "type": "string"
            },
            "maxmemory-policy": {
              "description": "MaxmemoryPolicy: The eviction strategy used when your data won't fit within its memory limit.",
              "type": "string"
            },
            "maxmemory-reserved": {
              "description": "MaxmemoryReserved: Value in megabytes reserved for non-cache usage per shard e.g. failover.",
              "type": "string"
            },
            "preferred-data-archive-auth-method": {
              "description": "PreferredDataArchiveAuthMethod: Preferred auth method to communicate to storage account used for data archive, specify\nSAS or ManagedIdentity, default value is SAS",
              "type": "string"
            },
            "preferred-data-persistence-auth-method": {
              "description": "PreferredDataPersistenceAuthMethod: Preferred auth method to communicate to storage account used for data persistence,\nspecify SAS or ManagedIdentity, default value is SAS",
              "type": "string"
            },
            "rdb-backup-enabled": {
              "description": "RdbBackupEnabled: Specifies whether the rdb backup is enabled",
              "type": "string"
            },
            "rdb-backup-frequency": {
              "description": "RdbBackupFrequency: Specifies the frequency for creating rdb backup in minutes. Valid values: (15, 30, 60, 360, 720,\n1440)",
              "type": "string"
            },
            "rdb-backup-max-snapshot-count": {
              "description": "RdbBackupMaxSnapshotCount: Specifies the maximum number of snapshots for rdb backup",
              "type": "string"
            },
            "rdb-storage-connection-string": {
              "description": "RdbStorageConnectionString: The storage account connection string for storing rdb file",
              "type": "string"
            },
            "storage-subscription-id": {
              "description": "StorageSubscriptionId: SubscriptionId of the storage account for persistence (aof/rdb) using ManagedIdentity.",
              "type": "string"
            },
            "zonal-configuration": {
              "description": "ZonalConfiguration: Zonal Configuration",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "redisVersion": {
          "description": "RedisVersion: Redis version. This should be in the form 'major[.minor]' (only 'major' is required) or the value 'latest'\nwhich refers to the latest stable Redis version that is available. Supported versions: 4.0, 6.0 (latest). Default value\nis 'latest'.",
          "type": "string"
        },
        "replicasPerMaster": {
          "description": "ReplicasPerMaster: The number of replicas to be created per primary.",
          "type": "integer"
        },
        "replicasPerPrimary": {
          "description": "ReplicasPerPrimary: The number of replicas to be created per primary.",
          "type": "integer"
        },
        "shardCount": {
          "description": "ShardCount: The number of shards to be created on a Premium Cluster Cache.",
          "type": "integer"
        },
        "sku": {
          "description": "Sku: The SKU of the Redis cache to deploy.",
          "properties": {
            "capacity": {
              "description": "Capacity: The size of the Redis cache to deploy. Valid values: for C (Basic/Standard) family (0, 1, 2, 3, 4, 5, 6), for\nP (Premium) family (1, 2, 3, 4).",
              "type": "integer"
            },
            "family": {
              "description": "Family: The SKU family to use. Valid values: (C, P). (C = Basic/Standard, P = Premium).",
              "type": "string"
            },
            "name": {
              "description": "Name: The type of Redis cache to deploy. Valid values: (Basic, Standard, Premium)",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "sslPort": {
          "description": "SslPort: Redis SSL port.",
          "type": "integer"
        },
        "staticIP": {
          "description": "StaticIP: Static IP address. Optionally, may be specified when deploying a Redis cache inside an existing Azure Virtual\nNetwork; auto assigned by default.",
          "type": "string"
        },
        "subnetId": {
          "description": "SubnetId: The full resource ID of a subnet in a virtual network to deploy the Redis cache in. Example format:\n/subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/Microsoft.{Network|ClassicNetwork}/VirtualNetworks/vnet1/subnets/subnet1",
          "type": "string"
        },
        "tags": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "Tags: Resource tags.",
          "type": "object"
        },
        "tenantSettings": {
          "additionalProperties": {
            "type": "string"
          },
          "description": "TenantSettings: A dictionary of tenant settings",
          "type": "object"
        },
        "type": {
          "description": "Type: The type of the resource. E.g. \"Microsoft.Compute/virtualMachines\" or \"Microsoft.Storage/storageAccounts\"",
          "type": "string"
        },
        "zones": {
          "description": "Zones: A list of availability zones denoting where the resource needs to come from.",
          "items": {
            "type": "string"
          },
          "type": "array"
        }
      },
      "type": "object",
      "additionalProperties": false
    }
  },
  "type": "object"
}
