Nano Hash - криптовалюты, майнинг, программирование

Есть ли способ избежать дублирования методов HTTP в определении Swagger YAML?

Я пишу спецификацию API, для которой хочу, чтобы функции PUT и PATCH были идентичными. Не имеет значения, получает ли API запрос PUT или PATCH. Он будет делать то же самое.

Есть ли для этого сокращенный/ссылочный синтаксис, который не позволил бы мне копировать и вставлять параметры, ответы и т. д. из определения метода PUT в определение метода PATCH?

07.06.2017

  • короткий ответ, нет. У вас не может быть операции с двумя методами. Технически можно, но выполнять их из ui не получится, поэтому придется модифицировать swagger ui, что нецелесообразно. 07.06.2017

Ответы:


1

No.

Хотя спецификация OpenAPI (fka Swagger) 2.0 поддерживает $ref в некоторых местах определения API, она не поддерживается на уровне операций. Поэтому вам нужно иметь отдельные определения для PUT и PATCH. Вы можете несколько уменьшить дублирование кода, $refing параметры и ответы внутри каждой операции.

paths:
  /foo:
    # If ALL operations within a path have some common parameters,
    # define these params on the path level instead
    # parameters:
    #  - $ref: '#/parameters/baz'

    put:
      parameters:
        - $ref: '#/parameters/baz'
      responses:
        200:
          $ref: '#/responses/Success'
        default:
          $ref: '#/responses/Error'
    patch:
      parameters:
        - $ref: '#/parameters/baz'
      responses:
        200:
          $ref: '#/responses/Success'
        default:
          $ref: '#/responses/Error'

parameters:
  baz:
    in: query
    name: baz
    type: string

responses:
  Success:
    description: Operation completed successfully
    schema:
      type: object
      ...
  Error:
    description: Error response
    schema:
      type: object
      ...
07.06.2017
  • Хорошо, я так и думал. Лучше чем ничего! 08.06.2017
  • Новые материалы

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

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..