當前位置: 首頁>>代碼示例>>PHP>>正文


PHP CRM_Contact_BAO_Contact_Permission::cache方法代碼示例

本文整理匯總了PHP中CRM_Contact_BAO_Contact_Permission::cache方法的典型用法代碼示例。如果您正苦於以下問題:PHP CRM_Contact_BAO_Contact_Permission::cache方法的具體用法?PHP CRM_Contact_BAO_Contact_Permission::cache怎麽用?PHP CRM_Contact_BAO_Contact_Permission::cache使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在CRM_Contact_BAO_Contact_Permission的用法示例。


在下文中一共展示了CRM_Contact_BAO_Contact_Permission::cache方法的7個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: buildACLClause

 function buildACLClause($tableAlias)
 {
     //override for ACL( Since Cotact may be source
     //contact/assignee or target also it may be null )
     require_once 'CRM/Core/Permission.php';
     require_once 'CRM/Contact/BAO/Contact/Permission.php';
     if (CRM_Core_Permission::check('view all contacts')) {
         $this->_aclFrom = $this->_aclWhere = null;
         return;
     }
     $session = CRM_Core_Session::singleton();
     $contactID = $session->get('userID');
     if (!$contactID) {
         $contactID = 0;
     }
     $contactID = CRM_Utils_Type::escape($contactID, 'Integer');
     CRM_Contact_BAO_Contact_Permission::cache($contactID);
     $clauses = array();
     foreach ($tableAlias as $k => $alias) {
         $clauses[] = " INNER JOIN civicrm_acl_contact_cache aclContactCache_{$k} ON ( {$alias}.id = aclContactCache_{$k}.contact_id OR {$alias}.id IS NULL ) AND aclContactCache_{$k}.user_id = {$contactID} ";
     }
     $this->_aclFrom = implode(" ", $clauses);
     $this->_aclWhere = null;
 }
開發者ID:ksecor,項目名稱:civicrm,代碼行數:24,代碼來源:Activity.php

示例2: updateEntry

 static function updateEntry($id)
 {
     // rebuilds civicrm_acl_cache
     self::deleteEntry($id);
     self::build($id);
     // rebuilds civicrm_acl_contact_cache
     require_once "CRM/Contact/BAO/Contact/Permission.php";
     CRM_Contact_BAO_Contact_Permission::cache($id, CRM_Core_Permission::VIEW, true);
 }
開發者ID:bhirsch,項目名稱:voipdev,代碼行數:9,代碼來源:Cache.php

示例3: testGetQuickFirstNameACLs

 /**
  * Test that getquick applies ACLs.
  */
 public function testGetQuickFirstNameACLs()
 {
     $this->getQuickSearchSampleData();
     $userID = $this->createLoggedInUser();
     $this->callAPISuccess('Setting', 'create', array('includeOrderByClause' => TRUE));
     CRM_Core_Config::singleton()->userPermissionClass->permissions = array();
     $result = $this->callAPISuccess('contact', 'getquick', array('name' => 'Bob', 'field_name' => 'first_name', 'table_name' => 'cc'));
     $this->assertEquals(0, $result['count']);
     $this->hookClass->setHook('civicrm_aclWhereClause', array($this, 'aclWhereNoBobH'));
     CRM_Contact_BAO_Contact_Permission::cache($userID, CRM_Core_Permission::VIEW, TRUE);
     $result = $this->callAPISuccess('contact', 'getquick', array('name' => 'Bob', 'field_name' => 'first_name', 'table_name' => 'cc'));
     $this->assertEquals('K Bobby, Bob', $result['values'][1]['sort_name']);
     // Without the ACL 9 would be bob@h.com.
     $this->assertEquals('I Bobby, Bobby', $result['values'][9]['sort_name']);
 }
開發者ID:nielosz,項目名稱:civicrm-core,代碼行數:18,代碼來源:ContactTest.php

示例4: filterACLContacts

 public function filterACLContacts()
 {
     if (CRM_Core_Permission::check('view all contacts')) {
         CRM_Core_DAO::executeQuery("DELETE FROM {$this->_tableName} WHERE contact_id IN (SELECT id FROM civicrm_contact WHERE is_deleted = 1)");
         return;
     }
     $session = CRM_Core_Session::singleton();
     $contactID = $session->get('userID');
     if (!$contactID) {
         $contactID = 0;
     }
     CRM_Contact_BAO_Contact_Permission::cache($contactID);
     $params = array(1 => array($contactID, 'Integer'));
     $sql = "\nDELETE     t.*\nFROM       {$this->_tableName} t\nWHERE      NOT EXISTS ( SELECT c.id\n                        FROM civicrm_acl_contact_cache c\n                        WHERE c.user_id = %1 AND t.contact_id = c.contact_id )\n";
     CRM_Core_DAO::executeQuery($sql, $params);
     $sql = "\nDELETE     t.*\nFROM       {$this->_tableName} t\nWHERE      t.table_name = 'Activity' AND\n           NOT EXISTS ( SELECT c.id\n                        FROM civicrm_acl_contact_cache c\n                        WHERE c.user_id = %1 AND ( t.target_contact_id = c.contact_id OR t.target_contact_id IS NULL ) )\n";
     CRM_Core_DAO::executeQuery($sql, $params);
     $sql = "\nDELETE     t.*\nFROM       {$this->_tableName} t\nWHERE      t.table_name = 'Activity' AND\n           NOT EXISTS ( SELECT c.id\n                        FROM civicrm_acl_contact_cache c\n                        WHERE c.user_id = %1 AND ( t.assignee_contact_id = c.contact_id OR t.assignee_contact_id IS NULL ) )\n";
     CRM_Core_DAO::executeQuery($sql, $params);
 }
開發者ID:BorislavZlatanov,項目名稱:civicrm-core,代碼行數:20,代碼來源:FullText.php

示例5: updateEntry

 /**
  * @param int $id
  */
 public static function updateEntry($id)
 {
     // rebuilds civicrm_acl_cache
     self::deleteEntry($id);
     self::build($id);
     // rebuilds civicrm_acl_contact_cache
     CRM_Contact_BAO_Contact_Permission::cache($id, CRM_Core_Permission::VIEW, TRUE);
 }
開發者ID:saurabhbatra96,項目名稱:civicrm-core,代碼行數:11,代碼來源:Cache.php

示例6: buildACLClause

 function buildACLClause($tableAlias = array())
 {
     if (CRM_Core_Permission::check('view all contacts')) {
         $this->_aclFrom = $this->_aclWhere = NULL;
         return;
     }
     $session = CRM_Core_Session::singleton();
     $contactID = $session->get('userID');
     if (!$contactID) {
         $contactID = 0;
     }
     $contactID = CRM_Utils_Type::escape($contactID, 'Integer');
     CRM_Contact_BAO_Contact_Permission::cache($contactID);
     $clauses = array();
     foreach ($tableAlias as $k => $alias) {
         $clauses[] = " INNER JOIN civicrm_acl_contact_cache aclContactCache_{$k} ON ( {$alias}.contact_id = aclContactCache_{$k}.contact_id OR {$alias}.contact_id IS NULL ) AND aclContactCache_{$k}.user_id = {$contactID} ";
     }
     $this->_aclFrom = implode(" ", $clauses);
 }
開發者ID:JoeMurray,項目名稱:civihr,代碼行數:19,代碼來源:HRAbsenceCalendar.php

示例7: filterACLContacts

 function filterACLContacts()
 {
     if (CRM_Core_Permission::check('view all contacts')) {
         return;
     }
     $session = CRM_Core_Session::singleton();
     $contactID = $session->get('userID');
     if (!$contactID) {
         $contactID = 0;
     }
     require_once 'CRM/Contact/BAO/Contact/Permission.php';
     CRM_Contact_BAO_Contact_Permission::cache($contactID);
     $params = array(1 => array($contactID, 'Integer'));
     $sql = "\r\nDELETE     t.*\r\nFROM       {$this->_tableName} t\r\nWHERE      NOT EXISTS ( SELECT c.id \r\n                        FROM civicrm_acl_contact_cache c\r\n                        WHERE c.user_id = %1 AND t.contact_id = c.contact_id )\r\n";
     CRM_Core_DAO::executeQuery($sql, $params);
     $sql = "\r\nDELETE     t.*\r\nFROM       {$this->_tableName} t\r\nWHERE      t.table_name = 'Activity' AND\r\n           NOT EXISTS ( SELECT c.id \r\n                        FROM civicrm_acl_contact_cache c\r\n                        WHERE c.user_id = %1 AND ( t.target_contact_id = c.contact_id OR t.target_contact_id IS NULL ) )\r\n";
     CRM_Core_DAO::executeQuery($sql, $params);
     $sql = "\r\nDELETE     t.*\r\nFROM       {$this->_tableName} t\r\nWHERE      t.table_name = 'Activity' AND\r\n           NOT EXISTS ( SELECT c.id \r\n                        FROM civicrm_acl_contact_cache c\r\n                        WHERE c.user_id = %1 AND ( t.assignee_contact_id = c.contact_id OR t.assignee_contact_id IS NULL ) )\r\n";
     CRM_Core_DAO::executeQuery($sql, $params);
 }
開發者ID:ksecor,項目名稱:civicrm,代碼行數:20,代碼來源:FullText.php


注:本文中的CRM_Contact_BAO_Contact_Permission::cache方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。