Example #1
0
 /**
  * @param string  $slug
  * @param Payment $payment
  *
  * @return RedirectResponse
  *
  * @Route("/event/{slug}/payment/{id}/participants/add", name="add_participants_to_payment")
  */
 public function addParticipantsToPaymentAction($slug, Payment $payment)
 {
     // @todo це мало порефакторитись а не тупо перенести кусок гавнокоду з одного місця в інше
     $event = $this->getEventBySlug($slug);
     $em = $this->getDoctrine()->getManager();
     $request = $this->getRequest();
     $ticketForm = $this->createForm('stfalcon_event_ticket');
     $ticketForm->bind($request);
     $participants = $ticketForm->get('participants')->getData();
     $alreadyPaidTickets = array();
     foreach ($participants as $participant) {
         $user = $this->get('fos_user.user_manager')->findUserBy(array('email' => $participant['email']));
         // создаем нового пользователя
         if (!$user) {
             $user = $this->get('fos_user.user_manager')->createUser();
             $user->setEmail($participant['email']);
             $user->setFullname($participant['name']);
             // генерация временного пароля
             $password = substr(str_shuffle(md5(time())), 5, 8);
             $user->setPlainPassword($password);
             $user->setEnabled(true);
             $this->get('fos_user.user_manager')->updateUser($user);
             // отправляем сообщение о регистрации
             $text = "Приветствуем " . $user->getFullname() . "!\n\nВы были автоматически зарегистрированы на сайте Frameworks Days.\n\nВаш временный пароль: " . $password . "\nЕго можно сменить на странице " . $this->generateUrl('fos_user_change_password', array(), true) . "\n\n\n---\nС уважением,\nКоманда Frameworks Days";
             $message = \Swift_Message::newInstance()->setSubject("Регистрация на сайте Frameworks Days")->setFrom('*****@*****.**', 'Frameworks Days')->setTo($user->getEmail())->setBody($text);
             // @todo каждый вызов отнимает память
             $this->get('mailer')->send($message);
         }
         // проверяем или у него нет билетов на этот ивент
         /** @var Ticket $ticket */
         $ticket = $em->getRepository('StfalconEventBundle:Ticket')->findOneBy(array('event' => $event->getId(), 'user' => $user->getId()));
         if (!$ticket) {
             $ticket = $this->createTicket($event, $user);
         }
         if (!$ticket->isPaid()) {
             if ($promoCode = $payment->getPromoCodeFromTickets()) {
                 if (!$ticket->getHasDiscount()) {
                     $ticket->setPromoCode($promoCode);
                 }
             }
             $payment->addTicket($ticket);
         } else {
             $alreadyPaidTickets[] = $user->getFullname();
         }
         $em->persist($payment);
         $em->persist($ticket);
     }
     $em->flush();
     if (!empty($alreadyPaidTickets)) {
         $this->get('session')->getFlashBag()->add('already_paid_tickets', implode(', ', $alreadyPaidTickets));
     }
     return $this->redirect($this->generateUrl('event_pay', array('event_slug' => $event->getSlug())));
 }
Example #2
0
 /**
  * @Route("/admin/event/{slug}/users/add", name="adminusersadd")
  * @Secure(roles="ROLE_ADMIN")
  * @Template()
  */
 public function addUsersAction(Event $event)
 {
     // @todo удалить этот метод. одноразовый харкод
     $em = $this->getDoctrine()->getManager();
     if (isset($_POST['users'])) {
         $users = explode("\r\n", $_POST['users']);
         foreach ($users as $data) {
             // данные с формы
             $dt = explode(' ', $data);
             unset($data);
             $data['name'] = $dt[0] . ' ' . $dt[1];
             $data['email'] = $dt[2];
             $data['discount'] = isset($dt[3]);
             $user = $this->get('fos_user.user_manager')->findUserBy(array('email' => $data['email']));
             // создаем нового пользователя
             if (!$user) {
                 $user = $this->get('fos_user.user_manager')->createUser();
                 $user->setEmail($data['email']);
                 $user->setFullname($data['name']);
                 // генерация временного пароля
                 $password = substr(str_shuffle(md5(time())), 5, 8);
                 $user->setPlainPassword($password);
                 $user->setEnabled(true);
                 $this->get('fos_user.user_manager')->updateUser($user);
                 // отправляем сообщение о регистрации
                 $text = "Приветствуем " . $user->getFullname() . "!\n\nВы были автоматически зарегистрированы на сайте Frameworks Days.\n\nВаш временный пароль: " . $password . "\nЕго можно сменить на странице " . $this->generateUrl('fos_user_change_password', array(), true) . "\n\n\n---\nС уважением,\nКоманда Frameworks Days";
                 $message = \Swift_Message::newInstance()->setSubject("Регистрация на сайте Frameworks Days")->setFrom('*****@*****.**', 'Frameworks Days')->setTo($user->getEmail())->setBody($text);
                 // @todo каждый вызов отнимает память
                 $this->get('mailer')->send($message);
                 echo "#{$user->getId()} {$user->getFullname()} — создаем нового пользователя<br>";
             } else {
                 echo "<b>#{$user->getId()} {$user->getFullname()} — уже зарегистрирован</b><br>";
             }
             // обновляем информацию о компании
             $user->setCountry('Украина');
             if (isset($_POST['city'])) {
                 $user->setCity($_POST['city']);
             }
             $user->setCompany($_POST['company']);
             $em->persist($user);
             // проверяем или у него нет билетов на этот ивент
             /** @var Ticket $ticket */
             $ticket = $em->getRepository('StfalconEventBundle:Ticket')->findOneBy(array('event' => $event->getId(), 'user' => $user->getId()));
             if (!$ticket) {
                 $ticket = new Ticket();
                 $ticket->setEvent($event);
                 $ticket->setUser($user);
                 $em->persist($ticket);
             }
             if ($ticket->isPaid()) {
                 echo "<b>он уже оплатил участие в конференции!</b><br>";
             } else {
                 // цена участия (с учетом скидки)
                 $amount = $data['discount'] ? $_POST['amount'] * 0.8 : $_POST['amount'];
                 $ticket->setAmount($amount);
                 $ticket->setHasDiscount($data['discount']);
                 $ticket->setAmountWithoutDiscount($_POST['amount']);
                 $oldPayment = $ticket->getPayment();
                 if ($oldPayment) {
                     $oldPayment->removeTicket($ticket);
                     $em->persist($oldPayment);
                 }
                 echo "создаем новый платеж<br>";
                 $payment = new Payment();
                 $payment->setUser($user);
                 $payment->addTicket($ticket);
                 // обновляем шлюз и статус платежа
                 $payment->setGate('admin');
                 $payment->setStatus('paid');
                 $em->persist($payment);
                 $em->persist($ticket);
                 // сохраняем все изменения
                 $em->flush();
                 echo "отмечаем как оплачено<br>";
             }
         }
         echo 'complete';
         exit;
     }
     return array();
 }