Import OpenSSL 1.1.1f
This commit is contained in:
@@ -3,7 +3,9 @@
|
||||
=head1 NAME
|
||||
|
||||
SSL_CTX_set_stateless_cookie_generate_cb,
|
||||
SSL_CTX_set_stateless_cookie_verify_cb
|
||||
SSL_CTX_set_stateless_cookie_verify_cb,
|
||||
SSL_CTX_set_cookie_generate_cb,
|
||||
SSL_CTX_set_cookie_verify_cb
|
||||
- Callback functions for stateless TLS1.3 cookies
|
||||
|
||||
=head1 SYNOPSIS
|
||||
@@ -21,22 +23,51 @@ SSL_CTX_set_stateless_cookie_verify_cb
|
||||
const unsigned char *cookie,
|
||||
size_t cookie_len));
|
||||
|
||||
void SSL_CTX_set_cookie_generate_cb(SSL_CTX *ctx,
|
||||
int (*app_gen_cookie_cb) (SSL *ssl,
|
||||
unsigned char
|
||||
*cookie,
|
||||
unsigned int
|
||||
*cookie_len));
|
||||
void SSL_CTX_set_cookie_verify_cb(SSL_CTX *ctx,
|
||||
int (*app_verify_cookie_cb) (SSL *ssl,
|
||||
const unsigned
|
||||
char *cookie,
|
||||
unsigned int
|
||||
cookie_len));
|
||||
|
||||
=head1 DESCRIPTION
|
||||
|
||||
SSL_CTX_set_cookie_generate_cb() sets the callback used by L<SSL_stateless(3)>
|
||||
to generate the application-controlled portion of the cookie provided to clients
|
||||
in the HelloRetryRequest transmitted as a response to a ClientHello with a
|
||||
missing or invalid cookie. gen_stateless_cookie_cb() must write at most
|
||||
SSL_COOKIE_LENGTH bytes into B<cookie>, and must write the number of bytes
|
||||
written to B<cookie_len>. If a cookie cannot be generated, a zero return value
|
||||
can be used to abort the handshake.
|
||||
SSL_CTX_set_stateless_cookie_generate_cb() sets the callback used by
|
||||
L<SSL_stateless(3)> to generate the application-controlled portion of the cookie
|
||||
provided to clients in the HelloRetryRequest transmitted as a response to a
|
||||
ClientHello with a missing or invalid cookie. gen_stateless_cookie_cb() must
|
||||
write at most SSL_COOKIE_LENGTH bytes into B<cookie>, and must write the number
|
||||
of bytes written to B<cookie_len>. If a cookie cannot be generated, a zero
|
||||
return value can be used to abort the handshake.
|
||||
|
||||
SSL_CTX_set_cookie_verify_cb() sets the callback used by L<SSL_stateless(3)> to
|
||||
determine whether the application-controlled portion of a ClientHello cookie is
|
||||
valid. A nonzero return value from app_verify_cookie_cb() communicates that the
|
||||
cookie is valid. The integrity of the entire cookie, including the
|
||||
application-controlled portion, is automatically verified by HMAC before
|
||||
verify_stateless_cookie_cb() is called.
|
||||
SSL_CTX_set_stateless_cookie_verify_cb() sets the callback used by
|
||||
L<SSL_stateless(3)> to determine whether the application-controlled portion of a
|
||||
ClientHello cookie is valid. The cookie data is pointed to by B<cookie> and is of
|
||||
length B<cookie_len>. A nonzero return value from verify_stateless_cookie_cb()
|
||||
communicates that the cookie is valid. The integrity of the entire cookie,
|
||||
including the application-controlled portion, is automatically verified by HMAC
|
||||
before verify_stateless_cookie_cb() is called.
|
||||
|
||||
SSL_CTX_set_cookie_generate_cb() sets the callback used by L<DTLSv1_listen(3)>
|
||||
to generate the cookie provided to clients in the HelloVerifyRequest transmitted
|
||||
as a response to a ClientHello with a missing or invalid cookie.
|
||||
app_gen_cookie_cb() must write at most DTLS1_COOKIE_LENGTH bytes into
|
||||
B<cookie>, and must write the number of bytes written to B<cookie_len>. If a
|
||||
cookie cannot be generated, a zero return value can be used to abort the
|
||||
handshake.
|
||||
|
||||
SSL_CTX_set_cookie_verify_cb() sets the callback used by L<DTLSv1_listen(3)> to
|
||||
determine whether the cookie in a ClientHello is valid. The cookie data is
|
||||
pointed to by B<cookie> and is of length B<cookie_len>. A nonzero return value
|
||||
from app_verify_cookie_cb() communicates that the cookie is valid. The
|
||||
integrity of the cookie is not verified by OpenSSL. This is an application
|
||||
responsibility.
|
||||
|
||||
=head1 RETURN VALUES
|
||||
|
||||
@@ -44,7 +75,13 @@ Neither function returns a value.
|
||||
|
||||
=head1 SEE ALSO
|
||||
|
||||
L<SSL_stateless(3)>
|
||||
L<SSL_stateless(3)>,
|
||||
L<DTLSv1_listen(3)>
|
||||
|
||||
=head1 HISTORY
|
||||
|
||||
SSL_CTX_set_stateless_cookie_generate_cb() and
|
||||
SSL_CTX_set_stateless_cookie_verify_cb() were added in OpenSSL 1.1.1.
|
||||
|
||||
=head1 COPYRIGHT
|
||||
|
||||
|
||||
Reference in New Issue
Block a user