2000-09-14 21:11:56 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
2013-06-13 06:42:08 +08:00
|
|
|
SSL_get_session, SSL_get0_session, SSL_get1_session - retrieve TLS/SSL session data
|
2000-09-14 21:11:56 +08:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/ssl.h>
|
|
|
|
|
2005-03-30 19:50:14 +08:00
|
|
|
SSL_SESSION *SSL_get_session(const SSL *ssl);
|
|
|
|
SSL_SESSION *SSL_get0_session(const SSL *ssl);
|
2000-09-14 21:11:56 +08:00
|
|
|
SSL_SESSION *SSL_get1_session(SSL *ssl);
|
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
2000-09-16 23:39:28 +08:00
|
|
|
SSL_get_session() returns a pointer to the B<SSL_SESSION> actually used in
|
|
|
|
B<ssl>. The reference count of the B<SSL_SESSION> is not incremented, so
|
2001-02-13 22:00:09 +08:00
|
|
|
that the pointer can become invalid by other operations.
|
2000-09-14 21:11:56 +08:00
|
|
|
|
|
|
|
SSL_get0_session() is the same as SSL_get_session().
|
|
|
|
|
|
|
|
SSL_get1_session() is the same as SSL_get_session(), but the reference
|
2000-09-16 23:39:28 +08:00
|
|
|
count of the B<SSL_SESSION> is incremented by one.
|
2000-09-14 21:11:56 +08:00
|
|
|
|
2001-02-13 22:00:09 +08:00
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
The ssl session contains all information required to re-establish the
|
2017-03-23 19:56:46 +08:00
|
|
|
connection without a full handshake for SSL versions up to and including
|
|
|
|
TLSv1.2. In TLSv1.3 the same is true, but sessions are established after the
|
|
|
|
main handshake has occurred. The server will send the session information to the
|
|
|
|
client at a time of its choosing, which may be some while after the initial
|
|
|
|
connection is established (or never). Calling these functions on the client side
|
|
|
|
in TLSv1.3 before the session has been established will still return an
|
|
|
|
SSL_SESSION object but that object cannot be used for resuming the session. See
|
|
|
|
L<SSL_SESSION_is_resumable(3)> for information on how to determine whether an
|
|
|
|
SSL_SESSION object can be used for resumption or not.
|
|
|
|
|
|
|
|
Additionally, in TLSv1.3, a server can send multiple messages that establish a
|
|
|
|
session for a single connection. In that case the above functions will only
|
|
|
|
return information on the last session that was received.
|
2017-03-21 21:51:03 +08:00
|
|
|
|
|
|
|
The preferred way for applications to obtain a resumable SSL_SESSION object is
|
|
|
|
to use a new session callback as described in L<SSL_CTX_sess_set_new_cb(3)>.
|
|
|
|
The new session callback is only invoked when a session is actually established,
|
|
|
|
so this avoids the problem described above where an application obtains an
|
|
|
|
SSL_SESSION object that cannot be used for resumption in TLSv1.3. It also
|
|
|
|
enables applications to obtain information about all sessions sent by the
|
|
|
|
server.
|
|
|
|
|
2018-04-23 18:23:43 +08:00
|
|
|
A session will be automatically removed from the session cache and marked as
|
|
|
|
non-resumable if the connection is not closed down cleanly, e.g. if a fatal
|
|
|
|
error occurs on the connection or L<SSL_shutdown(3)> is not called prior to
|
|
|
|
L<SSL_free(3)>.
|
|
|
|
|
2017-03-21 21:51:03 +08:00
|
|
|
In TLSv1.3 it is recommended that each SSL_SESSION object is only used for
|
|
|
|
resumption once.
|
2001-02-13 22:00:09 +08:00
|
|
|
|
|
|
|
SSL_get0_session() returns a pointer to the actual session. As the
|
|
|
|
reference counter is not incremented, the pointer is only valid while
|
2015-08-18 03:21:33 +08:00
|
|
|
the connection is in use. If L<SSL_clear(3)> or
|
|
|
|
L<SSL_free(3)> is called, the session may be removed completely
|
2001-02-13 22:00:09 +08:00
|
|
|
(if considered bad), and the pointer obtained will become invalid. Even
|
|
|
|
if the session is valid, it can be removed at any time due to timeout
|
2015-08-18 03:21:33 +08:00
|
|
|
during L<SSL_CTX_flush_sessions(3)>.
|
2001-02-13 22:00:09 +08:00
|
|
|
|
|
|
|
If the data is to be kept, SSL_get1_session() will increment the reference
|
2001-11-19 19:11:23 +08:00
|
|
|
count, so that the session will not be implicitly removed by other operations
|
|
|
|
but stays in memory. In order to remove the session
|
2015-08-18 03:21:33 +08:00
|
|
|
L<SSL_SESSION_free(3)> must be explicitly called once
|
2001-11-19 19:11:23 +08:00
|
|
|
to decrement the reference count again.
|
2001-02-13 22:00:09 +08:00
|
|
|
|
2001-10-12 20:29:16 +08:00
|
|
|
SSL_SESSION objects keep internal link information about the session cache
|
|
|
|
list, when being inserted into one SSL_CTX object's session cache.
|
|
|
|
One SSL_SESSION object, regardless of its reference count, must therefore
|
|
|
|
only be used with one SSL_CTX object (and the SSL objects created
|
|
|
|
from this SSL_CTX object).
|
|
|
|
|
2000-09-14 21:11:56 +08:00
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
The following return values can occur:
|
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item NULL
|
|
|
|
|
|
|
|
There is no session available in B<ssl>.
|
|
|
|
|
2016-01-27 13:55:19 +08:00
|
|
|
=item Pointer to an SSL_SESSION
|
2000-09-14 21:11:56 +08:00
|
|
|
|
|
|
|
The return value points to the data of an SSL session.
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2016-11-11 16:33:09 +08:00
|
|
|
L<ssl(7)>, L<SSL_free(3)>,
|
2015-08-18 03:21:33 +08:00
|
|
|
L<SSL_clear(3)>,
|
|
|
|
L<SSL_SESSION_free(3)>
|
2000-09-14 21:11:56 +08:00
|
|
|
|
2016-05-18 23:44:05 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2018-05-01 20:34:30 +08:00
|
|
|
Copyright 2000-2018 The OpenSSL Project Authors. All Rights Reserved.
|
2016-05-18 23:44:05 +08:00
|
|
|
|
|
|
|
Licensed under the OpenSSL license (the "License"). You may not use
|
|
|
|
this file except in compliance with the License. You can obtain a copy
|
|
|
|
in the file LICENSE in the source distribution or at
|
|
|
|
L<https://www.openssl.org/source/license.html>.
|
|
|
|
|
|
|
|
=cut
|