3 +--------------------------------------------------------------------+
4 | CiviCRM version 4.7 |
5 +--------------------------------------------------------------------+
6 | Copyright CiviCRM LLC (c) 2004-2017 |
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-2017
33 class CRM_Contact_BAO_ContactType
extends CRM_Contact_DAO_ContactType
{
36 * Fetch object based on array of properties.
38 * @param array $params
39 * (reference ) an assoc array of name/value pairs.
40 * @param array $defaults
41 * (reference ) an assoc array to hold the flattened values.
43 * @return CRM_Contact_BAO_ContactType|null
44 * object on success, null otherwise
46 public static function retrieve(&$params, &$defaults) {
47 $contactType = new CRM_Contact_DAO_ContactType();
48 $contactType->copyValues($params);
49 if ($contactType->find(TRUE)) {
50 CRM_Core_DAO
::storeValues($contactType, $defaults);
57 * Is this contact type active.
59 * @param string $contactType
63 public static function isActive($contactType) {
64 $contact = self
::contactTypeInfo(FALSE);
65 $active = array_key_exists($contactType, $contact) ?
TRUE : FALSE;
70 * Retrieve basic contact type information.
75 * Array of basic contact types information.
77 public static function basicTypeInfo($all = FALSE) {
78 static $_cache = NULL;
80 if ($_cache === NULL) {
84 $argString = $all ?
'CRM_CT_BTI_1' : 'CRM_CT_BTI_0';
85 if (!array_key_exists($argString, $_cache)) {
86 $cache = CRM_Utils_Cache
::singleton();
87 $_cache[$argString] = $cache->get($argString);
88 if (!$_cache[$argString]) {
91 FROM civicrm_contact_type
92 WHERE parent_id IS NULL
95 $sql .= " AND is_active = 1";
99 $dao = CRM_Core_DAO
::executeQuery($sql,
102 'CRM_Contact_DAO_ContactType'
104 while ($dao->fetch()) {
106 CRM_Core_DAO
::storeValues($dao, $value);
107 $_cache[$argString][$dao->name
] = $value;
110 $cache->set($argString, $_cache[$argString]);
113 return $_cache[$argString];
117 * Retrieve all basic contact types.
122 * Array of basic contact types
124 public static function basicTypes($all = FALSE) {
125 return array_keys(self
::basicTypeInfo($all));
134 public static function basicTypePairs($all = FALSE, $key = 'name') {
135 $subtypes = self
::basicTypeInfo($all);
138 foreach ($subtypes as $name => $info) {
139 $index = ($key == 'name') ?
$name : $info[$key];
140 $pairs[$index] = $info['label'];
146 * Retrieve all subtypes Information.
148 * @param array $contactType
151 * @param bool $ignoreCache
155 * Array of sub type information
157 public static function subTypeInfo($contactType = NULL, $all = FALSE, $ignoreCache = FALSE, $reset = FALSE) {
158 static $_cache = NULL;
160 if ($reset === TRUE) {
164 if ($_cache === NULL) {
167 if ($contactType && !is_array($contactType)) {
168 $contactType = array($contactType);
171 $argString = $all ?
'CRM_CT_STI_1_' : 'CRM_CT_STI_0_';
172 if (!empty($contactType)) {
173 $argString .= implode('_', $contactType);
176 if ((!array_key_exists($argString, $_cache)) ||
$ignoreCache) {
177 $cache = CRM_Utils_Cache
::singleton();
178 $_cache[$argString] = $cache->get($argString);
179 if (!$_cache[$argString] ||
$ignoreCache) {
180 $_cache[$argString] = array();
183 if (!empty($contactType)) {
184 $ctWHERE = " AND parent.name IN ('" . implode("','", $contactType) . "')";
188 SELECT subtype.*, parent.name as parent, parent.label as parent_label
189 FROM civicrm_contact_type subtype
190 INNER JOIN civicrm_contact_type parent ON subtype.parent_id = parent.id
191 WHERE subtype.name IS NOT NULL AND subtype.parent_id IS NOT NULL {$ctWHERE}
193 if ($all === FALSE) {
194 $sql .= " AND subtype.is_active = 1 AND parent.is_active = 1 ORDER BY parent.id";
196 $dao = CRM_Core_DAO
::executeQuery($sql, array(),
197 FALSE, 'CRM_Contact_DAO_ContactType'
199 while ($dao->fetch()) {
201 CRM_Core_DAO
::storeValues($dao, $value);
202 $value['parent'] = $dao->parent
;
203 $value['parent_label'] = $dao->parent_label
;
204 $_cache[$argString][$dao->name
] = $value;
207 $cache->set($argString, $_cache[$argString]);
210 return $_cache[$argString];
215 * retrieve all subtypes
217 * @param array $contactType
220 * @param string $columnName
221 * @param bool $ignoreCache
224 * all subtypes OR list of subtypes associated to
225 * a given basic contact type
227 public static function subTypes($contactType = NULL, $all = FALSE, $columnName = 'name', $ignoreCache = FALSE) {
228 if ($columnName == 'name') {
229 return array_keys(self
::subTypeInfo($contactType, $all, $ignoreCache));
232 return array_values(self
::subTypePairs($contactType, FALSE, NULL, $ignoreCache));
238 * retrieve subtype pairs with name as 'subtype-name' and 'label' as value
240 * @param array $contactType
242 * @param string $labelPrefix
243 * @param bool $ignoreCache
246 * list of subtypes with name as 'subtype-name' and 'label' as value
248 public static function subTypePairs($contactType = NULL, $all = FALSE, $labelPrefix = '- ', $ignoreCache = FALSE) {
249 $subtypes = self
::subTypeInfo($contactType, $all, $ignoreCache);
252 foreach ($subtypes as $name => $info) {
253 $pairs[$name] = $labelPrefix . $info['label'];
260 * retrieve list of all types i.e basic + subtypes.
265 * Array of basic types + all subtypes.
267 public static function contactTypes($all = FALSE) {
268 return array_keys(self
::contactTypeInfo($all));
272 * Retrieve info array about all types i.e basic + subtypes.
278 * Array of basic types + all subtypes.
280 public static function contactTypeInfo($all = FALSE, $reset = FALSE) {
281 static $_cache = NULL;
283 if ($reset === TRUE) {
287 if ($_cache === NULL) {
291 $argString = $all ?
'CRM_CT_CTI_1' : 'CRM_CT_CTI_0';
292 if (!array_key_exists($argString, $_cache)) {
293 $cache = CRM_Utils_Cache
::singleton();
294 $_cache[$argString] = $cache->get($argString);
295 if (!$_cache[$argString]) {
296 $_cache[$argString] = array();
299 SELECT type.*, parent.name as parent, parent.label as parent_label
300 FROM civicrm_contact_type type
301 LEFT JOIN civicrm_contact_type parent ON type.parent_id = parent.id
302 WHERE type.name IS NOT NULL
304 if ($all === FALSE) {
305 $sql .= " AND type.is_active = 1";
308 $dao = CRM_Core_DAO
::executeQuery($sql,
311 'CRM_Contact_DAO_ContactType'
313 while ($dao->fetch()) {
315 CRM_Core_DAO
::storeValues($dao, $value);
316 if (array_key_exists('parent_id', $value)) {
317 $value['parent'] = $dao->parent
;
318 $value['parent_label'] = $dao->parent_label
;
320 $_cache[$argString][$dao->name
] = $value;
323 $cache->set($argString, $_cache[$argString]);
327 return $_cache[$argString];
331 * Retrieve basic type pairs with name as 'built-in name' and 'label' as value.
334 * @param null $typeName
335 * @param null $delimiter
338 * Array of basictypes with name as 'built-in name' and 'label' as value
340 public static function contactTypePairs($all = FALSE, $typeName = NULL, $delimiter = NULL) {
341 $types = self
::contactTypeInfo($all);
343 if ($typeName && !is_array($typeName)) {
344 $typeName = explode(CRM_Core_DAO
::VALUE_SEPARATOR
, trim($typeName, CRM_Core_DAO
::VALUE_SEPARATOR
));
349 foreach ($typeName as $type) {
350 if (array_key_exists($type, $types)) {
351 $pairs[$type] = $types[$type]['label'];
356 foreach ($types as $name => $info) {
357 $pairs[$name] = $info['label'];
361 return !$delimiter ?
$pairs : implode($delimiter, $pairs);
365 * Get a list of elements for select box.
366 * Note that this used to default to using the hex(01) character - which results in an invalid character being used in form fields
367 * which was not handled well be anything that loaded & resaved the html (outside core)
368 * The use of this separator is now explicit in the calling functions as a step towards it's removal
371 * @param bool $isSeparator
372 * @param string $separator
376 public static function getSelectElements(
381 static $_cache = NULL;
383 if ($_cache === NULL) {
387 $argString = $all ?
'CRM_CT_GSE_1' : 'CRM_CT_GSE_0';
388 $argString .= $isSeparator ?
'_1' : '_0';
389 $argString .= $separator;
390 if (!array_key_exists($argString, $_cache)) {
391 $cache = CRM_Utils_Cache
::singleton();
392 $_cache[$argString] = $cache->get($argString);
394 if (!$_cache[$argString]) {
395 $_cache[$argString] = array();
398 SELECT c.name as child_name , c.label as child_label , c.id as child_id,
399 p.name as parent_name, p.label as parent_label, p.id as parent_id
400 FROM civicrm_contact_type c
401 LEFT JOIN civicrm_contact_type p ON ( c.parent_id = p.id )
402 WHERE ( c.name IS NOT NULL )
405 if ($all === FALSE) {
408 AND ( p.is_active = 1 OR p.id IS NULL )
411 $sql .= " ORDER BY c.id";
414 $dao = CRM_Core_DAO
::executeQuery($sql);
415 while ($dao->fetch()) {
416 if (!empty($dao->parent_id
)) {
417 $key = $isSeparator ?
$dao->parent_name
. $separator . $dao->child_name
: $dao->child_name
;
418 $label = "- {$dao->child_label}";
419 $pName = $dao->parent_name
;
422 $key = $dao->child_name
;
423 $label = $dao->child_label
;
424 $pName = $dao->child_name
;
427 if (!isset($values[$pName])) {
428 $values[$pName] = array();
430 $values[$pName][] = array('key' => $key, 'label' => $label);
433 $selectElements = array();
434 foreach ($values as $pName => $elements) {
435 foreach ($elements as $element) {
436 $selectElements[$element['key']] = $element['label'];
439 $_cache[$argString] = $selectElements;
441 $cache->set($argString, $_cache[$argString]);
444 return $_cache[$argString];
448 * Check if a given type is a subtype.
450 * @param string $subType
452 * @param bool $ignoreCache
455 * true if subType, false otherwise.
457 public static function isaSubType($subType, $ignoreCache = FALSE) {
458 return in_array($subType, self
::subTypes(NULL, TRUE, 'name', $ignoreCache));
462 * Retrieve the basic contact type associated with given subType.
464 * @param array /string $subType contact subType.
465 * @return array/string of basicTypes.
467 public static function getBasicType($subType) {
468 static $_cache = NULL;
469 if ($_cache === NULL) {
474 if ($subType && !is_array($subType)) {
475 $subType = array($subType);
478 $argString = implode('_', $subType);
480 if (!array_key_exists($argString, $_cache)) {
481 $_cache[$argString] = array();
484 SELECT subtype.name as contact_subtype, type.name as contact_type
485 FROM civicrm_contact_type subtype
486 INNER JOIN civicrm_contact_type type ON ( subtype.parent_id = type.id )
487 WHERE subtype.name IN ('" . implode("','", $subType) . "' )";
488 $dao = CRM_Core_DAO
::executeQuery($sql);
489 while ($dao->fetch()) {
491 $_cache[$argString] = $dao->contact_type
;
494 $_cache[$argString][$dao->contact_subtype
] = $dao->contact_type
;
497 return $_cache[$argString];
501 * Suppress all subtypes present in given array.
503 * @param array $subTypes
505 * @param bool $ignoreCache
508 * Array of suppressed subTypes.
510 public static function suppressSubTypes(&$subTypes, $ignoreCache = FALSE) {
511 $subTypes = array_diff($subTypes, self
::subTypes(NULL, TRUE, 'name', $ignoreCache));
516 * Verify if a given subtype is associated with a given basic contact type.
518 * @param string $subType
520 * @param string $contactType
522 * @param bool $ignoreCache
523 * @param string $columnName
526 * true if contact extends, false otherwise.
528 public static function isExtendsContactType($subType, $contactType, $ignoreCache = FALSE, $columnName = 'name') {
529 $subType = (array) CRM_Utils_Array
::explodePadded($subType);
530 $subtypeList = self
::subTypes($contactType, TRUE, $columnName, $ignoreCache);
531 $intersection = array_intersect($subType, $subtypeList);
532 return $subType == $intersection;
536 * Create shortcuts menu for contactTypes.
541 public static function getCreateNewList() {
542 $shortCuts = array();
543 //@todo FIXME - using the CRM_Core_DAO::VALUE_SEPARATOR creates invalid html - if you can find the form
544 // this is loaded onto then replace with something like '__' & test
545 $separator = CRM_Core_DAO
::VALUE_SEPARATOR
;
546 $contactTypes = self
::getSelectElements(FALSE, TRUE, $separator);
547 foreach ($contactTypes as $key => $value) {
549 $typeValue = explode(CRM_Core_DAO
::VALUE_SEPARATOR
, $key);
550 $cType = CRM_Utils_Array
::value('0', $typeValue);
551 $typeUrl = 'ct=' . $cType;
552 if ($csType = CRM_Utils_Array
::value('1', $typeValue)) {
553 $typeUrl .= "&cst=$csType";
556 'path' => 'civicrm/contact/add',
557 'query' => "$typeUrl&reset=1",
558 'ref' => "new-$value",
561 if ($csType = CRM_Utils_Array
::value('1', $typeValue)) {
562 $shortCuts[$cType]['shortCuts'][] = $shortCut;
565 $shortCuts[$cType] = $shortCut;
573 * Delete Contact SubTypes.
575 * @param int $contactTypeId
576 * ID of the Contact Subtype to be deleted.
580 public static function del($contactTypeId) {
582 if (!$contactTypeId) {
586 $params = array('id' => $contactTypeId);
587 self
::retrieve($params, $typeInfo);
588 $name = $typeInfo['name'];
589 // check if any custom group
590 $custom = new CRM_Core_DAO_CustomGroup();
591 $custom->whereAdd("extends_entity_column_value LIKE '%" .
592 CRM_Core_DAO
::VALUE_SEPARATOR
.
594 CRM_Core_DAO
::VALUE_SEPARATOR
. "%'"
596 if ($custom->find()) {
600 // remove subtype for existing contacts
602 UPDATE civicrm_contact SET contact_sub_type = NULL
603 WHERE contact_sub_type = '$name'";
604 CRM_Core_DAO
::executeQuery($sql);
606 // remove subtype from contact type table
607 $contactType = new CRM_Contact_DAO_ContactType();
608 $contactType->id
= $contactTypeId;
609 $contactType->delete();
611 // remove navigation entry if any
615 FROM civicrm_navigation
617 $params = array(1 => array("New $name", 'String'));
618 $dao = CRM_Core_DAO
::executeQuery($sql, $params);
619 CRM_Core_BAO_Navigation
::resetNavigation();
625 * Add or update Contact SubTypes.
627 * @param array $params
628 * An assoc array of name/value pairs.
630 * @return object|void
632 public static function add(&$params) {
635 if (empty($params['id']) && empty($params['label'])) {
638 if (!empty($params['parent_id']) &&
639 !CRM_Core_DAO
::getFieldValue('CRM_Contact_DAO_ContactType', $params['parent_id'])
644 $contactType = new CRM_Contact_DAO_ContactType();
645 $contactType->copyValues($params);
646 $contactType->id
= CRM_Utils_Array
::value('id', $params);
647 $contactType->is_active
= CRM_Utils_Array
::value('is_active', $params, 0);
649 $contactType->save();
650 if ($contactType->find(TRUE)) {
651 $contactName = $contactType->name
;
652 $contact = ucfirst($contactType->label
);
653 $active = $contactType->is_active
;
656 if (!empty($params['id'])) {
657 $params = array('name' => "New $contactName");
659 'label' => "New $contact",
660 'is_active' => $active,
662 CRM_Core_BAO_Navigation
::processUpdate($params, $newParams);
665 $name = self
::getBasicType($contactName);
669 $value = array('name' => "New $name");
670 CRM_Core_BAO_Navigation
::retrieve($value, $navinfo);
672 'label' => "New $contact",
673 'name' => "New $contactName",
674 'url' => "civicrm/contact/add?ct=$name&cst=$contactName&reset=1",
675 'permission' => 'add contacts',
676 'parent_id' => $navinfo['id'],
677 'is_active' => $active,
679 CRM_Core_BAO_Navigation
::add($navigation);
681 CRM_Core_BAO_Navigation
::resetNavigation();
683 // reset the cache after adding
684 self
::subTypeInfo(NULL, FALSE, FALSE, TRUE);
690 * Update the is_active flag in the db.
693 * Id of the database record.
694 * @param bool $is_active
695 * Value we want to set the is_active field.
698 * DAO object on success, null otherwise
700 public static function setIsActive($id, $is_active) {
701 $params = array('id' => $id);
702 self
::retrieve($params, $contactinfo);
703 $params = array('name' => "New $contactinfo[name]");
704 $newParams = array('is_active' => $is_active);
705 CRM_Core_BAO_Navigation
::processUpdate($params, $newParams);
706 CRM_Core_BAO_Navigation
::resetNavigation();
707 return CRM_Core_DAO
::setFieldValue('CRM_Contact_DAO_ContactType', $id,
708 'is_active', $is_active
713 * @param string $typeName
717 public static function getLabel($typeName) {
718 $types = self
::contactTypeInfo(TRUE);
720 if (array_key_exists($typeName, $types)) {
721 return $types[$typeName]['label'];
727 * Check whether allow to change any contact's subtype
728 * on the basis of custom data and relationship of specific subtype
729 * currently used in contact/edit form amd in import validation
731 * @param int $contactId
733 * @param string $subType
738 public static function isAllowEdit($contactId, $subType = NULL) {
744 if (empty($subType)) {
745 $subType = CRM_Core_DAO
::getFieldValue('CRM_Contact_DAO_Contact',
751 if (self
::hasCustomData($subType, $contactId) || self
::hasRelationships($contactId, $subType)) {
759 * @param $contactType
760 * @param int $contactId
764 public static function hasCustomData($contactType, $contactId = NULL) {
767 if (self
::isaSubType($contactType)) {
768 $subType = $contactType;
769 $contactType = self
::getBasicType($subType);
771 // check for empty custom data which extends subtype
772 $subTypeValue = CRM_Core_DAO
::VALUE_SEPARATOR
. $subType . CRM_Core_DAO
::VALUE_SEPARATOR
;
773 $subTypeClause = " AND extends_entity_column_value LIKE '%{$subTypeValue}%' ";
775 $query = "SELECT table_name FROM civicrm_custom_group WHERE extends = '{$contactType}' {$subTypeClause}";
777 $dao = CRM_Core_DAO
::executeQuery($query);
778 while ($dao->fetch()) {
779 $sql = "SELECT count(id) FROM {$dao->table_name}";
781 $sql .= " WHERE entity_id = {$contactId}";
785 $customDataCount = CRM_Core_DAO
::singleValueQuery($sql);
786 if (!empty($customDataCount)) {
795 * @todo what does this function do?
796 * @param int $contactId
797 * @param $contactType
801 public static function hasRelationships($contactId, $contactType) {
802 $subTypeClause = NULL;
803 if (self
::isaSubType($contactType)) {
804 $subType = $contactType;
805 $contactType = self
::getBasicType($subType);
806 $subTypeClause = " AND ( ( crt.contact_type_a = '{$contactType}' AND crt.contact_sub_type_a = '{$subType}') OR
807 ( crt.contact_type_b = '{$contactType}' AND crt.contact_sub_type_b = '{$subType}') ) ";
810 $subTypeClause = " AND ( crt.contact_type_a = '{$contactType}' OR crt.contact_type_b = '{$contactType}' ) ";
813 // check relationships for
814 $relationshipQuery = "
815 SELECT count(cr.id) FROM civicrm_relationship cr
816 INNER JOIN civicrm_relationship_type crt ON
817 ( cr.relationship_type_id = crt.id {$subTypeClause} )
818 WHERE ( cr.contact_id_a = {$contactId} OR cr.contact_id_b = {$contactId} )
821 $relationshipCount = CRM_Core_DAO
::singleValueQuery($relationshipQuery);
823 if (!empty($relationshipCount)) {
831 * @todo what does this function do?
832 * @param $contactType
833 * @param array $subtypeSet
837 public static function getSubtypeCustomPair($contactType, $subtypeSet = array()) {
838 if (empty($subtypeSet)) {
842 $customSet = $subTypeClause = array();
843 foreach ($subtypeSet as $subtype) {
844 $subtype = CRM_Utils_Type
::escape($subtype, 'String');
845 $subtype = CRM_Core_DAO
::VALUE_SEPARATOR
. $subtype . CRM_Core_DAO
::VALUE_SEPARATOR
;
846 $subTypeClause[] = "extends_entity_column_value LIKE '%{$subtype}%' ";
848 $query = "SELECT table_name
849 FROM civicrm_custom_group
850 WHERE extends = %1 AND " . implode(" OR ", $subTypeClause);
851 $dao = CRM_Core_DAO
::executeQuery($query, array(1 => array($contactType, 'String')));
852 while ($dao->fetch()) {
853 $customSet[] = $dao->table_name
;
855 return array_unique($customSet);
859 * Function that does something.
860 * @todo what does this function do?
862 * @param int $contactID
863 * @param $contactType
864 * @param array $oldSubtypeSet
865 * @param array $newSubtypeSet
869 public static function deleteCustomSetForSubtypeMigration(
872 $oldSubtypeSet = array(),
873 $newSubtypeSet = array()
875 $oldCustomSet = self
::getSubtypeCustomPair($contactType, $oldSubtypeSet);
876 $newCustomSet = self
::getSubtypeCustomPair($contactType, $newSubtypeSet);
878 $customToBeRemoved = array_diff($oldCustomSet, $newCustomSet);
879 foreach ($customToBeRemoved as $customTable) {
880 self
::deleteCustomRowsForEntityID($customTable, $contactID);
886 * Delete content / rows of a custom table specific to a subtype for a given custom-group.
887 * This function currently works for contact subtypes only and could be later improved / genralized
888 * to work for other subtypes as well.
892 * @param array $subtypes
893 * List of subtypes related to which entry is to be removed.
897 public static function deleteCustomRowsOfSubtype($gID, $subtypes = array(), $subtypesToPreserve = array()) {
898 if (!$gID or empty($subtypes)) {
902 $tableName = CRM_Core_DAO
::getFieldValue('CRM_Core_DAO_CustomGroup', $gID, 'table_name');
904 // drop triggers CRM-13587
905 CRM_Core_DAO
::dropTriggers($tableName);
907 foreach ($subtypesToPreserve as $subtypeToPreserve) {
908 $subtypeToPreserve = CRM_Utils_Type
::escape($subtypeToPreserve, 'String');
909 $subtypesToPreserveClause[] = "(civicrm_contact.contact_sub_type NOT LIKE '%" . CRM_Core_DAO
::VALUE_SEPARATOR
. $subtypeToPreserve . CRM_Core_DAO
::VALUE_SEPARATOR
. "%')";
911 $subtypesToPreserveClause = implode(' AND ', $subtypesToPreserveClause);
913 $subtypeClause = array();
914 foreach ($subtypes as $subtype) {
915 $subtype = CRM_Utils_Type
::escape($subtype, 'String');
916 $subtypeClause[] = "( civicrm_contact.contact_sub_type LIKE '%" . CRM_Core_DAO
::VALUE_SEPARATOR
. $subtype . CRM_Core_DAO
::VALUE_SEPARATOR
. "%'"
917 . " AND " . $subtypesToPreserveClause . ")";
919 $subtypeClause = implode(' OR ', $subtypeClause);
921 $query = "DELETE custom.*
922 FROM {$tableName} custom
923 INNER JOIN civicrm_contact ON civicrm_contact.id = custom.entity_id
924 WHERE ($subtypeClause)";
926 CRM_Core_DAO
::singleValueQuery($query);
928 // rebuild triggers CRM-13587
929 CRM_Core_DAO
::triggerRebuild($tableName);
933 * Delete content / rows of a custom table specific entity-id for a given custom-group table.
935 * @param int $customTable
937 * @param int $entityID
940 * @return null|string
942 public static function deleteCustomRowsForEntityID($customTable, $entityID) {
943 $customTable = CRM_Utils_Type
::escape($customTable, 'String');
944 $query = "DELETE FROM {$customTable} WHERE entity_id = %1";
945 return CRM_Core_DAO
::singleValueQuery($query, array(1 => array($entityID, 'Integer')));