/* This file is part of libbrandt. * Copyright (C) 2016 GNUnet e.V. * * libbrandt is free software: you can redistribute it and/or modify it under * the terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or (at your option) any later * version. * * libbrandt is distributed in the hope that it will be useful, but WITHOUT ANY * WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR * A PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with * libbrandt. If not, see . */ /** * @file crypto.h * @brief Interface of the crypto primitives. */ #ifndef _BRANDT_CRYPTO_H #define _BRANDT_CRYPTO_H #include #include void brandt_crypto_init (); /* --- RANDOM --- */ void brandt_rand_poll (); /* --- HASHING --- */ struct brandt_hash_code { uint32_t bits[512 / 8 / sizeof (uint32_t)]; /* = 16 */ }; void brandt_hash (const void *block, size_t size, struct brandt_hash_code *ret); /* --- MPI --- */ void brandt_mpi_print_unsigned (void *buf, size_t size, gcry_mpi_t val); void brandt_mpi_scan_unsigned (gcry_mpi_t *result, const void *data, size_t size); /* --- EC --- */ void brandt_ec_skey_create (gcry_mpi_t *skey); void brandt_ec_pkey_compute (gcry_mpi_point_t *pkey, const gcry_mpi_t skey); void brandt_ec_keypair_create (gcry_mpi_point_t *pkey, gcry_mpi_t *skey); void brandt_ec_keypair_create_base (gcry_mpi_point_t *pkey, gcry_mpi_t *skey, const gcry_mpi_point_t base); int brandt_ec_point_cmp (const gcry_mpi_point_t a, const gcry_mpi_point_t b); #endif /* ifndef _BRANDT_CRYPTO_H */