/** * @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()))); }
/** * @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(); }