Go to file
Matt Caswell e70656cf1c Ensure SSL_set_session clears the old session from cache if it is bad
SSL_clear() and SSL_free() will remove a session from the cache if it is
considered "bad". However SSL_set_session() does not do this for the session
it is replacing.

SSL_clear() clears an SSL object ready for reuse. It does not clear the
session though. This means that:

  SSL_clear(s)
  SSL_set_session(s, sess);

and
  SSL_set_session(s, sess);
  SSL_clear(s);

do not do the same thing, although logically you would expect that they
would.

The failure of SSL_set_session() to remove bad sessions from the cache
should be considered a bug, so this commit fixes it.

RT#597

Reviewed-by: Rich Salz <rsalz@openssl.org>
2016-06-13 17:35:18 +01:00
apps RT3809: basicConstraints is critical 2016-06-13 09:18:22 -04:00
Configurations Omit corpora from tarball. 2016-06-10 13:00:31 +01:00
crypto bn/bn_add.c: favour counted loops over ifs and breaks. 2016-06-13 12:35:39 +02:00
demos
doc RT3809: basicConstraints is critical 2016-06-13 09:18:22 -04:00
engines Handle inability to create AFALG socket 2016-06-13 17:28:40 +01:00
external/perl
fuzz include stdlib for malloc() and free() 2016-06-11 16:43:49 +02:00
include Make a2i_ipadd an internal function 2016-06-09 17:15:42 -04:00
ms Add final(?) set of copyrights. 2016-06-01 11:27:25 -04:00
os-dep
ssl Ensure SSL_set_session clears the old session from cache if it is bad 2016-06-13 17:35:18 +01:00
test SSL test: only write out server2 when testing SNI 2016-06-13 18:31:33 +02:00
tools GH1123: sort dir before rehash 2016-06-02 15:12:50 -04:00
util Make a2i_ipadd an internal function 2016-06-09 17:15:42 -04:00
VMS
.gitattributes Make corpora binary. 2016-06-10 13:00:31 +01:00
.gitignore Add some accessor API's 2016-06-08 11:37:06 -04:00
.travis-create-release.sh
.travis.yml Travis: update sanitizer configs 2016-05-30 18:47:32 +02:00
ACKNOWLEDGEMENTS
appveyor.yml
AUTHORS
build.info
CHANGES Deprecate the flags that switch off constant time 2016-06-06 11:09:06 +01:00
config Add final(?) set of copyrights. 2016-06-01 11:27:25 -04:00
config.com Add final(?) set of copyrights. 2016-06-01 11:27:25 -04:00
Configure Configure: complete the changed fuzz option checks 2016-06-05 21:38:59 +02:00
CONTRIBUTING Add a paragraph on documentation to CONTRIBUTING 2016-06-03 17:10:16 +01:00
e_os.h Fix strdup macro redefinition 2016-05-30 09:51:31 -04:00
FAQ
INSTALL Update INSTALL instructions 2016-06-03 17:24:50 +01:00
LICENSE
Makefile.shared Makefile.shared: revert Haiku support commit. 2016-05-25 23:47:55 +02:00
NEWS
NOTES.DJGPP
NOTES.PERL Tweaks to NOTES.PERL 2016-06-03 17:10:16 +01:00
NOTES.VMS
NOTES.WIN NOTES.WIN: use secure urls 2016-06-06 10:03:55 -04:00
README Bring the README file up to date 2016-06-03 17:10:16 +01:00
README.ECC
README.ENGINE
README.FIPS

 OpenSSL 1.1.0-pre6-dev

 Copyright (c) 1998-2016 The OpenSSL Project
 Copyright (c) 1995-1998 Eric A. Young, Tim J. Hudson
 All rights reserved.

 DESCRIPTION
 -----------

 The OpenSSL Project is a collaborative effort to develop a robust,
 commercial-grade, fully featured, and Open Source toolkit implementing the
 Transport Layer Security (TLS) protocols (including SSLv3) as well as a
 full-strength general purpose cryptographic library.

 OpenSSL is descended from the SSLeay library developed by Eric A. Young
 and Tim J. Hudson.  The OpenSSL toolkit is licensed under a dual-license (the
 OpenSSL license plus the SSLeay license), which means that you are free to
 get and use it for commercial and non-commercial purposes as long as you
 fulfill the conditions of both licenses.

 OVERVIEW
 --------

 The OpenSSL toolkit includes:

 libssl (with platform specific naming):
     Provides the client and server-side implementations for SSLv3 and TLS.

 libcrypto (with platform specific naming):
     Provides general cryptographic and X.509 support needed by SSL/TLS but
     not logically part of it.

 openssl:
     A command line tool that can be used for:
        Creation of key parameters
        Creation of X.509 certificates, CSRs and CRLs
        Calculation of message digests
        Encryption and decryption
        SSL/TLS client and server tests
        Handling of S/MIME signed or encrypted mail
        And more...

 INSTALLATION
 ------------

 See the appropriate file:
        INSTALL         Linux, Unix, Windows, OpenVMS, ...
        NOTES.*         INSTALL addendums for different platforms

 SUPPORT
 -------

 See the OpenSSL website www.openssl.org for details on how to obtain
 commercial technical support. Free community support is available through the
 openssl-users email list (see
 https://www.openssl.org/community/mailinglists.html for further details).

 If you have any problems with OpenSSL then please take the following steps
 first:

    - Download the current snapshot from ftp://ftp.openssl.org/snapshot/
      to see if the problem has already been addressed
    - Remove ASM versions of libraries
    - Remove compiler optimisation flags

 If you wish to report a bug then please include the following information in
 any bug report:

    - OpenSSL version: output of 'openssl version -a'
    - Any "Configure" options that you selected during compilation of the
      library if applicable (see INSTALL)
    - OS Name, Version, Hardware platform
    - Compiler Details (name, version)
    - Application Details (name, version)
    - Problem Description (steps that will reproduce the problem, if known)
    - Stack Traceback (if the application dumps core)

 Email the report to:

    rt@openssl.org

 In order to avoid spam, this is a moderated mailing list, and it might
 take a couple of days for the ticket to show up.  (We also scan posts to make
 sure that security disclosures aren't publically posted by mistake.) Mail
 to this address is recorded in the public RT (request tracker) database
 (see https://www.openssl.org/community/index.html#bugs for details) and
 also forwarded the public openssl-dev mailing list.  Confidential mail
 may be sent to openssl-security@openssl.org (PGP key available from the
 key servers).

 Please do NOT use this for general assistance or support queries.
 Just because something doesn't work the way you expect does not mean it
 is necessarily a bug in OpenSSL. Use the openssl-users email list for this type
 of query.

 You can also make GitHub pull requests. See the CONTRIBUTING file for more
 details.

 HOW TO CONTRIBUTE TO OpenSSL
 ----------------------------

 See CONTRIBUTING

 LEGALITIES
 ----------

 A number of nations, in particular the U.S., restrict the use or export
 of cryptography. If you are potentially subject to such restrictions
 you should seek competent professional legal advice before attempting to
 develop or distribute cryptographic code.