projects
/
Net-HTTPS-Any.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
add debugging, properly export subs
[Net-HTTPS-Any.git]
/
lib
/
Net
/
HTTPS
/
Any.pm
diff --git
a/lib/Net/HTTPS/Any.pm
b/lib/Net/HTTPS/Any.pm
index
c65c7d9
..
1812d06
100644
(file)
--- a/
lib/Net/HTTPS/Any.pm
+++ b/
lib/Net/HTTPS/Any.pm
@@
-2,11
+2,12
@@
package Net::HTTPS::Any;
use warnings;
use strict;
use warnings;
use strict;
-use vars qw(@EXPORT_OK $ssl_module $skip_NetSSLeay);
+use vars qw(@
ISA @
EXPORT_OK $ssl_module $skip_NetSSLeay);
use Exporter;
use URI::Escape;
use Tie::IxHash;
use Exporter;
use URI::Escape;
use Tie::IxHash;
+@ISA = qw( Exporter );
@EXPORT_OK = qw( https_get https_post );
BEGIN {
@EXPORT_OK = qw( https_get https_post );
BEGIN {
@@
-114,6
+115,8
@@
For example: 'text/namevalue',
CGI arguments, eitehr as a hashref or a listref. In the latter case, ordering
is preserved (see L<Tie::IxHash> to do so when passing a hashref).
CGI arguments, eitehr as a hashref or a listref. In the latter case, ordering
is preserved (see L<Tie::IxHash> to do so when passing a hashref).
+=item debug
+
=back
Returns a list consisting of the page content as a string, the HTTP
=back
Returns a list consisting of the page content as a string, the HTTP
@@
-134,6
+137,7
@@
sub https_get {
$post_data = \%hash;
}
$post_data = \%hash;
}
+ $opts->{'port'} ||= 443;
$opts->{"Content-Type"} ||= "application/x-www-form-urlencoded";
### XXX referer!!!
$opts->{"Content-Type"} ||= "application/x-www-form-urlencoded";
### XXX referer!!!
@@
-156,6
+160,8
@@
sub https_get {
import Net::SSLeay qw(get_https make_headers);
my $headers = make_headers(%headers);
import Net::SSLeay qw(get_https make_headers);
my $headers = make_headers(%headers);
+ $Net::SSLeay::trace = $opts->{'debug'} if exists $opts->{'debug'};
+
my( $res_page, $res_code, @res_headers ) =
get_https( $opts->{'host'},
$opts->{'port'},
my( $res_page, $res_code, @res_headers ) =
get_https( $opts->{'host'},
$opts->{'port'},
@@
-180,6
+186,7
@@
sub https_get {
foreach my $hdr ( keys %headers ) {
$ua->default_header( $hdr => $headers{$hdr} );
}
foreach my $hdr ( keys %headers ) {
$ua->default_header( $hdr => $headers{$hdr} );
}
+ $ENV{HTTPS_DEBUG} = $opts->{'debug'} if exists $opts->{'debug'};
my $res = $ua->request( GET($url) );
my @res_headers = map { $_ => $res->header($_) }
my $res = $ua->request( GET($url) );
my @res_headers = map { $_ => $res->header($_) }
@@
-248,6
+255,7
@@
sub https_post {
$post_data = $opts->{'content'};
}
$post_data = $opts->{'content'};
}
+ $opts->{'port'} ||= 443;
$opts->{"Content-Type"} ||= "application/x-www-form-urlencoded";
### XXX referer!!!
$opts->{"Content-Type"} ||= "application/x-www-form-urlencoded";
### XXX referer!!!
@@
-258,12
+266,14
@@
sub https_post {
$headers{'Host'} ||= $opts->{'host'};
if ( $ssl_module eq 'Net::SSLeay' ) {
$headers{'Host'} ||= $opts->{'host'};
if ( $ssl_module eq 'Net::SSLeay' ) {
-
+
import Net::SSLeay qw(post_https make_headers make_form);
my $headers = make_headers(%headers);
my $raw_data = ref($post_data) ? make_form(%$post_data) : $post_data;
import Net::SSLeay qw(post_https make_headers make_form);
my $headers = make_headers(%headers);
my $raw_data = ref($post_data) ? make_form(%$post_data) : $post_data;
+ $Net::SSLeay::trace = $opts->{'debug'} if exists $opts->{'debug'};
+
my( $res_page, $res_code, @res_headers ) =
post_https( $opts->{'host'},
$opts->{'port'},
my( $res_page, $res_code, @res_headers ) =
post_https( $opts->{'host'},
$opts->{'port'},
@@
-289,6
+299,8
@@
sub https_post {
$ua->default_header( $hdr => $headers{$hdr} );
}
$ua->default_header( $hdr => $headers{$hdr} );
}
+ $ENV{HTTPS_DEBUG} = $opts->{'debug'} if exists $opts->{'debug'};
+
my $res;
if ( ref($post_data) ) {
$res = $ua->request( POST( $url, [%$post_data] ) );
my $res;
if ( ref($post_data) ) {
$res = $ua->request( POST( $url, [%$post_data] ) );