2
0

users.go 5.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214
  1. package logic
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "sort"
  6. "github.com/gravitl/netmaker/database"
  7. "github.com/gravitl/netmaker/models"
  8. )
  9. // GetUser - gets a user
  10. // TODO support "masteradmin"
  11. func GetUser(username string) (*models.User, error) {
  12. var user models.User
  13. record, err := database.FetchRecord(database.USERS_TABLE_NAME, username)
  14. if err != nil {
  15. return &user, err
  16. }
  17. if err = json.Unmarshal([]byte(record), &user); err != nil {
  18. return &models.User{}, err
  19. }
  20. return &user, err
  21. }
  22. // GetReturnUser - gets a user
  23. func GetReturnUser(username string) (models.ReturnUser, error) {
  24. var user models.ReturnUser
  25. record, err := database.FetchRecord(database.USERS_TABLE_NAME, username)
  26. if err != nil {
  27. return user, err
  28. }
  29. if err = json.Unmarshal([]byte(record), &user); err != nil {
  30. return models.ReturnUser{}, err
  31. }
  32. return user, err
  33. }
  34. // ToReturnUser - gets a user as a return user
  35. func ToReturnUser(user models.User) models.ReturnUser {
  36. return models.ReturnUser{
  37. UserName: user.UserName,
  38. ExternalIdentityProviderID: user.ExternalIdentityProviderID,
  39. IsMFAEnabled: user.IsMFAEnabled,
  40. DisplayName: user.DisplayName,
  41. AccountDisabled: user.AccountDisabled,
  42. AuthType: user.AuthType,
  43. RemoteGwIDs: user.RemoteGwIDs,
  44. UserGroups: user.UserGroups,
  45. PlatformRoleID: user.PlatformRoleID,
  46. NetworkRoles: user.NetworkRoles,
  47. LastLoginTime: user.LastLoginTime,
  48. }
  49. }
  50. // SetUserDefaults - sets the defaults of a user to avoid empty fields
  51. func SetUserDefaults(user *models.User) {
  52. if user.RemoteGwIDs == nil {
  53. user.RemoteGwIDs = make(map[string]struct{})
  54. }
  55. if len(user.NetworkRoles) == 0 {
  56. user.NetworkRoles = make(map[models.NetworkID]map[models.UserRoleID]struct{})
  57. }
  58. if len(user.UserGroups) == 0 {
  59. user.UserGroups = make(map[models.UserGroupID]struct{})
  60. }
  61. }
  62. // SortUsers - Sorts slice of Users by username
  63. func SortUsers(unsortedUsers []models.ReturnUser) {
  64. sort.Slice(unsortedUsers, func(i, j int) bool {
  65. return unsortedUsers[i].UserName < unsortedUsers[j].UserName
  66. })
  67. }
  68. // GetSuperAdmin - fetches superadmin user
  69. func GetSuperAdmin() (models.ReturnUser, error) {
  70. users, err := GetUsers()
  71. if err != nil {
  72. return models.ReturnUser{}, err
  73. }
  74. for _, user := range users {
  75. if user.IsSuperAdmin || user.PlatformRoleID == models.SuperAdminRole {
  76. return user, nil
  77. }
  78. }
  79. return models.ReturnUser{}, errors.New("superadmin not found")
  80. }
  81. func InsertPendingUser(u *models.User) error {
  82. data, err := json.Marshal(u)
  83. if err != nil {
  84. return err
  85. }
  86. return database.Insert(u.UserName, string(data), database.PENDING_USERS_TABLE_NAME)
  87. }
  88. func DeletePendingUser(username string) error {
  89. return database.DeleteRecord(database.PENDING_USERS_TABLE_NAME, username)
  90. }
  91. func IsPendingUser(username string) bool {
  92. records, err := database.FetchRecords(database.PENDING_USERS_TABLE_NAME)
  93. if err != nil {
  94. return false
  95. }
  96. for _, record := range records {
  97. u := models.ReturnUser{}
  98. err := json.Unmarshal([]byte(record), &u)
  99. if err == nil && u.UserName == username {
  100. return true
  101. }
  102. }
  103. return false
  104. }
  105. func ListPendingReturnUsers() ([]models.ReturnUser, error) {
  106. pendingUsers := []models.ReturnUser{}
  107. records, err := database.FetchRecords(database.PENDING_USERS_TABLE_NAME)
  108. if err != nil && !database.IsEmptyRecord(err) {
  109. return pendingUsers, err
  110. }
  111. for _, record := range records {
  112. u := models.ReturnUser{}
  113. err = json.Unmarshal([]byte(record), &u)
  114. if err == nil {
  115. pendingUsers = append(pendingUsers, u)
  116. }
  117. }
  118. return pendingUsers, nil
  119. }
  120. func ListPendingUsers() ([]models.User, error) {
  121. var pendingUsers []models.User
  122. records, err := database.FetchRecords(database.PENDING_USERS_TABLE_NAME)
  123. if err != nil && !database.IsEmptyRecord(err) {
  124. return pendingUsers, err
  125. }
  126. for _, record := range records {
  127. var u models.User
  128. err = json.Unmarshal([]byte(record), &u)
  129. if err == nil {
  130. pendingUsers = append(pendingUsers, u)
  131. }
  132. }
  133. return pendingUsers, nil
  134. }
  135. func GetUserMap() (map[string]models.User, error) {
  136. userMap := make(map[string]models.User)
  137. records, err := database.FetchRecords(database.USERS_TABLE_NAME)
  138. if err != nil && !database.IsEmptyRecord(err) {
  139. return userMap, err
  140. }
  141. for _, record := range records {
  142. u := models.User{}
  143. err = json.Unmarshal([]byte(record), &u)
  144. if err == nil {
  145. userMap[u.UserName] = u
  146. }
  147. }
  148. return userMap, nil
  149. }
  150. func InsertUserInvite(invite models.UserInvite) error {
  151. data, err := json.Marshal(invite)
  152. if err != nil {
  153. return err
  154. }
  155. return database.Insert(invite.Email, string(data), database.USER_INVITES_TABLE_NAME)
  156. }
  157. func GetUserInvite(email string) (in models.UserInvite, err error) {
  158. d, err := database.FetchRecord(database.USER_INVITES_TABLE_NAME, email)
  159. if err != nil {
  160. return
  161. }
  162. err = json.Unmarshal([]byte(d), &in)
  163. return
  164. }
  165. func ListUserInvites() ([]models.UserInvite, error) {
  166. invites := []models.UserInvite{}
  167. records, err := database.FetchRecords(database.USER_INVITES_TABLE_NAME)
  168. if err != nil && !database.IsEmptyRecord(err) {
  169. return invites, err
  170. }
  171. for _, record := range records {
  172. in := models.UserInvite{}
  173. err = json.Unmarshal([]byte(record), &in)
  174. if err == nil {
  175. invites = append(invites, in)
  176. }
  177. }
  178. return invites, nil
  179. }
  180. func DeleteUserInvite(email string) error {
  181. return database.DeleteRecord(database.USER_INVITES_TABLE_NAME, email)
  182. }
  183. func ValidateAndApproveUserInvite(email, code string) error {
  184. in, err := GetUserInvite(email)
  185. if err != nil {
  186. return err
  187. }
  188. if code != in.InviteCode {
  189. return errors.New("invalid code")
  190. }
  191. return nil
  192. }