|
|
@@ -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
|
|
|
}
|