X-Git-Url: https://tinc-vpn.org/git/browse?a=blobdiff_plain;f=src%2Fcipher.h;h=116a031226c863db04247943aa073640c24dc344;hb=72091d5c770856870bb8cd51bcc5641078c7562c;hp=bbba5690bccbd95ca0e0fbb4740533775a041764;hpb=0da07280882253b792ddf9c6bd8b6690ba585b7a;p=tinc diff --git a/src/cipher.h b/src/cipher.h index bbba5690..116a0312 100644 --- a/src/cipher.h +++ b/src/cipher.h @@ -1,6 +1,9 @@ +#ifndef TINC_CIPHER_H +#define TINC_CIPHER_H + /* cipher.h -- header file cipher.c - Copyright (C) 2007-2013 Guus Sliepen + Copyright (C) 2007-2022 Guus Sliepen This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,34 +20,37 @@ 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA. */ -#ifndef __TINC_CIPHER_H__ -#define __TINC_CIPHER_H__ +#include "system.h" #define CIPHER_MAX_BLOCK_SIZE 32 #define CIPHER_MAX_IV_SIZE 16 #define CIPHER_MAX_KEY_SIZE 32 -typedef struct cipher cipher_t; - -extern cipher_t *cipher_open_by_name(const char *) __attribute__ ((__malloc__)); -extern cipher_t *cipher_open_by_nid(int) __attribute__ ((__malloc__)); -extern cipher_t *cipher_open_blowfish_ofb(void) __attribute__ ((__malloc__)); -extern void cipher_close(cipher_t *); -extern size_t cipher_keylength(const cipher_t *); -extern void cipher_get_key(const cipher_t *, void *); -extern bool cipher_set_key(cipher_t *, void *, bool) __attribute__ ((__warn_unused_result__)); -extern bool cipher_set_key_from_rsa(cipher_t *, void *, size_t, bool) __attribute__ ((__warn_unused_result__)); -extern bool cipher_set_counter(cipher_t *, const void *, size_t) __attribute__ ((__warn_unused_result__)); -extern bool cipher_set_counter_key(cipher_t *, void *) __attribute__ ((__warn_unused_result__)); -extern bool cipher_encrypt(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen, bool oneshot) __attribute__ ((__warn_unused_result__)); -extern bool cipher_decrypt(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen, bool oneshot) __attribute__ ((__warn_unused_result__)); -extern bool cipher_gcm_encrypt(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen) __attribute__ ((__warn_unused_result__)); -extern bool cipher_gcm_encrypt_start(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen) __attribute__ ((__warn_unused_result__)); -extern bool cipher_gcm_encrypt_finish(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen) __attribute__ ((__warn_unused_result__)); -extern bool cipher_gcm_decrypt(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen) __attribute__ ((__warn_unused_result__)); -extern bool cipher_gcm_decrypt_start(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen) __attribute__ ((__warn_unused_result__)); -extern bool cipher_gcm_decrypt_finish(cipher_t *, const void *indata, size_t inlen, void *outdata, size_t *outlen) __attribute__ ((__warn_unused_result__)); -extern int cipher_get_nid(const cipher_t *); -extern bool cipher_active(const cipher_t *); +#ifndef DISABLE_LEGACY +#ifdef HAVE_OPENSSL +#include "openssl/cipher.h" +#elif HAVE_LIBGCRYPT +#include "gcrypt/cipher.h" +#else +#error Incorrect cryptographic library, please reconfigure. #endif + +extern void cipher_free(cipher_t *cipher); +extern cipher_t *cipher_alloc(void) ATTR_MALLOC ATTR_DEALLOCATOR(cipher_free); +extern bool cipher_open_by_name(cipher_t *cipher, const char *name); +extern bool cipher_open_by_nid(cipher_t *cipher, nid_t nid); +extern void cipher_close(cipher_t *cipher); +extern size_t cipher_keylength(const cipher_t *cipher); +extern size_t cipher_blocksize(const cipher_t *cipher); +extern uint64_t cipher_budget(const cipher_t *cipher); +extern bool cipher_set_key(cipher_t *cipher, void *key, bool encrypt) ATTR_WARN_UNUSED; +extern bool cipher_set_key_from_rsa(cipher_t *cipher, void *rsa, size_t len, bool encrypt) ATTR_WARN_UNUSED; +extern bool cipher_encrypt(cipher_t *cipher, const void *indata, size_t inlen, void *outdata, size_t *outlen, bool oneshot) ATTR_WARN_UNUSED; +extern bool cipher_decrypt(cipher_t *cipher, const void *indata, size_t inlen, void *outdata, size_t *outlen, bool oneshot) ATTR_WARN_UNUSED; +extern nid_t cipher_get_nid(const cipher_t *cipher); +extern bool cipher_active(const cipher_t *cipher); + +#endif // DISABLE_LEGACY + +#endif // TINC_CIPHER_H