![]() 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-graph-ql/Model/Resolver/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ declare(strict_types=1); namespace Magento\VaultGraphQl\Model\Resolver; use Magento\Framework\GraphQl\Config\Element\Field; use Magento\Framework\GraphQl\Exception\GraphQlAuthorizationException; use Magento\Framework\GraphQl\Exception\GraphQlNoSuchEntityException; use Magento\Framework\GraphQl\Query\ResolverInterface; use Magento\Framework\GraphQl\Schema\Type\ResolveInfo; use Magento\GraphQl\Model\Query\ContextInterface; use Magento\Vault\Api\PaymentTokenManagementInterface; use Magento\Vault\Api\PaymentTokenRepositoryInterface; /** * Delete Payment Token resolver, used for GraphQL mutation processing. */ class DeletePaymentToken implements ResolverInterface { /** * @var PaymentTokenManagementInterface */ private $paymentTokenManagement; /** * @var PaymentTokenRepositoryInterface */ private $paymentTokenRepository; /** * @param PaymentTokenManagementInterface $paymentTokenManagement * @param PaymentTokenRepositoryInterface $paymentTokenRepository */ public function __construct( PaymentTokenManagementInterface $paymentTokenManagement, PaymentTokenRepositoryInterface $paymentTokenRepository ) { $this->paymentTokenManagement = $paymentTokenManagement; $this->paymentTokenRepository = $paymentTokenRepository; } /** * @inheritdoc */ public function resolve( Field $field, $context, ResolveInfo $info, array $value = null, array $args = null ) { /** @var ContextInterface $context */ if (false === $context->getExtensionAttributes()->getIsCustomer()) { throw new GraphQlAuthorizationException(__('The current customer isn\'t authorized.')); } $args['public_hash'] = $args['public_hash'] ?? ''; $token = $this->paymentTokenManagement->getByPublicHash($args['public_hash'], $context->getUserId()); if (!$token) { throw new GraphQlNoSuchEntityException( __('Could not find a token using public hash: %1', $args['public_hash']) ); } return ['result' => $this->paymentTokenRepository->delete($token)]; } }