From 813406322bd6b972a78ab388d5d685f60ea5009a Mon Sep 17 00:00:00 2001 From: Joas Schilling Date: Wed, 13 Mar 2024 10:24:22 +0100 Subject: fix: Use IUserManager::callForAllUsers() to save memory Signed-off-by: Joas Schilling --- core/Command/User/LastSeen.php | 31 ++++++++++++++++++++++++++----- 1 file changed, 26 insertions(+), 5 deletions(-) (limited to 'core/Command/User') diff --git a/core/Command/User/LastSeen.php b/core/Command/User/LastSeen.php index 8a47ad8837a..d78d8661ecf 100644 --- a/core/Command/User/LastSeen.php +++ b/core/Command/User/LastSeen.php @@ -59,7 +59,7 @@ class LastSeen extends Base { ; } - protected function execute(InputInterface $input, OutputInterface $output): int { + protected function execute(InputInterface $input, OutputInterface $output): int { $singleUserId = $input->getArgument('uid'); if ($singleUserId) { $user = $this->userManager->get($singleUserId); @@ -67,13 +67,34 @@ class LastSeen extends Base { $output->writeln('User does not exist'); return 1; } - $users = [$user]; - } elseif ($input->getOption('all')) { - $users = $this->userManager->search(''); - } else { + + $lastLogin = $user->getLastLogin(); + if ($lastLogin === 0) { + $output->writeln($user->getUID() . ' has never logged in.'); + } else { + $date = new \DateTime(); + $date->setTimestamp($lastLogin); + $output->writeln($user->getUID() . "'s last login: " . $date->format('Y-m-d H:i')); + } + + return 0; + } + + if (!$input->getOption('all')) { $output->writeln("Please specify a username, or \"--all\" to list all"); return 1; } + + $this->userManager->callForAllUsers(static function (IUser $user) use ($output) { + $lastLogin = $user->getLastLogin(); + if ($lastLogin === 0) { + $output->writeln($user->getUID() . ' has never logged in.'); + } else { + $date = new \DateTime(); + $date->setTimestamp($lastLogin); + $output->writeln($user->getUID() . "'s last login: " . $date->format('Y-m-d H:i')); + } + }); return 0; } -- cgit v1.2.3