DataTransferObjects
5 years ago
Models
5 years ago
Repositories
5 years ago
Webhooks
5 years ago
AccountAdminNotices.php
5 years ago
AdminSettingFields.php
5 years ago
AdvancedCardFields.php
5 years ago
AjaxRequestHandler.php
5 years ago
DonationDetailsPage.php
5 years ago
DonationFormPaymentMethod.php
5 years ago
DonationProcessor.php
5 years ago
PayPalClient.php
5 years ago
PayPalCommerce.php
5 years ago
RefreshToken.php
5 years ago
RefundPaymentHandler.php
5 years ago
ScriptLoader.php
5 years ago
Utils.php
5 years ago
onBoardingRedirectHandler.php
5 years ago
RefundPaymentHandler.php
133 lines
| 1 | <?php |
| 2 | |
| 3 | namespace Give\PaymentGateways\PayPalCommerce; |
| 4 | |
| 5 | use Exception; |
| 6 | use Give_Payment; |
| 7 | use Give\PaymentGateways\PayPalCommerce\Repositories\PayPalOrder; |
| 8 | |
| 9 | /** |
| 10 | * Class RefundPaymentHandler |
| 11 | * |
| 12 | * @since 2.9.0 |
| 13 | */ |
| 14 | class RefundPaymentHandler { |
| 15 | /** |
| 16 | * @since 2.9.0 |
| 17 | * |
| 18 | * @var PayPalOrder |
| 19 | */ |
| 20 | private $ordersRepository; |
| 21 | |
| 22 | /** |
| 23 | * RefundPaymentHandler constructor. |
| 24 | * |
| 25 | * @since 2.9.0 |
| 26 | * |
| 27 | * @param PayPalOrder $ordersRepository |
| 28 | */ |
| 29 | public function __construct( PayPalOrder $ordersRepository ) { |
| 30 | $this->ordersRepository = $ordersRepository; |
| 31 | } |
| 32 | |
| 33 | /** |
| 34 | * Refunds the payment when the donation is marked as refunded |
| 35 | * |
| 36 | * @since 2.9.0 |
| 37 | * |
| 38 | * @param int $donationId |
| 39 | * |
| 40 | * @throws Exception |
| 41 | */ |
| 42 | public function refundPayment( $donationId ) { |
| 43 | if ( ! $this->isAdminOptInToRefundPaymentOnPayPal() ) { |
| 44 | return; |
| 45 | } |
| 46 | |
| 47 | $payPalPaymentId = give_get_payment_transaction_id( $donationId ); |
| 48 | $paymentGateway = give_get_payment_gateway( $donationId ); |
| 49 | $newDonationStatus = give_clean( $_POST['give-payment-status'] ); |
| 50 | |
| 51 | if ( 'refunded' !== $newDonationStatus || PayPalCommerce::GATEWAY_ID !== $paymentGateway ) { |
| 52 | return; |
| 53 | } |
| 54 | |
| 55 | try { |
| 56 | $this->ordersRepository->refundPayment( $payPalPaymentId ); |
| 57 | } catch ( Exception $ex ) { |
| 58 | wp_safe_redirect( admin_url( "edit.php?post_type=give_forms&page=give-payment-history&view=view-payment-details&id={$donationId}&paypal-error=refund-failure" ) ); |
| 59 | exit(); |
| 60 | } |
| 61 | } |
| 62 | |
| 63 | |
| 64 | /** |
| 65 | * show Paypal Commerce payment refund failure notice. |
| 66 | * |
| 67 | * @since 2.9.0 |
| 68 | */ |
| 69 | public function showPaymentRefundFailureNotice() { |
| 70 | if ( ! isset( $_GET['paypal-error'] ) || 'refund-failure' !== $_GET['paypal-error'] ) { |
| 71 | return; |
| 72 | } |
| 73 | |
| 74 | give( 'notices' )->register_notice( |
| 75 | [ |
| 76 | 'id' => 'give-paypal-commerce-refund-failure', |
| 77 | 'type' => 'warning', |
| 78 | 'show' => true, |
| 79 | 'description' => sprintf( |
| 80 | '<strong>%1$s</strong> %2$s %3$s<a href="%4$s" target="_blank">%5$s</a>%6$s', |
| 81 | esc_html__( 'PayPal Donations:', 'give' ), |
| 82 | esc_html__( 'We were unable to process refund.', 'give' ), |
| 83 | esc_html__( 'Please ', 'give' ), |
| 84 | admin_url( 'edit.php?post_type=give_forms&page=give-tools&tab=logs' ), |
| 85 | esc_html__( 'check log', 'give' ), |
| 86 | esc_html__( ' for detailed information.', 'give' ) |
| 87 | ), |
| 88 | ] |
| 89 | ); |
| 90 | } |
| 91 | |
| 92 | /** |
| 93 | * This function will display field to opt for refund. |
| 94 | * |
| 95 | * @param int $donationId Donation ID. |
| 96 | * |
| 97 | * @since 2.5.0 |
| 98 | * |
| 99 | * @return void |
| 100 | */ |
| 101 | public function optInForRefundFormField( $donationId ) { |
| 102 | if ( PayPalCommerce::GATEWAY_ID !== give_get_payment_gateway( $donationId ) ) { |
| 103 | return; |
| 104 | } |
| 105 | |
| 106 | ?> |
| 107 | <div id="give-paypal-commerce-opt-refund-wrap" class="give-paypal-commerce-opt-refund give-admin-box-inside give-hidden"> |
| 108 | <p> |
| 109 | <input type="checkbox" id="give-paypal-commerce-opt-refund" name="give_paypal_donations_optin_for_refund" value="1"/> |
| 110 | <label for="give-paypal-commerce-opt-refund"> |
| 111 | <?php esc_html_e( 'Refund Charge in PayPal?', 'give' ); ?> |
| 112 | </label> |
| 113 | </p> |
| 114 | </div> |
| 115 | |
| 116 | <?php |
| 117 | } |
| 118 | |
| 119 | |
| 120 | /** |
| 121 | * Return whether or not admin optin for refund payment in PayPal |
| 122 | * |
| 123 | * @since 2.9.0 |
| 124 | * |
| 125 | * @return bool |
| 126 | */ |
| 127 | private function isAdminOptInToRefundPaymentOnPayPal() { |
| 128 | return ! empty( $_POST['give_paypal_donations_optin_for_refund'] ) ? |
| 129 | (bool) absint( $_POST['give_paypal_donations_optin_for_refund'] ) |
| 130 | : false; |
| 131 | } |
| 132 | } |
| 133 |