2017-07-24 16:24:21 +01:00
|
|
|
// Copyright 2016 Documize Inc. <legal@documize.com>. All rights reserved.
|
|
|
|
//
|
|
|
|
// This software (Documize Community Edition) is licensed under
|
|
|
|
// GNU AGPL v3 http://www.gnu.org/licenses/agpl-3.0.en.html
|
|
|
|
//
|
|
|
|
// You can operate outside the AGPL restrictions by purchasing
|
|
|
|
// Documize Enterprise Edition and obtaining a commercial license
|
|
|
|
// by contacting <sales@documize.com>.
|
|
|
|
//
|
|
|
|
// https://documize.com
|
|
|
|
|
|
|
|
package user
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
|
2017-07-26 10:50:26 +01:00
|
|
|
"github.com/documize/community/model"
|
|
|
|
"github.com/documize/community/model/account"
|
2018-03-01 19:14:27 +00:00
|
|
|
"github.com/documize/community/model/group"
|
2017-07-24 16:24:21 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
// User defines a login.
|
|
|
|
type User struct {
|
2017-07-26 10:50:26 +01:00
|
|
|
model.BaseEntity
|
2018-03-22 17:29:59 +00:00
|
|
|
Firstname string `json:"firstname"`
|
|
|
|
Lastname string `json:"lastname"`
|
|
|
|
Email string `json:"email"`
|
|
|
|
Initials string `json:"initials"`
|
|
|
|
Active bool `json:"active"`
|
|
|
|
Editor bool `json:"editor"`
|
|
|
|
Admin bool `json:"admin"`
|
|
|
|
ViewUsers bool `json:"viewUsers"`
|
2018-04-05 19:59:57 +01:00
|
|
|
Analytics bool `json:"analytics"`
|
2018-09-19 16:03:29 +01:00
|
|
|
GlobalAdmin bool `json:"global"`
|
2018-03-22 17:29:59 +00:00
|
|
|
Password string `json:"-"`
|
|
|
|
Salt string `json:"-"`
|
|
|
|
Reset string `json:"-"`
|
|
|
|
LastVersion string `json:"lastVersion"`
|
2018-12-02 16:19:25 +00:00
|
|
|
Theme string `json:"theme"`
|
2022-03-16 16:58:42 -04:00
|
|
|
Locale string `json:"locale"`
|
2018-03-22 17:29:59 +00:00
|
|
|
Accounts []account.Account `json:"accounts"`
|
|
|
|
Groups []group.Record `json:"groups"`
|
2017-07-24 16:24:21 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// ProtectSecrets blanks sensitive data.
|
|
|
|
func (user *User) ProtectSecrets() {
|
|
|
|
user.Password = ""
|
|
|
|
user.Salt = ""
|
|
|
|
user.Reset = ""
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fullname returns Firstname + Lastname.
|
|
|
|
func (user *User) Fullname() string {
|
|
|
|
return fmt.Sprintf("%s %s", user.Firstname, user.Lastname)
|
|
|
|
}
|
|
|
|
|
|
|
|
// GetAccount returns matching org account using orgID
|
|
|
|
func (user *User) GetAccount(orgID string) (a account.Account, found bool) {
|
|
|
|
for _, a := range user.Accounts {
|
|
|
|
if a.OrgID == orgID {
|
|
|
|
return a, true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return a, false
|
|
|
|
}
|
2018-01-23 12:34:43 +00:00
|
|
|
|
|
|
|
// Exists ehecks if user is in array.
|
|
|
|
func Exists(users []User, userID string) bool {
|
|
|
|
for _, u := range users {
|
|
|
|
if u.RefID == userID {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return false
|
|
|
|
}
|
2018-03-03 17:46:29 +00:00
|
|
|
|
|
|
|
const (
|
|
|
|
// EveryoneUserID provides a shortcut to state "all authenticated users".
|
|
|
|
EveryoneUserID string = "0"
|
2018-03-06 10:39:47 +00:00
|
|
|
|
|
|
|
// EveryoneUserName provides the descriptor for this type of user/group.
|
|
|
|
EveryoneUserName string = "Everyone"
|
2018-03-03 17:46:29 +00:00
|
|
|
)
|