2019-11-23 18:57:05 +01:00
|
|
|
package gethbridge
|
|
|
|
|
|
|
|
import (
|
2020-01-13 20:17:30 +01:00
|
|
|
"errors"
|
|
|
|
|
2020-01-02 10:10:19 +01:00
|
|
|
"go.uber.org/zap"
|
|
|
|
|
2020-01-15 12:36:49 +01:00
|
|
|
"github.com/status-im/status-go/waku"
|
2021-06-16 16:19:45 -04:00
|
|
|
"github.com/status-im/status-go/wakuv2"
|
2020-01-15 12:36:49 +01:00
|
|
|
|
2019-11-23 18:57:05 +01:00
|
|
|
"github.com/ethereum/go-ethereum/node"
|
2019-12-12 17:06:00 +01:00
|
|
|
"github.com/ethereum/go-ethereum/p2p/enode"
|
2020-01-02 10:10:19 +01:00
|
|
|
|
2019-11-23 18:57:05 +01:00
|
|
|
gethens "github.com/status-im/status-go/eth-node/bridge/geth/ens"
|
|
|
|
"github.com/status-im/status-go/eth-node/types"
|
|
|
|
enstypes "github.com/status-im/status-go/eth-node/types/ens"
|
|
|
|
)
|
|
|
|
|
|
|
|
type gethNodeWrapper struct {
|
|
|
|
stack *node.Node
|
2021-06-30 13:40:54 +02:00
|
|
|
waku1 *waku.Waku
|
|
|
|
waku2 *wakuv2.Waku
|
2019-11-23 18:57:05 +01:00
|
|
|
}
|
|
|
|
|
2021-06-30 13:40:54 +02:00
|
|
|
func NewNodeBridge(stack *node.Node, waku1 *waku.Waku, waku2 *wakuv2.Waku) types.Node {
|
|
|
|
return &gethNodeWrapper{stack: stack, waku1: waku1, waku2: waku2}
|
2019-11-23 18:57:05 +01:00
|
|
|
}
|
|
|
|
|
2019-11-27 13:22:23 +01:00
|
|
|
func (w *gethNodeWrapper) Poll() {
|
|
|
|
// noop
|
|
|
|
}
|
|
|
|
|
2019-11-23 18:57:05 +01:00
|
|
|
func (w *gethNodeWrapper) NewENSVerifier(logger *zap.Logger) enstypes.ENSVerifier {
|
|
|
|
return gethens.NewVerifier(logger)
|
|
|
|
}
|
|
|
|
|
2021-06-30 13:40:54 +02:00
|
|
|
func (w *gethNodeWrapper) SetWaku1(waku *waku.Waku) {
|
|
|
|
w.waku1 = waku
|
|
|
|
}
|
|
|
|
|
|
|
|
func (w *gethNodeWrapper) SetWaku2(waku *wakuv2.Waku) {
|
|
|
|
w.waku2 = waku
|
|
|
|
}
|
|
|
|
|
2020-01-13 20:17:30 +01:00
|
|
|
func (w *gethNodeWrapper) GetWaku(ctx interface{}) (types.Waku, error) {
|
2021-06-30 13:40:54 +02:00
|
|
|
if w.waku1 == nil {
|
2020-01-13 20:17:30 +01:00
|
|
|
return nil, errors.New("waku service is not available")
|
|
|
|
}
|
|
|
|
|
2021-06-30 13:40:54 +02:00
|
|
|
return NewGethWakuWrapper(w.waku1), nil
|
2020-01-13 20:17:30 +01:00
|
|
|
}
|
|
|
|
|
2021-06-16 16:19:45 -04:00
|
|
|
func (w *gethNodeWrapper) GetWakuV2(ctx interface{}) (types.Waku, error) {
|
2021-06-30 13:40:54 +02:00
|
|
|
if w.waku2 == nil {
|
2021-06-16 16:19:45 -04:00
|
|
|
return nil, errors.New("waku service is not available")
|
|
|
|
}
|
|
|
|
|
2021-06-30 13:40:54 +02:00
|
|
|
return NewGethWakuV2Wrapper(w.waku2), nil
|
2021-06-16 16:19:45 -04:00
|
|
|
}
|
|
|
|
|
2019-12-12 17:06:00 +01:00
|
|
|
func (w *gethNodeWrapper) AddPeer(url string) error {
|
|
|
|
parsedNode, err := enode.ParseV4(url)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
w.stack.Server().AddPeer(parsedNode)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
|
|
|
|
func (w *gethNodeWrapper) RemovePeer(url string) error {
|
|
|
|
parsedNode, err := enode.ParseV4(url)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
w.stack.Server().RemovePeer(parsedNode)
|
|
|
|
|
|
|
|
return nil
|
|
|
|
}
|
2020-08-27 14:38:59 +02:00
|
|
|
|
|
|
|
func (w *gethNodeWrapper) PeersCount() int {
|
2020-11-02 16:50:05 +01:00
|
|
|
if w.stack.Server() == nil {
|
|
|
|
return 0
|
|
|
|
}
|
2020-08-27 14:38:59 +02:00
|
|
|
return len(w.stack.Server().Peers())
|
|
|
|
}
|