Skip to content

Commit

Permalink
Merge pull request libwww-perl#22 from madsen/RT67947-verify_hostname
Browse files Browse the repository at this point in the history
verify_hostname defaults to 0 if ssl_opts provided [RT#67947]
  • Loading branch information
gisle committed Oct 14, 2011
2 parents a406ab1 + a835fc7 commit 0a9516a
Show file tree
Hide file tree
Showing 2 changed files with 40 additions and 4 deletions.
5 changes: 2 additions & 3 deletions lib/LWP/UserAgent.pm
Original file line number Diff line number Diff line change
Expand Up @@ -31,10 +31,9 @@ sub new
my $timeout = delete $cnf{timeout};
$timeout = 3*60 unless defined $timeout;
my $local_address = delete $cnf{local_address};
my $ssl_opts = delete $cnf{ssl_opts};
unless ($ssl_opts) {
my $ssl_opts = delete $cnf{ssl_opts} || {};
unless (exists $ssl_opts->{verify_hostname}) {
# The processing of HTTPS_CA_* below is for compatiblity with Crypt::SSLeay
$ssl_opts = {};
if (exists $ENV{PERL_LWP_SSL_VERIFY_HOSTNAME}) {
$ssl_opts->{verify_hostname} = $ENV{PERL_LWP_SSL_VERIFY_HOSTNAME};
}
Expand Down
39 changes: 38 additions & 1 deletion t/base/ua.t
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,17 @@
use strict;
use Test;

plan tests => 21;
plan tests => 31;

use LWP::UserAgent;

# Prevent environment from interfering with test:
delete $ENV{PERL_LWP_SSL_VERIFY_HOSTNAME};
delete $ENV{HTTPS_CA_FILE};
delete $ENV{HTTPS_CA_DIR};
delete $ENV{PERL_LWP_SSL_CA_FILE};
delete $ENV{PERL_LWP_SSL_CA_PATH};

my $ua = LWP::UserAgent->new;
my $clone = $ua->clone;

Expand Down Expand Up @@ -55,3 +62,33 @@ ok($ua->ssl_opts("verify_hostname"), 0);
ok($ua->ssl_opts(verify_hostname => undef), 0);
ok($ua->ssl_opts("verify_hostname"), undef);
ok(join(":", $ua->ssl_opts), "");

$ua = LWP::UserAgent->new(ssl_opts => {});
ok($ua->ssl_opts("verify_hostname"), 1);

$ua = LWP::UserAgent->new(ssl_opts => { verify_hostname => 0 });
ok($ua->ssl_opts("verify_hostname"), 0);

$ua = LWP::UserAgent->new(ssl_opts => { SSL_ca_file => 'cert.dat'});
ok($ua->ssl_opts("verify_hostname"), 1);
ok($ua->ssl_opts("SSL_ca_file"), 'cert.dat');

$ENV{PERL_LWP_SSL_VERIFY_HOSTNAME} = 1;
$ua = LWP::UserAgent->new();
ok($ua->ssl_opts("verify_hostname"), 1);

$ua = LWP::UserAgent->new(ssl_opts => {});
ok($ua->ssl_opts("verify_hostname"), 1);

$ua = LWP::UserAgent->new(ssl_opts => { verify_hostname => 0 });
ok($ua->ssl_opts("verify_hostname"), 0);

$ENV{PERL_LWP_SSL_VERIFY_HOSTNAME} = 0;
$ua = LWP::UserAgent->new();
ok($ua->ssl_opts("verify_hostname"), 0);

$ua = LWP::UserAgent->new(ssl_opts => {});
ok($ua->ssl_opts("verify_hostname"), 0);

$ua = LWP::UserAgent->new(ssl_opts => { verify_hostname => 1 });
ok($ua->ssl_opts("verify_hostname"), 1);

0 comments on commit 0a9516a

Please sign in to comment.