2009-10-21 14:43:13 +02:00
|
|
|
package Lemonldap::NG::Common::Conf::CDBI;
|
|
|
|
|
|
|
|
use strict;
|
|
|
|
require Storable;
|
2010-09-17 11:26:03 +02:00
|
|
|
use Lemonldap::NG::Common::Conf::_DBI;
|
2009-10-21 14:43:13 +02:00
|
|
|
|
2014-06-03 18:00:20 +02:00
|
|
|
our $VERSION = '1.4.0';
|
2010-09-17 11:26:03 +02:00
|
|
|
our @ISA = qw(Lemonldap::NG::Common::Conf::_DBI);
|
2009-10-21 14:43:13 +02:00
|
|
|
|
|
|
|
sub store {
|
|
|
|
my ( $self, $fields ) = @_;
|
2010-09-17 11:26:03 +02:00
|
|
|
my $cfgNum = $fields->{cfgNum};
|
2014-06-03 18:00:20 +02:00
|
|
|
my $req;
|
|
|
|
my $lastCfg = $self->lastCfg;
|
|
|
|
|
2009-10-21 14:43:13 +02:00
|
|
|
$fields = Storable::nfreeze($fields);
|
2014-06-03 18:00:20 +02:00
|
|
|
|
|
|
|
if ( $lastCfg == $cfgNum ) {
|
|
|
|
$req = $self->_dbh->prepare(
|
2014-06-08 12:04:50 +02:00
|
|
|
"UPDATE $self->{dbiTable} SET data=? WHERE cfgNum=?");
|
2014-06-03 18:00:20 +02:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$req = $self->_dbh->prepare(
|
2014-06-08 12:04:50 +02:00
|
|
|
"INSERT INTO $self->{dbiTable} (data,cfgNum) VALUES (?,?)");
|
2014-06-03 18:00:20 +02:00
|
|
|
}
|
|
|
|
unless ($req) {
|
2009-10-21 14:43:13 +02:00
|
|
|
$self->logError;
|
|
|
|
return UNKNOWN_ERROR;
|
|
|
|
}
|
2014-06-03 18:00:20 +02:00
|
|
|
unless ( $req->execute( $fields, $cfgNum ) ) {
|
2009-10-21 14:43:13 +02:00
|
|
|
$self->logError;
|
|
|
|
return UNKNOWN_ERROR;
|
|
|
|
}
|
|
|
|
eval { $self->_dbh->do("COMMIT"); };
|
2010-09-17 11:26:03 +02:00
|
|
|
return $cfgNum;
|
2009-10-21 14:43:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub load {
|
|
|
|
my ( $self, $cfgNum, $fields ) = @_;
|
|
|
|
$fields = $fields ? join( ",", @$fields ) : '*';
|
|
|
|
my $row = $self->_dbh->selectrow_arrayref(
|
2013-07-12 09:58:46 +02:00
|
|
|
"SELECT data from " . $self->{dbiTable} . " WHERE cfgNum=?",
|
|
|
|
{}, $cfgNum );
|
2009-10-21 14:43:13 +02:00
|
|
|
unless ($row) {
|
|
|
|
$self->logError;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
my $r;
|
2010-10-23 10:00:07 +02:00
|
|
|
eval { $r = Storable::thaw( $row->[0] ); };
|
2009-10-21 14:43:13 +02:00
|
|
|
if ($@) {
|
2011-07-07 17:08:45 +02:00
|
|
|
$Lemonldap::NG::Common::Conf::msg .=
|
|
|
|
"Bad stored data in conf database: $@ \n";
|
2009-10-21 14:43:13 +02:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
return $r;
|
|
|
|
}
|
|
|
|
|
|
|
|
1;
|
|
|
|
__END__
|