aboutsummaryrefslogtreecommitdiff
path: root/test/conn_test.exs
blob: 48c92f8f6819d163c85bc3e501e7692b410ea242 (plain) (blame)
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
defmodule ShardTest.Conn do
  use ExUnit.Case
  doctest Shard.Application

  require Salty.Box.Curve25519xchacha20poly1305, as: Box
  require Salty.Sign.Ed25519, as: Sign

  test "the truth" do
    assert 1 + 1 == 2
  end

  test "crypto connection" do
    {:ok, srv_pkey, srv_skey} = Sign.keypair
    {:ok, sess_pkey, sess_skey} = Box.keypair
    {:ok, challenge} = Salty.Random.buf 32
    {:ok, socket} = :gen_tcp.connect {127,0,0,1}, 4044, [:binary, packet: 2, active: false]

    :gen_tcp.send(socket, srv_pkey <> sess_pkey <> challenge)  
    {:ok, pkt} = :gen_tcp.recv(socket, 0)
    cli_pkey = binary_part(pkt, 0, Sign.publickeybytes)
    cli_sess_pkey = binary_part(pkt, Sign.publickeybytes, Box.publickeybytes)
    cli_challenge = binary_part(pkt, Sign.publickeybytes + Box.publickeybytes, 32)

    {:ok, cli_challenge_sign} = Sign.sign_detached(cli_challenge, srv_skey)
    sendmsg(socket, cli_challenge_sign, cli_sess_pkey, sess_skey)

    challenge_sign = recvmsg(socket, cli_sess_pkey, sess_skey)
    :ok = Sign.verify_detached(challenge_sign, challenge, cli_pkey)

    pkt = :erlang.binary_to_term(recvmsg(socket, cli_sess_pkey, sess_skey), [:safe])
    IO.puts (inspect pkt)
  end

  defp sendmsg(sock, msg, pk, sk) do
    {:ok, n} = Salty.Random.buf Box.noncebytes
    {:ok, msg} = Box.easy(msg, n, pk, sk)
    :gen_tcp.send(sock, n <> msg)
  end

  defp recvmsg(sock, pk, sk) do
    {:ok, pkt} = :gen_tcp.recv(sock, 0)
    n = binary_part(pkt, 0, Box.noncebytes)
    enc = binary_part(pkt, Box.noncebytes, (byte_size pkt) - Box.noncebytes)
    {:ok, msg} = Box.open_easy(enc, n, pk, sk)
    msg
  end
end