diff options
Diffstat (limited to 'protocol.go')
-rwxr-xr-x | protocol.go | 27 |
1 files changed, 16 insertions, 11 deletions
diff --git a/protocol.go b/protocol.go index bdf78296..5e8be37a 100755 --- a/protocol.go +++ b/protocol.go @@ -1,15 +1,13 @@ package roadrunner import ( - "fmt" "os" json "github.com/json-iterator/go" + "github.com/spiral/errors" "github.com/spiral/goridge/v2" ) -var j = json.ConfigCompatibleWithStandardLibrary - type stopCommand struct { Stop bool `json:"stop"` } @@ -19,35 +17,42 @@ type pidCommand struct { } func sendControl(rl goridge.Relay, v interface{}) error { + const op = errors.Op("send control") if data, ok := v.([]byte); ok { - return rl.Send(data, goridge.PayloadControl|goridge.PayloadRaw) + err := rl.Send(data, goridge.PayloadControl|goridge.PayloadRaw) + if err != nil { + return errors.E(op, err) + } + return nil } - data, err := j.Marshal(v) + data, err := json.Marshal(v) if err != nil { - return fmt.Errorf("invalid payload: %s", err) + return errors.E(op, errors.Errorf("invalid payload: %s", err)) } return rl.Send(data, goridge.PayloadControl) } func fetchPID(rl goridge.Relay) (int64, error) { + const op = errors.Op("fetchPID") err := sendControl(rl, pidCommand{Pid: os.Getpid()}) if err != nil { - return 0, err + return 0, errors.E(op, err) } body, p, err := rl.Receive() if err != nil { - return 0, err + return 0, errors.E(op, err) } if !p.HasFlag(goridge.PayloadControl) { - return 0, fmt.Errorf("unexpected response, header is missing") + return 0, errors.E(op, errors.Str("unexpected response, header is missing")) } link := &pidCommand{} - if err := json.Unmarshal(body, link); err != nil { - return 0, err + err = json.Unmarshal(body, link) + if err != nil { + return 0, errors.E(op, err) } return int64(link.Pid), nil |