summaryrefslogtreecommitdiff
path: root/cmd/_____/http/rpc.go
diff options
context:
space:
mode:
Diffstat (limited to 'cmd/_____/http/rpc.go')
-rw-r--r--cmd/_____/http/rpc.go44
1 files changed, 44 insertions, 0 deletions
diff --git a/cmd/_____/http/rpc.go b/cmd/_____/http/rpc.go
new file mode 100644
index 00000000..1bc8a06b
--- /dev/null
+++ b/cmd/_____/http/rpc.go
@@ -0,0 +1,44 @@
+package http
+
+import (
+ "github.com/sirupsen/logrus"
+ "github.com/spiral/roadrunner/cmd/_____/utils"
+ "github.com/pkg/errors"
+)
+
+type rpcServer struct {
+ service *Service
+}
+
+// WorkerList contains list of workers.
+type WorkerList struct {
+ // Workers is list of workers.
+ Workers []utils.Worker `json:"workers"`
+}
+
+// Reset resets underlying RR worker pool and restarts all of it's workers.
+func (rpc *rpcServer) Reset(reset bool, r *string) error {
+ if rpc.service.srv == nil {
+ return errors.New("no http server")
+ }
+
+ logrus.Info("http: restarting worker pool")
+ *r = "OK"
+
+ err := rpc.service.srv.rr.Reset()
+ if err != nil {
+ logrus.Errorf("http: %s", err)
+ }
+
+ return err
+}
+
+// Workers returns list of active workers and their stats.
+func (rpc *rpcServer) Workers(list bool, r *WorkerList) error {
+ if rpc.service.srv == nil {
+ return errors.New("no http server")
+ }
+
+ r.Workers = utils.FetchWorkers(rpc.service.srv.rr)
+ return nil
+}