]> git.immae.eu Git - github/wallabag/wallabag.git/blame - src/Wallabag/CoreBundle/Controller/ConfigController.php
Symfony Upgrade Fixer FTW
[github/wallabag/wallabag.git] / src / Wallabag / CoreBundle / Controller / ConfigController.php
CommitLineData
4d85d7e9
J
1<?php
2
3namespace Wallabag\CoreBundle\Controller;
4
5use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
6use Symfony\Bundle\FrameworkBundle\Controller\Controller;
0c83fd59 7use Symfony\Component\HttpFoundation\JsonResponse;
619cc453 8use Symfony\Component\HttpFoundation\Request;
4d85d7e9 9use Wallabag\CoreBundle\Entity\Config;
f19f9f62 10use Wallabag\CoreBundle\Entity\TaggingRule;
d9085c63 11use Wallabag\CoreBundle\Form\Type\ChangePasswordType;
e4977b8a 12use Wallabag\CoreBundle\Form\Type\NewUserType;
0c83fd59 13use Wallabag\CoreBundle\Form\Type\RssType;
619cc453
JB
14use Wallabag\CoreBundle\Form\Type\TaggingRuleType;
15use Wallabag\CoreBundle\Form\Type\UserInformationType;
0c83fd59 16use Wallabag\CoreBundle\Tools\Utils;
619cc453 17use Wallabag\UserBundle\Entity\User;
4d85d7e9
J
18
19class ConfigController extends Controller
20{
21 /**
22 * @param Request $request
23 *
24 * @Route("/config", name="config")
4d85d7e9
J
25 */
26 public function indexAction(Request $request)
27 {
d9085c63 28 $em = $this->getDoctrine()->getManager();
4d85d7e9 29 $config = $this->getConfig();
fcb1fba5 30 $userManager = $this->container->get('fos_user.user_manager');
c0d9eba0 31 $user = $this->getUser();
4d85d7e9 32
32da2a70 33 // handle basic config detail (this form is defined as a service)
33fe61f9 34 $configForm = $this->createForm('config', $config, array('action' => $this->generateUrl('config')));
d9085c63 35 $configForm->handleRequest($request);
4d85d7e9 36
d9085c63 37 if ($configForm->isValid()) {
4d85d7e9
J
38 $em->persist($config);
39 $em->flush();
40
32da2a70
J
41 // switch active theme
42 $activeTheme = $this->get('liip_theme.active_theme');
43 $activeTheme->setName($config->getTheme());
44
4d85d7e9
J
45 $this->get('session')->getFlashBag()->add(
46 'notice',
c89d35e8 47 'Config saved. Some parameters will be considered after disconnection.'
4d85d7e9
J
48 );
49
50 return $this->redirect($this->generateUrl('config'));
51 }
52
d9085c63 53 // handle changing password
33fe61f9 54 $pwdForm = $this->createForm(new ChangePasswordType(), null, array('action' => $this->generateUrl('config').'#set4'));
d9085c63
J
55 $pwdForm->handleRequest($request);
56
57 if ($pwdForm->isValid()) {
fcb1fba5
NL
58 $user->setPlainPassword($pwdForm->get('new_password')->getData());
59 $userManager->updateUser($user, true);
d9085c63
J
60
61 $this->get('session')->getFlashBag()->add(
62 'notice',
63 'Password updated'
64 );
65
66 return $this->redirect($this->generateUrl('config'));
67 }
68
c0d9eba0 69 // handle changing user information
33fe61f9
JB
70 $userForm = $this->createForm(new UserInformationType(), $user, array(
71 'validation_groups' => array('Profile'),
72 'action' => $this->generateUrl('config').'#set3',
73 ));
c0d9eba0
J
74 $userForm->handleRequest($request);
75
76 if ($userForm->isValid()) {
fcb1fba5 77 $userManager->updateUser($user, true);
c0d9eba0
J
78
79 $this->get('session')->getFlashBag()->add(
80 'notice',
81 'Information updated'
82 );
83
84 return $this->redirect($this->generateUrl('config'));
85 }
86
0c83fd59 87 // handle rss information
33fe61f9 88 $rssForm = $this->createForm(new RssType(), $config, array('action' => $this->generateUrl('config').'#set2'));
0c83fd59
J
89 $rssForm->handleRequest($request);
90
91 if ($rssForm->isValid()) {
92 $em->persist($config);
93 $em->flush();
94
95 $this->get('session')->getFlashBag()->add(
96 'notice',
97 'RSS information updated'
98 );
99
100 return $this->redirect($this->generateUrl('config'));
101 }
102
f19f9f62
KG
103 // handle tagging rule
104 $taggingRule = new TaggingRule();
c13eda46 105 $newTaggingRule = $this->createForm(new TaggingRuleType(), $taggingRule, array('action' => $this->generateUrl('config').'#set5'));
f19f9f62
KG
106 $newTaggingRule->handleRequest($request);
107
108 if ($newTaggingRule->isValid()) {
109 $taggingRule->setConfig($config);
110 $em->persist($taggingRule);
111 $em->flush();
112
113 $this->get('session')->getFlashBag()->add(
114 'notice',
115 'Tagging rules updated'
116 );
117
118 return $this->redirect($this->generateUrl('config'));
119 }
120
e4977b8a 121 // handle adding new user
fcb1fba5 122 $newUser = $userManager->createUser();
0f30f48b
JB
123 // enable created user by default
124 $newUser->setEnabled(true);
33fe61f9
JB
125 $newUserForm = $this->createForm(new NewUserType(), $newUser, array(
126 'validation_groups' => array('Profile'),
127 'action' => $this->generateUrl('config').'#set5',
128 ));
e4977b8a
J
129 $newUserForm->handleRequest($request);
130
fcb1fba5
NL
131 if ($newUserForm->isValid() && $this->get('security.authorization_checker')->isGranted('ROLE_SUPER_ADMIN')) {
132 $userManager->updateUser($newUser, true);
0bd2cb1e
J
133
134 $config = new Config($newUser);
135 $config->setTheme($this->container->getParameter('theme'));
136 $config->setItemsPerPage($this->container->getParameter('items_on_page'));
371ac69a 137 $config->setRssLimit($this->container->getParameter('rss_limit'));
0bd2cb1e
J
138 $config->setLanguage($this->container->getParameter('language'));
139
140 $em->persist($config);
141
e4977b8a
J
142 $em->flush();
143
144 $this->get('session')->getFlashBag()->add(
145 'notice',
146 sprintf('User "%s" added', $newUser->getUsername())
147 );
148
149 return $this->redirect($this->generateUrl('config'));
150 }
151
4d85d7e9 152 return $this->render('WallabagCoreBundle:Config:index.html.twig', array(
0c83fd59
J
153 'form' => array(
154 'config' => $configForm->createView(),
155 'rss' => $rssForm->createView(),
156 'pwd' => $pwdForm->createView(),
157 'user' => $userForm->createView(),
158 'new_user' => $newUserForm->createView(),
f19f9f62 159 'new_tagging_rule' => $newTaggingRule->createView(),
0c83fd59
J
160 ),
161 'rss' => array(
162 'username' => $user->getUsername(),
163 'token' => $config->getRssToken(),
9744e971 164 ),
4d85d7e9
J
165 ));
166 }
167
0c83fd59
J
168 /**
169 * @param Request $request
170 *
171 * @Route("/generate-token", name="generate_token")
172 *
173 * @return JsonResponse
174 */
175 public function generateTokenAction(Request $request)
176 {
177 $config = $this->getConfig();
178 $config->setRssToken(Utils::generateToken());
179
180 $em = $this->getDoctrine()->getManager();
181 $em->persist($config);
182 $em->flush();
183
184 if ($request->isXmlHttpRequest()) {
185 return new JsonResponse(array('token' => $config->getRssToken()));
186 }
187
188 return $request->headers->get('referer') ? $this->redirect($request->headers->get('referer')) : $this->redirectToRoute('config');
189 }
190
52e423f3
KG
191 /**
192 * Deletes a tagging rule and redirect to the config homepage.
193 *
194 * @param TaggingRule $rule
195 *
196 * @Route("/tagging-rule/delete/{id}", requirements={"id" = "\d+"}, name="delete_tagging_rule")
197 *
198 * @return \Symfony\Component\HttpFoundation\RedirectResponse
199 */
200 public function deleteTaggingRule(TaggingRule $rule)
201 {
202 if ($this->getUser()->getId() != $rule->getConfig()->getUser()->getId()) {
203 throw $this->createAccessDeniedException('You can not access this tagging ryle.');
204 }
205
206 $em = $this->getDoctrine()->getManager();
207 $em->remove($rule);
208 $em->flush();
209
210 $this->get('session')->getFlashBag()->add(
211 'notice',
212 'Tagging rule deleted'
213 );
214
215 return $this->redirect($this->generateUrl('config'));
216 }
217
d9085c63
J
218 /**
219 * Retrieve config for the current user.
220 * If no config were found, create a new one.
221 *
222 * @return Wallabag\CoreBundle\Entity\Config
223 */
4d85d7e9
J
224 private function getConfig()
225 {
226 $config = $this->getDoctrine()
227 ->getRepository('WallabagCoreBundle:Config')
228 ->findOneByUser($this->getUser());
229
230 if (!$config) {
231 $config = new Config($this->getUser());
232 }
233
234 return $config;
235 }
236}