webpractik/bitrixoa

A package for generating annotations and drawing SwUi when working with Bitrix controllers.

Maintainers

Package info

github.com/webpractik/bitrixoa

pkg:composer/webpractik/bitrixoa

Statistics

Installs: 8 821

Dependents: 0

Suggesters: 0

Stars: 40

Open Issues: 4

1.3.0 2026-06-08 09:15 UTC

This package is auto-updated.

Last update: 2026-06-08 09:17:37 UTC


README

Пакет для генерации 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

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