Add logging
[dbsrgits/DBIx-Class-DeploymentHandler.git] / lib / DBIx / Class / DeploymentHandler / VersionStorage / Standard.pm
CommitLineData
0905dc0e 1package DBIx::Class::DeploymentHandler::VersionStorage::Standard;
2use Moose;
0df68524 3use Log::Contextual::WarnLogger;
4use Log::Contextual ':log', -default_logger => Log::Contextual::WarnLogger->new({
5 env_prefix => 'DBICDH'
6});
9deabd1f 7
8# ABSTRACT: Version storage that does the normal stuff
9
0905dc0e 10use Method::Signatures::Simple;
53de57ed 11use DBIx::Class::DeploymentHandler::VersionStorage::Standard::VersionResult;
0905dc0e 12
13has schema => (
14 isa => 'DBIx::Class::Schema',
15 is => 'ro',
16 required => 1,
17);
18
19has version_rs => (
20 isa => 'DBIx::Class::ResultSet',
21 is => 'ro',
53de57ed 22 builder => '_build_version_rs',
0905dc0e 23 handles => [qw( database_version version_storage_is_installed )],
24);
25
26with 'DBIx::Class::DeploymentHandler::HandlesVersionStorage';
27
28sub _build_version_rs {
6bbb6ce7 29 $_[0]->schema->register_class(
30 __VERSION =>
31 'DBIx::Class::DeploymentHandler::VersionStorage::Standard::VersionResult'
32 );
33 $_[0]->schema->resultset('__VERSION')
0905dc0e 34}
35
0df68524 36sub add_database_version {
37 my $version = $_[1]->{version};
38 log_debug { "[DBICDH] Adding database version $version" };
39 $_[0]->version_rs->create($_[1])
40}
0905dc0e 41
f344dd91 42sub delete_database_version {
0df68524 43 my $version = $_[1]->{version};
44 log_debug { "[DBICDH] Deleting database version $version" };
45 $_[0]->version_rs->search({ version => $version})->delete
f344dd91 46}
47
c9149a81 48__PACKAGE__->meta->make_immutable;
49
0905dc0e 501;
51
e52174e3 52# vim: ts=2 sw=2 expandtab
53
0905dc0e 54__END__
55