package sqlstore import ( "time" "github.com/grafana/grafana/pkg/bus" "github.com/grafana/grafana/pkg/events" "github.com/grafana/grafana/pkg/log" m "github.com/grafana/grafana/pkg/models" ) func init() { bus.AddHandler("sql", GetOrgById) bus.AddHandler("sql", CreateOrg) bus.AddHandler("sql", UpdateOrg) bus.AddHandler("sql", GetOrgByName) bus.AddHandler("sql", GetOrgList) bus.AddHandler("sql", DeleteOrg) } func GetOrgList(query *m.GetOrgListQuery) error { return x.Find(&query.Result) } func GetOrgById(query *m.GetOrgByIdQuery) error { var org m.Org exists, err := x.Id(query.Id).Get(&org) if err != nil { return err } if !exists { return m.ErrOrgNotFound } query.Result = &org return nil } func GetOrgByName(query *m.GetOrgByNameQuery) error { var org m.Org exists, err := x.Where("name=?", query.Name).Get(&org) if err != nil { return err } if !exists { return m.ErrOrgNotFound } query.Result = &org return nil } func CreateOrg(cmd *m.CreateOrgCommand) error { return inTransaction2(func(sess *session) error { org := m.Org{ Name: cmd.Name, Created: time.Now(), Updated: time.Now(), } if _, err := sess.Insert(&org); err != nil { return err } user := m.OrgUser{ OrgId: org.Id, UserId: cmd.UserId, Role: m.ROLE_ADMIN, Created: time.Now(), Updated: time.Now(), } _, err := sess.Insert(&user) cmd.Result = org sess.publishAfterCommit(&events.OrgCreated{ Timestamp: org.Created, Id: org.Id, Name: org.Name, }) return err }) } func UpdateOrg(cmd *m.UpdateOrgCommand) error { return inTransaction2(func(sess *session) error { org := m.Org{ Name: cmd.Name, Updated: time.Now(), } if _, err := sess.Id(cmd.OrgId).Update(&org); err != nil { return err } sess.publishAfterCommit(&events.OrgUpdated{ Timestamp: org.Updated, Id: org.Id, Name: org.Name, }) return nil }) } func DeleteOrg(cmd *m.DeleteOrgCommand) error { return inTransaction2(func(sess *session) error { deletes := []string{ "DELETE FROM star WHERE EXISTS (SELECT 1 FROM dashboard WHERE org_id = ?)", "DELETE FROM dashboard_tag WHERE EXISTS (SELECT 1 FROM dashboard WHERE org_id = ?)", "DELETE FROM dashboard WHERE org_id = ?", "DELETE FROM api_key WHERE org_id = ?", "DELETE FROM data_source WHERE org_id = ?", "DELETE FROM org_user WHERE org_id = ?", "DELETE FROM org WHERE id = ?", } for _, sql := range deletes { log.Trace(sql) _, err := sess.Exec(sql, cmd.Id) if err != nil { return err } } return nil }) }