diff options
author | Mario <mario@mariovavti.com> | 2020-02-20 21:25:52 +0000 |
---|---|---|
committer | Mario <mario@mariovavti.com> | 2020-02-20 21:25:52 +0000 |
commit | 23acf02d5893233030688417d48ebd07bbd1d6cf (patch) | |
tree | 0955a5dcb37def871f4142bf446d96fab511c6fe /include/import.php | |
parent | 60311eb04bc0fa564b9fbe179eb907989ff09d8f (diff) | |
parent | b9a8b9e47b33c697ab2a5a460187ca53443bb06a (diff) | |
download | volse-hubzilla-23acf02d5893233030688417d48ebd07bbd1d6cf.tar.gz volse-hubzilla-23acf02d5893233030688417d48ebd07bbd1d6cf.tar.bz2 volse-hubzilla-23acf02d5893233030688417d48ebd07bbd1d6cf.zip |
Merge branch 'dev' of https://framagit.org/hubzilla/core into dev
Diffstat (limited to 'include/import.php')
-rw-r--r-- | include/import.php | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/include/import.php b/include/import.php index 6a3895b9f..0519052d8 100644 --- a/include/import.php +++ b/include/import.php @@ -1504,6 +1504,73 @@ function sync_files($channel, $files) { } /** + * @brief Synchronize addressbooks. + * + * @param array $channel + * @param array $data + */ +function sync_addressbook($channel, $data) { + + if(! \Zotlabs\Lib\Apps::system_app_installed($channel['channel_id'], 'CardDAV')) + return; + + logger("debug: " . print_r($data,true), LOGGER_DEBUG); + + require_once('include/cdav.php'); + + $principalUri = 'principals/' . $channel['channel_address']; + + if($data['action'] !== 'create') { + $id = get_cdav_id($principalUri, $data['uri'], 'addressbooks'); + if(! $id) + return; + } + + $pdo = \DBA::$dba->db; + + $carddavBackend = new \Sabre\CardDAV\Backend\PDO($pdo); + $addressbooks = $carddavBackend->getAddressBooksForUser($principalUri); + + switch($data['action']) { + + case 'create': + $carddavBackend->createAddressBook($principalUri, $data['uri'], $data['properties']); + break; + + case 'drop': + $carddavBackend->deleteAddressBook($id); + break; + + case 'edit': + $patch = new \Sabre\DAV\PropPatch($data['mutations']); + $carddavBackend->updateAddressBook($id, $patch); + $patch->commit(); + break; + + case 'delete_card': + $carddavBackend->deleteCard($id, $data['carduri']); + break; + + case 'update_card': + $vcard = \Sabre\VObject\Reader::read($data['card']); + $object = $vcard->convert(\Sabre\VObject\Document::VCARD40); + $cardData = $vcard->serialize(); + $carddavBackend->updateCard($id, $data['carduri'], $cardData); + break; + + case 'import': + $objects = new \Sabre\VObject\Splitter\VCard($data['card']); + $profile = \Sabre\VObject\Node::PROFILE_CARDDAV; + import_cdav_card($id, 'vcf', 'cards', 'addressbookid', $objects, $profile, $carddavBackend, $data['ids']); + break; + + default: + break; + } +} + + +/** * @brief Rename a key in an array. * * Replaces $old key with $new key in $arr. |