/** * Repeat a transaction as part of a recurring series. * * Only call this via the api as it is being refactored. The intention is that the repeatTransaction function * (possibly living on the ContributionRecur BAO) would be called first to create a pending contribution with a * subsequent call to the contribution.completetransaction api. * * The completeTransaction functionality has historically been overloaded to both complete and repeat payments. * * @param CRM_Contribute_BAO_Contribution $contribution * @param array $input * @param array $contributionParams * * @return array */ protected static function repeatTransaction(&$contribution, &$input, $contributionParams) { if (!empty($contribution->id)) { return FALSE; } if (empty($contribution->id)) { // Unclear why this would only be set for repeats. if (!empty($input['amount'])) { $contribution->total_amount = $contributionParams['total_amount'] = $input['amount']; } $templateContribution = CRM_Contribute_BAO_ContributionRecur::getTemplateContribution($contributionParams['contribution_recur_id']); if (!empty($contributionParams['contribution_recur_id'])) { $recurringContribution = civicrm_api3('ContributionRecur', 'getsingle', array('id' => $contributionParams['contribution_recur_id'])); if (!empty($recurringContribution['campaign_id'])) { // CRM-17718 the campaign id on the contribution recur record should get precedence. $contributionParams['campaign_id'] = $recurringContribution['campaign_id']; } if (!empty($recurringContribution['financial_type_id'])) { // CRM-17718 the campaign id on the contribution recur record should get precedence. $contributionParams['financial_type_id'] = $recurringContribution['financial_type_id']; } } $contributionParams['skipLineItem'] = TRUE; $contributionParams['status_id'] = 'Pending'; if (isset($contributionParams['financial_type_id'])) { // Give precedence to passed in type. $contribution->financial_type_id = $contributionParams['financial_type_id']; } else { $contributionParams['financial_type_id'] = $templateContribution['financial_type_id']; } $contributionParams['contact_id'] = $templateContribution['contact_id']; $contributionParams['source'] = empty($templateContribution['source']) ? ts('Recurring contribution') : $templateContribution['source']; $createContribution = civicrm_api3('Contribution', 'create', $contributionParams); $contribution->id = $createContribution['id']; $input['line_item'] = CRM_Contribute_BAO_ContributionRecur::addRecurLineItems($contribution->contribution_recur_id, $contribution); CRM_Contribute_BAO_ContributionRecur::copyCustomValues($contributionParams['contribution_recur_id'], $contribution->id); return TRUE; } }
/** * Repeat a transaction as part of a recurring series. * * Only call this via the api as it is being refactored. The intention is that the repeatTransaction function * (possibly living on the ContributionRecur BAO) would be called first to create a pending contribution with a * subsequent call to the contribution.completetransaction api. * * The completeTransaction functionality has historically been overloaded to both complete and repeat payments. * * @param CRM_Contribute_BAO_Contribution $contribution * @param array $input * @param array $contributionParams * @param int $paymentProcessorID * * @return array * @throws CiviCRM_API3_Exception */ protected static function repeatTransaction(&$contribution, &$input, $contributionParams, $paymentProcessorID) { if (!empty($contribution->id)) { return FALSE; } if (empty($contribution->id)) { // Unclear why this would only be set for repeats. if (!empty($input['amount'])) { $contribution->total_amount = $contributionParams['total_amount'] = $input['amount']; } if (!empty($contributionParams['contribution_recur_id'])) { $recurringContribution = civicrm_api3('ContributionRecur', 'getsingle', array('id' => $contributionParams['contribution_recur_id'])); if (!empty($recurringContribution['campaign_id'])) { // CRM-17718 the campaign id on the contribution recur record should get precedence. $contributionParams['campaign_id'] = $recurringContribution['campaign_id']; } if (!empty($recurringContribution['financial_type_id'])) { // CRM-17718 the campaign id on the contribution recur record should get precedence. $contributionParams['financial_type_id'] = $recurringContribution['financial_type_id']; } } $templateContribution = CRM_Contribute_BAO_ContributionRecur::getTemplateContribution($contributionParams['contribution_recur_id'], array_intersect_key($contributionParams, array('total_amount' => TRUE, 'financial_type_id' => TRUE))); $input['line_item'] = $contributionParams['line_item'] = $templateContribution['line_item']; $contributionParams['status_id'] = 'Pending'; if (isset($contributionParams['financial_type_id'])) { // Give precedence to passed in type. $contribution->financial_type_id = $contributionParams['financial_type_id']; } else { $contributionParams['financial_type_id'] = $templateContribution['financial_type_id']; } $contributionParams['contact_id'] = $templateContribution['contact_id']; $contributionParams['source'] = empty($templateContribution['source']) ? ts('Recurring contribution') : $templateContribution['source']; //CRM-18805 -- Contribution page not recorded on recurring transactions, Recurring contribution payments //do not create CC or BCC emails or profile notifications. //The if is just to be safe. Not sure if we can ever arrive with this unset if (isset($contribution->contribution_page_id)) { $contributionParams['contribution_page_id'] = $contribution->contribution_page_id; } $createContribution = civicrm_api3('Contribution', 'create', $contributionParams); $contribution->id = $createContribution['id']; CRM_Contribute_BAO_ContributionRecur::copyCustomValues($contributionParams['contribution_recur_id'], $contribution->id); return TRUE; } }