drewdan / paypal
A simple Paypal Client for the V2 API
Installs: 1 144
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 2
Open Issues: 2
Requires
- php: ^8.2
- guzzlehttp/guzzle: ^7.4
- laravel/framework: ^10.0.
- netresearch/jsonmapper: ^v4.0.0
Requires (Dev)
- ext-json: *
- orchestra/testbench: ^8.0
- phpunit/phpunit: ^10.0
- spatie/laravel-ray: ^1.35
README
This laravel package creates an interface with the PayPal API by generating API requests using the assorted classes available.
I built this package, because at the time, I could not find a suitable package to do what I wanted (though this might be due to poor Google skills.) - so I built this.
The documentation for the API which this package uses can be found here: https://developer.paypal.com/docs/api/payments/v2/
Installation
This is best installed by composer:
composer require drewdan/paypal
Publish the config files using the following command
php artisan vendor:publish --tag=drewdan-paypal-config
Orders
The orders class is the class you would use to create and capture payments from customers.
Creating an Order
use Drewdan\Paypal\Services\Orders\Order;
$order = new Order;
$purchaseUnits = [
[
'amount' => [
'currency_code' => 'GBP',
'value' => 12.50,
],
],
];
$applicationContext = [
'brand_name' => 'My Online Shop',
'shipping_preference' => 'NO_SHIPPING',
'user_action' => 'PAY_NOW',
'return_url' => 'https://localhost/return',
'cancel_url' => 'https://localhost/cancel',
];
$paypalOrder = $order->create($purchaseUnits, 'CAPTURE', $applicationContext);
return redirect($paypalOrder->getLinkByRel('approve')->href);
The above snippet will create a PayPal Order with a value of £12.50 and return an instance of PaypalOrder. This object contains a helper method to access the PayPal Links returned from the request. You can use this to redirect the user to PayPal to make payment.
The parameter for the application context can be found https://developer.paypal.com/docs/api/orders/v2/#definition-order_application_context
This will authorize the payment, but not capture it. To capture a payment, you will need the Order ID which will be passed in a get request when the user is redirected back. You can use whatever mechanism fits your application to track this Order ID.
Capturing a Payment
use Drewdan\Paypal\Services\Orders\Order;
$order = new Order;
//first retrieve the order from Paypal
$paypalOrder = $order->show(request()->PayerID);
//here you could do any validation you wish to verify the order is correct, checking the order amount etc before capturing the payment
$order->capture($paypalOrder);
Once this is complete, you will have captured the payment.
Captures
Refunding a captured payment
After payment has been completed, you might sometimes need to refund the payment, if for example, you are unable to fulfil the order. The captures class has the ability to show an existing captured payment, or refund it.
The refund method accepts the following parameters:
use Drewdan\Paypal\Services\Payments\Captures;
$client = new Captures;
$capture = $client->refund('captureId', 5.99, 'GBP', 'Some reason', 'Invoice 123');
Showing a captured payment
This call will show the details of a captured payment. They are retrieved via their capture ID. Ideally, when you take and capture a payment you would store the capture ID in a database against a given order, so you can reference it in future to make refunds or view details about the capture.
use Drewdan\Paypal\Services\Payments\Captures;
$client = new Captures;
$capture = $client->show('captureId');
Contributing
Contributions are welcome, if you have anything you'd like to add, please open a Pull Request. If you find a bug or other issue with this package, please open an issue on the repo.