2017-02-15 19:06:19 +01:00
|
|
|
package sessions
|
|
|
|
|
|
|
|
import (
|
|
|
|
"time"
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
|
2019-07-23 16:47:28 +02:00
|
|
|
"github.com/kataras/iris/context"
|
|
|
|
|
|
|
|
uuid "github.com/iris-contrib/go.uuid"
|
2017-02-15 19:06:19 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
// DefaultCookieName the secret cookie's name for sessions
|
|
|
|
DefaultCookieName = "irissessionid"
|
|
|
|
)
|
|
|
|
|
2017-10-01 03:31:13 +02:00
|
|
|
// Encoding is the Cookie Encoder/Decoder interface, which can be passed as configuration field
|
|
|
|
// alternatively to the `Encode` and `Decode` fields.
|
|
|
|
type Encoding interface {
|
|
|
|
// Encode the cookie value if not nil.
|
|
|
|
// Should accept as first argument the cookie name (config.Name)
|
|
|
|
// as second argument the server's generated session id.
|
2019-06-07 20:07:08 +02:00
|
|
|
// Should return the new session id, if error the session id set to empty which is invalid.
|
2017-10-01 03:31:13 +02:00
|
|
|
//
|
|
|
|
// Note: Errors are not printed, so you have to know what you're doing,
|
|
|
|
// and remember: if you use AES it only supports key sizes of 16, 24 or 32 bytes.
|
|
|
|
// You either need to provide exactly that amount or you derive the key from what you type in.
|
|
|
|
//
|
|
|
|
// Defaults to nil
|
|
|
|
Encode(cookieName string, value interface{}) (string, error)
|
|
|
|
// Decode the cookie value if not nil.
|
|
|
|
// Should accept as first argument the cookie name (config.Name)
|
|
|
|
// as second second accepts the client's cookie value (the encoded session id).
|
|
|
|
// Should return an error if decode operation failed.
|
|
|
|
//
|
|
|
|
// Note: Errors are not printed, so you have to know what you're doing,
|
|
|
|
// and remember: if you use AES it only supports key sizes of 16, 24 or 32 bytes.
|
|
|
|
// You either need to provide exactly that amount or you derive the key from what you type in.
|
|
|
|
//
|
|
|
|
// Defaults to nil
|
|
|
|
Decode(cookieName string, cookieValue string, v interface{}) error
|
|
|
|
}
|
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
type (
|
2017-12-24 05:24:45 +01:00
|
|
|
// Config is the configuration for sessions. Please read it before using sessions.
|
2017-02-15 19:06:19 +01:00
|
|
|
Config struct {
|
|
|
|
// Cookie string, the session's client cookie name, for example: "mysessionid"
|
|
|
|
//
|
2017-10-01 03:31:13 +02:00
|
|
|
// Defaults to "irissessionid".
|
2017-02-15 19:06:19 +01:00
|
|
|
Cookie string
|
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// CookieSecureTLS set to true if server is running over TLS
|
2019-06-07 20:07:08 +02:00
|
|
|
// and you need the session's cookie "Secure" field to be set true.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
//
|
|
|
|
// Note: The user should fill the Decode configuation field in order for this to work.
|
2019-06-07 20:07:08 +02:00
|
|
|
// Recommendation: You don't need this to be set to true, just fill the Encode and Decode fields
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// with a third-party library like secure cookie, example is provided at the _examples folder.
|
|
|
|
//
|
2017-10-01 03:31:13 +02:00
|
|
|
// Defaults to false.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
CookieSecureTLS bool
|
|
|
|
|
2017-12-13 13:37:02 +01:00
|
|
|
// AllowReclaim will allow to
|
|
|
|
// Destroy and Start a session in the same request handler.
|
2017-12-15 14:46:18 +01:00
|
|
|
// All it does is that it removes the cookie for both `Request` and `ResponseWriter` while `Destroy`
|
|
|
|
// or add a new cookie to `Request` while `Start`.
|
2017-12-13 13:37:02 +01:00
|
|
|
//
|
|
|
|
// Defaults to false.
|
|
|
|
AllowReclaim bool
|
|
|
|
|
2017-03-18 11:22:20 +01:00
|
|
|
// Encode the cookie value if not nil.
|
2017-10-01 03:31:13 +02:00
|
|
|
// Should accept as first argument the cookie name (config.Cookie)
|
2017-03-18 11:22:20 +01:00
|
|
|
// as second argument the server's generated session id.
|
2019-06-07 20:07:08 +02:00
|
|
|
// Should return the new session id, if error the session id set to empty which is invalid.
|
2017-03-18 11:22:20 +01:00
|
|
|
//
|
|
|
|
// Note: Errors are not printed, so you have to know what you're doing,
|
|
|
|
// and remember: if you use AES it only supports key sizes of 16, 24 or 32 bytes.
|
|
|
|
// You either need to provide exactly that amount or you derive the key from what you type in.
|
|
|
|
//
|
2017-10-01 03:31:13 +02:00
|
|
|
// Defaults to nil.
|
2017-03-18 11:22:20 +01:00
|
|
|
Encode func(cookieName string, value interface{}) (string, error)
|
|
|
|
// Decode the cookie value if not nil.
|
2017-10-01 03:31:13 +02:00
|
|
|
// Should accept as first argument the cookie name (config.Cookie)
|
2017-03-18 11:22:20 +01:00
|
|
|
// as second second accepts the client's cookie value (the encoded session id).
|
|
|
|
// Should return an error if decode operation failed.
|
|
|
|
//
|
|
|
|
// Note: Errors are not printed, so you have to know what you're doing,
|
|
|
|
// and remember: if you use AES it only supports key sizes of 16, 24 or 32 bytes.
|
|
|
|
// You either need to provide exactly that amount or you derive the key from what you type in.
|
|
|
|
//
|
2017-10-01 03:31:13 +02:00
|
|
|
// Defaults to nil.
|
2017-03-18 11:22:20 +01:00
|
|
|
Decode func(cookieName string, cookieValue string, v interface{}) error
|
|
|
|
|
2017-10-01 03:31:13 +02:00
|
|
|
// Encoding same as Encode and Decode but receives a single instance which
|
|
|
|
// completes the "CookieEncoder" interface, `Encode` and `Decode` functions.
|
2017-12-24 05:24:45 +01:00
|
|
|
//
|
|
|
|
// Defaults to nil.
|
2017-10-01 03:31:13 +02:00
|
|
|
Encoding Encoding
|
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
// Expires the duration of which the cookie must expires (created_time.Add(Expires)).
|
|
|
|
// If you want to delete the cookie when the browser closes, set it to -1.
|
|
|
|
//
|
|
|
|
// 0 means no expire, (24 years)
|
|
|
|
// -1 means when browser closes
|
|
|
|
// > 0 is the time.Duration which the session cookies should expire.
|
|
|
|
//
|
2017-10-01 03:31:13 +02:00
|
|
|
// Defaults to infinitive/unlimited life duration(0).
|
2017-02-15 19:06:19 +01:00
|
|
|
Expires time.Duration
|
|
|
|
|
2019-07-23 16:47:28 +02:00
|
|
|
// SessionIDGenerator can be set to a function which
|
|
|
|
// return a unique session id.
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
// By default we will use a uuid impl package to generate
|
|
|
|
// that, but developers can change that with simple assignment.
|
2019-07-23 16:47:28 +02:00
|
|
|
SessionIDGenerator func(ctx context.Context) string
|
2017-02-15 19:06:19 +01:00
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// DisableSubdomainPersistence set it to true in order dissallow your subdomains to have access to the session cookie
|
2017-02-15 19:06:19 +01:00
|
|
|
//
|
2017-10-01 03:31:13 +02:00
|
|
|
// Defaults to false.
|
2017-02-15 19:06:19 +01:00
|
|
|
DisableSubdomainPersistence bool
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
// Validate corrects missing fields configuration fields and returns the right configuration
|
|
|
|
func (c Config) Validate() Config {
|
|
|
|
if c.Cookie == "" {
|
|
|
|
c.Cookie = DefaultCookieName
|
|
|
|
}
|
|
|
|
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
if c.SessionIDGenerator == nil {
|
2019-07-23 16:47:28 +02:00
|
|
|
c.SessionIDGenerator = func(context.Context) string {
|
2018-04-03 12:07:23 +02:00
|
|
|
id, _ := uuid.NewV4()
|
Publish the new version :airplane: | Look description please!
# FAQ
### Looking for free support?
http://support.iris-go.com
https://kataras.rocket.chat/channel/iris
### Looking for previous versions?
https://github.com/kataras/iris#version
### Should I upgrade my Iris?
Developers are not forced to upgrade if they don't really need it. Upgrade whenever you feel ready.
> Iris uses the [vendor directory](https://docs.google.com/document/d/1Bz5-UB7g2uPBdOx-rw5t9MxJwkfpx90cqG9AFL0JAYo) feature, so you get truly reproducible builds, as this method guards against upstream renames and deletes.
**How to upgrade**: Open your command-line and execute this command: `go get -u github.com/kataras/iris`.
For further installation support, please click [here](http://support.iris-go.com/d/16-how-to-install-iris-web-framework).
### About our new home page
http://iris-go.com
Thanks to [Santosh Anand](https://github.com/santoshanand) the http://iris-go.com has been upgraded and it's really awesome!
[Santosh](https://github.com/santoshanand) is a freelancer, he has a great knowledge of nodejs and express js, Android, iOS, React Native, Vue.js etc, if you need a developer to find or create a solution for your problem or task, please contact with him.
The amount of the next two or three donations you'll send they will be immediately transferred to his own account balance, so be generous please!
Read more at https://github.com/kataras/iris/blob/master/HISTORY.md
Former-commit-id: eec2d71bbe011d6b48d2526eb25919e36e5ad94e
2017-06-03 22:22:52 +02:00
|
|
|
return id.String()
|
|
|
|
}
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-10-01 03:31:13 +02:00
|
|
|
if c.Encoding != nil {
|
|
|
|
c.Encode = c.Encoding.Encode
|
|
|
|
c.Decode = c.Encoding.Decode
|
|
|
|
}
|
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
return c
|
|
|
|
}
|