mirror of
https://github.com/grafana/grafana.git
synced 2025-07-30 17:52:30 +08:00
Plugins: Backend: Skip host environment variables (#77858)
* Add pluginsSkipHostEnvVars feature flag * Set go-plugin's SkipHostEnvVar depending on feature flags * add missing file * Re-generate feature flags * Add allowedHostEnvVarNames * Fix feature toggles not being passed to plugin context service's plugin env vars * Fix tests * PR review feedback: Use cfg.Features * Fix tests * PR review feedback: removed DefaultProviderWithFeatures * merge with master * fix tests * use features.IsEnabledGlobally
This commit is contained in:
@ -162,6 +162,7 @@ Experimental features might be changed or removed without prior notice.
|
|||||||
| `dashboardScene` | Enables dashboard rendering using scenes for all roles |
|
| `dashboardScene` | Enables dashboard rendering using scenes for all roles |
|
||||||
| `logsInfiniteScrolling` | Enables infinite scrolling for the Logs panel in Explore and Dashboards |
|
| `logsInfiniteScrolling` | Enables infinite scrolling for the Logs panel in Explore and Dashboards |
|
||||||
| `flameGraphItemCollapsing` | Allow collapsing of flame graph items |
|
| `flameGraphItemCollapsing` | Allow collapsing of flame graph items |
|
||||||
|
| `pluginsSkipHostEnvVars` | Disables passing host environment variable to plugin processes |
|
||||||
|
|
||||||
## Development feature toggles
|
## Development feature toggles
|
||||||
|
|
||||||
|
@ -162,4 +162,5 @@ export interface FeatureToggles {
|
|||||||
alertingDetailsViewV2?: boolean;
|
alertingDetailsViewV2?: boolean;
|
||||||
datatrails?: boolean;
|
datatrails?: boolean;
|
||||||
alertingSimplifiedRouting?: boolean;
|
alertingSimplifiedRouting?: boolean;
|
||||||
|
pluginsSkipHostEnvVars?: boolean;
|
||||||
}
|
}
|
||||||
|
@ -9,6 +9,8 @@ import (
|
|||||||
"github.com/grafana/dataplane/examples"
|
"github.com/grafana/dataplane/examples"
|
||||||
"github.com/grafana/grafana-plugin-sdk-go/backend"
|
"github.com/grafana/grafana-plugin-sdk-go/backend"
|
||||||
"github.com/grafana/grafana-plugin-sdk-go/data"
|
"github.com/grafana/grafana-plugin-sdk-go/data"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
|
||||||
"github.com/grafana/grafana/pkg/infra/log"
|
"github.com/grafana/grafana/pkg/infra/log"
|
||||||
"github.com/grafana/grafana/pkg/infra/tracing"
|
"github.com/grafana/grafana/pkg/infra/tracing"
|
||||||
"github.com/grafana/grafana/pkg/plugins"
|
"github.com/grafana/grafana/pkg/plugins"
|
||||||
@ -22,7 +24,6 @@ import (
|
|||||||
"github.com/grafana/grafana/pkg/services/user"
|
"github.com/grafana/grafana/pkg/services/user"
|
||||||
"github.com/grafana/grafana/pkg/setting"
|
"github.com/grafana/grafana/pkg/setting"
|
||||||
"github.com/grafana/grafana/pkg/util"
|
"github.com/grafana/grafana/pkg/util"
|
||||||
"github.com/stretchr/testify/require"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
func TestPassThroughDataplaneExamples(t *testing.T) {
|
func TestPassThroughDataplaneExamples(t *testing.T) {
|
||||||
|
@ -39,7 +39,7 @@ var pluginSet = map[int]goplugin.PluginSet{
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
func newClientConfig(executablePath string, args []string, env []string, logger log.Logger,
|
func newClientConfig(executablePath string, args []string, env []string, skipHostEnvVars bool, logger log.Logger,
|
||||||
versionedPlugins map[int]goplugin.PluginSet) *goplugin.ClientConfig {
|
versionedPlugins map[int]goplugin.PluginSet) *goplugin.ClientConfig {
|
||||||
// We can ignore gosec G201 here, since the dynamic part of executablePath comes from the plugin definition
|
// We can ignore gosec G201 here, since the dynamic part of executablePath comes from the plugin definition
|
||||||
// nolint:gosec
|
// nolint:gosec
|
||||||
@ -50,6 +50,7 @@ func newClientConfig(executablePath string, args []string, env []string, logger
|
|||||||
Cmd: cmd,
|
Cmd: cmd,
|
||||||
HandshakeConfig: handshake,
|
HandshakeConfig: handshake,
|
||||||
VersionedPlugins: versionedPlugins,
|
VersionedPlugins: versionedPlugins,
|
||||||
|
SkipHostEnv: skipHostEnvVars,
|
||||||
Logger: logWrapper{Logger: logger},
|
Logger: logWrapper{Logger: logger},
|
||||||
AllowedProtocols: []goplugin.Protocol{goplugin.ProtocolGRPC},
|
AllowedProtocols: []goplugin.Protocol{goplugin.ProtocolGRPC},
|
||||||
GRPCDialOptions: []grpc.DialOption{
|
GRPCDialOptions: []grpc.DialOption{
|
||||||
@ -75,6 +76,7 @@ type PluginDescriptor struct {
|
|||||||
pluginID string
|
pluginID string
|
||||||
executablePath string
|
executablePath string
|
||||||
executableArgs []string
|
executableArgs []string
|
||||||
|
skipHostEnvVars bool
|
||||||
managed bool
|
managed bool
|
||||||
versionedPlugins map[int]goplugin.PluginSet
|
versionedPlugins map[int]goplugin.PluginSet
|
||||||
startRendererFn StartRendererFunc
|
startRendererFn StartRendererFunc
|
||||||
@ -82,21 +84,22 @@ type PluginDescriptor struct {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// NewBackendPlugin creates a new backend plugin factory used for registering a backend plugin.
|
// NewBackendPlugin creates a new backend plugin factory used for registering a backend plugin.
|
||||||
func NewBackendPlugin(pluginID, executablePath string, executableArgs ...string) backendplugin.PluginFactoryFunc {
|
func NewBackendPlugin(pluginID, executablePath string, skipHostEnvVars bool, executableArgs ...string) backendplugin.PluginFactoryFunc {
|
||||||
return newBackendPlugin(pluginID, executablePath, true, executableArgs...)
|
return newBackendPlugin(pluginID, executablePath, true, skipHostEnvVars, executableArgs...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewUnmanagedBackendPlugin creates a new backend plugin factory used for registering an unmanaged backend plugin.
|
// NewUnmanagedBackendPlugin creates a new backend plugin factory used for registering an unmanaged backend plugin.
|
||||||
func NewUnmanagedBackendPlugin(pluginID, executablePath string, executableArgs ...string) backendplugin.PluginFactoryFunc {
|
func NewUnmanagedBackendPlugin(pluginID, executablePath string, skipHostEnvVars bool, executableArgs ...string) backendplugin.PluginFactoryFunc {
|
||||||
return newBackendPlugin(pluginID, executablePath, false, executableArgs...)
|
return newBackendPlugin(pluginID, executablePath, false, skipHostEnvVars, executableArgs...)
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewBackendPlugin creates a new backend plugin factory used for registering a backend plugin.
|
// NewBackendPlugin creates a new backend plugin factory used for registering a backend plugin.
|
||||||
func newBackendPlugin(pluginID, executablePath string, managed bool, executableArgs ...string) backendplugin.PluginFactoryFunc {
|
func newBackendPlugin(pluginID, executablePath string, managed bool, skipHostEnvVars bool, executableArgs ...string) backendplugin.PluginFactoryFunc {
|
||||||
return newPlugin(PluginDescriptor{
|
return newPlugin(PluginDescriptor{
|
||||||
pluginID: pluginID,
|
pluginID: pluginID,
|
||||||
executablePath: executablePath,
|
executablePath: executablePath,
|
||||||
executableArgs: executableArgs,
|
executableArgs: executableArgs,
|
||||||
|
skipHostEnvVars: skipHostEnvVars,
|
||||||
managed: managed,
|
managed: managed,
|
||||||
versionedPlugins: pluginSet,
|
versionedPlugins: pluginSet,
|
||||||
})
|
})
|
||||||
|
@ -44,7 +44,7 @@ func newGrpcPlugin(descriptor PluginDescriptor, logger log.Logger, env func() []
|
|||||||
descriptor: descriptor,
|
descriptor: descriptor,
|
||||||
logger: logger,
|
logger: logger,
|
||||||
clientFactory: func() *plugin.Client {
|
clientFactory: func() *plugin.Client {
|
||||||
return plugin.NewClient(newClientConfig(descriptor.executablePath, descriptor.executableArgs, env(), logger, descriptor.versionedPlugins))
|
return plugin.NewClient(newClientConfig(descriptor.executablePath, descriptor.executableArgs, env(), descriptor.skipHostEnvVars, logger, descriptor.versionedPlugins))
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10,6 +10,7 @@ import (
|
|||||||
"github.com/grafana/grafana/pkg/plugins/backendplugin/pluginextensionv2"
|
"github.com/grafana/grafana/pkg/plugins/backendplugin/pluginextensionv2"
|
||||||
"github.com/grafana/grafana/pkg/plugins/backendplugin/secretsmanagerplugin"
|
"github.com/grafana/grafana/pkg/plugins/backendplugin/secretsmanagerplugin"
|
||||||
"github.com/grafana/grafana/pkg/plugins/log"
|
"github.com/grafana/grafana/pkg/plugins/log"
|
||||||
|
"github.com/grafana/grafana/pkg/services/featuremgmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
// PluginBackendProvider is a function type for initializing a Plugin backend.
|
// PluginBackendProvider is a function type for initializing a Plugin backend.
|
||||||
@ -17,19 +18,21 @@ type PluginBackendProvider func(_ context.Context, _ *plugins.Plugin) backendplu
|
|||||||
|
|
||||||
type Service struct {
|
type Service struct {
|
||||||
providerChain []PluginBackendProvider
|
providerChain []PluginBackendProvider
|
||||||
|
features featuremgmt.FeatureToggles
|
||||||
}
|
}
|
||||||
|
|
||||||
func New(providers ...PluginBackendProvider) *Service {
|
func New(features featuremgmt.FeatureToggles, providers ...PluginBackendProvider) *Service {
|
||||||
if len(providers) == 0 {
|
if len(providers) == 0 {
|
||||||
return New(RendererProvider, SecretsManagerProvider, DefaultProvider)
|
return New(features, RendererProvider, SecretsManagerProvider, DefaultProvider(features))
|
||||||
}
|
}
|
||||||
return &Service{
|
return &Service{
|
||||||
providerChain: providers,
|
providerChain: providers,
|
||||||
|
features: features,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func ProvideService(coreRegistry *coreplugin.Registry) *Service {
|
func ProvideService(features featuremgmt.FeatureToggles, coreRegistry *coreplugin.Registry) *Service {
|
||||||
return New(coreRegistry.BackendFactoryProvider(), RendererProvider, SecretsManagerProvider, DefaultProvider)
|
return New(features, coreRegistry.BackendFactoryProvider(), RendererProvider, SecretsManagerProvider, DefaultProvider(features))
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *Service) BackendFactory(ctx context.Context, p *plugins.Plugin) backendplugin.PluginFactoryFunc {
|
func (s *Service) BackendFactory(ctx context.Context, p *plugins.Plugin) backendplugin.PluginFactoryFunc {
|
||||||
@ -65,6 +68,9 @@ var SecretsManagerProvider PluginBackendProvider = func(_ context.Context, p *pl
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
var DefaultProvider PluginBackendProvider = func(_ context.Context, p *plugins.Plugin) backendplugin.PluginFactoryFunc {
|
func DefaultProvider(features featuremgmt.FeatureToggles) PluginBackendProvider {
|
||||||
return grpcplugin.NewBackendPlugin(p.ID, p.ExecutablePath())
|
return func(_ context.Context, p *plugins.Plugin) backendplugin.PluginFactoryFunc {
|
||||||
|
skipEnvVars := features.IsEnabledGlobally(featuremgmt.FlagPluginsSkipHostEnvVars)
|
||||||
|
return grpcplugin.NewBackendPlugin(p.ID, p.ExecutablePath(), skipEnvVars)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -17,12 +17,26 @@ import (
|
|||||||
"github.com/grafana/grafana/pkg/plugins"
|
"github.com/grafana/grafana/pkg/plugins"
|
||||||
"github.com/grafana/grafana/pkg/plugins/auth"
|
"github.com/grafana/grafana/pkg/plugins/auth"
|
||||||
"github.com/grafana/grafana/pkg/plugins/config"
|
"github.com/grafana/grafana/pkg/plugins/config"
|
||||||
|
"github.com/grafana/grafana/pkg/services/featuremgmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
customConfigPrefix = "GF_PLUGIN"
|
customConfigPrefix = "GF_PLUGIN"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
// allowedHostEnvVarNames is the list of environment variables that can be passed from Grafana's process to the
|
||||||
|
// plugin's process
|
||||||
|
var allowedHostEnvVarNames = []string{
|
||||||
|
// Env vars used by net/http (Go stdlib) for http/https proxy
|
||||||
|
// https://github.com/golang/net/blob/fbaf41277f28102c36926d1368dafbe2b54b4c1d/http/httpproxy/proxy.go#L91-L93
|
||||||
|
"HTTP_PROXY",
|
||||||
|
"http_proxy",
|
||||||
|
"HTTPS_PROXY",
|
||||||
|
"https_proxy",
|
||||||
|
"NO_PROXY",
|
||||||
|
"no_proxy",
|
||||||
|
}
|
||||||
|
|
||||||
type Provider interface {
|
type Provider interface {
|
||||||
Get(ctx context.Context, p *plugins.Plugin) []string
|
Get(ctx context.Context, p *plugins.Plugin) []string
|
||||||
}
|
}
|
||||||
@ -72,7 +86,15 @@ func (s *Service) Get(ctx context.Context, p *plugins.Plugin) []string {
|
|||||||
hostEnv = append(hostEnv, azsettings.WriteToEnvStr(s.cfg.Azure)...)
|
hostEnv = append(hostEnv, azsettings.WriteToEnvStr(s.cfg.Azure)...)
|
||||||
hostEnv = append(hostEnv, s.tracingEnvVars(p)...)
|
hostEnv = append(hostEnv, s.tracingEnvVars(p)...)
|
||||||
|
|
||||||
|
// If FlagPluginsSkipHostEnvVars is enabled, get some allowed variables from the current process and pass
|
||||||
|
// them down to the plugin. If the feature flag is not enabled, do not add anything else because ALL env vars
|
||||||
|
// from the current process (os.Environ()) will be forwarded to the plugin's process by go-plugin
|
||||||
|
if s.cfg.Features != nil && s.cfg.Features.IsEnabledGlobally(featuremgmt.FlagPluginsSkipHostEnvVars) {
|
||||||
|
hostEnv = append(hostEnv, s.allowedHostEnvVars()...)
|
||||||
|
}
|
||||||
|
|
||||||
ev := getPluginSettings(p.ID, s.cfg).asEnvVar(customConfigPrefix, hostEnv...)
|
ev := getPluginSettings(p.ID, s.cfg).asEnvVar(customConfigPrefix, hostEnv...)
|
||||||
|
|
||||||
return ev
|
return ev
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -238,6 +260,19 @@ func (s *Service) secureSocksProxyEnvVars() []string {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// allowedHostEnvVars returns the variables that can be passed from Grafana's process
|
||||||
|
// (current process, also known as: "host") to the plugin process.
|
||||||
|
// A string in format "k=v" is returned for each variable in allowedHostEnvVarNames, if it's set.
|
||||||
|
func (s *Service) allowedHostEnvVars() []string {
|
||||||
|
var r []string
|
||||||
|
for _, envVarName := range allowedHostEnvVarNames {
|
||||||
|
if envVarValue, ok := os.LookupEnv(envVarName); ok {
|
||||||
|
r = append(r, envVarName+"="+envVarValue)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
type pluginSettings map[string]string
|
type pluginSettings map[string]string
|
||||||
|
|
||||||
func getPluginSettings(pluginID string, cfg *config.Cfg) pluginSettings {
|
func getPluginSettings(pluginID string, cfg *config.Cfg) pluginSettings {
|
||||||
|
@ -38,6 +38,7 @@ func TestInitializer_envVars(t *testing.T) {
|
|||||||
"custom_env_var": "customVal",
|
"custom_env_var": "customVal",
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
Features: featuremgmt.WithFeatures(),
|
||||||
}, licensing)
|
}, licensing)
|
||||||
|
|
||||||
envVars := envVarsProvider.Get(context.Background(), p)
|
envVars := envVarsProvider.Get(context.Background(), p)
|
||||||
@ -51,6 +52,76 @@ func TestInitializer_envVars(t *testing.T) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestInitializer_skipHostEnvVars(t *testing.T) {
|
||||||
|
const (
|
||||||
|
envVarName = "HTTP_PROXY"
|
||||||
|
envVarValue = "lorem ipsum"
|
||||||
|
)
|
||||||
|
|
||||||
|
t.Setenv(envVarName, envVarValue)
|
||||||
|
|
||||||
|
p := &plugins.Plugin{
|
||||||
|
JSONData: plugins.JSONData{
|
||||||
|
ID: "test",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
t.Run("without FlagPluginsSkipHostEnvVars should not populate host env vars", func(t *testing.T) {
|
||||||
|
envVarsProvider := NewProvider(&config.Cfg{Features: featuremgmt.WithFeatures()}, nil)
|
||||||
|
envVars := envVarsProvider.Get(context.Background(), p)
|
||||||
|
|
||||||
|
// We want to test that the envvars.Provider does not add any of the host env vars.
|
||||||
|
// When starting the plugin via go-plugin, ALL host env vars will be added by go-plugin,
|
||||||
|
// but we are testing the envvars.Provider here, so that's outside the scope of this test.
|
||||||
|
_, ok := getEnvVarWithExists(envVars, envVarName)
|
||||||
|
require.False(t, ok, "host env var should not be present")
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("with FlagPluginsSkipHostEnvVars", func(t *testing.T) {
|
||||||
|
envVarsProvider := NewProvider(&config.Cfg{
|
||||||
|
Features: featuremgmt.WithFeatures(featuremgmt.FlagPluginsSkipHostEnvVars),
|
||||||
|
}, nil)
|
||||||
|
|
||||||
|
t.Run("should populate allowed host env vars", func(t *testing.T) {
|
||||||
|
// Set all allowed variables
|
||||||
|
for _, ev := range allowedHostEnvVarNames {
|
||||||
|
t.Setenv(ev, envVarValue)
|
||||||
|
}
|
||||||
|
envVars := envVarsProvider.Get(context.Background(), p)
|
||||||
|
|
||||||
|
// Test against each variable
|
||||||
|
for _, expEvName := range allowedHostEnvVarNames {
|
||||||
|
gotEvValue, ok := getEnvVarWithExists(envVars, expEvName)
|
||||||
|
require.True(t, ok, "host env var should be present")
|
||||||
|
require.Equal(t, envVarValue, gotEvValue)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
t.Run("should not populate host env vars that aren't allowed", func(t *testing.T) {
|
||||||
|
// Set all allowed variables
|
||||||
|
for _, ev := range allowedHostEnvVarNames {
|
||||||
|
t.Setenv(ev, envVarValue)
|
||||||
|
}
|
||||||
|
// ...and an extra one, which should not leak
|
||||||
|
const superSecretEnvVariableName = "SUPER_SECRET_VALUE"
|
||||||
|
t.Setenv(superSecretEnvVariableName, "01189998819991197253")
|
||||||
|
envVars := envVarsProvider.Get(context.Background(), p)
|
||||||
|
|
||||||
|
// Super secret should not leak
|
||||||
|
_, ok := getEnvVarWithExists(envVars, superSecretEnvVariableName)
|
||||||
|
require.False(t, ok, "super secret env var should not be leaked")
|
||||||
|
|
||||||
|
// Everything else should be present
|
||||||
|
for _, expEvName := range allowedHostEnvVarNames {
|
||||||
|
var gotEvValue string
|
||||||
|
gotEvValue, ok = getEnvVarWithExists(envVars, expEvName)
|
||||||
|
require.True(t, ok, "host env var should be present")
|
||||||
|
require.Equal(t, envVarValue, gotEvValue)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
|
func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
|
||||||
const pluginID = "plugin_id"
|
const pluginID = "plugin_id"
|
||||||
|
|
||||||
|
@ -1063,6 +1063,13 @@ var (
|
|||||||
Owner: grafanaAlertingSquad,
|
Owner: grafanaAlertingSquad,
|
||||||
HideFromDocs: true,
|
HideFromDocs: true,
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
Name: "pluginsSkipHostEnvVars",
|
||||||
|
Description: "Disables passing host environment variable to plugin processes",
|
||||||
|
Stage: FeatureStageExperimental,
|
||||||
|
FrontendOnly: false,
|
||||||
|
Owner: grafanaPluginsPlatformSquad,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -143,3 +143,4 @@ flameGraphItemCollapsing,experimental,@grafana/observability-traces-and-profilin
|
|||||||
alertingDetailsViewV2,experimental,@grafana/alerting-squad,false,false,false,true
|
alertingDetailsViewV2,experimental,@grafana/alerting-squad,false,false,false,true
|
||||||
datatrails,experimental,@grafana/dashboards-squad,false,false,false,true
|
datatrails,experimental,@grafana/dashboards-squad,false,false,false,true
|
||||||
alertingSimplifiedRouting,experimental,@grafana/alerting-squad,false,false,false,false
|
alertingSimplifiedRouting,experimental,@grafana/alerting-squad,false,false,false,false
|
||||||
|
pluginsSkipHostEnvVars,experimental,@grafana/plugins-platform-backend,false,false,false,false
|
||||||
|
|
@ -582,4 +582,8 @@ const (
|
|||||||
// FlagAlertingSimplifiedRouting
|
// FlagAlertingSimplifiedRouting
|
||||||
// Enables the simplified routing for alerting
|
// Enables the simplified routing for alerting
|
||||||
FlagAlertingSimplifiedRouting = "alertingSimplifiedRouting"
|
FlagAlertingSimplifiedRouting = "alertingSimplifiedRouting"
|
||||||
|
|
||||||
|
// FlagPluginsSkipHostEnvVars
|
||||||
|
// Disables passing host environment variable to plugin processes
|
||||||
|
FlagPluginsSkipHostEnvVars = "pluginsSkipHostEnvVars"
|
||||||
)
|
)
|
||||||
|
@ -54,7 +54,7 @@ func CreateIntegrationTestCtx(t *testing.T, cfg *setting.Cfg, coreRegistry *core
|
|||||||
disc := pipeline.ProvideDiscoveryStage(pCfg, finder.NewLocalFinder(true), reg)
|
disc := pipeline.ProvideDiscoveryStage(pCfg, finder.NewLocalFinder(true), reg)
|
||||||
boot := pipeline.ProvideBootstrapStage(pCfg, signature.ProvideService(pCfg, statickey.New()), assetpath.ProvideService(pCfg, cdn))
|
boot := pipeline.ProvideBootstrapStage(pCfg, signature.ProvideService(pCfg, statickey.New()), assetpath.ProvideService(pCfg, cdn))
|
||||||
valid := pipeline.ProvideValidationStage(pCfg, signature.NewValidator(signature.NewUnsignedAuthorizer(pCfg)), angularInspector, errTracker)
|
valid := pipeline.ProvideValidationStage(pCfg, signature.NewValidator(signature.NewUnsignedAuthorizer(pCfg)), angularInspector, errTracker)
|
||||||
init := pipeline.ProvideInitializationStage(pCfg, reg, fakes.NewFakeLicensingService(), provider.ProvideService(coreRegistry), proc, &fakes.FakeAuthService{}, fakes.NewFakeRoleRegistry())
|
init := pipeline.ProvideInitializationStage(pCfg, reg, fakes.NewFakeLicensingService(), provider.ProvideService(featuremgmt.WithFeatures(), coreRegistry), proc, &fakes.FakeAuthService{}, fakes.NewFakeRoleRegistry())
|
||||||
term, err := pipeline.ProvideTerminationStage(pCfg, reg, proc)
|
term, err := pipeline.ProvideTerminationStage(pCfg, reg, proc)
|
||||||
require.NoError(t, err)
|
require.NoError(t, err)
|
||||||
|
|
||||||
@ -100,7 +100,7 @@ func CreateTestLoader(t *testing.T, cfg *pluginsCfg.Cfg, opts LoaderOpts) *loade
|
|||||||
if opts.Initializer == nil {
|
if opts.Initializer == nil {
|
||||||
reg := registry.ProvideService()
|
reg := registry.ProvideService()
|
||||||
coreRegistry := coreplugin.NewRegistry(make(map[string]backendplugin.PluginFactoryFunc))
|
coreRegistry := coreplugin.NewRegistry(make(map[string]backendplugin.PluginFactoryFunc))
|
||||||
opts.Initializer = pipeline.ProvideInitializationStage(cfg, reg, fakes.NewFakeLicensingService(), provider.ProvideService(coreRegistry), process.ProvideService(), &fakes.FakeAuthService{}, fakes.NewFakeRoleRegistry())
|
opts.Initializer = pipeline.ProvideInitializationStage(cfg, reg, fakes.NewFakeLicensingService(), provider.ProvideService(featuremgmt.WithFeatures(), coreRegistry), process.ProvideService(), &fakes.FakeAuthService{}, fakes.NewFakeRoleRegistry())
|
||||||
}
|
}
|
||||||
|
|
||||||
if opts.Terminator == nil {
|
if opts.Terminator == nil {
|
||||||
|
Reference in New Issue
Block a user