Skip to content

Commit

Permalink
feat(caldav): create subscriptions via occ
Browse files Browse the repository at this point in the history
Signed-off-by: Anna Larch <[email protected]>
  • Loading branch information
miaulalala committed Sep 12, 2024
1 parent 8feef45 commit 029419c
Show file tree
Hide file tree
Showing 4 changed files with 118 additions and 0 deletions.
1 change: 1 addition & 0 deletions apps/dav/appinfo/info.xml
Original file line number Diff line number Diff line change
Expand Up @@ -54,6 +54,7 @@
<commands>
<command>OCA\DAV\Command\CreateAddressBook</command>
<command>OCA\DAV\Command\CreateCalendar</command>
<command>OCA\DAV\Command\CreateSubscription</command>
<command>OCA\DAV\Command\DeleteCalendar</command>
<command>OCA\DAV\Command\FixCalendarSyncCommand</command>
<command>OCA\DAV\Command\MoveCalendar</command>
Expand Down
1 change: 1 addition & 0 deletions apps/dav/composer/composer/autoload_classmap.php
Original file line number Diff line number Diff line change
Expand Up @@ -153,6 +153,7 @@
'OCA\\DAV\\CardDAV\\Xml\\Groups' => $baseDir . '/../lib/CardDAV/Xml/Groups.php',
'OCA\\DAV\\Command\\CreateAddressBook' => $baseDir . '/../lib/Command/CreateAddressBook.php',
'OCA\\DAV\\Command\\CreateCalendar' => $baseDir . '/../lib/Command/CreateCalendar.php',
'OCA\\DAV\\Command\\CreateSubscription' => $baseDir . '/../lib/Command/CreateSubscription.php',
'OCA\\DAV\\Command\\DeleteCalendar' => $baseDir . '/../lib/Command/DeleteCalendar.php',
'OCA\\DAV\\Command\\FixCalendarSyncCommand' => $baseDir . '/../lib/Command/FixCalendarSyncCommand.php',
'OCA\\DAV\\Command\\ListCalendars' => $baseDir . '/../lib/Command/ListCalendars.php',
Expand Down
1 change: 1 addition & 0 deletions apps/dav/composer/composer/autoload_static.php
Original file line number Diff line number Diff line change
Expand Up @@ -168,6 +168,7 @@ class ComposerStaticInitDAV
'OCA\\DAV\\CardDAV\\Xml\\Groups' => __DIR__ . '/..' . '/../lib/CardDAV/Xml/Groups.php',
'OCA\\DAV\\Command\\CreateAddressBook' => __DIR__ . '/..' . '/../lib/Command/CreateAddressBook.php',
'OCA\\DAV\\Command\\CreateCalendar' => __DIR__ . '/..' . '/../lib/Command/CreateCalendar.php',
'OCA\\DAV\\Command\\CreateSubscription' => __DIR__ . '/..' . '/../lib/Command/CreateSubscription.php',
'OCA\\DAV\\Command\\DeleteCalendar' => __DIR__ . '/..' . '/../lib/Command/DeleteCalendar.php',
'OCA\\DAV\\Command\\FixCalendarSyncCommand' => __DIR__ . '/..' . '/../lib/Command/FixCalendarSyncCommand.php',
'OCA\\DAV\\Command\\ListCalendars' => __DIR__ . '/..' . '/../lib/Command/ListCalendars.php',
Expand Down
115 changes: 115 additions & 0 deletions apps/dav/lib/Command/CreateSubscription.php
Original file line number Diff line number Diff line change
@@ -0,0 +1,115 @@
<?php

declare(strict_types=1);

/**
* SPDX-FileCopyrightText: 2024 Nextcloud GmbH and Nextcloud contributors
* SPDX-License-Identifier: AGPL-3.0-only
*/
namespace OCA\DAV\Command;

use OC\KnownUser\KnownUserService;
use OCA\DAV\CalDAV\CalDavBackend;
use OCA\DAV\CalDAV\Proxy\ProxyMapper;
use OCA\DAV\CalDAV\Sharing\Backend;
use OCA\DAV\Connector\Sabre\Principal;
use OCP\Accounts\IAccountManager;
use OCP\EventDispatcher\IEventDispatcher;
use OCP\IConfig;
use OCP\IDBConnection;
use OCP\IGroupManager;
use OCP\IUserManager;
use Psr\Log\LoggerInterface;
use Sabre\DAV\Xml\Property\Href;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputArgument;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;

class CreateSubscription extends Command {
public function __construct(
protected IUserManager $userManager,
private IGroupManager $groupManager,
protected IDBConnection $dbConnection,
) {
parent::__construct();
}

protected function configure(): void {
$this
->setName('dav:create-subscription')
->setDescription('Create a dav subscription')
->addArgument('user',
InputArgument::REQUIRED,
'User for whom the subscription will be created')
->addArgument('name',
InputArgument::REQUIRED,
'Name of the subscription to create')
->addArgument('url',
InputArgument::REQUIRED,
'Source url of the subscription to create')
->addArgument('color',
InputArgument::OPTIONAL,
'Hex color code for the calendar color');
}

protected function execute(InputInterface $input, OutputInterface $output): int {
$user = $input->getArgument('user');
if (!$this->userManager->userExists($user)) {
$output->writeln("<error>User <$user> in unknown.</error>");
return self::FAILURE;
}

$name = $input->getArgument('name');
$url = $input->getArgument('url');
$color = $input->getArgument('color') ?? '#0082c9';

$principalBackend = new Principal(
$this->userManager,
$this->groupManager,
\OC::$server->get(IAccountManager::class),
\OC::$server->getShareManager(),

Check notice

Code scanning / Psalm

DeprecatedMethod Note

The method OC\Server::getShareManager has been marked as deprecated
\OC::$server->getUserSession(),

Check notice

Code scanning / Psalm

DeprecatedMethod Note

The method OC\Server::getUserSession has been marked as deprecated
\OC::$server->getAppManager(),

Check notice

Code scanning / Psalm

DeprecatedMethod Note

The method OC\Server::getAppManager has been marked as deprecated
\OC::$server->query(ProxyMapper::class),

Check notice

Code scanning / Psalm

DeprecatedMethod Note

The method OC\ServerContainer::query has been marked as deprecated
\OC::$server->get(KnownUserService::class),
\OC::$server->getConfig(),

Check notice

Code scanning / Psalm

DeprecatedMethod Note

The method OC\Server::getConfig has been marked as deprecated
\OC::$server->getL10NFactory(),

Check notice

Code scanning / Psalm

DeprecatedMethod Note

The method OC\Server::getL10NFactory has been marked as deprecated
);
$random = \OC::$server->getSecureRandom();

Check notice

Code scanning / Psalm

DeprecatedMethod Note

The method OC\Server::getSecureRandom has been marked as deprecated
$logger = \OC::$server->get(LoggerInterface::class);
$dispatcher = \OC::$server->get(IEventDispatcher::class);
$config = \OC::$server->get(IConfig::class);
$caldav = new CalDavBackend(
$this->dbConnection,
$principalBackend,
$this->userManager,
$random,
$logger,
$dispatcher,
$config,
\OC::$server->get(Backend::class),
);

$subscriptions = $caldav->getSubscriptionsForUser("principals/users/$user");

$exists = array_filter($subscriptions, function ($row) use ($url) {
return $row['source'] === $url;
});

if (!empty($exists)) {
$output->writeln("<error>Subscription for url <$url> already exists for this user.</error>");
return self::FAILURE;
}

$urlProperty = new Href($url);
$properties = ['{http://owncloud.org/ns}calendar-enabled' => 1,
'{DAV:}displayname' => $name,
'{http://apple.com/ns/ical/}calendar-color' => $color,
'{http://calendarserver.org/ns/}source' => $urlProperty,
];
$caldav->createSubscription("principals/users/$user", $name, $properties);
return self::SUCCESS;
}

}

0 comments on commit 029419c

Please sign in to comment.