103 lines
2.9 KiB
PHP
103 lines
2.9 KiB
PHP
|
<?php
|
||
|
/**
|
||
|
* Deprecated PayPal Functions
|
||
|
*
|
||
|
* @package easy-digital-downloads
|
||
|
* @subpackage Gateways\PayPal
|
||
|
* @copyright Copyright (c) 2021, Sandhills Development, LLC
|
||
|
* @license GPL2+
|
||
|
* @since 3.0
|
||
|
*/
|
||
|
|
||
|
namespace EDD\Gateways\PayPal;
|
||
|
|
||
|
/**
|
||
|
* Adds a "Refund in PayPal" checkbox when switching the payment's status to "Refunded".
|
||
|
*
|
||
|
* @deprecated 3.0 In favor of a `edd_after_submit_refund_table` hook.
|
||
|
*
|
||
|
* @param int $payment_id
|
||
|
*
|
||
|
* @since 2.11
|
||
|
* @return void
|
||
|
*/
|
||
|
function add_refund_javascript( $payment_id ) {
|
||
|
_edd_deprecated_function( __FUNCTION__, '3.0', null, debug_backtrace() );
|
||
|
|
||
|
$payment = edd_get_payment( $payment_id );
|
||
|
|
||
|
if ( ! $payment || 'paypal_commerce' !== $payment->gateway ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$mode = ( 'live' === $payment->mode ) ? API::MODE_LIVE : API::MODE_SANDBOX;
|
||
|
|
||
|
try {
|
||
|
$api = new API( $mode );
|
||
|
} catch ( Exceptions\Authentication_Exception $e ) {
|
||
|
// If we don't have credentials.
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$label = __( 'Refund Transaction in PayPal', 'easy-digital-downloads' );
|
||
|
?>
|
||
|
<script type="text/javascript">
|
||
|
jQuery( document ).ready( function ( $ ) {
|
||
|
$( 'select[name=edd-payment-status]' ).change( function () {
|
||
|
if ( 'refunded' === $( this ).val() ) {
|
||
|
$( this ).parent().parent().append( '<input type="checkbox" id="edd-paypal-commerce-refund" name="edd-paypal-commerce-refund" value="1" style="margin-top:0">' );
|
||
|
$( this ).parent().parent().append( '<label for="edd-paypal-commerce-refund"><?php echo esc_html( $label ); ?></label>' );
|
||
|
} else {
|
||
|
$( '#edd-paypal-commerce-refund' ).remove();
|
||
|
$( 'label[for="edd-paypal-commerce-refund"]' ).remove();
|
||
|
}
|
||
|
} );
|
||
|
} );
|
||
|
</script>
|
||
|
<?php
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Refunds the transaction in PayPal, if the option was selected.
|
||
|
*
|
||
|
* @deprecated 3.0 In favor of `edd_refund_order` hook.
|
||
|
*
|
||
|
* @param \EDD_Payment $payment The payment being refunded.
|
||
|
*
|
||
|
* @since 2.11
|
||
|
* @return void
|
||
|
*/
|
||
|
function maybe_refund_transaction( \EDD_Payment $payment ) {
|
||
|
_edd_deprecated_function( __FUNCTION__, '3.0', null, debug_backtrace() );
|
||
|
|
||
|
if ( ! current_user_can( 'edit_shop_payments', $payment->ID ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
if ( 'paypal_commerce' !== $payment->gateway || empty( $_POST['edd-paypal-commerce-refund'] ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// Payment status should be coming from "publish" or "revoked".
|
||
|
// @todo In 3.0 use `edd_get_refundable_order_statuses()`
|
||
|
if ( ! in_array( $payment->old_status, array( 'publish', 'complete', 'revoked', 'edd_subscription' ) ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// If the payment has already been refunded, bail.
|
||
|
if ( $payment->get_meta( '_edd_paypal_refunded', true ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
// Process the refund.
|
||
|
try {
|
||
|
refund_transaction( $payment );
|
||
|
} catch ( \Exception $e ) {
|
||
|
edd_insert_payment_note( $payment->ID, sprintf(
|
||
|
/* Translators: %s - The error message */
|
||
|
__( 'Failed to refund transaction in PayPal. Error Message: %s', 'easy-digital-downloads' ),
|
||
|
$e->getMessage()
|
||
|
) );
|
||
|
}
|
||
|
}
|