2022-11-25 16:54:11 -04:00
|
|
|
package store
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"errors"
|
|
|
|
"sync"
|
|
|
|
|
|
|
|
"github.com/libp2p/go-libp2p/core/host"
|
|
|
|
libp2pProtocol "github.com/libp2p/go-libp2p/core/protocol"
|
2023-08-15 21:40:00 -04:00
|
|
|
"github.com/prometheus/client_golang/prometheus"
|
2023-08-10 18:28:22 +05:30
|
|
|
"github.com/waku-org/go-waku/waku/v2/peermanager"
|
2023-05-05 15:19:15 +05:30
|
|
|
"github.com/waku-org/go-waku/waku/v2/protocol/relay"
|
2022-12-08 23:08:04 -04:00
|
|
|
"github.com/waku-org/go-waku/waku/v2/timesource"
|
2022-11-25 16:54:11 -04:00
|
|
|
"go.uber.org/zap"
|
|
|
|
)
|
|
|
|
|
|
|
|
// StoreID_v20beta4 is the current Waku Store protocol identifier
|
|
|
|
const StoreID_v20beta4 = libp2pProtocol.ID("/vac/waku/store/2.0.0-beta4")
|
2023-11-07 22:43:19 +05:30
|
|
|
const StoreENRField = uint8(1 << 1)
|
2022-11-25 16:54:11 -04:00
|
|
|
|
|
|
|
// MaxPageSize is the maximum number of waku messages to return per page
|
2023-10-12 08:42:53 -04:00
|
|
|
const MaxPageSize = 20
|
2022-11-25 16:54:11 -04:00
|
|
|
|
|
|
|
var (
|
|
|
|
|
|
|
|
// ErrNoPeersAvailable is returned when there are no store peers in the peer store
|
|
|
|
// that could be used to retrieve message history
|
|
|
|
ErrNoPeersAvailable = errors.New("no suitable remote peers")
|
|
|
|
|
|
|
|
// ErrFailedToResumeHistory is returned when the node attempted to retrieve historic
|
|
|
|
// messages to fill its own message history but for some reason it failed
|
|
|
|
ErrFailedToResumeHistory = errors.New("failed to resume the history")
|
|
|
|
)
|
|
|
|
|
2023-01-06 18:37:57 -04:00
|
|
|
type WakuSwap interface {
|
|
|
|
// TODO: add functions
|
|
|
|
}
|
|
|
|
|
2022-11-25 16:54:11 -04:00
|
|
|
type WakuStore struct {
|
2022-12-08 23:08:04 -04:00
|
|
|
ctx context.Context
|
2023-03-09 11:48:25 -04:00
|
|
|
cancel context.CancelFunc
|
2022-12-08 23:08:04 -04:00
|
|
|
timesource timesource.Timesource
|
2023-08-15 21:40:00 -04:00
|
|
|
metrics Metrics
|
2023-10-21 01:26:18 +05:30
|
|
|
MsgC *relay.Subscription
|
2022-12-08 23:08:04 -04:00
|
|
|
wg *sync.WaitGroup
|
2022-11-25 16:54:11 -04:00
|
|
|
|
|
|
|
log *zap.Logger
|
|
|
|
|
|
|
|
started bool
|
|
|
|
|
|
|
|
msgProvider MessageProvider
|
|
|
|
h host.Host
|
2023-08-10 18:28:22 +05:30
|
|
|
pm *peermanager.PeerManager
|
2022-11-25 16:54:11 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
// NewWakuStore creates a WakuStore using an specific MessageProvider for storing the messages
|
2023-08-10 18:28:22 +05:30
|
|
|
// Takes an optional peermanager if WakuStore is being created along with WakuNode.
|
|
|
|
// If using libp2p host, then pass peermanager as nil
|
2023-08-15 21:40:00 -04:00
|
|
|
func NewWakuStore(p MessageProvider, pm *peermanager.PeerManager, timesource timesource.Timesource, reg prometheus.Registerer, log *zap.Logger) *WakuStore {
|
2022-11-25 16:54:11 -04:00
|
|
|
wakuStore := new(WakuStore)
|
|
|
|
wakuStore.msgProvider = p
|
|
|
|
wakuStore.wg = &sync.WaitGroup{}
|
|
|
|
wakuStore.log = log.Named("store")
|
2022-12-08 23:08:04 -04:00
|
|
|
wakuStore.timesource = timesource
|
2023-08-10 18:28:22 +05:30
|
|
|
wakuStore.pm = pm
|
2023-08-15 21:40:00 -04:00
|
|
|
wakuStore.metrics = newMetrics(reg)
|
2022-11-25 16:54:11 -04:00
|
|
|
|
2023-11-07 22:43:19 +05:30
|
|
|
if pm != nil {
|
|
|
|
pm.RegisterWakuProtocol(StoreID_v20beta4, StoreENRField)
|
|
|
|
}
|
2022-11-25 16:54:11 -04:00
|
|
|
return wakuStore
|
|
|
|
}
|