📄 kick.cmd.php3
字号:
<?php
function room_in($what, $in)
{
$rooms = explode(",",$in);
for (reset($rooms); $room_name=current($rooms); next($rooms))
{
if (strcasecmp($what, $room_name) == 0) return true;
}
return false;
}
$UU = $Cmd[1];
// Check for invalid characters
if (ereg("[\, ]", stripslashes($UU)))
{
$Error = L_ERR_USR_16;
}
else
{
// Ensure the current user is moderator for the current room or admin.
$DbLink->query("SELECT password,perms,rooms FROM ".C_REG_TBL." WHERE username='$U' LIMIT 1");
if ($DbLink->num_rows() == 0)
{
$Error = L_NO_MODERATOR;
$DbLink->clean_results();
}
else
{
list($password,$perms,$rooms) = $DbLink->next_record();
$DbLink->clean_results();
if (($password != $PWD_Hash) || (($perms != "moderator")&&($perms != "admin")) || (($perms == "moderator")&&(!room_in(stripslashes($R), $rooms))))
{
$Error = L_NO_MODERATOR;
}
else
{
// Define an additional condition for moderators so they can only kick an user from their current room
$Query4Moder = ($perms != "admin" ? "room='$R' AND " : "");
// Ensure the user to be kicked is logged in (into the current room for moderators)
$DbLink->query("SELECT status FROM ".C_USR_TBL." WHERE ".$Query4Moder."username='$UU' LIMIT 1");
if ($DbLink->num_rows() == 0)
{
$DbLink->clean_results();
$Error = sprintf(L_NONEXIST_USER, stripslashes($UU));
}
else
{
list($status) = $DbLink->next_record();
$DbLink->clean_results();
// Ensure the user to be kicked is not a more powerfull user (admin>moderator)
if ($status == "a" || ($status == "m" && $perms != "admin"))
{
$Error = sprintf(L_NO_KICKED, stripslashes($UU));
}
else
{
$IsCommand = true;
$DbLink->query("UPDATE ".C_USR_TBL." SET u_time='".time()."', status='k' WHERE ".$Query4Moder."username='$UU'");
$Error = sprintf(L_KICKED, stripslashes($UU));
}
}
}
}
}
?>
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -