{
  "description": "Generator information:\n- Generated from: /cdn/resource-manager/Microsoft.Cdn/stable/2023-05-01/afdx.json\n- ARM URI: /subscriptions/{subscriptionId}/resourceGroups/{resourceGroupName}/providers/Microsoft.Cdn/profiles/{profileName}/afdEndpoints/{endpointName}/routes/{routeName}",
  "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"
        },
        "cacheConfiguration": {
          "description": "CacheConfiguration: The caching configuration for this route. To disable caching, do not provide a cacheConfiguration\nobject.",
          "properties": {
            "compressionSettings": {
              "description": "CompressionSettings: compression settings.",
              "properties": {
                "contentTypesToCompress": {
                  "description": "ContentTypesToCompress: List of content types on which compression applies. The value should be a valid MIME type.",
                  "items": {
                    "type": "string"
                  },
                  "type": "array"
                },
                "isCompressionEnabled": {
                  "description": "IsCompressionEnabled: Indicates whether content compression is enabled on AzureFrontDoor. Default value is false. If\ncompression is enabled, content will be served as compressed if user requests for a compressed version. Content won't be\ncompressed on AzureFrontDoor when requested content is smaller than 1 byte or larger than 1 MB.",
                  "type": "boolean"
                }
              },
              "type": "object",
              "additionalProperties": false
            },
            "queryParameters": {
              "description": "QueryParameters: query parameters to include or exclude (comma separated).",
              "type": "string"
            },
            "queryStringCachingBehavior": {
              "description": "QueryStringCachingBehavior: Defines how Frontdoor caches requests that include query strings. You can ignore any query\nstrings when caching, ignore specific query strings, cache every request with a unique URL, or cache specific query\nstrings.",
              "enum": [
                "IgnoreQueryString",
                "IgnoreSpecifiedQueryStrings",
                "IncludeSpecifiedQueryStrings",
                "UseQueryString"
              ],
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "customDomains": {
          "description": "CustomDomains: Domains referenced by this endpoint.",
          "items": {
            "description": "Reference to another resource along with its state.",
            "properties": {
              "reference": {
                "description": "Reference: 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
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "enabledState": {
          "description": "EnabledState: Whether to enable use of this rule. Permitted values are 'Enabled' or 'Disabled'",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "type": "string"
        },
        "forwardingProtocol": {
          "description": "ForwardingProtocol: Protocol this rule will use when forwarding traffic to backends.",
          "enum": [
            "HttpOnly",
            "HttpsOnly",
            "MatchRequest"
          ],
          "type": "string"
        },
        "httpsRedirect": {
          "description": "HttpsRedirect: Whether to automatically redirect HTTP traffic to HTTPS traffic. Note that this is a easy way to set up\nthis rule and it will be the first rule that gets executed.",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "type": "string"
        },
        "linkToDefaultDomain": {
          "description": "LinkToDefaultDomain: whether this route will be linked to the default endpoint domain.",
          "enum": [
            "Disabled",
            "Enabled"
          ],
          "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
        },
        "originGroup": {
          "description": "OriginGroup: A reference to the origin group.",
          "properties": {
            "reference": {
              "description": "Reference: 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
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "originPath": {
          "description": "OriginPath: A directory path on the origin that AzureFrontDoor can use to retrieve content from, e.g.\ncontoso.cloudapp.net/originpath.",
          "type": "string"
        },
        "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 cdn.azure.com/AfdEndpoint 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
        },
        "patternsToMatch": {
          "description": "PatternsToMatch: The route patterns of the rule.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "ruleSets": {
          "description": "RuleSets: rule sets referenced by this endpoint.",
          "items": {
            "description": "Reference to another resource.",
            "properties": {
              "reference": {
                "description": "Reference: 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
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "supportedProtocols": {
          "description": "SupportedProtocols: List of supported protocols for this route.",
          "items": {
            "description": "Supported protocols for the customer's endpoint.",
            "enum": [
              "Http",
              "Https"
            ],
            "type": "string"
          },
          "type": "array"
        }
      },
      "required": [
        "owner"
      ],
      "type": "object",
      "additionalProperties": false
    },
    "status": {
      "properties": {
        "cacheConfiguration": {
          "description": "CacheConfiguration: The caching configuration for this route. To disable caching, do not provide a cacheConfiguration\nobject.",
          "properties": {
            "compressionSettings": {
              "description": "CompressionSettings: compression settings.",
              "properties": {
                "contentTypesToCompress": {
                  "description": "ContentTypesToCompress: List of content types on which compression applies. The value should be a valid MIME type.",
                  "items": {
                    "type": "string"
                  },
                  "type": "array"
                },
                "isCompressionEnabled": {
                  "description": "IsCompressionEnabled: Indicates whether content compression is enabled on AzureFrontDoor. Default value is false. If\ncompression is enabled, content will be served as compressed if user requests for a compressed version. Content won't be\ncompressed on AzureFrontDoor when requested content is smaller than 1 byte or larger than 1 MB.",
                  "type": "boolean"
                }
              },
              "type": "object",
              "additionalProperties": false
            },
            "queryParameters": {
              "description": "QueryParameters: query parameters to include or exclude (comma separated).",
              "type": "string"
            },
            "queryStringCachingBehavior": {
              "description": "QueryStringCachingBehavior: Defines how Frontdoor caches requests that include query strings. You can ignore any query\nstrings when caching, ignore specific query strings, cache every request with a unique URL, or cache specific query\nstrings.",
              "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"
        },
        "customDomains": {
          "description": "CustomDomains: Domains referenced by this endpoint.",
          "items": {
            "description": "Reference to another resource along with its state.",
            "properties": {
              "id": {
                "description": "Id: Resource ID.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "deploymentStatus": {
          "type": "string"
        },
        "enabledState": {
          "description": "EnabledState: Whether to enable use of this rule. Permitted values are 'Enabled' or 'Disabled'",
          "type": "string"
        },
        "endpointName": {
          "description": "EndpointName: The name of the endpoint which holds the route.",
          "type": "string"
        },
        "forwardingProtocol": {
          "description": "ForwardingProtocol: Protocol this rule will use when forwarding traffic to backends.",
          "type": "string"
        },
        "httpsRedirect": {
          "description": "HttpsRedirect: Whether to automatically redirect HTTP traffic to HTTPS traffic. Note that this is a easy way to set up\nthis rule and it will be the first rule that gets executed.",
          "type": "string"
        },
        "id": {
          "description": "Id: Resource ID.",
          "type": "string"
        },
        "linkToDefaultDomain": {
          "description": "LinkToDefaultDomain: whether this route will be linked to the default endpoint domain.",
          "type": "string"
        },
        "name": {
          "description": "Name: Resource name.",
          "type": "string"
        },
        "originGroup": {
          "description": "OriginGroup: A reference to the origin group.",
          "properties": {
            "id": {
              "description": "Id: Resource ID.",
              "type": "string"
            }
          },
          "type": "object",
          "additionalProperties": false
        },
        "originPath": {
          "description": "OriginPath: A directory path on the origin that AzureFrontDoor can use to retrieve content from, e.g.\ncontoso.cloudapp.net/originpath.",
          "type": "string"
        },
        "patternsToMatch": {
          "description": "PatternsToMatch: The route patterns of the rule.",
          "items": {
            "type": "string"
          },
          "type": "array"
        },
        "provisioningState": {
          "description": "ProvisioningState: Provisioning status",
          "type": "string"
        },
        "ruleSets": {
          "description": "RuleSets: rule sets referenced by this endpoint.",
          "items": {
            "description": "Reference to another resource.",
            "properties": {
              "id": {
                "description": "Id: Resource ID.",
                "type": "string"
              }
            },
            "type": "object",
            "additionalProperties": false
          },
          "type": "array"
        },
        "supportedProtocols": {
          "description": "SupportedProtocols: List of supported protocols for this route.",
          "items": {
            "description": "Supported protocols for the customer's endpoint.",
            "type": "string"
          },
          "type": "array"
        },
        "systemData": {
          "description": "SystemData: Read only system data",
          "properties": {
            "createdAt": {
              "description": "CreatedAt: The timestamp of resource creation (UTC)",
              "type": "string"
            },
            "createdBy": {
              "description": "CreatedBy: An identifier for 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: An identifier for 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
        },
        "type": {
          "description": "Type: Resource type.",
          "type": "string"
        }
      },
      "type": "object",
      "additionalProperties": false
    }
  },
  "type": "object"
}
