user.go 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157
  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. authAgent *auth.AuthAgent
  29. database *db.Database
  30. phandler *permission.PermissionHandler
  31. basePool *storage.StoragePool
  32. shareEntryTable **shareEntry.ShareEntryTable
  33. }
  34. //Initiate a new user handler
  35. func NewUserHandler(systemdb *db.Database, authAgent *auth.AuthAgent, permissionHandler *permission.PermissionHandler, baseStoragePool *storage.StoragePool, shareEntryTable **shareEntry.ShareEntryTable) (*UserHandler, error) {
  36. return &UserHandler{
  37. authAgent: authAgent,
  38. database: systemdb,
  39. phandler: permissionHandler,
  40. basePool: baseStoragePool,
  41. shareEntryTable: shareEntryTable,
  42. }, nil
  43. }
  44. //Return the user handler's auth agent
  45. func (u *UserHandler) GetAuthAgent() *auth.AuthAgent {
  46. return u.authAgent
  47. }
  48. func (u *UserHandler) GetPermissionHandler() *permission.PermissionHandler {
  49. return u.phandler
  50. }
  51. func (u *UserHandler) GetStoragePool() *storage.StoragePool {
  52. return u.basePool
  53. }
  54. func (u *UserHandler) GetDatabase() *db.Database {
  55. return u.database
  56. }
  57. func (u *UserHandler) UpdateStoragePool(newpool *storage.StoragePool) {
  58. u.basePool = newpool
  59. }
  60. //Get User object from username
  61. func (u *UserHandler) GetUserInfoFromUsername(username string) (*User, error) {
  62. //Check if user exists
  63. if !u.authAgent.UserExists(username) {
  64. return &User{}, errors.New("User not exists")
  65. }
  66. //Get the user's permission group
  67. permissionGroups, err := u.phandler.GetUsersPermissionGroup(username)
  68. if err != nil {
  69. return &User{}, err
  70. }
  71. //Create user directories in the Home Directories
  72. if u.basePool.Storages == nil {
  73. //This userhandler do not have a basepool?
  74. log.Println("USER HANDLER DO NOT HAVE BASEPOOL")
  75. } else {
  76. for _, store := range u.basePool.Storages {
  77. if store.Hierarchy == "user" {
  78. os.MkdirAll(store.Path+"/users/"+username, 0755)
  79. }
  80. }
  81. }
  82. thisUser := User{
  83. Username: username,
  84. PermissionGroup: permissionGroups,
  85. HomeDirectories: u.basePool,
  86. parent: u,
  87. }
  88. //Get the storage quota manager for thus user
  89. var thisUserQuotaManager *quota.QuotaHandler
  90. if val, ok := quotaManagerBuffer.Load(username); ok {
  91. //user quota manager exists
  92. thisUserQuotaManager = val.(*quota.QuotaHandler)
  93. } else {
  94. //Get the largest quota from the user's group
  95. maxQuota := int64(0)
  96. for _, group := range permissionGroups {
  97. if group.DefaultStorageQuota == -1 {
  98. //Admin
  99. maxQuota = -1
  100. break
  101. } else if group.DefaultStorageQuota > maxQuota {
  102. //Other groups. Get the largest one
  103. maxQuota = group.DefaultStorageQuota
  104. }
  105. }
  106. //Create a new manager for this user
  107. allFsHandlers := thisUser.GetAllFileSystemHandler()
  108. thisUserQuotaManager = quota.NewUserQuotaHandler(u.database, username, allFsHandlers, maxQuota)
  109. if !thisUserQuotaManager.IsQuotaInitialized() {
  110. //This user quota hasn't been initalized. Initalize it now to match its group
  111. userMaxDefaultStorageQuota := permission.GetLargestStorageQuotaFromGroups(permissionGroups)
  112. thisUserQuotaManager.SetUserStorageQuota(userMaxDefaultStorageQuota)
  113. }
  114. //Push the manger to buffer
  115. quotaManagerBuffer.Store(username, thisUserQuotaManager)
  116. }
  117. thisUser.StorageQuota = thisUserQuotaManager
  118. //Return the user object
  119. return &thisUser, nil
  120. }
  121. //Get user obejct from session
  122. func (u *UserHandler) GetUserInfoFromRequest(w http.ResponseWriter, r *http.Request) (*User, error) {
  123. username, err := u.authAgent.GetUserName(w, r)
  124. if err != nil {
  125. return &User{}, err
  126. }
  127. userObject, err := u.GetUserInfoFromUsername(username)
  128. if err != nil {
  129. return &User{}, err
  130. }
  131. return userObject, nil
  132. }