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 function configure(): void
  20.     {
  21.         $this
  22.             ->setName('sylius:user:demote')
  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(<<<EOT
  31. The <info>sylius:user:demote</info> command demotes a user by removing security roles
  32.   <info>php app/console sylius:user:demote [email protected]</info>
  33. EOT
  34.             );
  35.     }
  36.     protected function executeRoleCommand(InputInterface $inputOutputInterface $outputUserInterface $user, array $securityRoles): void
  37.     {
  38.         $error false;
  39.         $successMessages = [];
  40.         foreach ($securityRoles as $securityRole) {
  41.             if (!$user->hasRole($securityRole)) {
  42.                 $output->writeln(sprintf('<error>User "%s" doesn\'t have "%s" Security role.</error>'$user->getEmail(), $securityRole));
  43.                 $error true;
  44.                 continue;
  45.             }
  46.             $user->removeRole($securityRole);
  47.             $successMessages[] = sprintf('Security role <comment>%s</comment> has been removed from user <comment>%s</comment>'$securityRole$user->getEmail());
  48.         }
  49.         if (!$error) {
  50.             $output->writeln($successMessages);
  51.             $this->getEntityManager($input->getOption('user-type'))->flush();
  52.         } else {
  53.             $output->writeln(sprintf('<error>No roles removed from User "%s".</error>'$user->getEmail()));
  54.         }
  55.     }
  56. }