'org.agbu.batchexportperm', 'name' => 'batchexportperm_batch_details', 'entity' => 'CustomGroup', 'params' => [ 'version' => 3, 'name' => 'batchexportperm_batch_details', 'title' => 'Batch Details', 'extends' => 'Contribution', 'style' => 'Inline', 'collapse_display' => TRUE, 'is_active' => TRUE, 'is_multiple' => FALSE, 'collapse_adv_display' => FALSE, 'is_reserved' => TRUE, ], ]; $entities[] = [ 'module' => 'org.agbu.batchexportperm', 'name' => 'export_date', 'entity' => 'CustomField', 'params' => [ 'version' => 3, 'name' => 'export_date', 'label' => 'Export Date', 'data_type' => 'Date', 'html_type' => 'Select Date', 'is_required' => FALSE, 'is_searchable' => FALSE, 'is_search_range' => FALSE, 'is_active' => TRUE, 'is_view' => TRUE, 'date_format' => 'mm/dd/yy', 'text_length' => 255, 'column_name' => 'export_date', 'note_columns' => 150, 'note_rows' => 4, 'custom_group_id' => 'batchexportperm_batch_details', ], ]; } /** * Implements hook_civicrm_caseTypes(). * * Generate a list of case-types. * * Note: This hook only runs in CiviCRM 4.4+. * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_caseTypes */ function batchexportperm_civicrm_caseTypes(&$caseTypes) { _batchexportperm_civix_civicrm_caseTypes($caseTypes); } /** * Implements hook_civicrm_angularModules(). * * Generate a list of Angular modules. * * Note: This hook only runs in CiviCRM 4.5+. It may * use features only available in v4.6+. * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_angularModules */ function batchexportperm_civicrm_angularModules(&$angularModules) { _batchexportperm_civix_civicrm_angularModules($angularModules); } /** * Implements hook_civicrm_alterSettingsFolders(). * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_alterSettingsFolders */ function batchexportperm_civicrm_alterSettingsFolders(&$metaDataFolders = NULL) { _batchexportperm_civix_civicrm_alterSettingsFolders($metaDataFolders); } /** * Implements hook_civicrm_entityTypes(). * * Declare entity types provided by this module. * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_entityTypes */ function batchexportperm_civicrm_entityTypes(&$entityTypes) { _batchexportperm_civix_civicrm_entityTypes($entityTypes); } /** * Implements hook_civicrm_permission(). * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_permission */ function batchexportperm_civicrm_permission(&$permissions) { $prefix = ts('CiviCRM') . ': '; $permissions['edit exported contributions'] = [ $prefix . ts('Edit exported contributions'), ts('Edit exported contributions'), ]; } /** * Implements hook_civicrm_links(). * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_links */ function batchexportperm_civicrm_links($op, $objectName, $objectId, &$links, &$mask, &$values) { if ($op == 'contribution.selector.row' && $objectName == 'Contribution') { if (!_batchexportperm_civicrm_allow_contribution_to_edit($objectId)) { foreach ($links as $key => $link) { if ($link['name'] == 'Edit') { unset($links[$key]); } } } } } /** * Implements hook_civicrm_pre(). * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_pre */ function batchexportperm_civicrm_pre($op, $objectName, $id, &$params) { if ($op == 'edit' && $objectName == 'Contribution') { _batchexportperm_civicrm_check_permission($id); } } /** * Implements hook_civicrm_apiWrappers(). * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_apiWrappers */ function batchexportperm_civicrm_apiWrappers(&$wrappers, $apiRequest) { if ($apiRequest['entity'] == 'Contribution' && $apiRequest['action'] == 'create') { $contibutionId = CRM_Utils_Array::value('id', $apiRequest['params']); _batchexportperm_civicrm_check_permission($contibutionId, 'exception'); } } /** * Implements hook_civicrm_preProcess(). * * @link http://wiki.civicrm.org/confluence/display/CRMDOC/hook_civicrm_preProcess */ function batchexportperm_civicrm_preProcess($formName, &$form) { if ($formName == 'CRM_Contribute_Form_Contribution' && $form->_action & CRM_Core_Action::UPDATE) { $contributionId = $form->_id; _batchexportperm_civicrm_check_permission($contributionId); } } /** * Check if user has permission to update contribution. * * @param int $contributionId * @param string $errorType */ function _batchexportperm_civicrm_check_permission($contributionId, $errorType = NULL) { if (empty($contributionId) || _batchexportperm_civicrm_allow_contribution_to_edit($contributionId)) { return FALSE; } $message = ts('You do not have the necessary permission to edit this contribution.'); if ($errorType == 'exception') { throw new API_Exception($message); } else { CRM_Core_Error::statusBounce($message); } } /** * Check if user has permission to update contribution. * * @param int $contributionId */ function _batchexportperm_civicrm_allow_contribution_to_edit($contributionId) { $customFieldId = civicrm_api3('CustomField', 'getvalue', [ 'return' => "id", 'custom_group_id' => "batchexportperm_batch_details", 'name' => "export_date", ]); $exportDate = civicrm_api3('Contribution', 'getvalue', [ 'return' => "custom_{$customFieldId}", 'id' => $contributionId, ]); if (empty($exportDate) || CRM_Core_Permission::check('edit exported contributions')) { return TRUE; } return FALSE; }