PlaceOrder.php 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Signifyd\Observer;
  7. use Magento\Framework\Event;
  8. use Magento\Framework\Event\Observer;
  9. use Magento\Framework\Event\ObserverInterface;
  10. use Magento\Framework\Exception\AlreadyExistsException;
  11. use Magento\Sales\Api\Data\OrderInterface;
  12. use Magento\Sales\Model\Order;
  13. use Magento\Signifyd\Api\CaseCreationServiceInterface;
  14. use Magento\Signifyd\Model\Config;
  15. use Psr\Log\LoggerInterface;
  16. /**
  17. * Observer should be triggered when new order is created and placed.
  18. * If Signifyd integration enabled in configuration then new case will be created.
  19. */
  20. class PlaceOrder implements ObserverInterface
  21. {
  22. /**
  23. * @var Config
  24. */
  25. private $signifydIntegrationConfig;
  26. /**
  27. * @var CaseCreationServiceInterface
  28. */
  29. private $caseCreationService;
  30. /**
  31. * @var LoggerInterface
  32. */
  33. private $logger;
  34. /**
  35. * @param Config $signifydIntegrationConfig
  36. * @param CaseCreationServiceInterface $caseCreationService
  37. * @param LoggerInterface $logger
  38. */
  39. public function __construct(
  40. Config $signifydIntegrationConfig,
  41. CaseCreationServiceInterface $caseCreationService,
  42. LoggerInterface $logger
  43. ) {
  44. $this->signifydIntegrationConfig = $signifydIntegrationConfig;
  45. $this->caseCreationService = $caseCreationService;
  46. $this->logger = $logger;
  47. }
  48. /**
  49. * {@inheritdoc}
  50. */
  51. public function execute(Observer $observer)
  52. {
  53. $orders = $this->extractOrders(
  54. $observer->getEvent()
  55. );
  56. if (null === $orders) {
  57. return;
  58. }
  59. foreach ($orders as $order) {
  60. $storeId = $order->getStoreId();
  61. if ($this->signifydIntegrationConfig->isActive($storeId)) {
  62. $this->createCaseForOrder($order);
  63. }
  64. }
  65. }
  66. /**
  67. * Creates Signifyd case for single order with online payment method.
  68. *
  69. * @param OrderInterface $order
  70. * @return void
  71. */
  72. private function createCaseForOrder($order)
  73. {
  74. $orderId = $order->getEntityId();
  75. if (null === $orderId
  76. || $order->getPayment()->getMethodInstance()->isOffline()
  77. || $order->getState() === Order::STATE_PENDING_PAYMENT) {
  78. return;
  79. }
  80. try {
  81. $this->caseCreationService->createForOrder($orderId);
  82. } catch (AlreadyExistsException $e) {
  83. $this->logger->error($e->getMessage());
  84. }
  85. }
  86. /**
  87. * Returns Orders entity list from Event data container
  88. *
  89. * @param Event $event
  90. * @return OrderInterface[]|null
  91. */
  92. private function extractOrders(Event $event)
  93. {
  94. $order = $event->getData('order');
  95. if (null !== $order) {
  96. return [$order];
  97. }
  98. return $event->getData('orders');
  99. }
  100. }