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/Session/SessionDonation/DonationAccessor.php
<?php

namespace Give\Session\SessionDonation;

use DateTime;
use Give\Session\Accessor;
use Give\Session\SessionDonation\SessionObjects\Donation as DonationObject;
use Give\Session\SessionDonation\SessionObjects\FormEntry;

/**
 * Class Donation
 *
 * This class provide way to access donation session data.
 *
 * @package Give\Session\Access
 *
 * @method DonationObject get
 */
class DonationAccessor extends Accessor
{
    /**
     * Session Id
     *
     * @since 2.7.0
     * @var string
     */
    protected $sessionKey = 'give_purchase';

    /**
     * Donation object.
     *
     * Since 2.7.0
     *
     * @var DonationObject
     */
    protected $dataObj;

    /**
     * property vs session key array.
     * It is useful to map array keys to class properties.
     *
     * @var array
     */
    private $renameTo = [
        'user_email' => 'donorEmail',
        'user_info' => 'donorInfo',
        'post_data' => 'formEntry',
        'donation_id' => 'id',
        'price' => 'totalAmount',
        'gateway' => 'paymentGateway',
        'date' => 'createdAt',
    ];

    /**
     * Map array keys to class properties
     *
     * @since 2.7.0
     *
     * @param array $data
     *
     * @return DonationObject
     */
    protected function convertToObject($data)
    {
        if ( ! $data) {
            return null;
        }

        // Cast date string to DateTime object.
        $data['date'] = DateTime::createFromFormat('Y-m-d H:i:s', $data['date']);

        // Rename key if property name exist for them.
        foreach ($data as $key => $value) {
            if (array_key_exists($key, $this->renameTo)) {
                $data[$this->renameTo[$key]] = $value;
                unset($data[$key]);
            }
        }

        // Rename unknown keys.
        $data = $this->renameArrayKeysToPropertyNames($data);

        return DonationObject::fromArray($data);
    }

    /**
     * Get donation id.
     *
     * @since 2.7.0
     * @return int
     *
     */
    public function getDonationId()
    {
        if ($donationId = $this->getByKey('id')) {
            return absint($donationId);
        }

        return null;
    }

    /**
     * Get donation id.
     *
     * @since 2.7.0
     * @return int
     *
     */
    public function getFormId()
    {
        /* @var FormEntry $data */
        if ($data = $this->getByKey('formEntry')) {
            return absint($data->formId);
        }

        return null;
    }
}