create('contacts_index', '/') ->actionInclude('contacts/index.php'); // ->action( // function($params){ // // // } // ); $this->create('contacts_jsconfig', 'ajax/config.js') ->actionInclude('contacts/js/config.php'); /* TODO: - Check what it requires to be a RESTful API. I think maybe {user} shouldn't be in the URI but be authenticated in headers or elsewhere. - Do security checks: logged in, csrf - Move the actual code to controllers. */ $this->create('contacts_address_books_for_user', 'addressbooks/{user}/') ->get() ->action( function($params) { session_write_close(); Main::main('AddressBookController', 'userAddressBooks', $params, new DIContainer()); } ) ->requirements(array('user')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_address_book_collection', 'addressbook/{user}/{backend}/{addressbookid}/contacts') ->get() ->action( function($params) { session_write_close(); Main::main('AddressBookController', 'getAddressBook', $params, new DIContainer()); } ) ->requirements(array('user', 'backend', 'addressbookid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_address_book_add', 'addressbook/{user}/{backend}/add') ->post() ->action( function($params) { session_write_close(); Main::main('AddressBookController', 'addAddressBook', $params, new DIContainer()); } ) ->requirements(array('user', 'backend', 'addressbookid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_address_book_delete', 'addressbook/{user}/{backend}/{addressbookid}/delete') ->post() ->action( function($params) { session_write_close(); Main::main('AddressBookController', 'deleteAddressBook', $params, new DIContainer()); } ) ->requirements(array('user', 'backend', 'addressbookid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_address_book_add_contact', 'addressbook/{user}/{backend}/{addressbookid}/contact/add') ->post() ->action( function($params) { session_write_close(); $app = new App($params['user']); $addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']); $id = $addressBook->addChild(); if($id === false) { bailOut(App::$l10n->t('Error creating contact.')); } $contact = $addressBook->getChild($id); \OCP\JSON::success(array( 'data' => Utils\JSONSerializer::serializeContact($contact), )); } ) ->requirements(array('user', 'backend', 'addressbookid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_address_book_delete_contact', 'addressbook/{user}/{backend}/{addressbookid}/contact/{contactid}/delete') ->post() ->action( function($params) { session_write_close(); $app = new App($params['user']); $addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']); $response = $addressBook->deleteChild($params['contactid']); if($response === false) { bailOut(App::$l10n->t('Error deleting contact.')); } \OCP\JSON::success(); } ) ->requirements(array('user', 'backend', 'addressbookid', 'contactid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_contact_photo', 'addressbook/{user}/{backend}/{addressbookid}/contact/{contactid}/photo') ->get() ->action( function($params) { // TODO: Cache resized photo session_write_close(); $etag = null; $caching = null; $max_size = 170; $app = new App(); $contact = $app->getContact($params['backend'], $params['addressbookid'], $params['contactid']); $image = new \OC_Image(); if (isset($contact->PHOTO) && $image->loadFromBase64((string)$contact->PHOTO)) { // OK $etag = md5($contact->PHOTO); } else // Logo :-/ if (isset($contact->LOGO) && $image->loadFromBase64((string)$contact->LOGO)) { // OK $etag = md5($contact->LOGO); } if ($image->valid()) { $modified = $contact->lastModified(); // Force refresh if modified within the last minute. if(!is_null($modified)) { $caching = (time() - $modified > 60) ? null : 0; } \OCP\Response::enableCaching($caching); if(!is_null($modified)) { \OCP\Response::setLastModifiedHeader($modified); } if($etag) { \OCP\Response::setETagHeader($etag); } if ($image->width() > $max_size || $image->height() > $max_size) { $image->resize($max_size); } header('Content-Type: ' . $image->mimeType()); $image->show(); } } ) ->requirements(array('user', 'backend', 'addressbook', 'contactid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_contact_delete_property', 'addressbook/{user}/{backend}/{addressbookid}/contact/{contactid}/property/delete') ->post() ->action( function($params) { session_write_close(); $request = Request::getRequest($params); $name = $request->post['name']; $checksum = isset($request->post['checksum']) ? $request->post['checksum'] : null; debug('contacts_contact_delete_property, name: ' . print_r($name, true)); debug('contacts_contact_delete_property, checksum: ' . print_r($checksum, true)); $app = new App($request->parameters['user']); $contact = $app->getContact( $request->parameters['backend'], $request->parameters['addressbookid'], $request->parameters['contactid'] ); if(!$contact) { bailOut(App::$l10n->t('Couldn\'t find contact.')); } if(!$name) { bailOut(App::$l10n->t('Property name is not set.')); } if(!$checksum && in_array($name, Utils\Properties::$multi_properties)) { bailOut(App::$l10n->t('Property checksum is not set.')); } if(!is_null($checksum)) { try { $contact->unsetPropertyByChecksum($checksum); } catch(Exception $e) { bailOut(App::$l10n->t('Information about vCard is incorrect. Please reload the page.')); } } else { unset($contact->{$name}); } if(!$contact->save()) { bailOut(App::$l10n->t('Error saving contact to backend.')); } \OCP\JSON::success(array( 'data' => array( 'backend' => $request->parameters['backend'], 'addressbookid' => $request->parameters['addressbookid'], 'contactid' => $request->parameters['contactid'], 'lastmodified' => $contact->lastModified(), ) )); } ) ->requirements(array('user', 'backend', 'addressbook', 'contactid')) ->defaults(array('user' => \OCP\User::getUser())); // Save a single property. $this->create('contacts_contact_save_property', 'addressbook/{user}/{backend}/{addressbookid}/contact/{contactid}/property/save') ->post() ->action( function($params) { session_write_close(); $request = Request::getRequest($params); // TODO: When value is empty unset the property and return a checksum of 'new' if multi_property $name = $request->post['name']; $value = $request->post['value']; $parameters = isset($request->post['parameters']) ? $request->post['parameters'] : null; $checksum = isset($request->post['checksum']) ? $request->post['checksum'] : null; debug('contacts_contact_save_property, name: ' . print_r($name, true)); debug('contacts_contact_save_property, value: ' . print_r($value, true)); debug('contacts_contact_save_property, parameters: ' . print_r($parameters, true)); debug('contacts_contact_save_property, checksum: ' . print_r($checksum, true)); $app = new App($params['user']); $contact = $app->getContact($params['backend'], $params['addressbookid'], $params['contactid']); $response = array('contactid' => $params['contactid']); if(!$contact) { bailOut(App::$l10n->t('Couldn\'t find contact.')); } if(!$name) { bailOut(App::$l10n->t('Property name is not set.')); } if(is_array($value)) { // NOTE: Important, otherwise the compound value will be // set in the order the fields appear in the form! ksort($value); } if(!$checksum && in_array($name, Utils\Properties::$multi_properties)) { bailOut(App::$l10n->t('Property checksum is not set.')); } elseif($checksum && in_array($name, Utils\Properties::$multi_properties)) { try { $checksum = $contact->setPropertyByChecksum($checksum, $name, $value, $parameters); $response['checksum'] = $checksum; } catch(Exception $e) { bailOut(App::$l10n->t('Information about vCard is incorrect. Please reload the page.')); } } elseif(!in_array($name, Utils\Properties::$multi_properties)) { if(!$contact->setPropertyByName($name, $value, $parameters)) { bailOut(App::$l10n->t('Error setting property')); } } if(!$contact->save()) { bailOut(App::$l10n->t('Error saving property to backend')); } $response['lastmodified'] = $contact->lastModified(); $contact->save(); \OCP\JSON::success(array('data' => $response)); } ) ->requirements(array('user', 'backend', 'addressbook', 'contactid')) ->defaults(array('user' => \OCP\User::getUser())); // Save all properties. Used for merging contacts. $this->create('contacts_contact_save_all', 'addressbook/{user}/{backend}/{addressbookid}/contact/{contactid}/save') ->post() ->action( function($params) { session_write_close(); $request = Request::getRequest($params); \OCP\Util::writeLog('contacts', __METHOD__.' params: '.print_r($request->parameters, true), \OCP\Util::DEBUG); $app = new App($params['user']); $contact = $app->getContact($params['backend'], $params['addressbookid'], $params['contactid']); $response = array('contactid' => $params['contactid']); if(!$contact) { bailOut(App::$l10n->t('Couldn\'t find contact.')); } if(!$contact->mergeFromArray($request->params)) { bailOut(App::$l10n->t('Error merging into contact.')); } if(!$contact->save()) { bailOut(App::$l10n->t('Error saving contact to backend.')); } $data = Utils\JSONSerializer::serializeContact($contact); \OCP\JSON::success(array('data' => $data)); } ) ->requirements(array('user', 'backend', 'addressbook', 'contactid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_categories_list', 'groups/{user}/') ->get() ->action( function($params) { session_write_close(); Main::main('GroupController', 'getGroups', $params, new DIContainer()); } ) ->requirements(array('user')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_categories_add', 'groups/{user}/add') ->post() ->action( function($params) { session_write_close(); Main::main('GroupController', 'addGroup', $params, new DIContainer()); } ) ->requirements(array('user')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_categories_delete', 'groups/{user}/delete') ->post() ->action( function($params) { session_write_close(); Main::main('GroupController', 'deleteGroup', $params, new DIContainer()); } ) ->requirements(array('user')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_categories_addto', 'groups/{user}/addto/{categoryid}') ->post() ->action( function($params) { session_write_close(); Main::main('GroupController', 'addToGroup', $params, new DIContainer()); } ) ->requirements(array('user', 'categoryid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_categories_removefrom', 'groups/{user}/removefrom/{categoryid}') ->post() ->action( function($params) { session_write_close(); Main::main('GroupController', 'removeFromGroup', $params, new DIContainer()); } ) ->requirements(array('user', 'categoryid')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_setpreference', 'preference/{user}/set') ->post() ->action( function($params) { session_write_close(); $request = Request::getRequest($params); $key = $request->post['key']; $value = $request->post['value']; if(is_null($key) || $key === "") { bailOut(App::$l10n->t('No key is given.')); } if(is_null($value) || $value === "") { bailOut(App::$l10n->t('No value is given.')); } if(\OCP\Config::setUserValue($params['user'], 'contacts', $key, $value)) { \OCP\JSON::success(array( 'data' => array( 'key' => $key, 'value' => $value) ) ); } else { bailOut(App::$l10n->t( 'Could not set preference: ' . $key . ':' . $value) ); } } ) ->requirements(array('user')) ->defaults(array('user' => \OCP\User::getUser())); $this->create('contacts_index_properties', 'indexproperties/{user}/') ->post() ->action( function($params) { session_write_close(); \OC_Hook::emit('OCA\Contacts', 'indexProperties', array()); \OCP\Config::setUserValue($params['user'], 'contacts', 'contacts_properties_indexed', 'yes'); \OCP\JSON::success(array('isIndexed' => true)); } ) ->requirements(array('user')) ->defaults(array('user' => \OCP\User::getUser()));