![]() 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-customer-graph-ql/Model/Resolver/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ declare(strict_types=1); namespace Magento\CustomerGraphQl\Model\Resolver; use Magento\CustomerGraphQl\Model\Customer\DeleteCustomer as DeleteCustomerModel; use Magento\CustomerGraphQl\Model\Customer\GetCustomer; use Magento\Framework\GraphQl\Config\Element\Field; use Magento\Framework\GraphQl\Exception\GraphQlAuthorizationException; use Magento\Framework\GraphQl\Query\ResolverInterface; use Magento\Framework\GraphQl\Schema\Type\ResolveInfo; use Magento\Framework\Registry; use Magento\GraphQl\Model\Query\ContextInterface; /** * Delete customer, used for GraphQL request processing. */ class DeleteCustomer implements ResolverInterface { /** * @var GetCustomer */ private $getCustomer; /** * @var DeleteCustomerModel */ private $deleteCustomer; /** * @var Registry */ private $registry; /** * @param GetCustomer $getCustomer * @param DeleteCustomerModel $deleteCustomer * @param Registry $registry */ public function __construct( GetCustomer $getCustomer, DeleteCustomerModel $deleteCustomer, Registry $registry ) { $this->getCustomer = $getCustomer; $this->deleteCustomer = $deleteCustomer; $this->registry = $registry; } /** * @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.')); } $isSecure = $this->registry->registry('isSecureArea'); $this->registry->unregister('isSecureArea'); $this->registry->register('isSecureArea', true); $customer = $this->getCustomer->execute($context); $this->deleteCustomer->execute($customer); $this->registry->unregister('isSecureArea'); $this->registry->register('isSecureArea', $isSecure); return true; } }