1998-12-21 11:52:47 +01:00
|
|
|
/* NOCW */
|
|
|
|
/*
|
|
|
|
Please read the README file for condition of use, before
|
|
|
|
using this software.
|
|
|
|
|
|
|
|
Maurice Gittens <mgittens@gits.nl> January 1997
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <netinet/in.h>
|
|
|
|
#include <fcntl.h>
|
|
|
|
#include <strings.h>
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
1999-04-24 00:13:45 +02:00
|
|
|
#include <openssl/rsa.h>
|
|
|
|
#include <openssl/evp.h>
|
|
|
|
#include <openssl/objects.h>
|
|
|
|
#include <openssl/x509.h>
|
|
|
|
#include <openssl/err.h>
|
|
|
|
#include <openssl/pem.h>
|
|
|
|
#include <openssl/ssl.h>
|
1998-12-21 11:52:47 +01:00
|
|
|
|
|
|
|
EVP_PKEY * ReadPublicKey(const char *certfile)
|
|
|
|
{
|
|
|
|
FILE *fp = fopen (certfile, "r");
|
|
|
|
X509 *x509;
|
|
|
|
EVP_PKEY *pkey;
|
|
|
|
|
|
|
|
if (!fp)
|
|
|
|
return NULL;
|
|
|
|
|
2001-09-28 03:48:34 +02:00
|
|
|
x509 = PEM_read_X509(fp, NULL, 0, NULL);
|
1998-12-21 11:52:47 +01:00
|
|
|
|
|
|
|
if (x509 == NULL)
|
|
|
|
{
|
|
|
|
ERR_print_errors_fp (stderr);
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
fclose (fp);
|
|
|
|
|
|
|
|
pkey=X509_extract_key(x509);
|
|
|
|
|
|
|
|
X509_free(x509);
|
|
|
|
|
|
|
|
if (pkey == NULL)
|
|
|
|
ERR_print_errors_fp (stderr);
|
|
|
|
|
|
|
|
return pkey;
|
|
|
|
}
|
|
|
|
|
|
|
|
EVP_PKEY *ReadPrivateKey(const char *keyfile)
|
|
|
|
{
|
|
|
|
FILE *fp = fopen(keyfile, "r");
|
|
|
|
EVP_PKEY *pkey;
|
|
|
|
|
|
|
|
if (!fp)
|
|
|
|
return NULL;
|
|
|
|
|
2001-09-28 03:48:34 +02:00
|
|
|
pkey = PEM_read_PrivateKey(fp, NULL, 0, NULL);
|
1998-12-21 11:52:47 +01:00
|
|
|
|
|
|
|
fclose (fp);
|
|
|
|
|
|
|
|
if (pkey == NULL)
|
|
|
|
ERR_print_errors_fp (stderr);
|
|
|
|
|
|
|
|
return pkey;
|
|
|
|
}
|
|
|
|
|
|
|
|
|