]> git.ipfire.org Git - thirdparty/bugzilla.git/commitdiff
Bug 704999: Add support for GitHub for the 'See Also' field
authorMatt Selsky <selsky@columbia.edu>
Wed, 18 Apr 2012 12:37:58 +0000 (14:37 +0200)
committerFrédéric Buclin <LpSolit@gmail.com>
Wed, 18 Apr 2012 12:37:58 +0000 (14:37 +0200)
r=timello a=LpSolit

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

index 888b11398f29ddeb8b85a1d340c5599388da0980..c48a333781c439f2f93b2f746438fdbf1bc9ccef 100644 (file)
@@ -57,6 +57,7 @@ use constant SUB_CLASSES => qw(
     Bugzilla::BugUrl::Trac
     Bugzilla::BugUrl::MantisBT
     Bugzilla::BugUrl::SourceForge
+    Bugzilla::BugUrl::GitHub
 );
 
 ###############################
diff --git a/Bugzilla/BugUrl/GitHub.pm b/Bugzilla/BugUrl/GitHub.pm
new file mode 100644 (file)
index 0000000..63be65b
--- /dev/null
@@ -0,0 +1,36 @@
+# 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::GitHub;
+use strict;
+use base qw(Bugzilla::BugUrl);
+
+###############################
+####        Methods        ####
+###############################
+
+sub should_handle {
+    my ($class, $uri) = @_;
+
+    # GitHub issue URLs have only one form:
+    #  https://github.com/USER_OR_TEAM_OR_ORGANIZATION_NAME/REPOSITORY_NAME/issues/111
+    return ($uri->authority =~ /^github.com$/i
+            and $uri->path =~ m|^/[^/]+/[^/]+/issues/\d+$|) ? 1 : 0;
+}
+
+sub _check_value {
+    my ($class, $uri) = @_;
+
+    $uri = $class->SUPER::_check_value($uri);
+
+    # GitHub HTTP URLs redirect to HTTPS, so just use the HTTPS scheme.
+    $uri->scheme('https');
+
+    return $uri;
+}
+
+1;
index 3b2eca6d4e17b37f93dd2478ebaab9745ad17b8d..72d0241a0b66127caf308ab9c4ce32e911e58de1 100644 (file)
         <li>A ticket in a Trac installation.</li>
         <li>A b[% %]ug in a MantisBT installation.</li>
         <li>A b[% %]ug on sourceforge.net.</li>
+        <li>An issue on github.com.</li>
         [% Hook.process('bug_url_invalid_tracker') %]
       </ul>
     [% ELSIF reason == 'id' %]