mambax7 /
newbb5
| 1 | <?php |
||||
| 2 | // |
||||
| 3 | // ------------------------------------------------------------------------ // |
||||
| 4 | // XOOPS - PHP Content Management System // |
||||
| 5 | // Copyright (c) 2000-2016 XOOPS.org // |
||||
| 6 | // <https://xoops.org/> // |
||||
| 7 | // ------------------------------------------------------------------------ // |
||||
| 8 | // This program is free software; you can redistribute it and/or modify // |
||||
| 9 | // it under the terms of the GNU General Public License as published by // |
||||
| 10 | // the Free Software Foundation; either version 2 of the License, or // |
||||
| 11 | // (at your option) any later version. // |
||||
| 12 | // // |
||||
| 13 | // You may not change or alter any portion of this comment or credits // |
||||
| 14 | // of supporting developers from this source code or any supporting // |
||||
| 15 | // source code which is considered copyrighted (c) material of the // |
||||
| 16 | // original comment or credit authors. // |
||||
| 17 | // // |
||||
| 18 | // This program is distributed in the hope that it will be useful, // |
||||
| 19 | // but WITHOUT ANY WARRANTY; without even the implied warranty of // |
||||
| 20 | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // |
||||
| 21 | // GNU General Public License for more details. // |
||||
| 22 | // // |
||||
| 23 | // You should have received a copy of the GNU General Public License // |
||||
| 24 | // along with this program; if not, write to the Free Software // |
||||
| 25 | // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA // |
||||
| 26 | // ------------------------------------------------------------------------ // |
||||
| 27 | |||||
| 28 | use Xmf\Request; |
||||
| 29 | use XoopsModules\Xoopspoll; |
||||
|
0 ignored issues
–
show
|
|||||
| 30 | |||||
| 31 | require_once __DIR__ . '/header.php'; |
||||
| 32 | $poll_id = Request::getInt('poll_id', Request::getInt('poll_id', 0, 'POST'), 'GET'); |
||||
| 33 | $topic_id = Request::getInt('topic_id', Request::getInt('topic_id', 0, 'POST'), 'GET'); |
||||
| 34 | $forum = Request::getInt('forum', Request::getInt('forum', 0, 'POST'), 'GET'); |
||||
| 35 | |||||
| 36 | ///** @var Newbb\TopicHandler $topicHandler */ |
||||
| 37 | //$topicHandler = Newbb\Helper::getInstance()->getHandler('Topic'); |
||||
| 38 | $topicObject = $topicHandler->get($topic_id); |
||||
| 39 | if (!$topicHandler->getPermission($topicObject->getVar('forum_id'), $topicObject->getVar('topic_status'), 'vote')) { |
||||
| 40 | redirect_header(Request::getString('HTTP_REFERER', '', 'SERVER'), 2, _NOPERM); |
||||
| 41 | } |
||||
| 42 | |||||
| 43 | if (!Request::getInt('option_id', 0, 'POST')) { |
||||
| 44 | // irmtfan - add error message - simple url |
||||
| 45 | redirect_header(XOOPS_URL . "/modules/newbb/viewtopic.php?topic_id={$topic_id}", 1, _MD_NEWBB_POLL_NOOPTION); |
||||
| 46 | } |
||||
| 47 | // poll module |
||||
| 48 | $pollModuleHandler = $moduleHandler->getByDirname($GLOBALS['xoopsModuleConfig']['poll_module']); |
||||
| 49 | if (is_object($pollModuleHandler) && $pollModuleHandler->getVar('isactive')) { |
||||
| 50 | // new xoopspoll module |
||||
| 51 | if ($pollModuleHandler->getVar('version') >= 140) { |
||||
| 52 | xoops_load('constants', $GLOBALS['xoopsModuleConfig']['poll_module']); |
||||
| 53 | xoops_loadLanguage('main', $GLOBALS['xoopsModuleConfig']['poll_module']); |
||||
| 54 | |||||
| 55 | /** @var \XoopsModules\Xoopspoll\PollHandler $xpPollHandler */ |
||||
| 56 | $xpPollHandler = Xoopspoll\Helper::getInstance()->getHandler('Poll'); |
||||
|
0 ignored issues
–
show
The type
XoopsModules\Xoopspoll\Helper was not found. Maybe you did not declare it correctly or list all dependencies?
The issue could also be caused by a filter entry in the build configuration.
If the path has been excluded in your configuration, e.g. filter:
dependency_paths: ["lib/*"]
For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths Loading history...
|
|||||
| 57 | /** @var \XoopsModules\Xoopspoll\LogHandler $xpLogHandler */ |
||||
| 58 | $xpLogHandler = Xoopspoll\Helper::getInstance()->getHandler('Log'); |
||||
| 59 | /** @var \XoopsModules\Xoopspoll\Poll $pollObject */ |
||||
| 60 | $pollObject = $xpPollHandler->get($poll_id); // will create poll if poll_id = 0 exist |
||||
| 61 | // old xoopspoll or umfrage or any clone from them |
||||
| 62 | } else { |
||||
| 63 | require_once $GLOBALS['xoops']->path('modules/' . $GLOBALS['xoopsModuleConfig']['poll_module'] . '/include/constants.php'); |
||||
| 64 | $classPoll = $topicObject->loadOldPoll(); |
||||
| 65 | $pollObject = new $classPoll($poll_id); // will create poll if poll_id = 0 exist |
||||
| 66 | } |
||||
| 67 | } else { |
||||
| 68 | redirect_header(Request::getString('HTTP_REFERER', '', 'SERVER'), 2, _MD_NEWBB_POLLMODULE_ERROR); |
||||
| 69 | } |
||||
| 70 | |||||
| 71 | $mail_author = false; |
||||
| 72 | // new xoopspoll module |
||||
| 73 | if ($pollModuleHandler->getVar('version') >= 140) { |
||||
| 74 | $classConstants = \XoopsModules\Xoopspoll\Constants(); |
||||
|
0 ignored issues
–
show
The function
Constants was not found. Maybe you did not declare it correctly or list all dependencies?
(
Ignorable by Annotation
)
If this is a false-positive, you can also ignore this issue in your code via the
Loading history...
|
|||||
| 75 | if (is_object($pollObject)) { |
||||
| 76 | if ($pollObject->getVar('multiple')) { |
||||
| 77 | $optionId = Request::getInt('option_id', 0, 'POST'); |
||||
| 78 | $optionId = (array)$optionId; // type cast to make sure it's an array |
||||
| 79 | $optionId = array_map('intval', $optionId); // make sure values are integers |
||||
| 80 | } else { |
||||
| 81 | $optionId = Request::getInt('option_id', 0, 'POST'); |
||||
| 82 | } |
||||
| 83 | if (!$pollObject->hasExpired()) { |
||||
| 84 | $msg = constant('_MD_' . mb_strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_MUSTLOGIN'); |
||||
| 85 | //@todo:: add $url to all redirects |
||||
| 86 | // $url = $GLOBALS['xoops']->buildUrl("index.php", array('poll_id' => $poll_id)); |
||||
| 87 | if ($pollObject->isAllowedToVote()) { |
||||
| 88 | $thisVoter = is_object($GLOBALS['xoopsUser']) ? $GLOBALS['xoopsUser']->getVar('uid') : null; |
||||
| 89 | $votedThisPoll = $xpLogHandler->hasVoted($poll_id, xoops_getenv('REMOTE_ADDR'), $thisVoter); |
||||
| 90 | if (!$votedThisPoll) { |
||||
| 91 | /* user that hasn't voted before in this poll or module preferences allow it */ |
||||
| 92 | $voteTime = time(); |
||||
| 93 | if ($pollObject->vote($optionId, xoops_getenv('REMOTE_ADDR'), $voteTime)) { |
||||
| 94 | if (!$xpPollHandler->updateCount($pollObject)) { // update the count and save in db |
||||
| 95 | echo $pollObject->getHtmlErrors(); |
||||
| 96 | exit(); |
||||
| 97 | } |
||||
| 98 | $msg = constant('_MD_' . mb_strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_THANKSFORVOTE'); |
||||
| 99 | } else { |
||||
| 100 | /* there was a problem registering the vote */ |
||||
| 101 | redirect_header($GLOBALS['xoops']->buildUrl('index.php', ['poll_id' => $poll_id]), $classConstants::REDIRECT_DELAY_MEDIUM, constant('_MD_' . mb_strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_VOTE_ERROR')); |
||||
| 102 | } |
||||
| 103 | } else { |
||||
| 104 | $msg = constant('_MD_' . mb_strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_ALREADYVOTED'); |
||||
| 105 | } |
||||
| 106 | /* set anon user vote (and the time they voted) */ |
||||
| 107 | if (!is_object($GLOBALS['xoopsUser'])) { |
||||
| 108 | xoops_load('pollUtility', $GLOBALS['xoopsModuleConfig']['poll_module']); |
||||
| 109 | /** @var \XoopsModules\Xoopspoll\Utility $classPollUtility */ |
||||
| 110 | $classPollUtility = new \XoopsModules\Xoopspoll\Utility(); |
||||
|
0 ignored issues
–
show
The type
XoopsModules\Xoopspoll\Utility was not found. Maybe you did not declare it correctly or list all dependencies?
The issue could also be caused by a filter entry in the build configuration.
If the path has been excluded in your configuration, e.g. filter:
dependency_paths: ["lib/*"]
For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths Loading history...
|
|||||
| 111 | $classPollUtility::setVoteCookie($poll_id, $voteTime, 0); |
||||
| 112 | } |
||||
| 113 | } else { |
||||
| 114 | $msg = constant('_MD_' . mb_strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_CANNOTVOTE'); |
||||
| 115 | } |
||||
| 116 | } else { |
||||
| 117 | /* poll has expired so just show the results */ |
||||
| 118 | $msg = constant('_MD_' . mb_strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . 'SORRYEXPIRED'); |
||||
| 119 | } |
||||
| 120 | } else { |
||||
| 121 | $msg = constant('_MD_' . mb_strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_ERROR_INVALID_POLLID'); |
||||
| 122 | } |
||||
| 123 | if (null !== $url) { |
||||
| 124 | redirect_header($url, $classConstants::REDIRECT_DELAY_MEDIUM, $msg); |
||||
| 125 | } else { |
||||
| 126 | redirect_header($GLOBALS['xoops']->buildUrl('viewtopic.php', ['topic_id' => $topic_id]), $classConstants::REDIRECT_DELAY_MEDIUM, $msg); |
||||
| 127 | } |
||||
| 128 | // old xoopspoll or umfrage or any clone from them |
||||
| 129 | } else { |
||||
| 130 | $classLog = $classPoll . 'Log'; |
||||
| 131 | if (is_object($GLOBALS['xoopsUser'])) { |
||||
| 132 | if ($classLog::hasVoted($poll_id, Request::getString('REMOTE_ADDR', '', 'SERVER'), $GLOBALS['xoopsUser']->getVar('uid'))) { |
||||
| 133 | $msg = _PL_ALREADYVOTED; |
||||
|
0 ignored issues
–
show
|
|||||
| 134 | setcookie("newbb_polls[{$poll_id}]", 1); |
||||
| 135 | } else { |
||||
| 136 | // irmtfan save ip to db |
||||
| 137 | $pollObject->vote(Request::getInt('option_id', 0, 'POST'), Request::getString('REMOTE_ADDR', '', 'SERVER'), $GLOBALS['xoopsUser']->getVar('uid')); |
||||
| 138 | $pollObject->updateCount(); |
||||
| 139 | $msg = _PL_THANKSFORVOTE; |
||||
|
0 ignored issues
–
show
|
|||||
| 140 | setcookie("newbb_polls[{$poll_id}]", 1); |
||||
| 141 | } |
||||
| 142 | } else { |
||||
| 143 | if ($classLog::hasVoted($poll_id, Request::getString('REMOTE_ADDR', '', 'SERVER'))) { |
||||
| 144 | $msg = _PL_ALREADYVOTED; |
||||
| 145 | setcookie("newbb_polls[{$poll_id}]", 1); |
||||
| 146 | } else { |
||||
| 147 | $pollObject->vote(Request::getInt('option_id', 0, 'POST'), Request::getString('REMOTE_ADDR', '', 'SERVER')); |
||||
| 148 | $pollObject->updateCount(); |
||||
| 149 | $msg = _PL_THANKSFORVOTE; |
||||
| 150 | setcookie("newbb_polls[{$poll_id}]", 1); |
||||
| 151 | } |
||||
| 152 | } |
||||
| 153 | } |
||||
| 154 | // irmtfan - simple url |
||||
| 155 | redirect_header("viewtopic.php?topic_id={$topic_id}", 1, $msg); |
||||
| 156 |
The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g.
excluded_paths: ["lib/*"], you can move it to the dependency path list as follows:For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths