Skip to content
GitLab
Projects
Groups
Snippets
Help
Loading...
Help
What's new
10
Help
Support
Community forum
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
Open sidebar
p2p
go-p2p-kad-dht
Commits
1d696d1e
Commit
1d696d1e
authored
Apr 21, 2020
by
Alan Shaw
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactor: implement feedback from review
parent
e01dc8e3
Changes
2
Show whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
20 additions
and
28 deletions
+20
-28
dht_options.go
dht_options.go
+4
-0
providers/providers_manager.go
providers/providers_manager.go
+16
-28
No files found.
dht_options.go
View file @
1d696d1e
...
...
@@ -351,6 +351,10 @@ func DisableValues() Option {
}
// ProvidersOptions are options passed directly to the provider manager.
//
// The provider manager adds and gets provider records from the datastore, cahing
// them in between. These options are passed to the provider manager allowing
// customisation of things like the GC interval and cache implementation.
func
ProvidersOptions
(
opts
[]
providers
.
Option
)
Option
{
return
func
(
c
*
config
)
error
{
c
.
providersOptions
=
opts
...
...
providers/providers_manager.go
View file @
1d696d1e
...
...
@@ -45,38 +45,23 @@ type ProviderManager struct {
cleanupInterval
time
.
Duration
}
type
options
struct
{
cleanupInterval
time
.
Duration
cache
lru
.
LRUCache
}
// Option is a function that sets a provider manager option.
type
Option
func
(
*
options
)
error
type
Option
func
(
*
ProviderManager
)
error
func
(
c
*
options
)
apply
(
opts
...
Option
)
error
{
func
(
pm
*
ProviderManager
)
applyOptions
(
opts
...
Option
)
error
{
for
i
,
opt
:=
range
opts
{
if
err
:=
opt
(
c
);
err
!=
nil
{
if
err
:=
opt
(
pm
);
err
!=
nil
{
return
fmt
.
Errorf
(
"provider manager option %d failed: %s"
,
i
,
err
)
}
}
return
nil
}
var
defaults
=
func
(
o
*
options
)
error
{
o
.
cleanupInterval
=
defaultCleanupInterval
cache
,
err
:=
lru
.
NewLRU
(
lruCacheSize
,
nil
)
if
err
!=
nil
{
return
err
}
o
.
cache
=
cache
return
nil
}
// CleanupInterval sets the time between GC runs.
// Defaults to 1h.
func
CleanupInterval
(
d
time
.
Duration
)
Option
{
return
func
(
o
*
options
)
error
{
o
.
cleanupInterval
=
d
return
func
(
pm
*
ProviderManager
)
error
{
pm
.
cleanupInterval
=
d
return
nil
}
}
...
...
@@ -84,8 +69,8 @@ func CleanupInterval(d time.Duration) Option {
// Cache sets the LRU cache implementation.
// Defaults to a simple LRU cache.
func
Cache
(
c
lru
.
LRUCache
)
Option
{
return
func
(
o
*
options
)
error
{
o
.
cache
=
c
return
func
(
pm
*
ProviderManager
)
error
{
pm
.
cache
=
c
return
nil
}
}
...
...
@@ -102,17 +87,20 @@ type getProv struct {
// NewProviderManager constructor
func
NewProviderManager
(
ctx
context
.
Context
,
local
peer
.
ID
,
dstore
ds
.
Batching
,
opts
...
Option
)
(
*
ProviderManager
,
error
)
{
var
cfg
options
if
err
:=
cfg
.
apply
(
append
([]
Option
{
defaults
},
opts
...
)
...
);
err
!=
nil
{
return
nil
,
err
}
pm
:=
new
(
ProviderManager
)
pm
.
getprovs
=
make
(
chan
*
getProv
)
pm
.
newprovs
=
make
(
chan
*
addProv
)
pm
.
dstore
=
autobatch
.
NewAutoBatching
(
dstore
,
batchBufferSize
)
pm
.
cache
=
cfg
.
cache
cache
,
err
:=
lru
.
NewLRU
(
lruCacheSize
,
nil
)
if
err
!=
nil
{
return
nil
,
err
}
pm
.
cache
=
cache
pm
.
cleanupInterval
=
defaultCleanupInterval
if
err
:=
pm
.
applyOptions
(
opts
...
);
err
!=
nil
{
return
nil
,
err
}
pm
.
proc
=
goprocessctx
.
WithContext
(
ctx
)
pm
.
cleanupInterval
=
cfg
.
cleanupInterval
pm
.
proc
.
Go
(
pm
.
run
)
return
pm
,
nil
}
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
.
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment