diff options
author | Nick Mathewson <nickm@torproject.org> | 2007-10-25 16:54:56 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2007-10-25 16:54:56 +0000 |
commit | 7da93b80ca7a6bafdc1caee71863db3eee99da4e (patch) | |
tree | 2891fc4e0e4aebb39d62f1f69a3eddf4121761a0 | |
parent | d5a0eeb57e174cd7182137928fa05a291df7a780 (diff) | |
download | tor-7da93b80ca7a6bafdc1caee71863db3eee99da4e.tar.gz tor-7da93b80ca7a6bafdc1caee71863db3eee99da4e.zip |
r16159@catbus: nickm | 2007-10-25 12:53:38 -0400
Drop support for OpenSSL 0.9.6.
svn:r12191
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | src/common/crypto.c | 18 | ||||
-rw-r--r-- | src/common/tortls.c | 9 |
3 files changed, 7 insertions, 24 deletions
@@ -1,4 +1,8 @@ Changes in version 0.2.0.10-alpha - 2007-1?-?? + o New requirements: + - Drop support for OpenSSL version 0.9.6. Just about nobody was using + it, it had no AES, and it hasn't seen any security patches since 2004. + o Minor bugfixes: - Refuse to start if both ORPort and UseBridges are set. Bugfix on 0.2.0.x. diff --git a/src/common/crypto.c b/src/common/crypto.c index f603b064a0..6c1dae9a73 100644 --- a/src/common/crypto.c +++ b/src/common/crypto.c @@ -53,15 +53,11 @@ const char crypto_c_id[] = #include "container.h" #include "compat.h" -#if OPENSSL_VERSION_NUMBER < 0x00905000l -#error "We require openssl >= 0.9.5" +#if OPENSSL_VERSION_NUMBER < 0x00907000l +#error "We require openssl >= 0.9.7" #endif -#if OPENSSL_VERSION_NUMBER < 0x00907000l -#define NO_ENGINES -#else #include <openssl/engine.h> -#endif /** Macro: is k a valid RSA public or private key? */ #define PUBLIC_KEY_OK(k) ((k) && (k)->key && (k)->key->n) @@ -153,7 +149,6 @@ crypto_log_errors(int severity, const char *doing) } } -#ifndef NO_ENGINES /** Log any OpenSSL engines we're using at NOTICE. */ static void log_engine(const char *fn, ENGINE *e) @@ -168,7 +163,6 @@ log_engine(const char *fn, ENGINE *e) log(LOG_INFO, LD_CRYPTO, "Using default implementation for %s", fn); } } -#endif /** Initialize the crypto library. Return 0 on success, -1 on failure. */ @@ -187,7 +181,6 @@ crypto_global_init(int useAccel) if (useAccel < 0) { log_info(LD_CRYPTO, "Initializing OpenSSL via tor_tls_init()."); } -#ifndef NO_ENGINES if (useAccel > 0) { log_info(LD_CRYPTO, "Initializing OpenSSL engine support."); ENGINE_load_builtin_engines(); @@ -202,7 +195,6 @@ crypto_global_init(int useAccel) log_engine("3DES", ENGINE_get_cipher_engine(NID_des_ede3_ecb)); log_engine("AES", ENGINE_get_cipher_engine(NID_aes_128_ecb)); } -#endif } return 0; } @@ -222,11 +214,9 @@ crypto_global_cleanup(void) EVP_cleanup(); ERR_remove_state(0); ERR_free_strings(); -#ifndef NO_ENGINES ENGINE_cleanup(); CONF_modules_unload(1); CRYPTO_cleanup_all_ex_data(); -#endif #ifdef TOR_IS_MULTITHREADED if (_n_openssl_mutexes) { int n = _n_openssl_mutexes; @@ -949,11 +939,7 @@ crypto_pk_asn1_decode(const char *str, size_t len) /* This ifdef suppresses a type warning. Take out the first case once * everybody is using openssl 0.9.7 or later. */ -#if OPENSSL_VERSION_NUMBER < 0x00907000l - unsigned char *cp; -#else const unsigned char *cp; -#endif cp = buf = tor_malloc(len); memcpy(buf,str,len); rsa = d2i_RSAPublicKey(NULL, &cp, len); diff --git a/src/common/tortls.c b/src/common/tortls.c index eed35cd32d..986265da9b 100644 --- a/src/common/tortls.c +++ b/src/common/tortls.c @@ -337,8 +337,7 @@ tor_tls_create_certificate(crypto_pk_env_t *rsa, #define CIPHER_LIST (TLS1_TXT_DHE_RSA_WITH_AES_128_SHA ":" \ SSL3_TXT_EDH_RSA_DES_192_CBC3_SHA) #else -/* We're running OpenSSL before 0.9.7. We only support 3DES. */ -#define CIPHER_LIST SSL3_TXT_EDH_RSA_DES_192_CBC3_SHA +#error "Tor requires OpenSSL version 0.9.7 or later, for AES support." #endif /** Create a new TLS context for use with Tor TLS handshakes. @@ -844,12 +843,6 @@ int tor_tls_get_pending_bytes(tor_tls_t *tls) { tor_assert(tls); -#if OPENSSL_VERSION_NUMBER < 0x0090700fl - if (tls->ssl->rstate == SSL_ST_READ_BODY) - return 0; - if (tls->ssl->s3->rrec.type != SSL3_RT_APPLICATION_DATA) - return 0; -#endif return SSL_pending(tls->ssl); } |