This repository has been archived by the owner on May 13, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 346
/
registry.go
134 lines (112 loc) · 2.72 KB
/
registry.go
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
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
// Copyright Monax Industries Limited
// SPDX-License-Identifier: Apache-2.0
package registry
import (
"fmt"
"net"
"github.com/hyperledger/burrow/crypto"
)
type NodeStats struct {
Addresses map[string]map[crypto.Address]struct{}
}
func NewNodeStats() NodeStats {
return NodeStats{
Addresses: make(map[string]map[crypto.Address]struct{}),
}
}
func (ns *NodeStats) GetAddresses(net string) []crypto.Address {
nodes := ns.Addresses[net]
addrs := make([]crypto.Address, 0, len(nodes))
for id := range nodes {
addrs = append(addrs, id)
}
return addrs
}
func (ns *NodeStats) Insert(net string, id crypto.Address) {
_, ok := ns.Addresses[net]
if !ok {
ns.Addresses[net] = make(map[crypto.Address]struct{})
}
ns.Addresses[net][id] = struct{}{}
}
func (ns *NodeStats) Remove(node *NodeIdentity) bool {
_, ok := ns.Addresses[node.GetNetworkAddress()]
if !ok {
return false
}
_, ok = ns.Addresses[node.GetNetworkAddress()][node.TendermintNodeID]
if ok {
delete(ns.Addresses[node.GetNetworkAddress()], node.TendermintNodeID)
return true
}
return false
}
type NodeFilter struct {
state IterableReader
}
func NewNodeFilter(state IterableReader) *NodeFilter {
return &NodeFilter{
state: state,
}
}
func (nf *NodeFilter) QueryPeerByID(id string) bool {
addr, err := crypto.AddressFromHexString(id)
if err != nil {
return false
}
node, err := nf.state.GetNodeByID(addr)
if err != nil || node == nil {
return false
}
return true
}
func (nf *NodeFilter) findByAddress(addr string) bool {
nodes, err := nf.state.GetNodeIDsByAddress(addr)
if err != nil {
panic(err)
} else if len(nodes) == 0 {
return false
}
return true
}
func (nf *NodeFilter) QueryPeerByAddress(addr string) bool {
// may have different outbound port in address, so fallback to host
ok := nf.findByAddress(addr)
if ok {
return ok
}
host, _, _ := net.SplitHostPort(addr)
return nf.findByAddress(host)
}
func (nf *NodeFilter) NumPeers() int {
return nf.state.GetNumPeers()
}
func (rn *NodeIdentity) String() string {
return fmt.Sprintf("RegisterNode{%v -> %v @ %v}", rn.ValidatorPublicKey, rn.TendermintNodeID, rn.NetworkAddress)
}
type Reader interface {
GetNodeByID(crypto.Address) (*NodeIdentity, error)
GetNodeIDsByAddress(net string) ([]crypto.Address, error)
GetNumPeers() int
}
type Writer interface {
// Updates the node, creating it if it does not exist
UpdateNode(crypto.Address, *NodeIdentity) error
// Remove the node by address
RemoveNode(crypto.Address) error
}
type ReaderWriter interface {
Reader
Writer
}
type Iterable interface {
IterateNodes(consumer func(crypto.Address, *NodeIdentity) error) (err error)
}
type IterableReader interface {
Iterable
Reader
}
type IterableReaderWriter interface {
Iterable
ReaderWriter
}