Skip to content

webpractik/bitrixoa

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

[bitrixoa] Bitrix OpenApi

Пакет для генерации Swagger UI на основе аннотаций при работе с контроллерами и роутером Bitrix.

Установка

composer install webpractik/bitrixoa

Генерация

./vendor/bin/bitrixoa

Параметры

  1. --bitrix-generate параметр указывает, что openapi необходимо смотреть в директорию local/modules
  2. --index-mode создаст сгенерированный /api-doc/index.php с разметкой swaggerui физически.
  3. --bootstrap (-b) подключить php-файл до сканирования (нужно для swagger-php >=5, см. ниже).

Совместимость со swagger-php 5/6

Пакет работает со swagger-php ^4.6, ^5 и ^6. Ключевые отличия:

  • Способы описания. Поддерживаются и PHP-атрибуты #[OA\...] (предпочтительно в 5/6), и docblock-аннотации @OA\.... Для аннотаций нужен пакет doctrine/annotations (в swagger-php он опционален начиная с 4.8) — он добавлен в зависимости bitrixoa.

  • Рефлексия и bootstrap. В swagger-php >=5 удалён TokenAnalyser, остался только ReflectionAnalyser: чтобы прочитать аннотации/атрибуты, он загружает классы. Контроллеры Bitrix наследуют классы ядра, поэтому генерацию нужно запускать при поднятом ядре — укажите bootstrap-скрипт, инициализирующий Bitrix:

    php vendor/bin/bitrixoa --bitrix-generate -b bootstrap.php

    Пример bootstrap.php (поднимает ядро и подключает модули):

    <?php
    $projectRoot = dirname(__DIR__);
    $_SERVER['DOCUMENT_ROOT'] = $projectRoot . '/public';
    require_once $_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/main/cli/bootstrap.php';
    require_once $projectRoot . '/vendor/autoload.php';
    \Bitrix\Main\Loader::includeModule('vendor.engine');

    Процедурные файлы без классов (admin/*, include.php и т.п.) рефлексия не исполняет — TokenScanner заранее находит имена классов и пропускает файлы без них.

Режимы работы

A. Через нативный bitrix router (v20+)

Если Ваш роутер не настроен, то прочтите Настройка роутера Bitrix:

  1. Добавьте в роутер
use Bitrix\Main\Routing\RoutingConfigurator;

return function (RoutingConfigurator $configurator) {
        $configurator->get('api-doc', [\BitrixOA\BitrixUiController::class, 'apidocAction']);
};
  1. В таком случае документация откроется по адресу /api-doc

B. Через Bitrix Controller без роутера

  1. Создайте в своем модуле файл .settings.php
  2. Задайте корректный namespace и конфигурации для своего модуля
  3. Скопируйте содержимое класса BitrixUiNativeController из этого пакета к себе в модуль, в свой класс-контроллер
  4. Обращайтесь по адресу <адрес сайта>/bitrix/services/main/ajax.php?action=<ваши настройки>

С. Статический UI

Запустить генерацию с флагом --index-mode создаст сгенерированный /api-doc/index.php с разметкой swaggerui физически.

Roadmap

  • Сделать генерацию путей на основе анализа роутера
  • Покрыть тестами

About

Пакет для генерации аннотаций и отрисовки SwUi, при работе с контроллерами Bitrix.

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages