setName('user:auth-tokens:list') ->setDescription('List authentication tokens of an user') ->addArgument( 'user', InputArgument::REQUIRED, 'User to list auth tokens for' ); } protected function execute(InputInterface $input, OutputInterface $output): int { $user = $this->userManager->get($input->getArgument('user')); if (is_null($user)) { $output->writeln('user not found'); return 1; } $tokens = $this->tokenProvider->getTokenByUser($user->getUID()); $tokens = array_map(function (IToken $token) use ($input): mixed { $sensitive = [ 'password', 'password_hash', 'token', 'public_key', 'private_key', ]; $data = array_diff_key($token->jsonSerialize(), array_flip($sensitive)); if ($input->getOption('output') === self::OUTPUT_FORMAT_PLAIN) { $data = $this->formatTokenForPlainOutput($data); } return $data; }, $tokens); $this->writeTableInOutputFormat($input, $output, $tokens); return 0; } public function formatTokenForPlainOutput(array $token): array { $token['scope'] = implode(', ', array_keys(array_filter($token['scope'] ?? []))); $token['lastActivity'] = date(DATE_ATOM, $token['lastActivity']); $token['type'] = match ($token['type']) { IToken::TEMPORARY_TOKEN => 'temporary', IToken::PERMANENT_TOKEN => 'permanent', IToken::WIPE_TOKEN => 'wipe', default => $token['type'], }; return $token; } }