diff options
author | obscuren <geffobscura@gmail.com> | 2015-03-18 04:27:34 +0800 |
---|---|---|
committer | obscuren <geffobscura@gmail.com> | 2015-03-18 04:27:34 +0800 |
commit | 917050dc30d8717d7e0bba1257165c1aec44887f (patch) | |
tree | 712f8823391286438a0e5c3d1f53c4682254650e /rpc/jeth.go | |
parent | fe819f3b9f7a2d8d842c53b7269ccceace533569 (diff) | |
parent | 53104b09fa823cb5457960b8518b9650a5b083da (diff) | |
download | go-tangerine-917050dc30d8717d7e0bba1257165c1aec44887f.tar go-tangerine-917050dc30d8717d7e0bba1257165c1aec44887f.tar.gz go-tangerine-917050dc30d8717d7e0bba1257165c1aec44887f.tar.bz2 go-tangerine-917050dc30d8717d7e0bba1257165c1aec44887f.tar.lz go-tangerine-917050dc30d8717d7e0bba1257165c1aec44887f.tar.xz go-tangerine-917050dc30d8717d7e0bba1257165c1aec44887f.tar.zst go-tangerine-917050dc30d8717d7e0bba1257165c1aec44887f.zip |
Merge branch 'develop' into rpcfrontier
Diffstat (limited to 'rpc/jeth.go')
-rw-r--r-- | rpc/jeth.go | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/rpc/jeth.go b/rpc/jeth.go new file mode 100644 index 000000000..11d4599c9 --- /dev/null +++ b/rpc/jeth.go @@ -0,0 +1,43 @@ +package rpc + +import ( + "encoding/json" + // "fmt" + "github.com/obscuren/otto" +) + +type Jeth struct { + ethApi *EthereumApi + toVal func(interface{}) otto.Value +} + +func NewJeth(ethApi *EthereumApi, toVal func(interface{}) otto.Value) *Jeth { + return &Jeth{ethApi, toVal} +} + +func (self *Jeth) err(code int, msg string, id interface{}) otto.Value { + rpcerr := &RpcErrorObject{code, msg} + rpcresponse := &RpcErrorResponse{Jsonrpc: jsonrpcver, Id: id, Error: rpcerr} + return self.toVal(rpcresponse) +} + +func (self *Jeth) Send(call otto.FunctionCall) (response otto.Value) { + reqif, err := call.Argument(0).Export() + if err != nil { + return self.err(-32700, err.Error(), nil) + } + + jsonreq, err := json.Marshal(reqif) + + var req RpcRequest + err = json.Unmarshal(jsonreq, &req) + + var respif interface{} + err = self.ethApi.GetRequestReply(&req, &respif) + if err != nil { + return self.err(-32603, err.Error(), req.Id) + } + rpcresponse := &RpcSuccessResponse{Jsonrpc: jsonrpcver, Id: req.Id, Result: respif} + response = self.toVal(rpcresponse) + return +} |