-
Notifications
You must be signed in to change notification settings - Fork 49
/
UsuarioController.php
80 lines (63 loc) · 2.9 KB
/
UsuarioController.php
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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
namespace Desymfony\DesymfonyBundle\Controller;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Symfony\Component\Security\Core\SecurityContext;
use Symfony\Component\Security\Core\Authentication\Token\UsernamePasswordToken;
use Desymfony\DesymfonyBundle\Form\UsuarioType;
class UsuarioController extends Controller
{
public function indexAction()
{
return $this->render('DesymfonyBundle:Usuario:index.html.twig');
}
public function loginAction()
{
if ($this->get('request')->attributes->has(SecurityContext::AUTHENTICATION_ERROR)) {
$error = $this->get('request')->attributes->get(SecurityContext::AUTHENTICATION_ERROR);
} else {
$error = $this->get('request')->getSession()->get(SecurityContext::AUTHENTICATION_ERROR);
}
return $this->render('DesymfonyBundle:Usuario:login.html.twig', array(
'last_username' => $this->get('request')->getSession()->get(SecurityContext::LAST_USERNAME),
'error' => $error,
));
}
public function perfilAction()
{
$usuario = $this->get('security.context')->getToken()->getUser();
return $this->render('DesymfonyBundle:Usuario:perfil.html.twig', array('usuario' => $usuario));
}
public function registroAction()
{
$form = $this->get('form.factory')->create(new UsuarioType(), array());
$request = $this->get('request');
if ($request->getMethod() == 'POST') {
$form->bindRequest($request);
if ($form->isValid()) {
// Mensaje para notificar al usuario que todo ha salido bien
$session = $this->get('request')->getSession();
$session->setFlash('notice', 'Gracias por registrarte en Desymfony 2011');
// Obtenemos el usuario
$usuario = $form->getData();
// Codificamos el password
$factory = $this->get('security.encoder_factory');
$codificador = $factory->getEncoder($usuario);
$password = $codificador->encodePassword($usuario->getPassword(), $usuario->getSalt());
$usuario->setPassword($password);
// Guardamos el objeto en base de datos
$em = $this->get('doctrine')->getEntityManager();
$em->persist($usuario);
$em->flush();
// Logueamos al usuario
$token = new UsernamePasswordToken($usuario, null, 'main', $usuario->getRoles());
$this->get('security.context')->setToken($token);
return $this->redirect($this->generateUrl('portada'));
}
}
return $this->render('DesymfonyBundle:Usuario:registro.html.twig', array('form' => $form->createView()));
}
public function denegadoAction()
{
return $this->render('DesymfonyBundle:Usuario:denegado.html.twig');
}
}