voral / bitrix-module-tool
Extension for vs-version-incrementor to automate building update packages for Bitrix modules.
Installs: 8
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/voral/bitrix-module-tool
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-10-19 06:50:07 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",
"pack:last": "sh scripts/pack-last.sh",
"pack:ver": "sh scripts/pack-version.sh",
"pack": [
"@pack:ver",
"@pack:last"
]
},
"scripts-descriptions": {
"vi:auto": "Increment module version and generate update package",
"pack:last": "Pack the full package of the module's latest version",
"pack:ver": "Pack the update package for a specified module version",
"pack": "Pack the full package of the latest version and the update package for a specified version"
}
}
Применение
-
После выполнения изменений в модуле выполните расчет версии. Ппо окончанию этого скрипта в консоль будут выведены рекомендуемые команды для выполнения коммита и установки тега. Они будут содержать новую версию пакета.
composer vi:auto
-
При необходимости внесите изменения в CHANGELOG.md, в так же сгенерированные файлы описания обновления /updates/<версия_пакета>/description.*
-
Выполните сборку пакета обновлений для полученной версии (например для версии 1.3.0)
composer pack:last 1.3.0
-
Выполните проверку пакета обновлений как описано в статье
-
После всех проверок выполните сборку пакетов обновления и полного пакета модуля
composer pack:pack 1.3.0
-
Выполните коммит релиза и установите так как рекомендовано на шаге 1
-
Загрузить пакет на Битрикс маркетплейс
Конфигурация
Настройка выполняется при помощи конструктора, который имеет следующие параметры:
$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.