2017-02-15 19:06:19 +01:00
|
|
|
package sessions
|
|
|
|
|
|
|
|
import (
|
2019-10-24 17:57:05 +02:00
|
|
|
"reflect"
|
2017-02-15 19:06:19 +01:00
|
|
|
"strconv"
|
|
|
|
"sync"
|
|
|
|
|
2019-10-25 00:27:02 +02:00
|
|
|
"github.com/kataras/iris/v12/core/memstore"
|
2017-02-15 19:06:19 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
type (
|
2017-07-10 17:32:42 +02:00
|
|
|
// Session should expose the Sessions's end-user API.
|
|
|
|
// It is the session's storage controller which you can
|
|
|
|
// save or retrieve values based on a key.
|
|
|
|
//
|
|
|
|
// This is what will be returned when sess := sessions.Start().
|
|
|
|
Session struct {
|
2020-04-13 21:15:55 +02:00
|
|
|
sid string
|
|
|
|
isNew bool
|
|
|
|
flashes map[string]*flashMessage
|
|
|
|
mu sync.RWMutex // for flashes.
|
|
|
|
// Lifetime it contains the expiration data, use it for read-only information.
|
|
|
|
// See `Sessions.UpdateExpiration` too.
|
2023-09-26 20:14:57 +02:00
|
|
|
Lifetime *memstore.LifeTime
|
2020-04-13 21:15:55 +02:00
|
|
|
// Man is the sessions manager that this session created of.
|
|
|
|
Man *Sessions
|
|
|
|
|
2017-08-01 21:25:08 +02:00
|
|
|
provider *provider
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
flashMessage struct {
|
|
|
|
// if true then this flash message is removed on the flash gc
|
|
|
|
shouldRemove bool
|
|
|
|
value interface{}
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
2017-12-16 22:12:49 +01:00
|
|
|
// Destroy destroys this session, it removes its session values and any flashes.
|
|
|
|
// This session entry will be removed from the server,
|
|
|
|
// the registered session databases will be notified for this deletion as well.
|
|
|
|
//
|
|
|
|
// Note that this method does NOT remove the client's cookie, although
|
|
|
|
// it should be reseted if new session is attached to that (client).
|
2017-12-16 22:09:00 +01:00
|
|
|
//
|
2020-04-13 21:15:55 +02:00
|
|
|
// Use the session's manager `Destroy(ctx)` in order to remove the cookie instead.
|
2017-12-16 22:09:00 +01:00
|
|
|
func (s *Session) Destroy() {
|
|
|
|
s.provider.deleteSession(s)
|
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// ID returns the session's ID.
|
|
|
|
func (s *Session) ID() string {
|
2017-02-15 19:06:19 +01:00
|
|
|
return s.sid
|
|
|
|
}
|
|
|
|
|
2020-10-04 15:50:21 +02:00
|
|
|
// IsNew returns true if this session is just
|
2017-08-21 00:45:02 +02:00
|
|
|
// created by the current application's process.
|
2017-08-01 10:00:30 +02:00
|
|
|
func (s *Session) IsNew() bool {
|
|
|
|
return s.isNew
|
|
|
|
}
|
|
|
|
|
2017-06-08 02:39:15 +02:00
|
|
|
// Get returns a value based on its "key".
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) Get(key string) interface{} {
|
2018-04-22 12:52:36 +02:00
|
|
|
return s.provider.db.Get(s.sid, key)
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2020-10-04 15:50:21 +02:00
|
|
|
// Decode binds the given "outPtr" to the value associated to the provided "key".
|
|
|
|
func (s *Session) Decode(key string, outPtr interface{}) error {
|
|
|
|
return s.provider.db.Decode(s.sid, key, outPtr)
|
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// when running on the session manager removes any 'old' flash messages.
|
|
|
|
func (s *Session) runFlashGC() {
|
2017-02-15 19:06:19 +01:00
|
|
|
s.mu.Lock()
|
|
|
|
for key, v := range s.flashes {
|
|
|
|
if v.shouldRemove {
|
|
|
|
delete(s.flashes, key)
|
|
|
|
}
|
|
|
|
}
|
2022-06-17 21:03:18 +02:00
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
s.mu.Unlock()
|
|
|
|
}
|
|
|
|
|
2017-06-10 04:00:18 +02:00
|
|
|
// HasFlash returns true if this session has available flash messages.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) HasFlash() bool {
|
2017-08-21 00:45:02 +02:00
|
|
|
s.mu.RLock()
|
|
|
|
has := len(s.flashes) > 0
|
|
|
|
s.mu.RUnlock()
|
|
|
|
return has
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-06-10 04:28:17 +02:00
|
|
|
// GetFlash returns a stored flash message based on its "key"
|
|
|
|
// which will be removed on the next request.
|
2017-02-15 19:06:19 +01:00
|
|
|
//
|
|
|
|
// To check for flash messages we use the HasFlash() Method
|
|
|
|
// and to obtain the flash message we use the GetFlash() Method.
|
|
|
|
// There is also a method GetFlashes() to fetch all the messages.
|
|
|
|
//
|
|
|
|
// Fetching a message deletes it from the session.
|
2017-06-10 04:28:17 +02:00
|
|
|
// This means that a message is meant to be displayed only on the first page served to the user.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) GetFlash(key string) interface{} {
|
2017-06-10 04:28:17 +02:00
|
|
|
fv, ok := s.peekFlashMessage(key)
|
|
|
|
if !ok {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
fv.shouldRemove = true
|
|
|
|
return fv.value
|
|
|
|
}
|
|
|
|
|
|
|
|
// PeekFlash returns a stored flash message based on its "key".
|
|
|
|
// Unlike GetFlash, this will keep the message valid for the next requests,
|
|
|
|
// until GetFlashes or GetFlash("key").
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) PeekFlash(key string) interface{} {
|
2017-06-10 04:28:17 +02:00
|
|
|
fv, ok := s.peekFlashMessage(key)
|
|
|
|
if !ok {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return fv.value
|
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) peekFlashMessage(key string) (*flashMessage, bool) {
|
2017-08-21 00:45:02 +02:00
|
|
|
s.mu.RLock()
|
|
|
|
fv, found := s.flashes[key]
|
|
|
|
s.mu.RUnlock()
|
|
|
|
|
|
|
|
if !found {
|
|
|
|
return nil, false
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
return fv, true
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
// GetString same as Get but returns its string representation,
|
|
|
|
// if key doesn't exist then it returns an empty string.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) GetString(key string) string {
|
2017-02-15 19:06:19 +01:00
|
|
|
if value := s.Get(key); value != nil {
|
|
|
|
if v, ok := value.(string); ok {
|
|
|
|
return v
|
|
|
|
}
|
2017-12-30 19:40:52 +01:00
|
|
|
|
|
|
|
if v, ok := value.(int); ok {
|
|
|
|
return strconv.Itoa(v)
|
|
|
|
}
|
|
|
|
|
|
|
|
if v, ok := value.(int64); ok {
|
|
|
|
return strconv.FormatInt(v, 10)
|
|
|
|
}
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2018-03-24 09:39:44 +01:00
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetStringDefault same as Get but returns its string representation,
|
|
|
|
// if key doesn't exist then it returns the "defaultValue".
|
|
|
|
func (s *Session) GetStringDefault(key string, defaultValue string) string {
|
|
|
|
if v := s.GetString(key); v != "" {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
return defaultValue
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
// GetFlashString same as `GetFlash` but returns its string representation,
|
|
|
|
// if key doesn't exist then it returns an empty string.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) GetFlashString(key string) string {
|
2017-08-21 00:45:02 +02:00
|
|
|
return s.GetFlashStringDefault(key, "")
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetFlashStringDefault same as `GetFlash` but returns its string representation,
|
|
|
|
// if key doesn't exist then it returns the "defaultValue".
|
|
|
|
func (s *Session) GetFlashStringDefault(key string, defaultValue string) string {
|
2017-02-15 19:06:19 +01:00
|
|
|
if value := s.GetFlash(key); value != nil {
|
|
|
|
if v, ok := value.(string); ok {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
return defaultValue
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2019-10-24 17:57:05 +02:00
|
|
|
// ErrEntryNotFound similar to core/memstore#ErrEntryNotFound but adds
|
|
|
|
// the value (if found) matched to the requested key-value pair of the session's memory storage.
|
|
|
|
type ErrEntryNotFound struct {
|
|
|
|
Err *memstore.ErrEntryNotFound
|
|
|
|
Value interface{}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (e *ErrEntryNotFound) Error() string {
|
|
|
|
return e.Err.Error()
|
|
|
|
}
|
|
|
|
|
|
|
|
// Unwrap method implements the dynamic Unwrap interface of the std errors package.
|
|
|
|
func (e *ErrEntryNotFound) Unwrap() error {
|
|
|
|
return e.Err
|
|
|
|
}
|
|
|
|
|
|
|
|
// As method implements the dynamic As interface of the std errors package.
|
|
|
|
// As should be NOT used directly, use `errors.As` instead.
|
|
|
|
func (e *ErrEntryNotFound) As(target interface{}) bool {
|
|
|
|
if v, ok := target.(*memstore.ErrEntryNotFound); ok && e.Err != nil {
|
|
|
|
return e.Err.As(v)
|
|
|
|
}
|
|
|
|
|
|
|
|
v, ok := target.(*ErrEntryNotFound)
|
|
|
|
if !ok {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
if v.Value != nil {
|
|
|
|
if v.Value != e.Value {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if v.Err != nil {
|
|
|
|
if e.Err != nil {
|
|
|
|
return e.Err.As(v.Err)
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
func newErrEntryNotFound(key string, kind reflect.Kind, value interface{}) *ErrEntryNotFound {
|
|
|
|
return &ErrEntryNotFound{Err: &memstore.ErrEntryNotFound{Key: key, Kind: kind}, Value: value}
|
|
|
|
}
|
2017-02-15 19:06:19 +01:00
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
// GetInt same as `Get` but returns its int representation,
|
2018-03-24 09:39:44 +01:00
|
|
|
// if key doesn't exist then it returns -1 and a non-nil error.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) GetInt(key string) (int, error) {
|
2017-02-15 19:06:19 +01:00
|
|
|
v := s.Get(key)
|
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
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
if v != nil {
|
|
|
|
if vint, ok := v.(int); ok {
|
|
|
|
return vint, nil
|
|
|
|
}
|
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
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
if vfloat64, ok := v.(float64); ok {
|
|
|
|
return int(vfloat64), nil
|
|
|
|
}
|
2018-06-03 01:47:48 +02:00
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
if vint64, ok := v.(int64); ok {
|
|
|
|
return int(vint64), nil
|
|
|
|
}
|
2018-06-03 01:47:48 +02:00
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
if vstring, sok := v.(string); sok {
|
|
|
|
return strconv.Atoi(vstring)
|
|
|
|
}
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2019-10-24 17:57:05 +02:00
|
|
|
return -1, newErrEntryNotFound(key, reflect.Int, v)
|
2018-03-24 09:39:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetIntDefault same as `Get` but returns its int representation,
|
|
|
|
// if key doesn't exist then it returns the "defaultValue".
|
|
|
|
func (s *Session) GetIntDefault(key string, defaultValue int) int {
|
|
|
|
if v, err := s.GetInt(key); err == nil {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
return defaultValue
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-12-15 19:28:06 +01:00
|
|
|
// Increment increments the stored int value saved as "key" by +"n".
|
|
|
|
// If value doesn't exist on that "key" then it creates one with the "n" as its value.
|
|
|
|
// It returns the new, incremented, value.
|
|
|
|
func (s *Session) Increment(key string, n int) (newValue int) {
|
2018-03-24 09:39:44 +01:00
|
|
|
newValue = s.GetIntDefault(key, 0)
|
2017-12-15 19:28:06 +01:00
|
|
|
newValue += n
|
|
|
|
s.Set(key, newValue)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
// Decrement decrements the stored int value saved as "key" by -"n".
|
|
|
|
// If value doesn't exist on that "key" then it creates one with the "n" as its value.
|
|
|
|
// It returns the new, decremented, value even if it's less than zero.
|
|
|
|
func (s *Session) Decrement(key string, n int) (newValue int) {
|
2018-03-24 09:39:44 +01:00
|
|
|
newValue = s.GetIntDefault(key, 0)
|
2017-12-15 19:28:06 +01:00
|
|
|
newValue -= n
|
|
|
|
s.Set(key, newValue)
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
// GetInt64 same as `Get` but returns its int64 representation,
|
2018-03-24 09:39:44 +01:00
|
|
|
// if key doesn't exist then it returns -1 and a non-nil error.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) GetInt64(key string) (int64, error) {
|
2017-02-15 19:06:19 +01:00
|
|
|
v := s.Get(key)
|
2020-05-06 03:45:12 +02:00
|
|
|
if v != nil {
|
|
|
|
if vint64, ok := v.(int64); ok {
|
|
|
|
return vint64, nil
|
|
|
|
}
|
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
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
if vfloat64, ok := v.(float64); ok {
|
|
|
|
return int64(vfloat64), nil
|
|
|
|
}
|
2018-06-03 01:47:48 +02:00
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
if vint, ok := v.(int); ok {
|
|
|
|
return int64(vint), nil
|
|
|
|
}
|
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
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
if vstring, sok := v.(string); sok {
|
|
|
|
return strconv.ParseInt(vstring, 10, 64)
|
|
|
|
}
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2019-10-24 17:57:05 +02:00
|
|
|
return -1, newErrEntryNotFound(key, reflect.Int64, v)
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2018-03-24 09:39:44 +01:00
|
|
|
// GetInt64Default same as `Get` but returns its int64 representation,
|
|
|
|
// if key doesn't exist it returns the "defaultValue".
|
|
|
|
func (s *Session) GetInt64Default(key string, defaultValue int64) int64 {
|
|
|
|
if v, err := s.GetInt64(key); err == nil {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
|
|
|
return defaultValue
|
2017-08-21 00:45:02 +02:00
|
|
|
}
|
|
|
|
|
2020-05-06 03:45:12 +02:00
|
|
|
// GetUint64 same as `Get` but returns as uint64,
|
|
|
|
// if key doesn't exist then it returns 0 and a non-nil error.
|
|
|
|
func (s *Session) GetUint64(key string) (uint64, error) {
|
|
|
|
v := s.Get(key)
|
|
|
|
if v != nil {
|
|
|
|
switch vv := v.(type) {
|
|
|
|
case string:
|
|
|
|
val, err := strconv.ParseUint(vv, 10, 64)
|
|
|
|
if err != nil {
|
|
|
|
return 0, err
|
|
|
|
}
|
|
|
|
return uint64(val), nil
|
|
|
|
case uint8:
|
|
|
|
return uint64(vv), nil
|
|
|
|
case uint16:
|
|
|
|
return uint64(vv), nil
|
|
|
|
case uint32:
|
|
|
|
return uint64(vv), nil
|
|
|
|
case uint64:
|
|
|
|
return vv, nil
|
|
|
|
case int64:
|
|
|
|
return uint64(vv), nil
|
|
|
|
case int:
|
|
|
|
return uint64(vv), nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0, newErrEntryNotFound(key, reflect.Uint64, v)
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetUint64Default same as `Get` but returns as uint64,
|
|
|
|
// if key doesn't exist it returns the "defaultValue".
|
|
|
|
func (s *Session) GetUint64Default(key string, defaultValue uint64) uint64 {
|
|
|
|
if v, err := s.GetUint64(key); err == nil {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
|
|
|
return defaultValue
|
|
|
|
}
|
|
|
|
|
2018-03-24 09:39:44 +01:00
|
|
|
// GetFloat32 same as `Get` but returns its float32 representation,
|
|
|
|
// if key doesn't exist then it returns -1 and a non-nil error.
|
|
|
|
func (s *Session) GetFloat32(key string) (float32, error) {
|
2017-02-15 19:06:19 +01:00
|
|
|
v := s.Get(key)
|
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
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
if vfloat32, ok := v.(float32); ok {
|
|
|
|
return vfloat32, nil
|
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 vfloat64, ok := v.(float64); ok {
|
2017-02-15 19:06:19 +01:00
|
|
|
return float32(vfloat64), nil
|
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 vint, ok := v.(int); ok {
|
2017-02-15 19:06:19 +01:00
|
|
|
return float32(vint), nil
|
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
|
|
|
}
|
|
|
|
|
2018-06-03 01:47:48 +02:00
|
|
|
if vint64, ok := v.(int64); ok {
|
|
|
|
return float32(vint64), nil
|
|
|
|
}
|
|
|
|
|
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 vstring, sok := v.(string); sok {
|
2017-02-15 19:06:19 +01:00
|
|
|
vfloat64, err := strconv.ParseFloat(vstring, 32)
|
|
|
|
if err != nil {
|
|
|
|
return -1, err
|
|
|
|
}
|
|
|
|
return float32(vfloat64), nil
|
|
|
|
}
|
|
|
|
|
2019-10-24 17:57:05 +02:00
|
|
|
return -1, newErrEntryNotFound(key, reflect.Float32, v)
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2018-03-24 09:39:44 +01:00
|
|
|
// GetFloat32Default same as `Get` but returns its float32 representation,
|
|
|
|
// if key doesn't exist then it returns the "defaultValue".
|
|
|
|
func (s *Session) GetFloat32Default(key string, defaultValue float32) float32 {
|
|
|
|
if v, err := s.GetFloat32(key); err == nil {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
|
|
|
return defaultValue
|
2017-08-21 00:45:02 +02:00
|
|
|
}
|
|
|
|
|
2018-03-24 09:39:44 +01:00
|
|
|
// GetFloat64 same as `Get` but returns its float64 representation,
|
|
|
|
// if key doesn't exist then it returns -1 and a non-nil error.
|
|
|
|
func (s *Session) GetFloat64(key string) (float64, error) {
|
2017-02-15 19:06:19 +01:00
|
|
|
v := s.Get(key)
|
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
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
if vfloat32, ok := v.(float32); ok {
|
|
|
|
return float64(vfloat32), nil
|
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 vfloat64, ok := v.(float64); ok {
|
2017-02-15 19:06:19 +01:00
|
|
|
return vfloat64, nil
|
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 vint, ok := v.(int); ok {
|
2017-02-15 19:06:19 +01:00
|
|
|
return float64(vint), nil
|
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
|
|
|
}
|
|
|
|
|
2018-06-03 01:47:48 +02:00
|
|
|
if vint64, ok := v.(int64); ok {
|
|
|
|
return float64(vint64), nil
|
|
|
|
}
|
|
|
|
|
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 vstring, sok := v.(string); sok {
|
2017-02-15 19:06:19 +01:00
|
|
|
return strconv.ParseFloat(vstring, 32)
|
|
|
|
}
|
|
|
|
|
2019-10-24 17:57:05 +02:00
|
|
|
return -1, newErrEntryNotFound(key, reflect.Float64, v)
|
2018-03-24 09:39:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetFloat64Default same as `Get` but returns its float64 representation,
|
|
|
|
// if key doesn't exist then it returns the "defaultValue".
|
|
|
|
func (s *Session) GetFloat64Default(key string, defaultValue float64) float64 {
|
|
|
|
if v, err := s.GetFloat64(key); err == nil {
|
|
|
|
return v
|
|
|
|
}
|
|
|
|
|
|
|
|
return defaultValue
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-08-21 00:45:02 +02:00
|
|
|
// GetBoolean same as `Get` but returns its boolean representation,
|
2018-03-24 09:39:44 +01:00
|
|
|
// if key doesn't exist then it returns false and a non-nil error.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) GetBoolean(key string) (bool, error) {
|
2018-03-24 09:39:44 +01:00
|
|
|
v := s.Get(key)
|
|
|
|
if v == nil {
|
2019-10-24 17:57:05 +02:00
|
|
|
return false, newErrEntryNotFound(key, reflect.Bool, nil)
|
2018-03-24 09:39:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// here we could check for "true", "false" and 0 for false and 1 for true
|
|
|
|
// but this may cause unexpected behavior from the developer if they expecting an error
|
|
|
|
// so we just check if bool, if yes then return that bool, otherwise return false and an error.
|
|
|
|
if vb, ok := v.(bool); ok {
|
|
|
|
return vb, nil
|
|
|
|
}
|
|
|
|
if vstring, ok := v.(string); ok {
|
|
|
|
return strconv.ParseBool(vstring)
|
|
|
|
}
|
|
|
|
|
2019-10-24 17:57:05 +02:00
|
|
|
return false, newErrEntryNotFound(key, reflect.Bool, v)
|
2017-08-21 00:45:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// GetBooleanDefault same as `Get` but returns its boolean representation,
|
|
|
|
// if key doesn't exist then it returns the "defaultValue".
|
2018-03-24 09:39:44 +01:00
|
|
|
func (s *Session) GetBooleanDefault(key string, defaultValue bool) bool {
|
|
|
|
/*
|
|
|
|
Note that here we can't do more than duplicate the GetBoolean's code, because of the "false".
|
|
|
|
*/
|
2017-02-15 19:06:19 +01:00
|
|
|
v := s.Get(key)
|
2018-03-24 09:39:44 +01:00
|
|
|
if v == nil {
|
|
|
|
return defaultValue
|
|
|
|
}
|
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
// here we could check for "true", "false" and 0 for false and 1 for true
|
|
|
|
// but this may cause unexpected behavior from the developer if they expecting an error
|
2017-07-10 17:32:42 +02:00
|
|
|
// so we just check if bool, if yes then return that bool, otherwise return false and an error.
|
2017-02-15 19:06:19 +01:00
|
|
|
if vb, ok := v.(bool); ok {
|
2018-03-24 09:39:44 +01:00
|
|
|
return vb
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2018-03-24 09:39:44 +01:00
|
|
|
if vstring, ok := v.(string); ok {
|
|
|
|
if b, err := strconv.ParseBool(vstring); err == nil {
|
|
|
|
return b
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return defaultValue
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// GetAll returns a copy of all session's values.
|
|
|
|
func (s *Session) GetAll() map[string]interface{} {
|
2018-04-22 12:52:36 +02:00
|
|
|
items := make(map[string]interface{}, s.provider.db.Len(s.sid))
|
2017-02-15 19:06:19 +01:00
|
|
|
s.mu.RLock()
|
2018-04-22 12:52:36 +02:00
|
|
|
s.provider.db.Visit(s.sid, func(key string, value interface{}) {
|
2018-04-10 20:01:24 +02:00
|
|
|
items[key] = value
|
|
|
|
})
|
2017-02-15 19:06:19 +01:00
|
|
|
s.mu.RUnlock()
|
|
|
|
return items
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetFlashes returns all flash messages as map[string](key) and interface{} value
|
2017-07-10 17:32:42 +02:00
|
|
|
// NOTE: this will cause at remove all current flash messages on the next request of the same user.
|
|
|
|
func (s *Session) GetFlashes() map[string]interface{} {
|
2017-02-15 19:06:19 +01:00
|
|
|
flashes := make(map[string]interface{}, len(s.flashes))
|
|
|
|
s.mu.Lock()
|
|
|
|
for key, v := range s.flashes {
|
|
|
|
flashes[key] = v.value
|
|
|
|
v.shouldRemove = true
|
|
|
|
}
|
|
|
|
s.mu.Unlock()
|
|
|
|
return flashes
|
|
|
|
}
|
|
|
|
|
2018-04-22 12:52:36 +02:00
|
|
|
// Visit loops each of the entries and calls the callback function func(key, value).
|
|
|
|
func (s *Session) Visit(cb func(k string, v interface{})) {
|
|
|
|
s.provider.db.Visit(s.sid, cb)
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2019-07-24 18:51:42 +02:00
|
|
|
// Len returns the total number of stored values in this session.
|
|
|
|
func (s *Session) Len() int {
|
|
|
|
return s.provider.db.Len(s.sid)
|
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) set(key string, value interface{}, immutable bool) {
|
2020-10-04 15:50:21 +02:00
|
|
|
s.provider.db.Set(s.sid, key, value, s.Lifetime.DurationUntilExpiration(), immutable)
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-12-24 18:43:31 +01:00
|
|
|
// Set fills the session with an entry "value", based on its "key".
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) Set(key string, value interface{}) {
|
2017-06-08 02:39:15 +02:00
|
|
|
s.set(key, value, false)
|
|
|
|
}
|
|
|
|
|
|
|
|
// SetImmutable fills the session with an entry "value", based on its "key".
|
|
|
|
// Unlike `Set`, the output value cannot be changed by the caller later on (when .Get)
|
|
|
|
// An Immutable entry should be only changed with a `SetImmutable`, simple `Set` will not work
|
|
|
|
// if the entry was immutable, for your own safety.
|
|
|
|
// Use it consistently, it's far slower than `Set`.
|
|
|
|
// Read more about muttable and immutable go types: https://stackoverflow.com/a/8021081
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) SetImmutable(key string, value interface{}) {
|
2017-06-08 02:39:15 +02:00
|
|
|
s.set(key, value, true)
|
|
|
|
}
|
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
// SetFlash sets a flash message by its key.
|
|
|
|
//
|
|
|
|
// A flash message is used in order to keep a message in session through one or several requests of the same user.
|
|
|
|
// It is removed from session after it has been displayed to the user.
|
|
|
|
// Flash messages are usually used in combination with HTTP redirections,
|
|
|
|
// because in this case there is no view, so messages can only be displayed in the request that follows redirection.
|
|
|
|
//
|
|
|
|
// A flash message has a name and a content (AKA key and value).
|
|
|
|
// It is an entry of an associative array. The name is a string: often "notice", "success", or "error", but it can be anything.
|
|
|
|
// The content is usually a string. You can put HTML tags in your message if you display it raw.
|
|
|
|
// You can also set the message value to a number or an array: it will be serialized and kept in session like a string.
|
|
|
|
//
|
|
|
|
// Flash messages can be set using the SetFlash() Method
|
|
|
|
// For example, if you would like to inform the user that his changes were successfully saved,
|
|
|
|
// you could add the following line to your Handler:
|
|
|
|
//
|
|
|
|
// SetFlash("success", "Data saved!");
|
|
|
|
//
|
|
|
|
// In this example we used the key 'success'.
|
2017-07-10 17:32:42 +02:00
|
|
|
// If you want to define more than one flash messages, you will have to use different keys.
|
|
|
|
func (s *Session) SetFlash(key string, value interface{}) {
|
2017-02-15 19:06:19 +01:00
|
|
|
s.mu.Lock()
|
2022-06-17 21:03:18 +02:00
|
|
|
if s.flashes == nil {
|
|
|
|
s.flashes = make(map[string]*flashMessage)
|
|
|
|
}
|
|
|
|
|
2017-02-15 19:06:19 +01:00
|
|
|
s.flashes[key] = &flashMessage{value: value}
|
|
|
|
s.mu.Unlock()
|
|
|
|
}
|
|
|
|
|
2017-06-08 02:39:15 +02:00
|
|
|
// Delete removes an entry by its key,
|
|
|
|
// returns true if actually something was removed.
|
2017-07-10 17:32:42 +02:00
|
|
|
func (s *Session) Delete(key string) bool {
|
2018-04-22 12:52:36 +02:00
|
|
|
removed := s.provider.db.Delete(s.sid, key)
|
2017-08-07 05:04:35 +02:00
|
|
|
return removed
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// DeleteFlash removes a flash message by its key.
|
|
|
|
func (s *Session) DeleteFlash(key string) {
|
2017-02-15 19:06:19 +01:00
|
|
|
s.mu.Lock()
|
|
|
|
delete(s.flashes, key)
|
|
|
|
s.mu.Unlock()
|
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// Clear removes all entries.
|
|
|
|
func (s *Session) Clear() {
|
2018-04-22 12:52:36 +02:00
|
|
|
s.provider.db.Clear(s.sid)
|
2017-02-15 19:06:19 +01:00
|
|
|
}
|
|
|
|
|
2017-07-10 17:32:42 +02:00
|
|
|
// ClearFlashes removes all flash messages.
|
|
|
|
func (s *Session) ClearFlashes() {
|
2017-02-15 19:06:19 +01:00
|
|
|
s.mu.Lock()
|
|
|
|
for key := range s.flashes {
|
|
|
|
delete(s.flashes, key)
|
|
|
|
}
|
|
|
|
s.mu.Unlock()
|
|
|
|
}
|