package plugins
import "github.com/open-policy-agent/opa/plugins"
Package plugins implements plugin management for the policy engine.
Index ¶
- func Info(term *ast.Term) func(*Manager)
- type Manager
- func New(raw []byte, id string, store storage.Store, opts ...func(*Manager)) (*Manager, error)
- func (m *Manager) Client(name string) rest.Client
- func (m *Manager) GetCompiler() *ast.Compiler
- func (m *Manager) Labels() map[string]string
- func (m *Manager) Plugin(name string) Plugin
- func (m *Manager) Plugins() []string
- func (m *Manager) Reconfigure(config *config.Config) error
- func (m *Manager) Register(name string, plugin Plugin)
- func (m *Manager) RegisterCompilerTrigger(f func(txn storage.Transaction))
- func (m *Manager) Services() []string
- func (m *Manager) Start(ctx context.Context) error
- func (m *Manager) Stop(ctx context.Context)
- type Plugin
- type PluginInitFunc
Functions ¶
func Info ¶
Info sets the runtime information on the manager. The runtime information is propagated to opa.runtime() built-in function calls.
Types ¶
type Manager ¶
type Manager struct { Store storage.Store Config *config.Config Info *ast.Term ID string // contains filtered or unexported fields }
Manager implements lifecycle management of plugins and gives plugins access to engine-wide components like storage.
func New ¶
New creates a new Manager using config.
func (*Manager) Client ¶
Client returns a client for communicating with a remote service.
func (*Manager) GetCompiler ¶
GetCompiler returns the manager's compiler.
func (*Manager) Labels ¶
Labels returns the set of labels from the configuration.
func (*Manager) Plugin ¶
Plugin returns the plugin registered with name or nil if name is not found.
func (*Manager) Plugins ¶
Plugins returns the list of plugins registered with the manager.
func (*Manager) Reconfigure ¶
Reconfigure updates the configuration on the manager.
func (*Manager) Register ¶
Register adds a plugin to the manager. When the manager is started, all of the plugins will be started.
func (*Manager) RegisterCompilerTrigger ¶
func (m *Manager) RegisterCompilerTrigger(f func(txn storage.Transaction))
RegisterCompilerTrigger registers for change notifications when the compiler is changed.
func (*Manager) Services ¶
Services returns a list of services that m can provide clients for.
func (*Manager) Start ¶
Start starts the manager.
func (*Manager) Stop ¶
Stop stops the manager, stopping all the plugins registered with it
type Plugin ¶
type Plugin interface { Start(ctx context.Context) error Stop(ctx context.Context) Reconfigure(ctx context.Context, config interface{}) }
Plugin defines the interface for OPA plugins.
type PluginInitFunc ¶
PluginInitFunc defines the interface for the constructing plugins from configuration. The function will be called with the plugin manager (which provides access to OPA's storage layer, compiler, and service clients) and the configuration for the plugin itself.
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
plugins/bundle | Package bundle implements bundle downloading. |
plugins/discovery | Package discovery implements configuration discovery. |
plugins/logs | Package logs implements decision log buffering and uploading. |
plugins/rest | Package rest implements a REST client for communicating with remote services. |
plugins/status | Package status implements status reporting. |
- Version
- v0.10.2
- Published
- Dec 10, 2018
- Platform
- js/wasm
- Imports
- 8 packages
- Last checked
- 2 minutes ago –
Tools for package owners.