1c91307af2622f6625525f3c1f9c954376df950adChia-chi Yeh/* $NetBSD: crypto_openssl.h,v 1.5 2006/10/06 12:02:27 manu Exp $ */ 20a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 30a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* Id: crypto_openssl.h,v 1.11 2004/11/13 11:28:01 manubsd Exp */ 40a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 50a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* 60a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project. 70a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * All rights reserved. 80a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * 90a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * Redistribution and use in source and binary forms, with or without 100a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * modification, are permitted provided that the following conditions 110a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * are met: 120a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * 1. Redistributions of source code must retain the above copyright 130a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * notice, this list of conditions and the following disclaimer. 140a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * 2. Redistributions in binary form must reproduce the above copyright 150a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * notice, this list of conditions and the following disclaimer in the 160a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * documentation and/or other materials provided with the distribution. 170a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * 3. Neither the name of the project nor the names of its contributors 180a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * may be used to endorse or promote products derived from this software 190a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * without specific prior written permission. 200a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * 210a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * THIS SOFTWARE IS PROVIDED BY THE PROJECT AND CONTRIBUTORS ``AS IS'' AND 220a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 230a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 240a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * ARE DISCLAIMED. IN NO EVENT SHALL THE PROJECT OR CONTRIBUTORS BE LIABLE 250a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 260a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 270a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 280a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 290a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 300a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 310a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang * SUCH DAMAGE. 320a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang */ 330a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 340a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#ifndef _CRYPTO_OPENSSL_H 350a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define _CRYPTO_OPENSSL_H 360a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 37c91307af2622f6625525f3c1f9c954376df950adChia-chi Yeh#include "crypto_openssl.h" 38c91307af2622f6625525f3c1f9c954376df950adChia-chi Yeh 390a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#include <openssl/x509v3.h> 400a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#include <openssl/rsa.h> 410a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 420a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_OTHERNAME GEN_OTHERNAME 430a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_EMAIL GEN_EMAIL 440a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_DNS GEN_DNS 450a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_X400 GEN_X400 460a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_DIRNAME GEN_DIRNAME 470a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_EDIPARTY GEN_EDIPARTY 480a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_URI GEN_URI 490a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_IPADD GEN_IPADD 500a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define GENT_RID GEN_RID 510a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 520a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_str2asn1dn __P((const char *, int)); 530a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hex2asn1dn __P((const char *, int)); 540a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_cmp_asn1dn __P((vchar_t *, vchar_t *)); 550a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_check_x509cert __P((vchar_t *, char *, char *, int)); 560a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_get_x509asn1subjectname __P((vchar_t *)); 570a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_get_x509subjectaltname __P((vchar_t *, char **, int *, int)); 580a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern char *eay_get_x509text __P((vchar_t *)); 590a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_get_x509cert __P((char *)); 600a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_get_x509sign __P((vchar_t *, vchar_t *)); 610a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_check_x509sign __P((vchar_t *, vchar_t *, vchar_t *)); 620a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 630a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_check_rsasign __P((vchar_t *, vchar_t *, RSA *)); 640a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_get_rsasign __P((vchar_t *, RSA *)); 650a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 660a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* RSA */ 670a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_rsa_sign __P((vchar_t *, RSA *)); 680a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_rsa_verify __P((vchar_t *, vchar_t *, RSA *)); 690a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 700a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* ASN.1 */ 710a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_get_pkcs1privkey __P((char *)); 720a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_get_pkcs1pubkey __P((char *)); 730a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 740a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* string error */ 750a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern char *eay_strerror __P((void)); 760a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 770a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* OpenSSL initialization */ 780a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_init __P((void)); 790a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 800a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* Generic EVP */ 810a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *evp_crypt __P((vchar_t *data, vchar_t *key, vchar_t *iv, 820a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang const EVP_CIPHER *e, int enc)); 830a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int evp_weakkey __P((vchar_t *key, const EVP_CIPHER *e)); 840a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int evp_keylen __P((int len, const EVP_CIPHER *e)); 850a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 860a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* DES */ 870a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_des_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 880a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_des_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 890a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_des_weakkey __P((vchar_t *)); 900a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_des_keylen __P((int)); 910a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 920a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* IDEA */ 930a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_idea_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 940a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_idea_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 950a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_idea_weakkey __P((vchar_t *)); 960a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_idea_keylen __P((int)); 970a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 980a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* blowfish */ 990a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_bf_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1000a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_bf_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1010a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_bf_weakkey __P((vchar_t *)); 1020a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_bf_keylen __P((int)); 1030a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1040a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* RC5 */ 1050a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_rc5_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1060a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_rc5_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1070a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_rc5_weakkey __P((vchar_t *)); 1080a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_rc5_keylen __P((int)); 1090a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1100a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* 3DES */ 1110a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_3des_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1120a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_3des_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1130a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_3des_weakkey __P((vchar_t *)); 1140a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_3des_keylen __P((int)); 1150a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1160a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* CAST */ 1170a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_cast_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1180a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_cast_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1190a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_cast_weakkey __P((vchar_t *)); 1200a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_cast_keylen __P((int)); 1210a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1220a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* AES(RIJNDAEL) */ 1230a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_aes_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1240a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_aes_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1250a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_aes_weakkey __P((vchar_t *)); 1260a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_aes_keylen __P((int)); 1270a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1280a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#if defined(HAVE_OPENSSL_CAMELLIA_H) 1290a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* Camellia */ 1300a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_camellia_encrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1310a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_camellia_decrypt __P((vchar_t *, vchar_t *, vchar_t *)); 1320a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_camellia_weakkey __P((vchar_t *)); 1330a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_camellia_keylen __P((int)); 1340a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#endif 1350a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1360a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* misc */ 1370a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_null_keylen __P((int)); 1380a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_null_hashlen __P((void)); 1390a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_kpdk_hashlen __P((void)); 1400a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_twofish_keylen __P((int)); 1410a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1420a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* hash */ 1430a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#if defined(WITH_SHA2) 1440a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* HMAC SHA2 */ 1450a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha2_512_one __P((vchar_t *, vchar_t *)); 1460a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_hmacsha2_512_init __P((vchar_t *)); 1470a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_hmacsha2_512_update __P((caddr_t, vchar_t *)); 1480a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha2_512_final __P((caddr_t)); 1490a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha2_384_one __P((vchar_t *, vchar_t *)); 1500a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_hmacsha2_384_init __P((vchar_t *)); 1510a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_hmacsha2_384_update __P((caddr_t, vchar_t *)); 1520a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha2_384_final __P((caddr_t)); 1530a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha2_256_one __P((vchar_t *, vchar_t *)); 1540a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_hmacsha2_256_init __P((vchar_t *)); 1550a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_hmacsha2_256_update __P((caddr_t, vchar_t *)); 1560a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha2_256_final __P((caddr_t)); 1570a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#endif 1580a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* HMAC SHA1 */ 1590a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha1_one __P((vchar_t *, vchar_t *)); 1600a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_hmacsha1_init __P((vchar_t *)); 1610a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_hmacsha1_update __P((caddr_t, vchar_t *)); 1620a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacsha1_final __P((caddr_t)); 1630a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* HMAC MD5 */ 1640a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacmd5_one __P((vchar_t *, vchar_t *)); 1650a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_hmacmd5_init __P((vchar_t *)); 1660a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_hmacmd5_update __P((caddr_t, vchar_t *)); 1670a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_hmacmd5_final __P((caddr_t)); 1680a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1690a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#if defined(WITH_SHA2) 1700a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* SHA2 functions */ 1710a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_sha2_512_init __P((void)); 1720a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_sha2_512_update __P((caddr_t, vchar_t *)); 1730a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha2_512_final __P((caddr_t)); 1740a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha2_512_one __P((vchar_t *)); 1750a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#endif 1760a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_sha2_512_hashlen __P((void)); 1770a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1780a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#if defined(WITH_SHA2) 1790a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_sha2_384_init __P((void)); 1800a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_sha2_384_update __P((caddr_t, vchar_t *)); 1810a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha2_384_final __P((caddr_t)); 1820a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha2_384_one __P((vchar_t *)); 1830a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#endif 1840a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_sha2_384_hashlen __P((void)); 1850a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1860a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#if defined(WITH_SHA2) 1870a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_sha2_256_init __P((void)); 1880a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_sha2_256_update __P((caddr_t, vchar_t *)); 1890a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha2_256_final __P((caddr_t)); 1900a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha2_256_one __P((vchar_t *)); 1910a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#endif 1920a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_sha2_256_hashlen __P((void)); 1930a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 1940a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* SHA functions */ 1950a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_sha1_init __P((void)); 1960a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_sha1_update __P((caddr_t, vchar_t *)); 1970a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha1_final __P((caddr_t)); 1980a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_sha1_one __P((vchar_t *)); 1990a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_sha1_hashlen __P((void)); 2000a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2010a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* MD5 functions */ 2020a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern caddr_t eay_md5_init __P((void)); 2030a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern void eay_md5_update __P((caddr_t, vchar_t *)); 2040a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_md5_final __P((caddr_t)); 2050a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_md5_one __P((vchar_t *)); 2060a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_md5_hashlen __P((void)); 2070a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2080a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* RNG */ 2090a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern vchar_t *eay_set_random __P((u_int32_t)); 2100a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern u_int32_t eay_random __P((void)); 2110a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2120a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* DH */ 2130a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_dh_generate __P((vchar_t *, u_int32_t, u_int, vchar_t **, vchar_t **)); 2140a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_dh_compute __P((vchar_t *, u_int32_t, vchar_t *, vchar_t *, vchar_t *, vchar_t **)); 2150a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2160a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* Base 64 */ 2170a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangvchar_t *base64_encode(char *in, long inlen); 2180a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangvchar_t *base64_decode(char *in, long inlen); 2190a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2200a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih WangRSA *base64_pubkey2rsa(char *in); 2210a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih WangRSA *bignum_pubkey2rsa(BIGNUM *in); 2220a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2230a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang/* misc */ 2240a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_revbnl __P((vchar_t *)); 2250a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#include <openssl/bn.h> 2260a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_v2bn __P((BIGNUM **, vchar_t *)); 2270a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern int eay_bn2v __P((vchar_t **, BIGNUM *)); 2280a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2290a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wangextern const char *eay_version __P((void)); 2300a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2310a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define CBC_BLOCKLEN 8 2320a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#define IPSEC_ENCRYPTKEYLEN 8 2330a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang 2340a1907d434839af6a9cb6329bbde60b237bf53dcChung-yih Wang#endif /* _CRYPTO_OPENSSL_H */ 235