summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rwxr-xr-xcreateaccount.cgi7
-rw-r--r--defparams.pl13
-rw-r--r--template/en/default/account/login.html.tmpl10
-rw-r--r--template/en/default/global/useful-links.html.tmpl4
-rw-r--r--template/en/default/global/user-error.html.tmpl6
-rw-r--r--template/en/default/index.html.tmpl4
6 files changed, 38 insertions, 6 deletions
diff --git a/createaccount.cgi b/createaccount.cgi
index 37776a780..4ce347fcf 100755
--- a/createaccount.cgi
+++ b/createaccount.cgi
@@ -69,6 +69,13 @@ if (defined($login)) {
|| ThrowTemplateError($template->error());
exit;
}
+
+ my $createexp = Param('createemailregexp');
+ if (!($createexp)
+ || ($login !~ /$createexp/)) {
+ ThrowUserError("account_creation_disabled");
+ exit;
+ }
# Create account
my $password = InsertNewUser($login, $realname);
diff --git a/defparams.pl b/defparams.pl
index 3e4807dc2..fc3fe8245 100644
--- a/defparams.pl
+++ b/defparams.pl
@@ -694,6 +694,19 @@ You will get this message once a day until you\'ve dealt with these bugs!
},
{
+ name => 'createemailregexp',
+ desc => 'This defines the regexp to use for email addresses that are ' .
+ 'permitted to self-register using a "New Account" feature. The ' .
+ 'default (.*) permits any account matching the emailregexp ' .
+ 'to be created. If this parameter is left blank, no users ' .
+ 'will be permitted to create their own accounts and all accounts ' .
+ 'will have to be created by an administrator',
+ type => 't',
+ default => q:.*:,
+ checker => \&check_regexp
+ },
+
+ {
name => 'voteremovedmail',
desc => 'This is a mail message to send to anyone who gets a vote removed ' .
'from a bug for any reason. %to% gets replaced by the person who ' .
diff --git a/template/en/default/account/login.html.tmpl b/template/en/default/account/login.html.tmpl
index 16a49580f..7d6e298d2 100644
--- a/template/en/default/account/login.html.tmpl
+++ b/template/en/default/account/login.html.tmpl
@@ -102,10 +102,12 @@
[% UNLESS Param("useLDAP") %]
<hr>
- <p>
- If you don't have a Bugzilla account, you can
- <a href="createaccount.cgi">create a new account</a>.
- </p>
+ [% IF Param("createemailregexp") %]
+ <p>
+ If you don't have a Bugzilla account, you can
+ <a href="createaccount.cgi">create a new account</a>.
+ </p>
+ [% END %]
<form method="get" action="token.cgi">
<input type="hidden" name="a" value="reqpw">
diff --git a/template/en/default/global/useful-links.html.tmpl b/template/en/default/global/useful-links.html.tmpl
index e172a0f55..fac714b0e 100644
--- a/template/en/default/global/useful-links.html.tmpl
+++ b/template/en/default/global/useful-links.html.tmpl
@@ -121,7 +121,9 @@
[% ELSE %]
<td valign="middle" align="right">
- <a href="createaccount.cgi">New&nbsp;Account</a> |
+ [% IF Param('createemailregexp') %]
+ <a href="createaccount.cgi">New&nbsp;Account</a> |
+ [% END %]
<a href="query.cgi?GoAheadAndLogIn=1">Log&nbsp;In</a>
</td>
</tr>
diff --git a/template/en/default/global/user-error.html.tmpl b/template/en/default/global/user-error.html.tmpl
index 0d43b62a5..965a3fb27 100644
--- a/template/en/default/global/user-error.html.tmpl
+++ b/template/en/default/global/user-error.html.tmpl
@@ -41,6 +41,12 @@
to any [% parameters %] which you may have set before calling
ThrowUserError.
+ [% ELSIF error == "account_creation_disabled" %]
+ [% title = "Account Creation Disabled" %]
+ Account self-creation has been disabled or restricted.
+ <hr>
+ New accounts must be created by an administrator.
+
[% ELSIF error == "account_disabled" %]
[% title = "Account Disabled" %]
[% disabled_reason %]
diff --git a/template/en/default/index.html.tmpl b/template/en/default/index.html.tmpl
index 07cdf63b5..dccf43f58 100644
--- a/template/en/default/index.html.tmpl
+++ b/template/en/default/index.html.tmpl
@@ -65,7 +65,9 @@ function addSidebar() {
<a href="relogin.cgi">Logout [% username FILTER html %]</a><br>
[% ELSE %]
<a href="query.cgi?GoAheadAndLogIn=1">Log in to an existing account</a><br>
- <a href="createaccount.cgi">Open a new Bugzilla account</a><br>
+ [% IF Param('createemailregexp') %]
+ <a href="createaccount.cgi">Open a new Bugzilla account</a><br>
+ [% END %]
[% END %]
</p><p>
<a href="javascript:addSidebar()">Add to Sidebar</a> (Requires Mozilla or Netscape 6)<br>