2024-07-18 23:03:18 +08:00
|
|
|
package sql
|
|
|
|
|
|
|
|
import (
|
2024-10-07 22:48:56 +08:00
|
|
|
"context"
|
2024-10-17 18:18:29 +08:00
|
|
|
"os"
|
|
|
|
"strings"
|
2024-10-07 22:48:56 +08:00
|
|
|
|
2024-11-13 20:17:15 +08:00
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
|
|
|
2024-10-07 22:48:56 +08:00
|
|
|
"github.com/grafana/authlib/claims"
|
2024-11-13 20:17:15 +08:00
|
|
|
"github.com/grafana/grafana/pkg/apimachinery/identity"
|
2024-07-23 01:08:30 +08:00
|
|
|
infraDB "github.com/grafana/grafana/pkg/infra/db"
|
2024-08-16 01:13:36 +08:00
|
|
|
"github.com/grafana/grafana/pkg/infra/tracing"
|
2024-07-18 23:03:18 +08:00
|
|
|
"github.com/grafana/grafana/pkg/services/featuremgmt"
|
|
|
|
"github.com/grafana/grafana/pkg/setting"
|
|
|
|
"github.com/grafana/grafana/pkg/storage/unified/resource"
|
|
|
|
"github.com/grafana/grafana/pkg/storage/unified/sql/db/dbimpl"
|
|
|
|
)
|
|
|
|
|
2024-09-12 22:22:27 +08:00
|
|
|
// Creates a new ResourceServer
|
2024-10-17 18:18:29 +08:00
|
|
|
func NewResourceServer(ctx context.Context, db infraDB.DB, cfg *setting.Cfg, features featuremgmt.FeatureToggles, tracer tracing.Tracer, reg prometheus.Registerer) (resource.ResourceServer, error) {
|
|
|
|
apiserverCfg := cfg.SectionWithEnvOverrides("grafana-apiserver")
|
2024-07-18 23:03:18 +08:00
|
|
|
opts := resource.ResourceServerOptions{
|
|
|
|
Tracer: tracer,
|
2024-10-17 18:18:29 +08:00
|
|
|
Blob: resource.BlobConfig{
|
|
|
|
URL: apiserverCfg.Key("blob_url").MustString(""),
|
|
|
|
},
|
|
|
|
Reg: reg,
|
|
|
|
}
|
|
|
|
|
|
|
|
// Support local file blob
|
|
|
|
if strings.HasPrefix(opts.Blob.URL, "./data/") {
|
|
|
|
dir := strings.Replace(opts.Blob.URL, "./data", cfg.DataPath, 1)
|
|
|
|
err := os.MkdirAll(dir, 0700)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
opts.Blob.URL = "file:///" + dir
|
2024-07-18 23:03:18 +08:00
|
|
|
}
|
|
|
|
|
2024-10-04 20:07:20 +08:00
|
|
|
eDB, err := dbimpl.ProvideResourceDB(db, cfg, tracer)
|
2024-07-18 23:03:18 +08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2024-07-23 01:08:30 +08:00
|
|
|
store, err := NewBackend(BackendOptions{DBProvider: eDB, Tracer: tracer})
|
2024-07-18 23:03:18 +08:00
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
opts.Backend = store
|
|
|
|
opts.Diagnostics = store
|
|
|
|
opts.Lifecycle = store
|
|
|
|
|
2024-11-07 22:20:07 +08:00
|
|
|
if features.IsEnabledGlobally(featuremgmt.FlagUnifiedStorageSearch) {
|
|
|
|
opts.Index = resource.NewResourceIndexServer(cfg, tracer)
|
|
|
|
}
|
|
|
|
|
2024-11-07 02:58:07 +08:00
|
|
|
rs, err := resource.NewResourceServer(opts)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
// Initialize the indexer if one is configured
|
|
|
|
if opts.Index != nil {
|
2024-11-13 20:17:15 +08:00
|
|
|
// TODO: Create a proper identity for the indexer
|
|
|
|
orgId := int64(1)
|
|
|
|
ctx = identity.WithRequester(ctx, &identity.StaticRequester{
|
|
|
|
Type: claims.TypeServiceAccount, // system:apiserver
|
|
|
|
UserID: 1,
|
|
|
|
OrgID: int64(1),
|
|
|
|
Name: "admin",
|
|
|
|
Login: "admin",
|
|
|
|
OrgRole: identity.RoleAdmin,
|
|
|
|
IsGrafanaAdmin: true,
|
|
|
|
Permissions: map[int64]map[string][]string{
|
|
|
|
orgId: {
|
|
|
|
"*": {"*"}, // all resources, all scopes
|
|
|
|
},
|
|
|
|
},
|
|
|
|
})
|
2024-11-07 02:58:07 +08:00
|
|
|
_, err = rs.(resource.ResourceIndexer).Index(ctx)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return rs, nil
|
2024-07-18 23:03:18 +08:00
|
|
|
}
|