Moved Filter's wrapping functions to their own util package. Fixes #61
* CLI ethereum should no longer require the Qt/QML package
This commit is contained in:
parent
70a00d602e
commit
d2bb83833f
@ -6,12 +6,10 @@ import (
|
|||||||
"math"
|
"math"
|
||||||
|
|
||||||
"github.com/ethereum/eth-go/ethstate"
|
"github.com/ethereum/eth-go/ethstate"
|
||||||
"github.com/ethereum/eth-go/ethutil"
|
|
||||||
"gopkg.in/qml.v1"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type data struct {
|
type AccountChange struct {
|
||||||
id, address []byte
|
Address, StateAddress []byte
|
||||||
}
|
}
|
||||||
|
|
||||||
// Filtering interface
|
// Filtering interface
|
||||||
@ -23,7 +21,7 @@ type Filter struct {
|
|||||||
from, to [][]byte
|
from, to [][]byte
|
||||||
max int
|
max int
|
||||||
|
|
||||||
altered []data
|
Altered []AccountChange
|
||||||
|
|
||||||
BlockCallback func(*Block)
|
BlockCallback func(*Block)
|
||||||
MessageCallback func(ethstate.Messages)
|
MessageCallback func(ethstate.Messages)
|
||||||
@ -35,48 +33,8 @@ func NewFilter(eth EthManager) *Filter {
|
|||||||
return &Filter{eth: eth}
|
return &Filter{eth: eth}
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewFilterFromMap(object map[string]interface{}, eth EthManager) *Filter {
|
func (self *Filter) AddAltered(address, stateAddress []byte) {
|
||||||
filter := NewFilter(eth)
|
self.Altered = append(self.Altered, AccountChange{address, stateAddress})
|
||||||
|
|
||||||
if object["earliest"] != nil {
|
|
||||||
val := ethutil.NewValue(object["earliest"])
|
|
||||||
filter.SetEarliestBlock(val.Int())
|
|
||||||
}
|
|
||||||
|
|
||||||
if object["latest"] != nil {
|
|
||||||
val := ethutil.NewValue(object["latest"])
|
|
||||||
filter.SetLatestBlock(val.Int())
|
|
||||||
}
|
|
||||||
|
|
||||||
if object["to"] != nil {
|
|
||||||
val := ethutil.NewValue(object["to"])
|
|
||||||
filter.AddTo(ethutil.Hex2Bytes(val.Str()))
|
|
||||||
}
|
|
||||||
|
|
||||||
if object["from"] != nil {
|
|
||||||
val := ethutil.NewValue(object["from"])
|
|
||||||
filter.AddFrom(ethutil.Hex2Bytes(val.Str()))
|
|
||||||
}
|
|
||||||
|
|
||||||
if object["max"] != nil {
|
|
||||||
val := ethutil.NewValue(object["max"])
|
|
||||||
filter.SetMax(int(val.Uint()))
|
|
||||||
}
|
|
||||||
|
|
||||||
if object["skip"] != nil {
|
|
||||||
val := ethutil.NewValue(object["skip"])
|
|
||||||
filter.SetSkip(int(val.Uint()))
|
|
||||||
}
|
|
||||||
|
|
||||||
if object["altered"] != nil {
|
|
||||||
filter.altered = makeAltered(object["altered"])
|
|
||||||
}
|
|
||||||
|
|
||||||
return filter
|
|
||||||
}
|
|
||||||
|
|
||||||
func (self *Filter) AddAltered(id, address []byte) {
|
|
||||||
self.altered = append(self.altered, data{id, address})
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set the earliest and latest block for filtering.
|
// Set the earliest and latest block for filtering.
|
||||||
@ -185,16 +143,16 @@ func (self *Filter) FilterMessages(msgs []*ethstate.Message) []*ethstate.Message
|
|||||||
}
|
}
|
||||||
|
|
||||||
var match bool
|
var match bool
|
||||||
if len(self.altered) == 0 {
|
if len(self.Altered) == 0 {
|
||||||
match = true
|
match = true
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, item := range self.altered {
|
for _, accountChange := range self.Altered {
|
||||||
if len(item.id) > 0 && bytes.Compare(message.To, item.id) != 0 {
|
if len(accountChange.Address) > 0 && bytes.Compare(message.To, accountChange.Address) != 0 {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
if len(item.address) > 0 && !includes(message.ChangedAddresses, item.address) {
|
if len(accountChange.StateAddress) > 0 && !includes(message.ChangedAddresses, accountChange.StateAddress) {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -246,47 +204,3 @@ func (self *Filter) bloomFilter(block *Block) bool {
|
|||||||
|
|
||||||
return fromIncluded && toIncluded
|
return fromIncluded && toIncluded
|
||||||
}
|
}
|
||||||
|
|
||||||
// Conversion methodn
|
|
||||||
func mapToData(m map[string]interface{}) (d data) {
|
|
||||||
if str, ok := m["id"].(string); ok {
|
|
||||||
d.id = ethutil.Hex2Bytes(str)
|
|
||||||
}
|
|
||||||
|
|
||||||
if str, ok := m["at"].(string); ok {
|
|
||||||
d.address = ethutil.Hex2Bytes(str)
|
|
||||||
}
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
|
||||||
// data can come in in the following formats:
|
|
||||||
// ["aabbccdd", {id: "ccddee", at: "11223344"}], "aabbcc", {id: "ccddee", at: "1122"}
|
|
||||||
func makeAltered(v interface{}) (d []data) {
|
|
||||||
if str, ok := v.(string); ok {
|
|
||||||
d = append(d, data{ethutil.Hex2Bytes(str), nil})
|
|
||||||
} else if obj, ok := v.(map[string]interface{}); ok {
|
|
||||||
d = append(d, mapToData(obj))
|
|
||||||
} else if slice, ok := v.([]interface{}); ok {
|
|
||||||
for _, item := range slice {
|
|
||||||
d = append(d, makeAltered(item)...)
|
|
||||||
}
|
|
||||||
} else if qList, ok := v.(*qml.List); ok {
|
|
||||||
var s []interface{}
|
|
||||||
qList.Convert(&s)
|
|
||||||
|
|
||||||
fmt.Println(s)
|
|
||||||
|
|
||||||
d = makeAltered(s)
|
|
||||||
} else if qMap, ok := v.(*qml.Map); ok {
|
|
||||||
var m map[string]interface{}
|
|
||||||
qMap.Convert(&m)
|
|
||||||
fmt.Println(m)
|
|
||||||
|
|
||||||
d = makeAltered(m)
|
|
||||||
} else {
|
|
||||||
panic(fmt.Sprintf("makeAltered err (unknown conversion): %T\n", v))
|
|
||||||
}
|
|
||||||
|
|
||||||
return
|
|
||||||
}
|
|
||||||
|
75
ui/filter.go
Normal file
75
ui/filter.go
Normal file
@ -0,0 +1,75 @@
|
|||||||
|
package ui
|
||||||
|
|
||||||
|
import (
|
||||||
|
"github.com/ethereum/eth-go/ethchain"
|
||||||
|
"github.com/ethereum/eth-go/ethutil"
|
||||||
|
)
|
||||||
|
|
||||||
|
func NewFilterFromMap(object map[string]interface{}, eth ethchain.EthManager) *ethchain.Filter {
|
||||||
|
filter := ethchain.NewFilter(eth)
|
||||||
|
|
||||||
|
if object["earliest"] != nil {
|
||||||
|
val := ethutil.NewValue(object["earliest"])
|
||||||
|
filter.SetEarliestBlock(val.Int())
|
||||||
|
}
|
||||||
|
|
||||||
|
if object["latest"] != nil {
|
||||||
|
val := ethutil.NewValue(object["latest"])
|
||||||
|
filter.SetLatestBlock(val.Int())
|
||||||
|
}
|
||||||
|
|
||||||
|
if object["to"] != nil {
|
||||||
|
val := ethutil.NewValue(object["to"])
|
||||||
|
filter.AddTo(ethutil.Hex2Bytes(val.Str()))
|
||||||
|
}
|
||||||
|
|
||||||
|
if object["from"] != nil {
|
||||||
|
val := ethutil.NewValue(object["from"])
|
||||||
|
filter.AddFrom(ethutil.Hex2Bytes(val.Str()))
|
||||||
|
}
|
||||||
|
|
||||||
|
if object["max"] != nil {
|
||||||
|
val := ethutil.NewValue(object["max"])
|
||||||
|
filter.SetMax(int(val.Uint()))
|
||||||
|
}
|
||||||
|
|
||||||
|
if object["skip"] != nil {
|
||||||
|
val := ethutil.NewValue(object["skip"])
|
||||||
|
filter.SetSkip(int(val.Uint()))
|
||||||
|
}
|
||||||
|
|
||||||
|
if object["altered"] != nil {
|
||||||
|
filter.Altered = makeAltered(object["altered"])
|
||||||
|
}
|
||||||
|
|
||||||
|
return filter
|
||||||
|
}
|
||||||
|
|
||||||
|
// Conversion methodn
|
||||||
|
func mapToAccountChange(m map[string]interface{}) (d ethchain.AccountChange) {
|
||||||
|
if str, ok := m["id"].(string); ok {
|
||||||
|
d.Address = ethutil.Hex2Bytes(str)
|
||||||
|
}
|
||||||
|
|
||||||
|
if str, ok := m["at"].(string); ok {
|
||||||
|
d.StateAddress = ethutil.Hex2Bytes(str)
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// data can come in in the following formats:
|
||||||
|
// ["aabbccdd", {id: "ccddee", at: "11223344"}], "aabbcc", {id: "ccddee", at: "1122"}
|
||||||
|
func makeAltered(v interface{}) (d []ethchain.AccountChange) {
|
||||||
|
if str, ok := v.(string); ok {
|
||||||
|
d = append(d, ethchain.AccountChange{ethutil.Hex2Bytes(str), nil})
|
||||||
|
} else if obj, ok := v.(map[string]interface{}); ok {
|
||||||
|
d = append(d, mapToAccountChange(obj))
|
||||||
|
} else if slice, ok := v.([]interface{}); ok {
|
||||||
|
for _, item := range slice {
|
||||||
|
d = append(d, makeAltered(item)...)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
38
ui/qt/filter.go
Normal file
38
ui/qt/filter.go
Normal file
@ -0,0 +1,38 @@
|
|||||||
|
package qt
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
|
||||||
|
"github.com/ethereum/eth-go/ethchain"
|
||||||
|
"github.com/ethereum/eth-go/ui"
|
||||||
|
"gopkg.in/qml.v1"
|
||||||
|
)
|
||||||
|
|
||||||
|
func NewFilterFromMap(object map[string]interface{}, eth ethchain.EthManager) *ethchain.Filter {
|
||||||
|
filter := ui.NewFilterFromMap(object, eth)
|
||||||
|
|
||||||
|
if object["altered"] != nil {
|
||||||
|
filter.Altered = makeAltered(object["altered"])
|
||||||
|
}
|
||||||
|
|
||||||
|
return filter
|
||||||
|
}
|
||||||
|
|
||||||
|
func makeAltered(v interface{}) (d []ethchain.AccountChange) {
|
||||||
|
if qList, ok := v.(*qml.List); ok {
|
||||||
|
var s []interface{}
|
||||||
|
qList.Convert(&s)
|
||||||
|
|
||||||
|
fmt.Println(s)
|
||||||
|
|
||||||
|
d = makeAltered(s)
|
||||||
|
} else if qMap, ok := v.(*qml.Map); ok {
|
||||||
|
var m map[string]interface{}
|
||||||
|
qMap.Convert(&m)
|
||||||
|
fmt.Println(m)
|
||||||
|
|
||||||
|
d = makeAltered(m)
|
||||||
|
}
|
||||||
|
|
||||||
|
return
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user