lemonldap-ng/lemonldap-ng-common/lib/Lemonldap/NG/Common/Conf/Backends/CDBI.pm

68 lines
1.6 KiB
Perl
Raw Normal View History

2017-01-06 13:30:41 +01:00
package Lemonldap::NG::Common::Conf::Backends::CDBI;
use strict;
2016-01-07 13:34:34 +01:00
use utf8;
2016-01-13 20:47:56 +01:00
use JSON;
2017-01-06 13:30:41 +01:00
use Lemonldap::NG::Common::Conf::Backends::_DBI;
2019-02-12 18:21:38 +01:00
our $VERSION = '2.1.0';
2017-01-06 13:30:41 +01:00
our @ISA = qw(Lemonldap::NG::Common::Conf::Backends::_DBI);
sub store {
my ( $self, $fields ) = @_;
my $cfgNum = $fields->{cfgNum};
my $req;
my $lastCfg = $self->lastCfg;
2016-01-11 21:32:44 +01:00
$fields = to_json($fields);
if ( $lastCfg == $cfgNum ) {
$req = $self->_dbh->prepare(
2014-06-08 12:04:50 +02:00
"UPDATE $self->{dbiTable} SET data=? WHERE cfgNum=?");
}
else {
$req = $self->_dbh->prepare(
2014-06-08 12:04:50 +02:00
"INSERT INTO $self->{dbiTable} (data,cfgNum) VALUES (?,?)");
}
unless ($req) {
$self->logError;
return UNKNOWN_ERROR;
}
2017-08-29 16:04:40 +02:00
my $execute;
eval { $execute = $req->execute( $fields, $cfgNum ); };
unless ($execute) {
$self->logError;
return UNKNOWN_ERROR;
}
return $cfgNum;
}
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 );
unless ($row) {
$self->logError;
return 0;
}
my $r;
2016-01-11 07:27:14 +01:00
if ( $row->[0] =~ /^\s*\{/s ) {
2017-09-28 14:52:14 +02:00
eval { $r = from_json( $row->[0], { allow_nonref => 1 } ); };
2016-01-11 07:27:14 +01:00
}
else { # Old format
require Storable;
eval { $r = Storable::thaw( $row->[0] ); };
}
if ($@) {
$Lemonldap::NG::Common::Conf::msg .=
"Bad stored data in conf database: $@ \n";
return 0;
}
return $r;
}
1;
__END__