forked from cerc-io/plugeth
fix sleepBlocks, implement sleep
This commit is contained in:
parent
6391ec0c8f
commit
518dc87db3
@ -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)
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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())
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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
|
||||||
}),
|
}),
|
||||||
|
Loading…
Reference in New Issue
Block a user