mirror of
https://github.com/status-im/status-go.git
synced 2025-01-25 05:58:59 +00:00
a1b3e3a772
There was a bug on status-react where it would save filters that were not listened to. This commit adds a task to clean up those filters as they might result in long syncing times. This commit also returns topics/ranges/mailserves from messenger in order to make the initialization of the app simpler and start moving logic to status-go. It also removes whisper from vendor.
103 lines
2.1 KiB
Go
103 lines
2.1 KiB
Go
package bridge
|
|
|
|
import (
|
|
"sync"
|
|
"unsafe"
|
|
|
|
"go.uber.org/zap"
|
|
|
|
"github.com/status-im/status-go/waku"
|
|
wakucommon "github.com/status-im/status-go/waku/common"
|
|
"github.com/status-im/status-go/whisper"
|
|
)
|
|
|
|
type Bridge struct {
|
|
whisper *whisper.Whisper
|
|
waku *waku.Waku
|
|
logger *zap.Logger
|
|
|
|
cancel chan struct{}
|
|
wg sync.WaitGroup
|
|
|
|
whisperIn chan *whisper.Envelope
|
|
whisperOut chan *whisper.Envelope
|
|
wakuIn chan *wakucommon.Envelope
|
|
wakuOut chan *wakucommon.Envelope
|
|
}
|
|
|
|
func New(shh *whisper.Whisper, w *waku.Waku, logger *zap.Logger) *Bridge {
|
|
return &Bridge{
|
|
whisper: shh,
|
|
waku: w,
|
|
logger: logger,
|
|
whisperOut: make(chan *whisper.Envelope),
|
|
whisperIn: make(chan *whisper.Envelope),
|
|
wakuIn: make(chan *wakucommon.Envelope),
|
|
wakuOut: make(chan *wakucommon.Envelope),
|
|
}
|
|
}
|
|
|
|
type bridgeWhisper struct {
|
|
*Bridge
|
|
}
|
|
|
|
func (b *bridgeWhisper) Pipe() (<-chan *whisper.Envelope, chan<- *whisper.Envelope) {
|
|
return b.whisperOut, b.whisperIn
|
|
}
|
|
|
|
type bridgeWaku struct {
|
|
*Bridge
|
|
}
|
|
|
|
func (b *bridgeWaku) Pipe() (<-chan *wakucommon.Envelope, chan<- *wakucommon.Envelope) {
|
|
return b.wakuOut, b.wakuIn
|
|
}
|
|
|
|
func (b *Bridge) Start() {
|
|
b.cancel = make(chan struct{})
|
|
|
|
b.waku.RegisterBridge(&bridgeWaku{Bridge: b})
|
|
b.whisper.RegisterBridge(&bridgeWhisper{Bridge: b})
|
|
|
|
b.wg.Add(1)
|
|
go func() {
|
|
defer b.wg.Done()
|
|
for {
|
|
select {
|
|
case <-b.cancel:
|
|
return
|
|
case env := <-b.wakuIn:
|
|
shhEnvelope := (*whisper.Envelope)(unsafe.Pointer(env)) // nolint: gosec
|
|
b.logger.Debug(
|
|
"received whisper envelope from waku",
|
|
zap.ByteString("hash", shhEnvelope.Hash().Bytes()),
|
|
)
|
|
b.whisperOut <- shhEnvelope
|
|
}
|
|
}
|
|
}()
|
|
|
|
b.wg.Add(1)
|
|
go func() {
|
|
defer b.wg.Done()
|
|
for {
|
|
select {
|
|
case <-b.cancel:
|
|
return
|
|
case env := <-b.whisperIn:
|
|
wakuEnvelope := (*wakucommon.Envelope)(unsafe.Pointer(env)) // nolint: gosec
|
|
b.logger.Debug(
|
|
"received waku envelope from whisper",
|
|
zap.ByteString("hash", wakuEnvelope.Hash().Bytes()),
|
|
)
|
|
b.wakuOut <- wakuEnvelope
|
|
}
|
|
}
|
|
}()
|
|
}
|
|
|
|
func (b *Bridge) Cancel() {
|
|
close(b.cancel)
|
|
b.wg.Wait()
|
|
}
|