2000-09-21 06:46:15 +00:00
|
|
|
=pod
|
|
|
|
|
|
|
|
=head1 NAME
|
|
|
|
|
|
|
|
SSL_pending - obtain number of readable bytes buffered in an SSL object
|
|
|
|
|
|
|
|
=head1 SYNOPSIS
|
|
|
|
|
|
|
|
#include <openssl/ssl.h>
|
|
|
|
|
2005-03-30 11:50:14 +00:00
|
|
|
int SSL_pending(const SSL *ssl);
|
2000-09-21 06:46:15 +00:00
|
|
|
|
|
|
|
=head1 DESCRIPTION
|
|
|
|
|
|
|
|
SSL_pending() returns the number of bytes which are available inside
|
|
|
|
B<ssl> for immediate read.
|
|
|
|
|
|
|
|
=head1 NOTES
|
|
|
|
|
|
|
|
Data are received in blocks from the peer. Therefore data can be buffered
|
|
|
|
inside B<ssl> and are ready for immediate retrieval with
|
|
|
|
L<SSL_read(3)|SSL_read(3)>.
|
|
|
|
|
|
|
|
=head1 RETURN VALUES
|
|
|
|
|
|
|
|
The number of bytes pending is returned.
|
|
|
|
|
2000-09-26 12:15:53 +00:00
|
|
|
=head1 BUGS
|
|
|
|
|
|
|
|
SSL_pending() takes into account only bytes from the TLS/SSL record
|
|
|
|
that is currently being processed (if any). If the B<SSL> object's
|
2015-01-26 23:28:31 +00:00
|
|
|
I<read_ahead> flag is set (see
|
|
|
|
L<SSL_CTX_set_read_ahead(3)|SSL_CTX_set_read_ahead(3)>), additional protocol
|
|
|
|
bytes may have been read containing more TLS/SSL records; these are ignored by
|
2000-09-26 12:15:53 +00:00
|
|
|
SSL_pending().
|
|
|
|
|
2000-12-25 18:40:46 +00:00
|
|
|
Up to OpenSSL 0.9.6, SSL_pending() does not check if the record type
|
|
|
|
of pending data is application data.
|
2000-09-26 12:15:53 +00:00
|
|
|
|
|
|
|
=head1 SEE ALSO
|
|
|
|
|
2015-01-26 23:28:31 +00:00
|
|
|
L<SSL_read(3)|SSL_read(3)>,
|
|
|
|
L<SSL_CTX_set_read_ahead(3)|SSL_CTX_set_read_ahead(3)>, L<ssl(3)|ssl(3)>
|
2000-09-21 06:46:15 +00:00
|
|
|
|
|
|
|
=cut
|