1
0
mirror of https://github.com/owncloudarchive/contacts.git synced 2025-01-18 07:52:21 +01:00

Contacts: Reenabled search. Currently only for own, local contacts.

This commit is contained in:
Thomas Tanghus 2013-04-30 02:05:15 +02:00
parent b11e76efc1
commit e7d52c5437
4 changed files with 30 additions and 30 deletions

View File

@ -40,16 +40,20 @@ if(\OCP\App::isEnabled('appframework')) {
$api->connectHook('\OC_Calendar', 'getEvents', '\OCA\Contacts\Hooks', 'getBirthdayEvents');
$api->connectHook('\OC_Calendar', 'getSources', '\OCA\Contacts\Hooks', 'getCalenderSources');
}
\OCP\Util::addscript('contacts', 'loader');
\OCP\Util::addscript('contacts', 'loader');
\OC_Search::registerProvider('OCA\Contacts\SearchProvider');
//\OCP\Share::registerBackend('contact', 'OCA\Contacts\Share_Backend_Contact');
\OCP\Share::registerBackend('addressbook', 'OCA\Contacts\Share\Addressbook', 'contact');
\OC_Search::registerProvider('OCA\Contacts\SearchProvider');
//\OCP\Share::registerBackend('contact', 'OCA\Contacts\Share_Backend_Contact');
\OCP\Share::registerBackend('addressbook', 'OCA\Contacts\Share\Addressbook', 'contact');
/*
if(OCP\User::isLoggedIn()) {
foreach(OCA\Contacts\Addressbook::all(OCP\USER::getUser()) as $addressbook) {
OCP\Contacts::registerAddressBook(new OCA\Contacts\AddressbookProvider($addressbook['id']));
if(\OCP\User::isLoggedIn()) {
$app = new App($api->getUserId());
$addressBooks = $app->getAddressBooksForUser();
foreach($addressBooks as $addressBook) {
if($addressBook->getBackend()->name === 'local') {
\OCP\Contacts::registerAddressBook(new AddressbookProvider($addressBook));
}
}
}
}*/
}

View File

@ -21,6 +21,7 @@
*/
namespace OCA\Contacts;
use OCA\Contacts\Utils\Properties;
/**
* This class manages our addressbooks.
@ -39,31 +40,28 @@ class AddressbookProvider implements \OCP\IAddressBook {
/**
* Addressbook info array
* @var array
* @var AddressBook
*/
public $addressbook;
public $addressBook;
/**
* Constructor
* @param integer $id
*/
public function __construct($id) {
$this->id = $id;
public function __construct($addressBook) {
$this->addressBook = $addressBook;
}
public function getAddressbook() {
if(!$this->addressbook) {
$this->addressbook = Addressbook::find($this->id);
}
return $this->addressbook;
return $this->addressBook;
}
/**
* @return string defining the technical unique key
*/
public function getKey() {
$book = $this->getAddressbook();
return $book['uri'].':'.$book['userid'];
$metaData = $this->addressBook->getMetaData();
return $metaData['backend'].':'.$metaData['id'];
}
/**
@ -71,16 +69,14 @@ class AddressbookProvider implements \OCP\IAddressBook {
* @return mixed
*/
public function getDisplayName() {
$book = $this->getAddressbook();
return $book['displayname'];
return $this->addressBook->getDisplayName();
}
/**
* @return mixed
*/
public function getPermissions() {
$book = $this->getAddressbook();
return $book['permissions'];
return $this->addressBook->getPermissions();
}
private function getProperty(&$results, $row) {
@ -107,7 +103,7 @@ class AddressbookProvider implements \OCP\IAddressBook {
break;
}
if(in_array($row['name'], App::$multi_properties)) {
if(in_array($row['name'], Properties::$multi_properties)) {
if(!isset($results[$row['contactid']])) {
$results[$row['contactid']] = array('id' => $row['contactid'], $row['name'] => array($value));
} elseif(!isset($results[$row['contactid']][$row['name']])) {
@ -159,7 +155,7 @@ class AddressbookProvider implements \OCP\IAddressBook {
$query = 'SELECT `' . self::CONTACT_TABLE . '`.`addressbookid`, `' . self::PROPERTY_TABLE . '`.`contactid`, `'
. self::PROPERTY_TABLE . '`.`name`, `' . self::PROPERTY_TABLE . '`.`value` FROM `'
. self::PROPERTY_TABLE . '`,`' . self::CONTACT_TABLE . '` WHERE `'
. self::CONTACT_TABLE . '`.`addressbookid` = \'' . $this->id . '\' AND `'
. self::CONTACT_TABLE . '`.`addressbookid` = \'' . $this->addressBook->getId() . '\' AND `'
. self::PROPERTY_TABLE . '`.`contactid` = `' . self::CONTACT_TABLE . '`.`id` AND `'
. self::PROPERTY_TABLE . '`.`contactid` IN (' . join(',', array_fill(0, count($ids), '?')) . ')';

View File

@ -117,7 +117,7 @@ class App {
public function getAddressBook($backendName, $addressbookid) {
\OCP\Util::writeLog('contacts', __METHOD__ . ': '. $backendName . ', ' . $addressbookid, \OCP\Util::DEBUG);
foreach(self::$addressBooks as $addressBook) {
if($addressBook->backend->name === $backendName
if($addressBook->getBackend()->name === $backendName
&& $addressBook->getId() === $addressbookid
) {
\OCP\Util::writeLog('contacts', __METHOD__ . ' returning: '. print_r($addressBook, true), \OCP\Util::DEBUG);

View File

@ -8,12 +8,12 @@ class SearchProvider extends \OC_Search_Provider{
return strtr($value, array('\,' => ',', '\;' => ';'));
};
$app = new App();
$searchresults = array( );
$results = \OCP\Contacts::search($query, array('N', 'FN', 'EMAIL', 'NICKNAME', 'ORG'));
$l = new \OC_l10n('contacts');
foreach($results as $result) {
$vcard = VCard::find($result['id']);
$link = \OCP\Util::linkTo('contacts', 'index.php').'#' . $vcard['id'];
$link = \OCP\Util::linkTo('contacts', 'index.php').'/#' . $result['id'];
$props = array();
foreach(array('EMAIL', 'NICKNAME', 'ORG') as $searchvar) {
if(isset($result[$searchvar]) && count($result[$searchvar]) > 0 && strlen($result[$searchvar][0]) > 3) {
@ -21,7 +21,7 @@ class SearchProvider extends \OC_Search_Provider{
}
}
$props = array_map($unescape, $props);
$searchresults[]=new \OC_Search_Result($vcard['fullname'], implode(', ', $props), $link, (string)$l->t('Contact'));//$name,$text,$link,$type
$searchresults[]=new \OC_Search_Result($result['FN'], implode(', ', $props), $link, (string)$l->t('Contact'));//$name,$text,$link,$type
}
return $searchresults;
}