2018-12-12 11:39:00 +02:00
|
|
|
package mailservers
|
|
|
|
|
|
|
|
import (
|
|
|
|
"sort"
|
|
|
|
|
|
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
2020-01-02 10:10:19 +01:00
|
|
|
|
2019-11-23 18:57:05 +01:00
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
2018-12-12 11:39:00 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
// GetFirstConnected returns first connected peer that is also added to a peer store.
|
|
|
|
// Raises ErrNoConnected if no peers are added to a peer store.
|
|
|
|
func GetFirstConnected(provider PeersProvider, store *PeerStore) (*enode.Node, error) {
|
|
|
|
peers := provider.Peers()
|
|
|
|
for _, p := range peers {
|
2019-11-23 18:57:05 +01:00
|
|
|
if store.Exist(types.EnodeID(p.ID())) {
|
2018-12-12 11:39:00 +02:00
|
|
|
return p.Node(), nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return nil, ErrNoConnected
|
|
|
|
}
|
|
|
|
|
|
|
|
// NodesNotifee interface to be notified when new nodes are received.
|
|
|
|
type NodesNotifee interface {
|
|
|
|
Notify([]*enode.Node)
|
|
|
|
}
|
|
|
|
|
|
|
|
// EnsureUsedRecordsAddedFirst checks if any nodes were marked as connected before app went offline.
|
|
|
|
func EnsureUsedRecordsAddedFirst(ps *PeerStore, conn NodesNotifee) error {
|
|
|
|
records, err := ps.cache.LoadAll()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if len(records) == 0 {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
sort.Slice(records, func(i, j int) bool {
|
|
|
|
return records[i].LastUsed.After(records[j].LastUsed)
|
|
|
|
})
|
|
|
|
all := recordsToNodes(records)
|
|
|
|
if !records[0].LastUsed.IsZero() {
|
|
|
|
conn.Notify(all[:1])
|
|
|
|
}
|
|
|
|
conn.Notify(all)
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func recordsToNodes(records []PeerRecord) []*enode.Node {
|
|
|
|
nodes := make([]*enode.Node, len(records))
|
|
|
|
for i := range records {
|
|
|
|
nodes[i] = records[i].Node()
|
|
|
|
}
|
|
|
|
return nodes
|
|
|
|
}
|