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
ba0ddf36
Commit
ba0ddf36
authored
Jul 26, 2017
by
Steven Allen
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
notify: make locking clearer
parent
13a847a8
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
35 additions
and
32 deletions
+35
-32
notif.go
notif.go
+35
-32
No files found.
notif.go
View file @
ba0ddf36
...
@@ -45,13 +45,16 @@ func (nn *netNotifiee) Connected(n inet.Network, v inet.Conn) {
...
@@ -45,13 +45,16 @@ func (nn *netNotifiee) Connected(n inet.Network, v inet.Conn) {
cancel
:
cancel
,
cancel
:
cancel
,
}
}
go
func
()
{
// Note: We *could* just check the peerstore to see if the remote side supports the dht
// Note: We *could* just check the peerstore to see if the remote side supports the dht
// protocol, but its not clear that that information will make it into the peerstore
// protocol, but its not clear that that information will make it into the peerstore
// by the time this notification is sent. So just to be very careful, we brute force this
// by the time this notification is sent. So just to be very careful, we brute force this
// and open a new stream
// and open a new stream
go
nn
.
testConnection
(
ctx
,
v
)
}
func
(
nn
*
netNotifiee
)
testConnection
(
ctx
context
.
Context
,
v
inet
.
Conn
)
{
dht
:=
nn
.
DHT
()
for
{
for
{
s
,
err
:=
dht
.
host
.
NewStream
(
ctx
,
v
.
RemotePeer
(),
ProtocolDHT
,
ProtocolDHTOld
)
s
,
err
:=
dht
.
host
.
NewStream
(
ctx
,
v
.
RemotePeer
(),
ProtocolDHT
,
ProtocolDHTOld
)
...
@@ -59,12 +62,13 @@ func (nn *netNotifiee) Connected(n inet.Network, v inet.Conn) {
...
@@ -59,12 +62,13 @@ func (nn *netNotifiee) Connected(n inet.Network, v inet.Conn) {
case
nil
:
case
nil
:
s
.
Close
()
s
.
Close
()
dht
.
plk
.
Lock
()
dht
.
plk
.
Lock
()
defer
dht
.
plk
.
Unlock
()
// Check if canceled under the lock.
// Check if canceled under the lock.
if
ctx
.
Err
()
==
nil
{
if
ctx
.
Err
()
==
nil
{
dht
.
Update
(
dht
.
Context
(),
v
.
RemotePeer
())
dht
.
Update
(
dht
.
Context
(),
v
.
RemotePeer
())
}
}
dht
.
plk
.
Unlock
()
case
io
.
EOF
:
case
io
.
EOF
:
if
ctx
.
Err
()
==
nil
{
if
ctx
.
Err
()
==
nil
{
// Connection died but we may still have *an* open connection (context not canceled) so try again.
// Connection died but we may still have *an* open connection (context not canceled) so try again.
...
@@ -78,7 +82,6 @@ func (nn *netNotifiee) Connected(n inet.Network, v inet.Conn) {
...
@@ -78,7 +82,6 @@ func (nn *netNotifiee) Connected(n inet.Network, v inet.Conn) {
}
}
return
return
}
}
}()
}
}
func
(
nn
*
netNotifiee
)
Disconnected
(
n
inet
.
Network
,
v
inet
.
Conn
)
{
func
(
nn
*
netNotifiee
)
Disconnected
(
n
inet
.
Network
,
v
inet
.
Conn
)
{
...
...
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