Файловый менеджер - Редактировать - /home/harasnat/www/horse/wp-content/plugins/mollie-payments-for-woocommerce/src/Payment/MolliePayment.php
Назад
<?php declare (strict_types=1); namespace Mollie\WooCommerce\Payment; use Mollie\Inpsyde\PaymentGateway\PaymentGateway; use Mollie\Api\Exceptions\ApiException; use Mollie\Api\Resources\Payment; use Mollie\Api\Resources\Refund; use Mollie\WooCommerce\Payment\Request\RequestFactory; use Mollie\WooCommerce\PaymentMethods\Voucher; use Mollie\WooCommerce\SDK\Api; use Mollie\WooCommerce\Settings\Settings; use Mollie\WooCommerce\Shared\Data; use Mollie\WooCommerce\Shared\SharedDataDictionary; use Mollie\Psr\Log\LoggerInterface as Logger; use Mollie\Psr\Log\LogLevel; use WC_Order; use WC_Subscriptions_Manager; use WP_Error; class MolliePayment extends \Mollie\WooCommerce\Payment\MollieObject { public const ACTION_AFTER_REFUND_PAYMENT_CREATED = 'mollie-payments-for-woocommerce' . '_refund_payment_created'; protected $pluginId; public function __construct($data, string $pluginId, Api $apiHelper, Settings $settingsHelper, Data $dataHelper, Logger $logger, RequestFactory $requestFactory) { $this->data = $data; $this->pluginId = $pluginId; $this->apiHelper = $apiHelper; $this->settingsHelper = $settingsHelper; $this->logger = $logger; $this->requestFactory = $requestFactory; $this->dataHelper = $dataHelper; } public function getPaymentObject($paymentId, $testMode = \false, $useCache = \true) { try { // Is test mode enabled? $settingsHelper = $this->settingsHelper; $testMode = $settingsHelper->isTestModeEnabled(); $apiKey = $this->settingsHelper->getApiKey(); self::$payment = $this->apiHelper->getApiClient($apiKey)->payments->get($paymentId); return parent::getPaymentObject($paymentId, $testMode = \false, $useCache = \true); } catch (ApiException $e) { $this->logger->debug(__FUNCTION__ . ": Could not load payment {$paymentId} (" . ($testMode ? 'test' : 'live') . "): " . $e->getMessage() . ' (' . get_class($e) . ')'); } return null; } /** * @param $order * @param $customerId * * @return array */ public function getPaymentRequestData($order, $customerId) { return $this->requestFactory->createRequest('payment', $order, $customerId); } /** * @return void */ public function setActiveMolliePayment($orderId) { self::$paymentId = $this->getMolliePaymentIdFromPaymentObject(); self::$customerId = $this->getMollieCustomerIdFromPaymentObject(); self::$order = wc_get_order($orderId); self::$order->update_meta_data('_mollie_payment_id', $this->data->id); self::$order->save(); parent::setActiveMolliePayment($orderId); } public function getMolliePaymentIdFromPaymentObject() { if (isset($this->data->id)) { return $this->data->id; } return null; } public function getMollieCustomerIdFromPaymentObject($payment = null) { if ($payment === null) { $payment = $this->data->id; } $payment = $this->getPaymentObject($payment); if (isset($payment->customerId)) { return $payment->customerId; } return null; } public function getSequenceTypeFromPaymentObject($payment = null) { if ($payment === null) { $payment = $this->data->id; } $payment = $this->getPaymentObject($payment); if (isset($payment->sequenceType)) { return $payment->sequenceType; } return null; } /** * @param Payment $payment * */ public function getMollieCustomerIbanDetailsFromPaymentObject($payment = null) { if ($payment === null) { $payment = $this->data->id; } $payment = $this->getPaymentObject($payment); /** * @var Payment $payment */ $ibanDetails['consumerName'] = $payment->details->consumerName; $ibanDetails['consumerAccount'] = $payment->details->consumerAccount; return $ibanDetails; } /** * @param \WC_Order $order * @param Payment $payment * @param string $paymentMethodTitle */ public function onWebhookPaid(WC_Order $order, $payment, $paymentMethodTitle) { $orderId = $order->get_id(); if ($payment->isPaid()) { // Add messages to log $this->logger->debug(__METHOD__ . ' called for payment ' . $orderId); if ($payment->method === 'paypal') { $this->addPaypalTransactionIdToOrder($order); } if (!empty($payment->amountChargedBack)) { $this->logger->debug(__METHOD__ . ' payment at Mollie has a chargeback, so no processing for order ' . $orderId); return; } // WooCommerce 2.2.0 has the option to store the Payment transaction id. $order->payment_complete($payment->id); // Add messages to log $this->logger->debug(__METHOD__ . ' WooCommerce payment_complete() processed and returned to ' . __METHOD__ . ' for payment ' . $orderId); $order->add_order_note(sprintf( /* translators: Placeholder 1: payment method title, placeholder 2: payment ID */ __('Order completed using %1$s payment (%2$s).', 'mollie-payments-for-woocommerce'), $paymentMethodTitle, $payment->id . ($payment->mode === 'test' ? ' - ' . __('test mode', 'mollie-payments-for-woocommerce') : '') )); // Mark the order as processed and paid via Mollie $this->setOrderPaidAndProcessed($order); // Remove (old) cancelled payments from this order $this->unsetCancelledMolliePaymentId($orderId); // Add messages to log $this->logger->debug(__METHOD__ . ' processing paid payment via Mollie plugin fully completed for order ' . $orderId); // Subscription processing $this->addMandateIdMetaToFirstPaymentSubscriptionOrder($order, $payment); if (class_exists('WC_Subscriptions') && class_exists('WC_Subscriptions_Admin')) { if ($this->dataHelper->isWcSubscription($orderId)) { $this->deleteSubscriptionOrderFromPendingPaymentQueue($order); WC_Subscriptions_Manager::activate_subscriptions_for_order($order); } } } else { // Add messages to log $this->logger->debug(__METHOD__ . ' payment at Mollie not paid, so no processing for order ' . $orderId); } } /** * @param \WC_Order $order * @param Payment $payment * @param string $paymentMethodTitle */ public function onWebhookAuthorized(WC_Order $order, Payment $payment, $paymentMethodTitle) { // Get order ID in the correct way depending on WooCommerce version $orderId = $order->get_id(); if ($payment->isAuthorized()) { // Add messages to log $this->logger->debug(__METHOD__ . ' called for order ' . $orderId); // WooCommerce 2.2.0 has the option to store the Payment transaction id. $order->payment_complete($payment->id); // Add messages to log $this->logger->debug(__METHOD__ . ' WooCommerce payment_complete() processed and returned to ' . __METHOD__ . ' for order ' . $orderId); $order->add_order_note(sprintf( /* translators: Placeholder 1: payment method title, placeholder 2: payment ID */ __('Order authorized using %1$s payment (%2$s). Set order to completed in WooCommerce when you have shipped the products, to capture the payment. Do this within 28 days, or the order will expire. To handle individual order lines, process the order via the Mollie Dashboard.', 'mollie-payments-for-woocommerce'), $paymentMethodTitle, $payment->id . ($payment->mode === 'test' ? ' - ' . __('test mode', 'mollie-payments-for-woocommerce') : '') )); //check for webhook that order is Authorized on Paid webhook $order->update_meta_data('_mollie_authorized', '1'); // Mark the order as processed and paid via Mollie $this->setOrderPaidAndProcessed($order); // Remove (old) cancelled payments from this order $this->unsetCancelledMolliePaymentId($orderId); // Add messages to log $this->logger->debug(__METHOD__ . ' processing order status update via Mollie plugin fully completed for order ' . $orderId); // Subscription processing $this->deleteSubscriptionFromPending($order); } else { // Add messages to log $this->logger->debug(__METHOD__ . ' order at Mollie not authorized, so no processing for order ' . $orderId); } } /** * @param WC_Order $order * @param \Mollie\Api\Resources\Payment $payment * @param string $paymentMethodTitle */ public function onWebhookCanceled(WC_Order $order, $payment, $paymentMethodTitle) { // Get order ID in the correct way depending on WooCommerce version $orderId = $order->get_id(); // Add messages to log $this->logger->debug(__METHOD__ . " called for payment {$orderId}"); // if the status is Completed|Refunded|Cancelled DONT change the status to cancelled if ($this->isFinalOrderStatus($order)) { $this->logger->debug(__METHOD__ . " called for payment {$orderId} has final status. Nothing to be done"); return; } //status is Pending|Failed|Processing|On-hold so Cancel $this->unsetActiveMolliePayment($orderId, $payment->id); $this->setCancelledMolliePaymentId($orderId, $payment->id); // What status does the user want to give orders with cancelled payments? $settingsHelper = $this->settingsHelper; $orderStatusCancelledPayments = $settingsHelper->getOrderStatusCancelledPayments(); // New order status if ($orderStatusCancelledPayments === 'pending' || $orderStatusCancelledPayments === null) { $newOrderStatus = SharedDataDictionary::STATUS_PENDING; } elseif ($orderStatusCancelledPayments === 'cancelled') { $newOrderStatus = SharedDataDictionary::STATUS_CANCELLED; } // if I cancel manually the order is canceled in Woo before calling Mollie if ($order->get_status() === 'cancelled') { $newOrderStatus = SharedDataDictionary::STATUS_CANCELLED; } // Get current gateway $gateway = wc_get_payment_gateway_by_order($order); // Overwrite plugin-wide $newOrderStatus = apply_filters($this->pluginId . '_order_status_cancelled', $newOrderStatus); // Overwrite gateway-wide $newOrderStatus = apply_filters($this->pluginId . '_order_status_cancelled_' . $gateway->id, $newOrderStatus); // Update order status, but only if there is no payment started by another gateway $this->maybeUpdateStatus($order, $gateway, $newOrderStatus); // User cancelled payment on Mollie or issuer page, add a cancel note.. do not cancel order. $order->add_order_note(sprintf( /* translators: Placeholder 1: payment method title, placeholder 2: payment ID */ __('%1$s payment (%2$s) cancelled .', 'mollie-payments-for-woocommerce'), $paymentMethodTitle, $payment->id . ($payment->mode === 'test' ? ' - ' . __('test mode', 'mollie-payments-for-woocommerce') : '') )); // Subscription processing $this->deleteSubscriptionFromPending($order); } /** * @param WC_Order $order * @param \Mollie\Api\Resources\Payment $payment * @param string $paymentMethodTitle */ public function onWebhookFailed(WC_Order $order, $payment, $paymentMethodTitle) { $orderId = $order->get_id(); // Add messages to log $this->logger->debug(__METHOD__ . ' called for order ' . $orderId); // Get current gateway $gateway = wc_get_payment_gateway_by_order($order); // New order status $newOrderStatus = SharedDataDictionary::STATUS_FAILED; // Overwrite plugin-wide $newOrderStatus = apply_filters($this->pluginId . '_order_status_failed', $newOrderStatus); // Overwrite gateway-wide $newOrderStatus = apply_filters($this->pluginId . '_order_status_failed_' . $gateway->id, $newOrderStatus); // If WooCommerce Subscriptions is installed, process this failure as a subscription, otherwise as a regular order // Update order status for order with failed payment, don't restore stock $this->failedSubscriptionProcess($orderId, $gateway, $order, $newOrderStatus, $paymentMethodTitle, $payment); if (isset($payment->details->failureReason)) { $this->logger->debug(__METHOD__ . ' called for order ' . $orderId . ' and payment ' . $payment->id . ', regular payment failed because of ' . esc_attr($payment->details->failureReason) . '.'); } else { $this->logger->debug(__METHOD__ . ' called for order ' . $orderId . ' and payment ' . $payment->id . ', regular payment failed.'); } } /** * @param WC_Order $order * @param \Mollie\Api\Resources\Payment $payment * @param string $paymentMethodTitle */ public function onWebhookExpired(WC_Order $order, $payment, $paymentMethodTitle) { $orderId = $order->get_id(); $molliePaymentId = $order->get_meta('_mollie_payment_id', \true); // Add messages to log $this->logger->debug(__METHOD__ . ' called for order ' . $orderId); // Check that this order has not been marked paid already if (!$order->needs_payment()) { $this->logger->log(LogLevel::DEBUG, __METHOD__ . ' called for order ' . $orderId . ', not processed because the order is already paid.'); return; } // Check that this payment is the most recent, based on Mollie Payment ID from post meta, do not cancel the order if it isn't if ($molliePaymentId !== $payment->id) { $this->logger->debug(__METHOD__ . ' called for order ' . $orderId . ' and payment ' . $payment->id . ', not processed because of a newer pending payment ' . $molliePaymentId); $order->add_order_note(sprintf( /* translators: Placeholder 1: payment method title, placeholder 2: payment ID */ __('%1$s payment expired (%2$s) but not cancelled because of another pending payment (%3$s).', 'mollie-payments-for-woocommerce'), $paymentMethodTitle, $payment->id . ($payment->mode === 'test' ? ' - ' . __('test mode', 'mollie-payments-for-woocommerce') : ''), $molliePaymentId )); return; } // New order status $newOrderStatus = SharedDataDictionary::STATUS_CANCELLED; //Get current gateway $gateway = wc_get_payment_gateway_by_order($order); // Overwrite plugin-wide $newOrderStatus = apply_filters($this->pluginId . '_order_status_expired', $newOrderStatus); // Overwrite gateway-wide $newOrderStatus = apply_filters($this->pluginId . '_order_status_expired_' . $gateway->id, $newOrderStatus); // Update order status, but only if there is no payment started by another gateway $this->maybeUpdateStatus($order, $gateway, $newOrderStatus); $order->add_order_note(sprintf( /* translators: Placeholder 1: payment method title, placeholder 2: payment ID */ __('%1$s payment expired (%2$s).', 'mollie-payments-for-woocommerce'), $paymentMethodTitle, $payment->id . ($payment->mode === 'test' ? ' - ' . __('test mode', 'mollie-payments-for-woocommerce') : '') )); // Remove (old) cancelled payments from this order $this->unsetCancelledMolliePaymentId($orderId); } /** * Process a payment object refund * * @param WC_Order $order * @param int $orderId * @param object $paymentObject * @param null $amount * @param string $reason * * @return bool | WP_Error */ public function refund(\WC_Order $order, $orderId, $paymentObject, $amount = null, $reason = '') { $this->logger->debug(__METHOD__ . ' - ' . $orderId . ' - Try to process refunds for individual order line(s).'); try { $paymentObject = $this->getActiveMolliePayment($orderId); if (!$paymentObject) { $errorMessage = "Could not find active Mollie payment for WooCommerce order ' . {$orderId}"; $this->logger->debug(__METHOD__ . ' - ' . $errorMessage); return new WP_Error('1', $errorMessage); } if ($paymentObject->isAuthorized()) { return \true; } if (!$paymentObject->isPaid()) { $errorMessage = "Can not refund payment {$paymentObject->id} for WooCommerce order {$orderId} as it is not paid."; $this->logger->debug(__METHOD__ . ' - ' . $errorMessage); return new WP_Error('1', $errorMessage); } $this->logger->debug(__METHOD__ . ' - Create refund - payment object: ' . $paymentObject->id . ', WooCommerce order: ' . $orderId . ', amount: ' . $this->dataHelper->getOrderCurrency($order) . $amount . (!empty($reason) ? ', reason: ' . $reason : '')); do_action($this->pluginId . '_create_refund', $paymentObject, $order); $apiKey = $this->settingsHelper->getApiKey(); // Send refund to Mollie $refund = $this->apiHelper->getApiClient($apiKey)->payments->refund($paymentObject, ['amount' => ['currency' => $this->dataHelper->getOrderCurrency($order), 'value' => $this->dataHelper->formatCurrencyValue($amount, $this->dataHelper->getOrderCurrency($order))], 'description' => $reason]); $this->logger->debug(__METHOD__ . ' - Refund created - refund: ' . $refund->id . ', payment: ' . $paymentObject->id . ', order: ' . $orderId . ', amount: ' . $this->dataHelper->getOrderCurrency($order) . $amount . (!empty($reason) ? ', reason: ' . $reason : '')); /** * After Payment Refund has been created * * @param Refund $refund * @param WC_Order $order */ do_action(self::ACTION_AFTER_REFUND_PAYMENT_CREATED, $refund, $order); do_action_deprecated($this->pluginId . '_refund_created', [$refund, $order], '5.3.1', self::ACTION_AFTER_REFUND_PAYMENT_CREATED); $order->add_order_note(sprintf( /* translators: Placeholder 1: currency, placeholder 2: refunded amount, placeholder 3: optional refund reason, placeholder 4: payment ID, placeholder 5: refund ID */ __('Refunded %1$s%2$s%3$s - Payment: %4$s, Refund: %5$s', 'mollie-payments-for-woocommerce'), $this->dataHelper->getOrderCurrency($order), $amount, !empty($reason) ? ' (reason: ' . $reason . ')' : '', $refund->paymentId, $refund->id )); return \true; } catch (ApiException $e) { return new WP_Error(1, $e->getMessage()); } } /** * @param WC_Order $order * @param PaymentGateway $gateway * @param $newOrderStatus * @param $orderId */ protected function maybeUpdateStatus(WC_Order $order, $gateway, $newOrderStatus) { if ($this->isOrderPaymentStartedByOtherGateway($order) || !is_a($gateway, PaymentGateway::class)) { $this->informNotUpdatingStatus($gateway->id, $order); return; } $this->updateOrderStatus($order, $newOrderStatus); } public function setPayment($data) { $this->data = $data; } }
| ver. 1.4 |
Github
|
.
| PHP 8.1.33 | Генерация страницы: 0.01 |
proxy
|
phpinfo
|
Настройка