Documentation ¶
Index ¶
- type CrDBSession
- type CrDBStore
- func (db *CrDBStore) Cleanup(interval time.Duration) (chan<- struct{}, <-chan struct{})
- func (db *CrDBStore) Close()
- func (db *CrDBStore) Get(r *http.Request, name string) (*sessions.Session, error)
- func (db *CrDBStore) MaxAge(age int)
- func (db *CrDBStore) MaxLength(l int)
- func (db *CrDBStore) New(r *http.Request, name string) (*sessions.Session, error)
- func (db *CrDBStore) Save(r *http.Request, w http.ResponseWriter, session *sessions.Session) error
- func (db *CrDBStore) StopCleanup(quit chan<- struct{}, done <-chan struct{})
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type CrDBSession ¶
type CrDBSession struct { ID int64 Key string Data string CreatedOn time.Time ModifiedOn time.Time ExpiresOn time.Time }
CrDBSession type
type CrDBStore ¶
type CrDBStore struct { Codecs []securecookie.Codec Options *sessions.Options Path string DbPool *sql.DB }
CrDBStore represents the currently configured session store.
func NewCrDBStore ¶
NewCrDBStore creates a new CrDBStore instance and a new database/sql pool. This will also create in the database the schema needed by CrDBStore.
func NewCrDBStoreFromPool ¶
NewCrDBStoreFromPool creates a new CrDBStore instance from an existing database/sql pool. This will also create the database schema needed by CrDBStore.
func (*CrDBStore) Cleanup ¶
Cleanup runs a background goroutine every interval that deletes expired sessions from the database.
The design is based on https://github.com/yosssi/boltstore
func (*CrDBStore) Get ¶
Get Fetches a session for a given name after it has been added to the registry.
func (*CrDBStore) MaxAge ¶
MaxAge sets the maximum age for the store and the underlying cookie implementation. Individual sessions can be deleted by setting Options.MaxAge = -1 for that session.
func (*CrDBStore) MaxLength ¶
MaxLength restricts the maximum length of new sessions to l. If l is 0 there is no limit to the size of a session, use with caution. The default for a new CrDBStore is 4096. PostgreSQL allows for max value sizes of up to 1GB (http://www.postgresql.org/docs/current/interactive/datatype-character.html)
func (*CrDBStore) New ¶
New returns a new session for the given name without adding it to the registry.
func (*CrDBStore) Save ¶
Save saves the given session into the database and deletes cookies if needed
func (*CrDBStore) StopCleanup ¶
func (db *CrDBStore) StopCleanup(quit chan<- struct{}, done <-chan struct{})
StopCleanup stops the background cleanup from running.