feat(dav): store scopes for properties and filter locally scoped properties for federated address book sync
Signed-off-by: Anna Larch <anna@nextcloud.com>pull/38048/head
parent
fc076271c7
commit
bd80a1b2dd
@ -0,0 +1,54 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
/**
|
||||
* @copyright Copyright (c) 2023 Anna Larch <anna.larch@gmx.net>
|
||||
*
|
||||
* @author Anna Larch <anna.larch@gmx.net>
|
||||
*
|
||||
* @license GNU AGPL version 3 or any later version
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Affero General Public License as
|
||||
* published by the Free Software Foundation, either version 3 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Affero General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Affero General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*
|
||||
*/
|
||||
|
||||
namespace OCA\DAV\Migration;
|
||||
|
||||
use Closure;
|
||||
use OCA\DAV\CardDAV\SyncService;
|
||||
use OCP\DB\ISchemaWrapper;
|
||||
use OCP\Migration\IOutput;
|
||||
use OCP\Migration\SimpleMigrationStep;
|
||||
use Psr\Container\ContainerExceptionInterface;
|
||||
use Psr\Container\NotFoundExceptionInterface;
|
||||
use Psr\Log\LoggerInterface;
|
||||
|
||||
class Version1027Date20230504122946 extends SimpleMigrationStep {
|
||||
private SyncService $syncService;
|
||||
private LoggerInterface $logger;
|
||||
|
||||
public function __construct(SyncService $syncService, LoggerInterface $logger) {
|
||||
$this->syncService = $syncService;
|
||||
$this->logger = $logger;
|
||||
}
|
||||
/**
|
||||
* @param IOutput $output
|
||||
* @param Closure(): ISchemaWrapper $schemaClosure
|
||||
* @param array $options
|
||||
*/
|
||||
public function postSchemaChange(IOutput $output, Closure $schemaClosure, array $options): void {
|
||||
$this->syncService->syncInstance();
|
||||
}
|
||||
}
|
||||
@ -0,0 +1,123 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
/*
|
||||
* @copyright 2023 Christoph Wurst <christoph@winzerhof-wurst.at>
|
||||
*
|
||||
* @author 2023 Christoph Wurst <christoph@winzerhof-wurst.at>
|
||||
*
|
||||
* @license GNU AGPL version 3 or any later version
|
||||
*
|
||||
* This program is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Affero General Public License as
|
||||
* published by the Free Software Foundation, either version 3 of the
|
||||
* License, or (at your option) any later version.
|
||||
*
|
||||
* This program is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Affero General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Affero General Public License
|
||||
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
namespace OCA\DAV\Tests\unit\CardDAV;
|
||||
|
||||
use OC\AppFramework\Http\Request;
|
||||
use OCA\DAV\CardDAV\SystemAddressbook;
|
||||
use OCA\Federation\TrustedServers;
|
||||
use OCP\Accounts\IAccountManager;
|
||||
use OCP\IConfig;
|
||||
use OCP\IL10N;
|
||||
use OCP\IRequest;
|
||||
use PHPUnit\Framework\MockObject\MockObject;
|
||||
use Sabre\CardDAV\Backend\BackendInterface;
|
||||
use Sabre\VObject\Component\VCard;
|
||||
use Sabre\VObject\Reader;
|
||||
use Test\TestCase;
|
||||
|
||||
class SystemAddressBookTest extends TestCase {
|
||||
|
||||
private MockObject|BackendInterface $cardDavBackend;
|
||||
private array $addressBookInfo;
|
||||
private IL10N|MockObject $l10n;
|
||||
private IConfig|MockObject $config;
|
||||
private IRequest|MockObject $request;
|
||||
private array $server;
|
||||
private TrustedServers|MockObject $trustedServers;
|
||||
private SystemAddressbook $addressBook;
|
||||
|
||||
protected function setUp(): void {
|
||||
parent::setUp();
|
||||
|
||||
$this->cardDavBackend = $this->createMock(BackendInterface::class);
|
||||
$this->addressBookInfo = [
|
||||
'id' => 123,
|
||||
'{DAV:}displayname' => 'Accounts',
|
||||
'principaluri' => 'principals/system/system',
|
||||
];
|
||||
$this->l10n = $this->createMock(IL10N::class);
|
||||
$this->config = $this->createMock(IConfig::class);
|
||||
$this->request = $this->createMock(Request::class);
|
||||
$this->server = [
|
||||
'PHP_AUTH_USER' => 'system',
|
||||
'PHP_AUTH_PW' => 'shared123',
|
||||
];
|
||||
$this->request->method('__get')->with('server')->willReturn($this->server);
|
||||
$this->trustedServers = $this->createMock(TrustedServers::class);
|
||||
|
||||
$this->addressBook = new SystemAddressbook(
|
||||
$this->cardDavBackend,
|
||||
$this->addressBookInfo,
|
||||
$this->l10n,
|
||||
$this->config,
|
||||
$this->request,
|
||||
$this->trustedServers,
|
||||
);
|
||||
}
|
||||
|
||||
public function testGetFilteredChildForFederation(): void {
|
||||
$this->trustedServers->expects(self::once())
|
||||
->method('getServers')
|
||||
->willReturn([
|
||||
[
|
||||
'shared_secret' => 'shared123',
|
||||
],
|
||||
]);
|
||||
$vcfWithScopes = <<<VCF
|
||||
BEGIN:VCARD
|
||||
VERSION:3.0
|
||||
PRODID:-//Sabre//Sabre VObject 4.4.2//EN
|
||||
UID:admin
|
||||
FN;X-NC-SCOPE=v2-federated:admin
|
||||
N;X-NC-SCOPE=v2-federated:admin;;;;
|
||||
ADR;TYPE=OTHER;X-NC-SCOPE=v2-local:Testing test test test;;;;;;
|
||||
EMAIL;TYPE=OTHER;X-NC-SCOPE=v2-federated:miau_lalala@gmx.net
|
||||
TEL;TYPE=OTHER;X-NC-SCOPE=v2-local:+435454454544
|
||||
CLOUD:admin@http://localhost
|
||||
END:VCARD
|
||||
VCF;
|
||||
$originalCard = [
|
||||
'carddata' => $vcfWithScopes,
|
||||
];
|
||||
$this->cardDavBackend->expects(self::once())
|
||||
->method('getCard')
|
||||
->with(123, 'user.vcf')
|
||||
->willReturn($originalCard);
|
||||
|
||||
$card = $this->addressBook->getChild("user.vcf");
|
||||
|
||||
/** @var VCard $vCard */
|
||||
$vCard = Reader::read($card->get());
|
||||
foreach ($vCard->children() as $child) {
|
||||
$scope = $child->offsetGet('X-NC-SCOPE');
|
||||
if ($scope !== null) {
|
||||
self::assertNotEquals(IAccountManager::SCOPE_PRIVATE, $scope->getValue());
|
||||
self::assertNotEquals(IAccountManager::SCOPE_LOCAL, $scope->getValue());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
Loading…
Reference in New Issue