<?php
namespace Srmklive\PayPal\Traits\PayPalAPI;
trait Orders
{
use Orders\Helpers;
/**
* Creates an order.
*
* @param array $data
*
* @throws \Throwable
*
* @return array|\Psr\Http\Message\StreamInterface|string
*
* @see https://developer.paypal.com/docs/api/orders/v2/#orders_create
*/
public function createOrder(array $data)
{
$this->apiEndPoint = 'v2/checkout/orders';
$this->options['json'] = (object) $data;
$this->verb = 'post';
return $this->doPayPalRequest();
}
/**
* Shows details for an order.
*
* @param string $order_id
*
* @throws \Throwable
*
* @return array|\Psr\Http\Message\StreamInterface|string
*
* @see https://developer.paypal.com/docs/api/orders/v2/#orders_get
*/
public function showOrderDetails(string $order_id)
{
$this->apiEndPoint = "v2/checkout/orders/{$order_id}";
$this->verb = 'get';
return $this->doPayPalRequest();
}
/**
* Update order details.
*
* @param string $order_id
* @param array $data
*
* @throws \Throwable
*
* @return array|\Psr\Http\Message\StreamInterface|string
*
* @see https://developer.paypal.com/docs/api/orders/v2/#orders_patch
*/
public function updateOrder(string $order_id, array $data)
{
$this->apiEndPoint = "v2/checkout/orders/{$order_id}";
$this->options['json'] = $data;
$this->verb = 'patch';
return $this->doPayPalRequest(false);
}
/**
* Confirm the order.
*
* @param string $order_id
* @param array $data
*
* @throws \Throwable
*
* @return array|\Psr\Http\Message\StreamInterface|string
*/
public function confirmOrder(string $order_id, array $data)
{
$this->apiEndPoint = "v2/checkout/orders/{$order_id}/confirm-payment-source";
$this->options['json'] = (object) $data;
$this->verb = 'post';
return $this->doPayPalRequest();
}
/**
* Authorizes payment for an order.
*
* @param string $order_id
* @param array $data
*
* @throws \Throwable
*
* @return array|\Psr\Http\Message\StreamInterface|string
*
* @see https://developer.paypal.com/docs/api/orders/v2/#orders_authorize
*/
public function authorizePaymentOrder(string $order_id, array $data = [])
{
$this->apiEndPoint = "v2/checkout/orders/{$order_id}/authorize";
$this->options['json'] = (object) $data;
$this->verb = 'post';
return $this->doPayPalRequest();
}
/**
* Captures payment for an order.
*
* @param string $order_id
* @param array $data
*
* @throws \Throwable
*
* @return array|\Psr\Http\Message\StreamInterface|string
*
* @see https://developer.paypal.com/docs/api/orders/v2/#orders_capture
*/
public function capturePaymentOrder(string $order_id, array $data = [])
{
$this->apiEndPoint = "v2/checkout/orders/{$order_id}/capture";
$this->options['json'] = (object) $data;
$this->verb = 'post';
return $this->doPayPalRequest();
}
}
How To Payment
Making a payment on our website is quick and secure. Start by logging in or creating an account. Select your preferred payment method, input the required details, and review the information. Once you confirm everything is correct, click on the "Submit Payment" button. You’ll receive instant confirmation and can track your payment status through your account dashboard. It’s an easy and secure process.