����JFIF��x�x����'
| Server IP : 78.140.185.180 / Your IP : 216.73.216.170 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 : /proc/thread-self/root/home/builderbox/./././public_html/vendor/omnipay/paypal/src/ |
Upload File : |
<?php
/**
* PayPal Pro Class using REST API
*/
namespace Omnipay\PayPal;
use Omnipay\Common\AbstractGateway;
use Omnipay\PayPal\Message\ProAuthorizeRequest;
use Omnipay\PayPal\Message\CaptureRequest;
use Omnipay\PayPal\Message\RefundRequest;
/**
* PayPal Pro Class using REST API
*
* This class forms the gateway class for PayPal REST requests via the PayPal REST APIs.
*
* The PayPal API uses HTTP verbs and a RESTful endpoint structure. OAuth 2.0 is used
* as the API Authorization framework. Request and response payloads are formatted as JSON.
*
* The PayPal REST APIs are supported in two environments. Use the Sandbox environment
* for testing purposes, then move to the live environment for production processing.
* When testing, generate an access token with your test credentials to make calls to
* the Sandbox URIs. When you’re set to go live, use the live credentials assigned to
* your app to generate a new access token to be used with the live URIs.
*
* ### Test Mode
*
* In order to use this for testing in sandbox mode you will need at least two sandbox
* test accounts. One will need to be a business account, and one will need to be a
* personal account with credit card details. To create these you will need to go to
* the sandbox accounts section of the PayPal developer dashboard, here:
* https://developer.paypal.com/webapps/developer/applications/accounts
* On that page click "Create Account" and follow the prompts. When you are creating the
* Personal account, ensure that it is created with a credit card -- either Visa or
* MasterCard or one of the other types. When you are testing in the sandbox, use the
* credit card details you will receive for this Personal account rather than any other
* commonly used test credit card numbers (e.g. visa card 4111111111111111 or 4444333322221111
* both of which will result in Error 500 / INTERNAL_SERVICE_ERROR type errors from the
* PayPal gateway).
*
* With each API call, you’ll need to set request headers, including an OAuth 2.0
* access token. Get an access token by using the OAuth 2.0 client_credentials token
* grant type with your clientId:secret as your Basic Auth credentials. For more
* information, see Make your first call (link). This class sets all of the headers
* associated with the API call for you, including making preliminary calls to create
* or update the OAuth 2.0 access token before each call you make, if required. All
* you need to do is provide the clientId and secret when you initialize the gateway,
* or use the set*() calls to set them after creating the gateway object.
*
* ### Credentials
*
* To create production and sandbox credentials for your PayPal account:
*
* * Log into your PayPal account.
* * Navigate to your Sandbox accounts at https://developer.paypal.com/webapps/developer/applications/accounts
* to ensure that you have a valid sandbox account to use for testing. If you don't already have a sandbox
* account, one can be created on this page. You will actually need 2 accounts, a personal account and a
* business account, the business account is the one you need to use for creating API applications.
* * Check your account status on https://developer.paypal.com/webapps/developer/account/status to ensure
* that it is valid for live transactions.
* * Navigate to the My REST apps page: https://developer.paypal.com/webapps/developer/applications/myapps
* * Click *Create App*
* * On the next page, enter an App name and select the sandbox account to use, then click *Create app*.
* * On the next page the sandbox account, endpoint, Client ID and Secret should be displayed.
* Record these. The Sandbox account should match the one that you selected on the previous
* page, and the sandbox endpoint should be ai.sandbox.paypal.com
* * Adjacent to *Live credentials* click *Show* to display your live credentials. The endpoint
* for these should be api.paypal.com, there should also be a Client ID and Secret.
*
* You can create additional REST APIs apps for other websites -- because the webhooks are
* stored per app then it pays to have one API app per website that you are using (and an
* additional one for things like command line testing, etc).
*
* ### Example
*
* #### Initialize Gateway
*
* <code>
* // Create a gateway for the PayPal RestGateway
* // (routes to GatewayFactory::create)
* $gateway = Omnipay::create('PayPal_Rest');
*
* // Initialise the gateway
* $gateway->initialize(array(
* 'clientId' => 'MyPayPalClientId',
* 'secret' => 'MyPayPalSecret',
* 'testMode' => true, // Or false when you are ready for live transactions
* ));
* </code>
*
* #### Direct Credit Card Payment
*
* <code>
* // Create a credit card object
* // DO NOT USE THESE CARD VALUES -- substitute your own
* // see the documentation in the class header.
* $card = new CreditCard(array(
* 'firstName' => 'Example',
* 'lastName' => 'User',
* 'number' => '4111111111111111',
* 'expiryMonth' => '01',
* 'expiryYear' => '2020',
* 'cvv' => '123',
* 'billingAddress1' => '1 Scrubby Creek Road',
* 'billingCountry' => 'AU',
* 'billingCity' => 'Scrubby Creek',
* 'billingPostcode' => '4999',
* 'billingState' => 'QLD',
* ));
*
* // Do a purchase transaction on the gateway
* try {
* $transaction = $gateway->purchase(array(
* 'amount' => '10.00',
* 'currency' => 'AUD',
* 'description' => 'This is a test purchase transaction.',
* 'card' => $card,
* ));
* $response = $transaction->send();
* $data = $response->getData();
* echo "Gateway purchase response data == " . print_r($data, true) . "\n";
*
* if ($response->isSuccessful()) {
* echo "Purchase transaction was successful!\n";
* }
* } catch (\Exception $e) {
* echo "Exception caught while attempting authorize.\n";
* echo "Exception type == " . get_class($e) . "\n";
* echo "Message == " . $e->getMessage() . "\n";
* }
* </code>
*
* ### Dashboard
*
* Once you have processed some payments you can go to the PayPal sandbox site,
* at https://www.sandbox.paypal.com/ and log in with the email address and password
* of your PayPal sandbox business test account. You will then see the result
* of those transactions on the "My recent activity" list under the My Account
* tab.
*
* @link https://developer.paypal.com/docs/api/
* @link https://devtools-paypal.com/integrationwizard/
* @link http://paypal.github.io/sdk/
* @link https://developer.paypal.com/docs/integration/direct/rest_api_payment_country_currency_support/
* @link https://developer.paypal.com/docs/faq/
* @link https://developer.paypal.com/docs/integration/direct/make-your-first-call/
* @link https://developer.paypal.com/docs/integration/web/accept-paypal-payment/
* @link https://developer.paypal.com/docs/api/#authentication--headers
* @see Omnipay\PayPal\Message\AbstractRestRequest
*/
class RestGateway extends AbstractGateway
{
// Constants used in plan creation
const BILLING_PLAN_TYPE_FIXED = 'FIXED';
const BILLING_PLAN_TYPE_INFINITE = 'INFINITE';
const BILLING_PLAN_FREQUENCY_DAY = 'DAY';
const BILLING_PLAN_FREQUENCY_WEEK = 'WEEK';
const BILLING_PLAN_FREQUENCY_MONTH = 'MONTH';
const BILLING_PLAN_FREQUENCY_YEAR = 'YEAR';
const BILLING_PLAN_STATE_CREATED = 'CREATED';
const BILLING_PLAN_STATE_ACTIVE = 'ACTIVE';
const BILLING_PLAN_STATE_INACTIVE = 'INACTIVE';
const BILLING_PLAN_STATE_DELETED = 'DELETED';
const PAYMENT_TRIAL = 'TRIAL';
const PAYMENT_REGULAR = 'REGULAR';
public function getName()
{
return 'PayPal REST';
}
public function getDefaultParameters()
{
return array(
'clientId' => '',
'secret' => '',
'token' => '',
'testMode' => false,
);
}
//
// Tokens -- methods to set up, store and retrieve the OAuth 2.0 access token.
//
// @link https://developer.paypal.com/docs/api/#authentication--headers
//
/**
* Get OAuth 2.0 client ID for the access token.
*
* Get an access token by using the OAuth 2.0 client_credentials
* token grant type with your clientId:secret as your Basic Auth
* credentials.
*
* @return string
*/
public function getClientId()
{
return $this->getParameter('clientId');
}
/**
* Set OAuth 2.0 client ID for the access token.
*
* Get an access token by using the OAuth 2.0 client_credentials
* token grant type with your clientId:secret as your Basic Auth
* credentials.
*
* @param string $value
* @return RestGateway provides a fluent interface
*/
public function setClientId($value)
{
return $this->setParameter('clientId', $value);
}
/**
* Get OAuth 2.0 secret for the access token.
*
* Get an access token by using the OAuth 2.0 client_credentials
* token grant type with your clientId:secret as your Basic Auth
* credentials.
*
* @return string
*/
public function getSecret()
{
return $this->getParameter('secret');
}
/**
* Set OAuth 2.0 secret for the access token.
*
* Get an access token by using the OAuth 2.0 client_credentials
* token grant type with your clientId:secret as your Basic Auth
* credentials.
*
* @param string $value
* @return RestGateway provides a fluent interface
*/
public function setSecret($value)
{
return $this->setParameter('secret', $value);
}
/**
* Get OAuth 2.0 access token.
*
* @param bool $createIfNeeded [optional] - If there is not an active token present, should we create one?
* @return string
*/
public function getToken($createIfNeeded = true)
{
if ($createIfNeeded && !$this->hasToken()) {
$response = $this->createToken()->send();
if ($response->isSuccessful()) {
$data = $response->getData();
if (isset($data['access_token'])) {
$this->setToken($data['access_token']);
$this->setTokenExpires(time() + $data['expires_in']);
}
}
}
return $this->getParameter('token');
}
/**
* Create OAuth 2.0 access token request.
*
* @return \Omnipay\PayPal\Message\RestTokenRequest
*/
public function createToken()
{
return $this->createRequest('\Omnipay\PayPal\Message\RestTokenRequest', array());
}
/**
* Set OAuth 2.0 access token.
*
* @param string $value
* @return RestGateway provides a fluent interface
*/
public function setToken($value)
{
return $this->setParameter('token', $value);
}
/**
* Get OAuth 2.0 access token expiry time.
*
* @return integer
*/
public function getTokenExpires()
{
return $this->getParameter('tokenExpires');
}
/**
* Set OAuth 2.0 access token expiry time.
*
* @param integer $value
* @return RestGateway provides a fluent interface
*/
public function setTokenExpires($value)
{
return $this->setParameter('tokenExpires', $value);
}
/**
* Is there a bearer token and is it still valid?
*
* @return bool
*/
public function hasToken()
{
$token = $this->getParameter('token');
$expires = $this->getTokenExpires();
if (!empty($expires) && !is_numeric($expires)) {
$expires = strtotime($expires);
}
return !empty($token) && time() < $expires;
}
/**
* Create Request
*
* This overrides the parent createRequest function ensuring that the OAuth
* 2.0 access token is passed along with the request data -- unless the
* request is a RestTokenRequest in which case no token is needed. If no
* token is available then a new one is created (e.g. if there has been no
* token request or the current token has expired).
*
* @param string $class
* @param array $parameters
* @return \Omnipay\PayPal\Message\AbstractRestRequest
*/
public function createRequest($class, array $parameters = array())
{
if (!$this->hasToken() && $class != '\Omnipay\PayPal\Message\RestTokenRequest') {
// This will set the internal token parameter which the parent
// createRequest will find when it calls getParameters().
$this->getToken(true);
}
return parent::createRequest($class, $parameters);
}
//
// Payments -- Create payments or get details of one or more payments.
//
// @link https://developer.paypal.com/docs/api/#payments
//
/**
* Create a purchase request.
*
* PayPal provides various payment related operations using the /payment
* resource and related sub-resources. Use payment for direct credit card
* payments and PayPal account payments. You can also use sub-resources
* to get payment related details.
*
* @link https://developer.paypal.com/docs/api/#create-a-payment
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestPurchaseRequest
*/
public function purchase(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestPurchaseRequest', $parameters);
}
/**
* Fetch a purchase request.
*
* Use this call to get details about payments that have not completed,
* such as payments that are created and approved, or if a payment has failed.
*
* @link https://developer.paypal.com/docs/api/#look-up-a-payment-resource
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestFetchPurchaseRequest
*/
public function fetchPurchase(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestFetchPurchaseRequest', $parameters);
}
/**
* List purchase requests.
*
* Use this call to get a list of payments in any state (created, approved,
* failed, etc.). The payments returned are the payments made to the merchant
* making the call.
*
* @link https://developer.paypal.com/docs/api/#list-payment-resources
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestListPurchaseRequest
*/
public function listPurchase(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestListPurchaseRequest', $parameters);
}
/**
* Completes a purchase request.
*
* @link https://developer.paypal.com/docs/api/#execute-an-approved-paypal-payment
* @param array $parameters
* @return Message\AbstractRestRequest
*/
public function completePurchase(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestCompletePurchaseRequest', $parameters);
}
// TODO: Update a payment resource https://developer.paypal.com/docs/api/#update-a-payment-resource
//
// Authorizations -- Capture, reauthorize, void and look up authorizations.
//
// @link https://developer.paypal.com/docs/api/#authorizations
// @link https://developer.paypal.com/docs/integration/direct/capture-payment/
//
/**
* Create an authorization request.
*
* To collect payment at a later time, first authorize a payment using the /payment resource.
* You can then capture the payment to complete the sale and collect payment.
*
* @link https://developer.paypal.com/docs/integration/direct/capture-payment/#authorize-the-payment
* @link https://developer.paypal.com/docs/api/#authorizations
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestAuthorizeRequest
*/
public function authorize(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestAuthorizeRequest', $parameters);
}
/**
* Void an authorization.
*
* To to void a previously authorized payment.
*
* @link https://developer.paypal.com/docs/api/#void-an-authorization
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestVoidRequest
*/
public function void(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestVoidRequest', $parameters);
}
/**
* Capture an authorization.
*
* Use this resource to capture and process a previously created authorization.
* To use this resource, the original payment call must have the intent set to
* authorize.
*
* @link https://developer.paypal.com/docs/api/#capture-an-authorization
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestCaptureRequest
*/
public function capture(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestCaptureRequest', $parameters);
}
// TODO: Authorizations with payment_method == paypal.
/**
* Refund a Captured Payment
*
* To refund captured payments (authorization transaction) created by a authorize request.
*
* @link https://developer.paypal.com/docs/api/#refund-a-captured-payment
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestRefundCaptureRequest
*/
public function refundCapture(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestRefundCaptureRequest', $parameters);
}
//
// Sale Transactions -- Get and refund completed payments (sale transactions).
// @link https://developer.paypal.com/docs/api/#sale-transactions
//
/**
* Fetch a Sale Transaction
*
* To get details about completed payments (sale transaction) created by a payment request
* or to refund a direct sale transaction, PayPal provides the /sale resource and related
* sub-resources.
*
* @link https://developer.paypal.com/docs/api/#sale-transactions
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestFetchTransactionRequest
*/
public function fetchTransaction(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestFetchTransactionRequest', $parameters);
}
/**
* Refund a Sale Transaction
*
* To get details about completed payments (sale transaction) created by a payment request
* or to refund a direct sale transaction, PayPal provides the /sale resource and related
* sub-resources.
*
* @link https://developer.paypal.com/docs/api/#sale-transactions
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestRefundRequest
*/
public function refund(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestRefundRequest', $parameters);
}
//
// Vault: Store customer credit cards securely.
//
// @link https://developer.paypal.com/docs/api/#vault
//
/**
* Store a credit card in the vault
*
* You can currently use the /vault API to store credit card details
* with PayPal instead of storing them on your own server. After storing
* a credit card, you can then pass the credit card id instead of the
* related credit card details to complete a payment.
*
* @link https://developer.paypal.com/docs/api/#store-a-credit-card
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestCreateCardRequest
*/
public function createCard(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestCreateCardRequest', $parameters);
}
/**
* Delete a credit card from the vault.
*
* Updating a card in the vault is no longer supported -- see
* http://stackoverflow.com/questions/20858910/paypal-rest-api-update-a-stored-credit-card
* Therefore the only way to update a card is to remove it using deleteCard and
* then re-add it using createCard.
*
* @link https://developer.paypal.com/docs/api/#delete-a-stored-credit-card
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestDeleteCardRequest
*/
public function deleteCard(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestDeleteCardRequest', $parameters);
}
//
// Billing Plans and Agreements -- Set up recurring payments.
// @link https://developer.paypal.com/docs/api/#billing-plans-and-agreements
//
/**
* Create a billing plan.
*
* You can create an empty billing plan and add a trial period and/or regular
* billing. Alternatively, you can create a fully loaded plan that includes
* both a trial period and regular billing. Note: By default, a created billing
* plan is in a CREATED state. A user cannot subscribe to the billing plan
* unless it has been set to the ACTIVE state.
*
* @link https://developer.paypal.com/docs/api/#create-a-plan
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestCreatePlanRequest
*/
public function createPlan(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestCreatePlanRequest', $parameters);
}
/**
* Update a billing plan.
*
* You can update the information for an existing billing plan. The state of a plan
* must be active before a billing agreement is created.
*
* @link https://developer.paypal.com/docs/api/#update-a-plan
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestUpdatePlanRequest
*/
public function updatePlan(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestUpdatePlanRequest', $parameters);
}
// TODO: Retrieve a plan
/**
* List billing plans.
*
* Use this call to get a list of plans in any state (CREATED, ACTIVE, etc.).
* The plans returned are the plans made by the merchant making the call.
*
* @link https://developer.paypal.com/docs/api/payments.billing-plans#plan_list
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestListPlanRequest
*/
public function listPlan(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestListPlanRequest', $parameters);
}
/**
* Create a subscription.
*
* Use this call to create a billing agreement for the buyer.
*
* @link https://developer.paypal.com/docs/api/#create-an-agreement
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestCreateSubscriptionRequest
*/
public function createSubscription(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestCreateSubscriptionRequest', $parameters);
}
/**
* Complete (execute) a subscription.
*
* Use this call to execute an agreement after the buyer approves it.
*
* @link https://developer.paypal.com/docs/api/#execute-an-agreement
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestCompleteSubscriptionRequest
*/
public function completeSubscription(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestCompleteSubscriptionRequest', $parameters);
}
/**
* Cancel a subscription.
*
* Use this call to cancel an agreement.
*
* @link https://developer.paypal.com/docs/api/#cancel-an-agreement
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestCancelSubscriptionRequest
*/
public function cancelSubscription(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestCancelSubscriptionRequest', $parameters);
}
/**
* Suspend a subscription.
*
* Use this call to suspend an agreement.
*
* @link https://developer.paypal.com/docs/api/#suspend-an-agreement
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestSuspendSubscriptionRequest
*/
public function suspendSubscription(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestSuspendSubscriptionRequest', $parameters);
}
/**
* Reactivate a suspended subscription.
*
* Use this call to reactivate or un-suspend an agreement.
*
* @link https://developer.paypal.com/docs/api/#reactivate-an-agreement
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestReactivateSubscriptionRequest
*/
public function reactivateSubscription(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestReactivateSubscriptionRequest', $parameters);
}
/**
* Search for transactions.
*
* Use this call to search for the transactions within a billing agreement.
* Note that this is not a generic transaction search function -- for that
* see RestListPurchaseRequest. It only searches for transactions within
* a billing agreement.
*
* This should be used on a regular basis to determine the success / failure
* state of transactions on active billing agreements.
*
* @link https://developer.paypal.com/docs/api/#search-for-transactions
* @param array $parameters
* @return \Omnipay\PayPal\Message\RestCompleteSubscriptionRequest
*/
public function searchTransaction(array $parameters = array())
{
return $this->createRequest('\Omnipay\PayPal\Message\RestSearchTransactionRequest', $parameters);
}
// TODO: Update an agreement
// TODO: Retrieve an agreement
// TODO: Set outstanding agreement amounts
// TODO: Bill outstanding agreement amounts
}