NAME
Plack::Session::Store::RedisFast - Redis session store.
DESCRIPTION
Default implementation of Redis handle is Redis::Fast; otherwise Redis.
May be overriden through "redis" or "builder" param.
Default implementation of serializer handle is JSON::XS; otherwise Mojo::JSON or JSON.
May be overriden through "inflate" and "deflate" param.
SYNOPSIS
use Plack::Builder;
use Plack::Session::Store::RedisFast;
my $app = sub {
return [ 200, [ 'Content-Type' => 'text/plain' ], [ 'Hello Foo' ] ];
};
builder {
enable 'Session',
store => Plack::Session::Store::RedisFast->new;
$app;
};
DESCRIPTION
This will persist session data using Redis::Fast or Redis.
This is a subclass of Plack::Session::Store and implements its full interface.
METHODS
new
Plack::Session::Store::RedisFast->new( %param );
Parameters:
- redis
-
A simple accessor for the Redis handle.
- builder
-
A simple builder for the Redis handle if "redis" not set.
- inflate
-
A simple serializer, requires "deflate" param.
- deflate
-
A simple deserializer, requires "inflate" param.
- encoder
-
A simple encoder (encode/decode implementation), class or instance. JSON/utf8 by default.
- prefix
-
A prefix for Redis session ids. 'Plack::Session::Store::RedisFast:' by default.
- expire
-
An expire for Redis sessions. "ONE_MONTH" in Time::Seconds by default.
each_session
$store->each_session(sub {
my ( $redis_instance, $redis_prefix, $session_id, $session ) = @_;
});
Enumerates all stored sessions using SCAN, see https://redis.io/commands/scan for limitations.
BUGS
All complex software has bugs lurking in it, and this module is no exception. If you find a bug please fill in GitHub issues.
AUTHOR
Akzhan Abdulin <akzhan.abdulin@gmail.com>
COPYRIGHT
Copyright 2017- Akzhan Abdulin
LICENSE
MIT License