These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more
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; |
||
30 | |||
31 | include_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 Xoopspoll\PollHandler $xpPollHandler */ |
||
56 | $xpPollHandler = Xoopspoll\Helper::getInstance()->getHandler('Poll'); |
||
57 | /** @var Xoopspoll\LogHandler $xpLogHandler */ |
||
58 | $xpLogHandler = Xoopspoll\Helper::getInstance()->getHandler('Log'); |
||
59 | /** @var \XoopsPoll $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 | include $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 = Xoopspoll\Constants(); |
||
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_' . 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_' . 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_' . strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_VOTE_ERROR')); |
||
102 | } |
||
103 | } else { |
||
104 | $msg = constant('_MD_' . 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 Xoopspoll\Utility $classPollUtility */ |
||
110 | $classPollUtility = new \Xoopspoll\Utility(); |
||
111 | $classXoopspoll\Utility::setVoteCookie($poll_id, $voteTime, 0); |
||
0 ignored issues
–
show
Bug
introduced
by
![]() |
|||
112 | } |
||
113 | } else { |
||
114 | $msg = constant('_MD_' . strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . '_CANNOTVOTE'); |
||
115 | } |
||
116 | } else { |
||
117 | /* poll has expired so just show the results */ |
||
118 | $msg = constant('_MD_' . strtoupper($GLOBALS['xoopsModuleConfig']['poll_module']) . 'SORRYEXPIRED'); |
||
119 | } |
||
120 | } else { |
||
121 | $msg = constant('_MD_' . 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; |
||
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; |
||
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 |