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.') . '
+ Contribution ID | Participant ID | ' . $strings . '
',
+ 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.') . '
+ Contribution ID | Membership ID | ' . $strings . '
',
+ ts('CiviCRM Membership Payment Records not matching'),
+ \Psr\Log\LogLevel::WARNING,
+ 'fa-database',
+ );
+ }
+}