HEX
Server: LiteSpeed
System: Linux server315.web-hosting.com 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
User: globfdxw (6114)
PHP: 8.1.34
Disabled: NONE
Upload Files
File: /home/globfdxw/www/wp-content/plugins/give/src/Helpers/Frontend/ConfirmDonation.php
<?php

namespace Give\Helpers\Frontend;

use Give\Helpers\Form\Utils as FormUtils;
use Give\Session\SessionDonation\DonationAccessor;

/**
 * Class ConfirmDonation
 *
 * @package Give\Helpers\Frontend
 */
class ConfirmDonation
{
    /**
     * Store posted data to donation session to access it in iframe if we are on payment confirmation page.
     * This function will return true if data stored successfully in purchase session (session key name "give_purchase" ) otherwise false.
     *
     * Note: only for internal use.
     *
     * @since 2.7.0
     * @return bool
     */
    public static function storePostedDataInDonationSession()
    {
        $isShowingDonationReceipt = ! empty($_REQUEST['giveDonationAction']) && 'showReceipt' === give_clean(
                $_REQUEST['giveDonationAction']
            );

        if ( ! $isShowingDonationReceipt || ! isset($_GET['payment-confirmation'])) {
            return false;
        }

        $paymentGatewayId = ucfirst(give_clean($_GET['payment-confirmation']));

        $session = new DonationAccessor();
        $session->store("postDataFor{$paymentGatewayId}", array_map('give_clean', $_POST));

        return true;
    }

    /**
     * Remove posted data from donation session just before rendering payment confirmation view because beyond this view this data is not useful.
     *
     * Note: Only for internal use.
     *
     * @since 2.7.0
     */
    public static function removePostedDataFromDonationSession()
    {
        $paymentGatewayId = ucfirst(give_clean($_GET['payment-confirmation']));

        $session = new DonationAccessor();
        $session->delete("postDataFor{$paymentGatewayId}");
    }

    /**
     * Return whether or not we are viewing donation confirmation view or not.
     *
     * @since 2.7.0
     * @return bool
     */
    public static function isConfirming()
    {
        return FormUtils::isViewingFormReceipt() && isset($_GET['payment-confirmation']);
    }
}