fiisoft / phinx
Console-commands to use Phinx's library console-commands in custom console application (based on symfony/console package).
Installs: 39
Dependents: 0
Suggesters: 0
Security: 0
Stars: 1
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/fiisoft/phinx
Requires
- php: >=5.6.0
- fiisoft/basics: ^2.2
- robmorgan/phinx: ^0.9.1
- symfony/console: ^2.8.27
README
Console-commands to use Phinx's library console-commands in custom console application (based on symfony/console package).
My advice is - do not use it unless you are enough strong mentally to immune for such bad code.
It contains wrappers for Phinx's commands:
- breakpoint
- create
- migrate
- rollback
- seed:create
- seed:run
- status
- test
It also contains six special commands (not available in Phinx):
- mark - marks migration as migrated without migrating it (adds entry log to phinxlog so migration seems to be already migrated)
- unmark - removes entry log from phinxlog, without rollback on migration (so migration will be migrated on next migrate)
- repeat - repeats single migration (specified by its version number) even if migrated
- revoke - performs rollback on single migration (specified by its version number)
- remove - removes entry log from phinxlog and deletes corresponding migration file from disk
- cleanup - removes entries of missing migrations from phinxlog (if files are not available)
In addition, it comes with special generic-purpose command phinx which allows to run other Phinx-specific commands in special way.
Keep in mind that this library uses its own configuration-schema as well as template for migrations classes and base abstract class for them.
The main goal of this custom configuration is to manage migrations for many destiny databases (in various environments). Therefore configurations are grouped in something called "destiny".
Here are some examples.
- The simplest possible (aka minimal required) configuration:
$config = new PhinxConfig([ 'local' => [ 'environments' => [ 'dev' => [ 'adapter' => 'pgsql', 'host' => 'localhost', 'name' => 'dbname', 'user' => 'username', 'pass' => 'password', ] ], ] ]);
This creates config for one destiny called local with one environment dev.
Migration files for this destiny will be stored in (current working directory)/phinx/local/migrations directory.
Notice that the name of destiny becames part of path.
- Similar configuration but with path to files with migrations in specified directory without name of destiny:
$config = new PhinxConfig([ 'local' => [ 'paths_root' => __DIR__ . DIRECTORY_SEPARATOR . 'phinx', 'environments' => [ 'dev' => [ 'adapter' => 'pgsql', 'host' => 'localhost', 'name' => 'dbname', 'user' => 'username', 'pass' => 'password', ] ], ] ]);
In this case path to migration files is __DIR__/phinx/migrations - there is no name of destiny local in path.
- Third way to create the simplest configuration is to specify path to directory with migrations like this:
$config = new PhinxConfig([ 'defaults' => [ 'phinx_files' => __DIR__ . DIRECTORY_SEPARATOR . 'dev', ], 'local' => [ 'environments' => [ 'dev' => [ 'adapter' => 'pgsql', 'host' => 'localhost', 'name' => 'dbname', 'user' => 'username', 'pass' => 'password', ] ], ] ]);
This defines root folder for all destinations. The path for migration files for local is now __DIR__/dev/local/migrations.
To handle various different sets of migrations reffered to the same database, use:
$config = new PhinxConfig([ 'defaults' => [ 'adapter' => 'pgsql', 'host' => 'localhost', 'name' => 'dbname', 'user' => 'username', 'pass' => 'password', ], 'alpha' => [ 'environments' => [ 'dev' => [ ], ], ], 'bravo' => [ 'environments' => [ 'dev' => [ ], 'default_migration_table' => 'phinx_migrations', ], ], ];
This configuration defines two destinations: alpha and bravo.
Migration files for alpha will be stored in (current working directory)/phinx/alpha/migrations
and the name of the table used by Phinx will be phinxlog (as default).
Migration files for bravo will be stored in (current working directory)/phinx/bravo/migrations
and the name of the table used by Phinx will be phinx_migrations.
Because there are no other data specified, both destinations will share the same database, so it gives possibility to handle various sets of migrations for the same database.
There is also a bin/finx executable file provided with library. Usage of it is a bit hard to explain because it uses its own schema of arguments.
Some examples (lets assume the local destination is defined in configuration):
bin/finx listshow list of available commandsbin/finxthe same as above (command list is default)bin/finx phinxshow help for generic command (phinx)bin/finx phinx local statusshow status of migrations from destiny localbin/finx phinx localthe same as above (command status is default)bin/finx localthe same as above (status is default, keyword phinx can be omitted)bin/finx phinx:status localthe same as above (by direct call of command status)
Some examples of call command migrate with environment dev from destination local, in different ways (and all do exactly the same!):
bin/finx phinx local migrate -e devbin/finx phinx local dev migratebin/finx phinx local migratebin/finx phinx:migrate local -e devbin/finx phinx:migrate local devbin/finx phinx:migrate localbin/finx local migrate -e devbin/finx local dev migratebin/finx local migrate(this one I prefer)
As you can see, it's a bit crazy.