]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 617802: Add see also support for Rietveld installations on appspot.com
authorMatt Selsky <selsky@columbia.edu>
Wed, 25 Jan 2012 20:19:51 +0000 (18:19 -0200)
committerTiago Mello <timello@gmail.com>
Wed, 25 Jan 2012 20:19:51 +0000 (18:19 -0200)
r=timello, a=LpSolit

Bugzilla/BugUrl.pm
Bugzilla/BugUrl/Rietveld.pm [new file with mode: 0644]
template/en/default/global/user-error.html.tmpl

index 1272b55fa7047524826d9cefe03548c827d84abd..99d46bd247e7648e02d74571ffd0e00c5a726cb3 100644 (file)
@@ -57,6 +57,7 @@ use constant SUB_CLASSES => qw(
     Bugzilla::BugUrl::MantisBT
     Bugzilla::BugUrl::SourceForge
     Bugzilla::BugUrl::ReviewBoard
+    Bugzilla::BugUrl::Rietveld
 );
 
 ###############################
diff --git a/Bugzilla/BugUrl/Rietveld.pm b/Bugzilla/BugUrl/Rietveld.pm
new file mode 100644 (file)
index 0000000..9baf85d
--- /dev/null
@@ -0,0 +1,45 @@
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+#
+# This Source Code Form is "Incompatible With Secondary Licenses", as
+# defined by the Mozilla Public License, v. 2.0.
+
+package Bugzilla::BugUrl::Rietveld;
+use strict;
+use base qw(Bugzilla::BugUrl);
+
+###############################
+####        Methods        ####
+###############################
+
+sub should_handle {
+    my ($class, $uri) = @_;
+    return ($uri->authority =~ /\.appspot\.com$/i
+            and $uri->path =~ m#^/\d+(?:/|/show)?$#) ? 1 : 0;
+}
+
+sub _check_value {
+    my ($class, $uri) = @_;
+
+    $uri = $class->SUPER::_check_value($uri);
+
+    # Rietveld URLs have three forms:
+    #   http(s)://example.appspot.com/1234
+    #   http(s)://example.appspot.com/1234/
+    #   http(s)://example.appspot.com/1234/show
+    if ($uri->path =~ m#^/(\d+)(?:/|/show)$#) {
+        # This is the shortest standard URL form for Rietveld issues,
+        # and so we reduce all URLs to this.
+        $uri->path('/' . $1);
+    }
+
+    # Make sure there are no query parameters.
+    $uri->query(undef);
+    # And remove any # part if there is one.
+    $uri->fragment(undef);
+
+    return $uri;
+}
+
+1;
index 8dbaa4ad408dc499293ca6bba3d4dad1a3109a0b..f5274b8bdcd9949f7fdb4027cc9240b965be5ac0 100644 (file)
         <li>A b[% %]ug in a MantisBT installation.</li>
         <li>A b[% %]ug on sourceforge.net.</li>
         <li>A Review Board review request.</li>
+        <li>An issue in a Rietveld installation.</li>
       </ul>
     [% ELSIF reason == 'id' %]
       There is no valid [% terms.bug %] id in that URL.