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
dms3
go-unixfs
Commits
eb6c40d5
Commit
eb6c40d5
authored
Jan 10, 2015
by
Brian Tiger Chow
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
refactor(core): isolate the complex initialization of PeerHost construction
parent
8e42e86d
Changes
1
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
30 additions
and
30 deletions
+30
-30
core/core.go
core/core.go
+30
-30
No files found.
core/core.go
View file @
eb6c40d5
...
...
@@ -191,9 +191,11 @@ func (n *IpfsNode) StartOnlineServices() error {
return
err
}
if
err
:=
n
.
startNetwork
();
err
!=
nil
{
return
err
peerhost
,
err
:=
constructPeerHost
(
ctx
,
n
.
ContextGroup
,
n
.
Config
,
n
.
Identity
,
n
.
Peerstore
)
if
err
!=
nil
{
return
debugerror
.
Wrap
(
err
)
}
n
.
PeerHost
=
peerhost
// setup diagnostics service
n
.
Diagnostics
=
diag
.
NewDiagnostics
(
n
.
Identity
,
n
.
PeerHost
)
...
...
@@ -234,34 +236,6 @@ func (n *IpfsNode) StartOnlineServices() error {
return
nil
}
func
(
n
*
IpfsNode
)
startNetwork
()
error
{
ctx
:=
n
.
Context
()
// setup the network
listenAddrs
,
err
:=
listenAddresses
(
n
.
Config
)
if
err
!=
nil
{
return
debugerror
.
Wrap
(
err
)
}
// make sure we dont error out if our config includes some addresses we cant use.
listenAddrs
=
swarm
.
FilterAddrs
(
listenAddrs
)
network
,
err
:=
swarm
.
NewNetwork
(
ctx
,
listenAddrs
,
n
.
Identity
,
n
.
Peerstore
)
if
err
!=
nil
{
return
debugerror
.
Wrap
(
err
)
}
n
.
AddChildGroup
(
network
.
CtxGroup
())
n
.
PeerHost
=
p2pbhost
.
New
(
network
)
// explicitly set these as our listen addrs.
// (why not do it inside inet.NewNetwork? because this way we can
// listen on addresses without necessarily advertising those publicly.)
addrs
,
err
:=
n
.
PeerHost
.
Network
()
.
InterfaceListenAddresses
()
if
err
!=
nil
{
return
debugerror
.
Wrap
(
err
)
}
n
.
Peerstore
.
AddAddresses
(
n
.
Identity
,
addrs
)
return
nil
}
func
(
n
*
IpfsNode
)
teardown
()
error
{
if
err
:=
n
.
Datastore
.
Close
();
err
!=
nil
{
return
err
...
...
@@ -381,3 +355,29 @@ func listenAddresses(cfg *config.Config) ([]ma.Multiaddr, error) {
return
listen
,
nil
}
// isolates the complex initialization steps
func
constructPeerHost
(
ctx
context
.
Context
,
ctxg
ctxgroup
.
ContextGroup
,
cfg
*
config
.
Config
,
id
peer
.
ID
,
ps
peer
.
Peerstore
)
(
p2phost
.
Host
,
error
)
{
listenAddrs
,
err
:=
listenAddresses
(
cfg
)
// make sure we dont error out if our config includes some addresses we cant use.
filteredAddrs
:=
swarm
.
FilterAddrs
(
listenAddrs
)
if
err
!=
nil
{
return
nil
,
debugerror
.
Wrap
(
err
)
}
network
,
err
:=
swarm
.
NewNetwork
(
ctx
,
filteredAddrs
,
id
,
ps
)
if
err
!=
nil
{
return
nil
,
debugerror
.
Wrap
(
err
)
}
ctxg
.
AddChildGroup
(
network
.
CtxGroup
())
peerhost
:=
p2pbhost
.
New
(
network
)
// explicitly set these as our listen addrs.
// (why not do it inside inet.NewNetwork? because this way we can
// listen on addresses without necessarily advertising those publicly.)
addrs
,
err
:=
peerhost
.
Network
()
.
InterfaceListenAddresses
()
if
err
!=
nil
{
return
nil
,
debugerror
.
Wrap
(
err
)
}
ps
.
AddAddresses
(
id
,
addrs
)
return
peerhost
,
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