'project_id', 'title' => 'Project ID', 'type' => CRM_Utils_Type::T_STRING, 'api.required' => 1, 'description' => 'The Twingle project ID.', ); $params['trx_id'] = array( 'name' => 'trx_id', 'title' => 'Transaction ID', 'type' => CRM_Utils_Type::T_STRING, 'api.required' => 1, 'description' => 'The unique transaction ID of the donation', ); $params['cancelled_at'] = array( 'name' => 'cancelled_at', 'title' => 'Cancelled at', 'type' => CRM_Utils_Type::T_INT, 'api.required' => 1, 'description' => 'The date when the donation was cancelled, format: YYYYMMDD.', ); $params['cancel_reason'] = array( 'name' => 'cancel_reason', 'title' => 'Cancel reason', 'type' => CRM_Utils_Type::T_STRING, 'api.required' => 1, 'description' => 'The reason for the donation being cancelled.', ); } /** * TwingleDonation.Cancel API * * @param array $params * @return array API result descriptor * @see civicrm_api3_create_success * @see civicrm_api3_create_error */ function civicrm_api3_twingle_donation_Cancel($params) { // Log call if debugging is enabled within civicrm.settings.php. if (defined('TWINGLE_API_LOGGING') && TWINGLE_API_LOGGING) { CRM_Core_Error::debug_log_message('TwingleDonation.Cancel: ' . json_encode($params, JSON_PRETTY_PRINT)); } try { // Validate date for parameter "cancelled_at". if (!DateTime::createFromFormat('Ymd', $params['cancelled_at'])) { throw new CiviCRM_API3_Exception( E::ts('Invalid date for parameter "cancelled_at".'), 'invalid_format' ); } // Retrieve (recurring) contribution. try { $contribution = civicrm_api3('Contribution', 'getsingle', array( 'trxn_id' => $params['trx_id'], )); $contribution_type = 'Contribution'; } catch (CiviCRM_API3_Exception $exception) { $contribution = civicrm_api3('ContributionRecur', 'getsingle', array( 'trxn_id' => $params['trx_id'], )); $contribution_type = 'ContributionRecur'; } // End SEPA mandate if applicable. if ( CRM_Twingle_Submission::civiSepaEnabled() && CRM_Sepa_Logic_Settings::isSDD($contribution) ) { $mandate_id = CRM_Sepa_Logic_Settings::getMandateFor($contribution['id']); // Mandates can not be terminated in the past. $end_date = date('Ymd', max( time(), date_create_from_format('Ymd', $params['cancelled_at'])->getTimestamp() )); if (!CRM_Sepa_BAO_SEPAMandate::terminateMandate( $mandate_id, $end_date, $params['cancel_reason'] )) { throw new CiviCRM_API3_Exception( E::ts('Could not terminate SEPA mandate'), 'api_error' ); } // Retrieve updated contribution for return value. $contribution = civicrm_api3($contribution_type, 'getsingle', array( 'id' => $contribution['id'], )); } else { $contribution = civicrm_api3($contribution_type, 'create', array( 'id' => $contribution['id'], 'cancel_date' => $params['cancelled_at'], 'contribution_status_id' => 'Cancelled', 'cancel_reason' => $params['cancel_reason'], )); } $result = civicrm_api3_create_success($contribution); } catch (CiviCRM_API3_Exception $exception) { $result = civicrm_api3_create_error($exception->getMessage()); } return $result; }