2019-08-06 22:27:18 +00:00
|
|
|
// This code is forked from https://github.com/wsddn/go-ecdh/blob/master/curve25519.go
|
|
|
|
/*
|
|
|
|
Copyright (c) 2014, tang0th
|
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions are met:
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in the
|
|
|
|
documentation and/or other materials provided with the distribution.
|
|
|
|
* Neither the name of tang0th nor the names of its contributors may be
|
|
|
|
used to endorse or promote products derived from this software without
|
|
|
|
specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
|
|
|
|
ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE FOR ANY
|
|
|
|
DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
|
|
|
|
LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
|
|
|
|
ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
|
|
|
|
SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package ecdh
|
|
|
|
|
|
|
|
import (
|
|
|
|
"bytes"
|
|
|
|
"crypto"
|
|
|
|
"crypto/rand"
|
2020-10-17 23:45:28 +00:00
|
|
|
"io"
|
2019-08-06 22:27:18 +00:00
|
|
|
"testing"
|
|
|
|
)
|
|
|
|
|
|
|
|
func TestCurve25519(t *testing.T) {
|
|
|
|
testECDH(t)
|
|
|
|
}
|
|
|
|
|
2020-10-17 23:45:28 +00:00
|
|
|
func TestErrors(t *testing.T) {
|
|
|
|
reader, writer := io.Pipe()
|
|
|
|
_ = writer.Close()
|
|
|
|
_, _, err := GenerateKey(reader)
|
|
|
|
if err == nil {
|
|
|
|
t.Error("GenerateKey should return error")
|
|
|
|
}
|
|
|
|
|
|
|
|
_, ok := Unmarshal([]byte{1})
|
|
|
|
if ok {
|
|
|
|
t.Error("Unmarshal should return false")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-08-06 22:27:18 +00:00
|
|
|
func BenchmarkCurve25519(b *testing.B) {
|
|
|
|
for i := 0; i < b.N; i++ {
|
|
|
|
testECDH(b)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func testECDH(t testing.TB) {
|
|
|
|
var privKey1, privKey2 crypto.PrivateKey
|
|
|
|
var pubKey1, pubKey2 crypto.PublicKey
|
|
|
|
var pubKey1Buf, pubKey2Buf []byte
|
|
|
|
var err error
|
|
|
|
var ok bool
|
|
|
|
var secret1, secret2 []byte
|
|
|
|
|
|
|
|
privKey1, pubKey1, err = GenerateKey(rand.Reader)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
privKey2, pubKey2, err = GenerateKey(rand.Reader)
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
pubKey1Buf = Marshal(pubKey1)
|
|
|
|
pubKey2Buf = Marshal(pubKey2)
|
|
|
|
|
|
|
|
pubKey1, ok = Unmarshal(pubKey1Buf)
|
|
|
|
if !ok {
|
|
|
|
t.Fatalf("Unmarshal does not work")
|
|
|
|
}
|
|
|
|
|
|
|
|
pubKey2, ok = Unmarshal(pubKey2Buf)
|
|
|
|
if !ok {
|
|
|
|
t.Fatalf("Unmarshal does not work")
|
|
|
|
}
|
|
|
|
|
2020-12-21 16:37:33 +00:00
|
|
|
secret1, err = GenerateSharedSecret(privKey1, pubKey2)
|
2019-08-06 22:27:18 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
2020-12-21 16:37:33 +00:00
|
|
|
secret2, err = GenerateSharedSecret(privKey2, pubKey1)
|
2019-08-06 22:27:18 +00:00
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
if !bytes.Equal(secret1, secret2) {
|
|
|
|
t.Fatalf("The two shared keys: %d, %d do not match", secret1, secret2)
|
|
|
|
}
|
|
|
|
}
|