# NOTE: Derived from blib/lib/Net/SSLeay.pm. # Changes made here will be lost when autosplit is run again. # See AutoSplit.pm. package Net::SSLeay; #line 714 "blib/lib/Net/SSLeay.pm (autosplit into blib/lib/auto/Net/SSLeay/ssl_read_until.al)" ### from patch by Clinton Wong <clintdw@netcom.com> # ssl_read_until($ssl [, $delimit [, $max_length]]) # if $delimit missing, use $/ if it exists, otherwise use \n # read until delimiter reached, up to $max_length chars if defined sub ssl_read_until ($;$$) { my ($ssl,$delim, $max_length) = @_; # guess the delim string if missing if ( ! defined $delim ) { if ( defined $/ && length $/ ) { $delim = $/ } else { $delim = "\n" } # Note: \n,$/ value depends on the platform } my $len_delim = length $delim; my ($got); my $reply = ''; # If we have OpenSSL 0.9.6a or later, we can use SSL_peek to # speed things up. # N.B. 0.9.6a has security problems, so the support for # anything earlier than 0.9.6e will be dropped soon. if (&Net::SSLeay::OPENSSL_VERSION_NUMBER >= 0x0090601f) { $max_length = 2000000000 unless (defined $max_length); my ($pending, $peek_length, $found, $done); while (blength($reply) < $max_length and !$done) { #Block if necessary until we get some data $got = Net::SSLeay::peek($ssl,1); last if print_errs('SSL_peek'); $pending = Net::SSLeay::pending($ssl) + blength($reply); $peek_length = ($pending > $max_length) ? $max_length : $pending; $peek_length -= blength($reply); $got = Net::SSLeay::peek($ssl, $peek_length); last if print_errs('SSL_peek'); $peek_length = blength($got); #$found = index($got, $delim); # Old and broken # the delimiter may be split across two gets, so we prepend # a little from the last get onto this one before we check # for a match my $match; if(blength($reply) >= blength($delim) - 1) { #if what we've read so far is greater or equal #in length of what we need to prepatch $match = substr $reply, blength($reply) - blength($delim) + 1; } else { $match = $reply; } $match .= $got; $found = index($match, $delim); if ($found > -1) { #$got = Net::SSLeay::read($ssl, $found+$len_delim); #read up to the end of the delimiter $got = Net::SSLeay::read($ssl, $found + $len_delim - ((blength($match)) - (blength($got)))); $done = 1; } else { $got = Net::SSLeay::read($ssl, $peek_length); $done = 1 if ($peek_length == $max_length - blength($reply)); } last if print_errs('SSL_read'); debug_read(\$reply, \$got) if $trace>1; last if $got eq ''; $reply .= $got; } } else { while (!defined $max_length || length $reply < $max_length) { $got = Net::SSLeay::read($ssl,1); # one by one last if print_errs('SSL_read'); debug_read(\$reply, \$got) if $trace>1; last if $got eq ''; $reply .= $got; last if $len_delim && substr($reply, blength($reply)-$len_delim) eq $delim; } } return $reply; } # end of Net::SSLeay::ssl_read_until 1;
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
SSLeay.so | File | 423.98 KB | 0755 |
|
autosplit.ix | File | 1.54 KB | 0644 |
|
debug_read.al | File | 677 B | 0644 |
|
do_https.al | File | 507 B | 0644 |
|
do_https2.al | File | 446 B | 0644 |
|
do_https3.al | File | 466 B | 0644 |
|
do_https4.al | File | 357 B | 0644 |
|
do_httpx2.al | File | 535 B | 0644 |
|
do_httpx3.al | File | 1.52 KB | 0644 |
|
do_httpx4.al | File | 544 B | 0644 |
|
dump_peer_certificate.al | File | 958 B | 0644 |
|
get_http.al | File | 316 B | 0644 |
|
get_http3.al | File | 319 B | 0644 |
|
get_http4.al | File | 319 B | 0644 |
|
get_https.al | File | 319 B | 0644 |
|
get_https3.al | File | 322 B | 0644 |
|
get_https4.al | File | 322 B | 0644 |
|
get_httpx.al | File | 316 B | 0644 |
|
get_httpx3.al | File | 319 B | 0644 |
|
get_httpx4.al | File | 319 B | 0644 |
|
head_http.al | File | 319 B | 0644 |
|
head_http3.al | File | 322 B | 0644 |
|
head_http4.al | File | 346 B | 0644 |
|
head_https.al | File | 322 B | 0644 |
|
head_https3.al | File | 325 B | 0644 |
|
head_https4.al | File | 333 B | 0644 |
|
head_httpx.al | File | 319 B | 0644 |
|
head_httpx3.al | File | 322 B | 0644 |
|
head_httpx4.al | File | 399 B | 0644 |
|
http_cat.al | File | 1.18 KB | 0644 |
|
https_cat.al | File | 2.96 KB | 0644 |
|
httpx_cat.al | File | 558 B | 0644 |
|
initialize.al | File | 814 B | 0644 |
|
make_form.al | File | 604 B | 0644 |
|
make_headers.al | File | 575 B | 0644 |
|
new_x_ctx.al | File | 1.2 KB | 0644 |
|
open_proxy_tcp_connection.al | File | 1.25 KB | 0644 |
|
open_tcp_connection.al | File | 1.4 KB | 0644 |
|
post_http.al | File | 318 B | 0644 |
|
post_http3.al | File | 321 B | 0644 |
|
post_http4.al | File | 321 B | 0644 |
|
post_https.al | File | 321 B | 0644 |
|
post_https3.al | File | 324 B | 0644 |
|
post_https4.al | File | 324 B | 0644 |
|
post_httpx.al | File | 318 B | 0644 |
|
post_httpx3.al | File | 321 B | 0644 |
|
post_httpx4.al | File | 321 B | 0644 |
|
put_http.al | File | 316 B | 0644 |
|
put_http3.al | File | 319 B | 0644 |
|
put_http4.al | File | 319 B | 0644 |
|
put_https.al | File | 319 B | 0644 |
|
put_https3.al | File | 322 B | 0644 |
|
put_https4.al | File | 322 B | 0644 |
|
put_httpx.al | File | 316 B | 0644 |
|
put_httpx3.al | File | 319 B | 0644 |
|
put_httpx4.al | File | 319 B | 0644 |
|
randomize.al | File | 1.05 KB | 0644 |
|
set_cert_and_key.al | File | 805 B | 0644 |
|
set_proxy.al | File | 540 B | 0644 |
|
set_server_cert_and_key.al | File | 413 B | 0644 |
|
ssl_read_CRLF.al | File | 384 B | 0644 |
|
ssl_read_all.al | File | 801 B | 0644 |
|
ssl_read_until.al | File | 3.04 KB | 0644 |
|
ssl_write_CRLF.al | File | 812 B | 0644 |
|
ssl_write_all.al | File | 5.6 KB | 0644 |
|
sslcat.al | File | 3.05 KB | 0644 |
|
tcp_read_CRLF.al | File | 400 B | 0644 |
|
tcp_read_all.al | File | 756 B | 0644 |
|
tcp_read_until.al | File | 970 B | 0644 |
|
tcp_write_CRLF.al | File | 793 B | 0644 |
|
tcp_write_all.al | File | 1.2 KB | 0644 |
|
tcpcat.al | File | 1.33 KB | 0644 |
|
tcpxcat.al | File | 485 B | 0644 |
|
want_X509_lookup.al | File | 441 B | 0644 |
|
want_nothing.al | File | 357 B | 0644 |
|
want_read.al | File | 309 B | 0644 |
|
want_write.al | File | 312 B | 0644 |
|