defis48/src/Mmi/Bundle/EnigmaBundle/Controller/DefaultController.php

80 lines
2.4 KiB
PHP
Raw Normal View History

2016-01-12 19:57:14 +01:00
<?php
namespace Mmi\Bundle\EnigmaBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
2016-01-12 20:31:48 +01:00
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
2016-01-12 23:51:17 +01:00
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\Form\Extension\Core\Type\TextType;
use Symfony\Component\Form\Extension\Core\Type\SubmitType;
use Symfony\Component\Form\Extension\Core\Type\PasswordType;
2016-01-12 19:57:14 +01:00
class DefaultController extends Controller
{
/**
2016-01-13 19:25:20 +01:00
* @Route("/enigma/{enigma}", name="enigma", requirements={"enigma": "\w{32}"})
2016-01-12 20:31:48 +01:00
* @Template()
2016-01-12 19:57:14 +01:00
*/
2016-01-13 19:25:20 +01:00
public function indexAction($enigma = null)
2016-01-12 19:57:14 +01:00
{
2016-01-12 23:51:17 +01:00
if (!$this->get('session')->get('user')) {
2016-01-13 19:25:20 +01:00
$this->get('session')->set(
'redirect_to',
$this->generateUrl('enigma', ['enigma' => null !== $enigma ? $enigma : null])
);
2016-01-12 23:51:17 +01:00
return $this->redirectToRoute('enigma_login');
}
2016-01-13 19:25:20 +01:00
2016-01-12 20:31:48 +01:00
return [];
2016-01-12 19:57:14 +01:00
}
2016-01-12 23:51:17 +01:00
/**
* @Route("/enigma/login", name="enigma_login")
* @Template()
*/
public function loginAction(Request $request)
{
2016-01-13 19:25:20 +01:00
$redirectTo = $this->get('session')->get('redirect_to');
$redirect = $redirectTo ? $this->redirect($redirectTo) : $this->redirectToRoute('enigma');
2016-01-12 23:51:17 +01:00
if ($this->get('session')->get('user')) {
2016-01-13 19:25:20 +01:00
return $redirect;
2016-01-12 23:51:17 +01:00
}
$form = $this->createFormBuilder()
->add('username', TextType::class, ['required' => true])
->add('password', PasswordType::class, ['required' => true])
->add('Se connecter', SubmitType::class)
->getForm();
if ($request->isMethod('post')) {
$form->handleRequest($request);
if ($form->isValid()) {
$user = $this->getDoctrine()
->getRepository('MmiEnigmaBundle:Team')
->findOneBy([
'username' => $form->getData()['username'],
'password' => $form->getData()['password'],
]);
if ($user === null) {
$invalid = true;
} else {
$this->get('session')->set('user', $user);
2016-01-13 19:25:20 +01:00
return $redirect;
2016-01-12 23:51:17 +01:00
}
}
}
return [
'form' => $form->createView(),
'invalid' => !empty($invalid),
];
}
2016-01-12 19:57:14 +01:00
}