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