andreyryabin / sprint.migration
bitrix migration module
Fund package maintenance!
yoomoney.ru/to/410012104240288
Installs: 144 122
Dependents: 2
Suggesters: 0
Security: 0
Stars: 170
Watchers: 19
Forks: 56
Open Issues: 25
Type:bitrix-module
Requires
- php: >=7.4
- ext-json: *
- composer/installers: ~1
- dev-master
- 4.15.1
- 4.13.1
- 4.12.6
- 4.11.4
- 4.10.4
- 4.9.9
- 4.8.2
- 4.7.1
- 4.6.2
- 4.4.1
- 4.3.2
- 4.2.5
- 4.1.3
- 4.0.6
- 3.30.1
- 3.29.5
- 3.28.8
- 3.27.1
- 3.26.1
- 3.25.1
- 3.24.1
- 3.23.4
- 3.22.4
- 3.21.4
- 3.20.4
- 3.19.1
- 3.18.1
- 3.17.3
- 3.16.3
- 3.15.1
- 3.14.6
- 3.13.5
- 3.12.19
- 3.11.1
- 3.10.2
- 3.9.3
- 3.8.6
- 3.7.3
- 3.6.9
- 3.5.6
- 3.4.7
- 3.3.8
- 3.2.1
- 3.1.3
- 3.0.9
- 2.8.9
- 2.7.5
- 2.6.2
- 2.5.8
- 2.4.5
- 2.3.9
- 2.2.9
- dev-release-4.9.1
- dev-release-4.7
- dev-release-4.1.1
- dev-release-4.1.0
- dev-medialib
- dev-release-3.15.1
This package is auto-updated.
Last update: 2024-11-03 20:04:22 UTC
README
Помогает переносить изменения между нескольким копиями проекта.
Все изменения для базы данных пишутся в файлы миграций, эти файлы, как и весь код проекта, хранятся в системе контроля версий (например git) и попадают в копии разработчиков, после чего им необходимо выполнить установку новых миграций, чтобы обновить бд.
Работать можно как через консоль, так и через админку.
- Маркетплейс: http://marketplace.1c-bitrix.ru/solutions/sprint.migration/
- Composer: https://packagist.org/packages/andreyryabin/sprint.migration
- Документация: https://github.com/andreyryabin/sprint.migration/wiki
- Материалы: https://dev.1c-bitrix.ru/community/webdev/user/39653/blog/
- Группа в телеграм: https://t.me/sprint_migration_bitrix
Особая благодарность
А также всем помощникам!
https://github.com/andreyryabin/sprint.migration/blob/master/contributors.txt
Установка через composer
Пример вашего composer.json с установкой модуля в local/modules/
{
"extra": {
"installer-paths": {
"local/modules/{$name}/": ["type:bitrix-module"]
}
},
"require": {
"andreyryabin/sprint.migration": "dev-master"
},
}
Консоль
Для работы через консоль используется скрипт
/bitrix/modules/sprint.migration/tools/migrate.php
Можно запускать его напрямую или сделать алиас,
создав файл в корне проекта, bin/migrate
и прописав в нем:
#!/usr/bin/env php
<?php
$_SERVER['DOCUMENT_ROOT'] = dirname(__DIR__);
require_once $_SERVER['DOCUMENT_ROOT'] . '/bitrix/modules/sprint.migration/tools/migrate.php';
Консоль symfony
Если у вас используется связка bitrix + symfony, то можно подключить модуль как бандл симфони и запускать консольные команды модуля через
php bin/console sprint:migration
Пример регистрации бандла:
// app/AppKernel.php
use Sprint\Migration\SymfonyBundle\SprintMigrationBundle;
public function registerBundles()
{
$bundles = array(
new SprintMigrationBundle(),
);
return $bundles;
}
Пример без регистрации бандла, только команды в symfony/console
// bin/console
use Sprint\Migration\SymfonyBundle\Command\ConsoleCommand;
use Symfony\Component\Console\Application;
$app = new Application();
$app->add(new ConsoleCommand());
$app->run();
Классы модуля должны уже быть автозагружены, через CModule::IncludeModule('sprint.migration')
Или через библиотеку https://packagist.org/packages/webarchitect609/bitrix-neverinclude (рекомендую этот вариант)
Примеры команд
- php bin/migrate add (создать новую миграцию)
- php bin/migrate ls (показать список миграций )
- php bin/migrate up (накатить все миграции)
- php bin/migrate up [version] (накатить выбранную миграцию)
- php bin/migrate down (откатить все миграции)
- php bin/migrate down [version] (откатить выбранную миграцию)
Все команды: https://github.com/andreyryabin/sprint.migration/blob/master/commands.txt