1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
|
package Data::Session::Serialize::JSON;
use parent 'Data::Session::Base';
no autovivification;
use strict;
use warnings;
use JSON;
our $VERSION = '1.18';
# -----------------------------------------------
sub freeze
{
my($self, $data) = @_;
return JSON -> new -> encode($data);
} # End of freeze.
# -----------------------------------------------
sub new
{
my($class) = @_;
return bless({}, $class);
} # End of new.
# -----------------------------------------------
sub thaw
{
my($self, $data) = @_;
return JSON -> new -> decode($data);
} # End of thaw.
# -----------------------------------------------
1;
=pod
=head1 NAME
L<Data::Session::Serialize::JSON> - A persistent session manager
=head1 Synopsis
See L<Data::Session> for details.
=head1 Description
L<Data::Session::Serialize::JSON> allows L<Data::Session> to manipulate sessions with L<JSON>.
To use this module do this:
=over 4
=item o Specify a driver of type JSON as Data::Session -> new(type => '... serialize:JSON')
=back
=head1 Case-sensitive Options
See L<Data::Session/Case-sensitive Options> for important information.
=head1 Method: new()
Creates a new object of type L<Data::Session::Serialize::JSON>.
C<new()> takes a hash of key/value pairs, some of which might mandatory. Further, some combinations
might be mandatory.
The keys are listed here in alphabetical order.
They are lower-case because they are (also) method names, meaning they can be called to set or get
the value at any time.
=over 4
=item o verbose => $integer
Print to STDERR more or less information.
Typical values are 0, 1 and 2.
This key is normally passed in as Data::Session -> new(verbose => $integer).
This key is optional.
=back
=head1 Method: freeze($data)
Returns $data frozen by L<JSON>.
=head1 Method: thaw($data)
Returns $data thawed by L<JSON>.
=head1 Support
Log a bug on RT: L<https://rt.cpan.org/Public/Dist/Display.html?Name=Data-Session>.
=head1 Author
L<Data::Session> was written by Ron Savage I<E<lt>ron@savage.net.auE<gt>> in 2010.
Home page: L<http://savage.net.au/index.html>.
=head1 Copyright
Australian copyright (c) 2010, Ron Savage.
All Programs of mine are 'OSI Certified Open Source Software';
you can redistribute them and/or modify them under the terms of
The Artistic License, a copy of which is available at:
http://www.opensource.org/licenses/index.html
=cut
|