summaryrefslogtreecommitdiffstats
path: root/apps/dav
diff options
context:
space:
mode:
authorJohn Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>2020-04-17 09:12:06 +0200
committerJohn Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>2020-04-17 13:02:21 +0200
commit8f160bf02aa8fe68b7f2cad75607ba8ef8dfe259 (patch)
tree2df955338fdb6c2fcc31944745f954738a9f5aba /apps/dav
parent0856745a47da96ff4839f7391e6a1c573f560014 (diff)
downloadnextcloud-server-8f160bf02aa8fe68b7f2cad75607ba8ef8dfe259.tar.gz
nextcloud-server-8f160bf02aa8fe68b7f2cad75607ba8ef8dfe259.zip
Update list of multiple properties
Signed-off-by: John Molakvoæ (skjnldsv) <skjnldsv@protonmail.com>
Diffstat (limited to 'apps/dav')
-rw-r--r--apps/dav/lib/CardDAV/AddressBookImpl.php24
-rw-r--r--apps/dav/tests/unit/CardDAV/AddressBookImplTest.php87
2 files changed, 89 insertions, 22 deletions
diff --git a/apps/dav/lib/CardDAV/AddressBookImpl.php b/apps/dav/lib/CardDAV/AddressBookImpl.php
index 7ced2e90561..5e355611c11 100644
--- a/apps/dav/lib/CardDAV/AddressBookImpl.php
+++ b/apps/dav/lib/CardDAV/AddressBookImpl.php
@@ -65,7 +65,6 @@ class AddressBookImpl implements IAddressBook {
array $addressBookInfo,
CardDavBackend $backend,
IURLGenerator $urlGenerator) {
-
$this->addressBook = $addressBook;
$this->addressBookInfo = $addressBookInfo;
$this->backend = $backend;
@@ -156,7 +155,6 @@ class AddressBookImpl implements IAddressBook {
}
return $this->vCard2Array($uri, $vCard);
-
}
/**
@@ -167,7 +165,7 @@ class AddressBookImpl implements IAddressBook {
$permissions = $this->addressBook->getACL();
$result = 0;
foreach ($permissions as $permission) {
- switch($permission['privilege']) {
+ switch ($permission['privilege']) {
case '{DAV:}read':
$result |= Constants::PERMISSION_READ;
break;
@@ -242,6 +240,7 @@ class AddressBookImpl implements IAddressBook {
*
* @param string $uri
* @param VCard $vCard
+ * @param boolean $withTypes (optional) return the values as arrays of value/type pairs
* @return array
*/
protected function vCard2Array($uri, VCard $vCard, $withTypes = false) {
@@ -261,20 +260,7 @@ class AddressBookImpl implements IAddressBook {
]) . '?photo';
$result['PHOTO'] = 'VALUE=uri:' . $url;
-
- } else if ($property->name === 'X-SOCIALPROFILE') {
- $type = $this->getTypeFromProperty($property);
-
- // Type is the social network, when it's empty we don't need this.
- if ($type !== null) {
- if (!isset($result[$property->name])) {
- $result[$property->name] = [];
- }
- $result[$property->name][$type] = $property->getValue();
- }
-
- // The following properties can be set multiple times
- } else if (in_array($property->name, ['CLOUD', 'EMAIL', 'IMPP', 'TEL', 'URL', 'X-ADDRESSBOOKSERVER-MEMBER'])) {
+ } elseif (in_array($property->name, ['URL', 'GEO', 'CLOUD', 'ADR', 'EMAIL', 'IMPP', 'TEL', 'X-SOCIALPROFILE', 'RELATED', 'LANG', 'X-ADDRESSBOOKSERVER-MEMBER'])) {
if (!isset($result[$property->name])) {
$result[$property->name] = [];
}
@@ -284,12 +270,10 @@ class AddressBookImpl implements IAddressBook {
$result[$property->name][] = [
'type' => $type,
'value' => $property->getValue()
- ];
+ ];
} else {
$result[$property->name][] = $property->getValue();
}
-
-
} else {
$result[$property->name] = $property->getValue();
}
diff --git a/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php b/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php
index 67c96259c60..48860a84fc3 100644
--- a/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php
+++ b/apps/dav/tests/unit/CardDAV/AddressBookImplTest.php
@@ -325,6 +325,9 @@ class AddressBookImplTest extends TestCase {
$property = $vCard->createProperty('X-SOCIALPROFILE', 'tw-example');
$property->add('TYPE', 'twitter');
$vCard->add($property);
+ $property = $vCard->createProperty('X-SOCIALPROFILE', 'tw-example-2');
+ $property->add('TYPE', 'twitter');
+ $vCard->add($property);
$property = $vCard->createProperty('X-SOCIALPROFILE', 'fb-example');
$property->add('TYPE', 'facebook');
$vCard->add($property);
@@ -359,8 +362,88 @@ class AddressBookImplTest extends TestCase {
],
'X-SOCIALPROFILE' => [
- 'twitter'=> 'tw-example',
- 'facebook'=> 'fb-example',
+ 'tw-example',
+ 'tw-example-2',
+ 'fb-example',
+ ],
+
+ 'isLocalSystemBook' => true,
+ ], $array);
+ }
+
+ public function testVCard2ArrayWithTypes() {
+ $vCard = new VCard();
+
+ $vCard->add($vCard->createProperty('FN', 'Full Name'));
+
+ // Multi-value properties
+ $vCard->add($vCard->createProperty('CLOUD', 'cloud-user1@localhost'));
+ $vCard->add($vCard->createProperty('CLOUD', 'cloud-user2@example.tld'));
+
+ $property = $vCard->createProperty('EMAIL', 'email-user1@localhost');
+ $property->add('TYPE', 'HOME');
+ $vCard->add($property);
+ $property = $vCard->createProperty('EMAIL', 'email-user2@example.tld');
+ $property->add('TYPE', 'WORK');
+ $vCard->add($property);
+
+ $vCard->add($vCard->createProperty('IMPP', 'impp-user1@localhost'));
+ $vCard->add($vCard->createProperty('IMPP', 'impp-user2@example.tld'));
+
+ $property = $vCard->createProperty('TEL', '+49 123456789');
+ $property->add('TYPE', 'HOME,VOICE');
+ $vCard->add($property);
+ $property = $vCard->createProperty('TEL', '+1 555 123456789');
+ $property->add('TYPE', 'WORK');
+ $vCard->add($property);
+
+ $vCard->add($vCard->createProperty('URL', 'https://localhost'));
+ $vCard->add($vCard->createProperty('URL', 'https://example.tld'));
+
+ // Type depending properties
+ $property = $vCard->createProperty('X-SOCIALPROFILE', 'tw-example');
+ $property->add('TYPE', 'twitter');
+ $vCard->add($property);
+ $property = $vCard->createProperty('X-SOCIALPROFILE', 'tw-example-2');
+ $property->add('TYPE', 'twitter');
+ $vCard->add($property);
+ $property = $vCard->createProperty('X-SOCIALPROFILE', 'fb-example');
+ $property->add('TYPE', 'facebook');
+ $vCard->add($property);
+
+ $array = $this->invokePrivate($this->addressBookImpl, 'vCard2Array', ['uri', $vCard, true]);
+ unset($array['PRODID']);
+ unset($array['UID']);
+
+ $this->assertEquals([
+ 'URI' => 'uri',
+ 'VERSION' => '4.0',
+ 'FN' => 'Full Name',
+ 'CLOUD' => [
+ ['type' => '', 'value' => 'cloud-user1@localhost'],
+ ['type' => '', 'value' => 'cloud-user2@example.tld'],
+ ],
+ 'EMAIL' => [
+ ['type' => 'HOME', 'value' => 'email-user1@localhost'],
+ ['type' => 'WORK', 'value' => 'email-user2@example.tld'],
+ ],
+ 'IMPP' => [
+ ['type' => '', 'value' => 'impp-user1@localhost'],
+ ['type' => '', 'value' => 'impp-user2@example.tld'],
+ ],
+ 'TEL' => [
+ ['type' => 'HOME,VOICE', 'value' => '+49 123456789'],
+ ['type' => 'WORK', 'value' => '+1 555 123456789'],
+ ],
+ 'URL' => [
+ ['type' => '', 'value' => 'https://localhost'],
+ ['type' => '', 'value' => 'https://example.tld'],
+ ],
+
+ 'X-SOCIALPROFILE' => [
+ ['type' => 'twitter', 'value' => 'tw-example'],
+ ['type' => 'twitter', 'value' => 'tw-example-2'],
+ ['type' => 'facebook', 'value' => 'fb-example'],
],
'isLocalSystemBook' => true,