2017-08-16 21:37:37 +00:00
|
|
|
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
2016-04-10 21:39:38 +00:00
|
|
|
// See License.txt for license information.
|
|
|
|
|
|
|
|
package model
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"io"
|
2016-09-17 13:19:18 +00:00
|
|
|
"strings"
|
2016-04-10 21:39:38 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
2017-08-16 21:37:37 +00:00
|
|
|
SESSION_COOKIE_TOKEN = "MMAUTHTOKEN"
|
|
|
|
SESSION_COOKIE_USER = "MMUSERID"
|
|
|
|
SESSION_CACHE_SIZE = 35000
|
|
|
|
SESSION_PROP_PLATFORM = "platform"
|
|
|
|
SESSION_PROP_OS = "os"
|
|
|
|
SESSION_PROP_BROWSER = "browser"
|
|
|
|
SESSION_PROP_TYPE = "type"
|
|
|
|
SESSION_PROP_USER_ACCESS_TOKEN_ID = "user_access_token_id"
|
|
|
|
SESSION_TYPE_USER_ACCESS_TOKEN = "UserAccessToken"
|
|
|
|
SESSION_ACTIVITY_TIMEOUT = 1000 * 60 * 5 // 5 minutes
|
|
|
|
SESSION_USER_ACCESS_TOKEN_EXPIRY = 100 * 365 // 100 years
|
2016-04-10 21:39:38 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
type Session struct {
|
2016-05-15 21:02:30 +00:00
|
|
|
Id string `json:"id"`
|
|
|
|
Token string `json:"token"`
|
|
|
|
CreateAt int64 `json:"create_at"`
|
|
|
|
ExpiresAt int64 `json:"expires_at"`
|
|
|
|
LastActivityAt int64 `json:"last_activity_at"`
|
|
|
|
UserId string `json:"user_id"`
|
|
|
|
DeviceId string `json:"device_id"`
|
|
|
|
Roles string `json:"roles"`
|
|
|
|
IsOAuth bool `json:"is_oauth"`
|
|
|
|
Props StringMap `json:"props"`
|
|
|
|
TeamMembers []*TeamMember `json:"team_members" db:"-"`
|
2016-04-10 21:39:38 +00:00
|
|
|
}
|
|
|
|
|
2018-02-08 23:11:04 +00:00
|
|
|
func (me *Session) DeepCopy() *Session {
|
2018-11-18 17:55:05 +00:00
|
|
|
copySession := *me
|
|
|
|
|
|
|
|
if me.Props != nil {
|
|
|
|
copySession.Props = CopyStringMap(me.Props)
|
|
|
|
}
|
|
|
|
|
|
|
|
if me.TeamMembers != nil {
|
|
|
|
copySession.TeamMembers = make([]*TeamMember, len(me.TeamMembers))
|
|
|
|
for index, tm := range me.TeamMembers {
|
|
|
|
copySession.TeamMembers[index] = new(TeamMember)
|
|
|
|
*copySession.TeamMembers[index] = *tm
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return ©Session
|
2018-02-08 23:11:04 +00:00
|
|
|
}
|
|
|
|
|
2016-04-10 21:39:38 +00:00
|
|
|
func (me *Session) ToJson() string {
|
2018-11-18 17:55:05 +00:00
|
|
|
b, _ := json.Marshal(me)
|
|
|
|
return string(b)
|
2016-04-10 21:39:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func SessionFromJson(data io.Reader) *Session {
|
2018-11-18 17:55:05 +00:00
|
|
|
var me *Session
|
|
|
|
json.NewDecoder(data).Decode(&me)
|
|
|
|
return me
|
2016-04-10 21:39:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (me *Session) PreSave() {
|
|
|
|
if me.Id == "" {
|
|
|
|
me.Id = NewId()
|
|
|
|
}
|
|
|
|
|
2017-08-16 21:37:37 +00:00
|
|
|
if me.Token == "" {
|
|
|
|
me.Token = NewId()
|
|
|
|
}
|
2016-04-10 21:39:38 +00:00
|
|
|
|
|
|
|
me.CreateAt = GetMillis()
|
|
|
|
me.LastActivityAt = me.CreateAt
|
|
|
|
|
|
|
|
if me.Props == nil {
|
|
|
|
me.Props = make(map[string]string)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (me *Session) Sanitize() {
|
|
|
|
me.Token = ""
|
|
|
|
}
|
|
|
|
|
|
|
|
func (me *Session) IsExpired() bool {
|
|
|
|
|
|
|
|
if me.ExpiresAt <= 0 {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
if GetMillis() > me.ExpiresAt {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
|
|
|
|
func (me *Session) SetExpireInDays(days int) {
|
2016-08-15 16:47:31 +00:00
|
|
|
if me.CreateAt == 0 {
|
|
|
|
me.ExpiresAt = GetMillis() + (1000 * 60 * 60 * 24 * int64(days))
|
|
|
|
} else {
|
|
|
|
me.ExpiresAt = me.CreateAt + (1000 * 60 * 60 * 24 * int64(days))
|
|
|
|
}
|
2016-04-10 21:39:38 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (me *Session) AddProp(key string, value string) {
|
|
|
|
|
|
|
|
if me.Props == nil {
|
|
|
|
me.Props = make(map[string]string)
|
|
|
|
}
|
|
|
|
|
|
|
|
me.Props[key] = value
|
|
|
|
}
|
|
|
|
|
2016-05-15 21:02:30 +00:00
|
|
|
func (me *Session) GetTeamByTeamId(teamId string) *TeamMember {
|
|
|
|
for _, team := range me.TeamMembers {
|
|
|
|
if team.TeamId == teamId {
|
|
|
|
return team
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
2016-09-17 13:19:18 +00:00
|
|
|
func (me *Session) IsMobileApp() bool {
|
2017-03-25 20:04:10 +00:00
|
|
|
return len(me.DeviceId) > 0
|
2016-09-17 13:19:18 +00:00
|
|
|
}
|
|
|
|
|
2016-11-12 21:00:53 +00:00
|
|
|
func (me *Session) GetUserRoles() []string {
|
|
|
|
return strings.Fields(me.Roles)
|
|
|
|
}
|
|
|
|
|
2018-11-18 17:55:05 +00:00
|
|
|
func (me *Session) GenerateCSRF() string {
|
|
|
|
token := NewId()
|
|
|
|
me.AddProp("csrf", token)
|
|
|
|
return token
|
|
|
|
}
|
|
|
|
|
|
|
|
func (me *Session) GetCSRF() string {
|
|
|
|
if me.Props == nil {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
|
|
|
|
return me.Props["csrf"]
|
|
|
|
}
|
|
|
|
|
2016-04-10 21:39:38 +00:00
|
|
|
func SessionsToJson(o []*Session) string {
|
|
|
|
if b, err := json.Marshal(o); err != nil {
|
|
|
|
return "[]"
|
|
|
|
} else {
|
|
|
|
return string(b)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func SessionsFromJson(data io.Reader) []*Session {
|
|
|
|
var o []*Session
|
2018-11-18 17:55:05 +00:00
|
|
|
json.NewDecoder(data).Decode(&o)
|
|
|
|
return o
|
2016-04-10 21:39:38 +00:00
|
|
|
}
|