summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorcall-me-matt <nextcloud@matthiasheinisch.de>2020-10-09 16:27:41 +0200
committercall-me-matt <nextcloud@matthiasheinisch.de>2020-10-12 21:27:38 +0200
commit1b2386d10850f570ff6352f6847f293dd399b307 (patch)
tree5b1d001ade064f301b1392e27663a9c496c7985e
parent0dbb99a81bc39cee97f6644faef5bec24881b69c (diff)
downloadnextcloud-server-1b2386d10850f570ff6352f6847f293dd399b307.tar.gz
nextcloud-server-1b2386d10850f570ff6352f6847f293dd399b307.zip
handle nested properties, fixes #20544
Signed-off-by: call-me-matt <nextcloud@matthiasheinisch.de>
-rw-r--r--apps/dav/lib/CardDAV/AddressBookImpl.php17
-rw-r--r--apps/dav/tests/unit/CardDAV/AddressBookImplTest.php39
2 files changed, 54 insertions, 2 deletions
diff --git a/apps/dav/lib/CardDAV/AddressBookImpl.php b/apps/dav/lib/CardDAV/AddressBookImpl.php
index 1c35e2c400c..785ec2b7a01 100644
--- a/apps/dav/lib/CardDAV/AddressBookImpl.php
+++ b/apps/dav/lib/CardDAV/AddressBookImpl.php
@@ -146,7 +146,22 @@ class AddressBookImpl implements IAddressBook {
}
foreach ($properties as $key => $value) {
- $vCard->$key = $vCard->createProperty($key, $value);
+ if (is_array($value)) {
+ $vCard->remove($key);
+ foreach ($value as $entry) {
+ if (($key === "ADR" || $key === "PHOTO") && is_string($entry["value"])) {
+ $entry["value"] = stripslashes($entry["value"]);
+ $entry["value"] = explode(';', $entry["value"]);
+ }
+ $property = $vCard->createProperty($key, $entry["value"]);
+ if (isset($entry["type"])) {
+ $property->add('TYPE', $entry["type"]);
+ }
+ $vCard->add($property);
+ }
+ } elseif ($key !== 'URI') {
+ $vCard->$key = $vCard->createProperty($key, $value);
+ }
}
if ($update) {
diff --git a/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php b/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php
index 67748cc0883..9261dc4057b 100644
--- a/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php
+++ b/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php
@@ -10,6 +10,7 @@
* @author Morris Jobke <hey@morrisjobke.de>
* @author Roeland Jago Douma <roeland@famdouma.nl>
* @author Thomas Müller <thomas.mueller@tmit.eu>
+ * @author Matthias Heinisch <nextcloud@matthiasheinisch.de>
*
* @license AGPL-3.0
*
@@ -35,6 +36,7 @@ use OCA\DAV\CardDAV\CardDavBackend;
use OCP\IURLGenerator;
use Sabre\VObject\Component\VCard;
use Sabre\VObject\Property\Text;
+//use Sabre\VObject\Property\;
use Test\TestCase;
class AddressBookImplTest extends TestCase {
@@ -199,7 +201,7 @@ class AddressBookImplTest extends TestCase {
->willReturn(['carddata' => 'data']);
$addressBookImpl->expects($this->once())->method('readCard')
->with('data')->willReturn($this->vCard);
- $this->vCard->expects($this->exactly(count($properties)))
+ $this->vCard->expects($this->exactly(count($properties)-1))
->method('createProperty');
$this->backend->expects($this->never())->method('createCard');
$this->backend->expects($this->once())->method('updateCard');
@@ -209,6 +211,41 @@ class AddressBookImplTest extends TestCase {
$this->assertTrue($addressBookImpl->createOrUpdate($properties));
}
+ public function testUpdateWithTypes() {
+ $uid = 'uid';
+ $uri = 'bla.vcf';
+ $properties = ['URI' => $uri, 'UID' => $uid, 'FN' => 'John Doe', 'ADR' => [['type' => 'HOME', 'value' => ';;street;city;;;country']]];
+ $vCard = new vCard;
+ $textProperty = $vCard->createProperty('KEY','value');
+
+ /** @var \PHPUnit\Framework\MockObject\MockObject | AddressBookImpl $addressBookImpl */
+ $addressBookImpl = $this->getMockBuilder(AddressBookImpl::class)
+ ->setConstructorArgs(
+ [
+ $this->addressBook,
+ $this->addressBookInfo,
+ $this->backend,
+ $this->urlGenerator,
+ ]
+ )
+ ->setMethods(['vCard2Array', 'createUid', 'createEmptyVCard', 'readCard'])
+ ->getMock();
+
+ $this->backend->expects($this->once())->method('getCard')
+ ->with($this->addressBookInfo['id'], $uri)
+ ->willReturn(['carddata' => 'data']);
+ $addressBookImpl->expects($this->once())->method('readCard')
+ ->with('data')->willReturn($this->vCard);
+ $this->vCard->method('createProperty')->willReturn($textProperty);
+ $this->vCard->expects($this->exactly(count($properties)-1))
+ ->method('createProperty');
+ $this->vCard->expects($this->once())->method('remove')
+ ->with('ADR');
+ $this->vCard->expects($this->once())->method('add');
+
+ $addressBookImpl->createOrUpdate($properties);
+ }
+
/**
* @dataProvider dataTestGetPermissions
*