diff options
author | Eric Wong <normalperson@yhbt.net> | 2009-07-25 13:14:16 -0700 |
---|---|---|
committer | Eric Wong <normalperson@yhbt.net> | 2009-07-25 13:37:02 -0700 |
commit | 5f8b2cbacd3bad38d0ae4d358fe9b34e98190935 (patch) | |
tree | de9d37d885234550884f326eea944c9d9931bd9f /git-svn.perl | |
parent | 884cce5bd042e67a0d2a1a9317f8435634486ad1 (diff) | |
download | git-5f8b2cbacd3bad38d0ae4d358fe9b34e98190935.tar.gz |
git svn: make minimize URL more reliable over http(s)
In addition to path-based restrictions, Subversion servers over
http(s) may have access controls implemented via the LimitExcept
directive in Apache. In some cases, LimitExcept may be
(arguably) misconfigured to not allow REPORT requests while
allowing OPTIONS and PROPFIND.
This caused problems with our existing minimize_url logic that
only issued OPTIONS and PROPFIND requests when connecting and
using SVN::Ra::get_latest_revnum. We now call SVN::Ra::get_log
if get_latest_revnum succeeds, resulting in a REPORT request
being sent. This will increase our chances of tripping access
controls before we start attempting to fetch history.
Signed-off-by: Eric Wong <normalperson@yhbt.net>
Diffstat (limited to 'git-svn.perl')
-rwxr-xr-x | git-svn.perl | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/git-svn.perl b/git-svn.perl index fd7232cf6d..d075810724 100755 --- a/git-svn.perl +++ b/git-svn.perl @@ -4831,7 +4831,11 @@ sub minimize_url { my $c = ''; do { $url .= "/$c" if length $c; - eval { (ref $self)->new($url)->get_latest_revnum }; + eval { + my $ra = (ref $self)->new($url); + my $latest = $ra->get_latest_revnum; + $ra->get_log("", $latest, 0, 1, 0, 1, sub {}); + }; } while ($@ && ($c = shift @components)); $url; } |