1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61
|
<?php
namespace LIG\Bundle\UserBundle\Form;
use Symfony\Component\Form as Form;
use Symfony\Component\HttpFoundation as HttpFoundation;
use Symfony\Component\OptionsResolver as OptionsResolver;
use Symfony\Component\Security as Security;
use Symfony\Component\Routing as Routing;
class LoginFormType extends Form\AbstractType
{
protected $request;
protected $router;
protected $csrf_provider;
public function __construct(HttpFoundation\Request $request, Routing\Router $router)
{
$this->request = $request;
$this->router = $router;
}
public function buildForm(Form\FormBuilderInterface $builder, array $options)
{
parent::buildForm($builder, $options);
$session = $this->request->getSession();
$lastUsername = (null === $session) ? '' : $session->get(Security\Core\SecurityContext::LAST_USERNAME);
$builder
->add('_csrf_token', 'hidden', array('mapped' => false, 'data' => $options['data']['_csrf_token']))
->add('login', 'text', array('label' => 'Nom d\'utilisateur ou email', 'data' => $lastUsername))
->add('password', 'password', array('label' => 'Mot de passe'))
->add('session', 'checkbox', array('label' => 'Garder ma session active', 'required' => false))
->add('connexion', 'submit', array('label' => 'Connexion'))
;
}
public function setDefaultOptions(OptionsResolver\OptionsResolverInterface $resolver)
{
$resolver->setDefaults(array(
'method' => 'POST',
'action' => $this->router->generate('fos_user_security_check'),
'csrf_protection' => false,
'csrf_field_name' => '_csrf_token',
));
}
public function getName()
{
return 'lig_user_form_login';
}
} |
Partager