2013-04-18 01:12:04 +02:00
|
|
|
<?php
|
|
|
|
/**
|
|
|
|
* @author Thomas Tanghus
|
|
|
|
* Copyright (c) 2013 Thomas Tanghus (thomas@tanghus.net)
|
|
|
|
* This file is licensed under the Affero General Public License version 3 or
|
|
|
|
* later.
|
|
|
|
* See the COPYING-README file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
namespace OCA\Contacts\Controller;
|
|
|
|
|
2013-05-24 20:35:23 +02:00
|
|
|
use OCA\Contacts\App,
|
|
|
|
OCA\Contacts\JSONResponse,
|
|
|
|
OCA\Contacts\Utils\JSONSerializer,
|
|
|
|
OCA\AppFramework\Controller\Controller as BaseController,
|
|
|
|
OCA\AppFramework\Http\TextDownloadResponse;
|
2013-04-18 01:12:04 +02:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
2013-04-24 23:36:54 +02:00
|
|
|
* Controller class For Address Books
|
2013-04-18 01:12:04 +02:00
|
|
|
*/
|
|
|
|
class AddressBookController extends BaseController {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function userAddressBooks() {
|
2013-04-25 04:21:14 +02:00
|
|
|
$app = new App($this->api->getUserId());
|
2013-04-18 01:12:04 +02:00
|
|
|
$addressBooks = $app->getAddressBooksForUser();
|
|
|
|
$response = array();
|
2013-09-10 07:17:05 +02:00
|
|
|
$lastModified = 0;
|
2013-04-18 01:12:04 +02:00
|
|
|
foreach($addressBooks as $addressBook) {
|
2013-09-10 07:17:05 +02:00
|
|
|
$data = $addressBook->getMetaData();
|
|
|
|
$response[] = $data;
|
|
|
|
if(!is_null($data['lastmodified'])) {
|
|
|
|
$lastModified = max($lastModified, $data['lastmodified']);
|
|
|
|
}
|
2013-04-18 01:12:04 +02:00
|
|
|
}
|
2013-09-10 07:17:05 +02:00
|
|
|
|
|
|
|
$response = new JSONResponse(array(
|
2013-04-18 01:12:04 +02:00
|
|
|
'addressbooks' => $response,
|
2013-04-19 09:59:30 +02:00
|
|
|
));
|
2013-09-10 07:17:05 +02:00
|
|
|
|
|
|
|
if($lastModified > 0) {
|
|
|
|
$response->setLastModified(\DateTime::createFromFormat('U', $lastModified) ?: null);
|
|
|
|
$response->setETag(md5($lastModified));
|
|
|
|
}
|
|
|
|
|
2013-04-19 09:59:30 +02:00
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function getAddressBook() {
|
2013-05-24 20:35:23 +02:00
|
|
|
\OCP\Util::writeLog('contacts', __METHOD__, \OCP\Util::DEBUG);
|
2013-04-19 09:59:30 +02:00
|
|
|
$params = $this->request->urlParams;
|
2013-04-25 04:21:14 +02:00
|
|
|
$app = new App($this->api->getUserId());
|
2013-04-19 09:59:30 +02:00
|
|
|
|
|
|
|
$addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
|
|
|
$lastModified = $addressBook->lastModified();
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
|
|
|
if(!is_null($lastModified)) {
|
2013-09-06 06:15:23 +02:00
|
|
|
//$response->addHeader('Cache-Control', 'private, must-revalidate');
|
2013-05-09 05:59:57 +02:00
|
|
|
$response->setLastModified(\DateTime::createFromFormat('U', $lastModified) ?: null);
|
2013-04-24 23:36:54 +02:00
|
|
|
$response->setETag(md5($lastModified));
|
2013-04-19 09:59:30 +02:00
|
|
|
}
|
|
|
|
|
2013-09-06 06:15:23 +02:00
|
|
|
$response->debug('method: ' . $this->request->method);
|
2013-05-27 08:04:06 +02:00
|
|
|
if($this->request->method === 'GET') {
|
|
|
|
$contacts = array();
|
|
|
|
foreach($addressBook->getChildren() as $i => $contact) {
|
|
|
|
$result = JSONSerializer::serializeContact($contact);
|
|
|
|
if($result !== null) {
|
|
|
|
$contacts[] = $result;
|
|
|
|
}
|
2013-04-19 09:59:30 +02:00
|
|
|
}
|
2013-05-27 08:04:06 +02:00
|
|
|
$response->setParams(array('contacts' => $contacts));
|
2013-04-19 09:59:30 +02:00
|
|
|
}
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-05-24 20:35:23 +02:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @CSRFExemption
|
|
|
|
*/
|
|
|
|
public function exportAddressBook() {
|
|
|
|
\OCP\Util::writeLog('contacts', __METHOD__, \OCP\Util::DEBUG);
|
|
|
|
$params = $this->request->urlParams;
|
|
|
|
$app = new App($this->api->getUserId());
|
|
|
|
|
|
|
|
$addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
|
|
|
$lastModified = $addressBook->lastModified();
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
|
|
|
if(!is_null($lastModified)) {
|
|
|
|
$response->addHeader('Cache-Control', 'private, must-revalidate');
|
|
|
|
$response->setLastModified(\DateTime::createFromFormat('U', $lastModified) ?: null);
|
|
|
|
$response->setETag(md5($lastModified));
|
|
|
|
}
|
|
|
|
|
|
|
|
$contacts = '';
|
|
|
|
foreach($addressBook->getChildren() as $i => $contact) {
|
|
|
|
$contacts .= $contact->serialize() . "\r\n";
|
|
|
|
}
|
|
|
|
$name = str_replace(' ', '_', $addressBook->getDisplayName()) . '.vcf';
|
|
|
|
return new TextDownloadResponse($contacts, $name, 'text/directory');
|
|
|
|
}
|
|
|
|
|
2013-04-19 09:59:30 +02:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function addAddressBook() {
|
2013-04-25 04:21:14 +02:00
|
|
|
$app = new App($this->api->getUserId());
|
2013-05-27 07:56:55 +02:00
|
|
|
$params = $this->request->urlParams;
|
2013-04-19 09:59:30 +02:00
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
2013-05-27 07:56:55 +02:00
|
|
|
$backend = $app->getBackend($params['backend']);
|
2013-05-05 22:23:11 +02:00
|
|
|
if(!$backend->hasAddressBookMethodFor(\OCP\PERMISSION_CREATE)) {
|
|
|
|
throw new \Exception('Not implemented');
|
|
|
|
}
|
2013-08-26 20:10:29 +02:00
|
|
|
try {
|
|
|
|
$id = $backend->createAddressBook($this->request->post);
|
|
|
|
} catch(Exception $e) {
|
|
|
|
$response->bailOut($e->getMessage());
|
|
|
|
return $response;
|
|
|
|
}
|
2013-04-19 09:59:30 +02:00
|
|
|
if($id === false) {
|
|
|
|
$response->bailOut(App::$l10n->t('Error creating address book'));
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-05-10 02:18:31 +02:00
|
|
|
$response->setStatus('201');
|
2013-04-19 09:59:30 +02:00
|
|
|
$response->setParams($backend->getAddressBook($id));
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-05-07 19:16:06 +02:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function updateAddressBook() {
|
|
|
|
$params = $this->request->urlParams;
|
|
|
|
$app = new App($this->api->getUserId());
|
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
2013-05-18 06:57:38 +02:00
|
|
|
$addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
2013-08-26 20:10:29 +02:00
|
|
|
try {
|
|
|
|
if(!$addressBook->update($this->request['properties'])) {
|
|
|
|
$response->bailOut(App::$l10n->t('Error updating address book'));
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
} catch(Exception $e) {
|
|
|
|
$response->bailOut($e->getMessage());
|
2013-05-22 03:37:56 +02:00
|
|
|
return $response;
|
2013-05-07 19:16:06 +02:00
|
|
|
}
|
2013-05-18 06:57:38 +02:00
|
|
|
$response->setParams($addressBook->getMetaData());
|
2013-05-07 19:16:06 +02:00
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-04-19 09:59:30 +02:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function deleteAddressBook() {
|
|
|
|
$params = $this->request->urlParams;
|
2013-04-25 04:21:14 +02:00
|
|
|
$app = new App($this->api->getUserId());
|
2013-04-19 09:59:30 +02:00
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
2013-05-27 07:56:55 +02:00
|
|
|
$backend = $app->getBackend($params['backend']);
|
2013-08-26 20:10:29 +02:00
|
|
|
|
2013-05-05 22:23:11 +02:00
|
|
|
if(!$backend->hasAddressBookMethodFor(\OCP\PERMISSION_DELETE)) {
|
2013-08-26 20:10:29 +02:00
|
|
|
throw new \Exception(
|
|
|
|
'The "%s" backend does not support deleting address books', array($backend->name)
|
|
|
|
);
|
2013-05-05 22:23:11 +02:00
|
|
|
}
|
2013-08-26 20:10:29 +02:00
|
|
|
|
|
|
|
$addressBookInfo = $backend->getAddressBook($params['addressbookid']);
|
|
|
|
|
|
|
|
if(!$addressBookInfo['permissions'] & \OCP\PERMISSION_DELETE) {
|
|
|
|
$response->bailOut(App::$l10n->t(
|
|
|
|
'You do not have permissions to delete the "%s" address book'),
|
|
|
|
array($addressBookInfo['displayname']
|
|
|
|
));
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-04-19 09:59:30 +02:00
|
|
|
if(!$backend->deleteAddressBook($params['addressbookid'])) {
|
|
|
|
$response->bailOut(App::$l10n->t('Error deleting address book'));
|
2013-05-22 03:37:56 +02:00
|
|
|
return $response;
|
2013-04-19 09:59:30 +02:00
|
|
|
}
|
|
|
|
return $response;
|
2013-04-18 01:12:04 +02:00
|
|
|
}
|
2013-04-24 23:36:54 +02:00
|
|
|
|
2013-09-05 22:07:40 +02:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function activateAddressBook() {
|
|
|
|
$params = $this->request->urlParams;
|
|
|
|
$app = new App($this->api->getUserId());
|
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
|
|
|
$addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
|
|
|
|
|
|
|
$addressBook->setActive($this->request->post['state']);
|
|
|
|
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-04-24 23:36:54 +02:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function addChild() {
|
|
|
|
$params = $this->request->urlParams;
|
2013-04-25 04:21:14 +02:00
|
|
|
$app = new App($this->api->getUserId());
|
2013-04-24 23:36:54 +02:00
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
|
|
|
$addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
2013-08-26 20:10:29 +02:00
|
|
|
|
|
|
|
try {
|
|
|
|
$id = $addressBook->addChild();
|
|
|
|
} catch(Exception $e) {
|
|
|
|
$response->bailOut($e->getMessage());
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-04-24 23:36:54 +02:00
|
|
|
if($id === false) {
|
|
|
|
$response->bailOut(App::$l10n->t('Error creating contact.'));
|
2013-05-22 03:37:56 +02:00
|
|
|
return $response;
|
2013-04-24 23:36:54 +02:00
|
|
|
}
|
2013-08-26 20:10:29 +02:00
|
|
|
|
2013-04-24 23:36:54 +02:00
|
|
|
$contact = $addressBook->getChild($id);
|
2013-05-10 02:18:31 +02:00
|
|
|
$response->setStatus('201');
|
|
|
|
$response->setETag($contact->getETag());
|
|
|
|
$response->addHeader('Location',
|
|
|
|
\OCP\Util::linkToRoute(
|
|
|
|
'contacts_contact_get',
|
|
|
|
array(
|
|
|
|
'backend' => $params['backend'],
|
|
|
|
'addressbookid' => $params['addressbookid'],
|
|
|
|
'contactid' => $id
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
2013-05-04 22:48:30 +02:00
|
|
|
$response->setParams(JSONSerializer::serializeContact($contact));
|
2013-04-24 23:36:54 +02:00
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function deleteChild() {
|
|
|
|
$params = $this->request->urlParams;
|
2013-04-25 04:21:14 +02:00
|
|
|
$app = new App($this->api->getUserId());
|
2013-04-24 23:36:54 +02:00
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
|
|
|
$addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
2013-08-26 20:10:29 +02:00
|
|
|
|
|
|
|
try {
|
|
|
|
$result = $addressBook->deleteChild($params['contactid']);
|
|
|
|
} catch(Exception $e) {
|
|
|
|
$response->bailOut($e->getMessage());
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-04-24 23:36:54 +02:00
|
|
|
if($result === false) {
|
|
|
|
$response->bailOut(App::$l10n->t('Error deleting contact.'));
|
|
|
|
}
|
2013-09-03 14:08:12 +02:00
|
|
|
$response->setStatus('204');
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function deleteChildren() {
|
|
|
|
$params = $this->request->urlParams;
|
|
|
|
$app = new App($this->api->getUserId());
|
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
|
|
|
$addressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
|
|
|
$contacts = $this->request->post['contacts'];
|
|
|
|
|
|
|
|
try {
|
|
|
|
$result = $addressBook->deleteChildren($contacts);
|
|
|
|
} catch(Exception $e) {
|
|
|
|
$response->bailOut($e->getMessage());
|
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
|
|
|
$response->setParams(array('result' => $result));
|
2013-04-24 23:36:54 +02:00
|
|
|
return $response;
|
|
|
|
}
|
|
|
|
|
2013-05-06 01:49:10 +02:00
|
|
|
/**
|
|
|
|
* @IsAdminExemption
|
|
|
|
* @IsSubAdminExemption
|
|
|
|
* @Ajax
|
|
|
|
*/
|
|
|
|
public function moveChild() {
|
|
|
|
$params = $this->request->urlParams;
|
|
|
|
$targetInfo = $this->request->post['target'];
|
|
|
|
$app = new App($this->api->getUserId());
|
|
|
|
|
|
|
|
$response = new JSONResponse();
|
|
|
|
|
2013-05-22 03:20:36 +02:00
|
|
|
// TODO: Check if the backend supports move (is 'local' or 'shared') and use that operation instead.
|
|
|
|
// If so, set status 204 and don't return the serialized contact.
|
2013-05-06 01:49:10 +02:00
|
|
|
$fromAddressBook = $app->getAddressBook($params['backend'], $params['addressbookid']);
|
|
|
|
$targetAddressBook = $app->getAddressBook($targetInfo['backend'], $targetInfo['id']);
|
|
|
|
$contact = $fromAddressBook->getChild($params['contactid']);
|
|
|
|
if(!$contact) {
|
|
|
|
$response->bailOut(App::$l10n->t('Error retrieving contact.'));
|
2013-05-22 03:37:56 +02:00
|
|
|
return $response;
|
2013-05-06 01:49:10 +02:00
|
|
|
}
|
2013-08-26 20:10:29 +02:00
|
|
|
try {
|
|
|
|
$contactid = $targetAddressBook->addChild($contact);
|
|
|
|
} catch(Exception $e) {
|
|
|
|
$response->bailOut($e->getMessage());
|
|
|
|
return $response;
|
|
|
|
}
|
2013-05-06 01:49:10 +02:00
|
|
|
$contact = $targetAddressBook->getChild($contactid);
|
|
|
|
if(!$contact) {
|
|
|
|
$response->bailOut(App::$l10n->t('Error saving contact.'));
|
2013-05-22 03:37:56 +02:00
|
|
|
return $response;
|
2013-05-06 01:49:10 +02:00
|
|
|
}
|
2013-05-22 03:20:36 +02:00
|
|
|
if(!$fromAddressBook->deleteChild($params['contactid'])) {
|
2013-05-06 01:49:10 +02:00
|
|
|
// Don't bail out because we have to return the contact
|
|
|
|
$response->debug(App::$l10n->t('Error removing contact from other address book.'));
|
|
|
|
}
|
|
|
|
$response->setParams(JSONSerializer::serializeContact($contact));
|
|
|
|
return $response;
|
|
|
|
}
|
2013-04-24 23:36:54 +02:00
|
|
|
|
2013-04-18 01:12:04 +02:00
|
|
|
}
|
2013-04-19 09:59:30 +02:00
|
|
|
|