-
-
Notifications
You must be signed in to change notification settings - Fork 35
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Invoices, Bills, Rates & Currencies resources fully implemented, Read…
…me updated * Invoices, Bills, Rates & Currencies resources fully implemented, Readme updated
- Loading branch information
1 parent
87c42b8
commit f02eac2
Showing
5 changed files
with
574 additions
and
30 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -5,19 +5,50 @@ | |
[data:image/s3,"s3://crabby-images/e73be/e73be0e6d4739f202e8d54a285fed25df4e5593c" alt="Quality Score"](https://scrutinizer-ci.com/g/vrajroham/laravel-bitpay) | ||
[data:image/s3,"s3://crabby-images/d4470/d4470fc3846d841ee17629fe60909d92e0ff2dc4" alt="Total Downloads"](https://packagist.org/packages/vrajroham/laravel-bitpay) | ||
|
||
Accept Bitcoin and Bitcoin Cash for your business with your Laravel application and BitPay client. | ||
LaravelBitpay enables you and your business to transact in Bitcoin, Bitcoin Cash and 10+ other BitPay-supported cryptocurrencies within your Laravel application. | ||
|
||
> Requires PHP ^7.3 | ||
### Supported Resources | ||
|
||
- :white_check_mark: [Invoices](https://bitpay.com/api/#rest-api-resources-invoices) | ||
- :hourglass_flowing_sand: [Settlements](https://bitpay.com/api/#rest-api-resources-settlements) | ||
- :hourglass_flowing_sand: [Ledgers](https://bitpay.com/api/#rest-api-resources-ledgers) | ||
- :hourglass_flowing_sand: [Recipients](https://bitpay.com/api/#rest-api-resources-recipients) | ||
- :hourglass_flowing_sand: [Payouts](https://bitpay.com/api/#rest-api-resources-payouts) | ||
- :white_check_mark: [Bills](https://bitpay.com/api/#rest-api-resources-bills) | ||
- :hourglass_flowing_sand: [Subscriptions](https://bitpay.com/api/#rest-api-resources-subscriptions) | ||
- :white_check_mark: [Rates](https://bitpay.com/api/#rest-api-resources-rates) | ||
- :hourglass_flowing_sand: [Sessions](https://bitpay.com/api/#rest-api-resources-sessions) | ||
- :white_check_mark: [Currencies](https://bitpay.com/api/#rest-api-resources-currencies) | ||
|
||
## Contents | ||
|
||
- [Installation](#installation) | ||
+ [Install Package](#install-package) | ||
+ [Publish config file](#publish-config-file) | ||
+ [Add configuration values](#add-configuration-values) | ||
+ [Add webhook event listener](#add-webhook-event-listener) | ||
+ [Connect to server and authenticate the client](#connect-to-server-and-authenticate-the-client) | ||
- [Examples](#examples) | ||
+ [Create Invoice and checkout (step wise)](#create-invoice-and-checkout) | ||
+ [Invoices](#invoices) | ||
+ [Create Invoice and checkout (step wise)](#create-invoice-and-checkout) | ||
+ [Retrieve an existing invoice](#retrieve-an-existing-invoice) | ||
+ [Retrieve a list of existing invoices](#retrieve-a-list-of-existing-invoices) | ||
+ [Refund an invoice](#refund-an-invoice) | ||
+ [Retrieve a refund request](#retrieve-a-refund-request) | ||
+ [Retrieve all refund requests on an invoice](#retrieve-all-refund-requests-on-an-invoice) | ||
+ [Cancel a refund request](#cancel-a-refund-request) | ||
+ [Bills](#bills) | ||
+ [Create a bill](#create-a-bill) | ||
+ [Retrieve a bill](#retrieve-a-bill) | ||
+ [Retrieve a list of existing bills](#retrieve-a-list-of-existing-bills) | ||
+ [Update a bill](#update-a-bill) | ||
+ [Deliver a bill via email](#deliver-a-bill-via-email) | ||
+ [Currencies](#currencies) | ||
+ [Retrieve the supported currencies](#retrieve-the-supported-currencies) | ||
+ [Rates](#rates) | ||
+ [Retrieve the exchange rate table maintained by BitPay](#retrieve-the-exchange-rate-table-maintained-by-bitpay) | ||
- [Changelog](#changelog) | ||
- [Contributing](#contributing) | ||
- [Security](#security) | ||
|
@@ -26,22 +57,26 @@ Accept Bitcoin and Bitcoin Cash for your business with your Laravel application | |
|
||
## Installation | ||
|
||
#### Install package | ||
### Install package | ||
|
||
You can install the package via composer: | ||
|
||
```bash | ||
composer require vrajroham/laravel-bitpay | ||
``` | ||
|
||
#### Publish config file | ||
### Publish config file | ||
|
||
Publish config file with: | ||
|
||
```bash | ||
php artisan vendor:publish --provider="Vrajroham\LaravelBitpay\LaravelBitpayServiceProvider" | ||
``` | ||
|
||
#### Add configuration values | ||
Add following keys to `.env` file and updated the details ([view more about configuration](https://support.bitpay.com/hc/en-us/articles/115003001063-How-do-I-configure-the-PHP-BitPay-Client-Library-)): | ||
### Add configuration values | ||
|
||
Add following keys to `.env` file and updated the | ||
details ([view more about configuration](https://support.bitpay.com/hc/en-us/articles/115003001063-How-do-I-configure-the-PHP-BitPay-Client-Library-)): | ||
|
||
```dotenv | ||
BITPAY_PRIVATE_KEY_PATH=/tmp/bitpay.pri | ||
|
@@ -51,10 +86,14 @@ BITPAY_KEY_STORAGE_PASSWORD=SomeRandomePasswordForKeypairEncryption | |
BITPAY_TOKEN= | ||
``` | ||
|
||
#### Add webhook event listener | ||
By default, package is capable of handling of webhook requests. Bitpay payment status updates are completely based on webhooks. Whenever webhook is received from server, `BitpayWebhookReceived` event is dispatched. You just need to provide a listener for this event. | ||
### Add webhook event listener | ||
|
||
By default, package is capable of handling of webhook requests. Bitpay payment status updates are completely based on | ||
webhooks. Whenever webhook is received from server, `BitpayWebhookReceived` event is dispatched. You just need to | ||
provide a listener for this event. | ||
|
||
You can add your listener as below, | ||
|
||
```php | ||
<?php | ||
|
||
|
@@ -111,34 +150,44 @@ class EventServiceProvider extends ServiceProvider{ | |
} | ||
``` | ||
|
||
## Connect to server and authenticate the client | ||
### Connect to server and authenticate the client | ||
|
||
- Create keypairs and pair your client(application) with BitPay server. | ||
|
||
```bash | ||
php artisan laravel-bitpay:createkeypair | ||
``` | ||
|
||
<p align="center"><a href="https://ibb.co/s9Z5jD6"><img src="https://i.ibb.co/DfZG468/Screenshot-2019-11-03-at-7-59-55-PM.png" alt="Screenshot-2019-11-03-at-7-59-55-PM" border="0"></a></p> | ||
|
||
- What exactly above command do? | ||
+ Above command will create **Private and Public key**, encrypt your private key using bitpay secure storage class using your provided password. | ||
+ SIN (Service Identification Number) for your client will be created to uniquely identify requests from your server. | ||
+ By using SIN **new Token and Pairing Code** will be created for your client on bitpay server and will be shown on your console output. | ||
+ Above command will create **Private and Public key**, encrypt your private key using bitpay secure storage class | ||
using your provided password. | ||
+ SIN (Service Identification Number) for your client will be created to uniquely identify requests from your | ||
server. | ||
+ By using SIN **new Token and Pairing Code** will be created for your client on bitpay server and will be shown on | ||
your console output. | ||
+ Token will be used for all future request to bitpay and will automatically be copied to your `.env` file. | ||
+ Based on environment you set **TEST/LIVE**, command will provide URL to approve your client, and then you need to copy and search Pairing Code on bitpay server & approve it. | ||
+ Based on environment you set **TEST/LIVE**, command will provide URL to approve your client, and then you need to | ||
copy and search Pairing Code on bitpay server & approve it. | ||
|
||
- You are all set. :golf: | ||
|
||
### Examples | ||
## Examples | ||
|
||
### Invoices | ||
|
||
##### Create Invoice and checkout | ||
Invoices are time-sensitive payment requests addressed to specific buyers. An invoice has a fixed price, typically | ||
denominated in fiat currency. It also has an equivalent price in the supported cryptocurrencies, calculated by BitPay, | ||
at a locked exchange rate with an expiration time of 15 minutes. | ||
|
||
#### Create Invoice and checkout | ||
|
||
Let's go step by step. | ||
- Create your internal system order and then initiate the workflow by creating bitpay invoice as below, | ||
``` php | ||
```php | ||
use Illuminate\Support\Facades\Redirect; | ||
use Vrajroham\LaravelBitpay\LaravelBitpay; | ||
|
@@ -166,7 +215,7 @@ public function createInvoice() | |
$invoice->setBuyer($buyer); | ||
// Set currency | ||
$invoice->setCurrency('USD'); | ||
$invoice->setCurrency(Currency::USD); // Always use the BitPay Currency model to prevent typos | ||
// Set redirect url to get back after completing the payment. GET Request | ||
$invoice->setRedirectURL(route('bitpay-redirect-back')); | ||
|
@@ -189,18 +238,215 @@ public function createInvoice() | |
} | ||
``` | ||
- Once you get the invoice url for payment, redirect user to that particular url. Use will see something like below on browser. | ||
- Once you get the invoice url for payment, redirect user to that particular url. Use will see something like below on | ||
browser. | ||
<p align="center"><a href="https://ibb.co/X8JhftX"><img src="https://i.ibb.co/FV7Skz6/Screenshot-2019-11-03-at-5-31-33-PM.png" alt="Screenshot-2019-11-03-at-5-31-33-PM" border="0"></a></p> | ||
- Next, open your bitpay wallet, scan the code and make a payment. Something like below, | ||
<p align="center"><a href="https://ibb.co/FY4G4gZ"><img src="https://i.ibb.co/WzvSvg8/IMG-3639.png" alt="IMG-3639" border="1"></a></p> | ||
- Once payment is done, success screen will be displayed and user needs to click on **Return to Shop Name**. | ||
<p align="center"><a href="https://ibb.co/8M21RBv"><img src="https://i.ibb.co/Jn2Dbd6/Screenshot-2019-11-03-at-5-32-05-PM.png" alt="Screenshot-2019-11-03-at-5-32-05-PM" border="0"></a></p> | ||
- Payment done! Now you need to wait for webhook to get notification regarding status of payment. | ||
#### Retrieve an existing invoice | ||
```php | ||
$invoice = LaravelBitpay::getInvoice('invoiceId_sGsdVsgheF'); | ||
``` | ||
#### Retrieve a list of existing invoices | ||
In this example we retrieve all MTD (Month-To-Date) invoices: | ||
```php | ||
$startDate = date('Y-m-d', strtotime('first day of this month')); | ||
$endDate = date('Y-m-d'); | ||
$invoices = LaravelBitpay::getInvoices($startDate, $endDate); | ||
``` | ||
#### Refund an invoice | ||
The item Jane purchased was dead on arrival. Give back the lady her crypto: | ||
```php | ||
$invoice = LaravelBitpay::getInvoice('invoiceId_sGsdVsgheF'); | ||
$refundRequested = LaravelBitpay::createRefund($invoice, '[email protected]', 0.016, 'ETH'); | ||
if ($refundRequested) { | ||
// Don't just sit there. Do something! | ||
} | ||
``` | ||
|
||
#### Retrieve a refund request | ||
|
||
Let's periodically retrieve (and check the status of) Jane's refund request: | ||
|
||
```php | ||
$invoice = LaravelBitpay::getInvoice('invoiceId_sGsdVsgheF'); | ||
|
||
$refund = LaravelBitpay::getRefund($invoice, 'refundId_pUdhjwGjsg'); | ||
``` | ||
|
||
#### Retrieve all refund requests on an invoice | ||
|
||
In this example we retrieve all refund requests related to Jane's invoice: | ||
|
||
```php | ||
$invoice = LaravelBitpay::getInvoice('invoiceId_sGsdVsgheF'); | ||
|
||
$refundRequests = LaravelBitpay::getRefunds($invoice); | ||
``` | ||
|
||
#### Cancel a refund request | ||
|
||
Turns out Jane didn't initially follow the instruction manual. The item works and she no longer wants a refund: | ||
|
||
```php | ||
$invoice = LaravelBitpay::getInvoice('invoiceId_sGsdVsgheF'); | ||
|
||
$refundRequestCancelled = LaravelBitpay::cancelRefund($invoice->getId(), 'refundId_pUdhjwGjsg'); | ||
``` | ||
|
||
### Bills | ||
|
||
Bills are payment requests addressed to specific buyers. Bill line items have fixed prices, typically denominated in | ||
fiat currency. | ||
|
||
#### Create a bill | ||
|
||
In the following example, we create a bill that's due in 10 days: | ||
|
||
```php | ||
// Initialize Bill | ||
$billData = LaravelBitpay::Bill(); | ||
$billData->setNumber('bill1234-EFGH'); | ||
$billData->setCurrency(Currency::USD); // Always use the BitPay Currency model to prevent typos | ||
$dueDate = date('Y-m-d\TH:i:s\Z', strtotime('+10 days')); // ISO-8601 formatted date | ||
$billData->setDueDate($dueDate); | ||
$billData->setPassProcessingFee(true); // Let the recipient shoulder BitPay's processing fee | ||
|
||
// Prepare Bill recipient's data | ||
$billData->setName('John Doe'); | ||
$billData->setAddress1('2630 Hegal Place'); | ||
$billData->setAddress2('Apt 42'); | ||
$billData->setCity('Alexandria'); | ||
$billData->setState('VA'); | ||
$billData->setZip(23242); | ||
$billData->setCountry('US'); | ||
$billData->setEmail('[email protected]'); | ||
$billData->setCc(['[email protected]']); | ||
$billData->setPhone('555-123-456'); | ||
|
||
// Prepare Bill's line item(s) | ||
$itemUno = LaravelBitpay::Item(); | ||
$itemUno->setDescription('Squid Game "Front Man" Costume'); | ||
$itemUno->setPrice(49.99); | ||
$itemUno->setQuantity(2); | ||
|
||
$itemDos = LaravelBitpay::Item(); | ||
$itemDos->setDescription('GOT "House Stark" Sterling Silver Pendant'); | ||
$itemDos->setPrice(35); | ||
$itemDos->setQuantity(1); | ||
|
||
$billData->setItems([$itemUno, $itemDos]); | ||
|
||
// Create Bill | ||
$bill = LaravelBitpay::createBill($billData); | ||
|
||
// Store the Bill's BitPay ID and URL for future reference | ||
$billId = $bill->getId(); | ||
$billPaymentUrl = $bill->getUrl(); | ||
|
||
// OR | ||
|
||
// Redirect the recipient to BitPay's hosted Bill payment page | ||
Redirect::to($billPaymentUrl); | ||
``` | ||
|
||
#### Retrieve a bill | ||
|
||
```php | ||
$bill = LaravelBitpay::getBill('bill1234-EFGH'); | ||
``` | ||
|
||
#### Retrieve a list of existing bills | ||
|
||
You can narrow down the retrieved list by specifying a Bill status: | ||
|
||
```php | ||
// Status can be "draft", "sent", "new", "paid", or "complete" | ||
$status = 'paid'; | ||
|
||
$paidBills = LaravelBitpay::getBills($status); | ||
``` | ||
|
||
#### Update a bill | ||
|
||
We managed to upsell a product to our client. Let's add an extra line item to their existing Bill: | ||
|
||
```php | ||
$existingBill = LaravelBitpay::getBill('bill1234-EFGH'); | ||
$existingItems = $existingBill->getItems(); | ||
|
||
$billData = LaravelBitpay::Bill(); | ||
|
||
$itemTres = LaravelBitpay::Item(); | ||
$itemTres->setDescription('The Tomorrow War "White Spike" Life-Size Wax Figure'); | ||
$itemTres->setPrice(189.99); | ||
$itemTres->setQuantity(1); | ||
|
||
$billData->setItems(array_merge($existingItems, [$itemTres])); | ||
|
||
// Update Bill | ||
$updatedBill = LaravelBitpay::updateBill($billData, 'bill1234-EFGH'); | ||
``` | ||
|
||
#### Deliver a bill via email | ||
|
||
```php | ||
$bill = LaravelBitpay::getBill('bill1234-EFGH'); | ||
|
||
$billId = $bill->getId(); | ||
$billToken = $bill->getToken(); | ||
|
||
$billDelivery = json_decode(LaravelBitpay::deliverBill($billId, $billToken)); | ||
|
||
if (isset($billDelivery->data) && $billDelivery->data == 'Success') { | ||
// Bill delivered successfully. Do something about that... or not. | ||
} | ||
``` | ||
|
||
### Currencies | ||
|
||
Currencies are fiat currencies supported by BitPay. | ||
|
||
#### Retrieve the supported currencies | ||
|
||
In this example, we retrieve the list of supported BitPay Currency objects. | ||
|
||
```php | ||
$supportedCurrencies = LaravelBitpay::getCurrencies(); | ||
``` | ||
|
||
### Rates | ||
|
||
Rates are exchange rates, representing the number of fiat currency units equivalent to one BTC. | ||
|
||
#### Retrieve the exchange rate table maintained by BitPay | ||
|
||
```php | ||
$rates = LaravelBitpay::getRates(); | ||
|
||
$btcToUsdRate = $rates->getRate(Currency::USD); // Always use the BitPay Currency model to prevent typos | ||
``` | ||
|
||
## Changelog | ||
|
||
Please see [CHANGELOG](CHANGELOG.md) for more information on what has changed recently. | ||
|
Oops, something went wrong.