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