aboutsummaryrefslogtreecommitdiffstats
path: root/ui/filter.go
blob: da2ea0edbd1c68e9f3561ea9689ada4c19030f2a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
package ui

import (
    "github.com/ethereum/go-ethereum/core"
    "github.com/ethereum/go-ethereum/ethutil"
)

func fromHex(s string) []byte {
    if len(s) > 1 {
        if s[0:2] == "0x" {
            s = s[2:]
        }
        return ethutil.Hex2Bytes(s)
    }
    return nil
}

func NewFilterFromMap(object map[string]interface{}, eth core.Backend) *core.Filter {
    filter := core.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["address"] != nil {
        val := ethutil.NewValue(object["address"])
        filter.SetAddress(fromHex(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["topics"] != nil {
        filter.SetTopics(MakeTopics(object["topics"]))
    }

    return filter
}

// Conversion methodn
func mapToAccountChange(m map[string]interface{}) (d core.AccountChange) {
    if str, ok := m["id"].(string); ok {
        d.Address = fromHex(str)
    }

    if str, ok := m["at"].(string); ok {
        d.StateAddress = fromHex(str)
    }

    return
}

// data can come in in the following formats:
// ["aabbccdd", {id: "ccddee", at: "11223344"}], "aabbcc", {id: "ccddee", at: "1122"}
func MakeTopics(v interface{}) (d [][]byte) {
    if str, ok := v.(string); ok {
        d = append(d, fromHex(str))
    } else if slice, ok := v.([]string); ok {
        for _, item := range slice {
            d = append(d, fromHex(item))
        }
    }
    return
}