src/Controller/CheckoutController.php line 107

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.             $usergender '';
  114.             $user $this->Users->findOneBy(['email' => $email]);
  115.             if (strlen($email) && $this->Auth->getUserId() == && $user) { // Клиент есть в базе но не авторизирован
  116.                 $this->Checkout->setEmail($email);
  117.                 $errors['notloggedin'] = 1;
  118.             } else {
  119.                 if (!strlen($surname)) { // Пустое поле Фамилии
  120.                     $errors['surname_empty'] = 1;
  121.                 } elseif (!strlen($name)) { // Пустое поле Имени
  122.                     $errors['name_empty'] = 1;
  123.                 } else {
  124.                     $usersurname $surname;
  125.                     $username $name;
  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.                     $this->Checkout->setAds($request->get('ads')=='on' 0);
  146.                 } else {
  147.                     $errors['email_invalid'] = 1;   // email невалиден
  148.                 }
  149.                 if (!strlen($phone)) { // Пустое поле Номер телефона
  150.                     $errors['phone_empty'] = 1;
  151.                 }
  152.                 if (count((array)$errors) == 0) { // Если ошибок нет, переходим на этап Доставка
  153.                     return $this->redirectToRoute('checkout_delivery');
  154.                 }
  155.             }
  156.             return $this->render('checkout/form.html.twig', [
  157.                 'controller_name' => 'CheckoutController',
  158.                 'checkout' => $this->Checkout,
  159.                 'user' => $this->getUser(),
  160.                 "errors" => $errors,
  161.                 "step" => 1,
  162.                 'h1' => $this->app->labels->get('checkout-title-1'),
  163.                 'cart' => $this->Cart,
  164.                 'cart_items' => $this->cart_items,
  165.             ]);
  166.         } else { // Форма не отправлена. Заход на страницу /checkout/
  167.             return $this->render('checkout/form.html.twig', [
  168.                 'controller_name' => 'CheckoutController',
  169.                 'checkout' => $this->Checkout,
  170.                 'user' => $this->getUser(),
  171.                 "errors" => $errors,
  172.                 "step" => 1,
  173.                 'h1' => $this->app->labels->get('checkout-title-1'),
  174.                 'cart' => $this->Cart,
  175.                 'cart_items' => $this->cart_items,
  176.             ]);
  177.         }
  178.     }
  179.     // Выбор способа доставки
  180.     #[Route(path'/checkout/delivery'name'checkout_delivery_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  181.     #[Route(path'/{_locale}/checkout/delivery'name'checkout_delivery'requirements: ['_locale' => '%app.langs%'])]
  182.     public function delivery(Request $request): Response
  183.     {
  184.         if (empty($this->Checkout->getName()) || empty($this->Checkout->getEmail())) {
  185.             return $this->redirectToRoute('checkout_form');
  186.         }
  187.         if ($request->get('postform')) { // Обработка формы с полями ввода (для некоторых видов доставки)
  188.             $d_addr $request->get('delivery-addr');
  189.             $d_flat $request->get('delivery-flat');
  190.             $d_post_code $request->get('delivery-postcode');
  191.             $d_comment $request->get('delivery-comment');
  192.             $name $request->get('name');
  193.             $d_post_name $request->get('delivery-postname');
  194.             $d_worktime $request->get('delivery-worktime');
  195.             $this->Checkout->setDelivery_post_code('');
  196.             $this->Checkout->setDelivery_post_name('');
  197.             $this->Checkout->setDelivery_post_worktime('');
  198.             $this->Checkout->setDelivery_post_phone('');
  199.             $this->Checkout->setDelivery_post_email('');
  200.             //if (($name) && ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX))) {
  201.             if ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX)) {
  202.                 $this->Checkout->setCity_name($name);
  203.                 $this->Checkout->setDelivery_post_name($d_post_name);
  204.             }
  205.             if (isset($d_addr)) {
  206.                 $this->Checkout->setUseraddr($d_addr);
  207.             }
  208.             if (isset($d_flat)) {
  209.                 $this->Checkout->setUseraddr($d_addr);
  210.                 if ((Env::site() != Env::MIX) && (Env::site() != Env::OPT_MIX) && (Env::site() != Env::MIR) && (Env::site() != Env::OPT_MIR)) {
  211.                     $this->Checkout->setUseraddr($d_addr ', ' $this->app->labels->get('checkout-confirm-6') . ' ' $d_flat);
  212.                 }
  213.                 $this->Checkout->setUserflat($d_flat);
  214.             }
  215.             if (isset($d_worktime)) {
  216.                 $this->Checkout->setDelivery_post_worktime($d_worktime);
  217.             }
  218.             $this->Checkout->setDelivery_post_code($d_post_code);
  219.             $this->Checkout->setComment($d_comment);
  220.             return $this->redirectToRoute('checkout_payment');
  221.         } else {
  222.             if (!$this->Checkout->getUserlat() && !$this->Checkout->getUserlon()) {
  223.                 $user $this->Users->find($this->Auth->getUserId());
  224.                 if ($user && $user->getLat() && $user->getLon()) {
  225.                     $this->Checkout->setUserlat($user->getLat());
  226.                     $this->Checkout->setUserlon($user->getLon());
  227.                 }
  228.             }
  229.             if (count($request->request->all()) > 0) {
  230.                 return $this->redirectToRoute('checkout_payment');
  231.             } else {
  232.                 $user $this->Users->find($this->Auth->getUserId());
  233.                 return $this->render('checkout/delivery.html.twig', [
  234.                     'controller_name' => 'CheckoutController',
  235.                     'checkout' => $this->Checkout,
  236.                     'user' => $this->getUser(),
  237.                     "step" => 2,
  238.                     'h1' => $this->app->labels->get('checkout-title-2'),
  239.                     'deliveries' => $this->Deliveries->getByRegion($this->Checkout->getRegion_fias_id()),
  240.                     'this_checkout' => $this->Checkout,
  241.                     'cart' => $this->Cart,
  242.                     'cart_items' => $this->cart_items,
  243.                 ]);
  244.             }
  245.         }
  246.     }
  247.     // Выбор способа оплаты
  248.     #[Route(path'/checkout/payment'name'checkout_payment_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  249.     #[Route(path'/{_locale}/checkout/payment'name'checkout_payment'requirements: ['_locale' => '%app.langs%'])]
  250.     public function payment(): Response
  251.     {
  252.         if (empty($this->Checkout->getName()) || empty($this->Checkout->getEmail())) {
  253.             //return $this->redirectToRoute('checkout_form');
  254.         }
  255.         $esystems $this->Esystems->getByRegion($this->Checkout->getRegion_fias_id(), $this->Auth->isOpt(), $this->Cart->getAmount());
  256.         $esystems $this->Esystems->filterByDelivery($esystems, (int) $this->Checkout->getDelivery_id());
  257.         return $this->render('checkout/payment.html.twig', [
  258.             'controller_name' => 'CheckoutController',
  259.             'checkout' => $this->Checkout,
  260.             'user' => $this->getUser(),
  261.             "step" => 3,
  262.             'h1' => $this->app->labels->get('checkout-title-3'),
  263.             'esystems' => $esystems,
  264.             'cart' => $this->Cart,
  265.             'cart_items' => $this->cart_items,
  266.         ]);
  267.     }
  268.     
  269.     // Подтверждение заказа
  270.     #[Route(path'/checkout/confirm'name'checkout_confirm_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  271.     #[Route(path'/{_locale}/checkout/confirm'name'checkout_confirm'requirements: ['_locale' => '%app.langs%'])]
  272.     public function confirm(Request $requestMail $MailReferal $Referal): Response
  273.     {
  274.         //$this->app->page->setH1($this->app->labels->get('checkout-title-4'));
  275.         $user null;        
  276.         if (empty($request->request->all())) {
  277.             $worktimestr '';
  278.             if ($this->Checkout->getDelivery_post_worktime()) {
  279.                 $worktimestr $this->Checkout->getDelivery_post_worktime();
  280.                 $worktimestr str_replace(': '':|'$worktimestr);
  281.                 $worktimestr str_replace('; ''|'$worktimestr);
  282.                 $worktimearr explode('|'$worktimestr);
  283.                 $worktimestr '';
  284.                 for ($i 0$i count($worktimearr); $i++) {
  285.                     if ($i == 0) {
  286.                         $worktimestr .= '<dt>' $worktimearr[$i] . '</dt>';
  287.                     } else {
  288.                         $worktimestr .= '<dd>' $worktimearr[$i] . '</dd>';
  289.                     }
  290.                 }
  291.             }
  292.             return $this->render('checkout/confirm.html.twig', [
  293.                 'worktime' => $worktimestr,
  294.                 'checkout' => $this->Checkout,
  295.                 'user' => $this->getUser(),
  296.                 "step" => 4,
  297.                 'cart' => $this->Cart,
  298.                 'cart_items' => $this->cart_items,
  299.             ]);
  300.         } else {
  301.             // if (empty($this->Checkout->getName()) || empty($this->Checkout->getEmail())) {
  302.             //     return $this->redirectToRoute('checkout_form');
  303.             // }
  304.             // if ($this->Checkout->getLastOrderTime() && $this->Checkout->getLastOrderTime() > (time() - 60)) {
  305.             //     return $this->redirectToRoute('cart');
  306.             // } else {
  307.             //     $this->Checkout->setLastOrderTime(time());
  308.             // }
  309.             // Регистрация нового клиента
  310.             if (!$this->Auth->getUserId()) {
  311.                 $password substr(md5(time()), 08);
  312.                 $usermail strtolower($this->Checkout->getEmail());
  313.                 $opt $this->Auth->isOpt() ? 0;
  314.                 $user = new User();
  315.                 $user->setType('client');
  316.                 $user->setPassword($password);
  317.                 $user->setEmail(strtolower(trim($usermail)));
  318.                 $user->setExternalId(md5($user->getEmail()));
  319.                 $user->setName($this->Checkout->getName());
  320.                 $user->setSurname($this->Checkout->getSurname());
  321.                 $user->setGender($this->Checkout->getGender());
  322.                 $user->setPhone(Func::mkphone($this->Checkout->getPhone()));
  323.                 $user->setCity($this->Checkout->getCity_name());
  324.                 $user->setAddress($this->Checkout->getUseraddr());
  325.                 $user->setLat($this->Checkout->getUserlat());
  326.                 $user->setLon($this->Checkout->getUserlon());
  327.                 $user->setIp($_SERVER['REMOTE_ADDR']);
  328.                 $user->setCreated(time());
  329.                 $user->setDiscount(0);
  330.                 $user->setOpt($opt);
  331.                 $user->setAds($this->Checkout->getAds());
  332.                 if ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX)) {
  333.                     $user->setCompanyNip($this->Checkout->getCompanyNip());
  334.                     $user->setCompanyName($this->Checkout->getCompanyName());
  335.                     $user->setCompanyIndex($this->Checkout->getCompanyIndex());
  336.                     $user->setCompanyCity($this->Checkout->getCompanyCity());
  337.                     $user->setCompanyStreet($this->Checkout->getCompanyStreet());
  338.                     $user->setCompanyHouse($this->Checkout->getCompanyHouse());
  339.                     $user->setCompanyFlat($this->Checkout->getCompanyFlat());
  340.                 }
  341.                 
  342.                 $this->em->persist($user);
  343.                 $this->em->flush();
  344.                 $userid $user->getId();
  345.                 $params = array(
  346.                     "type" => "client",
  347.                     "login" => $usermail,
  348.                     "gender" => $this->Checkout->getGender(),
  349.                     "pass" => $password,
  350.                     "email" => $usermail,
  351.                     "name" => $this->Checkout->getName(),
  352.                     "surname" => $this->Checkout->getSurname(),
  353.                     "phone" => $this->Checkout->getPhone(),
  354.                     "city" => $this->Checkout->getCity_name(),
  355.                     "address" => $this->Checkout->getUseraddr(),
  356.                 );
  357.                 // $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));
  358.                 // $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));
  359.             } else {
  360.                 $user $this->Users->find($this->Auth->getUserId());
  361.                 $userid $user->getId();
  362.             }
  363.             $deliverycost = (float) $this->Checkout->getDelivery_cost();
  364.             if (($this->Cart->getAmount() >= $this->app->sett->get('free_delivery_amount')) && (!$this->Auth->isOpt())) {
  365.                 $deliverycost 0;
  366.             }
  367.             $needcall = ($request->get('needcall') == 'on' || $request->get('needcall') == 1) ? 0;
  368.             $opt $this->Auth->isOpt() ? 0;
  369.             $Order = new Order();
  370.             $Order->setUser($userid);
  371.             $Order->setManager((int) $user->getManager());
  372.             $Order->setName($this->Checkout->getSurname() . " " $this->Checkout->getName());
  373.             if ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX)) {
  374.                 $addr $this->Checkout->getUseraddr();
  375.                 if ($this->Checkout->getUserflat()) {
  376.                     $addr $this->Checkout->getUseraddr() . ' ' $this->app->labels->get('checkout-confirm-6') . ' ' $this->Checkout->getUserflat();
  377.                 }
  378.                 $Order->setAddr($addr);
  379.             } else {
  380.                 $Order->setAddr($this->Checkout->getUseraddr());
  381.             }
  382.             $Order->setCity($this->Checkout->getCity_name());
  383.             $Order->setPhone($this->Checkout->getPhone());
  384.             $Order->setEmail($this->Checkout->getEmail());
  385.             $Order->setTstamp(time());
  386.             $Order->setDelivery($this->Checkout->getDelivery_id());
  387.             $Order->setSubdelivery($this->Checkout->getDelivery_sub_id());
  388.             $Order->setDeliverycost($deliverycost);
  389.             $Order->setPostcode($this->Checkout->getDelivery_post_code());
  390.             $Order->setEsystem($this->Checkout->getPayment_id());
  391.             $Order->setSklad($this->Checkout->getDelivery_post_name());
  392.             $Order->setComment($request->get('comment'''));
  393.             $Order->setStatus(4);
  394.             $Order->setNeedcall($needcall);
  395.             $Order->setReferal($Referal->getId());
  396.             $Order->setSession(json_encode($_SESSIONJSON_UNESCAPED_UNICODE));
  397.             $Order->setCookie(json_encode($_COOKIEJSON_UNESCAPED_UNICODE));
  398.             $Order->setOpt($opt);
  399.             $Order->setAmount($this->Cart->getAmount() + $deliverycost);
  400.             $Order->setWeight($this->Cart->getWeight());
  401.             $Order->setAmountWithoutDiscount($this->Cart->getAmountWithoutDiscount());
  402.             if ((Env::site() == Env::MIX) || (Env::site() == Env::OPT_MIX)) {
  403.                 $Order->setCompanyNip($this->Checkout->getCompanyNip());
  404.                 $Order->setCompanyName($this->Checkout->getCompanyName());
  405.                 $Order->setCompanyIndex($this->Checkout->getCompanyIndex());
  406.                 $Order->setCompanyCity($this->Checkout->getCompanyCity());
  407.                 $Order->setCompanyStreet($this->Checkout->getCompanyStreet());
  408.                 $Order->setCompanyHouse($this->Checkout->getCompanyHouse());
  409.                 $Order->setCompanyFlat($this->Checkout->getCompanyFlat());
  410.             }
  411.             $this->em->persist($Order);
  412.             $this->em->flush();
  413.             $order_id $Order->getId();
  414.             $this->Checkout->setLastOrderTime(time());
  415.             $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->getUseraddr() : $this->Checkout->getDelivery_post_name()) . " ".($this->Checkout->getDelivery_name() ? " (".$this->Checkout->getDelivery_name().")" '') . "</td></tr></table>";
  416.             $this->Cart->saveCart($order_id);
  417.             $order_maked 1;
  418.             // $Order = new Model_Order($order_id);
  419.             // $view->Model_Order = $Order;
  420.             // $view->cart = $Order->cart;
  421.             // $view->order = $Order->get($order_id);
  422.             // $view->order_amount = $Order->amount();
  423.             $order_cont $this->renderView('cart/show.html.twig', [
  424.                 'checkout' => $this->Checkout,
  425.                 'user' => $this->getUser(),
  426.                 'cart' => $this->Cart,
  427.                 'cart_items' => $this->cart_items,
  428.                 'freedelivery' => $this->Cart->isFreeDelivery((float) $this->app->sett->get('free_delivery_amount')),
  429.                 'order' => $Order,
  430.             ]);
  431.             $payment $this->Esystems->find($this->Checkout->getPayment_id());
  432.             $delivery $this->Deliveries->find($this->Checkout->getDelivery_id());
  433.             $params = array(
  434.                 "order_id" => $order_id,
  435.                 //"client" => $url->s['checkout']['surname']." ".$url->s['checkout']['name'],
  436.                 "order_time" => date("d.m.Y (G:i)"time()),
  437.                 "order" => $order_cont,
  438.                 "client" => $client_data,
  439.                 "payment" => $payment $payment->getCont() : '',
  440.                 "delivery" => $delivery $delivery->getCont() : '',
  441.                 "login" => $user->getEmail(),
  442.                 "pass" => $user->getPassword(),
  443.                 "name" => $this->Checkout->getName(),
  444.                 "surname" => $this->Checkout->getSurname(),
  445.                 "email" => $this->Checkout->getEmail(),
  446.                 "phone" => Func::mkphone($this->Checkout->getPhone()),
  447.                 "city" => $this->Checkout->getCity_name(),
  448.                 "address" => $this->Checkout->getUseraddr(),
  449.                 "needcall" => $needcall,
  450.             );
  451.             $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));
  452.             $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));
  453.             
  454.             $this->Cart->deleteNullFromColors();
  455.             $this->Cart->deleteAll();
  456.             $this->Checkout->setRemarkingCart(1);
  457.             if ($payment->isAutof()) {
  458.                 return $this->redirectToRoute('checkout_pay', ['order' => $order_id]);
  459.             } else {
  460.                 return $this->redirectToRoute('checkout_finish', ['order_id' => $order_id]);
  461.             }            
  462.         }
  463.     }
  464.     
  465.     // Заказ оформлен. Страница "Спасибо"
  466.     #[Route(path'/checkout/finish/{order_id}'name'checkout_finish_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  467.     #[Route(path'/checkout/completed/{order_id}'name'checkout_completed_no_locale'defaults: ['_locale' => '%app.default_lang%'])]
  468.     #[Route(path'/{_locale}/checkout/finish/{order_id}'name'checkout_finish'requirements: ['_locale' => '%app.langs%'])]
  469.     #[Route(path'/{_locale}/checkout/completed/{order_id}'name'checkout_completed'requirements: ['_locale' => '%app.langs%'])]
  470.     public function finish(EventDispatcherInterface $dispatcherint $order_id): Response
  471.     {
  472.         if ($this->Checkout->getRemarkingCart() == 1) {
  473.             $order $this->Orders->find($order_id);
  474.             $user $this->Users->find($order->getUser());
  475.             $this->Cart->loadFromOrder($order->getId());
  476.             if ($order->getStatus() != && !in_array($order->getEsystem(), [25])) {
  477.                 $event = new OrderMakedEvent($order);
  478.                 $dispatcher->dispatch($eventOrderMakedEvent::NAME);
  479.             }
  480.             $order_sum $this->Cart->getAmount();
  481.             $prods $this->Cart->getCart();
  482.             $cartitems $this->Cart->getCart();
  483.             $order_sum $order_sum;
  484.             $order_id $order_id;
  485.             $this->Cart->deleteAll();
  486.             $this->Checkout->clear();
  487.             $this->Checkout->setRemarkingCart(0);
  488.             return $this->render('checkout/finish.html.twig', [
  489.                 'controller_name' => 'CheckoutController',
  490.                 'checkout' => $this->Checkout,
  491.                 'user' => $this->getUser(),
  492.                 "step" => 5,
  493.                 'h1' => $this->app->labels->get('checkout-title-5'),
  494.                 "order_sum" => $order_sum,
  495.                 "prods" => $prods,
  496.                 "cartitems" => $cartitems,
  497.                 "order_sum" => $order_sum,
  498.                 "order_id" => $order_id,
  499.             ]);
  500.         } else {
  501.             return $this->redirectToRoute('home');
  502.         }
  503.     }
  504.     // Оплата
  505.     /**
  506.      * @param Pay $Pay 
  507.      * @param Request $request 
  508.      * @param EventDispatcherInterface $dispatcher 
  509.      * @return Response 
  510.      * @throws BadRequestException 
  511.      * @throws NotFoundExceptionInterface 
  512.      * @throws ContainerExceptionInterface 
  513.      * @throws LogicException 
  514.      * @throws InvalidArgumentException 
  515.      * @throws ORMException 
  516.      */
  517.     #[Route('/checkout/pay'name'checkout_pay')]
  518.     public function pay(Pay $PayRequest $requestEventDispatcherInterface $dispatcher): Response
  519.     {
  520.         $order_id $request->get("order"0);
  521.         $order $this->Orders->find($order_id);
  522.         if (!$order) {
  523.             return $this->redirectToRoute('home');
  524.         }
  525.         $esystem $this->Esystems->find($order->getEsystem());
  526.         
  527.         if (!$esystem || !$esystem->isAutof()) {
  528.             return $this->redirectToRoute('checkout_finish', ['order_id' => $order_id]);
  529.         }
  530.         //TODO. Решить костыль с задвоением
  531.         
  532.         $event = new OrderMakedEvent($order);
  533.         $dispatcher->dispatch($eventOrderMakedEvent::NAME);        
  534.         $this->Cart->loadFromOrder($order->getId());
  535.         $order_sum $order->getAmount();
  536.         $Pay->pay($order->getEsystem(), $order->getId(), $order_sum);
  537.         return new Response('ok');
  538.     }
  539.     // Проверка результата оплаты
  540.     #[Route('/checkout/pay-result/esystem-{esystem_id}/order-{order_id}'name'checkout_pay_result')]
  541.     public function payResult(EventDispatcherInterface $dispatcherint $esystem_idint $order_id): Response
  542.     {
  543.         $esystem $this->Esystems->find($esystem_id);
  544.         $script_name $esystem->getScript();
  545.         /** @var Pay $Pay */
  546.         $Pay = new $script_name();
  547.         if ($Pay->is_success($order_id)) {
  548.             $order $this->Orders->find($order_id);
  549.             $order->setStatus(7);
  550.             $this->em->flush();
  551.             $dispatcher->dispatch(new OrderPayedEvent($order), OrderPayedEvent::NAME);
  552.         }
  553.         return new Response('ok');
  554.     }
  555.     // Успешная оплата Robokassa
  556.     #[Route('/checkout/pay-result-robokassa-afog91856kgfsadf150h'name'checkout_pay_result_robokassa_success')]
  557.     public function payResultRobokassaSuccess(Request $request): Response
  558.     {
  559.         $order_id $request->get('inv_id');
  560.         $order_sum $request->get('out_summ');
  561.         $order $this->Orders->find($order_id);
  562.         $order->setStatus(7);
  563.         $this->em->flush();
  564.         return $this->redirectToRoute('checkout_finish', ['order_id' => $order_id]);
  565.     }
  566.     // Неудачная оплата Robokassa
  567.     #[Route('/checkout/pay-result-robokassa-asg258goag0lvb'name'checkout_pay_result_robokassa_failed')]
  568.     public function payResultRobokassaFailed(): Response
  569.     {
  570.         return $this->render('checkout/failed.html.twig', [
  571.             'controller_name' => 'CheckoutController',
  572.         ]);
  573.     }
  574.     // Успешная оплата Prezelewy
  575.     /**
  576.      * @param EventDispatcherInterface $dispatcher 
  577.      * @param Request $request 
  578.      * @return Response 
  579.      * @throws BadRequestException 
  580.      */
  581.     #[Route('/checkout/payresult-przelewy-asdflkh2058yjba0g8g250ib0'name'checkout_pay_result_przelewy_success')]
  582.     public function payResultPrzelewySuccess(EventDispatcherInterface $dispatcherRequest $request): Response
  583.     {
  584.         $order_id $request->get('order');
  585.         $input = (string) $request->getContent();
  586.         $post json_encode($_POST);
  587.         if (!empty($input)) {
  588.             $this->Transactions->transactionResult($order_id$post$input);
  589.         }
  590.         
  591.         $order $this->Orders->find($order_id);
  592.         $order->setStatus(7);
  593.         $this->em->flush();
  594.         $dispatcher->dispatch(new OrderPayedEvent($order), OrderPayedEvent::NAME);
  595.         return new Response('done');
  596.     }
  597.     #[Route('/checkout/test-test'name'checkout_test_test')]
  598.     public function testtest(EventDispatcherInterface $dispatcherRequest $request): Response
  599.     {
  600.         $order_id $request->get('order');
  601.         $input = (string) $request->getContent();
  602.         $post json_encode($_POST);
  603.         // if (!empty($input)) {
  604.         //     $this->Transactions->transactionResult($order_id, $post, $input);
  605.         // }
  606.         
  607.         $order $this->Orders->find($order_id);
  608.         $event = new OrderMakedEvent($order);
  609.         $dispatcher->dispatch($eventOrderMakedEvent::NAME);
  610.         return new Response('done');
  611.     }
  612. }