mirror of
https://github.com/grafana/grafana.git
synced 2024-12-01 21:19:28 -06:00
f73236f8f4
See, $ gometalinter --vendor --disable-all --enable=megacheck --disable=gotype --deadline 6m ./... | grep SQL alert.go:43:9⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) alert_notification.go:122:12⚠️ sess.Sql is deprecated: use SQL instead. (SA1019) (megacheck) annotation.go:226:12⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) dashboard.go:228:9⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) dashboard.go:302:10⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) dashboard.go:416:9⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) dashboard.go:635:12⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) migrations/user_mig.go:137:9⚠️ sess.Sql is deprecated: use SQL instead. (SA1019) (megacheck) plugin_setting.go:29:10⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) quota.go:41:12⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) quota.go:84:13⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) quota.go:143:12⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) quota.go:186:13⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) quota.go:234:12⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) team.go:172:12⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) team.go:199:17⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) team.go:223:9⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) temp_user.go:99:10⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) temp_user.go:124:10⚠️ x.Sql is deprecated: use SQL instead. (SA1019) (megacheck) user.go:375:3⚠️ sess.Sql is deprecated: use SQL instead. (SA1019) (megacheck) user.go:377:3⚠️ sess.Sql is deprecated: use SQL instead. (SA1019) (megacheck) user.go:379:3⚠️ sess.Sql is deprecated: use SQL instead. (SA1019) (megacheck)
136 lines
3.7 KiB
Go
136 lines
3.7 KiB
Go
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
|
|
}
|