datasources.go 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. package api
  2. import (
  3. "github.com/grafana/grafana/pkg/api/dtos"
  4. "github.com/grafana/grafana/pkg/bus"
  5. //"github.com/grafana/grafana/pkg/log"
  6. "github.com/grafana/grafana/pkg/middleware"
  7. m "github.com/grafana/grafana/pkg/models"
  8. "github.com/grafana/grafana/pkg/util"
  9. )
  10. func GetDataSources(c *middleware.Context) {
  11. query := m.GetDataSourcesQuery{OrgId: c.OrgId}
  12. if err := bus.Dispatch(&query); err != nil {
  13. c.JsonApiErr(500, "Failed to query datasources", err)
  14. return
  15. }
  16. result := make([]*dtos.DataSource, len(query.Result))
  17. for i, ds := range query.Result {
  18. result[i] = &dtos.DataSource{
  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. }
  31. }
  32. c.JSON(200, result)
  33. }
  34. func GetDataSourceById(c *middleware.Context) Response {
  35. query := m.GetDataSourceByIdQuery{
  36. Id: c.ParamsInt64(":id"),
  37. OrgId: c.OrgId,
  38. }
  39. if err := bus.Dispatch(&query); err != nil {
  40. if err == m.ErrDataSourceNotFound {
  41. return ApiError(404, "Data source not found", nil)
  42. }
  43. return ApiError(500, "Failed to query datasources", err)
  44. }
  45. ds := query.Result
  46. dtos := convertModelToDtos(ds)
  47. return Json(200, &dtos)
  48. }
  49. func DeleteDataSource(c *middleware.Context) {
  50. id := c.ParamsInt64(":id")
  51. if id <= 0 {
  52. c.JsonApiErr(400, "Missing valid datasource id", nil)
  53. return
  54. }
  55. cmd := &m.DeleteDataSourceCommand{Id: id, OrgId: c.OrgId}
  56. err := bus.Dispatch(cmd)
  57. if err != nil {
  58. c.JsonApiErr(500, "Failed to delete datasource", err)
  59. return
  60. }
  61. c.JsonOK("Data source deleted")
  62. }
  63. func AddDataSource(c *middleware.Context, cmd m.AddDataSourceCommand) {
  64. cmd.OrgId = c.OrgId
  65. if err := bus.Dispatch(&cmd); err != nil {
  66. c.JsonApiErr(500, "Failed to add datasource", err)
  67. return
  68. }
  69. c.JSON(200, util.DynMap{"message": "Datasource added", "id": cmd.Result.Id})
  70. }
  71. func UpdateDataSource(c *middleware.Context, cmd m.UpdateDataSourceCommand) {
  72. cmd.OrgId = c.OrgId
  73. cmd.Id = c.ParamsInt64(":id")
  74. err := bus.Dispatch(&cmd)
  75. if err != nil {
  76. c.JsonApiErr(500, "Failed to update datasource", err)
  77. return
  78. }
  79. c.JsonOK("Datasource updated")
  80. }
  81. // Get /api/datasources/name/:name
  82. func GetDataSourceByName(c *middleware.Context) Response {
  83. query := m.GetDataSourceByNameQuery{Name: c.Params(":name"), OrgId: c.OrgId}
  84. if err := bus.Dispatch(&query); err != nil {
  85. if err == m.ErrDataSourceNotFound {
  86. return ApiError(404, "Data source not found", nil)
  87. }
  88. return ApiError(500, "Failed to query datasources", err)
  89. }
  90. ds := query.Result
  91. dtos := convertModelToDtos(ds)
  92. return Json(200, &dtos)
  93. }
  94. // Get /api/datasources/id/:name
  95. func GetDataSourceIdByName(c *middleware.Context) Response {
  96. query := m.GetDataSourceByNameQuery{Name: c.Params(":name"), OrgId: c.OrgId}
  97. if err := bus.Dispatch(&query); err != nil {
  98. if err == m.ErrDataSourceNotFound {
  99. return ApiError(404, "Data source not found", nil)
  100. }
  101. return ApiError(500, "Failed to query datasources", err)
  102. }
  103. ds := query.Result
  104. dtos := dtos.AnyId{
  105. Id: ds.Id,
  106. }
  107. return Json(200, &dtos)
  108. }
  109. func convertModelToDtos(ds m.DataSource) dtos.DataSource {
  110. return dtos.DataSource{
  111. Id: ds.Id,
  112. OrgId: ds.OrgId,
  113. Name: ds.Name,
  114. Url: ds.Url,
  115. Type: ds.Type,
  116. Access: ds.Access,
  117. Password: ds.Password,
  118. Database: ds.Database,
  119. User: ds.User,
  120. BasicAuth: ds.BasicAuth,
  121. BasicAuthUser: ds.BasicAuthUser,
  122. BasicAuthPassword: ds.BasicAuthPassword,
  123. WithCredentials: ds.WithCredentials,
  124. IsDefault: ds.IsDefault,
  125. JsonData: ds.JsonData,
  126. }
  127. }