141 lines
2.9 KiB
Go
141 lines
2.9 KiB
Go
package sqlstore
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
"time"
|
|
|
|
"github.com/grafana/grafana/pkg/events"
|
|
"github.com/grafana/grafana/pkg/models"
|
|
"github.com/grafana/grafana/pkg/services/org"
|
|
"xorm.io/xorm"
|
|
)
|
|
|
|
// MainOrgName is the name of the main organization.
|
|
const MainOrgName = "Main Org."
|
|
|
|
func isOrgNameTaken(name string, existingId int64, sess *DBSession) (bool, error) {
|
|
// check if org name is taken
|
|
var org models.Org
|
|
exists, err := sess.Where("name=?", name).Get(&org)
|
|
|
|
if err != nil {
|
|
return false, nil
|
|
}
|
|
|
|
if exists && existingId != org.Id {
|
|
return true, nil
|
|
}
|
|
|
|
return false, nil
|
|
}
|
|
|
|
func (ss *SQLStore) createOrg(ctx context.Context, name string, userID int64, engine *xorm.Engine) (models.Org, error) {
|
|
orga := models.Org{
|
|
Name: name,
|
|
Created: time.Now(),
|
|
Updated: time.Now(),
|
|
}
|
|
if err := ss.inTransactionWithRetryCtx(ctx, engine, ss.bus, func(sess *DBSession) error {
|
|
if isNameTaken, err := isOrgNameTaken(name, 0, sess); err != nil {
|
|
return err
|
|
} else if isNameTaken {
|
|
return models.ErrOrgNameTaken
|
|
}
|
|
|
|
if _, err := sess.Insert(&orga); err != nil {
|
|
return err
|
|
}
|
|
|
|
user := models.OrgUser{
|
|
OrgId: orga.Id,
|
|
UserId: userID,
|
|
Role: org.RoleAdmin,
|
|
Created: time.Now(),
|
|
Updated: time.Now(),
|
|
}
|
|
|
|
_, err := sess.Insert(&user)
|
|
|
|
sess.publishAfterCommit(&events.OrgCreated{
|
|
Timestamp: orga.Created,
|
|
Id: orga.Id,
|
|
Name: orga.Name,
|
|
})
|
|
|
|
return err
|
|
}, 0); err != nil {
|
|
return orga, err
|
|
}
|
|
|
|
return orga, nil
|
|
}
|
|
|
|
func (ss *SQLStore) CreateOrg(ctx context.Context, cmd *models.CreateOrgCommand) error {
|
|
org, err := ss.createOrg(ctx, cmd.Name, cmd.UserId, ss.engine)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
cmd.Result = org
|
|
return nil
|
|
}
|
|
|
|
func verifyExistingOrg(sess *DBSession, orgId int64) error {
|
|
var org models.Org
|
|
has, err := sess.Where("id=?", orgId).Get(&org)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
if !has {
|
|
return models.ErrOrgNotFound
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func (ss *SQLStore) getOrCreateOrg(sess *DBSession, orgName string) (int64, error) {
|
|
var org models.Org
|
|
if ss.Cfg.AutoAssignOrg {
|
|
has, err := sess.Where("id=?", ss.Cfg.AutoAssignOrgId).Get(&org)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
if has {
|
|
return org.Id, nil
|
|
}
|
|
|
|
if ss.Cfg.AutoAssignOrgId != 1 {
|
|
ss.log.Error("Could not create user: organization ID does not exist", "orgID",
|
|
ss.Cfg.AutoAssignOrgId)
|
|
return 0, fmt.Errorf("could not create user: organization ID %d does not exist",
|
|
ss.Cfg.AutoAssignOrgId)
|
|
}
|
|
|
|
org.Name = MainOrgName
|
|
org.Id = int64(ss.Cfg.AutoAssignOrgId)
|
|
} else {
|
|
org.Name = orgName
|
|
}
|
|
|
|
org.Created = time.Now()
|
|
org.Updated = time.Now()
|
|
|
|
if org.Id != 0 {
|
|
if _, err := sess.InsertId(&org); err != nil {
|
|
return 0, err
|
|
}
|
|
} else {
|
|
if _, err := sess.InsertOne(&org); err != nil {
|
|
return 0, err
|
|
}
|
|
}
|
|
|
|
sess.publishAfterCommit(&events.OrgCreated{
|
|
Timestamp: org.Created,
|
|
Id: org.Id,
|
|
Name: org.Name,
|
|
})
|
|
|
|
return org.Id, nil
|
|
}
|