1
0
tetatet/src/crypt.h

64 lines
2.8 KiB
C
Raw Normal View History

2024-03-22 03:24:01 +04:00
#ifndef _CRYPT_H_
#define _CRYPT_H_
2024-03-21 17:50:55 +04:00
#include <stdbool.h>
#include <sodium.h>
#define CRYPT_KX_PKEY_LEN crypto_kx_PUBLICKEYBYTES
#define CRYPT_KX_SKEY_LEN crypto_kx_SECRETKEYBYTES
#define CRYPT_SIGN_PKEY_LEN crypto_sign_PUBLICKEYBYTES
#define CRYPT_SIGN_SKEY_LEN crypto_sign_SECRETKEYBYTES
#define CRYPT_SIGN_LEN crypto_sign_BYTES
#define CRYPT_SESS_KEY_LEN crypto_kx_SESSIONKEYBYTES
2024-03-21 17:50:55 +04:00
#define CRYPT_NONCE_LEN crypto_aead_aegis256_NPUBBYTES
#define CRYPT_NONCEHALF_LEN (CRYPT_NONCE_LEN/2)
#define CRYPT_HELLO_LEN (CRYPT_PKEY_HEXLEN + CRYPT_SIGN_LEN + (CRYPT_NONCEHALF_LEN))
#define CRYPT_PKEY_HEXLEN ((CRYPT_KX_PKEY_LEN + CRYPT_SIGN_PKEY_LEN) * 2)
#define CRYPT_SKEY_HEXLEN ((CRYPT_SIGN_PKEY_LEN + CRYPT_SIGN_SKEY_LEN) * 2)
2024-03-21 17:50:55 +04:00
typedef struct crypt_key_t {
unsigned char kx_pub[crypto_kx_PUBLICKEYBYTES];
unsigned char kx_sec[crypto_kx_SECRETKEYBYTES];
unsigned char sign_pub[crypto_sign_PUBLICKEYBYTES];
unsigned char sign_sec[crypto_sign_SECRETKEYBYTES];
2024-03-21 17:50:55 +04:00
bool hasSecKey;
} crypt_key_t;
int crypt_key_gen(crypt_key_t *const k);
int crypt_key_from_hex(crypt_key_t *const k, const char phex[CRYPT_PKEY_HEXLEN], const char shex[CRYPT_SKEY_HEXLEN]);
int crypt_key_from_hex_public(crypt_key_t *const k, const char phex[CRYPT_PKEY_HEXLEN]);
void crypt_key_destroy(crypt_key_t *const k);
int crypt_key_export_public(const crypt_key_t *const k, char hex[CRYPT_PKEY_HEXLEN]);
int crypt_key_export_secret(const crypt_key_t *const k, char hex[CRYPT_SKEY_HEXLEN]);
2024-03-21 17:50:55 +04:00
int crypt_load_key(crypt_key_t *const k, FILE *const pub, FILE *const sec);
int crypt_store_key(const crypt_key_t *const k, FILE *const pub, FILE *const sec);
2024-03-21 17:50:55 +04:00
int crypt_hello(const crypt_key_t *const own, unsigned char *const hello);
int crypt_hello_verify(const unsigned char *const hello, crypt_key_t *const remote);
void crypt_hello_get_nonce(const unsigned char *const own_hello, const unsigned char *const remote_hello, unsigned char *const nonce, bool is_client);
2024-03-21 17:50:55 +04:00
typedef struct crypt_session_t {
unsigned char rx[CRYPT_SESS_KEY_LEN];
unsigned char tx[CRYPT_SESS_KEY_LEN];
unsigned char nonce[CRYPT_NONCE_LEN];
crypt_key_t *remote_key;
2024-03-21 17:50:55 +04:00
} crypt_session_t;
#define CLEN(mlen) (mlen + crypto_aead_aegis256_ABYTES)
#define MLEN(clen) (clen - crypto_aead_aegis256_ABYTES)
int crypt_session_init(crypt_session_t *const s, const crypt_key_t *const own, crypt_key_t *const remote, const unsigned char *const nonce, bool is_client);
int crypt_session_encrypt(crypt_session_t *const s, const unsigned char *const m, unsigned long long mlen, unsigned char *const c, unsigned long long *const clen);
int crypt_session_decrypt(crypt_session_t *const s, const unsigned char *const c, unsigned long long clen, unsigned char *const m, unsigned long long *const mlen);
void crypt_session_destroy(crypt_session_t *const s);
2024-03-21 17:50:55 +04:00
#endif /* _CRYPT_H_ */