signup.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. package api
  2. import (
  3. "github.com/grafana/grafana/pkg/api/dtos"
  4. "github.com/grafana/grafana/pkg/bus"
  5. "github.com/grafana/grafana/pkg/events"
  6. "github.com/grafana/grafana/pkg/metrics"
  7. "github.com/grafana/grafana/pkg/middleware"
  8. m "github.com/grafana/grafana/pkg/models"
  9. "github.com/grafana/grafana/pkg/setting"
  10. "github.com/grafana/grafana/pkg/util"
  11. )
  12. // POST /api/user/signup
  13. func SignUp(c *middleware.Context, form dtos.SignUpForm) Response {
  14. if !setting.AllowUserSignUp {
  15. return ApiError(401, "User signup is disabled", nil)
  16. }
  17. existing := m.GetUserByLoginQuery{LoginOrEmail: form.Email}
  18. if err := bus.Dispatch(&existing); err == nil {
  19. return ApiError(401, "User with same email address already exists", nil)
  20. }
  21. cmd := m.CreateTempUserCommand{}
  22. cmd.OrgId = -1
  23. cmd.Email = form.Email
  24. cmd.Status = m.TmpUserSignUpStarted
  25. cmd.InvitedByUserId = c.UserId
  26. cmd.Code = util.GetRandomString(20)
  27. cmd.RemoteAddr = c.Req.RemoteAddr
  28. if err := bus.Dispatch(&cmd); err != nil {
  29. return ApiError(500, "Failed to create signup", err)
  30. }
  31. bus.Publish(&events.SignUpStarted{
  32. Email: form.Email,
  33. Code: cmd.Code,
  34. })
  35. metrics.M_Api_User_SignUpStarted.Inc(1)
  36. return Json(200, util.DynMap{"status": "SignUpCreated"})
  37. }
  38. func SignUpStep2(c *middleware.Context, form dtos.SignUpStep2Form) Response {
  39. if !setting.AllowUserSignUp {
  40. return ApiError(401, "User signup is disabled", nil)
  41. }
  42. query := m.GetTempUserByCodeQuery{Code: form.Code}
  43. if err := bus.Dispatch(&query); err != nil {
  44. if err == m.ErrTempUserNotFound {
  45. return ApiError(404, "Invalid email verification code", nil)
  46. }
  47. return ApiError(500, "Failed to read temp user", err)
  48. }
  49. tempUser := query.Result
  50. if tempUser.Email != form.Email {
  51. return ApiError(404, "Email verification code does not match email", nil)
  52. }
  53. existing := m.GetUserByLoginQuery{LoginOrEmail: tempUser.Email}
  54. if err := bus.Dispatch(&existing); err == nil {
  55. return ApiError(401, "User with same email address already exists", nil)
  56. }
  57. // create user
  58. createUserCmd := m.CreateUserCommand{
  59. Email: tempUser.Email,
  60. Login: form.Username,
  61. Name: form.Name,
  62. Password: form.Password,
  63. OrgName: form.OrgName,
  64. }
  65. if err := bus.Dispatch(&createUserCmd); err != nil {
  66. return ApiError(500, "Failed to create user", err)
  67. }
  68. user := createUserCmd.Result
  69. bus.Publish(&events.SignUpCompleted{
  70. Email: user.Email,
  71. Name: user.NameOrFallback(),
  72. })
  73. // check for pending invites
  74. invitesQuery := m.GetTempUsersQuery{Email: tempUser.Email, Status: m.TmpUserInvitePending}
  75. if err := bus.Dispatch(&invitesQuery); err != nil {
  76. return ApiError(500, "Failed to query database for invites", err)
  77. }
  78. loginUserWithUser(&user, c)
  79. metrics.M_Api_User_SignUpCompleted.Inc(1)
  80. return Json(200, util.DynMap{"status": "SignUpCreated"})
  81. }