summaryrefslogtreecommitdiff
path: root/code/crypto/crypto.h
blob: 7bd27d5e70202620dbbffbfb4517ed20a4b145df (plain)
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
#include <stddef.h>

#define CURVE25519_SIZE_KEY     32
#define CHACHA20_SIZE_KEY       32
#define POLY1305_SIZE_TAG       16
#define CHACHA20_SIZE_NONCE     8

#define ECP_ECDH_SIZE_KEY       32
#define ECP_AEAD_SIZE_KEY       32
#define ECP_AEAD_SIZE_TAG       16
#define ECP_AEAD_SIZE_NONCE     8

#define ECP_DSA_SIZE_KEY        32

typedef uint8_t ecp_dh_public_t[ECP_ECDH_SIZE_KEY];
typedef uint8_t ecp_dh_private_t[ECP_ECDH_SIZE_KEY];
typedef uint8_t ecp_aead_key_t[ECP_AEAD_SIZE_KEY];
typedef uint8_t ecp_dsa_public_t[ECP_DSA_SIZE_KEY];
typedef uint8_t ecp_dsa_private_t[ECP_DSA_SIZE_KEY];

int
aead_chacha20_poly1305_seal(unsigned char *out, size_t *out_len, 
    size_t max_out_len, unsigned char key[32], unsigned char tag_len,
    const unsigned char *nonce, size_t nonce_len,
    const unsigned char *in, size_t in_len,
    const unsigned char *ad, size_t ad_len);

int
aead_chacha20_poly1305_open(unsigned char *out, size_t *out_len, 
    size_t max_out_len, unsigned char key[32], unsigned char tag_len,
    const unsigned char *nonce, size_t nonce_len,
    const unsigned char *in, size_t in_len,
    const unsigned char *ad, size_t ad_len);