mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Correlations: add migration
* Correlations: Add CreateCorrelation API
* Correlations: Make correlations work with provisioning
* Handle version changes
* Fix lining error
* lint fixes
* rebuild betterer results
* add a UID to each correlation
* Fix lint errors
* add docs
* better wording in API docs
* remove leftover comment
* handle ds updates
* Fix error message typo
* add bad data test
* make correlations a separate table
* skip readonly check when provisioning correlations
* delete stale correlations when datasources are deleted
* restore provisioned readonly ds
* publish deletion event with full data
* generate swagger and HTTP API docs
* apply source datasource permission to create correlation API
* Fix tests & lint errors
* ignore empty deletion events
* fix last lint errors
* fix more lint error
* Only publish deletion event if datasource was actually deleted
* delete DS provisioning deletes correlations, added & fixed tests
* Fix unmarshalling tests
* Fix linting errors
* Fix deltion event tests
* fix small linting error
* fix lint errors
* update betterer
* fix test
* make path singular
* Revert "make path singular"
This reverts commit 420c3d315e.
* add integration tests
* remove unneeded id from correlations table
* update spec
* update leftover references to CorrelationDTO
* fix tests
* cleanup tests
* fix lint error
71 lines
1.9 KiB
Go
71 lines
1.9 KiB
Go
package correlations
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/grafana/grafana/pkg/services/datasources"
|
|
"github.com/grafana/grafana/pkg/services/sqlstore"
|
|
"github.com/grafana/grafana/pkg/util"
|
|
)
|
|
|
|
// createCorrelation adds a correlation
|
|
func (s CorrelationsService) createCorrelation(ctx context.Context, cmd CreateCorrelationCommand) (Correlation, error) {
|
|
correlation := Correlation{
|
|
UID: util.GenerateShortUID(),
|
|
SourceUID: cmd.SourceUID,
|
|
TargetUID: cmd.TargetUID,
|
|
Label: cmd.Label,
|
|
Description: cmd.Description,
|
|
}
|
|
|
|
err := s.SQLStore.WithTransactionalDbSession(ctx, func(session *sqlstore.DBSession) error {
|
|
var err error
|
|
|
|
query := &datasources.GetDataSourceQuery{
|
|
OrgId: cmd.OrgId,
|
|
Uid: cmd.SourceUID,
|
|
}
|
|
if err = s.DataSourceService.GetDataSource(ctx, query); err != nil {
|
|
return ErrSourceDataSourceDoesNotExists
|
|
}
|
|
|
|
if !cmd.SkipReadOnlyCheck && query.Result.ReadOnly {
|
|
return ErrSourceDataSourceReadOnly
|
|
}
|
|
|
|
if err = s.DataSourceService.GetDataSource(ctx, &datasources.GetDataSourceQuery{
|
|
OrgId: cmd.OrgId,
|
|
Uid: cmd.TargetUID,
|
|
}); err != nil {
|
|
return ErrTargetDataSourceDoesNotExists
|
|
}
|
|
|
|
_, err = session.Insert(correlation)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
})
|
|
|
|
if err != nil {
|
|
return Correlation{}, err
|
|
}
|
|
|
|
return correlation, nil
|
|
}
|
|
|
|
func (s CorrelationsService) deleteCorrelationsBySourceUID(ctx context.Context, cmd DeleteCorrelationsBySourceUIDCommand) error {
|
|
return s.SQLStore.WithDbSession(ctx, func(session *sqlstore.DBSession) error {
|
|
_, err := session.Delete(&Correlation{SourceUID: cmd.SourceUID})
|
|
return err
|
|
})
|
|
}
|
|
|
|
func (s CorrelationsService) deleteCorrelationsByTargetUID(ctx context.Context, cmd DeleteCorrelationsByTargetUIDCommand) error {
|
|
return s.SQLStore.WithDbSession(ctx, func(session *sqlstore.DBSession) error {
|
|
_, err := session.Delete(&Correlation{TargetUID: cmd.TargetUID})
|
|
return err
|
|
})
|
|
}
|