| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270 |
- package api
- import (
- "sort"
- "github.com/grafana/grafana/pkg/api/dtos"
- "github.com/grafana/grafana/pkg/bus"
- m "github.com/grafana/grafana/pkg/models"
- "github.com/grafana/grafana/pkg/plugins"
- "github.com/grafana/grafana/pkg/util"
- )
- func GetDataSources(c *m.ReqContext) Response {
- query := m.GetDataSourcesQuery{OrgId: c.OrgId}
- if err := bus.Dispatch(&query); err != nil {
- return ApiError(500, "Failed to query datasources", err)
- }
- result := make(dtos.DataSourceList, 0)
- for _, ds := range query.Result {
- dsItem := dtos.DataSourceListItemDTO{
- Id: ds.Id,
- OrgId: ds.OrgId,
- Name: ds.Name,
- Url: ds.Url,
- Type: ds.Type,
- Access: ds.Access,
- Password: ds.Password,
- Database: ds.Database,
- User: ds.User,
- BasicAuth: ds.BasicAuth,
- IsDefault: ds.IsDefault,
- JsonData: ds.JsonData,
- ReadOnly: ds.ReadOnly,
- }
- if plugin, exists := plugins.DataSources[ds.Type]; exists {
- dsItem.TypeLogoUrl = plugin.Info.Logos.Small
- } else {
- dsItem.TypeLogoUrl = "public/img/icn-datasource.svg"
- }
- result = append(result, dsItem)
- }
- sort.Sort(result)
- return Json(200, &result)
- }
- func GetDataSourceById(c *m.ReqContext) Response {
- query := m.GetDataSourceByIdQuery{
- Id: c.ParamsInt64(":id"),
- OrgId: c.OrgId,
- }
- if err := bus.Dispatch(&query); err != nil {
- if err == m.ErrDataSourceNotFound {
- return ApiError(404, "Data source not found", nil)
- }
- return ApiError(500, "Failed to query datasources", err)
- }
- ds := query.Result
- dtos := convertModelToDtos(ds)
- return Json(200, &dtos)
- }
- func DeleteDataSourceById(c *m.ReqContext) Response {
- id := c.ParamsInt64(":id")
- if id <= 0 {
- return ApiError(400, "Missing valid datasource id", nil)
- }
- ds, err := getRawDataSourceById(id, c.OrgId)
- if err != nil {
- return ApiError(400, "Failed to delete datasource", nil)
- }
- if ds.ReadOnly {
- return ApiError(403, "Cannot delete read-only data source", nil)
- }
- cmd := &m.DeleteDataSourceByIdCommand{Id: id, OrgId: c.OrgId}
- err = bus.Dispatch(cmd)
- if err != nil {
- return ApiError(500, "Failed to delete datasource", err)
- }
- return ApiSuccess("Data source deleted")
- }
- func DeleteDataSourceByName(c *m.ReqContext) Response {
- name := c.Params(":name")
- if name == "" {
- return ApiError(400, "Missing valid datasource name", nil)
- }
- getCmd := &m.GetDataSourceByNameQuery{Name: name, OrgId: c.OrgId}
- if err := bus.Dispatch(getCmd); err != nil {
- return ApiError(500, "Failed to delete datasource", err)
- }
- if getCmd.Result.ReadOnly {
- return ApiError(403, "Cannot delete read-only data source", nil)
- }
- cmd := &m.DeleteDataSourceByNameCommand{Name: name, OrgId: c.OrgId}
- err := bus.Dispatch(cmd)
- if err != nil {
- return ApiError(500, "Failed to delete datasource", err)
- }
- return ApiSuccess("Data source deleted")
- }
- func AddDataSource(c *m.ReqContext, cmd m.AddDataSourceCommand) Response {
- cmd.OrgId = c.OrgId
- if err := bus.Dispatch(&cmd); err != nil {
- if err == m.ErrDataSourceNameExists {
- return ApiError(409, err.Error(), err)
- }
- return ApiError(500, "Failed to add datasource", err)
- }
- ds := convertModelToDtos(cmd.Result)
- return Json(200, util.DynMap{
- "message": "Datasource added",
- "id": cmd.Result.Id,
- "name": cmd.Result.Name,
- "datasource": ds,
- })
- }
- func UpdateDataSource(c *m.ReqContext, cmd m.UpdateDataSourceCommand) Response {
- cmd.OrgId = c.OrgId
- cmd.Id = c.ParamsInt64(":id")
- err := fillWithSecureJsonData(&cmd)
- if err != nil {
- return ApiError(500, "Failed to update datasource", err)
- }
- err = bus.Dispatch(&cmd)
- if err != nil {
- if err == m.ErrDataSourceUpdatingOldVersion {
- return ApiError(500, "Failed to update datasource. Reload new version and try again", err)
- } else {
- return ApiError(500, "Failed to update datasource", err)
- }
- }
- ds := convertModelToDtos(cmd.Result)
- return Json(200, util.DynMap{
- "message": "Datasource updated",
- "id": cmd.Id,
- "name": cmd.Name,
- "datasource": ds,
- })
- }
- func fillWithSecureJsonData(cmd *m.UpdateDataSourceCommand) error {
- if len(cmd.SecureJsonData) == 0 {
- return nil
- }
- ds, err := getRawDataSourceById(cmd.Id, cmd.OrgId)
- if err != nil {
- return err
- }
- if ds.ReadOnly {
- return m.ErrDatasourceIsReadOnly
- }
- secureJsonData := ds.SecureJsonData.Decrypt()
- for k, v := range secureJsonData {
- if _, ok := cmd.SecureJsonData[k]; !ok {
- cmd.SecureJsonData[k] = v
- }
- }
- return nil
- }
- func getRawDataSourceById(id int64, orgId int64) (*m.DataSource, error) {
- query := m.GetDataSourceByIdQuery{
- Id: id,
- OrgId: orgId,
- }
- if err := bus.Dispatch(&query); err != nil {
- return nil, err
- }
- return query.Result, nil
- }
- // Get /api/datasources/name/:name
- func GetDataSourceByName(c *m.ReqContext) Response {
- query := m.GetDataSourceByNameQuery{Name: c.Params(":name"), OrgId: c.OrgId}
- if err := bus.Dispatch(&query); err != nil {
- if err == m.ErrDataSourceNotFound {
- return ApiError(404, "Data source not found", nil)
- }
- return ApiError(500, "Failed to query datasources", err)
- }
- dtos := convertModelToDtos(query.Result)
- dtos.ReadOnly = true
- return Json(200, &dtos)
- }
- // Get /api/datasources/id/:name
- func GetDataSourceIdByName(c *m.ReqContext) Response {
- query := m.GetDataSourceByNameQuery{Name: c.Params(":name"), OrgId: c.OrgId}
- if err := bus.Dispatch(&query); err != nil {
- if err == m.ErrDataSourceNotFound {
- return ApiError(404, "Data source not found", nil)
- }
- return ApiError(500, "Failed to query datasources", err)
- }
- ds := query.Result
- dtos := dtos.AnyId{
- Id: ds.Id,
- }
- return Json(200, &dtos)
- }
- func convertModelToDtos(ds *m.DataSource) dtos.DataSource {
- dto := dtos.DataSource{
- Id: ds.Id,
- OrgId: ds.OrgId,
- Name: ds.Name,
- Url: ds.Url,
- Type: ds.Type,
- Access: ds.Access,
- Password: ds.Password,
- Database: ds.Database,
- User: ds.User,
- BasicAuth: ds.BasicAuth,
- BasicAuthUser: ds.BasicAuthUser,
- BasicAuthPassword: ds.BasicAuthPassword,
- WithCredentials: ds.WithCredentials,
- IsDefault: ds.IsDefault,
- JsonData: ds.JsonData,
- SecureJsonFields: map[string]bool{},
- Version: ds.Version,
- ReadOnly: ds.ReadOnly,
- }
- for k, v := range ds.SecureJsonData {
- if len(v) > 0 {
- dto.SecureJsonFields[k] = true
- }
- }
- return dto
- }
|