2001-08-24 22:29:48 +08:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
2018-04-04 22:02:30 +08:00
|
|
|
SSL_CTX_set_info_callback,
|
|
|
|
SSL_CTX_get_info_callback,
|
|
|
|
SSL_set_info_callback,
|
|
|
|
SSL_get_info_callback
|
|
|
|
- handle information callback for SSL connections
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/ssl.h>
|
|
|
|
|
|
|
|
void SSL_CTX_set_info_callback(SSL_CTX *ctx, void (*callback)());
|
2005-03-30 19:50:14 +08:00
|
|
|
void (*SSL_CTX_get_info_callback(const SSL_CTX *ctx))();
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
void SSL_set_info_callback(SSL *ssl, void (*callback)());
|
2005-03-30 19:50:14 +08:00
|
|
|
void (*SSL_get_info_callback(const SSL *ssl))();
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
SSL_CTX_set_info_callback() sets the B<callback> function, that can be used to
|
|
|
|
obtain state information for SSL objects created from B<ctx> during connection
|
|
|
|
setup and use. The setting for B<ctx> is overridden from the setting for
|
|
|
|
a specific SSL object, if specified.
|
2014-07-02 00:44:32 +08:00
|
|
|
When B<callback> is NULL, no callback function is used.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
SSL_set_info_callback() sets the B<callback> function, that can be used to
|
|
|
|
obtain state information for B<ssl> during connection setup and use.
|
|
|
|
When B<callback> is NULL, the callback setting currently valid for
|
|
|
|
B<ctx> is used.
|
|
|
|
|
|
|
|
SSL_CTX_get_info_callback() returns a pointer to the currently set information
|
|
|
|
callback function for B<ctx>.
|
|
|
|
|
|
|
|
SSL_get_info_callback() returns a pointer to the currently set information
|
|
|
|
callback function for B<ssl>.
|
|
|
|
|
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
When setting up a connection and during use, it is possible to obtain state
|
|
|
|
information from the SSL/TLS engine. When set, an information callback function
|
2018-04-04 22:02:30 +08:00
|
|
|
is called whenever a significant event occurs such as: the state changes,
|
|
|
|
an alert appears, or an error occurs.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
The callback function is called as B<callback(SSL *ssl, int where, int ret)>.
|
|
|
|
The B<where> argument specifies information about where (in which context)
|
2001-09-07 14:13:40 +08:00
|
|
|
the callback function was called. If B<ret> is 0, an error condition occurred.
|
2001-08-24 22:29:48 +08:00
|
|
|
If an alert is handled, SSL_CB_ALERT is set and B<ret> specifies the alert
|
|
|
|
information.
|
|
|
|
|
2019-09-28 01:17:09 +08:00
|
|
|
B<where> is a bit-mask made up of the following bits:
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=over 4
|
|
|
|
|
|
|
|
=item SSL_CB_LOOP
|
|
|
|
|
2018-04-04 22:02:30 +08:00
|
|
|
Callback has been called to indicate state change or some other significant
|
|
|
|
state machine event. This may mean that the callback gets invoked more than once
|
|
|
|
per state in some situations.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=item SSL_CB_EXIT
|
|
|
|
|
2018-04-04 22:02:30 +08:00
|
|
|
Callback has been called to indicate exit of a handshake function. This will
|
|
|
|
happen after the end of a handshake, but may happen at other times too such as
|
2020-07-17 18:31:26 +08:00
|
|
|
on error or when IO might otherwise block and nonblocking is being used.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=item SSL_CB_READ
|
|
|
|
|
|
|
|
Callback has been called during read operation.
|
|
|
|
|
|
|
|
=item SSL_CB_WRITE
|
|
|
|
|
|
|
|
Callback has been called during write operation.
|
|
|
|
|
|
|
|
=item SSL_CB_ALERT
|
|
|
|
|
|
|
|
Callback has been called due to an alert being sent or received.
|
|
|
|
|
|
|
|
=item SSL_CB_READ_ALERT (SSL_CB_ALERT|SSL_CB_READ)
|
|
|
|
|
|
|
|
=item SSL_CB_WRITE_ALERT (SSL_CB_ALERT|SSL_CB_WRITE)
|
|
|
|
|
|
|
|
=item SSL_CB_ACCEPT_LOOP (SSL_ST_ACCEPT|SSL_CB_LOOP)
|
|
|
|
|
|
|
|
=item SSL_CB_ACCEPT_EXIT (SSL_ST_ACCEPT|SSL_CB_EXIT)
|
|
|
|
|
|
|
|
=item SSL_CB_CONNECT_LOOP (SSL_ST_CONNECT|SSL_CB_LOOP)
|
|
|
|
|
|
|
|
=item SSL_CB_CONNECT_EXIT (SSL_ST_CONNECT|SSL_CB_EXIT)
|
|
|
|
|
|
|
|
=item SSL_CB_HANDSHAKE_START
|
|
|
|
|
2019-01-27 19:00:16 +08:00
|
|
|
Callback has been called because a new handshake is started. It also occurs when
|
|
|
|
resuming a handshake following a pause to handle early data.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
2019-01-27 19:00:16 +08:00
|
|
|
=item SSL_CB_HANDSHAKE_DONE
|
2001-08-24 22:29:48 +08:00
|
|
|
|
2019-01-27 19:00:16 +08:00
|
|
|
Callback has been called because a handshake is finished. It also occurs if the
|
|
|
|
handshake is paused to allow the exchange of early data.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
The current state information can be obtained using the
|
2015-08-18 03:21:33 +08:00
|
|
|
L<SSL_state_string(3)> family of functions.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
The B<ret> information can be evaluated using the
|
2015-08-18 03:21:33 +08:00
|
|
|
L<SSL_alert_type_string(3)> family of functions.
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
SSL_set_info_callback() does not provide diagnostic information.
|
|
|
|
|
|
|
|
SSL_get_info_callback() returns the current setting.
|
|
|
|
|
|
|
|
=head1 EXAMPLES
|
|
|
|
|
|
|
|
The following example callback function prints state strings, information
|
|
|
|
about alerts being handled and error messages to the B<bio_err> BIO.
|
|
|
|
|
|
|
|
void apps_ssl_info_callback(SSL *s, int where, int ret)
|
2016-11-19 07:10:05 +08:00
|
|
|
{
|
|
|
|
const char *str;
|
|
|
|
int w = where & ~SSL_ST_MASK;
|
|
|
|
|
|
|
|
if (w & SSL_ST_CONNECT)
|
|
|
|
str = "SSL_connect";
|
|
|
|
else if (w & SSL_ST_ACCEPT)
|
|
|
|
str = "SSL_accept";
|
|
|
|
else
|
|
|
|
str = "undefined";
|
|
|
|
|
|
|
|
if (where & SSL_CB_LOOP) {
|
|
|
|
BIO_printf(bio_err, "%s:%s\n", str, SSL_state_string_long(s));
|
|
|
|
} else if (where & SSL_CB_ALERT) {
|
|
|
|
str = (where & SSL_CB_READ) ? "read" : "write";
|
|
|
|
BIO_printf(bio_err, "SSL3 alert %s:%s:%s\n", str,
|
|
|
|
SSL_alert_type_string_long(ret),
|
|
|
|
SSL_alert_desc_string_long(ret));
|
|
|
|
} else if (where & SSL_CB_EXIT) {
|
|
|
|
if (ret == 0) {
|
|
|
|
BIO_printf(bio_err, "%s:failed in %s\n",
|
|
|
|
str, SSL_state_string_long(s));
|
|
|
|
} else if (ret < 0) {
|
|
|
|
BIO_printf(bio_err, "%s:error in %s\n",
|
|
|
|
str, SSL_state_string_long(s));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2001-08-24 22:29:48 +08:00
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2016-11-11 16:33:09 +08:00
|
|
|
L<ssl(7)>, L<SSL_state_string(3)>,
|
2015-08-18 03:21:33 +08:00
|
|
|
L<SSL_alert_type_string(3)>
|
2001-08-24 22:29:48 +08:00
|
|
|
|
2016-05-18 23:44:05 +08:00
|
|
|
=head1 COPYRIGHT
|
|
|
|
|
2020-08-06 20:22:30 +08:00
|
|
|
Copyright 2001-2020 The OpenSSL Project Authors. All Rights Reserved.
|
2016-05-18 23:44:05 +08:00
|
|
|
|
2018-12-06 21:04:44 +08:00
|
|
|
Licensed under the Apache License 2.0 (the "License"). You may not use
|
2016-05-18 23:44:05 +08:00
|
|
|
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
|