Apache-Session-Browseable
view release on metacpan or search on metacpan
lib/Apache/Session/Browseable/PgJSON.pm view on Meta::CPAN
package Apache::Session::Browseable::PgJSON;
use strict;
use Apache::Session;
use Apache::Session::Lock::Null;
use Apache::Session::Browseable::Store::Postgres;
use Apache::Session::Generate::SHA256;
use Apache::Session::Serialize::JSON;
our $VERSION = '1.3.9';
our @ISA = qw(Apache::Session);
sub populate {
my $self = shift;
$self->{object_store} =
new Apache::Session::Browseable::Store::Postgres $self;
$self->{lock_manager} = new Apache::Session::Lock::Null $self;
$self->{generate} = \&Apache::Session::Generate::SHA256::generate;
$self->{validate} = \&Apache::Session::Generate::SHA256::validate;
$self->{serialize} = \&Apache::Session::Serialize::JSON::serialize;
$self->{unserialize} = \&Apache::Session::Serialize::JSON::unserialize;
return $self;
}
sub searchOn {
my ( $class, $args, $selectField, $value, @fields ) = @_;
$selectField =~ s/'/''/g;
my $query =
{ query => "a_session ->> '$selectField' =?", values => [$value] };
return $class->_query( $args, $query, @fields );
}
sub searchOnExpr {
my ( $class, $args, $selectField, $value, @fields ) = @_;
$selectField =~ s/'/''/g;
$value =~ s/\*/%/g;
my $query =
{ query => "a_session ->> '$selectField' like ?", values => [$value] };
return $class->_query( $args, $query, @fields );
}
sub _query {
my ( $class, $args, $query, @fields ) = @_;
my %res = ();
my $dbh = $class->_classDbh($args);
my $table_name = $args->{TableName}
|| $Apache::Session::Store::DBI::TableName;
my $sth;
my $fields =
@fields
? join( ',', 'id', map { s/'//g; "a_session ->> '$_' AS $_" } @fields )
: '*';
$sth =
$dbh->prepare("SELECT $fields from $table_name where $query->{query}");
$sth->execute( @{ $query->{values} } );
# In this case, PostgreSQL change field name in lowercase
my $res = $sth->fetchall_hashref('id') or return {};
if (@fields) {
foreach (@fields) {
if ( $_ ne lc($_) ) {
foreach my $s ( keys %$res ) {
$res->{$s}->{$_} = delete $res->{$s}->{ lc $_ };
}
}
}
}
else {
my $self = eval "&${class}::populate();";
my $sub = $self->{unserialize};
foreach my $s ( keys %$res ) {
eval {
my $tmp = &$sub( { serialized => $res->{$s}->{a_session} } );
$res->{$s} = $tmp;
};
if ($@) {
( run in 0.785 second using v1.01-cache-2.11-cpan-39bf76dae61 )