fix sleepBlocks, implement sleep

This commit is contained in:
zelig 2015-07-02 16:38:48 +01:00 committed by Jeffrey Wilcke
parent 6391ec0c8f
commit 518dc87db3
4 changed files with 45 additions and 19 deletions

View File

@ -129,7 +129,7 @@ func (self *Registrar) SetHashReg(hashreg string, addr common.Address) (err erro
return return
} }
HashRegAddr, err = self.backend.Transact(addr.Hex(), "", "", "", "200000", "", HashRegCode) HashRegAddr, err = self.backend.Transact(addr.Hex(), "", "", "", "", "", HashRegCode)
if err != nil { if err != nil {
err = fmt.Errorf("HashReg address not found and sender for creation failed: %v", err) err = fmt.Errorf("HashReg address not found and sender for creation failed: %v", err)
} }

View File

@ -43,7 +43,6 @@ var (
"admin_datadir": (*adminApi).DataDir, "admin_datadir": (*adminApi).DataDir,
"admin_startRPC": (*adminApi).StartRPC, "admin_startRPC": (*adminApi).StartRPC,
"admin_stopRPC": (*adminApi).StopRPC, "admin_stopRPC": (*adminApi).StopRPC,
"admin_sleepBlocks": (*adminApi).SleepBlocks,
"admin_setGlobalRegistrar": (*adminApi).SetGlobalRegistrar, "admin_setGlobalRegistrar": (*adminApi).SetGlobalRegistrar,
"admin_setHashReg": (*adminApi).SetHashReg, "admin_setHashReg": (*adminApi).SetHashReg,
"admin_setUrlHint": (*adminApi).SetUrlHint, "admin_setUrlHint": (*adminApi).SetUrlHint,
@ -54,6 +53,8 @@ var (
"admin_stopNatSpec": (*adminApi).StopNatSpec, "admin_stopNatSpec": (*adminApi).StopNatSpec,
"admin_getContractInfo": (*adminApi).GetContractInfo, "admin_getContractInfo": (*adminApi).GetContractInfo,
"admin_httpGet": (*adminApi).HttpGet, "admin_httpGet": (*adminApi).HttpGet,
"admin_sleepBlocks": (*adminApi).SleepBlocks,
"admin_sleep": (*adminApi).Sleep,
} }
) )
@ -303,14 +304,15 @@ func sleepBlocks(wait chan *big.Int, height *big.Int, timer <-chan time.Time) (n
return return
} }
// sec, err := call.Argument(0).ToInteger() func (self *adminApi) Sleep(req *shared.Request) (interface{}, error) {
// if err != nil { args := new(SleepArgs)
// fmt.Println(err) if err := self.coder.Decode(req.Params, &args); err != nil {
// return otto.FalseValue() return nil, shared.NewDecodeParamError(err.Error())
// } }
// time.Sleep(time.Duration(sec) * time.Second) time.Sleep(time.Duration(args.S) * time.Second)
// return otto.UndefinedValue() return nil, nil
// } }
func (self *adminApi) SetGlobalRegistrar(req *shared.Request) (interface{}, error) { func (self *adminApi) SetGlobalRegistrar(req *shared.Request) (interface{}, error) {
args := new(SetGlobalRegistrarArgs) args := new(SetGlobalRegistrarArgs)
if err := self.coder.Decode(req.Params, &args); err != nil { if err := self.coder.Decode(req.Params, &args); err != nil {

View File

@ -149,6 +149,30 @@ func (args *StartRPCArgs) UnmarshalJSON(b []byte) (err error) {
return nil return nil
} }
type SleepArgs struct {
S int
}
func (args *SleepArgs) UnmarshalJSON(b []byte) (err error) {
var obj []interface{}
if err := json.Unmarshal(b, &obj); err != nil {
return shared.NewDecodeParamError(err.Error())
}
if len(obj) >= 1 {
if obj[0] != nil {
if n, err := numString(obj[0]); err == nil {
args.S = int(n.Int64())
} else {
return shared.NewInvalidTypeError("N", "not an integer: "+err.Error())
}
} else {
return shared.NewInsufficientParamsError(0, 1)
}
}
return nil
}
type SleepBlocksArgs struct { type SleepBlocksArgs struct {
N int64 N int64
Timeout int64 Timeout int64
@ -163,19 +187,19 @@ func (args *SleepBlocksArgs) UnmarshalJSON(b []byte) (err error) {
args.N = 1 args.N = 1
args.Timeout = 0 args.Timeout = 0
if len(obj) >= 1 { if len(obj) >= 1 && obj[0] != nil {
if n, ok := obj[0].(int64); ok { if n, err := numString(obj[0]); err == nil {
args.N = n args.N = n.Int64()
} else { } else {
return shared.NewInvalidTypeError("N", "not an integer") return shared.NewInvalidTypeError("N", "not an integer: "+err.Error())
} }
} }
if len(obj) >= 2 { if len(obj) >= 2 && obj[1] != nil {
if n, ok := obj[1].(int64); ok { if n, err := numString(obj[1]); err == nil {
args.Timeout = n args.Timeout = n.Int64()
} else { } else {
return shared.NewInvalidTypeError("N", "not an integer") return shared.NewInvalidTypeError("Timeout", "not an integer: "+err.Error())
} }
} }

View File

@ -57,7 +57,7 @@ web3._extend({
new web3._extend.Method({ new web3._extend.Method({
name: 'stopRPC', name: 'stopRPC',
call: 'admin_stopRPC', call: 'admin_stopRPC',
params: 0, params: 2,
inputFormatter: [], inputFormatter: [],
outputFormatter: web3._extend.formatters.formatOutputBool outputFormatter: web3._extend.formatters.formatOutputBool
}), }),