Just had to access a server with a broken certificate (self signed), so I added that patch to git-svnimport.
--- /usr/bin/git-svnimport 2006-04-13 09:39:39.000000000 +0300 +++ /home/panos/bin/git-svnimport 2006-04-28 17:55:45.000000000 +0300 @@ -96,9 +96,14 @@ sub conn { my $self = shift; my $repo = $self->{'fullrep'}; - my $auth = SVN::Core::auth_open ([SVN::Client::get_simple_provider, +# my $auth = SVN::Core::auth_open ([SVN::Client::get_simple_provider, +# SVN::Client::get_ssl_server_trust_file_provider, +# SVN::Client::get_ssl_server_trust_prompt_provider(\&_trust_callback), +# SVN::Client::get_username_provider]); + my $auth = [SVN::Client::get_simple_provider, SVN::Client::get_ssl_server_trust_file_provider, - SVN::Client::get_username_provider]); + SVN::Client::get_ssl_server_trust_prompt_provider(\&_trust_callback), + SVN::Client::get_username_provider]; my $s = SVN::Ra->new(url => $repo, auth => $auth); die "SVN connection to $repo: $!\n" unless defined $s; $self->{'svn'} = $s; @@ -125,6 +130,45 @@ return $name; } +sub _trust_callback { + my ($cred,$realm,$ifailed,$server_cert_info,$may_save) = @_; + #$cred->accepted_failures($SVN::Auth::SSL::UNKNOWNCA); + print "SSL certificate is not trusted: $ifailed \n"; + print "Fingerprint: " . $server_cert_info->fingerprint . "\n"; + print "Hostname: ". $server_cert_info->hostname ; + print " (MISMATCH)" if ( $ifailed & $SVN::Auth::SSL::CNMISMATCH); + print "\n"; + + print "Valid from: ". $server_cert_info->valid_from; + print " (NOT YET)" if ( $ifailed & $SVN::Auth::SSL::NOTYETVALID); + print "\n"; + + print "Valid until: ". $server_cert_info->valid_until; + print " (EXPIRED)" if ( $ifailed & $SVN::Auth::SSL::EXPIRED); + print "\n"; + + print "Issuer: ". $server_cert_info->issuer_dname; + print " (UNKNOWN)" if ( $ifailed & $SVN::Auth::SSL::UNKNOWNCA); + print "\n\n"; + + print "Do you still want to accept that certificate? [y/N] "; + my $accept = <STDIN>; + chomp($accept); + print "\n"; + if (($accept eq "y") or ($accept eq "Y" )) { + $cred->accepted_failures($ifailed); + # print "Save cert, so that it is accepted in future calls? [y/N] "; + # my $mmsave = <STDIN>; + # chomp($mmsave); + # if (($mmsave eq "y") or ($mmsave eq "Y" )) { + # $may_save = 1; + # } + print "\n"; + } + +} + + package main; use URI;