setName('twofactor_totp:cleanup') ->setDescription('Remove orphaned totp secrets'); } protected function execute(InputInterface $input, OutputInterface $output): int { $io = new SymfonyStyle($input, $output); $io->title('Remove totp secrets for deleted users'); foreach ($this->findUserIds() as $userId) { if ($this->userManager->userExists($userId) === false) { try { $io->text('Delete secret for uid "' . $userId . '"'); $this->totpSecretMapper->deleteSecretByUserId($userId); } catch (Exception $e) { $io->caution('Error deleting secret: ' . $e->getMessage()); } } } $io->success('Orphaned totp secrets removed.'); $io->text('Thank you for using Two-Factor TOTP!'); return 0; } /** * @throws Exception */ private function findUserIds(): array { $userIds = []; $qb = $this->db->getQueryBuilder() ->selectDistinct('user_id') ->from($this->totpSecretMapper->getTableName()); $result = $qb->executeQuery(); while ($row = $result->fetch()) { $userIds[] = $row['user_id']; } $result->closeCursor(); return $userIds; } }