![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/mageplaza/module-smtp/Observer/Order/ |
<?php /** * Mageplaza * * NOTICE OF LICENSE * * This source file is subject to the Mageplaza.com license that is * available through the world-wide-web at this URL: * https://www.mageplaza.com/LICENSE.txt * * DISCLAIMER * * Do not edit or add to this file if you wish to upgrade this extension to newer * version in the future. * * @category Mageplaza * @package Mageplaza_Smtp * @copyright Copyright (c) Mageplaza (https://www.mageplaza.com/) * @license https://www.mageplaza.com/LICENSE.txt */ namespace Mageplaza\Smtp\Observer\Order; use Exception; use Magento\Framework\Event\Observer; use Magento\Framework\Event\ObserverInterface; use Magento\Framework\Exception\LocalizedException; use Magento\Framework\Exception\NoSuchEntityException; use Magento\Sales\Model\Order\Invoice; use Mageplaza\Smtp\Helper\EmailMarketing; use Magento\Sales\Model\ResourceModel\Order as ResourceOrder; use Psr\Log\LoggerInterface; /** * Class InvoiceCommitAfter * @package Mageplaza\Smtp\Observer\Order */ class InvoiceCommitAfter implements ObserverInterface { /** * @var EmailMarketing */ protected $helperEmailMarketing; /** * @var LoggerInterface */ protected $logger; /** * @var ResourceOrder */ protected $resourceOrder; /** * InvoiceCommitAfter constructor. * * @param EmailMarketing $helperEmailMarketing * @param LoggerInterface $logger * @param ResourceOrder $resourceOrder */ public function __construct( EmailMarketing $helperEmailMarketing, LoggerInterface $logger, ResourceOrder $resourceOrder ) { $this->helperEmailMarketing = $helperEmailMarketing; $this->logger = $logger; $this->resourceOrder = $resourceOrder; } /** * @param Observer $observer * * @throws LocalizedException * @throws NoSuchEntityException */ public function execute(Observer $observer) { if ($this->helperEmailMarketing->isEnableEmailMarketing() && $this->helperEmailMarketing->getSecretKey() && $this->helperEmailMarketing->getAppID() ) { /* @var Invoice $order */ $invoice = $observer->getEvent()->getDataObject(); $order = $invoice->getOrder(); try { if (!$order->getData('mp_smtp_email_marketing_order_created') && $order->getCreatedAt() === $order->getUpdatedAt()) { $this->helperEmailMarketing->sendOrderRequest($order); $this->helperEmailMarketing->updateCustomer($order->getCustomerId()); $order->setData('mp_smtp_email_marketing_order_created', true); $resource = $this->resourceOrder; $resource->getConnection()->update( $resource->getMainTable(), ['mp_smtp_email_marketing_order_created' => 1], ['entity_id = ?' => $order->getId()] ); } if ($invoice->getId() && $invoice->getCreatedAt() == $invoice->getUpdatedAt()) { $this->helperEmailMarketing->sendOrderRequest($invoice, EmailMarketing::INVOICE_URL); } $this->helperEmailMarketing->updateCustomer($order->getCustomerId()); } catch (Exception $e) { $this->logger->critical($e->getMessage()); } } } }