fix handshake race
This commit is contained in:
parent
156f3387eb
commit
5090006e2d
@ -12,13 +12,17 @@ func OutgoingHandshake(ctx context.Context, conn io.ReadWriteCloser, peerId stri
|
|||||||
}
|
}
|
||||||
h := newHandshake()
|
h := newHandshake()
|
||||||
done := make(chan struct{})
|
done := make(chan struct{})
|
||||||
|
var (
|
||||||
|
resIdentity []byte
|
||||||
|
resErr error
|
||||||
|
)
|
||||||
go func() {
|
go func() {
|
||||||
defer close(done)
|
defer close(done)
|
||||||
identity, err = outgoingHandshake(h, conn, peerId, cc)
|
resIdentity, resErr = outgoingHandshake(h, conn, peerId, cc)
|
||||||
}()
|
}()
|
||||||
select {
|
select {
|
||||||
case <-done:
|
case <-done:
|
||||||
return
|
return resIdentity, resErr
|
||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
_ = conn.Close()
|
_ = conn.Close()
|
||||||
return nil, ctx.Err()
|
return nil, ctx.Err()
|
||||||
@ -74,13 +78,17 @@ func IncomingHandshake(ctx context.Context, conn io.ReadWriteCloser, peerId stri
|
|||||||
}
|
}
|
||||||
h := newHandshake()
|
h := newHandshake()
|
||||||
done := make(chan struct{})
|
done := make(chan struct{})
|
||||||
|
var (
|
||||||
|
resIdentity []byte
|
||||||
|
resError error
|
||||||
|
)
|
||||||
go func() {
|
go func() {
|
||||||
defer close(done)
|
defer close(done)
|
||||||
identity, err = incomingHandshake(h, conn, peerId, cc)
|
resIdentity, resError = incomingHandshake(h, conn, peerId, cc)
|
||||||
}()
|
}()
|
||||||
select {
|
select {
|
||||||
case <-done:
|
case <-done:
|
||||||
return
|
return resIdentity, resError
|
||||||
case <-ctx.Done():
|
case <-ctx.Done():
|
||||||
_ = conn.Close()
|
_ = conn.Close()
|
||||||
return nil, ctx.Err()
|
return nil, ctx.Err()
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user