first round of changes for the new session system
This commit is contained in:
parent
da95226072
commit
d4b7f2ce59
128 changed files with 2442 additions and 1478 deletions
174
lib/WebGUI/Session/Scratch.pm
Normal file
174
lib/WebGUI/Session/Scratch.pm
Normal file
|
|
@ -0,0 +1,174 @@
|
|||
package WebGUI::Session::Scratch;
|
||||
|
||||
=head1 LEGAL
|
||||
|
||||
-------------------------------------------------------------------
|
||||
WebGUI is Copyright 2001-2005 Plain Black Corporation.
|
||||
-------------------------------------------------------------------
|
||||
Please read the legal notices (docs/legal.txt) and the license
|
||||
(docs/license.txt) that came with this distribution before using
|
||||
this software.
|
||||
-------------------------------------------------------------------
|
||||
http://www.plainblack.com info@plainblack.com
|
||||
-------------------------------------------------------------------
|
||||
|
||||
=cut
|
||||
|
||||
use strict;
|
||||
|
||||
=head1 NAME
|
||||
|
||||
Package WebGUI::Session::Scratch
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
This package allows you to attach arbitrary data to the session that lasts until the session dies.
|
||||
|
||||
=head1 SYNOPSIS
|
||||
|
||||
$scratch = WebGUI::Session::Scratch->new($sessionId, $db);
|
||||
|
||||
$scratch->delete('temp');
|
||||
$scratch->set('temp',$value);
|
||||
$value = $scratch->get('temp');
|
||||
|
||||
$scratch->deleteAll;
|
||||
$scratch->deleteName('temp');
|
||||
|
||||
|
||||
=head1 METHODS
|
||||
|
||||
These methods are available from this package:
|
||||
|
||||
=cut
|
||||
|
||||
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 delete ( name )
|
||||
|
||||
Deletes a scratch variable.
|
||||
|
||||
=head3 name
|
||||
|
||||
The name of the scratch variable.
|
||||
|
||||
=cut
|
||||
|
||||
sub delete {
|
||||
my $self = shift;
|
||||
my $name = shift;
|
||||
return undef unless ($name);
|
||||
delete $self->{_data}{$name};
|
||||
$self->{_db}->deleteRow("userSessionScratch","sessionId",$self->{_sessionId});
|
||||
}
|
||||
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 deleteAll ( )
|
||||
|
||||
Deletes all scratch variables for this session.
|
||||
|
||||
=cut
|
||||
|
||||
sub deleteAll {
|
||||
my $self = shift;
|
||||
delete $self->{_data};
|
||||
WebGUI::SQL->write("delete from userSessionScratch where sessionId=".quote($self->{_sessionId}));
|
||||
}
|
||||
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 deleteName ( name )
|
||||
|
||||
Deletes a scratch variable for all users. This function must be used with care.
|
||||
|
||||
=head3 name
|
||||
|
||||
The name of the scratch variable.
|
||||
|
||||
=cut
|
||||
|
||||
sub deleteName {
|
||||
my $self = shift;
|
||||
my $name = shift;
|
||||
return undef unless ($name);
|
||||
delete $self->{_data}{$name};
|
||||
WebGUI::SQL->write("delete from userSessionScratch where name=".quote($name));
|
||||
}
|
||||
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 get( varName )
|
||||
|
||||
Retrieves the current value of a scratch variable.
|
||||
|
||||
=head3 varName
|
||||
|
||||
The name of the variable.
|
||||
|
||||
=cut
|
||||
|
||||
sub get {
|
||||
my $self = shift;
|
||||
my $var = shift;
|
||||
return $self->{_data}{$var};
|
||||
}
|
||||
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 new ( sessionId, db )
|
||||
|
||||
Constructor. Returns a scratch object.
|
||||
|
||||
=head3 sessionId
|
||||
|
||||
The unique id of the current session.
|
||||
|
||||
=head3 db
|
||||
|
||||
An active WebGUI::SQL database handler.
|
||||
|
||||
=cut
|
||||
|
||||
sub new {
|
||||
my $class = shift;
|
||||
my $sessionId = shift;
|
||||
my $db = shift;
|
||||
my $data = $db->buildHashRef("select name,value from userSessionScratch where sessionId=".$db->quote($sessionId));
|
||||
bless {_sessionId=>$sessionId, _db=>$db, _data=>$data}, $class;
|
||||
}
|
||||
|
||||
|
||||
#-------------------------------------------------------------------
|
||||
|
||||
=head2 set ( name, value )
|
||||
|
||||
Sets a scratch variable for this user session.
|
||||
|
||||
=head3 name
|
||||
|
||||
The name of the scratch variable.
|
||||
|
||||
=head3 value
|
||||
|
||||
The value of the scratch variable. Must be a string no longer than 16000 characters.
|
||||
|
||||
=cut
|
||||
|
||||
sub set {
|
||||
my $self = shift;
|
||||
my $name = shift;
|
||||
my $value = shift;
|
||||
return undef unless ($name);
|
||||
$self->{_data}{$name} = $value;
|
||||
$self->{_db}->write("replace into userSessionScratch (sessionId, name, value) values (".$self->{_db}->quoteAndJoin([$self->{_sessionId}, $name, $value]).")");
|
||||
}
|
||||
|
||||
|
||||
1;
|
||||
Loading…
Add table
Add a link
Reference in a new issue