aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--phpBB/includes/acp/acp_ban.php2
-rw-r--r--phpBB/includes/functions_user.php16
-rw-r--r--phpBB/includes/mcp/mcp_ban.php2
3 files changed, 15 insertions, 5 deletions
diff --git a/phpBB/includes/acp/acp_ban.php b/phpBB/includes/acp/acp_ban.php
index b85b2d36d4..cf490a4643 100644
--- a/phpBB/includes/acp/acp_ban.php
+++ b/phpBB/includes/acp/acp_ban.php
@@ -26,7 +26,7 @@ class acp_ban
$unbansubmit= (isset($_POST['unbansubmit'])) ? true : false;
$current_time = time();
- $user->add_lang('acp/ban');
+ $user->add_lang(array('acp/ban', 'acp/users'));
$this->tpl_name = 'acp_ban';
// Ban submitted?
diff --git a/phpBB/includes/functions_user.php b/phpBB/includes/functions_user.php
index c78238b25f..6df1b838b2 100644
--- a/phpBB/includes/functions_user.php
+++ b/phpBB/includes/functions_user.php
@@ -602,12 +602,12 @@ function user_ban($mode, $ban, $ban_len, $ban_len_other, $ban_exclude, $ban_reas
$ban_end = 0;
}
- $founder = array();
+ $founder = $founder_names = array();
if (!$ban_exclude)
{
// Create a list of founder...
- $sql = 'SELECT user_id, user_email
+ $sql = 'SELECT user_id, user_email, username_clean
FROM ' . USERS_TABLE . '
WHERE user_type = ' . USER_FOUNDER;
$result = $db->sql_query($sql);
@@ -615,6 +615,7 @@ function user_ban($mode, $ban, $ban_len, $ban_len_other, $ban_exclude, $ban_reas
while ($row = $db->sql_fetchrow($result))
{
$founder[$row['user_id']] = $row['user_email'];
+ $founder_names[$row['user_id']] = $row['username_clean'];
}
$db->sql_freeresult($result);
}
@@ -641,7 +642,16 @@ function user_ban($mode, $ban, $ban_len, $ban_len_other, $ban_exclude, $ban_reas
$username = trim($username);
if ($username != '')
{
- $sql_usernames[] = utf8_clean_string($username);
+ $clean_name = utf8_clean_string($username);
+ if ($clean_name == $user->data['username_clean'])
+ {
+ trigger_error($user->lang['CANNOT_BAN_YOURSELF']);
+ }
+ if (in_array($clean_name, $founder_names))
+ {
+ trigger_error($user->lang['CANNOT_BAN_FOUNDER']);
+ }
+ $sql_usernames[] = $clean_name;
}
}
diff --git a/phpBB/includes/mcp/mcp_ban.php b/phpBB/includes/mcp/mcp_ban.php
index aea2466888..5080ae08f2 100644
--- a/phpBB/includes/mcp/mcp_ban.php
+++ b/phpBB/includes/mcp/mcp_ban.php
@@ -29,7 +29,7 @@ class mcp_ban
$unbansubmit = (isset($_POST['unbansubmit'])) ? true : false;
$current_time = time();
- $user->add_lang('acp/ban');
+ $user->add_lang(array('acp/ban', 'acp/users'));
$this->tpl_name = 'mcp_ban';
// Ban submitted?