NAME
Mojolicious::Plugin::Migration::Sqitch - Run Sqitch database migrations
from a Mojo app
SYNOPSIS
# Register plugin
$self->plugin('Migration::Sqitch' => {
dsn => 'dbi:mysql:host=localhost;port=3306;database=myapp',
registry => 'sqitch_myapp',
username => 'sqitch',
password => 'world-banana-tuesday',
directory => '/schema',
});
# use from command-line (normally done by startup script to ensure db up to date before app starts)
tyrrminal@prodserver:/app$ script/myapp schema-initdb
[2024-04-30 11:26:47.91166] [8982] [info] Database initialized
tyrrminal@prodserver:/app$ script/myapp schema-migrate
+ initial_schema .. ok
[2024-04-30 11:29:13.80192] [8985] [info] Database migration complete
# Revert a migration in dev
tyrrminal@devserver:/app$ script/myapp schema-migrate schema-migrate revert
- initial_schema .. ok
[2024-04-30 11:26:47.91166] [8982] [info] Database migration complete
# Start over from scratch
tyrrminal@devserver:/app$ script/myapp schema-initdb --reset
This will result in all data being deleted from the database. Are you sure you want to continue? [yN] y
[2024-04-30 11:28:10.73379] [8983] [info] Database reset
[2024-04-30 11:28:10.73501] [8983] [info] Database initialized
DESCRIPTION
Mojolicious::Plugin::Migration::Sqitch enables the use of sqitch via
Mojolicious commands. The primary advantage of this is single-point
configuration: just pass the appropriate parameters in at plugin
registration and then you don't have to worry about passwords, DSNs, and
filesystem locations for running sqitch commands thereafter.
This plugin also provides some additional functionality for initializing
the database, which can't easily be done strictly through sqitch
migrations without hardcoding database names, which can be troublesome
depending on the deployment.
METHODS
Mojolicious::Plugin::Migration::Sqitch inherits all methods from
Mojolicious::Plugin and implements the following new ones
register( $args )
Register plugin in Mojolicious application. The following keys are
required in $args
dsn
for connecting to the *application* database.
E.g., "dbi:mysql:host=db;port=3306;database=myapp_prod"
registry
The name of the database used by sqitch for tracking migrations
E.g., "myapp_prod_sqitch"
username
Database username for sqitch migrations. As this account needs to run
arbitrary SQL code (both DDL and DML), it must have sufficiently high
privileges. This can be the same account used by the application, if
this consideration is taken into account.
password
The password corresponding to the sqitch migration database account
directory
The on-disk location of the sqitch migrations directory. Sqitch expects
to find "deploy", "revert", and "verify" subdirectories there, as well
as the "sqitch.plan" file. It must also contain a "sqitch.conf" file,
but the only contents of this file needed are:
[core]
engine = $ENGINE
With $ENGINE replaced by the actual engine name, e.g., "mysql" or
"pgsql". This plugin handles the rest of the configuration that would
normally be found in that file.
E.g., "/schema" (in a containerized environment), or
"/home/mojo/myapp/schema"
run_schema_initialization( \%args )
Create the configured application and migration databases, if either or
both do not already exist. One key is regarded in the "args" HashRef:
reset
If this key is given and is assigned a "truthy" value, the application
and migration databases will be dropped (if either or both exists)
before being re-created. *This is a destructive operation!*
run_schema_migration( $sqitch_subcommand )
Run the specified $sqitch_subcommand including any additional parameters
(e.g., "deploy" or "revert -to @HEAD^1"). Returns the exit status of the
sqitch command to indicate success (zero) or failure (non-zero).
COMMANDS
schema-initdb [--reset]
Mojolicious command to execute "run_schema_initialization"
If the "--reset" flag is given, corresponding to the methods's "reset"
arg key, a console warning is given alerting the user of the destructive
nature of this operation and must be manually approved before
continuing.
schema-migrate [args]
Mojolicious command to execute "run_schema_migration". Any additional
args given are whitespace-joined and passed on to that method. If no
args are provided, "deploy" is assumed.
AUTHOR
Mark Tyrrell "<mark@tyrrminal.dev>"
LICENSE
Copyright (c) 2024 Mark Tyrrell
Permission is hereby granted, free of charge, to any person obtaining a
copy of this software and associated documentation files (the
"Software"), to deal in the Software without restriction, including
without limitation the rights to use, copy, modify, merge, publish,
distribute, sublicense, and/or sell copies of the Software, and to
permit persons to whom the Software is furnished to do so, subject to
the following conditions:
The above copyright notice and this permission notice shall be included
in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.