Skip to content
This repository has been archived by the owner on Aug 19, 2022. It is now read-only.

Commit

Permalink
Merge pull request #188 from libp2p/remove-manager
Browse files Browse the repository at this point in the history
remove the pstoremanager (will be moved to the Host)
  • Loading branch information
marten-seemann authored Dec 10, 2021
2 parents c1674ed + 048b941 commit 3efa6e1
Show file tree
Hide file tree
Showing 8 changed files with 15 additions and 857 deletions.
3 changes: 1 addition & 2 deletions go.mod
Original file line number Diff line number Diff line change
Expand Up @@ -6,18 +6,17 @@ retract v0.2.9 // Contains backwards-incompatible changes. Use v0.3.0 instead.

require (
github.com/gogo/protobuf v1.3.2
github.com/golang/mock v1.6.0
github.com/hashicorp/golang-lru v0.5.4
github.com/ipfs/go-datastore v0.5.0
github.com/ipfs/go-ds-badger v0.3.0
github.com/ipfs/go-ds-leveldb v0.5.0
github.com/ipfs/go-log/v2 v2.3.0
github.com/libp2p/go-buffer-pool v0.0.2
github.com/libp2p/go-eventbus v0.2.1
github.com/libp2p/go-libp2p-core v0.12.0
github.com/multiformats/go-base32 v0.0.3
github.com/multiformats/go-multiaddr v0.3.3
github.com/multiformats/go-multiaddr-fmt v0.1.0
github.com/stretchr/testify v1.7.0
go.uber.org/goleak v1.1.10
golang.org/x/tools v0.1.1 // indirect
)
83 changes: 0 additions & 83 deletions go.sum

Large diffs are not rendered by default.

38 changes: 3 additions & 35 deletions pstoreds/peerstore.go
Original file line number Diff line number Diff line change
Expand Up @@ -6,10 +6,6 @@ import (
"io"
"time"

"github.com/libp2p/go-libp2p-core/event"

"github.com/libp2p/go-libp2p-peerstore/pstoremanager"

"github.com/libp2p/go-libp2p-core/peer"
"github.com/libp2p/go-libp2p-core/peerstore"
pstore "github.com/libp2p/go-libp2p-peerstore"
Expand All @@ -27,13 +23,6 @@ type Options struct {
// MaxProtocols is the maximum number of protocols we store for one peer.
MaxProtocols int

// The EventBus that is used to subscribe to EvtPeerConnectednessChanged events.
// This allows the automatic clean up when a peer disconnect.
// This configuration option is optional. If no EventBus is set, it's the callers
// responsibility to call RemovePeer to ensure that memory consumption of the
// peerstore doesn't grow unboundedly.
EventBus event.Bus

// Sweep interval to purge expired addresses from the datastore. If this is a zero value, GC will not run
// automatically, but it'll be available on demand via explicit calls.
GCPurgeInterval time.Duration
Expand Down Expand Up @@ -71,17 +60,12 @@ type pstoreds struct {
*dsAddrBook
*dsProtoBook
*dsPeerMetadata

manager *pstoremanager.PeerstoreManager
}

var _ peerstore.Peerstore = &pstoreds{}

// NewPeerstore creates a peerstore backed by the provided persistent datastore.
// It is recommended to construct the peerstore with an event bus, using the WithEventBus option.
// In that case, the peerstore will automatically perform cleanups when a peer disconnects
// (see the pstoremanager package for details).
// If constructed without an event bus, it's the caller's responsibility to call RemovePeer to ensure
// It's the caller's responsibility to call RemovePeer to ensure
// that memory consumption of the peerstore doesn't grow unboundedly.
func NewPeerstore(ctx context.Context, store ds.Batching, opts Options) (*pstoreds, error) {
addrBook, err := NewAddrBook(ctx, store, opts)
Expand All @@ -104,22 +88,13 @@ func NewPeerstore(ctx context.Context, store ds.Batching, opts Options) (*pstore
return nil, err
}

ps := &pstoreds{
return &pstoreds{
Metrics: pstore.NewMetrics(),
dsKeyBook: keyBook,
dsAddrBook: addrBook,
dsPeerMetadata: peerMetadata,
dsProtoBook: protoBook,
}
if opts.EventBus != nil {
manager, err := pstoremanager.NewPeerstoreManager(ps, opts.EventBus)
if err != nil {
ps.Close()
return nil, err
}
ps.manager = manager
}
return ps, nil
}, nil
}

// uniquePeerIds extracts and returns unique peer IDs from database keys.
Expand Down Expand Up @@ -156,10 +131,6 @@ func uniquePeerIds(ds ds.Datastore, prefix ds.Key, extractor func(result query.R
return ids, nil
}

func (ps *pstoreds) Start() {
ps.manager.Start()
}

func (ps *pstoreds) Close() (err error) {
var errs []error
weakClose := func(name string, c interface{}) {
Expand All @@ -169,9 +140,6 @@ func (ps *pstoreds) Close() (err error) {
}
}
}
if ps.manager != nil {
weakClose("manager", ps.manager)
}
weakClose("keybook", ps.dsKeyBook)
weakClose("addressbook", ps.dsAddrBook)
weakClose("protobook", ps.dsProtoBook)
Expand Down
Loading

0 comments on commit 3efa6e1

Please sign in to comment.