temp_user.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. package sqlstore
  2. import (
  3. "time"
  4. "github.com/go-xorm/xorm"
  5. "github.com/grafana/grafana/pkg/bus"
  6. m "github.com/grafana/grafana/pkg/models"
  7. )
  8. func init() {
  9. bus.AddHandler("sql", CreateTempUser)
  10. bus.AddHandler("sql", GetTempUsersForOrg)
  11. bus.AddHandler("sql", UpdateTempUserStatus)
  12. bus.AddHandler("sql", GetTempUserByCode)
  13. }
  14. func UpdateTempUserStatus(cmd *m.UpdateTempUserStatusCommand) error {
  15. return inTransaction(func(sess *xorm.Session) 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 inTransaction2(func(sess *session) 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. Created: time.Now(),
  34. Updated: time.Now(),
  35. }
  36. if _, err := sess.Insert(user); err != nil {
  37. return err
  38. }
  39. cmd.Result = user
  40. return nil
  41. })
  42. }
  43. func GetTempUsersForOrg(query *m.GetTempUsersForOrgQuery) error {
  44. var rawSql = `SELECT
  45. tu.id as id,
  46. tu.org_id as org_id,
  47. tu.email as email,
  48. tu.name as name,
  49. tu.role as role,
  50. tu.code as code,
  51. tu.status as status,
  52. tu.email_sent as email_sent,
  53. tu.email_sent_on as email_sent_on,
  54. tu.created as created,
  55. u.login as invited_by_login,
  56. u.name as invited_by_name,
  57. u.email as invited_by_email
  58. FROM ` + dialect.Quote("temp_user") + ` as tu
  59. LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
  60. WHERE tu.org_id=? AND tu.status =? ORDER BY tu.created desc`
  61. query.Result = make([]*m.TempUserDTO, 0)
  62. sess := x.Sql(rawSql, query.OrgId, string(query.Status))
  63. err := sess.Find(&query.Result)
  64. return err
  65. }
  66. func GetTempUserByCode(query *m.GetTempUserByCodeQuery) error {
  67. var rawSql = `SELECT
  68. tu.id as id,
  69. tu.org_id as org_id,
  70. tu.email as email,
  71. tu.name as name,
  72. tu.role as role,
  73. tu.code as code,
  74. tu.status as status,
  75. tu.email_sent as email_sent,
  76. tu.email_sent_on as email_sent_on,
  77. tu.created as created,
  78. u.login as invited_by_login,
  79. u.name as invited_by_name,
  80. u.email as invited_by_email
  81. FROM ` + dialect.Quote("temp_user") + ` as tu
  82. LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
  83. WHERE tu.code=?`
  84. var tempUser m.TempUserDTO
  85. sess := x.Sql(rawSql, query.Code)
  86. has, err := sess.Get(&tempUser)
  87. if err != nil {
  88. return err
  89. } else if has == false {
  90. return m.ErrTempUserNotFound
  91. }
  92. query.Result = &tempUser
  93. return err
  94. }