web-dev-qa-db-ja.com

異なるタイプのアイテムの配列のJSONスキーマを修正する

JSONアイテムの順序なし配列があります。仕様によると http://tools.ietf.org/html/draft-zyp-json-schema-03#section-5.5 以下のjsonスキーマは、配列内のオブジェクトが表示される場合にのみ検証しますその順序で。オブジェクトの順序や数に関係なく、配列内のオブジェクトを検証するだけで、順序を指定したくありません。仕様から、これがどのように行われるのか理解できないようです。

"transactions" : {
    "type" : "array",
    "items" : [
        {
            "type" : "object",
            "properties" : {
                "type" : {
                    "type" : "string",
                    "enum" : ["BUILD", "REASSIGN"]
                }
            }
        },
        {
            "type" : "object",
            "properties" : {
                "type" : {
                    "type" : "string",
                    "enum" : ["BREAK"]
                }
            }
        }
    ]
}
24
deepwinter

JSONスキーマgoogleグループでこれと同じ質問をしたところ、すぐに答えられました。ユーザーfgeは、彼の応答をここに投稿するように依頼しました。

こんにちは、

現在の仕様は、ドラフトv3ではなくドラフトv4です。より具体的には、検証仕様は次のとおりです。

http://tools.ietf.org/html/draft-fge-json-schema-validation-

Webサイトは最新ではありません。理由がわかりません...プルリクエストを送信します。

ドラフトv4では、これを使用できます。

{
    "type": "array",
    "items": {
        "oneOf": [
            {"first": [ "schema", "here" ] }, 
            {"other": [ "schema": "here" ] }
        ]
    }  
}

たとえば、これはアイテムが文字列または整数のいずれかになる配列のスキーマです(ただし、より簡単な方法で記述できます)。

{
    "type": "array",
    "items": {
        "oneOf": [
            {"type": "string"},
            {"type": "integer"}
        ]
    }
}

これは正解です。修正されたスキーマには以下が含まれます。

"transactions" : {
    "type" : "array",
    "items" : {
        "oneOf" : [
            {
                "type" : "object",
                "properties" : {
                    "type" : {
                        "type" : "string",
                        "enum" : ["BUILD", "REASSIGN"]
                    }
                }
            },
            {
               "type" : "object",
               "properties" : {
                 "type" : {
                   "type" : "string",
                   "enum" : ["BREAK"]
                  }
               }
            }
        ]
    }
}
43
deepwinter

私もこれをかなり長い間探していました。しかし、有効なソリューションを見つけることができませんでした。たとえば、スキーマが1つしかない場合は正常に機能します。

"transactions" : {
          "type" : "array",
          "items" : 
          {
            "type" : "object",
            "properties" : {
              "type" : {
                "type" : "string",
                "enum" : ["BREAK"]
              },
          }
}

次に、配列括弧をスキップして、オブジェクトを使用します。しかし、あなたがやっていることをやりたいなら、確かな答えはないようです。これは私がこれまでに見つけた唯一のものです: http://the-long-dark-tech-time.blogspot.se/2012/12/using-json-schema-with-array-of -mixed.html

3
Jonas Kac

ドラフト3スキーマにこだわっている人向け。ドラフト4の「anyOf」に相当する「Type」キーワードがあります。

使用できます

{
    "fooBar" : {
        "type" : "array",
        "items" : {
            "type" : [{
                    "type" : "object",
                    "properties" : {
                        "foo" : {                           
                            "type" : "string"
                        }
                    }
                }, {
                    "type" : "object",
                    "properties" : {
                        "bar" : {
                            "type" : "string"
                        }
                    }
                }
            ]
        }
    }
}
1
Vdex

ユーザーVdexへの応答として:これは同等ではありません、あなたが書いたことは、配列要素がこの特定の順序で発生することを意味します配列内。

this schema validator を使用する場合、正しい実装に従う必要があります。

このスキーマでは:

{
  "$schema": "http://json-schema.org/draft-04/schema#",
  "type": "array",
  "items": [
    {
      "type": "boolean"
    },
    {
      "type": "number"
    },
    {
      "type": "string"
    }
  ]
}

このJSONは検証されます。

[
  true,
  5,
  "a",
  "6",
  "a",
  5.2
]

しかし、これではありません:

[
  5,
  true,
  "a",
  "6",
  "a",
  5.2
]

したがって、目的は「oneOf」などのキーワードとはまったく異なります。

1
Cwellan