summaryrefslogtreecommitdiff
path: root/plugins
diff options
context:
space:
mode:
authorValery Piashchynski <[email protected]>2021-06-02 20:56:49 +0300
committerValery Piashchynski <[email protected]>2021-06-02 20:56:49 +0300
commit6ccc3bb5e90073f579794c2d306ec01590afea05 (patch)
tree7b253c586135c00deebff245133b0b4a3ca798eb /plugins
parenta99c14abb333c10a9142cd2f178e001f1b1726fb (diff)
- Return nil if there are no workers in the requested plugin
Signed-off-by: Valery Piashchynski <[email protected]>
Diffstat (limited to 'plugins')
-rw-r--r--plugins/informer/plugin.go18
-rw-r--r--plugins/informer/rpc.go9
2 files changed, 13 insertions, 14 deletions
diff --git a/plugins/informer/plugin.go b/plugins/informer/plugin.go
index 2d76123b..f8725ed7 100644
--- a/plugins/informer/plugin.go
+++ b/plugins/informer/plugin.go
@@ -2,32 +2,30 @@ package informer
import (
endure "github.com/spiral/endure/pkg/container"
- "github.com/spiral/errors"
"github.com/spiral/roadrunner/v2/pkg/process"
)
const PluginName = "informer"
type Plugin struct {
- registry map[string]Informer
- available map[string]Availabler
+ withWorkers map[string]Informer
+ available map[string]Availabler
}
func (p *Plugin) Init() error {
p.available = make(map[string]Availabler)
- p.registry = make(map[string]Informer)
+ p.withWorkers = make(map[string]Informer)
return nil
}
// Workers provides BaseProcess slice with workers for the requested plugin
-func (p *Plugin) Workers(name string) ([]process.State, error) {
- const op = errors.Op("informer_plugin_workers")
- svc, ok := p.registry[name]
+func (p *Plugin) Workers(name string) []process.State {
+ svc, ok := p.withWorkers[name]
if !ok {
- return nil, errors.E(op, errors.Errorf("no such service: %s", name))
+ return nil
}
- return svc.Workers(), nil
+ return svc.Workers()
}
// Collects declares services to be collected.
@@ -45,7 +43,7 @@ func (p *Plugin) CollectPlugins(name endure.Named, l Availabler) {
// CollectWorkers obtains plugins with workers inside.
func (p *Plugin) CollectWorkers(name endure.Named, r Informer) {
- p.registry[name.Name()] = r
+ p.withWorkers[name.Name()] = r
}
// Name of the service.
diff --git a/plugins/informer/rpc.go b/plugins/informer/rpc.go
index 8955af92..3925ef64 100644
--- a/plugins/informer/rpc.go
+++ b/plugins/informer/rpc.go
@@ -16,7 +16,7 @@ type WorkerList struct {
// List all resettable services.
func (rpc *rpc) List(_ bool, list *[]string) error {
- *list = make([]string, 0, len(rpc.srv.registry))
+ *list = make([]string, 0, len(rpc.srv.withWorkers))
// append all plugin names to the output result
for name := range rpc.srv.available {
@@ -27,9 +27,10 @@ func (rpc *rpc) List(_ bool, list *[]string) error {
// Workers state of a given service.
func (rpc *rpc) Workers(service string, list *WorkerList) error {
- workers, err := rpc.srv.Workers(service)
- if err != nil {
- return err
+ workers := rpc.srv.Workers(service)
+ if workers == nil {
+ list = nil
+ return nil
}
// write actual processes