src/Controller/AboutController.php line 281

Open in your IDE?
  1. <?php
  2. namespace App\Controller;
  3. use App\Entity\User;
  4. use App\Entity\UserDetails;
  5. use App\Utils\Utils;
  6. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  7. use Symfony\Component\Routing\Annotation\Route;
  8. use Symfony\Component\HttpFoundation\Request;
  9. use Doctrine\DBAL\Connection;
  10. use Doctrine\Common\Collections\ArrayCollection;
  11. use Doctrine\ORM\EntityManagerInterface;
  12. use Doctrine\ORM\PersistentCollection;
  13. use Symfony\Component\HttpFoundation\RedirectResponse;
  14. use Symfony\Component\HttpFoundation\Session\SessionInterface;
  15. use Symfony\Component\PasswordHasher\Hasher\UserPasswordHasherInterface;
  16. use Symfony\Component\Security\Http\Authentication\AuthenticationUtils;
  17. use App\Utils\ResultGenerator;
  18. use Symfony\Component\HttpFoundation\Session\Session;
  19. use Symfony\Component\Translation\Translator;
  20. use Symfony\Contracts\Translation\TranslatorInterface;
  21. use Swift_Mailer;
  22. /**
  23.  * About controller.
  24.  *
  25.  * @Route("about")
  26.  */
  27. class AboutController extends AbstractController
  28. {
  29.     //private $fromEmail    = "inquiries@guardingmindsatwork.ca";
  30.     //private $mailHost     = "localhost";
  31.     //private $mailUser     = "test@guardingmindsatwork.ca";
  32.     //private $mailPassword = "qg3bvia8";
  33.     protected $translator;
  34.     protected $mailer;
  35.     protected $passwordHasher;
  36.     public function __construct(TranslatorInterface $translatorSwift_Mailer $mailerUserPasswordHasherInterface $passwordHasher)
  37.     {
  38.         $this->translator $translator;
  39.         $this->mailer $mailer;
  40.         $this->passwordHasher $passwordHasher;
  41.     }
  42.     /**
  43.      * @Route("/about", name="about")
  44.      */
  45.     public function aboutAction(Request $request)
  46.     {
  47.         return $this->render('about/about.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  48.                                                         'language' => $request->getLocale() ]);
  49.     }
  50.     /**
  51.      * @Route("/about-safety", name="about_safety")
  52.      */
  53.     public function whatsafetyAction(Request $request)
  54.     {
  55.         return $this->render('about/safety-what.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  56.                                                               'language' => $request->getLocale() ]);
  57.     }
  58.     /**
  59.      * @Route("/about-psychosocial-factors", name="about_factors")
  60.      */
  61.     public function aboutFactorsAction(Request $request)
  62.     {
  63.         return $this->render('about/1-psychosocial-factors.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR ]);
  64.     }
  65.     /**
  66.      * @Route("/about-needs", name="about_needs")
  67.      */
  68.     public function aboutNeedsAction(Request $request)
  69.     {
  70.         return $this->render('about/2-identify-needs.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  71.                                                                    'language' => $request->getLocale() ]);
  72.     }
  73.     /**
  74.      * @Route("/about-resources", name="about_resources")
  75.      */
  76.     public function aboutResourcesAction(Request $request)
  77.     {
  78.         return $this->render('about/3-determine-resources.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  79.                                                                         'language' => $request->getLocale() ]);
  80.     }
  81.     /**
  82.      * @Route("/about-participants", name="about_participants")
  83.      */
  84.     public function aboutParticipantsAction(Request $request)
  85.     {
  86.         return $this->render('about/4-identify-participants.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  87.                                                                           'language' => $request->getLocale() ]);
  88.     }
  89.     /**
  90.      * @Route("/about-plan", name="about_plan")
  91.      */
  92.     public function aboutPlanAction(Request $request)
  93.     {
  94.         return $this->render('about/5-create-plan.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  95.                                                                 'language' => $request->getLocale() ]);
  96.     }
  97.     /**
  98.      * @Route("/about-signup", name="about_signup")
  99.      * @param Request $request
  100.      * @return \Symfony\Component\HttpFoundation\Response
  101.      */
  102.     public function signupAction(Request $requestConnection $connSessionInterface $session)
  103.     {
  104.         $user = new User();
  105.         $userDetails = new UserDetails();
  106.         $userDetails->init($user$conn);
  107.         $utils = new Utils();
  108.         $utils->init($user$conn);
  109.         $msg "";
  110.         if (sizeof($request->request) > 0) {
  111.             if ($request->request->get('emailAddress') != '' && $userDetails->getActivcationIDByEmailAddress($request->request->get('emailAddress')) === false) {
  112.                 // encode the user password
  113.                 $password $this->passwordHasher->hashPassword($user$request->request->get('password'));
  114.                 $user->setPassword($password);
  115.                 $user->setUserName($request->request->get('emailAddress'));
  116.                 $user->setRole("ROLE_USER");
  117.                 $activation_id uniqid(rand());
  118.                 $user->setActivationId($activation_id);
  119.                 $user->setLanguageId($userDetails->getLanguageId($request->getLocale()));
  120.                 // save the user
  121.                 $em $this->getDoctrine()->getManager();
  122.                 $em->persist($user);
  123.                 $em->flush();
  124.                 $userInfoArr = array( 'user_id'         => $user->getUserId(),
  125.                                       'first_name'      => $request->request->get('firstName'),
  126.                                       'last_name'       => $request->request->get('lastName'),
  127.                                       'personal_title'  => $request->request->get('personalTitle'),
  128.                                       'job_title'       => $request->request->get('jobTitle'),
  129.                                       'department'      => $request->request->get('department'),
  130.                                       'phone_number'    => $request->request->get('phoneNumber'),
  131.                                       'street_address'  => $request->request->get('address'),
  132.                                       'city_name'       => $request->request->get('city'),
  133.                                       'province'        => $request->request->get('province'),
  134.                                       'postal_code'     => $request->request->get('postalCode'),
  135.                                       'iso_country'     => $request->request->get('country'),
  136.                                       'allow_share_data' => $request->request->get('termsAccepted') ? 0);
  137.                 $companyInfoArr = array( 'user_id'             => $user->getUserId(),
  138.                                          'company_name'        => $request->request->get('organization'),
  139.                                          'employees_in_org'    => $request->request->get('employeesInOrg'),
  140.                                          'org_type'            => $request->request->get('orgType'),
  141.                                          'sector'              => $request->request->get('sector'),
  142.                                          'union_status'        => $request->request->get('unionStatus'),
  143.                                          'company_category_id' => $request->request->get('companyCategoryId') );
  144.                 $userDetails->addUserDetails($userInfoArr$companyInfoArr);
  145.                 $session = new Session();
  146.                 $session->set('signup_email_address'$request->request->get('emailAddress'));
  147.                 return $this->redirectToRoute('about_signup_thankyou');
  148.             } else {
  149.                 $msg "emailAlreadyExists";
  150.             }
  151.         }
  152.         $countries $userDetails->getCountryData($userDetails->getLanguageId($request->getLocale()));
  153.         $provinces $userDetails->getProvinceData($userDetails->getLanguageId($request->getLocale()));
  154.         $companyCategory $userDetails->getCompanyCategory($userDetails->getLanguageId($request->getLocale()));
  155.         return $this->render('about/6-signup.html.twig', [ 'countries'    => $countries,
  156.                                                            'provinces'    => $provinces,
  157.                                                            'company_cat'  => $companyCategory,
  158.                                                            'base_dir'     => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  159.                                                            'msg'          => $msg ]);
  160.     }
  161.     /**
  162.      * @Route("/about-signup-thankyou", name="about_signup_thankyou")
  163.      * @param Request $request
  164.      * @return \Symfony\Component\HttpFoundation\Response
  165.      */
  166.     public function aboutSignUpThankYou(Request $requestSessionInterface $sessionConnection $conn, \Swift_Mailer $mailer)
  167.     {
  168.         $session = new Session();
  169.         $signup_email_address $session->get('signup_email_address');
  170.         $locale $request->getLocale();
  171.         if ($signup_email_address != '') {
  172.             $session->set('signup_email_address''');
  173.             $user = new User();
  174.             $userDetails = new UserDetails();
  175.             $userDetails->init($user$conn);
  176.             $activation_code $userDetails->getActivcationIDByEmailAddress($signup_email_address);
  177.             // MAYBE USED FOR GETTING CONTAINER INFO?
  178.             //$transport = $this->container()->get('swiftmailer.transport.real');
  179.             if ($locale == 'en') {
  180.                 $fromEmail $this->getParameter('mailer_from_user');
  181.             } elseif ($locale == 'fr') {
  182.                 $fromEmail $this->getParameter('mailer_from_user_fr');
  183.             } else {
  184.                 $fromEmail $this->getParameter('mailer_from_user');
  185.             }
  186.             $message = (new \Swift_Message($this->translator->trans('confirm-email')))
  187.                         ->setFrom($fromEmail)
  188.                         ->setTo($signup_email_address)
  189.                         ->setBody(
  190.                             $this->renderView(
  191.                                 'about/10-activation-email.html.twig',
  192.                                 array( 'activation_code' => $activation_code)
  193.                             ),
  194.                             'text/html'
  195.                         );
  196.             $this->mailer->send($message);
  197.             return $this->render('about/9-about-signup-thankyou.html.twig', [ 'signup_email_address' => $signup_email_address ]);
  198.         } else {
  199.             return $this->redirectToRoute('about_signup');
  200.         }
  201.     }
  202.     /**
  203.      * @Route("/about-signup-activation/{activation_code}", name="about_signup_activation")
  204.      * @param Request $request
  205.      * @return \Symfony\Component\HttpFoundation\Response
  206.      */
  207.     public function aboutSignUpActivation(Request $request$activation_codeConnection $conn, \Swift_Mailer $mailer)
  208.     {
  209.         $user = new User();
  210.         $userDetails = new UserDetails();
  211.         $userDetails->init($user$conn);
  212.         $locale $request->getLocale();
  213.         if ($activation_code != '') {
  214.             $activated_email $userDetails->activateUser($activation_code);
  215.             if ($activated_email != "") {
  216.                 if ($locale == 'en') {
  217.                     $fromEmail $this->getParameter('mailer_from_user');
  218.                 } elseif ($locale == 'fr') {
  219.                     $fromEmail $this->getParameter('mailer_from_user_fr');
  220.                 } else {
  221.                     $fromEmail $this->getParameter('mailer_from_user');
  222.                 }
  223.                 $message = (new \Swift_Message($this->translator->trans('email-welcome-chw')) )
  224.                             ->setFrom($fromEmail)
  225.                             ->setTo($activated_email)
  226.                             ->setBody(
  227.                                 $this->renderView(
  228.                                     'about/11-activation-confirmed-email.html.twig',
  229.                                     array( 'email' => $activated_email)
  230.                                 ),
  231.                                 'text/html'
  232.                             );
  233.                 $this->mailer->send($message);
  234.             } else {
  235.                 return $this->redirectToRoute('login');
  236.             }
  237.         }
  238.         return $this->render('default/login.html.twig', [ 'msg' => 'accountActivated' ]);
  239.     }
  240.     /**
  241.      * @Route("/about-results", name="about_results")
  242.      */
  243.     public function aboutResultsAction(Request $request)
  244.     {
  245.         return $this->render('about/7-track-results.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  246.                                                                   'language' => $request->getLocale() ]);
  247.     }
  248.     /**
  249.      * @Route("/about-evaluate", name="about_evaluate")
  250.      */
  251.     public function aboutEvaluateAction(Request $request)
  252.     {
  253.         return $this->render('about/8-evaluate.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  254.                                                              'language' => $request->getLocale() ]);
  255.     }
  256.       /**
  257.      * @Route("/about-review", name="about_review")
  258.      */
  259.     public function aboutReview(Request $request)
  260.     {
  261.         return $this->render('about/review.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  262.                                                              'language' => $request->getLocale() ]);
  263.     }
  264.       /**
  265.      * @Route("/about-steps", name="about_steps")
  266.      */
  267.     public function aboutSteps(Request $request)
  268.     {
  269.         return $this->render('about/about-steps.html.twig', [ 'base_dir' => realpath($this->getParameter('kernel.project_dir')) . DIRECTORY_SEPARATOR,
  270.                                                              'language' => $request->getLocale() ]);
  271.     }
  272. }