796ea1dde9
so we can persist password reset codes, OIDC auth sessions and tokens. These features will also work in multi-node setups without sicky sessions now Signed-off-by: Nicola Murino <nicola.murino@gmail.com>
34 lines
680 B
Go
34 lines
680 B
Go
package dataprovider
|
|
|
|
import (
|
|
"errors"
|
|
"fmt"
|
|
)
|
|
|
|
// SessionType defines the supported session types
|
|
type SessionType int
|
|
|
|
// Supported session types
|
|
const (
|
|
SessionTypeOIDCAuth SessionType = iota + 1
|
|
SessionTypeOIDCToken
|
|
SessionTypeResetCode
|
|
)
|
|
|
|
// Session defines a shared session persisted in the data provider
|
|
type Session struct {
|
|
Key string
|
|
Data any
|
|
Type SessionType
|
|
Timestamp int64
|
|
}
|
|
|
|
func (s *Session) validate() error {
|
|
if s.Key == "" {
|
|
return errors.New("unable to save a session with an empty key")
|
|
}
|
|
if s.Type < SessionTypeOIDCAuth || s.Type > SessionTypeResetCode {
|
|
return fmt.Errorf("invalid session type: %v", s.Type)
|
|
}
|
|
return nil
|
|
}
|