mirror of
https://github.com/torrentpier/torrentpier.git
synced 2024-12-15 00:21:17 -08:00
428984524e
* Hide vote button in poll if user already voted * Update viewtopic.php * Update CHANGELOG.md
170 lines
5.0 KiB
PHP
170 lines
5.0 KiB
PHP
<?php
|
||
/**
|
||
* TorrentPier – Bull-powered BitTorrent tracker engine
|
||
*
|
||
* @copyright Copyright (c) 2005-2024 TorrentPier (https://torrentpier.com)
|
||
* @link https://github.com/torrentpier/torrentpier for the canonical source repository
|
||
* @license https://github.com/torrentpier/torrentpier/blob/master/LICENSE MIT License
|
||
*/
|
||
|
||
define('BB_SCRIPT', 'vote');
|
||
|
||
require __DIR__ . '/common.php';
|
||
|
||
// Start session management
|
||
$user->session_start(['req_login' => true]);
|
||
|
||
$mode = (string)$_POST['mode'];
|
||
$topic_id = (int)$_POST['topic_id'];
|
||
$forum_id = (int)$_POST['forum_id'];
|
||
$vote_id = (int)$_POST['vote_id'];
|
||
|
||
$return_topic_url = TOPIC_URL . $topic_id;
|
||
$return_topic_url .= !empty($_POST['start']) ? "&start=" . (int)$_POST['start'] : '';
|
||
|
||
set_die_append_msg($forum_id, $topic_id);
|
||
|
||
$poll = new TorrentPier\Legacy\Poll();
|
||
|
||
// Checking $topic_id
|
||
if (!$topic_id) {
|
||
bb_die($lang['INVALID_TOPIC_ID']);
|
||
}
|
||
|
||
// Getting topic data if present
|
||
if (!$t_data = DB()->fetch_row("SELECT * FROM " . BB_TOPICS . " WHERE topic_id = $topic_id LIMIT 1")) {
|
||
bb_die($lang['INVALID_TOPIC_ID_DB']);
|
||
}
|
||
|
||
// Checking the rights
|
||
if ($mode != 'poll_vote') {
|
||
if ($t_data['topic_poster'] != $userdata['user_id']) {
|
||
if (!IS_AM) {
|
||
bb_die($lang['NOT_AUTHORISED']);
|
||
}
|
||
}
|
||
}
|
||
|
||
// Checking the ability to make changes
|
||
if ($mode == 'poll_delete') {
|
||
if ($t_data['topic_time'] < TIMENOW - $bb_cfg['poll_max_days'] * 86400) {
|
||
bb_die(sprintf($lang['NEW_POLL_DAYS'], $bb_cfg['poll_max_days']));
|
||
}
|
||
if (!IS_ADMIN && ($t_data['topic_vote'] != POLL_FINISHED)) {
|
||
bb_die($lang['CANNOT_DELETE_POLL']);
|
||
}
|
||
}
|
||
|
||
switch ($mode) {
|
||
case 'poll_vote':
|
||
// Checking for poll existence
|
||
if (!$t_data['topic_vote']) {
|
||
bb_die($lang['POST_HAS_NO_POLL']);
|
||
}
|
||
|
||
// Checking that the topic has not been locked
|
||
if ($t_data['topic_status'] == TOPIC_LOCKED) {
|
||
bb_die($lang['TOPIC_LOCKED_SHORT']);
|
||
}
|
||
|
||
// Checking that poll has not been finished
|
||
if (!\TorrentPier\Legacy\Poll::pollIsActive($t_data)) {
|
||
bb_die($lang['NEW_POLL_ENDED']);
|
||
}
|
||
|
||
if (!$vote_id) {
|
||
bb_die($lang['NO_VOTE_OPTION']);
|
||
}
|
||
|
||
if (\TorrentPier\Legacy\Poll::userIsAlreadyVoted($topic_id, (int)$userdata['user_id'])) {
|
||
bb_die($lang['ALREADY_VOTED']);
|
||
}
|
||
|
||
DB()->query("
|
||
UPDATE " . BB_POLL_VOTES . " SET
|
||
vote_result = vote_result + 1
|
||
WHERE topic_id = $topic_id
|
||
AND vote_id = $vote_id
|
||
LIMIT 1
|
||
");
|
||
|
||
if (DB()->affected_rows() != 1) {
|
||
bb_die($lang['NO_VOTE_OPTION']);
|
||
}
|
||
|
||
// Voting process
|
||
DB()->query("INSERT IGNORE INTO " . BB_POLL_USERS . " (topic_id, user_id, vote_ip, vote_dt) VALUES ($topic_id, {$userdata['user_id']}, '" . USER_IP . "', " . TIMENOW . ")");
|
||
CACHE('bb_poll_data')->rm("poll_$topic_id");
|
||
bb_die($lang['VOTE_CAST']);
|
||
break;
|
||
case 'poll_start':
|
||
// Checking for poll existence
|
||
if (!$t_data['topic_vote']) {
|
||
bb_die($lang['POST_HAS_NO_POLL']);
|
||
}
|
||
|
||
// Starting the poll
|
||
DB()->query("UPDATE " . BB_TOPICS . " SET topic_vote = 1 WHERE topic_id = $topic_id");
|
||
bb_die($lang['NEW_POLL_START']);
|
||
break;
|
||
case 'poll_finish':
|
||
// Checking for poll existence
|
||
if (!$t_data['topic_vote']) {
|
||
bb_die($lang['POST_HAS_NO_POLL']);
|
||
}
|
||
|
||
// Finishing the poll
|
||
DB()->query("UPDATE " . BB_TOPICS . " SET topic_vote = " . POLL_FINISHED . " WHERE topic_id = $topic_id");
|
||
bb_die($lang['NEW_POLL_END']);
|
||
break;
|
||
case 'poll_delete':
|
||
// Checking for poll existence
|
||
if (!$t_data['topic_vote']) {
|
||
bb_die($lang['POST_HAS_NO_POLL']);
|
||
}
|
||
|
||
// Removing poll from database
|
||
$poll->delete_poll($topic_id);
|
||
bb_die($lang['NEW_POLL_DELETE']);
|
||
break;
|
||
case 'poll_add':
|
||
// Checking that no other poll exists
|
||
if ($t_data['topic_vote']) {
|
||
bb_die($lang['NEW_POLL_ALREADY']);
|
||
}
|
||
|
||
// Make a poll from $_POST data
|
||
$poll->build_poll_data($_POST);
|
||
|
||
// Showing errors if present
|
||
if ($poll->err_msg) {
|
||
bb_die($poll->err_msg);
|
||
}
|
||
|
||
// Adding poll info to the database
|
||
$poll->insert_votes_into_db($topic_id);
|
||
bb_die($lang['NEW_POLL_ADDED']);
|
||
break;
|
||
case 'poll_edit':
|
||
// Checking for poll existence
|
||
if (!$t_data['topic_vote']) {
|
||
bb_die($lang['POST_HAS_NO_POLL']);
|
||
}
|
||
|
||
// Make a poll from $_POST data
|
||
$poll->build_poll_data($_POST);
|
||
|
||
// Showing errors if present
|
||
if ($poll->err_msg) {
|
||
bb_die($poll->err_msg);
|
||
}
|
||
|
||
// Updating poll info to the database
|
||
$poll->insert_votes_into_db($topic_id);
|
||
CACHE('bb_poll_data')->rm("poll_$topic_id");
|
||
bb_die($lang['NEW_POLL_RESULTS']);
|
||
break;
|
||
default:
|
||
bb_die('Invalid mode: ' . htmlCHR($mode));
|
||
}
|