diff options
author | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-05-08 17:56:55 +0800 |
---|---|---|
committer | Jeffrey Wilcke <jeffrey@ethereum.org> | 2015-05-08 17:56:55 +0800 |
commit | 637b2415d969a97b3d119be2aceb9411458d00d9 (patch) | |
tree | 3d61d0853f51bdca06881033b45ec22a9ddbe630 /rpc | |
parent | 69aac4d5316ca8ec3429de534349a8dbdb0b59a5 (diff) | |
parent | 60b5a94428abf57dc921347684508db44f0f1a04 (diff) | |
download | go-tangerine-637b2415d969a97b3d119be2aceb9411458d00d9.tar go-tangerine-637b2415d969a97b3d119be2aceb9411458d00d9.tar.gz go-tangerine-637b2415d969a97b3d119be2aceb9411458d00d9.tar.bz2 go-tangerine-637b2415d969a97b3d119be2aceb9411458d00d9.tar.lz go-tangerine-637b2415d969a97b3d119be2aceb9411458d00d9.tar.xz go-tangerine-637b2415d969a97b3d119be2aceb9411458d00d9.tar.zst go-tangerine-637b2415d969a97b3d119be2aceb9411458d00d9.zip |
Merge pull request #864 from obscuren/filter_changes
xeth, core, event/filter, rpc: new block and transaction filters
Diffstat (limited to 'rpc')
-rw-r--r-- | rpc/api.go | 23 | ||||
-rw-r--r-- | rpc/responses.go | 11 |
2 files changed, 27 insertions, 7 deletions
diff --git a/rpc/api.go b/rpc/api.go index b79a1306e..f75ae42c4 100644 --- a/rpc/api.go +++ b/rpc/api.go @@ -322,14 +322,13 @@ func (api *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) err return err } - id := api.xeth().RegisterFilter(args.Earliest, args.Latest, args.Skip, args.Max, args.Address, args.Topics) + id := api.xeth().NewLogFilter(args.Earliest, args.Latest, args.Skip, args.Max, args.Address, args.Topics) *reply = newHexNum(big.NewInt(int64(id)).Bytes()) + case "eth_newBlockFilter": - args := new(FilterStringArgs) - if err := json.Unmarshal(req.Params, &args); err != nil { - return err - } - *reply = newHexNum(api.xeth().NewFilterString(args.Word)) + *reply = newHexNum(api.xeth().NewBlockFilter()) + case "eth_newPendingTransactionFilter": + *reply = newHexNum(api.xeth().NewTransactionFilter()) case "eth_uninstallFilter": args := new(FilterIdArgs) if err := json.Unmarshal(req.Params, &args); err != nil { @@ -341,7 +340,17 @@ func (api *EthereumApi) GetRequestReply(req *RpcRequest, reply *interface{}) err if err := json.Unmarshal(req.Params, &args); err != nil { return err } - *reply = NewLogsRes(api.xeth().FilterChanged(args.Id)) + + switch api.xeth().GetFilterType(args.Id) { + case xeth.BlockFilterTy: + *reply = NewHashesRes(api.xeth().BlockFilterChanged(args.Id)) + case xeth.TransactionFilterTy: + *reply = NewHashesRes(api.xeth().TransactionFilterChanged(args.Id)) + case xeth.LogFilterTy: + *reply = NewLogsRes(api.xeth().LogFilterChanged(args.Id)) + default: + *reply = []string{} // reply empty string slice + } case "eth_getFilterLogs": args := new(FilterIdArgs) if err := json.Unmarshal(req.Params, &args); err != nil { diff --git a/rpc/responses.go b/rpc/responses.go index 884b7e69b..9fdf60c02 100644 --- a/rpc/responses.go +++ b/rpc/responses.go @@ -3,6 +3,7 @@ package rpc import ( "encoding/json" + "github.com/ethereum/go-ethereum/common" "github.com/ethereum/go-ethereum/core/state" "github.com/ethereum/go-ethereum/core/types" ) @@ -303,3 +304,13 @@ func NewLogsRes(logs state.Logs) (ls []LogRes) { return } + +func NewHashesRes(hs []common.Hash) []string { + hashes := make([]string, len(hs)) + + for i, hash := range hs { + hashes[i] = hash.Hex() + } + + return hashes +} |