package cookiestore import ( ginsessions "github.com/dalu/sessions" "github.com/gorilla/sessions" ) // CookieStore interface type CookieStore interface { ginsessions.Store } // NewCookieStore creates a new cookieStore. // Keys are defined in pairs to allow key rotation, but the common case is to set a single // authentication key and optionally an encryption key. // // The first key in a pair is used for authentication and the second for encryption. The // encryption key can be set to nil or omitted in the last pair, but the authentication key // is required in all pairs. // // It is recommended to use an authentication key with 32 or 64 bytes. The encryption key, // if set, must be either 16, 24, or 32 bytes to select AES-128, AES-192, or AES-256 modes. func NewCookieStore(keyPairs ...[]byte) CookieStore { return &cookieStore{sessions.NewCookieStore(keyPairs...)} } type cookieStore struct { *sessions.CookieStore } func (c *cookieStore) Options(options ginsessions.Options) { c.CookieStore.Options = &sessions.Options{ Path: options.Path, Domain: options.Domain, MaxAge: options.MaxAge, Secure: options.Secure, HttpOnly: options.HTTPOnly, } }