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-dms3
Commits
eaffabec
Commit
eaffabec
authored
Sep 23, 2014
by
Juan Batiz-Benet
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
handshake: error out while sending + dbg
parent
72287869
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
5 deletions
+21
-5
crypto/spipe/handshake.go
crypto/spipe/handshake.go
+21
-5
No files found.
crypto/spipe/handshake.go
View file @
eaffabec
...
@@ -67,8 +67,12 @@ func (s *SecurePipe) handshake() error {
...
@@ -67,8 +67,12 @@ func (s *SecurePipe) handshake() error {
return
err
return
err
}
}
// u.POut("sending encoded handshake\n")
// Send our Propose packet
s
.
insecure
.
Out
<-
encoded
select
{
case
s
.
insecure
.
Out
<-
encoded
:
case
<-
s
.
ctx
.
Done
()
:
return
ErrClosed
}
// Parse their Propose packet and generate an Exchange packet.
// Parse their Propose packet and generate an Exchange packet.
// Exchange = (EphemeralPubKey, Signature)
// Exchange = (EphemeralPubKey, Signature)
...
@@ -137,7 +141,12 @@ func (s *SecurePipe) handshake() error {
...
@@ -137,7 +141,12 @@ func (s *SecurePipe) handshake() error {
exEncoded
,
err
:=
proto
.
Marshal
(
exPacket
)
exEncoded
,
err
:=
proto
.
Marshal
(
exPacket
)
s
.
insecure
.
Out
<-
exEncoded
// send out Exchange packet
select
{
case
s
.
insecure
.
Out
<-
exEncoded
:
case
<-
s
.
ctx
.
Done
()
:
return
ErrClosed
}
// Parse their Exchange packet and generate a Finish packet.
// Parse their Exchange packet and generate a Finish packet.
// Finish = E('Finish')
// Finish = E('Finish')
...
@@ -182,7 +191,14 @@ func (s *SecurePipe) handshake() error {
...
@@ -182,7 +191,14 @@ func (s *SecurePipe) handshake() error {
finished
:=
[]
byte
(
"Finished"
)
finished
:=
[]
byte
(
"Finished"
)
s
.
Out
<-
finished
// send finished msg
select
{
case
<-
s
.
ctx
.
Done
()
:
return
ErrClosed
case
s
.
Out
<-
finished
:
}
// recv finished msg
var
resp2
[]
byte
var
resp2
[]
byte
select
{
select
{
case
<-
s
.
ctx
.
Done
()
:
case
<-
s
.
ctx
.
Done
()
:
...
@@ -194,7 +210,7 @@ func (s *SecurePipe) handshake() error {
...
@@ -194,7 +210,7 @@ func (s *SecurePipe) handshake() error {
return
errors
.
New
(
"Negotiation failed."
)
return
errors
.
New
(
"Negotiation failed."
)
}
}
u
.
DOut
(
"[%s]
identify
: Got node id: %s
\n
"
,
s
.
local
.
ID
.
Pretty
(),
s
.
remote
.
ID
.
Pretty
())
u
.
DOut
(
"[%s]
handshake
: Got node id: %s
\n
"
,
s
.
local
.
ID
.
Pretty
(),
s
.
remote
.
ID
.
Pretty
())
return
nil
return
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