2020-07-28 05:19:17 +03:00
|
|
|
#ifndef URCRYPT_H
|
|
|
|
#define URCRYPT_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2020-08-01 03:30:09 +03:00
|
|
|
#include <stdbool.h>
|
2020-08-07 22:28:50 +03:00
|
|
|
#include <stdlib.h>
|
2020-07-31 00:40:47 +03:00
|
|
|
#include <string.h>
|
2020-08-06 02:06:04 +03:00
|
|
|
|
2020-07-28 05:19:17 +03:00
|
|
|
#include <ed25519.h>
|
|
|
|
#include <ge-additions.h>
|
|
|
|
|
2020-08-07 22:28:50 +03:00
|
|
|
#include <openssl/crypto.h>
|
2020-08-06 02:06:04 +03:00
|
|
|
#include <openssl/aes.h>
|
|
|
|
|
2020-08-07 22:28:50 +03:00
|
|
|
typedef void *(*urcrypt_malloc_t)(size_t);
|
|
|
|
typedef void *(*urcrypt_realloc_t)(void*, size_t);
|
|
|
|
typedef void (*urcrypt_free_t)(void*);
|
|
|
|
|
|
|
|
int urcrypt_init(urcrypt_malloc_t, urcrypt_realloc_t, urcrypt_free_t);
|
|
|
|
|
|
|
|
void *urcrypt_malloc(size_t);
|
|
|
|
void *urcrypt_realloc(void*, size_t);
|
|
|
|
void urcrypt_free(void*);
|
|
|
|
|
|
|
|
int urcrypt_ed_point_add(const uint8_t a[32],
|
|
|
|
const uint8_t b[32],
|
|
|
|
uint8_t out[32]);
|
|
|
|
int urcrypt_ed_scalarmult(const uint8_t a[32],
|
|
|
|
const uint8_t b[32],
|
|
|
|
uint8_t out[32]);
|
|
|
|
void urcrypt_ed_scalarmult_base(const uint8_t a[32],
|
|
|
|
uint8_t out[32]);
|
|
|
|
int urcrypt_ed_add_scalarmult_scalarmult_base(const uint8_t a[32],
|
|
|
|
const uint8_t a_point[32],
|
|
|
|
const uint8_t b[32],
|
2020-08-01 00:21:02 +03:00
|
|
|
uint8_t out[32]);
|
2020-08-07 22:28:50 +03:00
|
|
|
int urcrypt_ed_add_double_scalarmult(const uint8_t a[32],
|
|
|
|
const uint8_t a_point[32],
|
|
|
|
const uint8_t b[32],
|
|
|
|
const uint8_t b_point[32],
|
2020-08-01 00:46:19 +03:00
|
|
|
uint8_t out[32]);
|
2020-08-06 02:06:04 +03:00
|
|
|
|
2020-08-07 22:28:50 +03:00
|
|
|
void urcrypt_ed_puck(const uint8_t seed[32],
|
|
|
|
uint8_t out[32]);
|
|
|
|
void urcrypt_ed_shar(const uint8_t public[32],
|
|
|
|
const uint8_t seed[32],
|
|
|
|
uint8_t out[32]);
|
|
|
|
void urcrypt_ed_sign(const uint8_t *message,
|
2020-07-31 00:40:47 +03:00
|
|
|
size_t length,
|
2020-08-07 22:28:50 +03:00
|
|
|
const uint8_t seed[32],
|
2020-08-01 02:31:56 +03:00
|
|
|
uint8_t out[64]);
|
2020-08-07 22:28:50 +03:00
|
|
|
bool urcrypt_ed_veri(const uint8_t *message,
|
|
|
|
size_t length,
|
|
|
|
const uint8_t signature[64],
|
|
|
|
const uint8_t public[32]);
|
|
|
|
|
|
|
|
int urcrypt_aes_ecba_en(const uint8_t key[16],
|
|
|
|
const uint8_t block[16],
|
|
|
|
uint8_t out[16]);
|
|
|
|
int urcrypt_aes_ecba_de(const uint8_t key[16],
|
|
|
|
const uint8_t block[16],
|
|
|
|
uint8_t out[16]);
|
|
|
|
int urcrypt_aes_ecbb_en(const uint8_t key[24],
|
|
|
|
const uint8_t block[16],
|
|
|
|
uint8_t out[16]);
|
|
|
|
int urcrypt_aes_ecbb_de(const uint8_t key[24],
|
|
|
|
const uint8_t block[16],
|
|
|
|
uint8_t out[16]);
|
|
|
|
int urcrypt_aes_ecbc_en(const uint8_t key[32],
|
|
|
|
const uint8_t block[16],
|
|
|
|
uint8_t out[16]);
|
|
|
|
int urcrypt_aes_ecbc_de(const uint8_t key[32],
|
|
|
|
const uint8_t block[16],
|
|
|
|
uint8_t out[16]);
|
|
|
|
|
|
|
|
uint8_t* urcrypt_aes_cbca_en(const uint8_t *message,
|
|
|
|
size_t length,
|
|
|
|
const uint8_t key[16],
|
|
|
|
const uint8_t ivec[16],
|
|
|
|
size_t *out_length);
|
2020-08-08 00:40:27 +03:00
|
|
|
uint8_t* urcrypt_aes_cbca_de(const uint8_t *message,
|
|
|
|
size_t length,
|
|
|
|
const uint8_t key[16],
|
|
|
|
const uint8_t ivec[16],
|
|
|
|
size_t *out_length);
|
2020-08-06 02:06:04 +03:00
|
|
|
|
2020-07-28 05:19:17 +03:00
|
|
|
#endif
|