user.go 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213
  1. package api
  2. import (
  3. "github.com/grafana/grafana/pkg/bus"
  4. "github.com/grafana/grafana/pkg/middleware"
  5. m "github.com/grafana/grafana/pkg/models"
  6. "github.com/grafana/grafana/pkg/setting"
  7. "github.com/grafana/grafana/pkg/util"
  8. )
  9. // GET /api/user (current authenticated user)
  10. func GetSignedInUser(c *middleware.Context) Response {
  11. return getUserUserProfile(c.UserId)
  12. }
  13. // GET /api/user/:id
  14. func GetUserById(c *middleware.Context) Response {
  15. return getUserUserProfile(c.ParamsInt64(":id"))
  16. }
  17. func getUserUserProfile(userId int64) Response {
  18. query := m.GetUserProfileQuery{UserId: userId}
  19. if err := bus.Dispatch(&query); err != nil {
  20. return ApiError(500, "Failed to get user", err)
  21. }
  22. return Json(200, query.Result)
  23. }
  24. // POST /api/user
  25. func UpdateSignedInUser(c *middleware.Context, cmd m.UpdateUserCommand) Response {
  26. cmd.UserId = c.UserId
  27. return handleUpdateUser(cmd)
  28. }
  29. // POST /api/users/:id
  30. func UpdateUser(c *middleware.Context, cmd m.UpdateUserCommand) Response {
  31. cmd.UserId = c.ParamsInt64(":id")
  32. return handleUpdateUser(cmd)
  33. }
  34. //POST /api/users/:id/using/:orgId
  35. func UpdateUserActiveOrg(c *middleware.Context) Response {
  36. userId := c.ParamsInt64(":id")
  37. orgId := c.ParamsInt64(":orgId")
  38. if !validateUsingOrg(userId, orgId) {
  39. return ApiError(401, "Not a valid organization", nil)
  40. }
  41. cmd := m.SetUsingOrgCommand{UserId: userId, OrgId: orgId}
  42. if err := bus.Dispatch(&cmd); err != nil {
  43. return ApiError(500, "Failed change active organization", err)
  44. }
  45. return ApiSuccess("Active organization changed")
  46. }
  47. func handleUpdateUser(cmd m.UpdateUserCommand) Response {
  48. if len(cmd.Login) == 0 {
  49. cmd.Login = cmd.Email
  50. if len(cmd.Login) == 0 {
  51. return ApiError(400, "Validation error, need specify either username or email", nil)
  52. }
  53. }
  54. if err := bus.Dispatch(&cmd); err != nil {
  55. return ApiError(500, "failed to update user", err)
  56. }
  57. return ApiSuccess("User updated")
  58. }
  59. // GET /api/user/orgs
  60. func GetSignedInUserOrgList(c *middleware.Context) Response {
  61. return getUserOrgList(c.UserId)
  62. }
  63. // GET /api/user/:id/orgs
  64. func GetUserOrgList(c *middleware.Context) Response {
  65. return getUserOrgList(c.ParamsInt64(":id"))
  66. }
  67. func getUserOrgList(userId int64) Response {
  68. query := m.GetUserOrgListQuery{UserId: userId}
  69. if err := bus.Dispatch(&query); err != nil {
  70. return ApiError(500, "Faile to get user organziations", err)
  71. }
  72. return Json(200, query.Result)
  73. }
  74. func validateUsingOrg(userId int64, orgId int64) bool {
  75. query := m.GetUserOrgListQuery{UserId: userId}
  76. if err := bus.Dispatch(&query); err != nil {
  77. return false
  78. }
  79. // validate that the org id in the list
  80. valid := false
  81. for _, other := range query.Result {
  82. if other.OrgId == orgId {
  83. valid = true
  84. }
  85. }
  86. return valid
  87. }
  88. // POST /api/user/using/:id
  89. func UserSetUsingOrg(c *middleware.Context) Response {
  90. orgId := c.ParamsInt64(":id")
  91. if !validateUsingOrg(c.UserId, orgId) {
  92. return ApiError(401, "Not a valid organization", nil)
  93. }
  94. cmd := m.SetUsingOrgCommand{UserId: c.UserId, OrgId: orgId}
  95. if err := bus.Dispatch(&cmd); err != nil {
  96. return ApiError(500, "Failed change active organization", err)
  97. }
  98. return ApiSuccess("Active organization changed")
  99. }
  100. // GET /profile/switch-org/:id
  101. func ChangeActiveOrgAndRedirectToHome(c *middleware.Context) {
  102. orgId := c.ParamsInt64(":id")
  103. if !validateUsingOrg(c.UserId, orgId) {
  104. NotFoundHandler(c)
  105. }
  106. cmd := m.SetUsingOrgCommand{UserId: c.UserId, OrgId: orgId}
  107. if err := bus.Dispatch(&cmd); err != nil {
  108. NotFoundHandler(c)
  109. }
  110. c.Redirect(setting.AppSubUrl + "/")
  111. }
  112. func ChangeUserPassword(c *middleware.Context, cmd m.ChangeUserPasswordCommand) Response {
  113. userQuery := m.GetUserByIdQuery{Id: c.UserId}
  114. if err := bus.Dispatch(&userQuery); err != nil {
  115. return ApiError(500, "Could not read user from database", err)
  116. }
  117. passwordHashed := util.EncodePassword(cmd.OldPassword, userQuery.Result.Salt)
  118. if passwordHashed != userQuery.Result.Password {
  119. return ApiError(401, "Invalid old password", nil)
  120. }
  121. if len(cmd.NewPassword) < 4 {
  122. return ApiError(400, "New password too short", nil)
  123. }
  124. cmd.UserId = c.UserId
  125. cmd.NewPassword = util.EncodePassword(cmd.NewPassword, userQuery.Result.Salt)
  126. if err := bus.Dispatch(&cmd); err != nil {
  127. return ApiError(500, "Failed to change user password", err)
  128. }
  129. return ApiSuccess("User password changed")
  130. }
  131. // GET /api/users
  132. func SearchUsers(c *middleware.Context) Response {
  133. query := m.SearchUsersQuery{Query: "", Page: 0, Limit: 1000}
  134. if err := bus.Dispatch(&query); err != nil {
  135. return ApiError(500, "Failed to fetch users", err)
  136. }
  137. return Json(200, query.Result)
  138. }
  139. func SetHelpFlag(c *middleware.Context) Response {
  140. flag := c.ParamsInt64(":id")
  141. bitmask := &c.HelpFlags1
  142. bitmask.AddFlag(m.HelpFlags1(flag))
  143. cmd := m.SetUserHelpFlagCommand{
  144. UserId: c.UserId,
  145. HelpFlags1: *bitmask,
  146. }
  147. if err := bus.Dispatch(&cmd); err != nil {
  148. return ApiError(500, "Failed to update help flag", err)
  149. }
  150. return Json(200, &util.DynMap{"message": "Help flag set", "helpFlags1": cmd.HelpFlags1})
  151. }
  152. func ClearHelpFlags(c *middleware.Context) Response {
  153. cmd := m.SetUserHelpFlagCommand{
  154. UserId: c.UserId,
  155. HelpFlags1: m.HelpFlags1(0),
  156. }
  157. if err := bus.Dispatch(&cmd); err != nil {
  158. return ApiError(500, "Failed to update help flag", err)
  159. }
  160. return Json(200, &util.DynMap{"message": "Help flag set", "helpFlags1": cmd.HelpFlags1})
  161. }