diff options
author | Valery Piashchynski <[email protected]> | 2021-10-18 15:33:20 +0300 |
---|---|---|
committer | Valery Piashchynski <[email protected]> | 2021-10-18 15:33:20 +0300 |
commit | 025b6c84ac0592fa0f1bc07efe9c62646c397bef (patch) | |
tree | 4198fe8feb40e4ac1e5f1ecfd0a3017429dcd799 /internal/protocol.go | |
parent | d5474764f095fc2d829654272d5b5bf3662d0241 (diff) |
Update error handling in the pipe/socket worker allocate methods
Signed-off-by: Valery Piashchynski <[email protected]>
Diffstat (limited to 'internal/protocol.go')
-rwxr-xr-x | internal/protocol.go | 30 |
1 files changed, 14 insertions, 16 deletions
diff --git a/internal/protocol.go b/internal/protocol.go index 73cb960e..e6e6e7ab 100755 --- a/internal/protocol.go +++ b/internal/protocol.go @@ -34,8 +34,6 @@ func putFrame(f *frame.Frame) { } func SendControl(rl relay.Relay, payload interface{}) error { - const op = errors.Op("send_control") - fr := getFrame() defer putFrame(fr) @@ -45,7 +43,7 @@ func SendControl(rl relay.Relay, payload interface{}) error { if data, ok := payload.([]byte); ok { // check if payload no more that 4Gb if uint32(len(data)) > ^uint32(0) { - return errors.E(op, errors.Str("payload is more that 4gb")) + return errors.Str("payload is more that 4gb") } fr.WritePayloadLen(fr.Header(), uint32(len(data))) @@ -54,14 +52,14 @@ func SendControl(rl relay.Relay, payload interface{}) error { err := rl.Send(fr) if err != nil { - return errors.E(op, err) + return err } return nil } data, err := json.Marshal(payload) if err != nil { - return errors.E(op, errors.Errorf("invalid payload: %s", err)) + return errors.Errorf("invalid payload: %s", err) } fr.WritePayloadLen(fr.Header(), uint32(len(data))) @@ -71,47 +69,47 @@ func SendControl(rl relay.Relay, payload interface{}) error { // we don't need a copy here, because frame copy the data before send err = rl.Send(fr) if err != nil { - return errors.E(op, err) + return errors.E(errors.FileNotFound, err) } return nil } func Pid(rl relay.Relay) (int64, error) { - const op = errors.Op("fetch_pid") err := SendControl(rl, pidCommand{Pid: os.Getpid()}) if err != nil { - return 0, errors.E(op, err) + return 0, err } fr := getFrame() defer putFrame(fr) err = rl.Receive(fr) - if !fr.VerifyCRC(fr.Header()) { - return 0, errors.E(op, errors.Str("CRC mismatch")) - } if err != nil { - return 0, errors.E(op, err) + return 0, err + } + + if !fr.VerifyCRC(fr.Header()) { + return 0, errors.Str("CRC mismatch") } if fr == nil { - return 0, errors.E(op, errors.Str("nil frame received")) + return 0, errors.Str("nil frame received") } flags := fr.ReadFlags() if flags&frame.CONTROL == 0 { - return 0, errors.E(op, errors.Str("unexpected response, header is missing, no CONTROL flag")) + return 0, errors.Str("unexpected response, header is missing, no CONTROL flag") } link := &pidCommand{} err = json.Unmarshal(fr.Payload(), link) if err != nil { - return 0, errors.E(op, err) + return 0, err } if link.Pid <= 0 { - return 0, errors.E(op, errors.Str("pid should be greater than 0")) + return 0, errors.Str("pid should be greater than 0") } return int64(link.Pid), nil |