diff options
author | Andreas Baumann <mail@andreasbaumann.cc> | 2015-01-03 13:58:15 +0100 |
---|---|---|
committer | Andreas Baumann <mail@andreasbaumann.cc> | 2015-01-03 13:58:15 +0100 |
commit | 4aca87515a5083ae0e31ce3177189fd43b6d05ac (patch) | |
tree | 7b1d9a31393ca090757dc6f0d3859b4fcd93f271 /release/src/router/matrixssl/src/crypto/matrixCrypto.h | |
parent | 008d0be72b2f160382c6e880765e96b64a050c65 (diff) | |
download | tomato-4aca87515a5083ae0e31ce3177189fd43b6d05ac.tar.gz tomato-4aca87515a5083ae0e31ce3177189fd43b6d05ac.tar.bz2 |
patch to Vanilla Tomato 1.28
Diffstat (limited to 'release/src/router/matrixssl/src/crypto/matrixCrypto.h')
-rw-r--r-- | release/src/router/matrixssl/src/crypto/matrixCrypto.h | 145 |
1 files changed, 145 insertions, 0 deletions
diff --git a/release/src/router/matrixssl/src/crypto/matrixCrypto.h b/release/src/router/matrixssl/src/crypto/matrixCrypto.h new file mode 100644 index 00000000..58f45f3d --- /dev/null +++ b/release/src/router/matrixssl/src/crypto/matrixCrypto.h @@ -0,0 +1,145 @@ +/* + * matrixCrypto.h + * Release $Name: MATRIXSSL_1_8_8_OPEN $ + * + * Public API set for matrixCrypto + */ +/* + * Copyright (c) PeerSec Networks, 2002-2009. All Rights Reserved. + * The latest version of this code is available at http://www.matrixssl.org + * + * This software is open source; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 2 of the License, or + * (at your option) any later version. + * + * This General Public License does NOT permit incorporating this software + * into proprietary programs. If you are unable to comply with the GPL, a + * commercial license for this software may be purchased from PeerSec Networks + * at http://www.peersec.com + * + * This program is distributed in WITHOUT ANY WARRANTY; without even the + * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. + * See the GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software + * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA + * http://www.gnu.org/copyleft/gpl.html + */ +/******************************************************************************/ + +#ifndef _h_MATRIX_CRYPTO +#define _h_MATRIX_CRYPTO + +#ifdef __cplusplus +extern "C" { +#endif + +#include "../../matrixCommon.h" + +/* + User application. Now include cryptoLayer to get the proper algorithm + defines so we know what API set to expose +*/ +#include "cryptoLayer.h" + +/******************************************************************************/ + + +MATRIXPUBLIC int32 matrixGetRandomBytes(unsigned char *bytes, int32 size); + +#ifdef USE_ARC4 +MATRIXPUBLIC void matrixArc4Init(sslCipherContext_t *ctx, unsigned char *key, + int32 keylen); +MATRIXPUBLIC int32 matrixArc4(sslCipherContext_t *ctx, unsigned char *in, + unsigned char *out, int32 len); +#endif /* USE_ARC4 */ + +#ifdef USE_3DES +MATRIXPUBLIC int32 matrix3desInit(sslCipherContext_t *ctx, unsigned char *IV, + unsigned char *key, int32 keylen); +MATRIXPUBLIC int32 matrix3desEncrypt(sslCipherContext_t *ctx, unsigned char *pt, + unsigned char *ct, int32 len); +MATRIXPUBLIC int32 matrix3desDecrypt(sslCipherContext_t *ctx, unsigned char *ct, + unsigned char *pt, int32 len); +MATRIXPUBLIC void generate3DESKey(unsigned char *pass, int32 passlen, + unsigned char *salt, unsigned char *key); +#endif /* USE_3DES */ + + + +/* + HMAC and message digests +*/ +MATRIXPUBLIC int32 matrixHmacMd5(unsigned char *key, int32 keyLen, + const unsigned char *buf, unsigned long len, + unsigned char *hash, unsigned char *hmacKey, + int32 *hmacKeyLen); +MATRIXPUBLIC void matrixHmacMd5Init(sslHmacContext_t *ctx, + unsigned char *key, int32 keyLen); +MATRIXPUBLIC void matrixHmacMd5Update(sslHmacContext_t *ctx, + const unsigned char *buf, unsigned long len); +MATRIXPUBLIC int32 matrixHmacMd5Final(sslHmacContext_t *ctx, + unsigned char *hash); + +MATRIXPUBLIC int32 matrixHmacSha1(unsigned char *key, int32 keyLen, + const unsigned char *buf, unsigned long len, + unsigned char *hash, unsigned char *hmacKey, + int32 *hmacKeyLen); +MATRIXPUBLIC void matrixHmacSha1Init(sslHmacContext_t *ctx, + unsigned char *key, int32 keyLen); +MATRIXPUBLIC void matrixHmacSha1Update(sslHmacContext_t *ctx, + const unsigned char *buf, unsigned long len); +MATRIXPUBLIC int32 matrixHmacSha1Final(sslHmacContext_t *ctx, + unsigned char *hash); + +MATRIXPUBLIC void matrixSha1Init(sslSha1Context_t *ctx); +MATRIXPUBLIC void matrixSha1Update(sslSha1Context_t *ctx, + const unsigned char *buf, unsigned long len); +MATRIXPUBLIC int32 matrixSha1Final(sslSha1Context_t *ctx, unsigned char *hash); + + +MATRIXPUBLIC void matrixMd5Init(sslMd5Context_t *ctx); +MATRIXPUBLIC void matrixMd5Update(sslMd5Context_t *ctx, + const unsigned char *buf, unsigned long len); +MATRIXPUBLIC int32 matrixMd5Final(sslMd5Context_t *ctx, unsigned char *hash); + + +#ifdef USE_MD2 +/* + MD2 is provided for compatibility with V2 and older X509 certificates, + it is known to have security problems and should not be used for any current + development. +*/ +MATRIXPUBLIC void matrixMd2Init(sslMd2Context_t *ctx); +MATRIXPUBLIC int32 matrixMd2Update(sslMd2Context_t *ctx, + const unsigned char *buf, unsigned long len); +MATRIXPUBLIC int32 matrixMd2Final(sslMd2Context_t *ctx, unsigned char *hash); +#endif /* USE_MD2 */ + + + + +#ifdef USE_RSA +MATRIXPUBLIC int32 matrixRsaEncryptPub(psPool_t *pool, sslRsaKey_t *key, + unsigned char *in, int32 inlen, + unsigned char *out, int32 outlen); +MATRIXPUBLIC int32 matrixRsaDecryptPriv(psPool_t *pool, sslRsaKey_t *key, + unsigned char *in, int32 inlen, + unsigned char *out, int32 outlen); +MATRIXPUBLIC int32 matrixRsaDecryptPub(psPool_t *pool, sslRsaKey_t *key, + unsigned char *in, int32 inlen, + unsigned char *out, int32 outlen); +#endif /* USE_RSA */ + + + + +#ifdef __cplusplus +} +#endif + +#endif /* _h_MATRIX_CRYPTO */ + +/******************************************************************************/ |