Kora облачно ориентированный серверный фреймворк написанный на Java для написания Java / Kotlin приложений с упором на производительность, эффективность, прозрачность сделанный разработчиками Т-Банк / Тинькофф

Kora is a cloud-oriented server-side Java framework for writing Java / Kotlin applications with a focus on performance, efficiency and transparency made by T-Bank / Tinkoff developers

Перейти к содержанию

OpenAPI отображение

Модуль для предоставления OpenAPI файла из приложения, а также Swagger UI и Rapidoc для отображения OpenAPI.

Подключение

Зависимость build.gradle:

implementation "ru.tinkoff.kora:openapi-management"

Модуль:

@KoraApp
public interface Application extends OpenApiManagementModule { }

Зависимость build.gradle.kts:

implementation("ru.tinkoff.kora:openapi-management")

Модуль:

@KoraApp
interface Application : OpenApiManagementModule

Требует подключения HTTP сервера.

Конфигурация

Пример конфигурации описанной в классе OpenApiManagementConfig:

openapi {
    management {
        file = [ "my-openapi-1.yaml", "my-openapi-2.yaml" ] //(1)!
        enabled = false  //(2)!
        endpoint = "/openapi" //(3)!
        swaggerui {
            enabled = false //(4)!
            endpoint = "/swagger-ui" //(5)!
        }
        rapidoc {
            enabled = false //(6)!
            endpoint = "/rapidoc" //(7)!
        }
    }
}
  1. Относительный путь до OpenAPI файлов в resources директории, можно указывать как один файл, так и несколько файлов
  2. Вкл/Выкл контроллера который отдает OpenAPI
  3. Путь по которому будет доступен OpenAPI
    1. Если указан один OpenAPI файл, является целиком путем по которому доступен файл
    2. Если указаны несколько OpenAPI файлов, является префиксом к пути перед именем файла /openapi/{fileName}, берется указанный путь и к нему добавляется имя файла без диреторий и его расширения, в случае файла someDirectory/my-openapi-1.yaml путь к файлу будет /openapi/my-openapi-1
  4. Вкл/Выкл контроллера который отдает SwaggerUI
  5. Путь по которому будет доступен SwaggerUI
  6. Вкл/Выкл контроллера который отдает Rapidoc
  7. Путь по которому будет доступен Rapidoc
openapi:
  management:
    file: [ "my-openapi-1.yaml", "my-openapi-2.yaml" ] #(1)!
    enabled: false  #(2)!
    endpoint: "/openapi" #(3)!
    swaggerui:
      enabled: false #(4)!
      endpoint: "/swagger-ui" #(5)!
    rapidoc:
      enabled: false #(6)!
      endpoint: "/rapidoc" #(7)!
  1. Относительный путь до OpenAPI файлов в resources директории, можно указывать как один файл, так и несколько файлов
  2. Вкл/Выкл контроллера который отдает OpenAPI
  3. Путь по которому будет доступен OpenAPI
    1. Если указан один OpenAPI файл, является целиком путем по которому доступен файл
    2. Если указаны несколько OpenAPI файлов, является префиксом к пути перед именем файла /openapi/{fileName}, берется указанный путь и к нему добавляется имя файла без диреторий и его расширения, в случае файла someDirectory/my-openapi-1.yaml путь к файлу будет /openapi/my-openapi-1
  4. Вкл/Выкл контроллера который отдает SwaggerUI
  5. Путь по которому будет доступен SwaggerUI
  6. Вкл/Выкл контроллера который отдает Rapidoc
  7. Путь по которому будет доступен Rapidoc

Рекомендации

Совет

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

В случае же когда первичен код и по нему предполагается создавать файл контракт, можно использовать Swagger Gradle Plugin вкупе с набором Swagger аннотаций по которым будет создаваться файл контракт.