Валидация данных HTTP сервиса с помощью Json Schema на основе OpenAPI

15.05.25

Интеграция - WEB-интеграция

Описываю вариант формирования Json Schema из OpenAPI и валидации данных на её основе.

Вводные

Требуется проверить входящие данные в HTTP сервисе в формате JSON. Использование проверки кодом сформированного вручную неудобно.

Наличие описания HTTP сервиса в формате OpenAPI https://spec.openapis.org/oas/v3.1.1.html.

 

 

 

Вариант решения

Получение файла схемы.

В OpenAPI версии 3.1 формат данных приведен к JSON Schema 2020-12

Типы данных в OAS основаны на типах, определённых в проекте спецификации JSON Schema Validation 2020-12: null, булево, объект, массив, число, строка или целое число. Модели определяются с помощью объекта Schema, который является расширенной версией спецификации JSON Schema 2020-12. (https://swagger.io/specification/)

поэтому для формирования схемы только требуется добавить "$schema": "https://json-schema.org/draft/2020-12/schema".

Для упрощения использования описание объектов выделяю в отдельные файлы. Выдержка из корневого файла.

  requestBody:
	content:
	  application/json:
		schema:
		  type: array
		  items:
			$ref: "./Order.yml"

Описание объекта, выдержка (Order.yml)

type: object
properties:
  order_id:
    type: string
    description: Уникальный идентификатор заказа
  created_at:
    type: string
    format: date-time
    description: "Дата создания заказа"
  updated_at:
    type: string
    format: date-time
    description: "Дата обновления заказа"
  header:
    description: "Заголовок заказа"
    type: object
    properties:
      confirmation_method:
        description: "Метод подтверждения заказа"
        type: string
        enum:
          - sms
          - email
          - whatsapp
          - phone
      status:
        description: "Статус заказа"
        type: string
        enum:
          - canceled
          - created

 

Описание в формате YAML. Для преобразования в JSON с добавлением "$schema" использую скрипт (convert.js).

const yaml = require('js-yaml');
const fs = require('fs');

filename = "Order";

// Get document, or throw exception on error
try {
    const doc = yaml.load(fs.readFileSync(`./${filename}.yml`, 'utf8'));
    //console.log(doc);
    doc["$schema"] = "https://json-schema.org/draft/2020-12/schema";
    content = JSON.stringify(doc, null, 2);

    fs.writeFileSync(`./${filename}.json`, content);

} catch (e) {
    console.log(e);
}

Запускаю скрипт

node convert.js

В результате получаю Order.json

{
  "type": "object",
  "properties": {
    "order_id": {
      "type": "string",
      "description": "Уникальный идентификатор заказа"
    },
    "created_at": {
      "type": "string",
      "format": "date-time",
      "description": "Дата создания заказа"
    },
...
  "$schema": "https://json-schema.org/draft/2020-12/schema"
}

 

Валидация используя схему

Для валидации использую внешнюю компоненту https://github.com/Toveal/jsonschema-1c

Схему поместил в макет.

Модуль проверки изменил под свою задачу

	СхемаЗаказ = ПолучитьОбщийМакет("Заказ_Схема").ПолучитьТекст();
	
	ТелоЗаказ = КоннекторHTTP.ОбъектВJson(СтруктураЗаказ);
	
	БуферОшибок = ПроверитьТелоЗапроса(ТелоЗаказ, СхемаЗаказ, Отказ);
	
	Если БуферОшибок <> Неопределено Тогда
		Отказ = Истина;
		СтруктураОтвет.Вставить("errors", КоннекторHTTP.JsonВОбъект(БуферОшибок));	
	ИначеЕсли Отказ Тогда
		МассивОшибок = Новый Массив;
		МассивОшибок.Добавить("Ошибка валидатора JSON");
		СтруктураОтвет.Вставить("errors", МассивОшибок);	
	КонецЕсли;

...

Функция ПроверитьТелоЗапроса(ТелоЗаказ, СхемаЗаказ, Отказ = Ложь) Экспорт

	БуферОшибок = Неопределено;
	
	КомпонентаПодключена = ПодключитьВнешнююКомпоненту(ПутьККомпоненте(), "JsonСхема",
		ТипВнешнейКомпоненты.Native, ТипПодключенияВнешнейКомпоненты.НеИзолированно);

		Если Не КомпонентаПодключена Тогда
			Отказ = Истина;
		Возврат БуферОшибок;
	КонецЕсли;

	КомпонентаОбъект = Новый ("AddIn.JsonСхема.JsonSchema1C");

		// Отключение доп. форматов
	КомпонентаОбъект.ИспользоватьДопФорматы = Ложь;

	// Установка основной схемы
	Попытка
		КомпонентаОбъект.УстановитьОсновнуюСхему(СхемаЗаказ);
	Исключение
	    Сообщить(КомпонентаОбъект.ПолучитьПоследнююОшибку());
		Отказ = Истина;
		Возврат БуферОшибок;
	КонецПопытки;

	// Установка формата вывода
	КомпонентаОбъект.Формат = "Ошибка: {error}, в: {path}";

	// Подробная проверка
	// Буфер в любом случае будет преобразован в строку
	Попытка
		Действителен = КомпонентаОбъект.Проверить(ТелоЗаказ, БуферОшибок);
	Исключение
		Сообщить(КомпонентаОбъект.ПолучитьПоследнююОшибку());
		Отказ = Истина;
	КонецПопытки;

	Возврат БуферОшибок;

КонецФункции

 

Результат

Без дополнительного кода получил проверку входящих данных по актуальной версии схемы.

Для изменения валидатора нужно только поправить и сконвертировать описание сервиса.

Схема упрощенная, как использовать вложенные объекты ("$ref:") нужно разобраться.

Генераторы для приложений https://openapi-generator.tech/docs/generators не пользуют схему, а конвертируют в код на целевом языке с учетом фреймворка.

Схема OpenAPI схожа со схемой AsyncAPI https://www.asyncapi.com/docs/tutorials/getting-started/coming-from-openapi, и ту же схему можно применять при валидации для асинхронных обменов.

 

Благодарю за внимание.

OpenAPI JSON Schema валидация

См. также

WEB-интеграция Администрирование веб-серверов Платные (руб)

Веб-портал обеспечивает удобный доступ к конфигурации 1С:ITIL(ИТИЛ), 1С:ITILIUM, Управление IT-отделом 8 через интернет с любого устройства посредством браузера, увеличивая эффективность работы пользователей и снижая нагрузку на сервер. Быстрая инсталляция портала за пару часов, удобный и интуитивно понятный интерфейс и безопасность данных помогут упростить работу с порталом и ускорить выполнение бизнес-процессов компании.

128000 руб.

19.12.2023    4576    5    0    

11

WEB-интеграция Анализ продаж Системный администратор Программист Пользователь Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х Управленческий учет Платные (руб)

Модуль "Подсистема интеграции AmoCRM с 1С" позволяет обеспечить единое информационное пространство, в котором пользователи могут эффективно управлять клиентской базой, следить за статусами сделок и поддерживать актуальность данных как в AmoCRM, так и в 1С.

60000 руб.

07.05.2019    35922    71    45    

30

Оптовая торговля Розничная торговля WEB-интеграция 1С:Управление торговлей 10 1С:Управление производственным предприятием 1С:Управление нашей фирмой 1.6 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 Платные (руб)

Онлайн-заказ - это решение для автоматизации процесса оформления заказов на сайте в торговых организациях. Продукт обеспечивает легкое взаимодействие между компанией и клиентами через веб-интерфейс, интегрированный с 1С:Предприятие. Система позволяет снизить операционные расходы, повысить лояльность клиентов и оптимизировать работу отдела продаж.

57600 руб.

26.11.2024    3353    3    3    

5

Сайты и интернет-магазины WEB-интеграция Системный администратор Программист Пользователь Платформа 1С v8.3 1C:Бухгалтерия 1С:Управление торговлей 11 Автомобили, автосервисы Россия Управленческий учет Платные (руб)

Интеграционный модуль обмена между конфигурацией Альфа Авто 5 и Альфа Авто 6 и порталом AUTOCRM. Данный модуль универсален. Позволяет работать с несколькими обменами AUTOCRM разных брендов в одной информационной базе в ручном и автоматическом режиме.

36000 руб.

03.08.2020    19741    26    24    

22

WEB-интеграция Программист Бизнес-аналитик Платформа 1С v8.3 1С:ERP Управление предприятием 2 1С:Бухгалтерия 3.0 1С:Управление торговлей 11 1С:Комплексная автоматизация 2.х 1С:Управление нашей фирмой 3.0 1С:Розница 3.0 Оптовая торговля, дистрибуция, логистика ИТ-компания Платные (руб)

Модуль "Экспортер" — это расширение для 1С, предназначенное для автоматизации процессов выгрузки данных. Оно позволяет эффективно извлекать, преобразовывать и передавать данные из систем 1С в интеграционную платформу Spot2D. Подсистема упрощает настройку, снижает количество ручных операций и обеспечивает удобный контроль данных.

14400 руб.

20.12.2024    1421    9    2    

11

WEB-интеграция Программист Руководитель проекта Платформа 1С v8.3 1C:Бухгалтерия 1С:Франчайзи, автоматизация бизнеса Платные (руб)

Расширение значительно упрощает написание API на 1С. Веб программисты получают простой и понятный доступ к 1С. Описание API создаётся автоматически и представляется в виде удобном как для человека, так и для программной обработки.

24000 руб.

27.09.2024    5627    5    2    

6

Сайты и интернет-магазины Интеграция WEB-интеграция Платформа 1С v8.3 1C:Бухгалтерия Управленческий учет Платные (руб)

Решение осуществляет синхронизацию задач Битрикс24 и 1С, что позволяет в одной системе ставить задачи, контролировать выполнение всего пула задач с группировкой по ответственным и проектам, формировать управленческие отчеты по работе сотрудников (загрузка, просроченные задачи), уведомлять сотрудников о ходе выполнения задач посредством чат-бот Telegram

7200 руб.

04.05.2021    21347    14    19    

19
Оставьте свое сообщение