Как определить объект с проверяемым именем в схеме JSON? - PullRequest
0 голосов
/ 26 февраля 2019

Я хочу создать схему JSON для этого примера JSON "псевдокод":

{
    "xyz": {
        "$something": {
            "property_a": "...",
            "property_b": "...",
            "property_c": "..."
        }
    }
}

$something может быть одной из следующих строк: foo, bar или buz.Моя текущая схема выглядит так:

{
  "xyz": {
    "id": "xyz",
    "type": "object",
    "properties": {
      "foo": {
        "id": "foo",
        "type": "object",
        "additionalProperties": false,
        "required": ["property_a"],
        "properties": {
          "property_a": {
            "id": "property_a",
            "type": "string"
          },
          "property_b": {
            "id": "property_b",
            "type": "string"
          },
          "property_c": {
            "id": "property_a",
            "type": "string"
          }
        }
      },
      "bar": {
        ... copy&paste foo
      },
      "buz": {
        ... copy&paste foo
      }
    }
  }
}

Это работает, но это очень дублированный код.Поэтому я ищу более элегантный способ его реализации.

Как определить список значений (ложь enum), разрешенных в качестве имени для свойства в схеме JSON?

1 Ответ

0 голосов
/ 27 февраля 2019

patternProperties работает как свойства, за исключением того, что ключи объекта являются регулярными выражениями.

https://tools.ietf.org/html/draft-handrews-json-schema-validation-01#section-6.5.5

Пример с сайта Понимание схемы JSON

{
  "type": "object",
  "patternProperties": {
    "^S_": { "type": "string" },
    "^I_": { "type": "integer" }
  },
  "additionalProperties": false
}

В этом примере любые дополнительные свойства, имена которых начинаются с префикса S_, должны быть строками, а любые с префиксом I_ - целыми числами.Любые свойства, явно определенные в ключевом слове properties, также принимаются, и любые дополнительные свойства, которые не соответствуют ни одному регулярному выражению, запрещены.

...