2014-10-16 13:10:03 +00:00
|
|
|
--- lib/IO/Socket/SSL.pm
|
|
|
|
+++ lib/IO/Socket/SSL.pm
|
2015-01-12 13:28:46 +00:00
|
|
|
@@ -85,7 +85,7 @@ my $algo2digest = do {
|
2014-10-16 13:10:03 +00:00
|
|
|
# global defaults
|
|
|
|
my %DEFAULT_SSL_ARGS = (
|
|
|
|
SSL_check_crl => 0,
|
|
|
|
- SSL_version => 'SSLv23:!SSLv3:!SSLv2', # consider both SSL3.0 and SSL2.0 as broken
|
|
|
|
+ SSL_version => '',
|
|
|
|
SSL_verify_callback => undef,
|
|
|
|
SSL_verifycn_scheme => undef, # fallback cn verification
|
|
|
|
SSL_verifycn_publicsuffix => undef, # fallback default list verification
|
2016-02-07 16:11:20 +00:00
|
|
|
@@ -2179,7 +2179,7 @@ sub new {
|
2014-10-21 14:27:58 +00:00
|
|
|
$ssl_op |= &Net::SSLeay::OP_SINGLE_DH_USE;
|
|
|
|
$ssl_op |= &Net::SSLeay::OP_SINGLE_ECDH_USE if $can_ecdh;
|
2014-10-16 13:10:03 +00:00
|
|
|
|
|
|
|
- my $ver;
|
|
|
|
+ my $ver = '';
|
|
|
|
for (split(/\s*:\s*/,$arg_hash->{SSL_version})) {
|
|
|
|
m{^(!?)(?:(SSL(?:v2|v3|v23|v2/3))|(TLSv1(?:_?[12])?))$}i
|
|
|
|
or croak("invalid SSL_version specified");
|
|
|
|
--- lib/IO/Socket/SSL.pod
|
|
|
|
+++ lib/IO/Socket/SSL.pod
|
2015-12-03 13:55:07 +00:00
|
|
|
@@ -942,11 +942,12 @@ protocol to the specified version.
|
2014-10-16 13:10:03 +00:00
|
|
|
All values are case-insensitive. Instead of 'TLSv1_1' and 'TLSv1_2' one can
|
|
|
|
also use 'TLSv11' and 'TLSv12'. Support for 'TLSv1_1' and 'TLSv1_2' requires
|
|
|
|
recent versions of Net::SSLeay and openssl.
|
|
|
|
+The default SSL_version is defined by the underlying cryptographic library.
|
|
|
|
|
2014-11-23 14:55:09 +00:00
|
|
|
Independent from the handshake format you can limit to set of accepted SSL
|
2014-10-16 13:10:03 +00:00
|
|
|
versions by adding !version separated by ':'.
|
2014-10-21 14:27:58 +00:00
|
|
|
|
2014-10-16 13:10:03 +00:00
|
|
|
-The default SSL_version is 'SSLv23:!SSLv3:!SSLv2' which means, that the
|
|
|
|
+For example, 'SSLv23:!SSLv3:!SSLv2' means that the
|
|
|
|
handshake format is compatible to SSL2.0 and higher, but that the successful
|
|
|
|
handshake is limited to TLS1.0 and higher, that is no SSL2.0 or SSL3.0 because
|
|
|
|
both of these versions have serious security issues and should not be used
|