95 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JSON
		
	
	
	
	
	
			
		
		
	
	
			95 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			JSON
		
	
	
	
	
	
{
 | 
						|
  "$schema": "http://json-schema.org/draft-07/schema#",
 | 
						|
  "$id": "https://raw.githubusercontent.com/ajv-validator/ajv/master/lib/refs/json-schema-secure.json#",
 | 
						|
  "title": "Meta-schema for the security assessment of JSON Schemas",
 | 
						|
  "description": "If a JSON Schema fails validation against this meta-schema, it may be unsafe to validate untrusted data",
 | 
						|
  "definitions": {
 | 
						|
    "schemaArray": {
 | 
						|
      "type": "array",
 | 
						|
      "minItems": 1,
 | 
						|
      "items": {"$ref": "#"}
 | 
						|
    }
 | 
						|
  },
 | 
						|
  "dependencies": {
 | 
						|
    "patternProperties": {
 | 
						|
      "description": "prevent slow validation of large property names",
 | 
						|
      "required": ["propertyNames"],
 | 
						|
      "properties": {
 | 
						|
        "propertyNames": {
 | 
						|
          "required": ["maxLength"]
 | 
						|
        }
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "uniqueItems": {
 | 
						|
      "description": "prevent slow validation of large non-scalar arrays",
 | 
						|
      "if": {
 | 
						|
        "properties": {
 | 
						|
          "uniqueItems": {"const": true},
 | 
						|
          "items": {
 | 
						|
            "properties": {
 | 
						|
              "type": {
 | 
						|
                "anyOf": [
 | 
						|
                  {
 | 
						|
                    "enum": ["object", "array"]
 | 
						|
                  },
 | 
						|
                  {
 | 
						|
                    "type": "array",
 | 
						|
                    "contains": {"enum": ["object", "array"]}
 | 
						|
                  }
 | 
						|
                ]
 | 
						|
              }
 | 
						|
            }
 | 
						|
          }
 | 
						|
        }
 | 
						|
      },
 | 
						|
      "then": {
 | 
						|
        "required": ["maxItems"]
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "pattern": {
 | 
						|
      "description": "prevent slow pattern matching of large strings",
 | 
						|
      "required": ["maxLength"]
 | 
						|
    },
 | 
						|
    "format": {
 | 
						|
      "description": "prevent slow format validation of large strings",
 | 
						|
      "required": ["maxLength"]
 | 
						|
    }
 | 
						|
  },
 | 
						|
  "properties": {
 | 
						|
    "additionalItems": {"$ref": "#"},
 | 
						|
    "additionalProperties": {"$ref": "#"},
 | 
						|
    "dependencies": {
 | 
						|
      "additionalProperties": {
 | 
						|
        "anyOf": [
 | 
						|
          {"type": "array"},
 | 
						|
          {"$ref": "#"}
 | 
						|
        ]
 | 
						|
      }
 | 
						|
    },
 | 
						|
    "items": {
 | 
						|
      "anyOf": [
 | 
						|
        {"$ref": "#"},
 | 
						|
        {"$ref": "#/definitions/schemaArray"}
 | 
						|
      ]
 | 
						|
    },
 | 
						|
    "definitions": {
 | 
						|
      "additionalProperties": {"$ref": "#"}
 | 
						|
    },
 | 
						|
    "patternProperties": {
 | 
						|
      "additionalProperties": {"$ref": "#"}
 | 
						|
    },
 | 
						|
    "properties": {
 | 
						|
      "additionalProperties": {"$ref": "#"}
 | 
						|
    },
 | 
						|
    "if": {"$ref": "#"},
 | 
						|
    "then": {"$ref": "#"},
 | 
						|
    "else": {"$ref": "#"},
 | 
						|
    "allOf": {"$ref": "#/definitions/schemaArray"},
 | 
						|
    "anyOf": {"$ref": "#/definitions/schemaArray"},
 | 
						|
    "oneOf": {"$ref": "#/definitions/schemaArray"},
 | 
						|
    "not": {"$ref": "#"},
 | 
						|
    "contains": {"$ref": "#"},
 | 
						|
    "propertyNames": {"$ref": "#"}
 | 
						|
  }
 | 
						|
}
 |