2016-05-30 16:08:09 +02:00
|
|
|
package config
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/imdario/mergo"
|
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
universe time.Time // 0001-01-01 00:00:00 +0000 UTC
|
|
|
|
// CookieExpireNever the default cookie's life for sessions, unlimited
|
|
|
|
CookieExpireNever = universe
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// DefaultCookieName the secret cookie's name for sessions
|
2016-06-03 04:11:50 +02:00
|
|
|
DefaultCookieName = "irissessionid"
|
|
|
|
// DefaultSessionGcDuration is the default Session Manager's GCDuration , which is 2 hours
|
2016-05-30 16:08:09 +02:00
|
|
|
DefaultSessionGcDuration = time.Duration(2) * time.Hour
|
|
|
|
)
|
|
|
|
|
|
|
|
type (
|
|
|
|
|
|
|
|
// Sessions the configuration for sessions
|
:rainbow: sessions were re-written, update to 4.0.0-alpha.2, read HISTORY.md
**Sessions were re-written **
- Developers can use more than one 'session database', at the same time,
to store the sessions
- Easy to develop a custom session database (only two functions are
required (Load & Update)), [learn
more](https://github.com/iris-contrib/sessiondb/blob/master/redis/database.go)
- Session databases are located
[here](https://github.com/iris-contrib/sessiondb), contributions are
welcome
- The only frontend deleted 'thing' is the: **config.Sessions.Provider**
- No need to register a database, the sessions works out-of-the-box
- No frontend/API changes except the
`context.Session().Set/Delete/Clear`, they doesn't return errors
anymore, btw they (errors) were always nil :)
- Examples (master branch) were updated.
```sh
$ go get github.com/iris-contrib/sessiondb/$DATABASE
```
```go
db := $DATABASE.New(configurationHere{})
iris.UseSessionDB(db)
```
> Note: Book is not updated yet, examples are up-to-date as always.
2016-07-15 19:50:36 +02:00
|
|
|
// has 5 fields
|
|
|
|
// first is the cookieName, the session's name (string) ["mysessionsecretcookieid"]
|
|
|
|
// second enable if you want to decode the cookie's key also
|
2016-05-30 16:08:09 +02:00
|
|
|
// third is the time which the client's cookie expires
|
|
|
|
// forth is the gcDuration (time.Duration) when this time passes it removes the unused sessions from the memory until the user come back
|
:rainbow: sessions were re-written, update to 4.0.0-alpha.2, read HISTORY.md
**Sessions were re-written **
- Developers can use more than one 'session database', at the same time,
to store the sessions
- Easy to develop a custom session database (only two functions are
required (Load & Update)), [learn
more](https://github.com/iris-contrib/sessiondb/blob/master/redis/database.go)
- Session databases are located
[here](https://github.com/iris-contrib/sessiondb), contributions are
welcome
- The only frontend deleted 'thing' is the: **config.Sessions.Provider**
- No need to register a database, the sessions works out-of-the-box
- No frontend/API changes except the
`context.Session().Set/Delete/Clear`, they doesn't return errors
anymore, btw they (errors) were always nil :)
- Examples (master branch) were updated.
```sh
$ go get github.com/iris-contrib/sessiondb/$DATABASE
```
```go
db := $DATABASE.New(configurationHere{})
iris.UseSessionDB(db)
```
> Note: Book is not updated yet, examples are up-to-date as always.
2016-07-15 19:50:36 +02:00
|
|
|
// fifth is the DisableSubdomainPersistence which you can set it to true in order dissallow your iris subdomains to have access to the session cook
|
2016-05-30 16:08:09 +02:00
|
|
|
Sessions struct {
|
|
|
|
// Cookie string, the session's client cookie name, for example: "irissessionid"
|
|
|
|
Cookie string
|
2016-07-01 00:38:29 +02:00
|
|
|
// DecodeCookie set it to true to decode the cookie key with base64 URLEncoding
|
|
|
|
// Defaults to false
|
|
|
|
DecodeCookie bool
|
2016-07-20 05:33:24 +02:00
|
|
|
// Expires the duration of which the cookie must expires (created_time.Add(Expires)).
|
|
|
|
// Default infinitive/unlimited life duration(0)
|
|
|
|
Expires time.Duration
|
2016-05-30 16:08:09 +02:00
|
|
|
// GcDuration every how much duration(GcDuration) the memory should be clear for unused cookies (GcDuration)
|
|
|
|
// for example: time.Duration(2)*time.Hour. it will check every 2 hours if cookie hasn't be used for 2 hours,
|
2016-07-20 05:33:24 +02:00
|
|
|
// deletes it from backend memory until the user comes back, then the session continue to work as it was
|
2016-05-30 16:08:09 +02:00
|
|
|
//
|
|
|
|
// Default 2 hours
|
|
|
|
GcDuration time.Duration
|
2016-06-30 04:58:04 +02:00
|
|
|
|
:rainbow: sessions were re-written, update to 4.0.0-alpha.2, read HISTORY.md
**Sessions were re-written **
- Developers can use more than one 'session database', at the same time,
to store the sessions
- Easy to develop a custom session database (only two functions are
required (Load & Update)), [learn
more](https://github.com/iris-contrib/sessiondb/blob/master/redis/database.go)
- Session databases are located
[here](https://github.com/iris-contrib/sessiondb), contributions are
welcome
- The only frontend deleted 'thing' is the: **config.Sessions.Provider**
- No need to register a database, the sessions works out-of-the-box
- No frontend/API changes except the
`context.Session().Set/Delete/Clear`, they doesn't return errors
anymore, btw they (errors) were always nil :)
- Examples (master branch) were updated.
```sh
$ go get github.com/iris-contrib/sessiondb/$DATABASE
```
```go
db := $DATABASE.New(configurationHere{})
iris.UseSessionDB(db)
```
> Note: Book is not updated yet, examples are up-to-date as always.
2016-07-15 19:50:36 +02:00
|
|
|
// DisableSubdomainPersistence set it to true in order dissallow your iris subdomains to have access to the session cookie
|
2016-06-30 04:58:04 +02:00
|
|
|
// defaults to false
|
2016-06-30 16:55:33 +02:00
|
|
|
DisableSubdomainPersistence bool
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
// DefaultSessions the default configs for Sessions
|
|
|
|
func DefaultSessions() Sessions {
|
|
|
|
return Sessions{
|
2016-06-30 04:58:04 +02:00
|
|
|
Cookie: DefaultCookieName,
|
2016-07-01 00:38:29 +02:00
|
|
|
DecodeCookie: false,
|
2016-07-20 05:33:24 +02:00
|
|
|
Expires: 0,
|
2016-06-30 04:58:04 +02:00
|
|
|
GcDuration: DefaultSessionGcDuration,
|
2016-06-30 16:55:33 +02:00
|
|
|
DisableSubdomainPersistence: false,
|
2016-05-30 16:08:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
// Merge merges the default with the given config and returns the result
|
|
|
|
func (c Sessions) Merge(cfg []Sessions) (config Sessions) {
|
|
|
|
|
|
|
|
if len(cfg) > 0 {
|
|
|
|
config = cfg[0]
|
|
|
|
mergo.Merge(&config, c)
|
|
|
|
} else {
|
|
|
|
_default := c
|
|
|
|
config = _default
|
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2016-06-03 04:11:50 +02:00
|
|
|
// MergeSingle merges the default with the given config and returns the result
|
2016-05-30 16:08:09 +02:00
|
|
|
func (c Sessions) MergeSingle(cfg Sessions) (config Sessions) {
|
|
|
|
|
|
|
|
config = cfg
|
|
|
|
mergo.Merge(&config, c)
|
|
|
|
|
|
|
|
return
|
|
|
|
}
|