![]() 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/magento/module-vault/Observer/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace Magento\Vault\Observer; use Magento\Framework\Encryption\EncryptorInterface; use Magento\Framework\Event\Observer; use Magento\Framework\Event\ObserverInterface; use Magento\Sales\Api\Data\OrderPaymentExtensionInterface; use Magento\Sales\Api\Data\OrderPaymentInterface; use Magento\Vault\Api\Data\PaymentTokenInterface; use Magento\Vault\Api\PaymentTokenManagementInterface; use Magento\Vault\Model\Ui\VaultConfigProvider; /** * Order payment after save observer for storing payment vault record in db */ class AfterPaymentSaveObserver implements ObserverInterface { const PAYMENT_OBJECT_DATA_KEY = 'payment'; /** * @var PaymentTokenManagementInterface */ protected $paymentTokenManagement; /** * @var EncryptorInterface */ protected $encryptor; /** * @param PaymentTokenManagementInterface $paymentTokenManagement * @param EncryptorInterface $encryptor */ public function __construct( PaymentTokenManagementInterface $paymentTokenManagement, EncryptorInterface $encryptor ) { $this->paymentTokenManagement = $paymentTokenManagement; $this->encryptor = $encryptor; } /** * Create payment vault record * * @param Observer $observer * @return $this */ public function execute(Observer $observer) { /** @var OrderPaymentInterface $payment */ $payment = $observer->getDataByKey(self::PAYMENT_OBJECT_DATA_KEY); $extensionAttributes = $payment->getExtensionAttributes(); $paymentToken = $this->getPaymentToken($extensionAttributes); if ($paymentToken === null) { return $this; } if ($paymentToken->getEntityId() !== null) { $this->paymentTokenManagement->addLinkToOrderPayment( $paymentToken->getEntityId(), $payment->getEntityId() ); return $this; } $order = $payment->getOrder(); $paymentToken->setCustomerId($order->getCustomerId()); $paymentToken->setIsActive(true); $paymentToken->setPaymentMethodCode($payment->getMethod()); $additionalInformation = $payment->getAdditionalInformation(); $paymentToken->setIsVisible( (bool) (int) ($additionalInformation[VaultConfigProvider::IS_ACTIVE_CODE] ?? 0) ); $paymentToken->setPublicHash($this->generatePublicHash($paymentToken)); $this->paymentTokenManagement->saveTokenWithPaymentLink($paymentToken, $payment); $extensionAttributes->setVaultPaymentToken($paymentToken); return $this; } /** * Generate vault payment public hash * * @param PaymentTokenInterface $paymentToken * @return string */ protected function generatePublicHash(PaymentTokenInterface $paymentToken) { $hashKey = $paymentToken->getGatewayToken(); if ($paymentToken->getCustomerId()) { $hashKey = $paymentToken->getCustomerId(); } $hashKey .= $paymentToken->getPaymentMethodCode() . $paymentToken->getType() . $paymentToken->getTokenDetails(); return $this->encryptor->getHash($hashKey); } /** * Reads Payment token from Order Payment * * @param OrderPaymentExtensionInterface|null $extensionAttributes * @return PaymentTokenInterface | null */ protected function getPaymentToken(OrderPaymentExtensionInterface $extensionAttributes = null) { if (null === $extensionAttributes) { return null; } /** @var PaymentTokenInterface $paymentToken */ $paymentToken = $extensionAttributes->getVaultPaymentToken(); if (null === $paymentToken || empty($paymentToken->getGatewayToken())) { return null; } return $paymentToken; } }