/* * crypt.h: header for crypt.c * * Written By Michael Sandrof * * Copyright (c) 1990 Michael Sandrof. * Copyright (c) 1991, 1992 Troy Rollo. * Copyright (c) 1992-2003 Matthew R. Green. * 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 of the author may not be used to endorse or promote products * derived from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS OR * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. * IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY DIRECT, INDIRECT, * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF * SUCH DAMAGE. * * @(#)$Id: crypt.h,v 1.7 2003/01/08 20:00:54 f Exp $ */ #ifndef __crypt_h_ #define __crypt_h_ #define CTCP_SHUTUP 0 #define CTCP_VERBOSE 1 #define CTCP_NOREPLY 2 /* * crypt interface */ typedef struct crypt_key crypt_key; typedef int (*CryptFunc) _((crypt_key *, u_char **, int *)); struct crypt_key { u_char *key; char *type; CryptFunc crypt; CryptFunc decrypt; void *cookie; /* cipher dependant cookie, will be freed */ }; /* * function interfaces we have */ u_char *crypt_msg _((u_char *, crypt_key *, int)); void encrypt_cmd _((u_char *, u_char *, u_char *)); crypt_key *is_crypted _((u_char *)); /* * the ciphers we support */ #define CAST_STRING UP("CAST128ED-CBC") #define SED_STRING UP("SED") #define RIJNDAEL_STRING UP("RIJNDAEL") #define DEFAULT_CRYPTER cast_encrypt_str #define DEFAULT_DECRYPTER cast_decrypt_str #define DEFAULT_CRYPTYPE CAST_STRING #endif /* _crypt_h_ */