[ Avaa Bypassed ]




Upload:

Command:

hmhc3928@3.129.195.200: ~ $
# 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;

Filemanager

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