go-waku/waku/v2/protocol/store/waku_store_common.go

73 lines
2.1 KiB
Go
Raw Normal View History

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"
"github.com/prometheus/client_golang/prometheus"
"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")
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
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
metrics Metrics
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
pm *peermanager.PeerManager
2022-11-25 16:54:11 -04:00
}
// NewWakuStore creates a WakuStore using an specific MessageProvider for storing the messages
// Takes an optional peermanager if WakuStore is being created along with WakuNode.
// If using libp2p host, then pass peermanager as nil
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
wakuStore.pm = pm
wakuStore.metrics = newMetrics(reg)
2022-11-25 16:54:11 -04:00
if pm != nil {
pm.RegisterWakuProtocol(StoreID_v20beta4, StoreENRField)
}
2022-11-25 16:54:11 -04:00
return wakuStore
}