ASP4
view release on metacpan or search on metacpan
lib/ASP4/SessionStateManager.pm view on Meta::CPAN
$class->set_db('Session',
$conn->dsn,
$conn->username,
$conn->password
);
my $id = $s->parse_session_id();
unless( $id && $s->verify_session_id( $id, $conn->session_timeout ) )
{
$s->{SessionID} = $s->new_session_id();
$s->write_session_cookie($r);
return $s->create( $s->{SessionID} );
}# end unless()
return $s->retrieve( $id );
}# end new()
sub context { ASP4::HTTPContext->current }
sub is_read_only
{
my ($s, $val) = @_;
if( defined($val) )
{
$s->{____is_read_only} = $val;
}
else
{
return $s->{____is_read_only};
}# end if()
}# end is_readonly()
sub parse_session_id
{
my $session_config = context()->config->data_connections->session;
my $cookie_name = $session_config->cookie_name;
my ($id) = ($ENV{HTTP_COOKIE}||'') =~ m/\b\Q$cookie_name\E\=([a-f0-9]{32,32})/s;
return $id;
}# end parse_session_id()
sub new_session_id { md5_hex( join ':', ( context()->config->web->www_root, $$, gettimeofday() ) ) }
sub write_session_cookie
{
my ($s, $r) = @_;
my $config = context()->config->data_connections->session;
my $domain = "";
unless( $config->cookie_domain eq '*' )
{
$domain = "domain=" . ( $config->cookie_domain || $ENV{HTTP_HOST} ) . ";";
}# end unless()
my $name = $config->cookie_name;
my @cookie = (
'Set-Cookie' => "$name=$s->{SessionID}; path=/; $domain"
);
context()->headers_out->push_header( @cookie );
@cookie;
}# end write_session_cookie()
sub verify_session_id
{
my ($s, $id, $timeout ) = @_;
my $is_active;
if( $timeout eq '*' )
{
local $s->db_Session->{AutoCommit} = 1;
my $sth = $s->db_Session->prepare(<<"");
SELECT count(*)
FROM asp_sessions
WHERE session_id = ?
$sth->execute( $id );
($is_active) = $sth->fetchrow();
$sth->finish();
}
else
{
my $range_start = time() - ( $timeout * 60 );
local $s->db_Session->{AutoCommit} = 1;
my $sth = $s->db_Session->prepare(<<"");
SELECT count(*)
FROM asp_sessions
WHERE session_id = ?
AND modified_on - created_on < ?
$sth->execute( $id, $timeout );
($is_active) = $sth->fetchrow();
$sth->finish();
}# end if()
return $is_active;
}# end verify_session_id()
sub create
{
my ($s, $id) = @_;
local $s->db_Session->{AutoCommit} = 1;
my $sth = $s->db_Session->prepare_cached(<<"");
delete from asp_sessions
where session_id = ?
$sth->execute( $id );
$sth = $s->db_Session->prepare_cached(<<"");
INSERT INTO asp_sessions (
session_id,
session_data,
created_on,
modified_on
)
( run in 0.490 second using v1.01-cache-2.11-cpan-cdf2f3d4e48 )