voral / bitrix-module-tool
Extension for vs-version-incrementor to automate building update packages for Bitrix modules.
Requires
- php: ^8.1
- voral/version-increment: ^3.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.66.0
- php-mock/php-mock-phpunit: ^2.13
- phpstan/phpstan: ^2.1
- phpstan/phpstan-phpunit: ^2.0
- phpunit/phpunit: ^10.5
This package is auto-updated.
Last update: 2025-05-30 07:14:09 UTC
README
Расширение для пакета voral/version-increment автоматизирующее пакетов обновления модулей для Битрикс-маркетплейс на основе анализа git коммитов и семантического обновления версии. А так же изменяющее номер версии в файле version.php
Основные функции
При вычислении новой версии утилитой voral/version-increment перед коммитом выполняются следующие этапы по сборке обновления версии:
- Изменение версии модуля в соответствии с обновлением в файле install/version.php. А так же даты версии модуля на текущую. Если это файла нет в модуле - он будет создан.
- На основе анализа коммитов выполненных с предыдущей версии копируются новые и измененные файлы модуля в каталог пакета обновления. Кроме того, при необходимости, добавляется код удаления файлов, которые были удалены из модуля в скрипт обновления
updater.php
Обратите внимание, что функционал удаления упрощенный - перед окончательным оформлением пакета обновлений рекомендую проверить и скорректировать при необходимости
- Если в обновление были добавлены каталоги
install/admin
,install/components
и т.п в скриптupdater.php
добавляется код по их копированию. При этом для каталога admin выполняется не копирование, а создание файлов которые подключают оригинальные. - Если произведена соответствующая настройка в скрипт
updater.php
добавляется проверка версии PHP - Если произведена соответствующая настройка в скрипт
updater.php
добавляется дополнительный кастомный PHP код - На основе коммитов git выполненных с предыдущей версии формируются файлы description.* пакета обновлений
- Если произведена соответствующая настройка генерируется файл контроля версий модулей от которых ваш модуль зависит
- Файлы
updater.php
,description.*
, а так же<путь_к_исходникам>/install/version.php
(если он был создан) добавляются в репозиторий git
Требования
- PHP >= 8.1
- Git установлен и доступен в CLI
- Composer для управления зависимостями
Как пользоваться
Для начала необходимо установить пакет
composer require -dev voral/bitrix-module-tool
Если у вас до этого не был установлен пакет voral/version-increment - он будет установлен и необходимо будет произвести настройку согласно документации. А так же подключить данный пакет в файле .vs-version-increment.php
use Vasoft\VersionIncrement\Config; use Vasoft\VersionIncrement\Events\EventType; use Voral\BitrixModuleTool\ModuleListener; $config = new Config(); $eventBus = $config->getEventBus(); $listener = new ModuleListener( $config, 'vendor.module', includePhpFile: __DIR__ . '/updates/update_include.php', ); $eventBus->addListener(EventType::BEFORE_VERSION_SET, $listener); // прочие настройки return $config;
Т.к., как правило, есть необходимость доработать пакет обновлений перед загрузкой на маркетплейс (например перевести языковые description.*), рекомендую команду обновления версии выполнять с флагом отключающим коммит
php ./vendor/bin/vs-version-increment --no-commit
Удобно записать этот скрипт в composer.json
{ "scripts": { "vi:auto": "php ./vendor/bin/vs-version-increment --no-commit" }, "scripts-descriptions": { "vi:auto": "Increment module version and generate update package" } }
После выполнения скрипта произведите необходимую корректировку собранного обновления, упакуйте и загружайте на маркетплейс Битрикс.
Конфигурация
Настройка выполняется при помощи конструктора, который имеет следующие параметры:
$config - обязательный. Конфигурация version-increment
$moduleId - обязательный. Идентификатор вашего модуля
$sourcePath - необязательный. Каталог с исходниками модуля, относительно корня проекта. По умолчанию src
$destinationPath - необязательный. Каталог для пакетов обновлений, относительно корня проекта. По умолчанию updates
$phpVersion - необязательный. Версия PHP если необходим контроль в скрипте обновления
$modulesVersion - необязательный. Требующиеся модули и их версии
$excludeCommitTypes - необязательный. Типы коммитов, сообщения которых необходимо пропускать при формировании файлов description.*
$lang - необязательный. Символьные коды языков для создания описания обновлений (файлов description.*)
$includePhpFile - необязательный. Путь у php файлу, код которого необходимо включить в скрипт обновления update.php
Пример конфигурации
use Vasoft\VersionIncrement\Config; use Vasoft\VersionIncrement\Events\EventType; use Voral\BitrixModuleTool\ModuleListener; $config = new Config(); $eventBus = $config->getEventBus(); $listener = new ModuleListener( $config, 'vendor.module', 'last_version', 'marketplace', '8.3.0', [ 'main' => '24.100.100', 'sale' => '24.0.100', ], ['build','docs','test'], ['ru','en','fr'] __DIR__ . '/updates/update_include.php', ); $eventBus->addListener(EventType::BEFORE_VERSION_SET, $listener); // прочие настройки return $config;
Исключения генерируемые расширением
Код | Описание |
---|---|
5101 | Нет доступа к каталогу проекта |
5102 | Не корректный путь к проекту |
5103 | Не найден git тег версии |
5104 | Отсутствует или не верный формат файла version.php |
5105 | Не корректно задан путь к каталогу исходников или обновлений |
Чтобы избежать конфликты с прочими расширениями пакета voral/vs-version-incrementor можно изменять коды ошибок. Для этого необходимо задать дельту. В приведенном ниже примере коды ошибок будут увеличены на 100
use Vasoft\VersionIncrement\Config; use Vasoft\VersionIncrement\Events\EventType; use Voral\BitrixModuleTool\ModuleListener; use Voral\BitrixModuleTool\Exception\ExtensionException; ExtensionException::$errorCodeDelta = 100; $config = new Config(); $eventBus = $config->getEventBus(); $listener = new ModuleListener($config, 'vendor.module'); $eventBus->addListener(EventType::BEFORE_VERSION_SET, $listener); // прочие настройки return $config;
Пример файла install/version.php
<?php $arModuleVersion = [ 'VERSION' => '1.0.0', 'VERSION_DATE' => '2023-01-01' ];
Лицензия
MIT License. Подробности в файле LICENSE.