aboutsummaryrefslogtreecommitdiffstats
path: root/Bugzilla
diff options
context:
space:
mode:
authorFrédéric Buclin <LpSolit@netscape.net>2018-04-19 20:21:19 +0200
committerFrédéric Buclin <LpSolit@netscape.net>2018-04-19 20:21:19 +0200
commit7fee353ce5190f5e08bb05fd9b29e24fdd4dc654 (patch)
tree91c7fa2c8fac5c2d6af7426fcd45f92716581f9f /Bugzilla
parentc52e3c6e8ad547ec035309994144fd22e2925267 (diff)
downloadbugs-7fee353ce5190f5e08bb05fd9b29e24fdd4dc654.tar
bugs-7fee353ce5190f5e08bb05fd9b29e24fdd4dc654.tar.gz
bugs-7fee353ce5190f5e08bb05fd9b29e24fdd4dc654.tar.bz2
bugs-7fee353ce5190f5e08bb05fd9b29e24fdd4dc654.tar.xz
bugs-7fee353ce5190f5e08bb05fd9b29e24fdd4dc654.zip
Backport upstream bug 919122: Support for SourceForge Allura bugs in "see also" field
Diffstat (limited to 'Bugzilla')
-rw-r--r--Bugzilla/BugUrl/SourceForge.pm21
1 files changed, 16 insertions, 5 deletions
diff --git a/Bugzilla/BugUrl/SourceForge.pm b/Bugzilla/BugUrl/SourceForge.pm
index acba0df28..4a330f34b 100644
--- a/Bugzilla/BugUrl/SourceForge.pm
+++ b/Bugzilla/BugUrl/SourceForge.pm
@@ -22,12 +22,18 @@ sub should_handle {
# SourceForge tracker URLs have only one form:
# http://sourceforge.net/tracker/?func=detail&aid=111&group_id=111&atid=111
+ # SourceForge Allura ticket URLs have several forms:
+ # http://sourceforge.net/p/project/bugs/12345/
+ # http://sourceforge.net/p/project/feature-requests/12345/
+ # http://sourceforge.net/p/project/patches/12345/
+ # http://sourceforge.net/p/project/support-requests/12345/
return (lc($uri->authority) eq 'sourceforge.net'
- and $uri->path =~ m|/tracker/|
- and $uri->query_param('func') eq 'detail'
- and $uri->query_param('aid')
- and $uri->query_param('group_id')
- and $uri->query_param('atid')) ? 1 : 0;
+ and (($uri->path eq '/tracker/'
+ and $uri->query_param('func') eq 'detail'
+ and $uri->query_param('aid')
+ and $uri->query_param('group_id')
+ and $uri->query_param('atid'))
+ or $uri->path =~ m!^/p/[^/]+/(?:bugs|feature-requests|patches|support-requests)/\d+/?$!)) ? 1 : 0;
}
sub _check_value {
@@ -38,6 +44,11 @@ sub _check_value {
# Remove any # part if there is one.
$uri->fragment(undef);
+ # Make sure the trailing slash is present
+ my $path = $uri->path;
+ $path =~ s!/*$!/!;
+ $uri->path($path);
+
return $uri;
}