12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 |
- <?php
- declare(strict_types=1);
- /**
- * SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-License-Identifier: AGPL-3.0-or-later
- */
- namespace OCA\DAV\Command;
- use OCA\DAV\CalDAV\CalDavBackend;
- use OCP\IUser;
- use OCP\IUserManager;
- use Symfony\Component\Console\Command\Command;
- use Symfony\Component\Console\Helper\ProgressBar;
- use Symfony\Component\Console\Input\InputArgument;
- use Symfony\Component\Console\Input\InputInterface;
- use Symfony\Component\Console\Output\OutputInterface;
- class FixCalendarSyncCommand extends Command {
- public function __construct(private IUserManager $userManager,
- private CalDavBackend $calDavBackend) {
- parent::__construct('dav:fix-missing-caldav-changes');
- }
- protected function configure(): void {
- $this->setDescription('Insert missing calendarchanges rows for existing events');
- $this->addArgument(
- 'user',
- InputArgument::OPTIONAL,
- 'User to fix calendar sync tokens for, if omitted all users will be fixed',
- null,
- );
- }
- public function execute(InputInterface $input, OutputInterface $output): int {
- $userArg = $input->getArgument('user');
- if ($userArg !== null) {
- $user = $this->userManager->get($userArg);
- if ($user === null) {
- $output->writeln("<error>User $userArg does not exist</error>");
- return 1;
- }
- $this->fixUserCalendars($user);
- } else {
- $progress = new ProgressBar($output);
- $this->userManager->callForSeenUsers(function (IUser $user) use ($progress) {
- $this->fixUserCalendars($user, $progress);
- });
- $progress->finish();
- }
- return 0;
- }
- private function fixUserCalendars(IUser $user, ?ProgressBar $progress = null): void {
- $calendars = $this->calDavBackend->getCalendarsForUser("principals/users/" . $user->getUID());
- foreach ($calendars as $calendar) {
- $this->calDavBackend->restoreChanges($calendar['id']);
- }
- if ($progress !== null) {
- $progress->advance();
- }
- }
- }
|