datasources.go 5.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238
  1. package api
  2. import (
  3. "sort"
  4. "github.com/grafana/grafana/pkg/api/dtos"
  5. "github.com/grafana/grafana/pkg/bus"
  6. "github.com/grafana/grafana/pkg/middleware"
  7. m "github.com/grafana/grafana/pkg/models"
  8. "github.com/grafana/grafana/pkg/plugins"
  9. "github.com/grafana/grafana/pkg/util"
  10. )
  11. func GetDataSources(c *middleware.Context) Response {
  12. query := m.GetDataSourcesQuery{OrgId: c.OrgId}
  13. if err := bus.Dispatch(&query); err != nil {
  14. return ApiError(500, "Failed to query datasources", err)
  15. }
  16. result := make(dtos.DataSourceList, 0)
  17. for _, ds := range query.Result {
  18. dsItem := dtos.DataSourceListItemDTO{
  19. Id: ds.Id,
  20. OrgId: ds.OrgId,
  21. Name: ds.Name,
  22. Url: ds.Url,
  23. Type: ds.Type,
  24. Access: ds.Access,
  25. Password: ds.Password,
  26. Database: ds.Database,
  27. User: ds.User,
  28. BasicAuth: ds.BasicAuth,
  29. IsDefault: ds.IsDefault,
  30. JsonData: ds.JsonData,
  31. }
  32. if plugin, exists := plugins.DataSources[ds.Type]; exists {
  33. dsItem.TypeLogoUrl = plugin.Info.Logos.Small
  34. } else {
  35. dsItem.TypeLogoUrl = "public/img/icn-datasource.svg"
  36. }
  37. result = append(result, dsItem)
  38. }
  39. sort.Sort(result)
  40. return Json(200, &result)
  41. }
  42. func GetDataSourceById(c *middleware.Context) Response {
  43. query := m.GetDataSourceByIdQuery{
  44. Id: c.ParamsInt64(":id"),
  45. OrgId: c.OrgId,
  46. }
  47. if err := bus.Dispatch(&query); err != nil {
  48. if err == m.ErrDataSourceNotFound {
  49. return ApiError(404, "Data source not found", nil)
  50. }
  51. return ApiError(500, "Failed to query datasources", err)
  52. }
  53. ds := query.Result
  54. dtos := convertModelToDtos(ds)
  55. return Json(200, &dtos)
  56. }
  57. func DeleteDataSourceById(c *middleware.Context) {
  58. id := c.ParamsInt64(":id")
  59. if id <= 0 {
  60. c.JsonApiErr(400, "Missing valid datasource id", nil)
  61. return
  62. }
  63. cmd := &m.DeleteDataSourceByIdCommand{Id: id, OrgId: c.OrgId}
  64. err := bus.Dispatch(cmd)
  65. if err != nil {
  66. c.JsonApiErr(500, "Failed to delete datasource", err)
  67. return
  68. }
  69. c.JsonOK("Data source deleted")
  70. }
  71. func DeleteDataSourceByName(c *middleware.Context) {
  72. name := c.Params(":name")
  73. if name == "" {
  74. c.JsonApiErr(400, "Missing valid datasource name", nil)
  75. return
  76. }
  77. cmd := &m.DeleteDataSourceByNameCommand{Name: name, OrgId: c.OrgId}
  78. err := bus.Dispatch(cmd)
  79. if err != nil {
  80. c.JsonApiErr(500, "Failed to delete datasource", err)
  81. return
  82. }
  83. c.JsonOK("Data source deleted")
  84. }
  85. func AddDataSource(c *middleware.Context, cmd m.AddDataSourceCommand) {
  86. cmd.OrgId = c.OrgId
  87. if err := bus.Dispatch(&cmd); err != nil {
  88. if err == m.ErrDataSourceNameExists {
  89. c.JsonApiErr(409, err.Error(), err)
  90. return
  91. }
  92. c.JsonApiErr(500, "Failed to add datasource", err)
  93. return
  94. }
  95. c.JSON(200, util.DynMap{"message": "Datasource added", "id": cmd.Result.Id, "name": cmd.Result.Name})
  96. }
  97. func UpdateDataSource(c *middleware.Context, cmd m.UpdateDataSourceCommand) Response {
  98. cmd.OrgId = c.OrgId
  99. cmd.Id = c.ParamsInt64(":id")
  100. err := fillWithSecureJsonData(&cmd)
  101. if err != nil {
  102. return ApiError(500, "Failed to update datasource", err)
  103. }
  104. err = bus.Dispatch(&cmd)
  105. if err != nil {
  106. return ApiError(500, "Failed to update datasource", err)
  107. }
  108. return Json(200, util.DynMap{"message": "Datasource updated", "id": cmd.Id, "name": cmd.Name})
  109. }
  110. func fillWithSecureJsonData(cmd *m.UpdateDataSourceCommand) error {
  111. if len(cmd.SecureJsonData) == 0 {
  112. return nil
  113. }
  114. ds, err := getRawDataSourceById(cmd.Id, cmd.OrgId)
  115. if err != nil {
  116. return err
  117. }
  118. secureJsonData := ds.SecureJsonData.Decrypt()
  119. for k, v := range secureJsonData {
  120. if _, ok := cmd.SecureJsonData[k]; !ok {
  121. cmd.SecureJsonData[k] = v
  122. }
  123. }
  124. return nil
  125. }
  126. func getRawDataSourceById(id int64, orgId int64) (*m.DataSource, error) {
  127. query := m.GetDataSourceByIdQuery{
  128. Id: id,
  129. OrgId: orgId,
  130. }
  131. if err := bus.Dispatch(&query); err != nil {
  132. return nil, err
  133. }
  134. return query.Result, nil
  135. }
  136. // Get /api/datasources/name/:name
  137. func GetDataSourceByName(c *middleware.Context) Response {
  138. query := m.GetDataSourceByNameQuery{Name: c.Params(":name"), OrgId: c.OrgId}
  139. if err := bus.Dispatch(&query); err != nil {
  140. if err == m.ErrDataSourceNotFound {
  141. return ApiError(404, "Data source not found", nil)
  142. }
  143. return ApiError(500, "Failed to query datasources", err)
  144. }
  145. dtos := convertModelToDtos(query.Result)
  146. return Json(200, &dtos)
  147. }
  148. // Get /api/datasources/id/:name
  149. func GetDataSourceIdByName(c *middleware.Context) Response {
  150. query := m.GetDataSourceByNameQuery{Name: c.Params(":name"), OrgId: c.OrgId}
  151. if err := bus.Dispatch(&query); err != nil {
  152. if err == m.ErrDataSourceNotFound {
  153. return ApiError(404, "Data source not found", nil)
  154. }
  155. return ApiError(500, "Failed to query datasources", err)
  156. }
  157. ds := query.Result
  158. dtos := dtos.AnyId{
  159. Id: ds.Id,
  160. }
  161. return Json(200, &dtos)
  162. }
  163. func convertModelToDtos(ds *m.DataSource) dtos.DataSource {
  164. dto := dtos.DataSource{
  165. Id: ds.Id,
  166. OrgId: ds.OrgId,
  167. Name: ds.Name,
  168. Url: ds.Url,
  169. Type: ds.Type,
  170. Access: ds.Access,
  171. Password: ds.Password,
  172. Database: ds.Database,
  173. User: ds.User,
  174. BasicAuth: ds.BasicAuth,
  175. BasicAuthUser: ds.BasicAuthUser,
  176. BasicAuthPassword: ds.BasicAuthPassword,
  177. WithCredentials: ds.WithCredentials,
  178. IsDefault: ds.IsDefault,
  179. JsonData: ds.JsonData,
  180. SecureJsonFields: map[string]bool{},
  181. }
  182. for k, v := range ds.SecureJsonData {
  183. if len(v) > 0 {
  184. dto.SecureJsonFields[k] = true
  185. }
  186. }
  187. return dto
  188. }