go-ethereum/rpc/comms/comms.go

67 lines
1.5 KiB
Go
Raw Normal View History

2015-06-08 03:41:04 -05:00
package comms
2015-06-16 04:16:50 -05:00
import (
"io"
"net"
"github.com/ethereum/go-ethereum/logger"
"github.com/ethereum/go-ethereum/logger/glog"
"github.com/ethereum/go-ethereum/rpc/api"
"github.com/ethereum/go-ethereum/rpc/codec"
"github.com/ethereum/go-ethereum/rpc/shared"
"strings"
2015-06-16 04:16:50 -05:00
)
2015-06-16 06:07:13 -05:00
const (
maxHttpSizeReqLength = 1024 * 1024 // 1MB
)
var (
// List with all API's which are offered over the in proc interface by default
DefaultInProcApis = api.AllApis
// List with all API's which are offered over the IPC interface by default
DefaultIpcApis = api.AllApis
// List with API's which are offered over thr HTTP/RPC interface by default
DefaultHttpRpcApis = strings.Join([]string{
api.DbApiName, api.EthApiName, api.NetApiName, api.Web3ApiName,
}, ",")
)
2015-06-08 03:41:04 -05:00
type EthereumClient interface {
// Close underlaying connection
2015-06-08 03:41:04 -05:00
Close()
// Send request
2015-06-08 03:41:04 -05:00
Send(interface{}) error
// Receive response
2015-06-08 03:41:04 -05:00
Recv() (interface{}, error)
}
2015-06-16 04:16:50 -05:00
func handle(conn net.Conn, api api.EthereumApi, c codec.Codec) {
codec := c.New(conn)
for {
req, err := codec.ReadRequest()
if err == io.EOF {
codec.Close()
return
} else if err != nil {
2015-06-16 06:07:13 -05:00
glog.V(logger.Error).Infof("comms recv err - %v\n", err)
2015-06-16 04:16:50 -05:00
codec.Close()
return
}
var rpcResponse interface{}
res, err := api.Execute(req)
rpcResponse = shared.NewRpcResponse(req.Id, req.Jsonrpc, res, err)
err = codec.WriteResponse(rpcResponse)
if err != nil {
glog.V(logger.Error).Infof("comms send err - %v\n", err)
codec.Close()
return
}
}
}