mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* enable case insensitive by default * fix missing case-insensitive query * fix missing case insensitive query * fix missing case insensitive query in temp_user * skip integration testing in mysql * skip integration testing in mysql * use t.cleanup * lowercase only once * aligned to only using sql as that is what we do in other parts --------- Co-authored-by: Eric Leijonmarck <eric.leijonmarck@gmail.com>
178 lines
5.8 KiB
Go
178 lines
5.8 KiB
Go
package tempuserimpl
|
|
|
|
import (
|
|
"context"
|
|
"time"
|
|
|
|
"github.com/grafana/grafana/pkg/infra/db"
|
|
tempuser "github.com/grafana/grafana/pkg/services/temp_user"
|
|
"github.com/grafana/grafana/pkg/setting"
|
|
)
|
|
|
|
type store interface {
|
|
UpdateTempUserStatus(ctx context.Context, cmd *tempuser.UpdateTempUserStatusCommand) error
|
|
CreateTempUser(ctx context.Context, cmd *tempuser.CreateTempUserCommand) (*tempuser.TempUser, error)
|
|
UpdateTempUserWithEmailSent(ctx context.Context, cmd *tempuser.UpdateTempUserWithEmailSentCommand) error
|
|
GetTempUsersQuery(ctx context.Context, query *tempuser.GetTempUsersQuery) ([]*tempuser.TempUserDTO, error)
|
|
GetTempUserByCode(ctx context.Context, query *tempuser.GetTempUserByCodeQuery) (*tempuser.TempUserDTO, error)
|
|
ExpireOldUserInvites(ctx context.Context, cmd *tempuser.ExpireTempUsersCommand) error
|
|
}
|
|
|
|
type xormStore struct {
|
|
db db.DB
|
|
cfg *setting.Cfg
|
|
}
|
|
|
|
func (ss *xormStore) UpdateTempUserStatus(ctx context.Context, cmd *tempuser.UpdateTempUserStatusCommand) error {
|
|
return ss.db.WithTransactionalDbSession(ctx, func(sess *db.Session) error {
|
|
var rawSQL = "UPDATE temp_user SET status=? WHERE code=?"
|
|
_, err := sess.Exec(rawSQL, string(cmd.Status), cmd.Code)
|
|
return err
|
|
})
|
|
}
|
|
|
|
func (ss *xormStore) CreateTempUser(ctx context.Context, cmd *tempuser.CreateTempUserCommand) (*tempuser.TempUser, error) {
|
|
var queryResult *tempuser.TempUser
|
|
err := ss.db.WithTransactionalDbSession(ctx, func(sess *db.Session) error {
|
|
// create user
|
|
user := &tempuser.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().Unix(),
|
|
Updated: time.Now().Unix(),
|
|
}
|
|
|
|
if _, err := sess.Insert(user); err != nil {
|
|
return err
|
|
}
|
|
|
|
queryResult = user
|
|
|
|
return nil
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return queryResult, nil
|
|
}
|
|
|
|
func (ss *xormStore) UpdateTempUserWithEmailSent(ctx context.Context, cmd *tempuser.UpdateTempUserWithEmailSentCommand) error {
|
|
return ss.db.WithTransactionalDbSession(ctx, func(sess *db.Session) error {
|
|
user := &tempuser.TempUser{
|
|
EmailSent: true,
|
|
EmailSentOn: time.Now(),
|
|
}
|
|
|
|
_, err := sess.Where("code = ?", cmd.Code).Cols("email_sent", "email_sent_on").Update(user)
|
|
|
|
return err
|
|
})
|
|
}
|
|
|
|
func (ss *xormStore) GetTempUsersQuery(ctx context.Context, query *tempuser.GetTempUsersQuery) ([]*tempuser.TempUserDTO, error) {
|
|
queryResult := make([]*tempuser.TempUserDTO, 0)
|
|
err := ss.db.WithDbSession(ctx, func(dbSess *db.Session) 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 ` + ss.db.GetDialect().Quote("temp_user") + ` as tu
|
|
LEFT OUTER JOIN ` + ss.db.GetDialect().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 != "" {
|
|
if ss.cfg.CaseInsensitiveLogin {
|
|
rawSQL += ` AND LOWER(tu.email)=LOWER(?)`
|
|
} else {
|
|
rawSQL += ` AND tu.email=?`
|
|
}
|
|
params = append(params, query.Email)
|
|
}
|
|
|
|
rawSQL += " ORDER BY tu.created desc"
|
|
|
|
sess := dbSess.SQL(rawSQL, params...)
|
|
err := sess.Find(&queryResult)
|
|
return err
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return queryResult, nil
|
|
}
|
|
|
|
func (ss *xormStore) GetTempUserByCode(ctx context.Context, query *tempuser.GetTempUserByCodeQuery) (*tempuser.TempUserDTO, error) {
|
|
var queryResult *tempuser.TempUserDTO
|
|
err := ss.db.WithDbSession(ctx, func(dbSess *db.Session) 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 ` + ss.db.GetDialect().Quote("temp_user") + ` as tu
|
|
LEFT OUTER JOIN ` + ss.db.GetDialect().Quote("user") + ` as u on u.id = tu.invited_by_user_id
|
|
WHERE tu.code=?`
|
|
|
|
var tempUser tempuser.TempUserDTO
|
|
sess := dbSess.SQL(rawSQL, query.Code)
|
|
has, err := sess.Get(&tempUser)
|
|
|
|
if err != nil {
|
|
return err
|
|
} else if !has {
|
|
return tempuser.ErrTempUserNotFound
|
|
}
|
|
|
|
queryResult = &tempUser
|
|
return err
|
|
})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return queryResult, nil
|
|
}
|
|
|
|
func (ss *xormStore) ExpireOldUserInvites(ctx context.Context, cmd *tempuser.ExpireTempUsersCommand) error {
|
|
return ss.db.WithTransactionalDbSession(ctx, func(sess *db.Session) error {
|
|
var rawSQL = "UPDATE temp_user SET status = ?, updated = ? WHERE created <= ? AND status in (?, ?)"
|
|
if result, err := sess.Exec(rawSQL, string(tempuser.TmpUserExpired), time.Now().Unix(), cmd.OlderThan.Unix(), string(tempuser.TmpUserSignUpStarted), string(tempuser.TmpUserInvitePending)); err != nil {
|
|
return err
|
|
} else if cmd.NumExpired, err = result.RowsAffected(); err != nil {
|
|
return err
|
|
}
|
|
return nil
|
|
})
|
|
}
|