3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.6 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2014 |
7 +--------------------------------------------------------------------+
8 | This file is a part of CiviCRM. |
10 | CiviCRM is free software; you can copy, modify, and distribute it |
11 | under the terms of the GNU Affero General Public License |
12 | Version 3, 19 November 2007 and the CiviCRM Licensing Exception. |
14 | CiviCRM is distributed in the hope that it will be useful, but |
15 | WITHOUT ANY WARRANTY; without even the implied warranty of |
16 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. |
17 | See the GNU Affero General Public License for more details. |
19 | You should have received a copy of the GNU Affero General Public |
20 | License and the CiviCRM Licensing Exception along |
21 | with this program; if not, contact CiviCRM LLC |
22 | at info[AT]civicrm[DOT]org. If you have questions about the |
23 | GNU Affero General Public License or the licensing of CiviCRM, |
24 | see the CiviCRM license FAQ at http://civicrm.org/licensing |
25 +--------------------------------------------------------------------+
31 * @copyright CiviCRM LLC (c) 2004-2014
35 class CRM_Contact_BAO_SearchCustom
{
45 public static function details($csID, $ssID = NULL, $gID = NULL) {
46 $error = array(NULL, NULL, NULL);
55 $customSearchID = $csID;
56 $formValues = array();
59 $ssID = CRM_Core_DAO
::getFieldValue('CRM_Contact_DAO_Group', $gID, 'saved_search_id');
62 $formValues = CRM_Contact_BAO_SavedSearch
::getFormValues($ssID);
63 $customSearchID = CRM_Utils_Array
::value('customSearchID',
68 if (!$customSearchID) {
72 // check that the csid exists in the db along with the right file
73 // and implements the right interface
74 $customSearchClass = CRM_Core_OptionGroup
::getLabel('custom_search',
77 if (!$customSearchClass) {
81 $ext = CRM_Extension_System
::singleton()->getMapper();
83 if (!$ext->isExtensionKey($customSearchClass)) {
84 $customSearchFile = str_replace('_',
90 $customSearchFile = $ext->keyToPath($customSearchClass);
91 $customSearchClass = $ext->keyToClass($customSearchClass);
94 $error = include_once $customSearchFile;
95 if ($error == FALSE) {
96 CRM_Core_Error
::fatal('Custom search file: ' . $customSearchFile . ' does not exist. Please verify your custom search settings in CiviCRM administrative panel.');
99 return array($customSearchID, $customSearchClass, $formValues);
109 public static function customClass($csID, $ssID) {
110 list($customSearchID, $customSearchClass, $formValues) = self
::details($csID, $ssID);
112 if (!$customSearchID) {
113 CRM_Core_Error
::fatal('Could not resolve custom search ID');
116 // instantiate the new class
117 $customClass = new $customSearchClass($formValues);
128 public static function contactIDSQL($csID, $ssID) {
129 $customClass = self
::customClass($csID, $ssID);
130 return $customClass->contactIDs();
138 public static function &buildFormValues($args) {
141 $values = explode("\n", $args);
142 $formValues = array();
143 foreach ($values as $value) {
144 list($n, $v) = CRM_Utils_System
::explode('=', $value, 2);
146 $formValues[$n] = $v;
158 public static function fromWhereEmail($csID, $ssID) {
159 $customClass = self
::customClass($csID, $ssID);
161 $from = $customClass->from();
162 $where = $customClass->where();
164 return array($from, $where);