setName('user:keys:verify') ->setDescription('Verify if the stored public key matches the stored private key') ->addArgument( 'user-id', InputArgument::REQUIRED, 'User ID of the user to verify' ) ; } /** * @param InputInterface $input * @param OutputInterface $output * @return int */ protected function execute(InputInterface $input, OutputInterface $output): int { $userId = $input->getArgument('user-id'); $user = $this->userManager->get($userId); if (!$user instanceof IUser) { $output->writeln('Unknown user'); return static::FAILURE; } $key = $this->keyManager->getKey($user); $publicKey = $key->getPublic(); $privateKey = $key->getPrivate(); $output->writeln('User public key size: ' . strlen($publicKey)); $output->writeln('User private key size: ' . strlen($privateKey)); // Derive the public key from the private key again to validate the stored public key $opensslPrivateKey = openssl_pkey_get_private($privateKey); $publicKeyDerived = openssl_pkey_get_details($opensslPrivateKey); $publicKeyDerived = $publicKeyDerived['key']; $output->writeln('User derived public key size: ' . strlen($publicKeyDerived)); $output->writeln(''); $output->writeln('Stored public key:'); $output->writeln($publicKey); $output->writeln('Derived public key:'); $output->writeln($publicKeyDerived); if ($publicKey != $publicKeyDerived) { $output->writeln('Stored public key does not match stored private key'); return static::FAILURE; } $output->writeln('Stored public key matches stored private key'); return static::SUCCESS; } }