Zeile 12 | Zeile 12 |
---|
define('THIS_SCRIPT', 'reputation.php');
$templatelist = "reputation_addlink,reputation_no_votes,reputation,reputation_vote,multipage,multipage_end,multipage_jump_page,multipage_nextpage,multipage_page,multipage_page_current,multipage_page_link_current,multipage_prevpage,multipage_start,reputation_vote_delete";
|
define('THIS_SCRIPT', 'reputation.php');
$templatelist = "reputation_addlink,reputation_no_votes,reputation,reputation_vote,multipage,multipage_end,multipage_jump_page,multipage_nextpage,multipage_page,multipage_page_current,multipage_page_link_current,multipage_prevpage,multipage_start,reputation_vote_delete";
|
$templatelist .= ",reputation_add_delete,reputation_add_neutral,reputation_add_positive,reputation_add_negative,reputation_add_error,reputation_add_error_nomodal,reputation_add,reputation_added,reputation_deleted,reputation_vote_report";
| $templatelist .= ",reputation_add_delete,reputation_add_neutral,reputation_add_positive,reputation_add_negative,reputation_add_error,reputation_add_error_nomodal,reputation_add,reputation_added,reputation_deleted,reputation_vote_report,postbit_reputation_formatted_link";
|
require_once "./global.php"; require_once MYBB_ROOT."inc/class_parser.php";
| require_once "./global.php"; require_once MYBB_ROOT."inc/class_parser.php";
|
Zeile 36 | Zeile 36 |
---|
}
// If we have a specified incoming username, validate it and fetch permissions for it
|
}
// If we have a specified incoming username, validate it and fetch permissions for it
|
$uid = $mybb->get_input('uid', 1);
| $uid = $mybb->get_input('uid', MyBB::INPUT_INT);
|
$user = get_user($uid); if(!$user) { error($lang->add_no_uid); } $user_permissions = user_permissions($uid);
|
$user = get_user($uid); if(!$user) { error($lang->add_no_uid); } $user_permissions = user_permissions($uid);
|
| // Fetch display group properties. $displaygroupfields = array("title", "description", "namestyle", "usertitle", "stars", "starimage", "image"); $display_group = usergroup_displaygroup($user['displaygroup']); if(is_array($display_group)) { $user_permissions = array_merge($user_permissions, $display_group); }
|
$mybb->input['action'] = $mybb->get_input('action');
| $mybb->input['action'] = $mybb->get_input('action');
|
Zeile 54 | Zeile 62 |
---|
if($mybb->usergroup['cangivereputations'] != 1) { $message = $lang->add_no_permission;
|
if($mybb->usergroup['cangivereputations'] != 1) { $message = $lang->add_no_permission;
|
if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else
| if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else
|
{ eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); }
| { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); }
|
Zeile 70 | Zeile 78 |
---|
if($user_permissions['usereputationsystem'] != 1) { $message = $lang->add_disabled;
|
if($user_permissions['usereputationsystem'] != 1) { $message = $lang->add_disabled;
|
if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";");
| if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";");
|
} echo $error; exit;
| } echo $error; exit;
|
Zeile 104 | Zeile 112 |
---|
$mybb->input['pid'] = 0; }
|
$mybb->input['pid'] = 0; }
|
// Check if this user has reached their "maximum reputations per day" quota if($mybb->usergroup['maxreputationsday'] != 0 && ($mybb->input['action'] != "do_add" || ($mybb->input['action'] == "do_add" && empty($mybb->input['delete'])))) { $timesearch = TIME_NOW - (60 * 60 * 24); $query = $db->simple_select("reputation", "*", "adduid='".$mybb->user['uid']."' AND dateline>'$timesearch'"); $numtoday = $db->num_rows($query);
// Reached the quota - error. if($numtoday >= $mybb->usergroup['maxreputationsday']) { $message = $lang->add_maxperday; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); } echo $error; exit; } }
// Is the user giving too much reputation to another? if($mybb->usergroup['maxreputationsperuser'] != 0 && ($mybb->input['action'] != "do_add" || ($mybb->input['action'] == "do_add" && empty($mybb->input['delete'])))) { $timesearch = TIME_NOW - (60 * 60 * 24); $query = $db->simple_select("reputation", "*", "uid='".$uid."' AND dateline>'$timesearch'"); $numtoday = $db->num_rows($query);
if($numtoday >= $mybb->usergroup['maxreputationsperuser']) { $message = $lang->add_maxperuser; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); } echo $error; exit; } }
if($mybb->get_input('pid', 1))
| if($mybb->get_input('pid', MyBB::INPUT_INT))
|
{ // Make sure that this post exists, and that the author of the post we're giving this reputation for corresponds with the user the rep is being given to.
|
{ // Make sure that this post exists, and that the author of the post we're giving this reputation for corresponds with the user the rep is being given to.
|
$post = get_post($mybb->get_input('pid', 1));
| $post = get_post($mybb->get_input('pid', MyBB::INPUT_INT));
|
if($post) { $thread = get_thread($post['tid']); $forum = get_forum($thread['fid']); $forumpermissions = forum_permissions($forum['fid']);
|
if($post) { $thread = get_thread($post['tid']); $forum = get_forum($thread['fid']); $forumpermissions = forum_permissions($forum['fid']);
|
|
|
// Post doesn't belong to that user or isn't visible
|
// Post doesn't belong to that user or isn't visible
|
if($uid != $post['uid'] || ($post['visible'] == 0 && !is_moderator($fid, "canviewunapprove")) || $post['visible'] < 0) { $mybb->input['pid'] = 0; } // Thread isn't visible elseif(($thread['visible'] == 0 && !is_moderator($forum['fid'], "canviewunapprove")) || $thread['visible'] < 0) { $mybb->input['pid'] = 0;
| if($uid != $post['uid'] || $post['visible'] != 1) { $mybb->input['pid'] = 0; }
// Thread isn't visible elseif($thread['visible'] != 1) { $mybb->input['pid'] = 0;
|
}
|
}
|
|
|
// Current user can't see the forum elseif($forumpermissions['canview'] == 0 || $forumpermissions['canpostreplys'] == 0 || $mybb->user['suspendposting'] == 1)
|
// Current user can't see the forum elseif($forumpermissions['canview'] == 0 || $forumpermissions['canpostreplys'] == 0 || $mybb->user['suspendposting'] == 1)
|
{ $mybb->input['pid'] = 0;
| { $mybb->input['pid'] = 0;
|
}
|
}
|
|
|
// Current user can't see that thread elseif(isset($forumpermissions['canonlyviewownthreads']) && $forumpermissions['canonlyviewownthreads'] == 1 && $thread['uid'] != $mybb->user['uid']) { $mybb->input['pid'] = 0;
|
// Current user can't see that thread elseif(isset($forumpermissions['canonlyviewownthreads']) && $forumpermissions['canonlyviewownthreads'] == 1 && $thread['uid'] != $mybb->user['uid']) { $mybb->input['pid'] = 0;
|
} else // We have the correct post, but has the user given too much reputation to another in the same thread? if($mybb->usergroup['maxreputationsperthread'] != 0 && ($mybb->input['action'] != "do_add" || ($mybb->input['action'] == "do_add" && empty($mybb->input['delete'])))) { $timesearch = TIME_NOW - (60 * 60 * 24); $query = $db->query(" SELECT COUNT(p.pid) AS posts FROM ".TABLE_PREFIX."reputation r LEFT JOIN ".TABLE_PREFIX."posts p ON (p.pid = r.pid) WHERE r.uid = '{$uid}' AND r.adduid = '{$mybb->user['uid']}' AND p.tid = '{$post['tid']}' AND r.dateline > '{$timesearch}' ");
$numtoday = $db->fetch_field($query, 'posts');
if($numtoday >= $mybb->usergroup['maxreputationsperthread']) { $message = $lang->add_maxperthread; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); } echo $error; exit; }
| |
} } else
| } } else
|
Zeile 220 | Zeile 156 |
---|
// Fetch the existing reputation for this user given by our current user if there is one. // If multiple reputations is allowed, then this isn't needed
|
// Fetch the existing reputation for this user given by our current user if there is one. // If multiple reputations is allowed, then this isn't needed
|
if($mybb->settings['multirep'] != 1 && $mybb->get_input('pid', 1) == 0)
| if($mybb->settings['multirep'] != 1 && $mybb->get_input('pid', MyBB::INPUT_INT) == 0)
|
{ $query = $db->simple_select("reputation", "*", "adduid='".$mybb->user['uid']."' AND uid='{$uid}' AND pid='0'"); $existing_reputation = $db->fetch_array($query); $rid = $existing_reputation['rid'];
|
{ $query = $db->simple_select("reputation", "*", "adduid='".$mybb->user['uid']."' AND uid='{$uid}' AND pid='0'"); $existing_reputation = $db->fetch_array($query); $rid = $existing_reputation['rid'];
|
| $was_post = false;
|
}
|
}
|
if($mybb->get_input('pid', 1) != 0)
| if($mybb->get_input('pid', MyBB::INPUT_INT) != 0)
|
{
|
{
|
$query = $db->simple_select("reputation", "*", "adduid='".$mybb->user['uid']."' AND uid='{$uid}' AND pid = '".$mybb->get_input('pid', 1)."'"); $existing_post_reputation = $db->fetch_array($query); $rid = $existing_post_reputation['rid'];
| $query = $db->simple_select("reputation", "*", "adduid='".$mybb->user['uid']."' AND uid='{$uid}' AND pid = '".$mybb->get_input('pid', MyBB::INPUT_INT)."'"); $existing_reputation = $db->fetch_array($query); $rid = $existing_reputation['rid']; $was_post = true; }
if($rid == 0 && ($mybb->input['action'] != "do_add" || ($mybb->input['action'] == "do_add" && empty($mybb->input['delete'])))) { $message = '';
// Check if this user has reached their "maximum reputations per day" quota if($mybb->usergroup['maxreputationsday'] != 0) { $timesearch = TIME_NOW - (60 * 60 * 24); $query = $db->simple_select("reputation", "*", "adduid='{$mybb->user['uid']}' AND dateline>'$timesearch'"); $numtoday = $db->num_rows($query);
// Reached the quota - error. if($numtoday >= $mybb->usergroup['maxreputationsday']) { $message = $lang->add_maxperday; } }
// Is the user giving too much reputation to another? if(!$message && $mybb->usergroup['maxreputationsperuser'] != 0) { $timesearch = TIME_NOW - (60 * 60 * 24); $query = $db->simple_select("reputation", "*", "uid='{$uid}' AND adduid='{$mybb->user['uid']}' AND dateline>'$timesearch'"); $numtoday = $db->num_rows($query);
if($numtoday >= $mybb->usergroup['maxreputationsperuser']) { $message = $lang->add_maxperuser; } }
// We have the correct post, but has the user given too much reputation to another in the same thread? if(!$message && $was_post && $mybb->usergroup['maxreputationsperthread'] != 0) { $timesearch = TIME_NOW - (60 * 60 * 24); $query = $db->query(" SELECT COUNT(p.pid) AS posts FROM ".TABLE_PREFIX."reputation r LEFT JOIN ".TABLE_PREFIX."posts p ON (p.pid = r.pid) WHERE r.uid = '{$uid}' AND r.adduid = '{$mybb->user['uid']}' AND p.tid = '{$post['tid']}' AND r.dateline > '{$timesearch}' ");
$numtoday = $db->fetch_field($query, 'posts');
if($numtoday >= $mybb->usergroup['maxreputationsperthread']) { $message = $lang->add_maxperthread; } }
if($message) { if($mybb->input['nomodal']) { eval('$error = "'.$templates->get("reputation_add_error_nomodal", 1, 0).'";'); } else { eval('$error = "'.$templates->get("reputation_add_error", 1, 0).'";'); } echo $error; exit; }
|
} }
| } }
|
Zeile 243 | Zeile 246 |
---|
$plugins->run_hooks("reputation_do_add_start");
// Check if the reputation power they're trying to give is within their "power limit"
|
$plugins->run_hooks("reputation_do_add_start");
// Check if the reputation power they're trying to give is within their "power limit"
|
$reputation = abs($mybb->get_input('reputation', 1));
| $reputation = abs($mybb->get_input('reputation', MyBB::INPUT_INT));
|
// Deleting our current reputation of this user. if(!empty($mybb->input['delete'])) { // Only administrators, super moderators, as well as users who gave a specifc vote can delete one.
|
// Deleting our current reputation of this user. if(!empty($mybb->input['delete'])) { // Only administrators, super moderators, as well as users who gave a specifc vote can delete one.
|
if($mybb->usergroup['cancp'] != 1 && $mybb->usergroup['issupermod'] != 1 && $existing_reputation['adduid'] != $mybb->user['uid']) {
| if($mybb->usergroup['issupermod'] != 1 && ($mybb->usergroup['candeletereputations'] != 1 || $existing_reputation['adduid'] != $mybb->user['uid'] || $mybb->user['uid'] == 0)) {
|
error_no_permission(); }
|
error_no_permission(); }
|
if($mybb->get_input('pid', 1) != 0)
| if($mybb->get_input('pid', MyBB::INPUT_INT) != 0)
|
{
|
{
|
$db->delete_query("reputation", "uid='{$uid}' AND adduid='".$mybb->user['uid']."' AND pid = '".$mybb->get_input('pid', 1)."'");
| $db->delete_query("reputation", "uid='{$uid}' AND adduid='".$mybb->user['uid']."' AND pid = '".$mybb->get_input('pid', MyBB::INPUT_INT)."'");
|
} else {
| } else {
|
Zeile 274 | Zeile 277 |
---|
}
$mybb->input['comments'] = trim($mybb->get_input('comments')); // Trim whitespace to check for length
|
}
$mybb->input['comments'] = trim($mybb->get_input('comments')); // Trim whitespace to check for length
|
if(my_strlen($mybb->input['comments']) < $mybb->settings['minreplength'] && $mybb->get_input('pid', 1) == 0)
| if(my_strlen($mybb->input['comments']) < $mybb->settings['minreplength'] && $mybb->get_input('pid', MyBB::INPUT_INT) == 0)
|
{
|
{
|
$message = $lang->add_no_comment;
| $message = $lang->sprintf($lang->add_no_comment, $mybb->settings['minreplength']);
|
if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";");
| if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";");
|
Zeile 294 | Zeile 297 |
---|
{ $message = $lang->add_invalidpower; if($mybb->input['nomodal'])
|
{ $message = $lang->add_invalidpower; if($mybb->input['nomodal'])
|
{ eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); } echo $error; exit; }
// The user is trying to give a negative reputation, but negative reps have been disabled. if($mybb->get_input('reputation', 1) < 0 && $mybb->settings['negrep'] != 1) { $message = $lang->add_negative_disabled; if($mybb->input['nomodal']) {
| {
|
eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";");
|
eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";");
|
}
| } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); } echo $error; exit; }
// The user is trying to give a negative reputation, but negative reps have been disabled. if($mybb->get_input('reputation', MyBB::INPUT_INT) < 0 && $mybb->settings['negrep'] != 1) { $message = $lang->add_negative_disabled; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); }
|
else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";");
| else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";");
|
Zeile 322 | Zeile 325 |
---|
}
// This user is trying to give a neutral reputation, but neutral reps have been disabled.
|
}
// This user is trying to give a neutral reputation, but neutral reps have been disabled.
|
if($mybb->get_input('reputation', 1) == 0 && $mybb->settings['neurep'] != 1)
| if($mybb->get_input('reputation', MyBB::INPUT_INT) == 0 && $mybb->settings['neurep'] != 1)
|
{ $message = $lang->add_neutral_disabled; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";");
|
{ $message = $lang->add_neutral_disabled; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";");
|
} else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); } echo $error; exit; }
// This user is trying to give a positive reputation, but positive reps have been disabled. if($mybb->get_input('reputation', 1) > 0 && $mybb->settings['posrep'] != 1) { $message = $lang->add_positive_disabled; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); }
| } else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";"); } echo $error; exit; }
// This user is trying to give a positive reputation, but positive reps have been disabled. if($mybb->get_input('reputation', MyBB::INPUT_INT) > 0 && $mybb->settings['posrep'] != 1) { $message = $lang->add_positive_disabled; if($mybb->input['nomodal']) { eval("\$error = \"".$templates->get("reputation_add_error_nomodal", 1, 0)."\";"); }
|
else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";");
| else { eval("\$error = \"".$templates->get("reputation_add_error", 1, 0)."\";");
|
Zeile 373 | Zeile 376 |
---|
$reputation = array( "uid" => $uid, "adduid" => $mybb->user['uid'],
|
$reputation = array( "uid" => $uid, "adduid" => $mybb->user['uid'],
|
"pid" => $mybb->get_input('pid', 1), "reputation" => $mybb->get_input('reputation', 1),
| "pid" => $mybb->get_input('pid', MyBB::INPUT_INT), "reputation" => $mybb->get_input('reputation', MyBB::INPUT_INT),
|
"dateline" => TIME_NOW, "comments" => $db->escape_string($mybb->input['comments']) );
| "dateline" => TIME_NOW, "comments" => $db->escape_string($mybb->input['comments']) );
|
Zeile 382 | Zeile 385 |
---|
$plugins->run_hooks("reputation_do_add_process");
// Updating an existing reputation
|
$plugins->run_hooks("reputation_do_add_process");
// Updating an existing reputation
|
if(!empty($existing_reputation['uid']) || !empty($existing_post_reputation['uid']))
| if(!empty($existing_reputation['uid']))
|
{
|
{
|
if(!empty($existing_reputation['uid'])) { $db->update_query("reputation", $reputation, "rid='".$existing_reputation['rid']."'"); } elseif(!empty($existing_post_reputation['uid'])) { $db->update_query("reputation", $reputation, "rid='".$existing_post_reputation['rid']."'"); }
| $db->update_query("reputation", $reputation, "rid='".$existing_reputation['rid']."'");
|
// Recount the reputation of this user - keep it in sync. $query = $db->simple_select("reputation", "SUM(reputation) AS reputation_count", "uid='{$uid}'");
| // Recount the reputation of this user - keep it in sync. $query = $db->simple_select("reputation", "SUM(reputation) AS reputation_count", "uid='{$uid}'");
|
Zeile 427 | Zeile 423 |
---|
$plugins->run_hooks("reputation_add_start");
// If we have an existing reputation for this user, the user can modify or delete it.
|
$plugins->run_hooks("reputation_add_start");
// If we have an existing reputation for this user, the user can modify or delete it.
|
if(!empty($existing_reputation['uid']) || !empty($existing_post_reputation['uid']))
| $user['username'] = htmlspecialchars_uni($user['username']); if(!empty($existing_reputation['uid']))
|
{ $vote_title = $lang->sprintf($lang->update_reputation_vote, $user['username']); $vote_button = $lang->update_vote;
|
{ $vote_title = $lang->sprintf($lang->update_reputation_vote, $user['username']); $vote_button = $lang->update_vote;
|
if(!empty($existing_reputation['uid']))
| $comments = htmlspecialchars_uni($existing_reputation['comments']);
if($mybb->usergroup['issupermod'] == 1 || ($mybb->usergroup['candeletereputations'] == 1 && $existing_reputation['adduid'] == $mybb->user['uid'] && $mybb->user['uid'] != 0))
|
{
|
{
|
$comments = htmlspecialchars_uni($existing_reputation['comments']); } elseif(!empty($existing_post_reputation['uid'])) { $comments = htmlspecialchars_uni($existing_post_reputation['comments']);
| $reputation_pid = $mybb->get_input('pid', MyBB::INPUT_INT); eval("\$delete_button = \"".$templates->get("reputation_add_delete")."\";");
|
}
|
}
|
eval("\$delete_button = \"".$templates->get("reputation_add_delete")."\";");
| |
} // Otherwise we're adding an entirely new reputation for this user. else
| } // Otherwise we're adding an entirely new reputation for this user. else
|
Zeile 452 | Zeile 446 |
---|
} $lang->user_comments = $lang->sprintf($lang->user_comments, $user['username']);
|
} $lang->user_comments = $lang->sprintf($lang->user_comments, $user['username']);
|
if($mybb->get_input('pid', 1))
| if($mybb->get_input('pid', MyBB::INPUT_INT))
|
{ $post_rep_info = $lang->sprintf($lang->add_reputation_to_post, $user['username']); $lang->user_comments = $lang->no_comment_needed;
| { $post_rep_info = $lang->sprintf($lang->add_reputation_to_post, $user['username']); $lang->user_comments = $lang->no_comment_needed;
|
Zeile 475 | Zeile 469 |
---|
$vote_check[$value] = ''; }
|
$vote_check[$value] = ''; }
|
if(!empty($existing_reputation['uid']))
| if(!empty($existing_reputation['uid']) && !$was_post)
|
{ $vote_check[$existing_reputation['reputation']] = " selected=\"selected\""; }
| { $vote_check[$existing_reputation['reputation']] = " selected=\"selected\""; }
|
Zeile 502 | Zeile 496 |
---|
} }
|
} }
|
$mybb->input['pid'] = $mybb->get_input('pid', 1);
| $reputation_pid = $mybb->get_input('pid', MyBB::INPUT_INT);
|
$plugins->run_hooks("reputation_add_end"); eval("\$reputation_add = \"".$templates->get("reputation_add", 1, 0)."\";");
| $plugins->run_hooks("reputation_add_end"); eval("\$reputation_add = \"".$templates->get("reputation_add", 1, 0)."\";");
|
Zeile 537 | Zeile 531 |
---|
SELECT r.*, u.username FROM ".TABLE_PREFIX."reputation r LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=r.adduid)
|
SELECT r.*, u.username FROM ".TABLE_PREFIX."reputation r LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=r.adduid)
|
WHERE rid = '".$mybb->get_input('rid', 1)."'
| WHERE rid = '".$mybb->get_input('rid', MyBB::INPUT_INT)."'
|
"); $existing_reputation = $db->fetch_array($query);
// Only administrators, super moderators, as well as users who gave a specifc vote can delete one.
|
"); $existing_reputation = $db->fetch_array($query);
// Only administrators, super moderators, as well as users who gave a specifc vote can delete one.
|
if($mybb->usergroup['cancp'] != 1 && $mybb->usergroup['issupermod'] != 1 && $existing_reputation['adduid'] != $mybb->user['uid'])
| if($mybb->usergroup['issupermod'] != 1 && ($mybb->usergroup['candeletereputations'] != 1 || $existing_reputation['adduid'] != $mybb->user['uid'] || $mybb->user['uid'] == 0))
|
{ error_no_permission(); }
// Delete the specified reputation
|
{ error_no_permission(); }
// Delete the specified reputation
|
$db->delete_query("reputation", "uid='{$uid}' AND rid='".$mybb->get_input('rid', 1)."'");
| $db->delete_query("reputation", "uid='{$uid}' AND rid='".$mybb->get_input('rid', MyBB::INPUT_INT)."'");
|
// Recount the reputation of this user - keep it in sync. $query = $db->simple_select("reputation", "SUM(reputation) AS reputation_count", "uid='{$uid}'");
| // Recount the reputation of this user - keep it in sync. $query = $db->simple_select("reputation", "SUM(reputation) AS reputation_count", "uid='{$uid}'");
|
Zeile 571 | Zeile 565 |
---|
error_no_permission(); }
|
error_no_permission(); }
|
// Set display group to their user group if they don't have a display group. if(!$user['displaygroup']) { $user['displaygroup'] = $user['usergroup']; }
// Fetch display group properties. $displaygroupfields = array('title', 'description', 'namestyle', 'usertitle', 'stars', 'starimage', 'image', 'usereputationsystem'); $display_group = usergroup_displaygroup($user['displaygroup']);
if($user_permissions['usereputationsystem'] != 1 || $display_group['title'] && $display_group['usereputationsystem'] == 0)
| if($user_permissions['usereputationsystem'] != 1)
|
{ // Group has reputation disabled or user has a display group that has reputation disabled error($lang->reputations_disabled_group); }
|
{ // Group has reputation disabled or user has a display group that has reputation disabled error($lang->reputations_disabled_group); }
|
| $user['username'] = htmlspecialchars_uni($user['username']);
|
$lang->nav_profile = $lang->sprintf($lang->nav_profile, $user['username']); $lang->reputation_report = $lang->sprintf($lang->reputation_report, $user['username']);
// Format the user name using the group username style $username = format_name($user['username'], $user['usergroup'], $user['displaygroup']);
|
$lang->nav_profile = $lang->sprintf($lang->nav_profile, $user['username']); $lang->reputation_report = $lang->sprintf($lang->reputation_report, $user['username']);
// Format the user name using the group username style $username = format_name($user['username'], $user['usergroup'], $user['displaygroup']);
|
// Set display group to their user group if they don't have a display group. if(!$user['displaygroup']) { $user['displaygroup'] = $user['usergroup']; }
$usertitle = '';
| $usertitle = '';
|
// This user has a custom user title if(trim($user['usertitle']) != '')
| // This user has a custom user title if(trim($user['usertitle']) != '')
|
Zeile 612 | Zeile 591 |
---|
$usertitle = $display_group['usertitle']; } // Otherwise, fetch it from our titles table for the number of posts this user has
|
$usertitle = $display_group['usertitle']; } // Otherwise, fetch it from our titles table for the number of posts this user has
|
else {
| else {
|
$usertitles = $cache->read('usertitles'); foreach($usertitles as $title) { if($title['posts'] <= $user['postnum']) { $usertitle = $title['title'];
|
$usertitles = $cache->read('usertitles'); foreach($usertitles as $title) { if($title['posts'] <= $user['postnum']) { $usertitle = $title['title'];
|
| break;
|
} } unset($usertitles, $title); } $usertitle = htmlspecialchars_uni($usertitle);
|
} } unset($usertitles, $title); } $usertitle = htmlspecialchars_uni($usertitle);
|
|
|
// If the user has permission to add reputations - show the image if($mybb->usergroup['cangivereputations'] == 1 && $mybb->user['uid'] != $user['uid'] && ($mybb->settings['posrep'] || $mybb->settings['neurep'] || $mybb->settings['negrep'])) {
| // If the user has permission to add reputations - show the image if($mybb->usergroup['cangivereputations'] == 1 && $mybb->user['uid'] != $user['uid'] && ($mybb->settings['posrep'] || $mybb->settings['neurep'] || $mybb->settings['negrep'])) {
|
Zeile 640 | Zeile 620 |
---|
// Build navigation menu add_breadcrumb($lang->nav_profile, get_profile_link($user['uid'])); add_breadcrumb($lang->nav_reputation);
|
// Build navigation menu add_breadcrumb($lang->nav_profile, get_profile_link($user['uid'])); add_breadcrumb($lang->nav_reputation);
|
|
|
// Check our specified conditionals for what type of reputations to show $show_selected = array('all' => '', 'positive' => '', 'neutral' => '', 'negative' => ''); switch($mybb->get_input('show'))
| // Check our specified conditionals for what type of reputations to show $show_selected = array('all' => '', 'positive' => '', 'neutral' => '', 'negative' => ''); switch($mybb->get_input('show'))
|
Zeile 664 | Zeile 644 |
---|
$s_url = '&show=all'; $conditions = ''; $show_select['all'] = 'selected="selected"';
|
$s_url = '&show=all'; $conditions = ''; $show_select['all'] = 'selected="selected"';
|
break; }
| break; }
|
// Check the sorting options for the reputation list $sort_selected = array('username' => '', 'last_ipdated' => ''); switch($mybb->get_input('sort'))
| // Check the sorting options for the reputation list $sort_selected = array('username' => '', 'last_ipdated' => ''); switch($mybb->get_input('sort'))
|
Zeile 691 | Zeile 671 |
---|
// Fetch the total number of reputations for this user $query = $db->simple_select("reputation r", "COUNT(r.rid) AS reputation_count", "r.uid='{$user['uid']}' $conditions"); $reputation_count = $db->fetch_field($query, "reputation_count");
|
// Fetch the total number of reputations for this user $query = $db->simple_select("reputation r", "COUNT(r.rid) AS reputation_count", "r.uid='{$user['uid']}' $conditions"); $reputation_count = $db->fetch_field($query, "reputation_count");
|
|
|
// If the user has no reputation, suspect 0... if(!$user['reputation']) {
| // If the user has no reputation, suspect 0... if(!$user['reputation']) {
|
Zeile 704 | Zeile 684 |
---|
$sync_reputation = (int)$reputation['reputation']; $total_reputation = $reputation['total_reputation'];
|
$sync_reputation = (int)$reputation['reputation']; $total_reputation = $reputation['total_reputation'];
|
|
|
if($sync_reputation != $user['reputation']) { // We're out of sync! Oh noes!
| if($sync_reputation != $user['reputation']) { // We're out of sync! Oh noes!
|
Zeile 717 | Zeile 697 |
---|
$positive_week = $negative_week = $neutral_week = 0; $positive_month = $negative_month = $neutral_month = 0; $positive_6months = $negative_6months = $neutral_6months = 0;
|
$positive_week = $negative_week = $neutral_week = 0; $positive_month = $negative_month = $neutral_month = 0; $positive_6months = $negative_6months = $neutral_6months = 0;
|
|
|
// Unix timestamps for when this week, month and last 6 months started $last_week = TIME_NOW-604800; $last_month = TIME_NOW-2678400;
| // Unix timestamps for when this week, month and last 6 months started $last_week = TIME_NOW-604800; $last_month = TIME_NOW-2678400;
|
Zeile 742 | Zeile 722 |
---|
if($reputation_vote['dateline'] >= $last_6months) { $positive_6months++;
|
if($reputation_vote['dateline'] >= $last_6months) { $positive_6months++;
|
}
| }
|
} // Negative reputation given else if($reputation_vote['reputation'] < 0)
| } // Negative reputation given else if($reputation_vote['reputation'] < 0)
|
Zeile 751 | Zeile 731 |
---|
if($reputation_vote['dateline'] >= $last_week) { $negative_week++;
|
if($reputation_vote['dateline'] >= $last_week) { $negative_week++;
|
} if($reputation_vote['dateline'] >= $last_month)
| } if($reputation_vote['dateline'] >= $last_month)
|
{ $negative_month++; }
| { $negative_month++; }
|
Zeile 770 | Zeile 750 |
---|
$neutral_week++; } if($reputation_vote['dateline'] >= $last_month)
|
$neutral_week++; } if($reputation_vote['dateline'] >= $last_month)
|
{
| {
|
$neutral_month++;
|
$neutral_month++;
|
}
| }
|
if($reputation_vote['dateline'] >= $last_6months) { $neutral_6months++; } }
|
if($reputation_vote['dateline'] >= $last_6months) { $neutral_6months++; } }
|
}
| } // Format all reputation numbers $rep_total = my_number_format($user['reputation']); $f_positive_count = my_number_format($positive_count); $f_negative_count = my_number_format($negative_count); $f_neutral_count = my_number_format($neutral_count); $f_positive_week = my_number_format($positive_week); $f_negative_week = my_number_format($negative_week); $f_neutral_week = my_number_format($neutral_week); $f_positive_month = my_number_format($positive_month); $f_negative_month = my_number_format($negative_month); $f_neutral_month = my_number_format($neutral_month); $f_positive_6months = my_number_format($positive_6months); $f_negative_6months = my_number_format($negative_6months); $f_neutral_6months = my_number_format($neutral_6months);
|
// Format the user's 'total' reputation if($user['reputation'] < 0) {
| // Format the user's 'total' reputation if($user['reputation'] < 0) {
|
Zeile 802 | Zeile 797 |
---|
// General // We count how many reps in total, then subtract the reps from posts
|
// General // We count how many reps in total, then subtract the reps from posts
|
$rep_members = my_number_format($total_reputation - $rep_posts);
| $rep_members = my_number_format($total_reputation - $rep_post_count);
|
// Is negative reputation disabled? If so, tell the user if($mybb->settings['negrep'] == 0) { $neg_rep_info = $lang->neg_rep_disabled;
|
// Is negative reputation disabled? If so, tell the user if($mybb->settings['negrep'] == 0) { $neg_rep_info = $lang->neg_rep_disabled;
|
}
| }
|
if($mybb->settings['posrep'] == 0)
|
if($mybb->settings['posrep'] == 0)
|
{
| {
|
$pos_rep_info = $lang->pos_rep_disabled; }
|
$pos_rep_info = $lang->pos_rep_disabled; }
|
if($mybb->settings['neurep'] == 0)
| if($mybb->settings['neurep'] == 0) { $neu_rep_info = $lang->neu_rep_disabled; }
$perpage = (int)$mybb->settings['repsperpage']; if($perpage < 1)
|
{
|
{
|
$neu_rep_info = $lang->neu_rep_disabled;
| $perpage = 15;
|
}
// Check if we're browsing a specific page of results
|
}
// Check if we're browsing a specific page of results
|
if($mybb->get_input('page', 1) > 0)
| if($mybb->get_input('page', MyBB::INPUT_INT) > 0)
|
{
|
{
|
$page = $mybb->get_input('page', 1); $start = ($page-1) * $mybb->settings['repsperpage']; $pages = $reputation_count / $mybb->settings['repsperpage'];
| $page = $mybb->get_input('page', MyBB::INPUT_INT); $start = ($page-1) * $perpage; $pages = $reputation_count / $perpage;
|
$pages = ceil($pages); if($page > $pages) {
| $pages = ceil($pages); if($page > $pages) {
|
Zeile 844 | Zeile 845 |
---|
// Build out multipage navigation if($reputation_count > 0) {
|
// Build out multipage navigation if($reputation_count > 0) {
|
$multipage = multipage($reputation_count, $mybb->settings['repsperpage'], $page, "reputation.php?uid={$user['uid']}".$s_url);
| $multipage = multipage($reputation_count, $perpage, $page, "reputation.php?uid={$user['uid']}".$s_url);
|
}
// Fetch the reputations which will be displayed on this page
| }
// Fetch the reputations which will be displayed on this page
|
Zeile 854 | Zeile 855 |
---|
LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=r.adduid) WHERE r.uid='{$user['uid']}' $conditions ORDER BY $order
|
LEFT JOIN ".TABLE_PREFIX."users u ON (u.uid=r.adduid) WHERE r.uid='{$user['uid']}' $conditions ORDER BY $order
|
LIMIT $start, {$mybb->settings['repsperpage']}
| LIMIT $start, {$perpage}
|
");
// Gather a list of items that have post reputation
| ");
// Gather a list of items that have post reputation
|
Zeile 873 | Zeile 874 |
---|
if(!empty($post_cache)) {
|
if(!empty($post_cache)) {
|
$sql = implode(',', $post_cache);
| $pids = implode(',', $post_cache);
$sql = array("p.pid IN ({$pids})");
// get forums user cannot view $unviewable = get_unviewable_forums(true); if($unviewable) { $sql[] = "p.fid NOT IN ({$unviewable})"; }
// get inactive forums $inactive = get_inactive_forums(); if($inactive) { $sql[] = "p.fid NOT IN ({$inactive})"; }
if(!$mybb->user['ismoderator']) { $sql[] = "p.visible='1'"; $sql[] = "t.visible='1'"; }
$sql = implode(' AND ', $sql);
|
$query = $db->query("
|
$query = $db->query("
|
SELECT p.pid, p.uid, p.message, t.tid, t.subject
| SELECT p.pid, p.uid, p.fid, p.visible, p.message, t.tid, t.subject, t.visible AS thread_visible
|
FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."threads t ON (t.tid=p.tid)
|
FROM ".TABLE_PREFIX."posts p LEFT JOIN ".TABLE_PREFIX."threads t ON (t.tid=p.tid)
|
WHERE p.pid IN ({$sql})
| WHERE {$sql}
|
");
|
");
|
| $forumpermissions = array();
|
while($post = $db->fetch_array($query)) {
|
while($post = $db->fetch_array($query)) {
|
| if(($post['visible'] == 0 || $post['thread_visible'] == 0) && !is_moderator($post['fid'], 'canviewunapprove')) { continue; }
if(($post['visible'] == -1 || $post['thread_visible'] == -1) && !is_moderator($post['fid'], 'canviewdeleted')) { continue; }
if(!isset($forumpermissions[$post['fid']])) { $forumpermissions[$post['fid']] = forum_permissions($post['fid']); }
// Make sure we can view this post if(isset($forumpermissions[$post['fid']]['canonlyviewownthreads']) && $forumpermissions[$post['fid']]['canonlyviewownthreads'] == 1 && $post['uid'] != $mybb->user['uid']) { continue; }
|
$post_reputation[$post['pid']] = $post; } }
| $post_reputation[$post['pid']] = $post; } }
|
Zeile 896 | Zeile 944 |
---|
if($reputation_vote['adduid'] == 0) { $reputation_vote['user_reputation'] = 0;
|
if($reputation_vote['adduid'] == 0) { $reputation_vote['user_reputation'] = 0;
|
}
| }
|
$reputation_vote['user_reputation'] = get_reputation($reputation_vote['user_reputation'], $reputation_vote['adduid']);
// Format the username of this poster
| $reputation_vote['user_reputation'] = get_reputation($reputation_vote['user_reputation'], $reputation_vote['adduid']);
// Format the username of this poster
|
Zeile 905 | Zeile 953 |
---|
{ $reputation_vote['username'] = $lang->na; $reputation_vote['user_reputation'] = '';
|
{ $reputation_vote['username'] = $lang->na; $reputation_vote['user_reputation'] = '';
|
} else
| } else
|
{
|
{
|
$reputation_vote['username'] = format_name($reputation_vote['username'], $reputation_vote['user_usergroup'], $reputation_vote['user_displaygroup']);
| $reputation_vote['username'] = format_name(htmlspecialchars_uni($reputation_vote['username']), $reputation_vote['user_usergroup'], $reputation_vote['user_displaygroup']);
|
$reputation_vote['username'] = build_profile_link($reputation_vote['username'], $reputation_vote['uid']); $reputation_vote['user_reputation'] = "({$reputation_vote['user_reputation']})"; }
| $reputation_vote['username'] = build_profile_link($reputation_vote['username'], $reputation_vote['uid']); $reputation_vote['user_reputation'] = "({$reputation_vote['user_reputation']})"; }
|
Zeile 943 | Zeile 991 |
---|
// Format the date this reputation was last modified $last_updated_date = my_date('relative', $reputation_vote['dateline']); $last_updated = $lang->sprintf($lang->last_updated, $last_updated_date);
|
// Format the date this reputation was last modified $last_updated_date = my_date('relative', $reputation_vote['dateline']); $last_updated = $lang->sprintf($lang->last_updated, $last_updated_date);
|
| $user['username'] = htmlspecialchars_uni($user['username']);
|
// Is this rating specific to a post? $postrep_given = ''; if($reputation_vote['pid']) {
|
// Is this rating specific to a post? $postrep_given = ''; if($reputation_vote['pid']) {
|
$link = get_post_link($reputation_vote['pid'])."#pid{$reputation_vote['pid']}";
$thread_link = '';
| $postrep_given = $lang->sprintf($lang->postrep_given_nolink, $user['username']);
|
if(isset($post_reputation[$reputation_vote['pid']])) {
|
if(isset($post_reputation[$reputation_vote['pid']])) {
|
$post = $post_reputation[$reputation_vote['pid']];
$thread_link = get_thread_link($post['tid']); $subject = htmlspecialchars_uni($post['subject']);
| $thread_link = get_thread_link($post_reputation[$reputation_vote['pid']]['tid']); $subject = htmlspecialchars_uni($parser->parse_badwords($post_reputation[$reputation_vote['pid']]['subject']));
|
$thread_link = $lang->sprintf($lang->postrep_given_thread, $thread_link, $subject);
|
$thread_link = $lang->sprintf($lang->postrep_given_thread, $thread_link, $subject);
|
| $link = get_post_link($reputation_vote['pid'])."#pid{$reputation_vote['pid']}";
$postrep_given = $lang->sprintf($lang->postrep_given, $link, $user['username'], $thread_link);
|
}
|
}
|
$postrep_given = $lang->sprintf($lang->postrep_given, $link, $user['username'], $thread_link);
| |
}
// Does the current user have permission to delete this reputation? Show delete link $delete_link = '';
|
}
// Does the current user have permission to delete this reputation? Show delete link $delete_link = '';
|
if($mybb->usergroup['cancp'] == 1 || $mybb->usergroup['issupermod'] == 1 || ($mybb->usergroup['cangivereputations'] == 1 && $reputation_vote['adduid'] == $mybb->user['uid'] && $mybb->user['uid'] != 0))
| if($mybb->usergroup['issupermod'] == 1 || ($mybb->usergroup['candeletereputations'] == 1 && $reputation_vote['adduid'] == $mybb->user['uid'] && $mybb->user['uid'] != 0))
|
{ eval("\$delete_link = \"".$templates->get("reputation_vote_delete")."\";"); }
| { eval("\$delete_link = \"".$templates->get("reputation_vote_delete")."\";"); }
|