1999-10-27 03:42:43 +00:00
|
|
|
/*
|
1999-11-24 13:26:21 +00:00
|
|
|
*
|
|
|
|
* rsa.h
|
|
|
|
*
|
|
|
|
* Author: Tatu Ylonen <ylo@cs.hut.fi>
|
|
|
|
*
|
|
|
|
* Copyright (c) 1995 Tatu Ylonen <ylo@cs.hut.fi>, Espoo, Finland
|
|
|
|
* All rights reserved
|
|
|
|
*
|
|
|
|
* Created: Fri Mar 3 22:01:06 1995 ylo
|
|
|
|
*
|
|
|
|
* RSA key generation, encryption and decryption.
|
|
|
|
*
|
1999-10-27 03:42:43 +00:00
|
|
|
*/
|
|
|
|
|
2000-01-29 09:40:22 +00:00
|
|
|
/* RCSID("$Id: rsa.h,v 1.6 2000/01/29 09:40:22 damien Exp $"); */
|
1999-10-27 03:42:43 +00:00
|
|
|
|
|
|
|
#ifndef RSA_H
|
|
|
|
#define RSA_H
|
|
|
|
|
1999-11-24 13:26:21 +00:00
|
|
|
#include "config.h"
|
|
|
|
|
1999-10-28 03:25:17 +00:00
|
|
|
#ifdef HAVE_OPENSSL
|
1999-10-27 03:42:43 +00:00
|
|
|
#include <openssl/bn.h>
|
|
|
|
#include <openssl/rsa.h>
|
2000-01-29 09:40:22 +00:00
|
|
|
#include <openssl/rand.h>
|
1999-10-28 03:25:17 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef HAVE_SSL
|
|
|
|
#include <ssl/bn.h>
|
|
|
|
#include <ssl/rsa.h>
|
2000-01-29 09:40:22 +00:00
|
|
|
#include <ssl/rand.h>
|
1999-10-28 03:25:17 +00:00
|
|
|
#endif
|
1999-10-27 03:42:43 +00:00
|
|
|
|
|
|
|
/* Calls SSL RSA_generate_key, only copies to prv and pub */
|
1999-11-24 13:26:21 +00:00
|
|
|
void rsa_generate_key(RSA * prv, RSA * pub, unsigned int bits);
|
1999-10-27 03:42:43 +00:00
|
|
|
|
1999-11-25 00:54:57 +00:00
|
|
|
/*
|
|
|
|
* Indicates whether the rsa module is permitted to show messages on the
|
|
|
|
* terminal.
|
|
|
|
*/
|
1999-11-24 13:26:21 +00:00
|
|
|
void rsa_set_verbose __P((int verbose));
|
1999-10-27 03:42:43 +00:00
|
|
|
|
1999-11-24 13:26:21 +00:00
|
|
|
int rsa_alive __P((void));
|
1999-10-27 03:42:43 +00:00
|
|
|
|
1999-11-24 13:26:21 +00:00
|
|
|
void rsa_public_encrypt __P((BIGNUM * out, BIGNUM * in, RSA * prv));
|
|
|
|
void rsa_private_decrypt __P((BIGNUM * out, BIGNUM * in, RSA * prv));
|
1999-10-27 03:42:43 +00:00
|
|
|
|
1999-11-24 13:26:21 +00:00
|
|
|
#endif /* RSA_H */
|