Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
G
Geth-Modification
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
张蕾
Geth-Modification
Commits
87447f9f
Commit
87447f9f
authored
Apr 21, 2015
by
Péter Szilágyi
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
whisper: fix payload loss in case of plaintext decrypt
parent
7f48eb87
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
109 additions
and
4 deletions
+109
-4
envelope_test.go
whisper/envelope_test.go
+103
-1
message.go
whisper/message.go
+6
-3
No files found.
whisper/envelope_test.go
View file @
87447f9f
...
...
@@ -4,6 +4,9 @@ import (
"bytes"
"testing"
"time"
"github.com/ethereum/go-ethereum/crypto"
"github.com/ethereum/go-ethereum/crypto/ecies"
)
func
TestEnvelopeOpen
(
t
*
testing
.
T
)
{
...
...
@@ -16,7 +19,7 @@ func TestEnvelopeOpen(t *testing.T) {
}
opened
,
err
:=
envelope
.
Open
(
nil
)
if
err
!=
nil
{
t
.
Fatalf
(
"failed to open envelope: %v
.
"
,
err
)
t
.
Fatalf
(
"failed to open envelope: %v"
,
err
)
}
if
opened
.
Flags
!=
message
.
Flags
{
t
.
Fatalf
(
"flags mismatch: have %d, want %d"
,
opened
.
Flags
,
message
.
Flags
)
...
...
@@ -38,3 +41,102 @@ func TestEnvelopeOpen(t *testing.T) {
t
.
Fatalf
(
"message hash mismatch: have 0x%x, want 0x%x"
,
opened
.
Hash
,
envelope
.
Hash
())
}
}
func
TestEnvelopeAnonymousOpenUntargeted
(
t
*
testing
.
T
)
{
payload
:=
[]
byte
(
"hello envelope"
)
envelope
,
err
:=
NewMessage
(
payload
)
.
Wrap
(
DefaultPoW
,
Options
{})
if
err
!=
nil
{
t
.
Fatalf
(
"failed to wrap message: %v"
,
err
)
}
opened
,
err
:=
envelope
.
Open
(
nil
)
if
err
!=
nil
{
t
.
Fatalf
(
"failed to open envelope: %v"
,
err
)
}
if
opened
.
To
!=
nil
{
t
.
Fatalf
(
"recipient mismatch: have 0x%x, want nil"
,
opened
.
To
)
}
if
bytes
.
Compare
(
opened
.
Payload
,
payload
)
!=
0
{
t
.
Fatalf
(
"payload mismatch: have 0x%x, want 0x%x"
,
opened
.
Payload
,
payload
)
}
}
func
TestEnvelopeAnonymousOpenTargeted
(
t
*
testing
.
T
)
{
key
,
err
:=
crypto
.
GenerateKey
()
if
err
!=
nil
{
t
.
Fatalf
(
"failed to generate test identity: %v"
,
err
)
}
payload
:=
[]
byte
(
"hello envelope"
)
envelope
,
err
:=
NewMessage
(
payload
)
.
Wrap
(
DefaultPoW
,
Options
{
To
:
&
key
.
PublicKey
,
})
if
err
!=
nil
{
t
.
Fatalf
(
"failed to wrap message: %v"
,
err
)
}
opened
,
err
:=
envelope
.
Open
(
nil
)
if
err
!=
nil
{
t
.
Fatalf
(
"failed to open envelope: %v"
,
err
)
}
if
opened
.
To
!=
nil
{
t
.
Fatalf
(
"recipient mismatch: have 0x%x, want nil"
,
opened
.
To
)
}
if
bytes
.
Compare
(
opened
.
Payload
,
payload
)
==
0
{
t
.
Fatalf
(
"payload match, should have been encrypted: 0x%x"
,
opened
.
Payload
)
}
}
func
TestEnvelopeIdentifiedOpenUntargeted
(
t
*
testing
.
T
)
{
key
,
err
:=
crypto
.
GenerateKey
()
if
err
!=
nil
{
t
.
Fatalf
(
"failed to generate test identity: %v"
,
err
)
}
payload
:=
[]
byte
(
"hello envelope"
)
envelope
,
err
:=
NewMessage
(
payload
)
.
Wrap
(
DefaultPoW
,
Options
{})
if
err
!=
nil
{
t
.
Fatalf
(
"failed to wrap message: %v"
,
err
)
}
opened
,
err
:=
envelope
.
Open
(
key
)
switch
err
{
case
nil
:
t
.
Fatalf
(
"envelope opened with bad key: %v"
,
opened
)
case
ecies
.
ErrInvalidPublicKey
:
// Ok, key mismatch but opened
default
:
t
.
Fatalf
(
"failed to open envelope: %v"
,
err
)
}
if
opened
.
To
!=
nil
{
t
.
Fatalf
(
"recipient mismatch: have 0x%x, want nil"
,
opened
.
To
)
}
if
bytes
.
Compare
(
opened
.
Payload
,
payload
)
!=
0
{
t
.
Fatalf
(
"payload mismatch: have 0x%x, want 0x%x"
,
opened
.
Payload
,
payload
)
}
}
func
TestEnvelopeIdentifiedOpenTargeted
(
t
*
testing
.
T
)
{
key
,
err
:=
crypto
.
GenerateKey
()
if
err
!=
nil
{
t
.
Fatalf
(
"failed to generate test identity: %v"
,
err
)
}
payload
:=
[]
byte
(
"hello envelope"
)
envelope
,
err
:=
NewMessage
(
payload
)
.
Wrap
(
DefaultPoW
,
Options
{
To
:
&
key
.
PublicKey
,
})
if
err
!=
nil
{
t
.
Fatalf
(
"failed to wrap message: %v"
,
err
)
}
opened
,
err
:=
envelope
.
Open
(
key
)
if
err
!=
nil
{
t
.
Fatalf
(
"failed to open envelope: %v"
,
err
)
}
if
opened
.
To
!=
nil
{
t
.
Fatalf
(
"recipient mismatch: have 0x%x, want nil"
,
opened
.
To
)
}
if
bytes
.
Compare
(
opened
.
Payload
,
payload
)
!=
0
{
t
.
Fatalf
(
"payload mismatch: have 0x%x, want 0x%x"
,
opened
.
Payload
,
payload
)
}
}
whisper/message.go
View file @
87447f9f
...
...
@@ -120,9 +120,12 @@ func (self *Message) encrypt(key *ecdsa.PublicKey) (err error) {
}
// decrypt decrypts an encrypted payload with a private key.
func
(
self
*
Message
)
decrypt
(
key
*
ecdsa
.
PrivateKey
)
(
err
error
)
{
self
.
Payload
,
err
=
crypto
.
Decrypt
(
key
,
self
.
Payload
)
return
func
(
self
*
Message
)
decrypt
(
key
*
ecdsa
.
PrivateKey
)
error
{
cleartext
,
err
:=
crypto
.
Decrypt
(
key
,
self
.
Payload
)
if
err
==
nil
{
self
.
Payload
=
cleartext
}
return
err
}
// hash calculates the SHA3 checksum of the message flags and payload.
...
...
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