- Always use <openssl/include.h> instead of just <include.h>

- Check if RAND_pseudo_bytes() exists, otherwise just use RAND_bytes()
This commit is contained in:
Guus Sliepen 2001-07-04 08:41:36 +00:00
parent 6bd93e4c06
commit 1e2bdc2b6d
5 changed files with 31 additions and 83 deletions

View file

@ -29,6 +29,8 @@ AC_DEFUN(tinc_OPENSSL,
[AC_MSG_ERROR("OpenSSL libraries not found.")] [AC_MSG_ERROR("OpenSSL libraries not found.")]
) )
AC_CHECK_FUNCS(RAND_pseudo_bytes)
AC_CHECK_FUNC(dlopen, AC_CHECK_FUNC(dlopen,
[], [],
AC_CHECK_LIB(dl, dlopen, AC_CHECK_LIB(dl, dlopen,

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: meta.c,v 1.1.2.18 2001/05/25 11:54:28 guus Exp $ $Id: meta.c,v 1.1.2.19 2001/07/04 08:41:36 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -32,11 +32,7 @@
/* This line must be below the rest for FreeBSD */ /* This line must be below the rest for FreeBSD */
#include <sys/socket.h> #include <sys/socket.h>
#ifdef HAVE_OPENSSL_EVP_H #include <openssl/evp.h>
# include <openssl/evp.h>
#else
# include <evp.h>
#endif
#include "net.h" #include "net.h"
#include "connection.h" #include "connection.h"

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: net.c,v 1.35.4.117 2001/06/29 10:30:18 guus Exp $ $Id: net.c,v 1.35.4.118 2001/07/04 08:41:36 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -45,28 +45,12 @@
#include <sys/socket.h> #include <sys/socket.h>
#include <net/if.h> #include <net/if.h>
#ifdef HAVE_OPENSSL_RAND_H #include <openssl/rand.h>
# include <openssl/rand.h> #include <openssl/evp.h>
#else #include <openssl/pem.h>
# include <rand.h>
#endif
#ifdef HAVE_OPENSSL_EVP_H #ifndef HAVE_RAND_PSEUDO_BYTES
# include <openssl/evp.h> #define RAND_pseudo_bytes RAND_bytes
#else
# include <evp.h>
#endif
#ifdef HAVE_OPENSSL_ERR_H
# include <openssl/err.h>
#else
# include <err.h>
#endif
#ifdef HAVE_OPENSSL_PEM_H
# include <openssl/pem.h>
#else
# include <pem.h>
#endif #endif
#ifdef HAVE_TUNTAP #ifdef HAVE_TUNTAP
@ -134,7 +118,7 @@ cp
/* Encrypt the packet. */ /* Encrypt the packet. */
RAND_bytes(inpkt->salt, sizeof(inpkt->salt)); RAND_pseudo_bytes(inpkt->salt, sizeof(inpkt->salt));
EVP_EncryptInit(&ctx, cl->cipher_pkttype, cl->cipher_pktkey, cl->cipher_pktkey + cl->cipher_pkttype->key_len); EVP_EncryptInit(&ctx, cl->cipher_pkttype, cl->cipher_pktkey, cl->cipher_pktkey + cl->cipher_pkttype->key_len);
EVP_EncryptUpdate(&ctx, outpkt.salt, &outlen, inpkt->salt, inpkt->len + sizeof(inpkt->salt)); EVP_EncryptUpdate(&ctx, outpkt.salt, &outlen, inpkt->salt, inpkt->len + sizeof(inpkt->salt));
@ -344,12 +328,12 @@ cp
/* Set default MAC address for ethertap devices */ /* Set default MAC address for ethertap devices */
mymac.type = SUBNET_MAC; mymac.type = SUBNET_MAC;
mymac.net.mac.address.x[0] = 0xff; mymac.net.mac.address.x[0] = 0xfe;
mymac.net.mac.address.x[1] = 0xff; mymac.net.mac.address.x[1] = 0xfd;
mymac.net.mac.address.x[2] = 0xff; mymac.net.mac.address.x[2] = 0x00;
mymac.net.mac.address.x[3] = 0xff; mymac.net.mac.address.x[3] = 0x00;
mymac.net.mac.address.x[4] = 0xff; mymac.net.mac.address.x[4] = 0x00;
mymac.net.mac.address.x[5] = 0xff; mymac.net.mac.address.x[5] = 0x00;
#ifdef HAVE_LINUX #ifdef HAVE_LINUX
#ifdef HAVE_TUNTAP #ifdef HAVE_TUNTAP
@ -366,8 +350,7 @@ cp
taptype = TAP_TYPE_TUNTAP; taptype = TAP_TYPE_TUNTAP;
} }
#endif #endif
#endif #else
#ifdef HAVE_FREEBSD
taptype = TAP_TYPE_TUNTAP; taptype = TAP_TYPE_TUNTAP;
#endif #endif
cp cp
@ -1427,7 +1410,7 @@ cp
if(debug_lvl >= DEBUG_STATUS) if(debug_lvl >= DEBUG_STATUS)
syslog(LOG_INFO, _("Regenerating symmetric key")); syslog(LOG_INFO, _("Regenerating symmetric key"));
RAND_bytes(myself->cipher_pktkey, myself->cipher_pktkeylength); RAND_pseudo_bytes(myself->cipher_pktkey, myself->cipher_pktkeylength);
send_key_changed(myself, NULL); send_key_changed(myself, NULL);
keyexpires = time(NULL) + keylifetime; keyexpires = time(NULL) + keylifetime;
} }

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: protocol.c,v 1.28.4.97 2001/07/01 21:42:13 guus Exp $ $Id: protocol.c,v 1.28.4.98 2001/07/04 08:41:36 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -40,25 +40,14 @@
#include <netinet/in.h> #include <netinet/in.h>
#ifdef HAVE_OPENSSL_SHA_H #include <openssl/sha.h>
# include <openssl/sha.h> #include <openssl/rand.h>
#else #include <openssl/evp.h>
# include <sha.h>
#endif
#ifdef HAVE_OPENSSL_RAND_H #ifndef HAVE_RAND_PSEUDO_BYTES
# include <openssl/rand.h> #define RAND_pseudo_bytes RAND_bytes
#else
# include <rand.h>
#endif #endif
#ifdef HAVE_OPENSSL_EVP_H
# include <openssl/evp.h>
#else
# include <evp.h>
#endif
#include "conf.h" #include "conf.h"
#include "net.h" #include "net.h"
#include "netutl.h" #include "netutl.h"
@ -1066,7 +1055,7 @@ int send_ping(connection_t *cl)
cp cp
cl->status.pinged = 1; cl->status.pinged = 1;
cl->last_ping_time = time(NULL); cl->last_ping_time = time(NULL);
RAND_bytes(salt, SALTLEN); RAND_pseudo_bytes(salt, SALTLEN);
bin2hex(salt, salt, SALTLEN); bin2hex(salt, salt, SALTLEN);
salt[SALTLEN*2] = '\0'; salt[SALTLEN*2] = '\0';
cp cp
@ -1083,7 +1072,7 @@ int send_pong(connection_t *cl)
{ {
char salt[SALTLEN*2+1]; char salt[SALTLEN*2+1];
cp cp
RAND_bytes(salt, SALTLEN); RAND_pseudo_bytes(salt, SALTLEN);
bin2hex(salt, salt, SALTLEN); bin2hex(salt, salt, SALTLEN);
salt[SALTLEN*2] = '\0'; salt[SALTLEN*2] = '\0';
cp cp

View file

@ -17,7 +17,7 @@
along with this program; if not, write to the Free Software along with this program; if not, write to the Free Software
Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
$Id: tincd.c,v 1.10.4.47 2001/06/05 16:09:55 guus Exp $ $Id: tincd.c,v 1.10.4.48 2001/07/04 08:41:36 guus Exp $
*/ */
#include "config.h" #include "config.h"
@ -38,31 +38,9 @@
# include <sys/ioctl.h> # include <sys/ioctl.h>
#endif #endif
#ifdef HAVE_OPENSSL_RAND_H #include <openssl/rand.h>
# include <openssl/rand.h> #include <openssl/rsa.h>
#else #include <openssl/pem.h>
# include <rand.h>
#endif
#ifdef HAVE_OPENSSL_RSA_H
# include <openssl/rsa.h>
#else
# include <rsa.h>
#endif
#ifdef HAVE_OPENSSL_ERR_H
# include <openssl/err.h>
#else
# include <err.h>
#endif
#ifdef HAVE_OPENSSL_PEM_H
# include <openssl/pem.h>
#else
# include <pem.h>
#endif
#include <utils.h> #include <utils.h>
#include <xalloc.h> #include <xalloc.h>