* @throws \RuntimeException When user has not at least guest role
*/
public function add(Request $request) {
- //Prevent non-guest to access here
- $this->denyAccessUnlessGranted('ROLE_GUEST', null, $this->translator->trans('Unable to access this page without role %role%!', ['%role%' => $this->translator->trans('Guest')]));
+ //Without guest role
+ if (!$this->checker->isGranted('ROLE_GUEST')) {
+ //Throw 403
+ throw $this->createAccessDeniedException($this->translator->trans('Unable to access this page without role %role%!', ['%role%' => $this->translator->trans('Guest')]));
+ }
//Get favorites dances
- $danceFavorites = $this->doctrine->getRepository(Dance::class)->findByUserId($this->getUser()->getId());
+ $danceFavorites = $this->doctrine->getRepository(Dance::class)->findByUserId($this->security->getUser()->getId());
//Set dance default
$danceDefault = !empty($danceFavorites)?current($danceFavorites):null;
-
//Get favorites locations
- $locationFavorites = $this->doctrine->getRepository(Location::class)->findByUserId($this->getUser()->getId());
+ $locationFavorites = $this->doctrine->getRepository(Location::class)->findByUserId($this->security->getUser()->getId());
//Set location default
$locationDefault = !empty($locationFavorites)?current($locationFavorites):null;
//With admin
- if ($this->isGranted('ROLE_ADMIN')) {
+ if ($this->checker->isGranted('ROLE_ADMIN')) {
//Get dances
$dances = $this->doctrine->getRepository(Dance::class)->findAll();
}
//Create ApplicationType form
- $form = $this->createForm('Rapsys\AirBundle\Form\ApplicationType', null, [
+ $form = $this->factory->create('Rapsys\AirBundle\Form\ApplicationType', null, [
//Set the action
'action' => $this->generateUrl('rapsys_air_application_add'),
//Set the form attribute
//Set location favorites
'location_favorites' => $locationFavorites,
//With user
- 'user' => $this->isGranted('ROLE_ADMIN'),
+ 'user' => $this->checker->isGranted('ROLE_ADMIN'),
//Set user choices
- 'user_choices' => $this->doctrine->getRepository(User::class)->findIndexByGroupPseudonym(),
+ 'user_choices' => $this->doctrine->getRepository(User::class)->findChoicesAsArray(),
//Set default user to current
- 'user_default' => $this->getUser()->getId(),
+ 'user_default' => $this->security->getUser()->getId(),
//Set default slot to evening
//XXX: default to Evening (3)
'slot_default' => $this->doctrine->getRepository(Slot::class)->findOneByTitle('Evening')
]);
+ //Set title
+ $this->context['title']['page'] = $this->translator->trans('Application add');
+
+ //Set section
+ $this->context['title']['section'] = $this->translator->trans('Application');
+
//Refill the fields in case of invalid form
$form->handleRequest($request);
//Handle invalid form
if (!$form->isSubmitted() || !$form->isValid()) {
- //Set title
- $title = $this->translator->trans('Application add');
-
//Render the view
- return $this->render('@RapsysAir/application/add.html.twig', ['title' => $title, 'form' => $form->createView()]+$this->context);
+ return $this->render('@RapsysAir/application/add.html.twig', ['form' => $form->createView()]+$this->context);
}
//Get data
$session->setLength(new \DateTime('06:00:00'));
//Check if admin
- if ($this->isGranted('ROLE_ADMIN')) {
+ if ($this->checker->isGranted('ROLE_ADMIN')) {
//Check if morning
if ($slot == 'Morning') {
//Set begin at 9h
//Check if afternoon
} elseif ($slot == 'Afternoon') {
//Set begin at 18h
- $session->setBegin(new \DateTime('14:00:00'));
+ $session->setBegin(new \DateTime('15:30:00'));
//Set length at 5h
- $session->setLength(new \DateTime('05:00:00'));
+ $session->setLength(new \DateTime('05:30:00'));
//Check if evening
} elseif ($slot == 'Evening') {
//Set begin at 19h00
- $session->setBegin(new \DateTime('19:00:00'));
+ $session->setBegin(new \DateTime('19:30:00'));
//Set length at 5h
- $session->setLength(new \DateTime('06:00:00'));
+ $session->setLength(new \DateTime('05:30:00'));
//Check if next day is premium
if ($premium) {
//Set length at 7h
- $session->setLength(new \DateTime('07:00:00'));
+ $session->setLength(new \DateTime('06:30:00'));
}
//Check if after
} else {
//Add error in flash message
$this->addFlash('error', $this->translator->trans('Session on %date% %location% %slot% not yet supported', ['%location%' => $this->translator->trans('at '.$data['location']), '%slot%' => $this->translator->trans('the '.strtolower(strval($data['slot']))), '%date%' => $data['date']->format('Y-m-d')]));
- //Set title
- $title = $this->translator->trans('Application add');
-
//Render the view
- return $this->render('@RapsysAir/application/add.html.twig', ['title' => $title, 'form' => $form->createView()]+$this->context);
+ return $this->render('@RapsysAir/application/add.html.twig', ['form' => $form->createView()]+$this->context);
}
//Check if admin
- if (!$this->isGranted('ROLE_ADMIN') && $session->getStart() < new \DateTime('00:00:00')) {
+ if (!$this->checker->isGranted('ROLE_ADMIN') && $session->getStart() < new \DateTime('00:00:00')) {
//Add error in flash message
$this->addFlash('error', $this->translator->trans('Session in the past on %date% %location% %slot% not yet supported', ['%location%' => $this->translator->trans('at '.$data['location']), '%slot%' => $this->translator->trans('the '.strtolower(strval($data['slot']))), '%date%' => $data['date']->format('Y-m-d')]));
- //Set title
- $title = $this->translator->trans('Application add');
-
//Render the view
- return $this->render('@RapsysAir/application/add.html.twig', ['title' => $title, 'form' => $form->createView()]+$this->context);
+ return $this->render('@RapsysAir/application/add.html.twig', ['form' => $form->createView()]+$this->context);
}
//Queue session save
}
//Set user
- $user = $this->getUser();
+ $user = $this->security->getUser();
//Replace with requested user for admin
- if ($this->isGranted('ROLE_ADMIN') && !empty($data['user'])) {
- $user = $this->getDoctrine()->getRepository(User::class)->findOneById($data['user']);
+ if ($this->checker->isGranted('ROLE_ADMIN') && !empty($data['user'])) {
+ $user = $this->doctrine->getRepository(User::class)->findOneById($data['user']);
}
//Protect application fetching