/* ppp-crypo-priv.h - Crypto private data structures * * Copyright (c) 2022 Eivind Næss. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * 1. Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in * the documentation and/or other materials provided with the * distribution. * * 3. The name(s) of the authors of this software must not be used to * endorse or promote products derived from this software without * prior written permission. * * THE AUTHORS OF THIS SOFTWARE DISCLAIM ALL WARRANTIES WITH REGARD TO * THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY * AND FITNESS, IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY * SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN * AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING * OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ #ifndef PPP_CRYPTO_PRIV_H #define PPP_CRYPTO_PRIV_H #include "crypto.h" #define MAX_KEY_SIZE 32 #define MAX_IV_SIZE 32 struct _PPP_MD { int (*init_fn)(PPP_MD_CTX *ctx); int (*update_fn)(PPP_MD_CTX *ctx, const void *data, size_t cnt); int (*final_fn)(PPP_MD_CTX *ctx, unsigned char *out, unsigned int *outlen); void (*clean_fn)(PPP_MD_CTX *ctx); }; struct _PPP_MD_CTX { PPP_MD md; void *priv; }; struct _PPP_CIPHER { int (*init_fn)(PPP_CIPHER_CTX *ctx, const unsigned char *key, const unsigned char *iv); int (*update_fn)(PPP_CIPHER_CTX *ctx, unsigned char *out, int *outl, const unsigned char *in, int inl); int (*final_fn)(PPP_CIPHER_CTX *ctx, unsigned char *out, int *outl); void (*clean_fn)(PPP_CIPHER_CTX *ctx); }; struct _PPP_CIPHER_CTX { PPP_CIPHER cipher; unsigned char key[MAX_KEY_SIZE]; unsigned char iv[MAX_IV_SIZE]; int is_encr; void *priv; }; #endif