temp_user.go 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120
  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. }
  13. func UpdateTempUserStatus(cmd *m.UpdateTempUserStatusCommand) error {
  14. return inTransaction(func(sess *DBSession) error {
  15. var rawSql = "UPDATE temp_user SET status=? WHERE code=?"
  16. _, err := sess.Exec(rawSql, string(cmd.Status), cmd.Code)
  17. return err
  18. })
  19. }
  20. func CreateTempUser(cmd *m.CreateTempUserCommand) error {
  21. return inTransaction(func(sess *DBSession) error {
  22. // create user
  23. user := &m.TempUser{
  24. Email: cmd.Email,
  25. Name: cmd.Name,
  26. OrgId: cmd.OrgId,
  27. Code: cmd.Code,
  28. Role: cmd.Role,
  29. Status: cmd.Status,
  30. RemoteAddr: cmd.RemoteAddr,
  31. InvitedByUserId: cmd.InvitedByUserId,
  32. Created: time.Now(),
  33. Updated: time.Now(),
  34. }
  35. if _, err := sess.Insert(user); err != nil {
  36. return err
  37. }
  38. cmd.Result = user
  39. return nil
  40. })
  41. }
  42. func GetTempUsersQuery(query *m.GetTempUsersQuery) error {
  43. rawSql := `SELECT
  44. tu.id as id,
  45. tu.org_id as org_id,
  46. tu.email as email,
  47. tu.name as name,
  48. tu.role as role,
  49. tu.code as code,
  50. tu.status as status,
  51. tu.email_sent as email_sent,
  52. tu.email_sent_on as email_sent_on,
  53. tu.created as created,
  54. u.login as invited_by_login,
  55. u.name as invited_by_name,
  56. u.email as invited_by_email
  57. FROM ` + dialect.Quote("temp_user") + ` as tu
  58. LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
  59. WHERE tu.status=?`
  60. params := []interface{}{string(query.Status)}
  61. if query.OrgId > 0 {
  62. rawSql += ` AND tu.org_id=?`
  63. params = append(params, query.OrgId)
  64. }
  65. if query.Email != "" {
  66. rawSql += ` AND tu.email=?`
  67. params = append(params, query.Email)
  68. }
  69. rawSql += " ORDER BY tu.created desc"
  70. query.Result = make([]*m.TempUserDTO, 0)
  71. sess := x.Sql(rawSql, params...)
  72. err := sess.Find(&query.Result)
  73. return err
  74. }
  75. func GetTempUserByCode(query *m.GetTempUserByCodeQuery) error {
  76. var rawSql = `SELECT
  77. tu.id as id,
  78. tu.org_id as org_id,
  79. tu.email as email,
  80. tu.name as name,
  81. tu.role as role,
  82. tu.code as code,
  83. tu.status as status,
  84. tu.email_sent as email_sent,
  85. tu.email_sent_on as email_sent_on,
  86. tu.created as created,
  87. u.login as invited_by_login,
  88. u.name as invited_by_name,
  89. u.email as invited_by_email
  90. FROM ` + dialect.Quote("temp_user") + ` as tu
  91. LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
  92. WHERE tu.code=?`
  93. var tempUser m.TempUserDTO
  94. sess := x.Sql(rawSql, query.Code)
  95. has, err := sess.Get(&tempUser)
  96. if err != nil {
  97. return err
  98. } else if has == false {
  99. return m.ErrTempUserNotFound
  100. }
  101. query.Result = &tempUser
  102. return err
  103. }