����JFIF��x�x����'403WebShell
403Webshell
Server IP : 66.29.137.217  /  Your IP : 18.223.168.194
Web Server : LiteSpeed
System : Linux premium294.web-hosting.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
User : gltevjme ( 1095)
PHP Version : 7.0.33
Disable Function : NONE
MySQL : OFF  |  cURL : ON  |  WGET : ON  |  Perl : ON  |  Python : ON  |  Sudo : OFF  |  Pkexec : OFF
Directory :  /home/gltevjme/bofirm.gltechlimited.com/vendor/bitpay/sdk/docs/usage/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Command :


[ Back ]     

Current File : /home/gltevjme/bofirm.gltechlimited.com/vendor/bitpay/sdk/docs/usage/refunds.md
# Refunds

## Create a new refund request

`POST /refunds`

Facades `MERCHANT`

### HTTP Request

Headers

| Fields | Description | Presence |
| --- | --- | :---: |
| `X-Accept-Version` | Must be set to `2.0.0` for requests to the BitPay API. | Mandatory |
| `Content-Type` | must be set to `application/json` for requests to the BitPay API. | Mandatory |
| `X-Identity` | the hexadecimal public key generated from the client private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |
| `X-Signature` | header is the ECDSA signature of the full request URL concatenated with the request body, signed with your private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |

Body

| Name | Description | Type | Presence |
| --- | --- | :---: | :---: |
| `invoiceId` | the id of the invoice to refund | `string` | Mandatory |
| `amount` | Amount to be refunded in the `currency` indicated | `number` | Mandatory |
| `currency` | reference currency used for the refund, usually the same as the currency used to create the invoice. | `string` | Mandatory |
| `preview` | whether to create the refund request as a preview (which will not be acted on until status is updated) | `boolean` | Default: `false` |
| `immediate` | whether funds should be removed from merchant ledger immediately on submission or at time of processing | `boolean` | Default: `false` |
| `buyerPaysRefundFee` | whether the buyer should pay the refund fee (default is `merchant`) | `boolean` | Default: `false` |

An example code of the create a new refund request

```php
$date = new \DateTime();
$today = $date->format("Y-m-d");
$dateBefore = $date->modify('-30 day');
$sevenDaysAgo = $dateBefore->format("Y-m-d");

$invoices = $bitpay->getInvoices($sevenDaysAgo, $today, InvoiceStatus::Complete);

$firstInvoice = $invoices[0];
$invoice = $bitpay->getInvoice($firstInvoice->getId());

$refunded = $bitpay->createRefund($invoice->getId(), 10.0, Currency::USD, true, false, false);
```

Response Body Fields

| Name | Description | Type |
| --- | --- | :---: |
| `id` | the refund request id | `string` |
| `requestDate` | the date that the refund request was created (ISO-8601) | `string` |
| `status` | refund lifecycle status of the request string. `preview` - no funds deducted, refund will not proceed automatically. `created` - funds deducted/allocated if immediate, will proceed when txs are confirmed and required data is collected. `pending` - refund is in process of being fulfilled. `cancelled` - refund was canceled by merchant action. `success` - refund was successfully processed. `failure` - refund failed during processing (this is really more of an internal state) | `string` |
| `amount` | Amount to be refunded in the currency indicated | `number` |
| `currency` | reference currency used for the refund, usually the same as the currency used to create the invoice. | `string` |
| `immediate` | whether funds should be removed from merchant ledger immediately on submission or at time of processing | `boolean` |
| `refundFee` | the amount of refund fee expressed in terms of pricing currency | `number` |
| `lastRefundNotification` | the last time notification of buyer was attempted | `date` |
| `invoice` | associated invoice id | `string` |
| `buyerPaysRefundFee` | whether the buyer should pay the refund fee (default is `merchant`) | `boolean` |

```json
{
   "id":"TPxL75VtRRuoNexUaNQ8da",
   "invoice":"8g6B3UsQ9QWvjqFrrYBssm",
   "status":"preview",
   "amount":1,
   "currency":"USD",
   "refundFee":0.09,
   "immediate":false,
   "buyerPaysRefundFee":false,
   "requestDate":"2021-12-21T14:42:58.000Z"
}
```

Error Scenarios & Format

| Name | Description | Type |
| --- | --- | :---: |
| `status` | will be “error” in an error scenario | `string` |
| `code` | six digit code that maps to an error on BitPay’s side | `string` |
| `data` | will be `null` in an error scenario | `object` |
| `Name` | error message pertaining to the specific error | `string` |

Example error response

```json
{
    "status": "error",
    "code": "010207",
    "data": null,
    "error": "Invalid invoice state for refund"
}
```

## Get existing refund request

`GET /refunds/:refundId`

Facades `MERCHANT`

### HTTP Request

URL Parameters

| Parameter | Description | Type | Presence |
| --- | --- | :---: | :---: |
| `refundId` | The id of the refund request | `string` | Mandatory |
| `?token=` | When fetching an existing refund request via the `merchant` facade, pass the API token as a URL parameter. | `string` | Mandatory |

Headers

| Fields | Description | Presence |
| --- | --- | :---: |
| `X-Accept-Version` | Must be set to `2.0.0` for requests to the BitPay API. | Mandatory |
| `Content-Type` | must be set to `application/json` for requests to the BitPay API. | Mandatory |
| `X-Identity` | the hexadecimal public key generated from the client private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |
| `X-Signature` | header is the ECDSA signature of the full request URL concatenated with the request body, signed with your private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |

To get the existing refund request, pass the Refund Id with URL parameter

```php
$retrievedRefund = $bitpay->getRefund($refunded->getId());
```

Response Body Fields

| Name | Description | Type |
| --- | --- | :---: |
| `id` | the refund request id | `string` |
| `requestDate` | the date that the refund request was created (ISO-8601) | `string` |
| `status` | refund lifecycle status of the request string. `preview` - no funds deducted, refund will not proceed automatically. `created` - funds deducted/allocated if immediate, will proceed when txs are confirmed and required data is collected. `pending` - refund is in process of being fulfilled. `cancelled` - refund was canceled by merchant action. `success` - refund was successfully processed. `failure` - refund failed during processing (this is really more of an internal state) | `string` |
| `amount` | Amount to be refunded in the currency indicated | `number` |
| `currency` | reference currency used for the refund, usually the same as the currency used to create the invoice. | `string` |
| `immediate` | whether funds should be removed from merchant ledger immediately on submission or at time of processing | `boolean` |
| `refundFee` | the amount of refund fee expressed in terms of pricing currency | `number` |
| `lastRefundNotification` | the last time notification of buyer was attempted | `date` |
| `invoice` | associated invoice id | `string` |
| `buyerPaysRefundFee` | whether the buyer should pay the refund fee (default is `merchant`) | `boolean` |

```json
{
    "id": "TPxL75VtRRuoNexUaNQ8da",
    "invoice": "8g6B3UsQ9QWvjqFrrYBssm",
    "status": "preview",
    "amount": 1,
    "currency": "USD",
    "refundFee": 0.09,
    "immediate": false,
    "buyerPaysRefundFee": false,
    "requestDate": "2021-12-21T14:42:58.000Z"
}
```

## Get all refund requests on an invoice

`GET /refunds?invoiceId=:invoiceId`

Facades `MERCHANT`

### HTTP Request

URL Parameters

| Parameter | Description | Type | Presence |
| --- | --- | :---: | :---: |
| `invoiceId` | The id of the invoice you want to look up. | `string` | Mandatory |
| `?token=` | The resource token for the `invoiceId` you want to look up. You need to retrieve this token from the invoice object itself, using the `merchant` facade. | `string` | Mandatory |

Headers

| Fields | Description | Presence |
| --- | --- | :---: |
| `X-Accept-Version` | Must be set to `2.0.0` for requests to the BitPay API. | Mandatory |
| `Content-Type` | must be set to `application/json` for requests to the BitPay API. | Mandatory |
| `X-Identity` | the hexadecimal public key generated from the client private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |
| `X-Signature` | header is the ECDSA signature of the full request URL concatenated with the request body, signed with your private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |

To get all refund requests for an invoice, pass the Invoice Id with URL parameter

```php
$retrievedRefunds = $bitpay->getRefunds($invoice->getId());
```

Response body fields same as `POST /refunds`

HTTP Response

```json
[
    {
        "id":"H9DpXzrNLxSzpKcVKPDqD1",
        "invoice":"8g6B3UsQ9QWvjqFrrYBssm",
        "status":"canceled",
        "amount":1,
        "currency":"USD",
        "lastRefundNotification":"2021-12-21T14:34:14.695Z",
        "refundFee":0.09,
        "immediate":false,
        "buyerPaysRefundFee":false,
        "requestDate":"2021-12-21T14:34:14.000Z"
    },
    {
        "id":"AtgkAGnW9RpAwqWs22mTF8",
        "invoice":"8g6B3UsQ9QWvjqFrrYBssm",
        "status":"canceled",
        "amount":1,
        "currency":"USD",
        "refundFee":0.09,
        "immediate":false,
        "buyerPaysRefundFee":false,
        "requestDate":"2021-12-21T14:34:21.000Z"
    },
    {
        "id":"TPxL75VtRRuoNexUaNQ8da",
        "invoice":"8g6B3UsQ9QWvjqFrrYBssm",
        "status":"canceled",
        "amount":1,
        "currency":"USD",
        "refundFee":0.09,
        "immediate":false,
        "buyerPaysRefundFee":false,
        "requestDate":"2021-12-21T14:42:58.000Z"
    },
    ...
]
```

## Update refund request

`PUT /refunds/:refundId`

Facades `MERCHANT`

### HTTP Request

URL Parameters

| Parameter | Description | Type | Presence |
| --- | --- | :---: | :---: |
| `refundId` | The id of the refund request | `string` | Mandatory |
| `?token=` | When fetching an existing refund request via the `merchant` facade, pass the API token as a URL parameter. | `string` | Mandatory |

Headers

| Fields | Description | Presence |
| --- | --- | :---: |
| `X-Accept-Version` | Must be set to `2.0.0` for requests to the BitPay API. | Mandatory |
| `Content-Type` | must be set to `application/json` for requests to the BitPay API. | Mandatory |
| `X-Identity` | the hexadecimal public key generated from the client private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |
| `X-Signature` | header is the ECDSA signature of the full request URL concatenated with the request body, signed with your private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |

To update the status of refund request

```php
$updateRefund = $bitpay->updateRefund($retrievedRefunds[0]->getId(), 'created');
```

Response body fields

| Name | Description | Type |
| --- | --- | :---: |
| `status` | set to `created` in order to confirm the refund request and initiate the flow to send it to shopper | `string` |

Success will return the updated refund request

HTTP Response

```json
{
    "id": "TPxL75VtRRuoNexUaNQ8da",
    "invoice": "8g6B3UsQ9QWvjqFrrYBssm",
    "status": "created",
    "amount": 1,
    "currency": "USD",
    "refundFee": 0.09,
    "immediate": false,
    "buyerPaysRefundFee": false,
    "requestDate": "2021-12-21T14:42:58.000Z"
}
```

## Cancel refund request

`GET /refunds/:refundId`

Facades `MERCHANT`

### HTTP Request

URL Parameters

| Parameter | Description | Type | Presence |
| --- | --- | :---: | :---: |
| `refundId` | The id of the refund request | `string` | Mandatory |
| `?token=` | When fetching an existing refund request via the `merchant` facade, pass the API token as a URL parameter. | `string` | Mandatory |

Headers

| Fields | Description | Presence |
| --- | --- | :---: |
| `X-Accept-Version` | Must be set to `2.0.0` for requests to the BitPay API. | Mandatory |
| `Content-Type` | must be set to `application/json` for requests to the BitPay API. | Mandatory |
| `X-Identity` | the hexadecimal public key generated from the client private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |
| `X-Signature` | header is the ECDSA signature of the full request URL concatenated with the request body, signed with your private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |

To cancel the refund request, no special parameters required, if successful will return refund request with updated status ('cancelled')

```php
$cancelRefund = $bitpay->cancelRefund($invoice->getId(), $retrievedRefund);
```
Response body fields same as `POST /refunds`

HTTP Response

```json
{
    "id": "TPxL75VtRRuoNexUaNQ8da",
    "invoice": "8g6B3UsQ9QWvjqFrrYBssm",
    "status": "created",
    "amount": 1,
    "currency": "USD",
    "refundFee": 0.09,
    "immediate": false,
    "buyerPaysRefundFee": false,
    "requestDate": "2021-12-21T14:42:58.000Z"
}
```

## Request refund notification

`POST /refunds/:refundId/notifications`

Facades `MERCHANT`

### HTTP Request

URL Parameters

| Parameter | Description | Type | Presence |
| --- | --- | :---: | :---: |
| `refundId` | The id of the refund request | `string` | Mandatory |

Headers

| Fields | Description | Presence |
| --- | --- | :---: |
| `X-Accept-Version` | Must be set to `2.0.0` for requests to the BitPay API. | Mandatory |
| `Content-Type` | must be set to `application/json` for requests to the BitPay API. | Mandatory |
| `X-Identity` | the hexadecimal public key generated from the client private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |
| `X-Signature` | header is the ECDSA signature of the full request URL concatenated with the request body, signed with your private key. This header is required when using tokens with higher privileges (`merchant` facade). When using standard `pos` facade token directly from the [BitPay dashboard](https://test.bitpay.com/dashboard/merchant/api-tokens) (with `"Require Authentication"` disabled), this header is not needed. | Mandatory |

Body

| Parameter | Description | Type | Presence |
| --- | --- | :---: | :---: |
| `token` | Pass the `merchant` with request body paraments. | `string` | Mandatory |

Request refund notification to be resent. Will trigger email to be resent to the buyer.

```php
$lastRefund = end($retrievedRefunds);

$notificationStatus = $bitpay->sendRefundNotification($lastRefund->getId());
```

Response body fields

| Name | Description | Type |
| --- | --- | :---: |
| `status` | set to `created` in order to confirm the refund request and initiate the flow to send it to shopper | `string` |

Success will return the updated refund request

HTTP Response

```json
{
    "status": "success",
}
```

## Get supported wallets

`GET /supportedWallets`

Facades `PUBLIC`

> **Note**: 
this endpoint uses the “public” facade and does not require a token

### HTTP Request

Headers

| Fields | Description | Presence |
| --- | --- | :---: |
| `X-Accept-Version` | Must be set to `2.0.0` for requests to the BitPay API. | Mandatory |
| `Content-Type` | must be set to `application/json` for requests to the BitPay API. | Mandatory |

To fetch the list of supported wallets and supported currency details

```php
$supportedWallets = $bitpay->getSupportedWallets();
```

Response body fields

| Name | Description | Type |
| --- | --- | :---: |
| `key` | a unique identifier for the wallet | `string` |
| `displayName` | human readable display name for the wallet | `string` |
| `avatar` | filename of a wallet graphic (not fully qualified) | `string` |
| `payPro` | whether or not the wallet supports ANY BitPay Payment Protocol options | `boolean` |
| `currencies` | details of what currencies support payments for this wallet | `object` |
| `code` | identifying code for the currency | `string` |
| `p2p` | indicates that this is a peer to peer (p2p) payment method (as opposed to payment protocol) | `boolean` |
| `dappBrowser` | indicates that this payment method operates via a browser plugin interacting with the invoice | `boolean` |
| `withdrawalFee` | custodial wallet withdrawal fee | `string` |
| `walletConnect` | whether or not this wallet supports walletConnect | `boolean` |
| `payPro` | whether or not BitPay Payment Protocol is supported on this particular currency option | `boolean` |
| `qr` | object containing QR code related information to show for this payment method | `object` |
| `type` | the type of QR code to use (ex. BIP21, ADDRESS, BIP72b, BIP681, BIP681b, etc) | `string` |
| `collapsed` | UI hint for BitPay invoice, generally not relevant to customer integrations | `boolean` |


### [Back to guide index](../../GUIDE.md)

Youez - 2016 - github.com/yon3zu
LinuXploit