![]() 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/web-token/jwt-framework/src/Component/Console/ |
<?php declare(strict_types=1); namespace Jose\Component\Console; use InvalidArgumentException; use Jose\Component\Core\JWKSet; use Jose\Component\Core\Util\JsonConverter; use Symfony\Component\Console\Attribute\AsCommand; use Symfony\Component\Console\Input\InputArgument; use Symfony\Component\Console\Input\InputInterface; use Symfony\Component\Console\Output\OutputInterface; use function is_array; #[AsCommand(name: 'keyset:merge', description: 'Merge several key sets into one.',)] final class MergeKeysetCommand extends ObjectOutputCommand { protected static $defaultName = 'keyset:merge'; protected static $defaultDescription = 'Merge several key sets into one.'; protected function configure(): void { parent::configure(); $this->setHelp( 'This command merges several key sets into one. It is very useful when you generate e.g. RSA, EC and OKP keys and you want only one key set to rule them all.' ) ->addArgument('jwksets', InputArgument::REQUIRED | InputArgument::IS_ARRAY, 'The JWKSet objects'); } protected function execute(InputInterface $input, OutputInterface $output): int { /** @var string[] $keySets */ $keySets = $input->getArgument('jwksets'); $newJwkset = new JWKSet([]); foreach ($keySets as $keySet) { $json = JsonConverter::decode($keySet); if (! is_array($json)) { throw new InvalidArgumentException('The argument must be a valid JWKSet.'); } $jwkset = JWKSet::createFromKeyData($json); foreach ($jwkset->all() as $jwk) { $newJwkset = $newJwkset->with($jwk); } } $this->prepareJsonOutput($input, $output, $newJwkset); return self::SUCCESS; } }