summaryrefslogtreecommitdiffstats
path: root/extensions
diff options
context:
space:
mode:
authorKoosha Khajeh Moogahi <koosha.khajeh@gmail.com>2013-02-03 23:46:29 +0100
committerFrédéric Buclin <LpSolit@gmail.com>2013-02-03 23:46:29 +0100
commitfb3e9b2bfe67aadd7c4baadd485e39e818d643cf (patch)
treede64e3f32269dc2e3e6382c95de1f338fa7ff6d9 /extensions
parent52deac516eb3dd1cc22f97b3a295ee856f69d354 (diff)
downloadbugzilla-fb3e9b2bfe67aadd7c4baadd485e39e818d643cf.tar.gz
bugzilla-fb3e9b2bfe67aadd7c4baadd485e39e818d643cf.tar.xz
Bug 821410: Add support for bitbucket.org for the 'See Also' field
r/a=LpSolit
Diffstat (limited to 'extensions')
-rw-r--r--extensions/MoreBugUrl/Extension.pm1
-rw-r--r--extensions/MoreBugUrl/lib/BitBucket.pm39
-rw-r--r--extensions/MoreBugUrl/template/en/default/hook/global/user-error-bug_url_invalid_tracker.html.tmpl1
3 files changed, 41 insertions, 0 deletions
diff --git a/extensions/MoreBugUrl/Extension.pm b/extensions/MoreBugUrl/Extension.pm
index 5c71fa598..f2ca7150c 100644
--- a/extensions/MoreBugUrl/Extension.pm
+++ b/extensions/MoreBugUrl/Extension.pm
@@ -12,6 +12,7 @@ use strict;
use parent qw(Bugzilla::Extension);
use constant MORE_SUB_CLASSES => qw(
+ Bugzilla::Extension::MoreBugUrl::BitBucket
Bugzilla::Extension::MoreBugUrl::ReviewBoard
Bugzilla::Extension::MoreBugUrl::Rietveld
Bugzilla::Extension::MoreBugUrl::RT
diff --git a/extensions/MoreBugUrl/lib/BitBucket.pm b/extensions/MoreBugUrl/lib/BitBucket.pm
new file mode 100644
index 000000000..fbb7be1a1
--- /dev/null
+++ b/extensions/MoreBugUrl/lib/BitBucket.pm
@@ -0,0 +1,39 @@
+# 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::Extension::MoreBugUrl::BitBucket;
+
+use 5.10.1;
+use strict;
+use parent qw(Bugzilla::BugUrl);
+
+###############################
+#### Methods ####
+###############################
+
+sub should_handle {
+ my ($class, $uri) = @_;
+
+ # BitBucket issues have the form of
+ # bitbucket.org/user/project/issue/1234
+ return (lc($uri->authority) eq "bitbucket.org"
+ && $uri->path =~ m|[^/]+/[^/]+/issue/\d+|i) ? 1 : 0;
+}
+
+sub _check_value {
+ my $class = shift;
+
+ my $uri = $class->SUPER::_check_value(@_);
+
+ my ($path) = $uri->path =~ m|([^/]+/[^/]+/issue/\d+)|i;
+ $uri = new URI("https://bitbucket.org/$path");
+
+ return $uri;
+}
+
+1;
+
diff --git a/extensions/MoreBugUrl/template/en/default/hook/global/user-error-bug_url_invalid_tracker.html.tmpl b/extensions/MoreBugUrl/template/en/default/hook/global/user-error-bug_url_invalid_tracker.html.tmpl
index 7683e4299..0c62f6e5f 100644
--- a/extensions/MoreBugUrl/template/en/default/hook/global/user-error-bug_url_invalid_tracker.html.tmpl
+++ b/extensions/MoreBugUrl/template/en/default/hook/global/user-error-bug_url_invalid_tracker.html.tmpl
@@ -6,6 +6,7 @@
# defined by the Mozilla Public License, v. 2.0.
#%]
+<li>An issue on bitbucket.org.</li>
<li>A Review Board review request.</li>
<li>An issue in a Rietveld installation.</li>
<li>A ticket in an RT installation.</li>