diff options
author | Bas van Kervel <bas@ethdev.com> | 2015-10-29 15:40:07 +0800 |
---|---|---|
committer | Bas van Kervel <bas@ethdev.com> | 2015-10-29 16:23:03 +0800 |
commit | c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e (patch) | |
tree | 37a575308d81a95cc22c667841f82a7c4b083fd8 /rpc/comms | |
parent | 56f8699a6c6bfe613d2ab28c47631a1f4a29e36f (diff) | |
download | go-tangerine-c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e.tar go-tangerine-c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e.tar.gz go-tangerine-c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e.tar.bz2 go-tangerine-c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e.tar.lz go-tangerine-c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e.tar.xz go-tangerine-c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e.tar.zst go-tangerine-c3c5f8b654f9ddaeedeb2d3d5d1caf000e08320e.zip |
rpc: fixed params parsing problem which could lead to a panic
check argument type before parsing params
recover from panic in ipc channel
Diffstat (limited to 'rpc/comms')
-rw-r--r-- | rpc/comms/comms.go | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/rpc/comms/comms.go b/rpc/comms/comms.go index 731b2f62e..61fba5722 100644 --- a/rpc/comms/comms.go +++ b/rpc/comms/comms.go @@ -62,13 +62,18 @@ type EthereumClient interface { func handle(id int, conn net.Conn, api shared.EthereumApi, c codec.Codec) { codec := c.New(conn) + defer func() { + if r := recover(); r != nil { + glog.Errorf("panic: %v\n", r) + } + codec.Close() + }() + for { requests, isBatch, err := codec.ReadRequest() if err == io.EOF { - codec.Close() return } else if err != nil { - codec.Close() glog.V(logger.Debug).Infof("Closed IPC Conn %06d recv err - %v\n", id, err) return } @@ -87,7 +92,6 @@ func handle(id int, conn net.Conn, api shared.EthereumApi, c codec.Codec) { err = codec.WriteResponse(responses[:responseCount]) if err != nil { - codec.Close() glog.V(logger.Debug).Infof("Closed IPC Conn %06d send err - %v\n", id, err) return } @@ -98,7 +102,6 @@ func handle(id int, conn net.Conn, api shared.EthereumApi, c codec.Codec) { rpcResponse = shared.NewRpcResponse(requests[0].Id, requests[0].Jsonrpc, res, err) err = codec.WriteResponse(rpcResponse) if err != nil { - codec.Close() glog.V(logger.Debug).Infof("Closed IPC Conn %06d send err - %v\n", id, err) return } |