]> git.sur5r.net Git - bacula/bacula/commitdiff
Fix OpenSSL 1.x problem in crypto.c on Fedora 12
authorKern Sibbald <kern@sibbald.com>
Wed, 3 Mar 2010 13:34:56 +0000 (14:34 +0100)
committerKern Sibbald <kern@sibbald.com>
Wed, 3 Mar 2010 13:37:27 +0000 (14:37 +0100)
bacula/autoconf/configure.in
bacula/src/lib/crypto.c

index 9d804412189fd77856475fd491934f544e8715bc..98ad8612bf4986d12efea88c77c4bbca8bb1127a 100644 (file)
@@ -1210,6 +1210,8 @@ fi
 if test "$support_crypto" = "no"; then
    OPENSSL_LIBS=""
    OPENSSL_INC=""
+else
+   AC_CHECK_LIB(ssl, EVP_PKEY_encrypt_old, AC_DEFINE(HAVE_OPENSSLv1, 1, [Set if have OpenSSL version 1.x]))
 fi  
 
 AC_MSG_RESULT([$support_tls])
@@ -3291,4 +3293,3 @@ then
        echo " upgrade it in order to avoid problems with Batch insert mode"
        echo
 fi
-
index 25b1d44a5c3a623c3acbeec5206e40147ce6eb01..fb52c254b908e976505f62597810c440776d33bf 100644 (file)
@@ -1,7 +1,7 @@
 /*
    Bacula® - The Network Backup Solution
 
-   Copyright (C) 2005-2007 Free Software Foundation Europe e.V.
+   Copyright (C) 2005-2010 Free Software Foundation Europe e.V.
 
    The main author of Bacula is Kern Sibbald, with contributions from
    many others, a complete list can be found in the file AUTHORS.
@@ -30,8 +30,6 @@
  *
  * Author: Landon Fuller <landonf@opendarwin.org>
  *
- * Version $Id$
- *
  * This file was contributed to the Bacula project by Landon Fuller.
  *
  * Landon Fuller has been granted a perpetual, worldwide, non-exclusive,
 #include "jcr.h"
 #include <assert.h>
 
+/**
+ * For OpenSSL version 1.x, EVP_PKEY_encrypt no longer
+ *  exists.  It was not an official API.
+ */
+#ifdef HAVE_OPENSSLv1
+#define EVP_PKEY_encrypt EVP_PKEY_encrypt_old
+#define EVP_PKEY_decrypt EVP_PKEY_decrypt_old
+#endif
+
 /*
  * Bacula ASN.1 Syntax
  *
@@ -309,7 +316,7 @@ typedef struct PEM_CB_Context {
  */
 static ASN1_OCTET_STRING *openssl_cert_keyid(X509 *cert) {
    X509_EXTENSION *ext;
-   X509V3_EXT_METHOD *method;
+   const X509V3_EXT_METHOD *method;
    ASN1_OCTET_STRING *keyid;
    int i;
 #if (OPENSSL_VERSION_NUMBER >= 0x0090800FL)