org.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134
  1. package sqlstore
  2. import (
  3. "time"
  4. "github.com/grafana/grafana/pkg/bus"
  5. "github.com/grafana/grafana/pkg/events"
  6. "github.com/grafana/grafana/pkg/log"
  7. m "github.com/grafana/grafana/pkg/models"
  8. )
  9. func init() {
  10. bus.AddHandler("sql", GetOrgById)
  11. bus.AddHandler("sql", CreateOrg)
  12. bus.AddHandler("sql", UpdateOrg)
  13. bus.AddHandler("sql", GetOrgByName)
  14. bus.AddHandler("sql", GetOrgList)
  15. bus.AddHandler("sql", DeleteOrg)
  16. }
  17. func GetOrgList(query *m.GetOrgListQuery) error {
  18. return x.Find(&query.Result)
  19. }
  20. func GetOrgById(query *m.GetOrgByIdQuery) error {
  21. var org m.Org
  22. exists, err := x.Id(query.Id).Get(&org)
  23. if err != nil {
  24. return err
  25. }
  26. if !exists {
  27. return m.ErrOrgNotFound
  28. }
  29. query.Result = &org
  30. return nil
  31. }
  32. func GetOrgByName(query *m.GetOrgByNameQuery) error {
  33. var org m.Org
  34. exists, err := x.Where("name=?", query.Name).Get(&org)
  35. if err != nil {
  36. return err
  37. }
  38. if !exists {
  39. return m.ErrOrgNotFound
  40. }
  41. query.Result = &org
  42. return nil
  43. }
  44. func CreateOrg(cmd *m.CreateOrgCommand) error {
  45. return inTransaction2(func(sess *session) error {
  46. org := m.Org{
  47. Name: cmd.Name,
  48. Created: time.Now(),
  49. Updated: time.Now(),
  50. }
  51. if _, err := sess.Insert(&org); err != nil {
  52. return err
  53. }
  54. user := m.OrgUser{
  55. OrgId: org.Id,
  56. UserId: cmd.UserId,
  57. Role: m.ROLE_ADMIN,
  58. Created: time.Now(),
  59. Updated: time.Now(),
  60. }
  61. _, err := sess.Insert(&user)
  62. cmd.Result = org
  63. sess.publishAfterCommit(&events.OrgCreated{
  64. Timestamp: org.Created,
  65. Id: org.Id,
  66. Name: org.Name,
  67. })
  68. return err
  69. })
  70. }
  71. func UpdateOrg(cmd *m.UpdateOrgCommand) error {
  72. return inTransaction2(func(sess *session) error {
  73. org := m.Org{
  74. Name: cmd.Name,
  75. Updated: time.Now(),
  76. }
  77. if _, err := sess.Id(cmd.OrgId).Update(&org); err != nil {
  78. return err
  79. }
  80. sess.publishAfterCommit(&events.OrgUpdated{
  81. Timestamp: org.Updated,
  82. Id: org.Id,
  83. Name: org.Name,
  84. })
  85. return nil
  86. })
  87. }
  88. func DeleteOrg(cmd *m.DeleteOrgCommand) error {
  89. return inTransaction2(func(sess *session) error {
  90. deletes := []string{
  91. "DELETE FROM star WHERE EXISTS (SELECT 1 FROM dashboard WHERE org_id = ?)",
  92. "DELETE FROM dashboard_tag WHERE EXISTS (SELECT 1 FROM dashboard WHERE org_id = ?)",
  93. "DELETE FROM dashboard WHERE org_id = ?",
  94. "DELETE FROM api_key WHERE org_id = ?",
  95. "DELETE FROM data_source WHERE org_id = ?",
  96. "DELETE FROM org_user WHERE org_id = ?",
  97. "DELETE FROM org WHERE id = ?",
  98. }
  99. for _, sql := range deletes {
  100. log.Trace(sql)
  101. _, err := sess.Exec(sql, cmd.Id)
  102. if err != nil {
  103. return err
  104. }
  105. }
  106. return nil
  107. })
  108. }