user.go 5.8 KB

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