temp_user.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. package sqlstore
  2. import (
  3. "time"
  4. "github.com/grafana/grafana/pkg/bus"
  5. m "github.com/grafana/grafana/pkg/models"
  6. )
  7. func init() {
  8. bus.AddHandler("sql", CreateTempUser)
  9. bus.AddHandler("sql", GetTempUsersQuery)
  10. bus.AddHandler("sql", UpdateTempUserStatus)
  11. bus.AddHandler("sql", GetTempUserByCode)
  12. bus.AddHandler("sql", UpdateTempUserWithEmailSent)
  13. }
  14. func UpdateTempUserStatus(cmd *m.UpdateTempUserStatusCommand) error {
  15. return inTransaction(func(sess *DBSession) error {
  16. var rawSql = "UPDATE temp_user SET status=? WHERE code=?"
  17. _, err := sess.Exec(rawSql, string(cmd.Status), cmd.Code)
  18. return err
  19. })
  20. }
  21. func CreateTempUser(cmd *m.CreateTempUserCommand) error {
  22. return inTransaction(func(sess *DBSession) error {
  23. // create user
  24. user := &m.TempUser{
  25. Email: cmd.Email,
  26. Name: cmd.Name,
  27. OrgId: cmd.OrgId,
  28. Code: cmd.Code,
  29. Role: cmd.Role,
  30. Status: cmd.Status,
  31. RemoteAddr: cmd.RemoteAddr,
  32. InvitedByUserId: cmd.InvitedByUserId,
  33. EmailSentOn: time.Now(),
  34. Created: time.Now(),
  35. Updated: time.Now(),
  36. }
  37. if _, err := sess.Insert(user); err != nil {
  38. return err
  39. }
  40. cmd.Result = user
  41. return nil
  42. })
  43. }
  44. func UpdateTempUserWithEmailSent(cmd *m.UpdateTempUserWithEmailSentCommand) error {
  45. return inTransaction(func(sess *DBSession) error {
  46. user := &m.TempUser{
  47. EmailSent: true,
  48. EmailSentOn: time.Now(),
  49. }
  50. _, err := sess.Where("code = ?", cmd.Code).Cols("email_sent", "email_sent_on").Update(user)
  51. return err
  52. })
  53. }
  54. func GetTempUsersQuery(query *m.GetTempUsersQuery) error {
  55. rawSql := `SELECT
  56. tu.id as id,
  57. tu.org_id as org_id,
  58. tu.email as email,
  59. tu.name as name,
  60. tu.role as role,
  61. tu.code as code,
  62. tu.status as status,
  63. tu.email_sent as email_sent,
  64. tu.email_sent_on as email_sent_on,
  65. tu.created as created,
  66. u.login as invited_by_login,
  67. u.name as invited_by_name,
  68. u.email as invited_by_email
  69. FROM ` + dialect.Quote("temp_user") + ` as tu
  70. LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
  71. WHERE tu.status=?`
  72. params := []interface{}{string(query.Status)}
  73. if query.OrgId > 0 {
  74. rawSql += ` AND tu.org_id=?`
  75. params = append(params, query.OrgId)
  76. }
  77. if query.Email != "" {
  78. rawSql += ` AND tu.email=?`
  79. params = append(params, query.Email)
  80. }
  81. rawSql += " ORDER BY tu.created desc"
  82. query.Result = make([]*m.TempUserDTO, 0)
  83. sess := x.Sql(rawSql, params...)
  84. err := sess.Find(&query.Result)
  85. return err
  86. }
  87. func GetTempUserByCode(query *m.GetTempUserByCodeQuery) error {
  88. var rawSql = `SELECT
  89. tu.id as id,
  90. tu.org_id as org_id,
  91. tu.email as email,
  92. tu.name as name,
  93. tu.role as role,
  94. tu.code as code,
  95. tu.status as status,
  96. tu.email_sent as email_sent,
  97. tu.email_sent_on as email_sent_on,
  98. tu.created as created,
  99. u.login as invited_by_login,
  100. u.name as invited_by_name,
  101. u.email as invited_by_email
  102. FROM ` + dialect.Quote("temp_user") + ` as tu
  103. LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
  104. WHERE tu.code=?`
  105. var tempUser m.TempUserDTO
  106. sess := x.Sql(rawSql, query.Code)
  107. has, err := sess.Get(&tempUser)
  108. if err != nil {
  109. return err
  110. } else if has == false {
  111. return m.ErrTempUserNotFound
  112. }
  113. query.Result = &tempUser
  114. return err
  115. }