Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   JsonSchema: взаимосвязь типов и их значений (https://javascript.ru/forum/misc/50665-jsonschema-vzaimosvyaz-tipov-i-ikh-znachenijj.html)

XelaNimed 06.10.2014 18:17

JsonSchema: взаимосвязь типов и их значений
 
Всем доброго и продуктивного времени суток.
Недавно столкнулся с необходимостью описать структуру Json для ее проверки и после недолгого поиска в интернете было найдено возможное решение JsonSchema. Полное описание возможных параметров и их значений на великом и могучем найдено не было, но суть не в этом.
Типичная сфера применения JsonSchema - это проверка корректности всевозможных API запросов и ответов. И если при описании типов, формата строки, обязательности параметра или макс. мин. количества элементов и т.д. никаких проблем не возникает, то при попытке описать взаимосвязь/взаимозависимость параметров друг от друга сталкиваюсь с проблемой. Объясню на примере. К примеру имеем следующий объект:
var obj = {
  // anything...
  "sqlServer1" : "FULL.QUALIFIED.NAME1",
  "dbName1"    : "dbOne",
  "dbTable1"   : "tablOne",
  "cols1"      : ["col1_1", "col1_2", "col1_3"],
  // anything...
  "sqlServer2" : "FULL.QUALIFIED.NAME2",
  "dbName2"    : "dbTwo",
  "dbTable2"   : "tablTwo",
  "cols2"      : ["col2_1", "col2_2", "col2_3"]
};

В приведенном примере можно с легкостью описать (стандартными средствами JsonSchema) и проверить (например при использовании Tiny Validator возможно добавление собственных функций проверки) тип значений, и даже описать с помощью pattern синтаксис. Но как описать, что свойство dbName1 относится к sqlServer1, dbTable1 относится к dbName1, cols1 относится к dbTable1? И самое главное, как затем это проверить?
Прихожу к выводу, что JsonSchema для таких задач не подходит и придется мастерить свой велосипед с сопутствующими костылями и т.д.. Но все еще теплится надежда, что я не прав и возможно использовать уже сущствующие библиотеки JsonSchema для своего проекта.
Буду рад любым конструктивным предложениям и подсказкам в какую сторону копать для решения моей проблемы. Заранее всем спасибо за уделенное время и помощь.

XelaNimed 07.10.2014 21:38

Всем доброго времени суток.
Сразу извиняюсь за поднятие темы, но все таки прошу знающих людей подсказать советом/словом/ссылкой. Может JsonSchema не подходит для описанных задач и есть другое решение?!


Часовой пояс GMT +3, время: 02:25.