From 8c816d1349d681bae148f6be04352120c33184f7 Mon Sep 17 00:00:00 2001 From: Seamus Lee Date: Fri, 29 Nov 2024 10:37:19 +1100 Subject: [PATCH] [REF] Add in CiviCRM Status checks to check for inconsistencies between the membership_payment participant_payment and line item tables Updates As per Dave --- ext/civi_event/civi_event.php | 38 +++++++++++++++++++++++++++++++++ ext/civi_member/civi_member.php | 38 +++++++++++++++++++++++++++++++++ 2 files changed, 76 insertions(+) diff --git a/ext/civi_event/civi_event.php b/ext/civi_event/civi_event.php index f201f3421e3e..1a63dc73639c 100644 --- a/ext/civi_event/civi_event.php +++ b/ext/civi_event/civi_event.php @@ -1,3 +1,41 @@ fetch()) { + $lineItemCheck = CRM_Core_DAO::singleValueQuery("SELECT id FROM civicrm_line_item WHERE contribution_id = %1 AND entity_id = %2 AND entity_table = 'civicrm_participant'", [ + 1 => [$parcitipantPayments->contribution_id, 'Positive'], + 2 => [$parcitipantPayments->participant_id, 'Positive'], + ]); + if (empty($lineItemCheck)) { + $lineItemsMissingPayments[] = [ + 'contribution_id' => $parcitipantPayments->contribution_id, + 'participant_id' => $parcitipantPayments->participant_id, + ]; + } + } + if (!empty($lineItemsMissingPayments)) { + $strings = ''; + foreach ($lineItemsMissingPayments as $lineItemsMissingPayment) { + $strings .= ''. $lineItemsMissingPayment['contribution_id'] . '' . $lineItemsMissingPayment['participant_id'] . ''; + } + $messages[] = new CRM_Utils_Check_Message( + 'civi_event_participant_payments_missing', + ts('The Following Participant Payments do not have a corresponding line item record linking the contribution to participant.') . ts('This should be corrected either by updating the relevant line item record or adding a line item record as appropriate.') . '

+

' . $strings . '
Contribution IDParticipant ID

', + ts('CiviCRM Participant Payment Records not matching'), + \Psr\Log\LogLevel::WARNING, + 'fa-database', + ); + } +} diff --git a/ext/civi_member/civi_member.php b/ext/civi_member/civi_member.php index 41ad6469a868..0173f7feeb2f 100644 --- a/ext/civi_member/civi_member.php +++ b/ext/civi_member/civi_member.php @@ -1,3 +1,41 @@ fetch()) { + $lineItemCheck = CRM_Core_DAO::singleValueQuery("SELECT id FROM civicrm_line_item WHERE contribution_id = %1 AND entity_id = %2 AND entity_table = 'civicrm_membership'", [ + 1 => [$membershipPayments->contribution_id, 'Positive'], + 2 => [$membershipPayments->membership_id, 'Positive'], + ]); + if (empty($lineItemCheck)) { + $lineItemsMissingPayments[] = [ + 'contribution_id' => $membershipPayments->contribution_id, + 'membership_id' => $membershipPayments->membership_id, + ]; + } + } + if (!empty($lineItemsMissingPayments)) { + $strings = ''; + foreach ($lineItemsMissingPayments as $lineItemsMissingPayment) { + $strings .= ''. $lineItemsMissingPayment['contribution_id'] . '' . $lineItemsMissingPayment['membership_id'] . ''; + } + $messages[] = new CRM_Utils_Check_Message( + 'civi_member_membership_payments_missing', + ts('The Following Membership Payments do not have a corresponding line item record linking the contribution to membership.') . ts('This should be corrected either by updating the relevant line item record or adding a line item record as appropriate.') . '

+

' . $strings . '
Contribution IDMembership ID

', + ts('CiviCRM Membership Payment Records not matching'), + \Psr\Log\LogLevel::WARNING, + 'fa-database', + ); + } +}