user.go 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184
  1. package user
  2. import (
  3. "errors"
  4. "log"
  5. "net/http"
  6. "os"
  7. "golang.org/x/sync/syncmap"
  8. auth "imuslab.com/arozos/mod/auth"
  9. db "imuslab.com/arozos/mod/database"
  10. permission "imuslab.com/arozos/mod/permission"
  11. quota "imuslab.com/arozos/mod/quota"
  12. "imuslab.com/arozos/mod/share/shareEntry"
  13. storage "imuslab.com/arozos/mod/storage"
  14. )
  15. var (
  16. //Create a buffer to put the pointers to created user quota managers, mapped by username
  17. //quotaManagerBuffer map[string]*quota.QuotaHandler = map[string]*quota.QuotaHandler{}
  18. quotaManagerBuffer = syncmap.Map{}
  19. )
  20. type User struct {
  21. Username string
  22. StorageQuota *quota.QuotaHandler
  23. PermissionGroup []*permission.PermissionGroup
  24. HomeDirectories *storage.StoragePool
  25. parent *UserHandler
  26. }
  27. type UserHandler struct {
  28. UniversalModules []string //Modules where all user can access
  29. authAgent *auth.AuthAgent
  30. database *db.Database
  31. phandler *permission.PermissionHandler
  32. basePool *storage.StoragePool
  33. shareEntryTable **shareEntry.ShareEntryTable
  34. }
  35. //Initiate a new user handler
  36. func NewUserHandler(systemdb *db.Database, authAgent *auth.AuthAgent, permissionHandler *permission.PermissionHandler, baseStoragePool *storage.StoragePool, shareEntryTable **shareEntry.ShareEntryTable) (*UserHandler, error) {
  37. return &UserHandler{
  38. authAgent: authAgent,
  39. database: systemdb,
  40. phandler: permissionHandler,
  41. basePool: baseStoragePool,
  42. shareEntryTable: shareEntryTable,
  43. }, nil
  44. }
  45. //Return the user handler's auth agent
  46. func (u *UserHandler) GetAuthAgent() *auth.AuthAgent {
  47. return u.authAgent
  48. }
  49. func (u *UserHandler) GetPermissionHandler() *permission.PermissionHandler {
  50. return u.phandler
  51. }
  52. func (u *UserHandler) GetStoragePool() *storage.StoragePool {
  53. return u.basePool
  54. }
  55. func (u *UserHandler) GetDatabase() *db.Database {
  56. return u.database
  57. }
  58. func (u *UserHandler) UpdateStoragePool(newpool *storage.StoragePool) {
  59. u.basePool = newpool
  60. }
  61. //Get User object from username
  62. func (u *UserHandler) GetUserInfoFromUsername(username string) (*User, error) {
  63. //Check if user exists
  64. if !u.authAgent.UserExists(username) {
  65. return &User{}, errors.New("User not exists")
  66. }
  67. //Get the user's permission group
  68. permissionGroups, err := u.phandler.GetUsersPermissionGroup(username)
  69. if err != nil {
  70. return &User{}, err
  71. }
  72. //Create user directories in the Home Directories
  73. if u.basePool.Storages == nil {
  74. //This userhandler do not have a basepool?
  75. log.Println("USER HANDLER DO NOT HAVE BASEPOOL")
  76. } else {
  77. for _, store := range u.basePool.Storages {
  78. if store.Hierarchy == "user" {
  79. os.MkdirAll(store.Path+"/users/"+username, 0755)
  80. }
  81. }
  82. }
  83. thisUser := User{
  84. Username: username,
  85. PermissionGroup: permissionGroups,
  86. HomeDirectories: u.basePool,
  87. parent: u,
  88. }
  89. //Get the storage quota manager for thus user
  90. var thisUserQuotaManager *quota.QuotaHandler
  91. if val, ok := quotaManagerBuffer.Load(username); ok {
  92. //user quota manager exists
  93. thisUserQuotaManager = val.(*quota.QuotaHandler)
  94. } else {
  95. //Get the largest quota from the user's group
  96. maxQuota := int64(0)
  97. for _, group := range permissionGroups {
  98. if group.DefaultStorageQuota == -1 {
  99. //Admin
  100. maxQuota = -1
  101. break
  102. } else if group.DefaultStorageQuota > maxQuota {
  103. //Other groups. Get the largest one
  104. maxQuota = group.DefaultStorageQuota
  105. }
  106. }
  107. //Create a new manager for this user
  108. allFsHandlers := thisUser.GetAllFileSystemHandler()
  109. thisUserQuotaManager = quota.NewUserQuotaHandler(u.database, username, allFsHandlers, maxQuota)
  110. if !thisUserQuotaManager.IsQuotaInitialized() {
  111. //This user quota hasn't been initalized. Initalize it now to match its group
  112. userMaxDefaultStorageQuota := permission.GetLargestStorageQuotaFromGroups(permissionGroups)
  113. thisUserQuotaManager.SetUserStorageQuota(userMaxDefaultStorageQuota)
  114. }
  115. //Push the manger to buffer
  116. quotaManagerBuffer.Store(username, thisUserQuotaManager)
  117. }
  118. thisUser.StorageQuota = thisUserQuotaManager
  119. //Return the user object
  120. return &thisUser, nil
  121. }
  122. //Get user obejct from session
  123. func (u *UserHandler) GetUserInfoFromRequest(w http.ResponseWriter, r *http.Request) (*User, error) {
  124. username, err := u.authAgent.GetUserName(w, r)
  125. if err != nil {
  126. return &User{}, err
  127. }
  128. userObject, err := u.GetUserInfoFromUsername(username)
  129. if err != nil {
  130. return &User{}, err
  131. }
  132. return userObject, nil
  133. }
  134. //Get all the users given the permission group name, super IO heavy operation
  135. func (u *UserHandler) GetUsersInPermissionGroup(permissionGroupName string) ([]*User, error) {
  136. results := []*User{}
  137. //Check if the given group exists
  138. if u.phandler.GetPermissionGroupByName(permissionGroupName) == nil {
  139. //Permission group with given name not exists
  140. return results, errors.New("Permission group not exists")
  141. }
  142. AllRegisteredUsers := u.authAgent.ListUsers()
  143. for _, thisUser := range AllRegisteredUsers {
  144. thisUserInfo, err := u.GetUserInfoFromUsername(thisUser)
  145. if err != nil {
  146. continue
  147. }
  148. //Check if the user is in the given permission group
  149. if thisUserInfo.UserIsInOneOfTheGroupOf([]string{permissionGroupName}) {
  150. results = append(results, thisUserInfo)
  151. }
  152. }
  153. return results, nil
  154. }