mirror of
https://github.com/grafana/grafana.git
synced 2025-01-18 20:43:26 -06:00
736be74128
* add usage stats providers * migrate thumbnails service to `registry.ProvidesUsageStats` * snake -> camel * lint fix * migrate accesscontrol to `registry.ProvidesUsageStats` * add accesscontrol to usage stats providers registry * fix test * added a note about errors
57 lines
1.9 KiB
Go
57 lines
1.9 KiB
Go
package registry
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/grafana/grafana/pkg/services/sqlstore/migrator"
|
|
)
|
|
|
|
// BackgroundServiceRegistry provides background services.
|
|
type BackgroundServiceRegistry interface {
|
|
GetServices() []BackgroundService
|
|
}
|
|
|
|
// CanBeDisabled allows the services to decide if it should
|
|
// be started or not by itself. This is useful for services
|
|
// that might not always be started, ex alerting.
|
|
// This will be called after `Init()`.
|
|
type CanBeDisabled interface {
|
|
// IsDisabled should return a bool saying if it can be started or not.
|
|
IsDisabled() bool
|
|
}
|
|
|
|
// BackgroundService should be implemented for services that have
|
|
// long running tasks in the background.
|
|
type BackgroundService interface {
|
|
// Run starts the background process of the service after `Init` have been called
|
|
// on all services. The `context.Context` passed into the function should be used
|
|
// to subscribe to ctx.Done() so the service can be notified when Grafana shuts down.
|
|
Run(ctx context.Context) error
|
|
}
|
|
|
|
// UsageStatsProvidersRegistry provides services sharing their usage stats
|
|
type UsageStatsProvidersRegistry interface {
|
|
GetServices() []ProvidesUsageStats
|
|
}
|
|
|
|
// ProvidesUsageStats is an interface for services that share their usage stats
|
|
type ProvidesUsageStats interface {
|
|
// GetUsageStats is called on a schedule by the UsageStatsService
|
|
// Any errors occurring during usage stats collection should be collected and logged within the provider.
|
|
GetUsageStats(ctx context.Context) map[string]interface{}
|
|
}
|
|
|
|
// DatabaseMigrator allows the caller to add migrations to
|
|
// the migrator passed as argument
|
|
type DatabaseMigrator interface {
|
|
// AddMigrations allows the service to add migrations to
|
|
// the database migrator.
|
|
AddMigration(mg *migrator.Migrator)
|
|
}
|
|
|
|
// IsDisabled returns whether a background service is disabled.
|
|
func IsDisabled(srv BackgroundService) bool {
|
|
canBeDisabled, ok := srv.(CanBeDisabled)
|
|
return ok && canBeDisabled.IsDisabled()
|
|
}
|