implement transact
This commit is contained in:
parent
ec85458612
commit
6d012f628b
|
@ -550,9 +550,6 @@ var contract = function (address, desc) {
|
||||||
result[displayName][typeName] = impl;
|
result[displayName][typeName] = impl;
|
||||||
|
|
||||||
});
|
});
|
||||||
console.log("call:")
|
|
||||||
console.log(result.call)
|
|
||||||
console.log(JSON.stringify(result));
|
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
|
|
|
@ -45,8 +45,8 @@ ApplicationWindow {
|
||||||
|
|
||||||
mainSplit.setView(wallet.view, wallet.menuItem);
|
mainSplit.setView(wallet.view, wallet.menuItem);
|
||||||
|
|
||||||
console.log("starting browser")
|
//newBrowserTab("http://etherian.io");
|
||||||
newBrowserTab("http://etherian.io");
|
newBrowserTab("file:///users/jeffrey/test.html");
|
||||||
|
|
||||||
// Command setup
|
// Command setup
|
||||||
gui.sendCommand(0)
|
gui.sendCommand(0)
|
||||||
|
|
37
rpc/args.go
37
rpc/args.go
|
@ -1,8 +1,6 @@
|
||||||
package rpc
|
package rpc
|
||||||
|
|
||||||
import (
|
import "encoding/json"
|
||||||
"encoding/json"
|
|
||||||
)
|
|
||||||
|
|
||||||
type GetBlockArgs struct {
|
type GetBlockArgs struct {
|
||||||
BlockNumber int32
|
BlockNumber int32
|
||||||
|
@ -30,33 +28,18 @@ func (obj *GetBlockArgs) requirements() error {
|
||||||
}
|
}
|
||||||
|
|
||||||
type NewTxArgs struct {
|
type NewTxArgs struct {
|
||||||
Sec string `json:"sec"`
|
|
||||||
Recipient string `json:"recipient"`
|
Recipient string `json:"recipient"`
|
||||||
Value string `json:"value"`
|
Value string `json:"value"`
|
||||||
Gas string `json:"gas"`
|
Gas string `json:"gas"`
|
||||||
GasPrice string `json:"gasprice"`
|
GasPrice string `json:"gasprice"`
|
||||||
Init string `json:"init"`
|
Data string `json:"data"`
|
||||||
Body string `json:"body"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// type TxResponse struct {
|
// type TxResponse struct {
|
||||||
// Hash string
|
// Hash string
|
||||||
// }
|
// }
|
||||||
|
|
||||||
func (obj *NewTxArgs) UnmarshalJSON(b []byte) (err error) {
|
|
||||||
if err = json.Unmarshal(b, obj); err == nil {
|
|
||||||
return
|
|
||||||
}
|
|
||||||
return NewErrorResponse(ErrorDecodeArgs)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (a *NewTxArgs) requirements() error {
|
func (a *NewTxArgs) requirements() error {
|
||||||
if a.Recipient == "" {
|
|
||||||
return NewErrorResponse("Transact requires a 'recipient' address as argument")
|
|
||||||
}
|
|
||||||
if a.Value == "" {
|
|
||||||
return NewErrorResponse("Transact requires a 'value' as argument")
|
|
||||||
}
|
|
||||||
if a.Gas == "" {
|
if a.Gas == "" {
|
||||||
return NewErrorResponse("Transact requires a 'gas' value as argument")
|
return NewErrorResponse("Transact requires a 'gas' value as argument")
|
||||||
}
|
}
|
||||||
|
@ -66,22 +49,6 @@ func (a *NewTxArgs) requirements() error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (a *NewTxArgs) requirementsContract() error {
|
|
||||||
if a.Value == "" {
|
|
||||||
return NewErrorResponse("Create requires a 'value' as argument")
|
|
||||||
}
|
|
||||||
if a.Gas == "" {
|
|
||||||
return NewErrorResponse("Create requires a 'gas' value as argument")
|
|
||||||
}
|
|
||||||
if a.GasPrice == "" {
|
|
||||||
return NewErrorResponse("Create requires a 'gasprice' value as argument")
|
|
||||||
}
|
|
||||||
if a.Body == "" {
|
|
||||||
return NewErrorResponse("Create requires a 'body' value as argument")
|
|
||||||
}
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
type PushTxArgs struct {
|
type PushTxArgs struct {
|
||||||
Tx string `json:"tx"`
|
Tx string `json:"tx"`
|
||||||
}
|
}
|
||||||
|
|
|
@ -20,6 +20,7 @@ import (
|
||||||
"bytes"
|
"bytes"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
"errors"
|
||||||
|
"fmt"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
|
@ -56,6 +57,14 @@ type RpcRequest struct {
|
||||||
Params []json.RawMessage `json:"params"`
|
Params []json.RawMessage `json:"params"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func NewErrorResponse(msg string) error {
|
||||||
|
return errors.New(msg)
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewErrorResponseWithError(msg string, err error) error {
|
||||||
|
return fmt.Errorf("%s: %v", msg, err)
|
||||||
|
}
|
||||||
|
|
||||||
func (req *RpcRequest) ToSha3Args() (*Sha3Args, error) {
|
func (req *RpcRequest) ToSha3Args() (*Sha3Args, error) {
|
||||||
if len(req.Params) < 1 {
|
if len(req.Params) < 1 {
|
||||||
return nil, NewErrorResponse(ErrorArguments)
|
return nil, NewErrorResponse(ErrorArguments)
|
||||||
|
@ -86,7 +95,7 @@ func (req *RpcRequest) ToGetBlockArgs() (*GetBlockArgs, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func (req *RpcRequest) ToNewTxArgs() (*NewTxArgs, error) {
|
func (req *RpcRequest) ToNewTxArgs() (*NewTxArgs, error) {
|
||||||
if len(req.Params) < 7 {
|
if len(req.Params) < 1 {
|
||||||
return nil, NewErrorResponse(ErrorArguments)
|
return nil, NewErrorResponse(ErrorArguments)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -94,7 +103,7 @@ func (req *RpcRequest) ToNewTxArgs() (*NewTxArgs, error) {
|
||||||
r := bytes.NewReader(req.Params[0])
|
r := bytes.NewReader(req.Params[0])
|
||||||
err := json.NewDecoder(r).Decode(args)
|
err := json.NewDecoder(r).Decode(args)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, NewErrorResponse(ErrorDecodeArgs)
|
return nil, NewErrorResponseWithError(ErrorDecodeArgs, err)
|
||||||
}
|
}
|
||||||
rpclogger.DebugDetailf("%T %v", args, args)
|
rpclogger.DebugDetailf("%T %v", args, args)
|
||||||
return args, nil
|
return args, nil
|
||||||
|
@ -175,7 +184,3 @@ func (req *RpcRequest) ToGetCodeAtArgs() (*GetCodeAtArgs, error) {
|
||||||
rpclogger.DebugDetailf("%T %v", args, args)
|
rpclogger.DebugDetailf("%T %v", args, args)
|
||||||
return args, nil
|
return args, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewErrorResponse(msg string) error {
|
|
||||||
return errors.New(msg)
|
|
||||||
}
|
|
||||||
|
|
|
@ -67,7 +67,8 @@ func (p *EthereumApi) Transact(args *NewTxArgs, reply *interface{}) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
result, _ := p.xeth.Transact( /* TODO specify account */ args.Recipient, args.Value, args.Gas, args.GasPrice, args.Body)
|
result, _ := p.xeth.Transact( /* TODO specify account */ args.Recipient, args.Value, args.Gas, args.GasPrice, args.Data)
|
||||||
|
fmt.Println("result:", result)
|
||||||
*reply = result
|
*reply = result
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -78,7 +79,7 @@ func (p *EthereumApi) Create(args *NewTxArgs, reply *interface{}) error {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
result, _ := p.xeth.Transact( /* TODO specify account */ "", args.Value, args.Gas, args.GasPrice, args.Body)
|
result, _ := p.xeth.Transact( /* TODO specify account */ "", args.Value, args.Gas, args.GasPrice, args.Data)
|
||||||
*reply = result
|
*reply = result
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -210,6 +211,12 @@ func (p *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) error
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
return p.GetBlock(args, reply)
|
return p.GetBlock(args, reply)
|
||||||
|
case "eth_transact":
|
||||||
|
args, err := req.ToNewTxArgs()
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return p.Transact(args, reply)
|
||||||
case "web3_sha3":
|
case "web3_sha3":
|
||||||
args, err := req.ToSha3Args()
|
args, err := req.ToSha3Args()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
|
Loading…
Reference in New Issue