summaryrefslogtreecommitdiff
path: root/store.go
diff options
context:
space:
mode:
Diffstat (limited to 'store.go')
-rw-r--r--store.go60
1 files changed, 23 insertions, 37 deletions
diff --git a/store.go b/store.go
index 33b2e77..0641254 100644
--- a/store.go
+++ b/store.go
@@ -12,7 +12,7 @@ import (
"strings"
"sync"
- "github.com/gorilla/securecookie"
+ "github.com/admpub/securecookie"
"github.com/webx-top/echo"
)
@@ -53,20 +53,13 @@ type Store interface {
func NewCookieStore(keyPairs ...[]byte) *CookieStore {
cs := &CookieStore{
Codecs: securecookie.CodecsFromPairs(keyPairs...),
- Options: &Options{
- Path: "/",
- MaxAge: 86400 * 30,
- },
}
-
- cs.MaxAge(cs.Options.MaxAge)
return cs
}
// CookieStore stores sessions using secure cookies.
type CookieStore struct {
- Codecs []securecookie.Codec
- Options *Options // default configuration
+ Codecs []securecookie.Codec
}
// Get returns a session for the given name after adding it to the registry.
@@ -87,12 +80,12 @@ func (s *CookieStore) Get(ctx echo.Context, name string) (*Session, error) {
// decoded session after the first call.
func (s *CookieStore) New(ctx echo.Context, name string) (*Session, error) {
session := NewSession(s, name)
- opts := *s.Options
- session.Options = &opts
session.IsNew = true
var err error
if v := ctx.GetCookie(name); len(v) > 0 {
- err = securecookie.DecodeMulti(name, v, &session.Values,
+ err = securecookie.DecodeMultiWithMaxAge(
+ name, v, &session.Values,
+ ctx.CookieOptions().MaxAge,
s.Codecs...)
if err == nil {
session.IsNew = false
@@ -108,7 +101,7 @@ func (s *CookieStore) Save(ctx echo.Context, session *Session) error {
if err != nil {
return err
}
- SetCookie(ctx, session.Name(), encoded, session.Options)
+ SetCookie(ctx, session.Name(), encoded)
return nil
}
@@ -116,8 +109,6 @@ func (s *CookieStore) Save(ctx echo.Context, session *Session) error {
// implementation. Individual sessions can be deleted by setting Options.MaxAge
// = -1 for that session.
func (s *CookieStore) MaxAge(age int) {
- s.Options.MaxAge = age
-
// Set the maxAge for each securecookie instance.
for _, codec := range s.Codecs {
if sc, ok := codec.(*securecookie.SecureCookie); ok {
@@ -142,14 +133,8 @@ func NewFilesystemStore(path string, keyPairs ...[]byte) *FilesystemStore {
}
fs := &FilesystemStore{
Codecs: securecookie.CodecsFromPairs(keyPairs...),
- Options: &Options{
- Path: "/",
- MaxAge: 86400 * 30,
- },
- path: path,
+ path: path,
}
-
- fs.MaxAge(fs.Options.MaxAge)
return fs
}
@@ -159,9 +144,8 @@ func NewFilesystemStore(path string, keyPairs ...[]byte) *FilesystemStore {
//
// This store is still experimental and not well tested. Feedback is welcome.
type FilesystemStore struct {
- Codecs []securecookie.Codec
- Options *Options // default configuration
- path string
+ Codecs []securecookie.Codec
+ path string
}
// MaxLength restricts the maximum length of new sessions to l.
@@ -187,14 +171,15 @@ func (s *FilesystemStore) Get(ctx echo.Context, name string) (*Session, error) {
// See CookieStore.New().
func (s *FilesystemStore) New(ctx echo.Context, name string) (*Session, error) {
session := NewSession(s, name)
- opts := *s.Options
- session.Options = &opts
session.IsNew = true
var err error
if v := ctx.GetCookie(name); len(v) > 0 {
- err = securecookie.DecodeMulti(name, v, &session.ID, s.Codecs...)
+ err = securecookie.DecodeMultiWithMaxAge(
+ name, v, &session.ID,
+ ctx.CookieOptions().MaxAge,
+ s.Codecs...)
if err == nil {
- err = s.load(session)
+ err = s.load(ctx, session)
if err == nil {
session.IsNew = false
}
@@ -207,11 +192,11 @@ func (s *FilesystemStore) New(ctx echo.Context, name string) (*Session, error) {
func (s *FilesystemStore) Save(ctx echo.Context,
session *Session) error {
// Delete if max-age is <= 0
- if session.Options.MaxAge <= 0 {
+ if ctx.CookieOptions().MaxAge <= 0 {
if err := s.erase(session); err != nil {
return err
}
- SetCookie(ctx, session.Name(), "", session.Options)
+ SetCookie(ctx, session.Name(), "")
return nil
}
if len(session.ID) == 0 {
@@ -229,7 +214,7 @@ func (s *FilesystemStore) Save(ctx echo.Context,
if err != nil {
return err
}
- SetCookie(ctx, session.Name(), encoded, session.Options)
+ SetCookie(ctx, session.Name(), encoded)
return nil
}
@@ -247,8 +232,6 @@ func (s *FilesystemStore) erase(session *Session) error {
// implementation. Individual sessions can be deleted by setting Options.MaxAge
// = -1 for that session.
func (s *FilesystemStore) MaxAge(age int) {
- s.Options.MaxAge = age
-
// Set the maxAge for each securecookie instance.
for _, codec := range s.Codecs {
if sc, ok := codec.(*securecookie.SecureCookie); ok {
@@ -271,7 +254,7 @@ func (s *FilesystemStore) save(session *Session) error {
}
// load reads a file and decodes its content into session.Values.
-func (s *FilesystemStore) load(session *Session) error {
+func (s *FilesystemStore) load(ctx echo.Context, session *Session) error {
filename := filepath.Join(s.path, "session_"+session.ID)
fileMutex.RLock()
defer fileMutex.RUnlock()
@@ -279,8 +262,11 @@ func (s *FilesystemStore) load(session *Session) error {
if err != nil {
return err
}
- if err = securecookie.DecodeMulti(session.Name(), string(fdata),
- &session.Values, s.Codecs...); err != nil {
+ if err = securecookie.DecodeMultiWithMaxAge(
+ session.Name(), string(fdata),
+ &session.Values,
+ ctx.CookieOptions().MaxAge,
+ s.Codecs...); err != nil {
return err
}
return nil