App-Standby
view release on metacpan or search on metacpan
lib/App/Standby/DB.pm view on Meta::CPAN
package App::Standby::DB;
$App::Standby::DB::VERSION = '0.04';
BEGIN {
$App::Standby::DB::AUTHORITY = 'cpan:TEX';
}
# ABSTRACT: Database abstraction/helper for App::Standby
use 5.010_000;
use mro 'c3';
use feature ':5.10';
use Moose;
use namespace::autoclean;
# use IO::Handle;
# use autodie;
# use MooseX::Params::Validate;
# use Carp;
# use English qw( -no_match_vars );
# use Try::Tiny;
use DBI;
# extends ...
# has ...
has 'dbh' => (
'is' => 'rw',
'isa' => 'DBI::db',
'lazy' => 1,
'builder' => '_init_dbh',
);
# with ...
with qw(Config::Yak::RequiredConfig Log::Tree::RequiredLogger);
# initializers ...
sub _init_dbh {
my $self = shift;
my $db_file = $self->config()->get('App::Standby::DBFile', { Default => '/var/lib/standby-mgm/db.sqlite3'});
my $dsn = 'DBI:SQLite:dbname='.$db_file;
# see http://search.cpan.org/~adamk/DBD-SQLite-1.35/lib/DBD/SQLite.pm#Transaction_and_Database_Locking
my $dbh = DBI->connect($dsn, '', '', { sqlite_use_immediate_transaction => 1, });
if($dbh) {
$self->_check_tables($dbh);
}
return $dbh;
}
sub DEMOLISH {
my $self = shift;
$self->dbh()->disconnect();
return;
}
# your code here ...
sub prepare {
my $self = shift;
my $sqlstr = shift;
return $self->dbh()->prepare($sqlstr);
}
sub prepexec {
my ( $self, $sqlstr, @params ) = @_;
my $sth = $self->dbh()->prepare($sqlstr);
if(!$sth) {
$self->logger()->log( message => 'Failed to prepare statement from SQL: '.$sqlstr.' w/ error: '.$self->dbh()->errstr, level => 'warning', );
return;
}
if($sth->execute(@params)) {
return $sth;
} else {
( run in 2.989 seconds using v1.01-cache-2.11-cpan-5837b0d9d2c )