src/Controller/CheckoutController.php line 115

Open in your IDE?
  1. <?php
  2. namespace App\Controller;
  3. use App\Env;
  4. use App\Func;
  5. use App\DTO\AppDTO;
  6. use LogicException;
  7. use App\Entity\City;
  8. use App\Entity\Prod;
  9. use App\Entity\User;
  10. use App\Entity\Order;
  11. use App\Entity\Region;
  12. use App\Entity\Esystem;
  13. use App\Entity\Delivery;
  14. use App\Service\Pay\Pay;
  15. use App\Service\Auth\Auth;
  16. use App\Service\Cart\Cart;
  17. use App\Service\Mail\Mail;
  18. use App\Entity\Subdelivery;
  19. use App\Entity\Transaction;
  20. use App\Event\OrderMakedEvent;
  21. use App\Event\OrderPayedEvent;
  22. use App\Service\Referal\Referal;
  23. use App\Repository\CityRepository;
  24. use App\Repository\ProdRepository;
  25. use App\Repository\UserRepository;
  26. use App\Service\Checkout\Checkout;
  27. use App\Repository\OrderRepository;
  28. use App\Repository\RegionRepository;
  29. use App\Repository\EsystemRepository;
  30. use App\Repository\DeliveryRepository;
  31. use Psr\Cache\InvalidArgumentException;
  32. use Doctrine\ORM\EntityManagerInterface;
  33. use Doctrine\ORM\Exception\ORMException;
  34. use App\Repository\SubdeliveryRepository;
  35. use App\Repository\TransactionRepository;
  36. use Symfony\Contracts\Cache\CacheInterface;
  37. use Psr\Container\NotFoundExceptionInterface;
  38. use Symfony\Component\HttpFoundation\Request;
  39. use Symfony\Component\Security\Core\Security;
  40. use Psr\Container\ContainerExceptionInterface;
  41. use Symfony\Component\HttpFoundation\Response;
  42. use Symfony\Component\Routing\Annotation\Route;
  43. use Psr\EventDispatcher\EventDispatcherInterface;
  44. use Symfony\Component\EventDispatcher\EventDispatcher;
  45. use Symfony\Bundle\FrameworkBundle\Controller\AbstractController;
  46. use Symfony\Component\HttpFoundation\Exception\BadRequestException;
  47. use Symfony\Component\HttpFoundation\RequestStack;
  48. /** @package App\Controller */
  49. class CheckoutController extends AbstractASController
  50. {
  51.     protected EntityManagerInterface $em;
  52.     protected CacheInterface $Cache;
  53.     protected AppDTO $app;
  54.     protected Auth $Auth;
  55.     protected Checkout $Checkout;
  56.     protected User $User;
  57.     protected Cart $Cart;
  58.     protected $cart_items;
  59.     // Repositories
  60.     protected ProdRepository $Prods;
  61.     protected DeliveryRepository $Deliveries;
  62.     protected SubdeliveryRepository $SubDeliveries;
  63.     protected CityRepository $Cities;
  64.     protected RegionRepository $Regions;
  65.     protected EsystemRepository $Esystems;
  66.     protected UserRepository $Users;
  67.     protected OrderRepository $Orders;
  68.     protected TransactionRepository $Transactions;
  69.     private $step;
  70.     private $order_key "asdflhi2508qyslakg08q2t5ojgz";
  71.     public function __construct(EntityManagerInterface $emCacheInterface $CacheAppDTO $appAuth $AuthCheckout $CheckoutCart $CartSecurity $securityRequestStack $requestStack)
  72.     {
  73.         $this->requestStack $requestStack;
  74.         $this->Cache $Cache;
  75.         $this->em $em;
  76.         $this->app $app;
  77.         $this->Auth $Auth;
  78.         $this->Auth->setUser($security->getUser());
  79.         $this->Checkout $Checkout;
  80.         $this->Cart $Cart;
  81.         $this->Deliveries $this->em->getRepository(Delivery::class);
  82.         $this->SubDeliveries $this->em->getRepository(Subdelivery::class);
  83.         $this->Cities $this->em->getRepository(City::class);
  84.         $this->Regions $this->em->getRepository(Region::class);
  85.         $this->Esystems $this->em->getRepository(Esystem::class);
  86.         $this->Users $this->em->getRepository(User::class);
  87.         $this->Orders $this->em->getRepository(Order::class);
  88.         $this->Prods $em->getRepository(Prod::class);
  89.         $this->Transactions $em->getRepository(Transaction::class);
  90.         $this->cart_items $this->Cart->getCart();
  91.         foreach ($this->cart_items as $k => $v) {
  92.             $this->cart_items[$k]['prod'] = $this->Prods->find($v['id']);
  93.         }
  94.     }
  95.     
  96.     #[Route(path'/checkout'name'checkout_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  97.     #[Route(path'/{_locale}/checkout'name'checkout'requirements: ['_locale' => '%app.langs%'])]
  98.     public function index(): Response
  99.     {
  100.         return $this->redirectToRoute('checkout_form');
  101.     }
  102.     // Форма. Данные пользователя
  103.     #[Route(path'/checkout/form'name'checkout_form_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  104.     #[Route(path'/{_locale}/checkout/form'name'checkout_form'requirements: ['_locale' => '%app.langs%'])]
  105.     public function form(Request $request): Response
  106.     {
  107.         $email strtolower(trim($request->get('email')));
  108.         $surname trim($request->get('surname'));
  109.         $name trim($request->get('name'));
  110.         $phone trim($request->get('phone'));
  111.         $errors = [];
  112.         if (!empty($request->get('submit'))) {
  113.             $user $this->Users->findOneBy(['email' => $email]);
  114.             if (strlen($email) && $this->Auth->getUserId() == && $user) { // Клиент есть в базе но не авторизирован
  115.                 $this->Checkout->setEmail($email);
  116.                 $errors['notloggedin'] = 1;
  117.             } else {
  118.                 if (!strlen($surname)) { // Пустое поле Фамилии
  119.                     $errors['surname_empty'] = 1;
  120.                 } elseif (!strlen($name)) { // Пустое поле Имени
  121.                     $errors['name_empty'] = 1;
  122.                 } else {
  123.                     $usersurname $surname;
  124.                     $username $name;
  125.                     $usergender '';
  126.                     if ($username && $usersurname) {
  127.                         if ($this->Auth->getUserId() == && !$user) { // Новый клиент
  128.                         } elseif ($this->Auth->getUserId()) { // Клиент авторизирован
  129.                             $user->setName($username);
  130.                             $user->setSurname($usersurname);
  131.                             $user->setGender($usergender);
  132.                             $user->setPhone($phone);
  133.                             //$this->Auth->login($user); /// TODO
  134.                             $this->em->flush();
  135.                         }
  136.                     }
  137.                 }
  138.                 if (!empty($email) && filter_var($emailFILTER_CALLBACK, array('options' => '\App\Func::is_email'))) {
  139.                     $this->Checkout->setName($name);
  140.                     $this->Checkout->setSurname($surname);
  141.                     $this->Checkout->setGender($usergender);
  142.                     $this->Checkout->setEmail($email);
  143.                     $this->Checkout->setPhone($phone);
  144.                     $this->Checkout->setKey($this->order_key);
  145.                 } else {
  146.                     $errors['email_invalid'] = 1;   // email невалиден
  147.                 }
  148.                 if (!strlen($phone)) { // Пустое поле Номер телефона
  149.                     $errors['phone_empty'] = 1;
  150.                 }
  151.                 if (count((array)$errors) == 0) { // Если ошибок нет, переходим на этап Доставка
  152.                     return $this->redirectToRoute('checkout_delivery');
  153.                 }
  154.             }
  155.             return $this->render('checkout/form.html.twig', [
  156.                 'controller_name' => 'CheckoutController',
  157.                 'checkout' => $this->Checkout,
  158.                 'user' => $this->getUser(),
  159.                 "errors" => $errors,
  160.                 "step" => 1,
  161.                 'h1' => $this->app->labels->get('checkout-title-1'),
  162.                 'cart' => $this->Cart,
  163.                 'cart_items' => $this->cart_items,
  164.             ]);
  165.         } else { // Форма не отправлена. Заход на страницу /checkout/
  166.             return $this->render('checkout/form.html.twig', [
  167.                 'controller_name' => 'CheckoutController',
  168.                 'checkout' => $this->Checkout,
  169.                 'user' => $this->getUser(),
  170.                 "errors" => $errors,
  171.                 "step" => 1,
  172.                 'h1' => $this->app->labels->get('checkout-title-1'),
  173.                 'cart' => $this->Cart,
  174.                 'cart_items' => $this->cart_items,
  175.             ]);
  176.         }
  177.     }
  178.     // Выбор способа доставки
  179.     #[Route(path'/checkout/delivery'name'checkout_delivery_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  180.     #[Route(path'/{_locale}/checkout/delivery'name'checkout_delivery'requirements: ['_locale' => '%app.langs%'])]
  181.     public function delivery(Request $request): Response
  182.     {
  183.         if (empty($this->Checkout->getName()) || empty($this->Checkout->getEmail())) {
  184.             return $this->redirectToRoute('checkout_form');
  185.         }
  186.         if ($request->get('postform')) { // Обработка формы с полями ввода (для некоторых видов доставки)
  187.             $d_addr $request->get('delivery-addr');
  188.             $d_flat $request->get('delivery-flat');
  189.             $d_post_code $request->get('delivery-postcode');
  190.             $d_comment $request->get('delivery-comment');
  191.             $name $request->get('name');
  192.             $d_post_name $request->get('delivery-postname');
  193.             $this->Checkout->setDelivery_post_code('');
  194.             $this->Checkout->setDelivery_post_name('');
  195.             $this->Checkout->setDelivery_post_worktime('');
  196.             $this->Checkout->setDelivery_post_phone('');
  197.             $this->Checkout->setDelivery_post_email('');
  198.             if (($name) && ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX))) {
  199.                 $this->Checkout->setCity_name($name);
  200.                 $this->Checkout->setDelivery_post_name($d_post_name);
  201.             }
  202.             if ($d_addr) {
  203.                 $this->Checkout->setUseraddr($d_addr);
  204.             }
  205.             if ($d_flat) {
  206.                 $this->Checkout->setUseraddr($d_addr);
  207.                 if ((Env::site() != Env::MIX) && (Env::site() != Env::OPT_MIX)) {
  208.                     $this->Checkout->setUseraddr($d_addr ', ' $this->app->labels->get('checkout-confirm-6') . ' ' $d_flat);
  209.                 }
  210.                 $this->Checkout->setUserflat($d_flat);
  211.             }
  212.             $this->Checkout->setDelivery_post_code($d_post_code);
  213.             $this->Checkout->setComment($d_comment);
  214.             return $this->redirectToRoute('checkout_payment');
  215.         } else {
  216.             if (!$this->Checkout->getUserlat() && !$this->Checkout->getUserlon()) {
  217.                 $user $this->Users->find($this->Auth->getUserId());
  218.                 if ($user && $user->getLat() && $user->getLon()) {
  219.                     $this->Checkout->setUserlat($user->getLat());
  220.                     $this->Checkout->setUserlon($user->getLon());
  221.                 }
  222.             }
  223.             if (count($request->request->all()) > 0) {
  224.                 return $this->redirectToRoute('checkout_payment');
  225.             } else {
  226.                 $user $this->Users->find($this->Auth->getUserId());
  227.                 return $this->render('checkout/delivery.html.twig', [
  228.                     'controller_name' => 'CheckoutController',
  229.                     'checkout' => $this->Checkout,
  230.                     'user' => $this->getUser(),
  231.                     "step" => 2,
  232.                     'h1' => $this->app->labels->get('checkout-title-2'),
  233.                     'deliveries' => $this->Deliveries->getByRegion($this->Checkout->getRegion_fias_id()),
  234.                     'this_checkout' => $this->Checkout,
  235.                     'cart' => $this->Cart,
  236.                     'cart_items' => $this->cart_items,
  237.                 ]);
  238.             }
  239.         }
  240.     }
  241.     // Выбор способа оплаты
  242.     #[Route(path'/checkout/payment'name'checkout_payment_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  243.     #[Route(path'/{_locale}/checkout/payment'name'checkout_payment'requirements: ['_locale' => '%app.langs%'])]
  244.     public function payment(): Response
  245.     {
  246.         if (empty($this->Checkout->getName()) || empty($this->Checkout->getEmail())) {
  247.             //return $this->redirectToRoute('checkout_form');
  248.         }
  249.         $esystems $this->Esystems->getByRegion($this->Checkout->getRegion_fias_id(), $this->Auth->isOpt(), $this->Cart->getAmount());
  250.         $esystems $this->Esystems->filterByDelivery($esystems, (int) $this->Checkout->getDelivery_id());
  251.         return $this->render('checkout/payment.html.twig', [
  252.             'controller_name' => 'CheckoutController',
  253.             'checkout' => $this->Checkout,
  254.             'user' => $this->getUser(),
  255.             "step" => 3,
  256.             'h1' => $this->app->labels->get('checkout-title-3'),
  257.             'esystems' => $esystems,
  258.             'cart' => $this->Cart,
  259.             'cart_items' => $this->cart_items,
  260.         ]);
  261.     }
  262.     
  263.     // Подтверждение заказа
  264.     #[Route(path'/checkout/confirm'name'checkout_confirm_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  265.     #[Route(path'/{_locale}/checkout/confirm'name'checkout_confirm'requirements: ['_locale' => '%app.langs%'])]
  266.     public function confirm(Request $requestMail $MailReferal $Referal): Response
  267.     {
  268.         //$this->app->page->setH1($this->app->labels->get('checkout-title-4'));
  269.         $user null;        
  270.         if (empty($request->request->all())) {
  271.             $worktimestr '';
  272.             if ($this->Checkout->getDelivery_post_worktime()) {
  273.                 $worktimestr $this->Checkout->getDelivery_post_worktime();
  274.                 $worktimestr str_replace(': '':|'$worktimestr);
  275.                 $worktimestr str_replace('; ''|'$worktimestr);
  276.                 $worktimearr explode('|'$worktimestr);
  277.                 $worktimestr '';
  278.                 for ($i 0$i count($worktimearr); $i++) {
  279.                     if ($i == 0) {
  280.                         $worktimestr .= '<dt>' $worktimearr[$i] . '</dt>';
  281.                     } else {
  282.                         $worktimestr .= '<dd>' $worktimearr[$i] . '</dd>';
  283.                     }
  284.                 }
  285.             }
  286.             return $this->render('checkout/confirm.html.twig', [
  287.                 'worktime' => $worktimestr,
  288.                 'checkout' => $this->Checkout,
  289.                 'user' => $this->getUser(),
  290.                 "step" => 4,
  291.                 'cart' => $this->Cart,
  292.                 'cart_items' => $this->cart_items,
  293.             ]);
  294.         } else {
  295.             // if (empty($this->Checkout->getName()) || empty($this->Checkout->getEmail())) {
  296.             //     return $this->redirectToRoute('checkout_form');
  297.             // }
  298.             // if ($this->Checkout->getLastOrderTime() && $this->Checkout->getLastOrderTime() > (time() - 60)) {
  299.             //     return $this->redirectToRoute('cart');
  300.             // } else {
  301.             //     $this->Checkout->setLastOrderTime(time());
  302.             // }
  303.             // Регистрация нового клиента
  304.             if (!$this->Auth->getUserId()) {
  305.                 $password substr(md5(time()), 08);
  306.                 $usermail strtolower($this->Checkout->getEmail());
  307.                 $opt $this->Auth->isOpt() ? 0;
  308.                 $user = new User();
  309.                 $user->setType('client');
  310.                 $user->setPassword($password);
  311.                 $user->setEmail(strtolower(trim($usermail)));
  312.                 $user->setExternalId(md5($user->getEmail()));
  313.                 $user->setName($this->Checkout->getName());
  314.                 $user->setSurname($this->Checkout->getSurname());
  315.                 $user->setGender($this->Checkout->getGender());
  316.                 $user->setPhone(Func::mkphone($this->Checkout->getPhone()));
  317.                 $user->setCity($this->Checkout->getCity_name());
  318.                 $user->setAddress($this->Checkout->getUseraddr());
  319.                 $user->setLat($this->Checkout->getUserlat());
  320.                 $user->setLon($this->Checkout->getUserlon());
  321.                 $user->setIp($_SERVER['REMOTE_ADDR']);
  322.                 $user->setCreated(time());
  323.                 $user->setDiscount(0);
  324.                 $user->setOpt($opt);
  325.                 if ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX)) {
  326.                     $user->setCompanyNip($this->Checkout->getCompanyNip());
  327.                     $user->setCompanyName($this->Checkout->getCompanyName());
  328.                     $user->setCompanyIndex($this->Checkout->getCompanyIndex());
  329.                     $user->setCompanyCity($this->Checkout->getCompanyCity());
  330.                     $user->setCompanyStreet($this->Checkout->getCompanyStreet());
  331.                     $user->setCompanyHouse($this->Checkout->getCompanyHouse());
  332.                     $user->setCompanyFlat($this->Checkout->getCompanyFlat());
  333.                 }
  334.                 
  335.                 $this->em->persist($user);
  336.                 $this->em->flush();
  337.                 $userid $user->getId();
  338.                 $params = array(
  339.                     "type" => "client",
  340.                     "login" => $usermail,
  341.                     "gender" => $this->Checkout->getGender(),
  342.                     "pass" => $password,
  343.                     "email" => $usermail,
  344.                     "name" => $this->Checkout->getName(),
  345.                     "surname" => $this->Checkout->getSurname(),
  346.                     "phone" => $this->Checkout->getPhone(),
  347.                     "city" => $this->Checkout->getCity_name(),
  348.                     "address" => $this->Checkout->getUseraddr(),
  349.                 );
  350.                 // $Mail->send($this->app->sett->get('sitename'), Env::mail_from(), $usermail, $this->app->labels->get("register_message_theme"), Func::mess_from_tmp($this->app->templates->get("register_message_template"), $params));
  351.                 // $Mail->send($this->app->sett->get('sitename'), Env::mail_from(), $this->app->sett->get('admin_email'), $this->app->labels->get("register_message_theme"), Func::mess_from_tmp($this->app->templates->get("register_message_template"), $params));
  352.             } else {
  353.                 $user $this->Users->find($this->Auth->getUserId());
  354.                 $userid $user->getId();
  355.             }
  356.             $deliverycost = (float) $this->Checkout->getDelivery_cost();
  357.             if (($this->Cart->getAmount() >= $this->app->sett->get('free_delivery_amount')) && (!$this->Auth->isOpt())) {
  358.                 $deliverycost 0;
  359.             }
  360.             $needcall = ($request->get('needcall') == 'on' || $request->get('needcall') == 1) ? 0;
  361.             $opt $this->Auth->isOpt() ? 0;
  362.             $Order = new Order();
  363.             $Order->setUser($userid);
  364.             $Order->setManager((int) $user->getManager());
  365.             $Order->setName($this->Checkout->getSurname() . " " $this->Checkout->getName());
  366.             if ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX)) {
  367.                 $addr $this->Checkout->getUseraddr();
  368.                 if ($this->Checkout->getUserflat()) {
  369.                     $addr $this->Checkout->getUseraddr() . ' ' $this->app->labels->get('checkout-confirm-6') . ' ' $this->Checkout->getUserflat();
  370.                 }
  371.                 $Order->setAddr($addr);
  372.             } else {
  373.                 $Order->setAddr($this->Checkout->getUseraddr());
  374.             }
  375.             $Order->setCity($this->Checkout->getCity_name());
  376.             $Order->setPhone($this->Checkout->getPhone());
  377.             $Order->setEmail($this->Checkout->getEmail());
  378.             $Order->setTstamp(time());
  379.             $Order->setDelivery($this->Checkout->getDelivery_id());
  380.             $Order->setSubdelivery($this->Checkout->getDelivery_sub_id());
  381.             $Order->setDeliverycost($deliverycost);
  382.             $Order->setPostcode($this->Checkout->getDelivery_post_code());
  383.             $Order->setEsystem($this->Checkout->getPayment_id());
  384.             $Order->setSklad($this->Checkout->getDelivery_post_name());
  385.             $Order->setComment($request->get('comment'''));
  386.             $Order->setStatus(4);
  387.             $Order->setNeedcall($needcall);
  388.             $Order->setReferal($Referal->getId());
  389.             $Order->setSession(json_encode($_SESSIONJSON_UNESCAPED_UNICODE));
  390.             $Order->setCookie(json_encode($_COOKIEJSON_UNESCAPED_UNICODE));
  391.             $Order->setOpt($opt);
  392.             $Order->setAmount($this->Cart->getAmount() + $deliverycost);
  393.             $Order->setWeight($this->Cart->getWeight());
  394.             $Order->setAmountWithoutDiscount($this->Cart->getAmountWithoutDiscount());
  395.             if ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX)) {
  396.                 $Order->setCompanyNip($this->Checkout->getCompanyNip());
  397.                 $Order->setCompanyName($this->Checkout->getCompanyName());
  398.                 $Order->setCompanyIndex($this->Checkout->getCompanyIndex());
  399.                 $Order->setCompanyCity($this->Checkout->getCompanyCity());
  400.                 $Order->setCompanyStreet($this->Checkout->getCompanyStreet());
  401.                 $Order->setCompanyHouse($this->Checkout->getCompanyHouse());
  402.                 $Order->setCompanyFlat($this->Checkout->getCompanyFlat());
  403.             }
  404.             $this->em->persist($Order);
  405.             $this->em->flush();
  406.             $order_id $Order->getId();
  407.             $this->Checkout->setLastOrderTime(time());
  408.             $client_data "<table><tr><td>" $this->app->labels->get('name') . "</td><td>" $this->Checkout->getName() . " " $this->Checkout->getSurname() . "</td></tr><tr><td>Email</td><td>" $this->Checkout->getEmail() . "</td></tr><tr><td>" $this->app->labels->get('phone') . "</td><td>" Func::mkphone($this->Checkout->getPhone()) . "</td></tr><tr><td>" $this->app->labels->get('address') . "</td><td>" $this->Checkout->getCity_name() . ", " $this->Checkout->getUseraddr() . " ".($this->Checkout->getDelivery_name() ? " (".$this->Checkout->getDelivery_name().")" '') . "</td></tr></table>";
  409.             $this->Cart->saveCart($order_id);
  410.             $order_maked 1;
  411.             // $Order = new Model_Order($order_id);
  412.             // $view->Model_Order = $Order;
  413.             // $view->cart = $Order->cart;
  414.             // $view->order = $Order->get($order_id);
  415.             // $view->order_amount = $Order->amount();
  416.             $order_cont $this->renderView('cart/show.html.twig', [
  417.                 'checkout' => $this->Checkout,
  418.                 'user' => $this->getUser(),
  419.                 'cart' => $this->Cart,
  420.                 'cart_items' => $this->cart_items,
  421.                 'freedelivery' => $this->Cart->isFreeDelivery((float) $this->app->sett->get('free_delivery_amount')),
  422.                 'order' => $Order,
  423.             ]);
  424.             $payment $this->Esystems->find($this->Checkout->getPayment_id());
  425.             $delivery $this->Deliveries->find($this->Checkout->getDelivery_id());
  426.             $params = array(
  427.                 "order_id" => $order_id,
  428.                 //"client" => $url->s['checkout']['surname']." ".$url->s['checkout']['name'],
  429.                 "order_time" => date("d.m.Y (G:i)"time()),
  430.                 "order" => $order_cont,
  431.                 "client" => $client_data,
  432.                 "payment" => $payment $payment->getCont() : '',
  433.                 "delivery" => $delivery $delivery->getCont() : '',
  434.                 "login" => $user->getEmail(),
  435.                 "pass" => $user->getPassword(),
  436.                 "name" => $this->Checkout->getName(),
  437.                 "surname" => $this->Checkout->getSurname(),
  438.                 "email" => $this->Checkout->getEmail(),
  439.                 "phone" => Func::mkphone($this->Checkout->getPhone()),
  440.                 "city" => $this->Checkout->getCity_name(),
  441.                 "address" => $this->Checkout->getUseraddr(),
  442.                 "needcall" => $needcall,
  443.             );
  444.             $Mail->send($this->app->sett->get('sitename'), Env::mail_from(), $this->Checkout->getEmail(), $this->app->labels->get("order_message_theme"), Func::mess_from_tmp($this->app->templates->get("order_message_template"), $params));
  445.             $Mail->send($this->app->sett->get('sitename'), Env::mail_from(), $this->app->sett->get('admin_email'), $this->app->labels->get("order_message_theme"), Func::mess_from_tmp($this->app->templates->get("order_message_template"), $params));
  446.             $Mail->send($this->app->sett->get('sitename'), Env::mail_from(), "alex.suleymanov@gmail.com"$this->app->labels->get("order_message_theme"), Func::mess_from_tmp($this->app->templates->get("order_message_template"), $params));
  447.             
  448.             $this->Cart->deleteNullFromColors();
  449.             $this->Cart->deleteAll();
  450.             $this->Checkout->setRemarkingCart(1);
  451.             if ($payment->isAutof()) {
  452.                 return $this->redirectToRoute('checkout_pay', ['order' => $order_id]);
  453.             } else {
  454.                 return $this->redirectToRoute('checkout_finish', ['order_id' => $order_id]);
  455.             }            
  456.         }
  457.     }
  458.     
  459.     // Заказ оформлен. Страница "Спасибо"
  460.     #[Route(path'/checkout/finish/{order_id}'name'checkout_finish_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  461.     #[Route(path'/checkout/completed/{order_id}'name'checkout_completed_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  462.     #[Route(path'/{_locale}/checkout/finish/{order_id}'name'checkout_finish'requirements: ['_locale' => '%app.langs%'])]
  463.     #[Route(path'/{_locale}/checkout/completed/{order_id}'name'checkout_completed'requirements: ['_locale' => '%app.langs%'])]
  464.     public function finish(EventDispatcherInterface $dispatcherint $order_id): Response
  465.     {
  466.         if ($this->Checkout->getRemarkingCart() == 1) {
  467.             $order $this->Orders->find($order_id);
  468.             $user $this->Users->find($order->getUser());
  469.             $this->Cart->loadFromOrder($order->getId());
  470.             if ($order->getStatus() != && !in_array($order->getEsystem(), [25])) {
  471.                 $event = new OrderMakedEvent($order);
  472.                 $dispatcher->dispatch($eventOrderMakedEvent::NAME);
  473.             }
  474.             $order_sum $this->Cart->getAmount();
  475.             $prods $this->Cart->getCart();
  476.             $cartitems $this->Cart->getCart();
  477.             $order_sum $order_sum;
  478.             $order_id $order_id;
  479.             $this->Cart->deleteAll();
  480.             $this->Checkout->clear();
  481.             $this->Checkout->setRemarkingCart(0);
  482.             return $this->render('checkout/finish.html.twig', [
  483.                 'controller_name' => 'CheckoutController',
  484.                 'checkout' => $this->Checkout,
  485.                 'user' => $this->getUser(),
  486.                 "step" => 5,
  487.                 'h1' => $this->app->labels->get('checkout-title-5'),
  488.                 "order_sum" => $order_sum,
  489.                 "prods" => $prods,
  490.                 "cartitems" => $cartitems,
  491.                 "order_sum" => $order_sum,
  492.                 "order_id" => $order_id,
  493.             ]);
  494.         } else {
  495.             return $this->redirectToRoute('home');
  496.         }
  497.     }
  498.     // Оплата
  499.     /**
  500.      * @param Pay $Pay 
  501.      * @param Request $request 
  502.      * @param EventDispatcherInterface $dispatcher 
  503.      * @return Response 
  504.      * @throws BadRequestException 
  505.      * @throws NotFoundExceptionInterface 
  506.      * @throws ContainerExceptionInterface 
  507.      * @throws LogicException 
  508.      * @throws InvalidArgumentException 
  509.      * @throws ORMException 
  510.      */
  511.     #[Route('/checkout/pay'name'checkout_pay')]
  512.     public function pay(Pay $PayRequest $requestEventDispatcherInterface $dispatcher): Response
  513.     {
  514.         $order_id $request->get("order"0);
  515.         $order $this->Orders->find($order_id);
  516.         if (!$order) {
  517.             return $this->redirectToRoute('home');
  518.         }
  519.         $esystem $this->Esystems->find($order->getEsystem());
  520.         
  521.         if (!$esystem || !$esystem->isAutof()) {
  522.             return $this->redirectToRoute('checkout_finish', ['order_id' => $order_id]);
  523.         }
  524.         //TODO. Решить костыль с задвоением
  525.         
  526.         $event = new OrderMakedEvent($order);
  527.         $dispatcher->dispatch($eventOrderMakedEvent::NAME);        
  528.         $this->Cart->loadFromOrder($order->getId());
  529.         $order_sum $order->getAmount();
  530.         $Pay->pay($order->getEsystem(), $order->getId(), $order_sum);
  531.         return new Response('ok');
  532.     }
  533.     // Проверка результата оплаты
  534.     #[Route('/checkout/pay-result/esystem-{esystem_id}/order-{order_id}'name'checkout_pay_result')]
  535.     public function payResult(EventDispatcherInterface $dispatcherint $esystem_idint $order_id): Response
  536.     {
  537.         $esystem $this->Esystems->find($esystem_id);
  538.         $script_name $esystem->getScript();
  539.         /** @var Pay $Pay */
  540.         $Pay = new $script_name();
  541.         if ($Pay->is_success($order_id)) {
  542.             $order $this->Orders->find($order_id);
  543.             $order->setStatus(7);
  544.             $this->em->flush();
  545.             $dispatcher->dispatch(new OrderPayedEvent($order), OrderPayedEvent::NAME);
  546.         }
  547.         return new Response('ok');
  548.     }
  549.     // Успешная оплата Robokassa
  550.     #[Route('/checkout/pay-result-robokassa-afog91856kgfsadf150h'name'checkout_pay_result_robokassa_success')]
  551.     public function payResultRobokassaSuccess(Request $request): Response
  552.     {
  553.         $order_id $request->get('inv_id');
  554.         $order_sum $request->get('out_summ');
  555.         $order $this->Orders->find($order_id);
  556.         $order->setStatus(7);
  557.         $this->em->flush();
  558.         return $this->redirectToRoute('checkout_finish', ['order_id' => $order_id]);
  559.     }
  560.     // Неудачная оплата Robokassa
  561.     #[Route('/checkout/pay-result-robokassa-asg258goag0lvb'name'checkout_pay_result_robokassa_failed')]
  562.     public function payResultRobokassaFailed(): Response
  563.     {
  564.         return $this->render('checkout/failed.html.twig', [
  565.             'controller_name' => 'CheckoutController',
  566.         ]);
  567.     }
  568.     // Успешная оплата Prezelewy
  569.     /**
  570.      * @param EventDispatcherInterface $dispatcher 
  571.      * @param Request $request 
  572.      * @return Response 
  573.      * @throws BadRequestException 
  574.      */
  575.     #[Route('/checkout/payresult-przelewy-asdflkh2058yjba0g8g250ib0'name'checkout_pay_result_przelewy_success')]
  576.     public function payResultPrzelewySuccess(EventDispatcherInterface $dispatcherRequest $request): Response
  577.     {
  578.         $order_id $request->get('order');
  579.         $input = (string) $request->getContent();
  580.         $post json_encode($_POST);
  581.         if (!empty($input)) {
  582.             $this->Transactions->transactionResult($order_id$post$input);
  583.         }
  584.         
  585.         $order $this->Orders->find($order_id);
  586.         $order->setStatus(7);
  587.         $this->em->flush();
  588.         $dispatcher->dispatch(new OrderPayedEvent($order), OrderPayedEvent::NAME);
  589.         return new Response('done');
  590.     }
  591.     #[Route('/checkout/test-test'name'checkout_test_test')]
  592.     public function testtest(EventDispatcherInterface $dispatcherRequest $request): Response
  593.     {
  594.         $order_id $request->get('order');
  595.         $input = (string) $request->getContent();
  596.         $post json_encode($_POST);
  597.         // if (!empty($input)) {
  598.         //     $this->Transactions->transactionResult($order_id, $post, $input);
  599.         // }
  600.         
  601.         $order $this->Orders->find($order_id);
  602.         $event = new OrderMakedEvent($order);
  603.         $dispatcher->dispatch($eventOrderMakedEvent::NAME);
  604.         return new Response('done');
  605.     }
  606. }