vendor/sylius/sylius/src/Sylius/Bundle/UserBundle/Command/DemoteUserCommand.php line 22

Open in your IDE?
  1. <?php
  2. /*
  3.  * This file is part of the Sylius package.
  4.  *
  5.  * (c) Paweł Jędrzejewski
  6.  *
  7.  * For the full copyright and license information, please view the LICENSE
  8.  * file that was distributed with this source code.
  9.  */
  10. declare(strict_types=1);
  11. namespace Sylius\Bundle\UserBundle\Command;
  12. use Sylius\Component\User\Model\UserInterface;
  13. use Symfony\Component\Console\Input\InputArgument;
  14. use Symfony\Component\Console\Input\InputInterface;
  15. use Symfony\Component\Console\Input\InputOption;
  16. use Symfony\Component\Console\Output\OutputInterface;
  17. class DemoteUserCommand extends AbstractRoleCommand
  18. {
  19.     protected static $defaultName 'sylius:user:demote';
  20.     protected function configure(): void
  21.     {
  22.         $this
  23.             ->setDescription('Demotes a user by removing a role.')
  24.             ->setDefinition([
  25.                 new InputArgument('email'InputArgument::REQUIRED'Email'),
  26.                 new InputArgument('roles'InputArgument::IS_ARRAY'Security roles'),
  27.                 new InputOption('super-admin'nullInputOption::VALUE_NONE'Unset the user as super admin'),
  28.                 new InputOption('user-type'nullInputOption::VALUE_REQUIRED'Use shop or admin user type'),
  29.             ])
  30.             ->setHelp(
  31.                 <<<EOT
  32. The <info>sylius:user:demote</info> command demotes a user by removing security roles
  33.   <info>php app/console sylius:user:demote matthieu@email.com</info>
  34. EOT
  35.             );
  36.     }
  37.     protected function executeRoleCommand(InputInterface $inputOutputInterface $outputUserInterface $user, array $securityRoles): void
  38.     {
  39.         $error false;
  40.         $successMessages = [];
  41.         foreach ($securityRoles as $securityRole) {
  42.             if (!$user->hasRole($securityRole)) {
  43.                 $output->writeln(sprintf('<error>User "%s" doesn\'t have "%s" Security role.</error>'$user->getEmail(), $securityRole));
  44.                 $error true;
  45.                 continue;
  46.             }
  47.             $user->removeRole($securityRole);
  48.             $successMessages[] = sprintf('Security role <comment>%s</comment> has been removed from user <comment>%s</comment>'$securityRole$user->getEmail());
  49.         }
  50.         if (!$error) {
  51.             $output->writeln($successMessages);
  52.             $this->getEntityManager($input->getOption('user-type'))->flush();
  53.         } else {
  54.             $output->writeln(sprintf('<error>No roles removed from User "%s".</error>'$user->getEmail()));
  55.         }
  56.     }
  57. }