. * */ namespace OCA\Contacts\Backend; use OCA\Contacts\Contact; /** * Subclass this class for Cantacts backends */ class Shared extends Database { public $addressbooks = array(); /** * Returns the list of addressbooks for a specific user. * * TODO: Create default if none exists. * * @param string $principaluri * @return array */ public function getAddressBooksForUser($userid = null) { $userid = $userid ? $userid : $this->userid; $this->addressbooks = \OCP\Share::getItemsSharedWith( 'addressbook', \OCA\Contacts\Share_Backend_Addressbook::FORMAT_ADDRESSBOOKS ); return $this->addressbooks; } /** * Returns all contacts for a specific addressbook id. * * TODO: Check for parent permissions * * @param string $addressbookid * @param bool $omitdata Don't fetch the entire carddata or vcard. * @return array */ public function getContacts($addressbookid, $limit = null, $offset = null, $omitdata = false) { $permissions = 0; if(!$this->addressbooks) { $this->addressbooks = \OCP\Share::getItemsSharedWith( 'addressbook', \OCA\Contacts\Share_Backend_Addressbook::FORMAT_ADDRESSBOOKS ); } foreach($this->addressbooks as $addressbook) { if($addressbook['id'] === $addressbookid) { $permissions = $addressbook['permissions']; break; } } $cards = array(); try { $qfields = $omitdata ? '`id`, `fullname`' : '*'; $query = 'SELECT ' . $qfields . ' FROM `' . $this->cardsTableName . '` WHERE `addressbookid` = ? ORDER BY `fullname`'; $stmt = \OCP\DB::prepare($query, $limit, $offset); $result = $stmt->execute(array($addressbookid)); if (\OC_DB::isError($result)) { \OC_Log::write('contacts', __METHOD__. 'DB error: ' . \OC_DB::getErrorMessage($result), \OCP\Util::ERROR); return $cards; } } catch(\Exception $e) { \OCP\Util::writeLog('contacts', __METHOD__.', exception: ' . $e->getMessage(), \OCP\Util::ERROR); return $cards; } if(!is_null($result)) { while( $row = $result->fetchRow()) { $row['permissions'] = $permissions; $cards[] = $row; } } return $cards; } }