| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135 |
- package sqlstore
- import (
- "time"
- "github.com/grafana/grafana/pkg/bus"
- m "github.com/grafana/grafana/pkg/models"
- )
- func init() {
- bus.AddHandler("sql", CreateTempUser)
- bus.AddHandler("sql", GetTempUsersQuery)
- bus.AddHandler("sql", UpdateTempUserStatus)
- bus.AddHandler("sql", GetTempUserByCode)
- bus.AddHandler("sql", UpdateTempUserWithEmailSent)
- }
- func UpdateTempUserStatus(cmd *m.UpdateTempUserStatusCommand) error {
- return inTransaction(func(sess *DBSession) error {
- var rawSql = "UPDATE temp_user SET status=? WHERE code=?"
- _, err := sess.Exec(rawSql, string(cmd.Status), cmd.Code)
- return err
- })
- }
- func CreateTempUser(cmd *m.CreateTempUserCommand) error {
- return inTransaction(func(sess *DBSession) error {
- // create user
- user := &m.TempUser{
- Email: cmd.Email,
- Name: cmd.Name,
- OrgId: cmd.OrgId,
- Code: cmd.Code,
- Role: cmd.Role,
- Status: cmd.Status,
- RemoteAddr: cmd.RemoteAddr,
- InvitedByUserId: cmd.InvitedByUserId,
- EmailSentOn: time.Now(),
- Created: time.Now(),
- Updated: time.Now(),
- }
- if _, err := sess.Insert(user); err != nil {
- return err
- }
- cmd.Result = user
- return nil
- })
- }
- func UpdateTempUserWithEmailSent(cmd *m.UpdateTempUserWithEmailSentCommand) error {
- return inTransaction(func(sess *DBSession) error {
- user := &m.TempUser{
- EmailSent: true,
- EmailSentOn: time.Now(),
- }
- _, err := sess.Where("code = ?", cmd.Code).Cols("email_sent", "email_sent_on").Update(user)
- return err
- })
- }
- func GetTempUsersQuery(query *m.GetTempUsersQuery) error {
- rawSql := `SELECT
- tu.id as id,
- tu.org_id as org_id,
- tu.email as email,
- tu.name as name,
- tu.role as role,
- tu.code as code,
- tu.status as status,
- tu.email_sent as email_sent,
- tu.email_sent_on as email_sent_on,
- tu.created as created,
- u.login as invited_by_login,
- u.name as invited_by_name,
- u.email as invited_by_email
- FROM ` + dialect.Quote("temp_user") + ` as tu
- LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
- WHERE tu.status=?`
- params := []interface{}{string(query.Status)}
- if query.OrgId > 0 {
- rawSql += ` AND tu.org_id=?`
- params = append(params, query.OrgId)
- }
- if query.Email != "" {
- rawSql += ` AND tu.email=?`
- params = append(params, query.Email)
- }
- rawSql += " ORDER BY tu.created desc"
- query.Result = make([]*m.TempUserDTO, 0)
- sess := x.Sql(rawSql, params...)
- err := sess.Find(&query.Result)
- return err
- }
- func GetTempUserByCode(query *m.GetTempUserByCodeQuery) error {
- var rawSql = `SELECT
- tu.id as id,
- tu.org_id as org_id,
- tu.email as email,
- tu.name as name,
- tu.role as role,
- tu.code as code,
- tu.status as status,
- tu.email_sent as email_sent,
- tu.email_sent_on as email_sent_on,
- tu.created as created,
- u.login as invited_by_login,
- u.name as invited_by_name,
- u.email as invited_by_email
- FROM ` + dialect.Quote("temp_user") + ` as tu
- LEFT OUTER JOIN ` + dialect.Quote("user") + ` as u on u.id = tu.invited_by_user_id
- WHERE tu.code=?`
- var tempUser m.TempUserDTO
- sess := x.Sql(rawSql, query.Code)
- has, err := sess.Get(&tempUser)
- if err != nil {
- return err
- } else if !has {
- return m.ErrTempUserNotFound
- }
- query.Result = &tempUser
- return err
- }
|