docs, docs and more docs
[catagits/Web-Session.git] / lib / Plack / Session / State / Cookie.pm
CommitLineData
bd992981 1package Plack::Session::State::Cookie;
2use strict;
3use warnings;
4
5use parent 'Plack::Session::State';
6
ac4892f4 7use Plack::Util::Accessor qw[
8 path
9 domain
10 expires
11 secure
12];
bd992981 13
14sub expire_session_id {
15 my ($self, $id) = @_;
16 $self->SUPER::expire_session_id( $id );
17 $self->expires( 0 );
18}
19
20sub extract {
21 my ($self, $request) = @_;
22 $self->check_expired( ( $request->cookie( $self->session_key ) || return )->value );
23}
24
25sub finalize {
26 my ($self, $id, $response) = @_;
27 $response->cookies->{ $self->session_key } = +{
28 value => $id,
29 path => ($self->path || '/'),
05b5f99d 30 ( defined $self->domain ? ( domain => $self->domain ) : () ),
31 ( defined $self->expires ? ( expires => $self->expires ) : () ),
32 ( defined $self->secure ? ( secure => $self->secure ) : () ),
bd992981 33 };
05b5f99d 34
35 # clear the expires after
36 # finalization if the session
37 # has been expired - SL
38 $self->expires( undef )
39 if defined $self->expires
40 && $self->expires == 0
41 && $self->is_session_expired( $id );
bd992981 42}
43
fe1bfe7d 441;
ac4892f4 45
46__END__
47
48=pod
49
50=head1 NAME
51
52Plack::Session::State::Cookie - Basic cookie-based session state
53
54=head1 DESCRIPTION
55
43f34c01 56This is a subclass of L<Plack::Session::State> and implements it's
57full interface.
58
ac4892f4 59=head1 METHODS
60
61=over 4
62
63=item B<new ( %params )>
64
65=item B<path>
66
67=item B<domain>
68
69=item B<expires>
70
71=item B<secure>
72
73=back
74
ac4892f4 75=head1 BUGS
76
77All complex software has bugs lurking in it, and this module is no
78exception. If you find a bug please either email me, or add the bug
79to cpan-RT.
80
81=head1 AUTHOR
82
83Stevan Little E<lt>stevan.little@iinteractive.comE<gt>
84
85=head1 COPYRIGHT AND LICENSE
86
87Copyright 2009 Infinity Interactive, Inc.
88
89L<http://www.iinteractive.com>
90
91This library is free software; you can redistribute it and/or modify
92it under the same terms as Perl itself.
93
94=cut
95
96