From 7ce3f1930daaab8973b8063fdd5683807b32ff2c Mon Sep 17 00:00:00 2001 From: eileen Date: Thu, 2 May 2019 00:19:51 +1200 Subject: [PATCH] [ref] Move copyCustomFields function from Event to Core_DAO for re-usablibilty --- CRM/Core/DAO.php | 51 +++++++++++++++++++++++++++++++++++++++++ CRM/Event/BAO/Event.php | 51 ----------------------------------------- 2 files changed, 51 insertions(+), 51 deletions(-) diff --git a/CRM/Core/DAO.php b/CRM/Core/DAO.php index 027dba4a89fd..f08309f72a9c 100644 --- a/CRM/Core/DAO.php +++ b/CRM/Core/DAO.php @@ -1679,6 +1679,57 @@ public static function ©Generic($daoName, $criteria, $newData = NULL, $field return $newObject; } + /** + * Method that copies custom fields values from an old event to a new one. Fixes bug CRM-19302, + * where if a custom field of File type was present, left both events using the same file, + * breaking download URL's for the old event. + * + * @param int $oldEventID + * @param int $newCopyID + */ + public static function copyCustomFields($oldEventID, $newCopyID) { + // Obtain custom values for old event + $customParams = $htmlType = []; + $customValues = CRM_Core_BAO_CustomValueTable::getEntityValues($oldEventID, 'Event'); + + // If custom values present, we copy them + if (!empty($customValues)) { + // Get Field ID's and identify File type attributes, to handle file copying. + $fieldIds = implode(', ', array_keys($customValues)); + $sql = "SELECT id FROM civicrm_custom_field WHERE html_type = 'File' AND id IN ( {$fieldIds} )"; + $result = CRM_Core_DAO::executeQuery($sql); + + // Build array of File type fields + while ($result->fetch()) { + $htmlType[] = $result->id; + } + + // Build params array of custom values + foreach ($customValues as $field => $value) { + if ($value !== NULL) { + // Handle File type attributes + if (in_array($field, $htmlType)) { + $fileValues = CRM_Core_BAO_File::path($value, $oldEventID); + $customParams["custom_{$field}_-1"] = [ + 'name' => CRM_Utils_File::duplicate($fileValues[0]), + 'type' => $fileValues[1], + ]; + } + // Handle other types + else { + $customParams["custom_{$field}_-1"] = $value; + } + } + } + + // Save Custom Fields for new Event + CRM_Core_BAO_CustomValueTable::postProcess($customParams, 'civicrm_event', $newCopyID, 'Event'); + } + + // copy activity attachments ( if any ) + CRM_Core_BAO_File::copyEntityFile('civicrm_event', $oldEventID, 'civicrm_event', $newCopyID); + } + /** * Cascade update through related entities. * diff --git a/CRM/Event/BAO/Event.php b/CRM/Event/BAO/Event.php index 518bc9bd0bb3..4ac86ba11531 100644 --- a/CRM/Event/BAO/Event.php +++ b/CRM/Event/BAO/Event.php @@ -996,57 +996,6 @@ public static function copy($id, $params = []) { return $copyEvent; } - /** - * Method that copies custom fields values from an old event to a new one. Fixes bug CRM-19302, - * where if a custom field of File type was present, left both events using the same file, - * breaking download URL's for the old event. - * - * @param int $oldEventID - * @param int $newCopyID - */ - public static function copyCustomFields($oldEventID, $newCopyID) { - // Obtain custom values for old event - $customParams = $htmlType = []; - $customValues = CRM_Core_BAO_CustomValueTable::getEntityValues($oldEventID, 'Event'); - - // If custom values present, we copy them - if (!empty($customValues)) { - // Get Field ID's and identify File type attributes, to handle file copying. - $fieldIds = implode(', ', array_keys($customValues)); - $sql = "SELECT id FROM civicrm_custom_field WHERE html_type = 'File' AND id IN ( {$fieldIds} )"; - $result = CRM_Core_DAO::executeQuery($sql); - - // Build array of File type fields - while ($result->fetch()) { - $htmlType[] = $result->id; - } - - // Build params array of custom values - foreach ($customValues as $field => $value) { - if ($value !== NULL) { - // Handle File type attributes - if (in_array($field, $htmlType)) { - $fileValues = CRM_Core_BAO_File::path($value, $oldEventID); - $customParams["custom_{$field}_-1"] = [ - 'name' => CRM_Utils_File::duplicate($fileValues[0]), - 'type' => $fileValues[1], - ]; - } - // Handle other types - else { - $customParams["custom_{$field}_-1"] = $value; - } - } - } - - // Save Custom Fields for new Event - CRM_Core_BAO_CustomValueTable::postProcess($customParams, 'civicrm_event', $newCopyID, 'Event'); - } - - // copy activity attachments ( if any ) - CRM_Core_BAO_File::copyEntityFile('civicrm_event', $oldEventID, 'civicrm_event', $newCopyID); - } - /** * This is sometimes called in a loop (during event search). *