forked from keys-pub/keys
-
Notifications
You must be signed in to change notification settings - Fork 0
/
box_test.go
67 lines (54 loc) · 2.51 KB
/
box_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
package keys_test
import (
"fmt"
"log"
"testing"
"github.com/keys-pub/keys"
"github.com/keys-pub/keys/encoding"
"github.com/stretchr/testify/require"
)
func TestBoxSeal(t *testing.T) {
alice := keys.GenerateX25519Key()
bob := keys.GenerateX25519Key()
msg := "Hey bob, it's alice. The passcode is 12345."
encrypted := keys.BoxSeal([]byte(msg), bob.PublicKey(), alice)
out, err := keys.BoxOpen(encrypted, alice.PublicKey(), bob)
require.NoError(t, err)
require.Equal(t, "Hey bob, it's alice. The passcode is 12345.", string(out))
}
func ExampleBoxSeal() {
ak := keys.GenerateX25519Key()
bk := keys.GenerateX25519Key()
msg := "Hey bob, it's alice. The passcode is 12345."
encrypted := keys.BoxSeal([]byte(msg), bk.PublicKey(), ak)
out, err := keys.BoxOpen(encrypted, ak.PublicKey(), bk)
if err != nil {
log.Fatal(err)
}
fmt.Printf("%s\n", string(out))
// Output:
// Hey bob, it's alice. The passcode is 12345.
}
func TestBox(t *testing.T) {
ka := keys.Bytes32(encoding.MustDecode("77076d0a7318a57d3c16c17251b26645df4c2f87ebc0992ab177fba51db92c2a", encoding.Hex))
kpa := keys.Bytes32(encoding.MustDecode("8520f0098930a754748b7ddcb43ef75a0dbf3a0d26381af4eba4a98eaa9b4e6a", encoding.Hex))
kb := keys.Bytes32(encoding.MustDecode("5dab087e624a8a4b79e17f8b83800ee66f3bb1292618b6fd1c2f8b27ff88e0eb", encoding.Hex))
kpb := keys.Bytes32(encoding.MustDecode("de9edb7d7b7dc1b4d35b61c2ece435373f8343c85b78674dadfc7e146f882b4f", encoding.Hex))
nonce := keys.Bytes24(encoding.MustDecode("69696ee955b62b73cd62bda875fc73d68219e0036b7a0b37", encoding.Hex))
plain := encoding.MustDecode("be075fc53c81f2d5cf141316ebeb0c7b5228c52a4c62cbd44b66849b64244ffc"+
"e5ecbaaf33bd751a1ac728d45e6c61296cdc3c01233561f41db66cce314adb31"+
"0e3be8250c46f06dceea3a7fa1348057e2f6556ad6b1318a024a838f21af1fde"+
"048977eb48f59ffd4924ca1c60902e52f0a089bc76897040e082f93776384864"+
"5e0705", encoding.Hex)
cipher := encoding.MustDecode("f3ffc7703f9400e52a7dfb4b3d3305d98e993b9f48681273c29650ba32fc76ce"+
"48332ea7164d96a4476fb8c531a1186ac0dfc17c98dce87b4da7f011ec48c972"+
"71d2c20f9b928fe2270d6fb863d51738b48eeee314a7cc8ab932164548e526ae"+
"90224368517acfeabd6bb3732bc0e9da99832b61ca01b6de56244a9e88d5f9b3"+
"7973f622a43d14a6599b1f654cb45a74e355a5", encoding.Hex)
alice := keys.NewX25519KeyFromPrivateKey(ka)
bob := keys.NewX25519KeyFromPrivateKey(kb)
require.Equal(t, alice.PublicKey().Bytes32(), kpa)
require.Equal(t, bob.PublicKey().Bytes32(), kpb)
encrypted := alice.Seal(plain, nonce, bob.PublicKey())
require.Equal(t, cipher, encrypted)
}