plugin_setting.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. package sqlstore
  2. import (
  3. "time"
  4. "github.com/grafana/grafana/pkg/bus"
  5. m "github.com/grafana/grafana/pkg/models"
  6. "github.com/grafana/grafana/pkg/setting"
  7. "github.com/grafana/grafana/pkg/util"
  8. )
  9. func init() {
  10. bus.AddHandler("sql", GetPluginSettings)
  11. bus.AddHandler("sql", GetPluginSettingById)
  12. bus.AddHandler("sql", UpdatePluginSetting)
  13. bus.AddHandler("sql", UpdatePluginSettingVersion)
  14. }
  15. func GetPluginSettings(query *m.GetPluginSettingsQuery) error {
  16. sql := `SELECT org_id, plugin_id, enabled, pinned, plugin_version
  17. FROM plugin_setting `
  18. params := make([]interface{}, 0)
  19. if query.OrgId != 0 {
  20. sql += "WHERE org_id=?"
  21. params = append(params, query.OrgId)
  22. }
  23. sess := x.Sql(sql, params...)
  24. query.Result = make([]*m.PluginSettingInfoDTO, 0)
  25. return sess.Find(&query.Result)
  26. }
  27. func GetPluginSettingById(query *m.GetPluginSettingByIdQuery) error {
  28. pluginSetting := m.PluginSetting{OrgId: query.OrgId, PluginId: query.PluginId}
  29. has, err := x.Get(&pluginSetting)
  30. if err != nil {
  31. return err
  32. } else if !has {
  33. return m.ErrPluginSettingNotFound
  34. }
  35. query.Result = &pluginSetting
  36. return nil
  37. }
  38. func UpdatePluginSetting(cmd *m.UpdatePluginSettingCmd) error {
  39. return inTransaction(func(sess *DBSession) error {
  40. var pluginSetting m.PluginSetting
  41. exists, err := sess.Where("org_id=? and plugin_id=?", cmd.OrgId, cmd.PluginId).Get(&pluginSetting)
  42. if err != nil {
  43. return err
  44. }
  45. sess.UseBool("enabled")
  46. sess.UseBool("pinned")
  47. if !exists {
  48. pluginSetting = m.PluginSetting{
  49. PluginId: cmd.PluginId,
  50. OrgId: cmd.OrgId,
  51. Enabled: cmd.Enabled,
  52. Pinned: cmd.Pinned,
  53. JsonData: cmd.JsonData,
  54. PluginVersion: cmd.PluginVersion,
  55. SecureJsonData: cmd.GetEncryptedJsonData(),
  56. Created: time.Now(),
  57. Updated: time.Now(),
  58. }
  59. // add state change event on commit success
  60. sess.events = append(sess.events, &m.PluginStateChangedEvent{
  61. PluginId: cmd.PluginId,
  62. OrgId: cmd.OrgId,
  63. Enabled: cmd.Enabled,
  64. })
  65. _, err = sess.Insert(&pluginSetting)
  66. return err
  67. } else {
  68. for key, data := range cmd.SecureJsonData {
  69. encryptedData, err := util.Encrypt([]byte(data), setting.SecretKey)
  70. if err != nil {
  71. return err
  72. }
  73. pluginSetting.SecureJsonData[key] = encryptedData
  74. }
  75. // add state change event on commit success
  76. if pluginSetting.Enabled != cmd.Enabled {
  77. sess.events = append(sess.events, &m.PluginStateChangedEvent{
  78. PluginId: cmd.PluginId,
  79. OrgId: cmd.OrgId,
  80. Enabled: cmd.Enabled,
  81. })
  82. }
  83. pluginSetting.Updated = time.Now()
  84. pluginSetting.Enabled = cmd.Enabled
  85. pluginSetting.JsonData = cmd.JsonData
  86. pluginSetting.Pinned = cmd.Pinned
  87. pluginSetting.PluginVersion = cmd.PluginVersion
  88. _, err = sess.Id(pluginSetting.Id).Update(&pluginSetting)
  89. return err
  90. }
  91. })
  92. }
  93. func UpdatePluginSettingVersion(cmd *m.UpdatePluginSettingVersionCmd) error {
  94. return inTransaction(func(sess *DBSession) error {
  95. _, err := sess.Exec("UPDATE plugin_setting SET plugin_version=? WHERE org_id=? AND plugin_id=?", cmd.PluginVersion, cmd.OrgId, cmd.PluginId)
  96. return err
  97. })
  98. }