JSON schema to enforce array contents

前端 未结 2 739
没有蜡笔的小新
没有蜡笔的小新 2021-02-19 01:40

Hi all and thanks in advance.

I am attempting to create a JSON schema to enforce an array to contain one A and B object and N C objects, where A and B are C objects and

相关标签:
2条回答
  • 2021-02-19 02:04

    What you are looking for is called "tuple typing".

    If the value of the items keyword is an array, then the items in the array data must match up with the schema in the corresponding position. Additional items (past the last index) are matched by additionalItems (or are disallowed if additionalItems is false).

    So, roughly what you want is something like:

    {
        "type": "array",
        "items": [
            {"$ref": "#/definitions/itemTypeA"},
            {"$ref": "#/definitions/itemTypeB"}
        ],
        "additionalItems": {"$ref": "#/definitions/itemTypeC"},
        "definitions": {
            ... actual definitions for A/B/C ...
        }
    }
    

    If you want to ensure that A and B exist, then you simply specify a minimum length using minItems, so there are at least two items (which because of "tuple typing", must match up with A and B).

    (This also assumes that A and B are the first items in the array. If that's not what you want, then it gets a bit more complicated - although there is a contains keyword proposed for v5 that would handle that neatly.)

    Slightly more detailed live demo:

    • Valid: [A, B]
    • Invalid: [A, C]
    • Valid: [A, B, C, C]
    0 讨论(0)
  • 2021-02-19 02:20

    I have determined a solution that solves my problem, enforcing that A and B are present within the array, though does so positionally, thus requiring the JSON object I am validating to be ordered in some manner.

    Working Schema

    
    {
      "$schema": "http://json-schema.org/draft-04/schema#",
      "title": "Order dependent solution",
    
      "type": "array",
      "items": [
        {
          "$schema": "http://json-schema.org/draft-04/schema#",
          "title": "A Object",
    
          "type": "object",
          "required": ["id", "name"],
    
          "properties": {
            "id": {
              "type": "integer"
            },
            "name": {
              "type": "string",
              "enum": ["A"]
            }
          },
          "additionalProperties": false
        },
        {
          "$schema": "http://json-schema.org/draft-04/schema#",
          "title": "B Object",
    
          "type": "object",
          "required": ["id", "name"],
    
          "properties": {
            "id": {
              "type": "integer"
            },
            "name": {
              "type": "string",
              "enum": ["B"]
            }
          },
          "additionalProperties": false
        }
      ],
    
      "additionalItems": {
    
        "$schema": "http://json-schema.org/draft-04/schema#",
        "title": "C Object",
    
        "type": "object",
        "required": ["id", "name"],
    
        "properties": {
          "id": {
            "type": "integer"
          },
          "name": {
            "type": "string"
          }
        },
        "additionalProperties": false  
      }
    
    }
    

    This JSON schema validates a JSON array containing a A object at index 0, a B object at index 1, and C objects composing all remaining elements. This solution is usable, and allows me to move forward with development, though a order independent solution would be prefered.

    Any help is appreciated! :)

    PS - These schemas are not optimized, and demonstrate redundancy, which I will remove in the final version by making use of the "id" and "$ref" keyword.

    0 讨论(0)
提交回复
热议问题