forked from GNUsocial/gnu-social
		
	[Poll] Removed/refactored unnecessary files, changed redirect to default parameters in new poll route
This commit is contained in:
		@@ -1,71 +0,0 @@
 | 
				
			|||||||
<?php
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// {{{ License
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// This file is part of GNU social - https://www.gnu.org/software/social
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// GNU social is free software: you can redistribute it and/or modify
 | 
					 | 
				
			||||||
// it under the terms of the GNU Affero General Public License as published by
 | 
					 | 
				
			||||||
// the Free Software Foundation, either version 3 of the License, or
 | 
					 | 
				
			||||||
// (at your option) any later version.
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// GNU social is distributed in the hope that it will be useful,
 | 
					 | 
				
			||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					 | 
				
			||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					 | 
				
			||||||
// GNU Affero General Public License for more details.
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// You should have received a copy of the GNU Affero General Public License
 | 
					 | 
				
			||||||
// along with GNU social.  If not, see <http://www.gnu.org/licenses/>.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// }}}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
namespace Plugin\Poll\Controller;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
use App\Entity\Note;
 | 
					 | 
				
			||||||
use App\Entity\Poll;
 | 
					 | 
				
			||||||
use App\Util\Common;
 | 
					 | 
				
			||||||
use App\Util\Exception\NoSuchNoteException;
 | 
					 | 
				
			||||||
use App\Util\Exception\NotFoundException;
 | 
					 | 
				
			||||||
use Symfony\Component\HttpFoundation\Request;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * Show a Poll
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * @package  GNUsocial
 | 
					 | 
				
			||||||
 * @category PollPlugin
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * @author    Daniel Brandao <up201705812@fe.up.pt>
 | 
					 | 
				
			||||||
 * @copyright 2020 Free Software Foundation, Inc http://www.fsf.org
 | 
					 | 
				
			||||||
 * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
class ShowPoll
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Show poll
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @param Request $request
 | 
					 | 
				
			||||||
     * @param string  $id      poll id
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @throws NotFoundException                  poll does not exist
 | 
					 | 
				
			||||||
     * @throws \App\Util\Exception\NoLoggedInUser user is not logged in
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @return array Template
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    public function showPoll(Request $request, string $id)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        $user = Common::ensureLoggedIn();
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        $poll = Poll::getFromId((int) $id);
 | 
					 | 
				
			||||||
        if ($poll == null) {
 | 
					 | 
				
			||||||
            throw new NotFoundException('Poll does not exist');
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        $note = Note::getFromId($poll->getNoteId());
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if ($note == null || !$note->isVisibleTo($user)) {
 | 
					 | 
				
			||||||
            throw new NoSuchNoteException();
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        return ['_template' => 'Poll/showpoll.html.twig', 'poll' => $poll];
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -1,69 +0,0 @@
 | 
				
			|||||||
<?php
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// {{{ License
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// This file is part of GNU social - https://www.gnu.org/software/social
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// GNU social is free software: you can redistribute it and/or modify
 | 
					 | 
				
			||||||
// it under the terms of the GNU Affero General Public License as published by
 | 
					 | 
				
			||||||
// the Free Software Foundation, either version 3 of the License, or
 | 
					 | 
				
			||||||
// (at your option) any later version.
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// GNU social is distributed in the hope that it will be useful,
 | 
					 | 
				
			||||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
					 | 
				
			||||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
					 | 
				
			||||||
// GNU Affero General Public License for more details.
 | 
					 | 
				
			||||||
//
 | 
					 | 
				
			||||||
// You should have received a copy of the GNU Affero General Public License
 | 
					 | 
				
			||||||
// along with GNU social.  If not, see <http://www.gnu.org/licenses/>.
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// }}}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
namespace Plugin\Poll\Forms;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
use App\Core\Form;
 | 
					 | 
				
			||||||
use function App\Core\I18n\_m;
 | 
					 | 
				
			||||||
use App\Entity\Poll;
 | 
					 | 
				
			||||||
use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
 | 
					 | 
				
			||||||
use Symfony\Component\Form\Extension\Core\Type\HiddenType;
 | 
					 | 
				
			||||||
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
 | 
					 | 
				
			||||||
use Symfony\Component\Form\Form as SymfForm;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * Form to respond a Poll
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * @package  GNUsocial
 | 
					 | 
				
			||||||
 * @category PollPlugin
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * @author    Daniel Brandao <up201705812@fe.up.pt>
 | 
					 | 
				
			||||||
 * @copyright 2020 Free Software Foundation, Inc http://www.fsf.org
 | 
					 | 
				
			||||||
 * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
class PollResponseForm extends Form
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    /**
 | 
					 | 
				
			||||||
     * Creates a radio form with the options given
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @param Poll $poll
 | 
					 | 
				
			||||||
     * @param int  $noteId
 | 
					 | 
				
			||||||
     *
 | 
					 | 
				
			||||||
     * @return SymfForm
 | 
					 | 
				
			||||||
     */
 | 
					 | 
				
			||||||
    public static function make(Poll $poll,int $noteId): SymfForm
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        $opts    = $poll->getOptionsArr();
 | 
					 | 
				
			||||||
        $options = [];
 | 
					 | 
				
			||||||
        for ($i = 1; $i <= count($opts); ++$i) {
 | 
					 | 
				
			||||||
            $options[$opts[$i - 1]] = $i;
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        $formOptions = [
 | 
					 | 
				
			||||||
            ['Options' . $poll->getId(), ChoiceType::class, [
 | 
					 | 
				
			||||||
                'choices'  => $options,
 | 
					 | 
				
			||||||
                'expanded' => true,
 | 
					 | 
				
			||||||
            ]],
 | 
					 | 
				
			||||||
            ['note_id',     HiddenType::class, ['data' => $noteId]],
 | 
					 | 
				
			||||||
            ['pollresponse', SubmitType::class, ['label' => _m('Vote')]],
 | 
					 | 
				
			||||||
        ];
 | 
					 | 
				
			||||||
        return parent::create($formOptions);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
@@ -22,6 +22,8 @@ namespace Plugin\Poll;
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
use App\Core\DB\DB;
 | 
					use App\Core\DB\DB;
 | 
				
			||||||
use App\Core\Event;
 | 
					use App\Core\Event;
 | 
				
			||||||
 | 
					use App\Core\Form;
 | 
				
			||||||
 | 
					use function App\Core\I18n\_m;
 | 
				
			||||||
use App\Core\Module;
 | 
					use App\Core\Module;
 | 
				
			||||||
use App\Core\Router\RouteLoader;
 | 
					use App\Core\Router\RouteLoader;
 | 
				
			||||||
use App\Entity\Note;
 | 
					use App\Entity\Note;
 | 
				
			||||||
@@ -31,27 +33,16 @@ use App\Util\Exception\InvalidFormException;
 | 
				
			|||||||
use App\Util\Exception\NotFoundException;
 | 
					use App\Util\Exception\NotFoundException;
 | 
				
			||||||
use App\Util\Exception\RedirectException;
 | 
					use App\Util\Exception\RedirectException;
 | 
				
			||||||
use App\Util\Exception\ServerException;
 | 
					use App\Util\Exception\ServerException;
 | 
				
			||||||
use Plugin\Poll\Forms\PollResponseForm;
 | 
					use Symfony\Component\Form\Extension\Core\Type\ChoiceType;
 | 
				
			||||||
use Symfony\Bundle\FrameworkBundle\Controller\RedirectController;
 | 
					use Symfony\Component\Form\Extension\Core\Type\HiddenType;
 | 
				
			||||||
 | 
					use Symfony\Component\Form\Extension\Core\Type\SubmitType;
 | 
				
			||||||
use Symfony\Component\HttpFoundation\Request;
 | 
					use Symfony\Component\HttpFoundation\Request;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
/**
 | 
					/**
 | 
				
			||||||
 * Poll plugin main class
 | 
					 * Poll plugin main class
 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * @package  GNUsocial
 | 
					 * @package  GNUsocial
 | 
				
			||||||
 * @category PollPlugin
 | 
					 * @category Poll
 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * @author    Daniel Brandao <up201705812@fe.up.pt>
 | 
					 | 
				
			||||||
 * @copyright 2020 Free Software Foundation, Inc http://www.fsf.org
 | 
					 | 
				
			||||||
 * @license   https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
 | 
					 | 
				
			||||||
 */
 | 
					 | 
				
			||||||
const ID_FMT = '[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}';
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
/**
 | 
					 | 
				
			||||||
 * Poll plugin main class
 | 
					 | 
				
			||||||
 *
 | 
					 | 
				
			||||||
 * @package  GNUsocial
 | 
					 | 
				
			||||||
 * @category PollPlugin
 | 
					 | 
				
			||||||
 *
 | 
					 *
 | 
				
			||||||
 * @author    Daniel Brandao <up201705812@fe.up.pt>
 | 
					 * @author    Daniel Brandao <up201705812@fe.up.pt>
 | 
				
			||||||
 * @copyright 2020 Free Software Foundation, Inc http://www.fsf.org
 | 
					 * @copyright 2020 Free Software Foundation, Inc http://www.fsf.org
 | 
				
			||||||
@@ -68,10 +59,7 @@ class Poll extends Module
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    public function onAddRoute(RouteLoader $r): bool
 | 
					    public function onAddRoute(RouteLoader $r): bool
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        $r->connect('newpollnum', 'main/poll/new/{num<\\d*>}', [Controller\NewPoll::class, 'newpoll']);
 | 
					        $r->connect('newpoll', 'main/poll/new/{num<\\d+>?3}', [Controller\NewPoll::class, 'newpoll']);
 | 
				
			||||||
        $r->connect('showpoll', 'main/poll/{id<\\d*>}',[Controller\ShowPoll::class, 'showpoll']);
 | 
					 | 
				
			||||||
        $r->connect('answerpoll', 'main/poll/{id<\\d*>}/respond',[Controller\AnswerPoll::class, 'answerpoll']);
 | 
					 | 
				
			||||||
        $r->connect('newpoll', 'main/poll/new', RedirectController::class, ['defaults' => ['route' => 'newpollnum', 'num' => 3]]);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        return Event::next;
 | 
					        return Event::next;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
@@ -85,9 +73,9 @@ class Poll extends Module
 | 
				
			|||||||
     */
 | 
					     */
 | 
				
			||||||
    public function onStartTwigPopulateVars(array &$vars): bool
 | 
					    public function onStartTwigPopulateVars(array &$vars): bool
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        $vars['tabs'] = [['title' => 'Poll',
 | 
					        $vars['tabs'][] = ['title' => 'Poll',
 | 
				
			||||||
            'href'                 => 'newpoll',
 | 
					            'href'                 => 'newpoll',
 | 
				
			||||||
        ]];
 | 
					        ];
 | 
				
			||||||
        return Event::next;
 | 
					        return Event::next;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@@ -129,7 +117,21 @@ class Poll extends Module
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (Common::isLoggedIn() && !PollResponse::exits($poll->getId(), Common::ensureLoggedIn()->getId())) {
 | 
					        if (Common::isLoggedIn() && !PollResponse::exits($poll->getId(), Common::ensureLoggedIn()->getId())) {
 | 
				
			||||||
            $form     = PollResponseForm::make($poll, $note->getId());
 | 
					            $opts    = $poll->getOptionsArr();
 | 
				
			||||||
 | 
					            $options = [];
 | 
				
			||||||
 | 
					            for ($i = 1; $i <= count($opts); ++$i) {
 | 
				
			||||||
 | 
					                $options[$opts[$i - 1]] = $i;
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					            $formOptions = [
 | 
				
			||||||
 | 
					                ['Options' . $poll->getId(), ChoiceType::class, [
 | 
				
			||||||
 | 
					                    'choices'  => $options,
 | 
				
			||||||
 | 
					                    'expanded' => true,
 | 
				
			||||||
 | 
					                ]],
 | 
				
			||||||
 | 
					                ['note_id',     HiddenType::class, ['data' => $note->getId()]],
 | 
				
			||||||
 | 
					                ['pollresponse', SubmitType::class, ['label' => _m('Vote')]],
 | 
				
			||||||
 | 
					            ];
 | 
				
			||||||
 | 
					            $form = Form::create($formOptions);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            $formView = $form->createView();
 | 
					            $formView = $form->createView();
 | 
				
			||||||
            $ret      = self::noteActionHandle($request, $form, $note, 'pollresponse', /** TODO Documentation */ function ($note, $data) {
 | 
					            $ret      = self::noteActionHandle($request, $form, $note, 'pollresponse', /** TODO Documentation */ function ($note, $data) {
 | 
				
			||||||
                $user = Common::ensureLoggedIn();
 | 
					                $user = Common::ensureLoggedIn();
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user