All requests need to set api-key
to their peanut api key in their headers:
Header | Value |
---|---|
api-key |
YOUR_PEANUT_API_KEY |
POST
https://api.peanut.me/charges
Parameter | Type | Required | Description |
---|---|---|---|
pricing_type |
string | Yes | Type of pricing. Options: "fixed_price" , "no_price" |
local_price |
object | Yes | Price information containing amount and currency |
local_price.amount |
string | Yes | The price amount as a string |
local_price.currency |
string | No | The currency code (currently only "USD" is supported) |
baseUrl |
string | No | Custom base URL for the payment page |
requestId |
string | No | Existing request ID to associate with this charge |
requestProps |
object | No | Payment request properties |
metadata |
object | No | Arbitrary additional data. Returned in webhook call |
redirect_url |
string | No | URL to redirect user after successful payment |
cancel_url |
string | No | URL to redirect user if payment is canceled |
const res = await fetch('<https://api.peanut.me/charges>', {
method: 'POST',
headers: {
"Content-Type": "application/json",
'api-key': "YOUR_API_KEY"
},
body: JSON.stringify({
pricing_type: "fixed_price",
local_price: {
amount: "13.37",
currency: "USD"
},
redirect_url: "<https://shopify.com/success>",
cancel_url: "<https://shopify.com/cancel>"
})
});
const data = await res.json();
Status Code: 201 Created
{
"data": {
"id": "4f77223g-f5be-5e6d-bcb3-443f29gf5f5g",
"hosted_url": "<https://peanut.me/pay/4f77223g-f5be-5e6d-bcb3-443f29gf5f5g>",
"created_at": "2024-11-28T06:45:23.034Z",
"metadata": {
"userId": "0x742d35"
},
"pricing_type": "fixed_price",
"brand_color": "#122332",
"brand_logo_url": "",
"charge_kind": "WEB3",
"code": "4f77223g-f5be-5e6d-bcb3-443f29gf5f5g",
"collected_email": false,
"organization_name": "",
"payments": [],
"pricing": {
"local": {
"amount": "13.37",
"currency": "USD"
},
"settlement": {
"amount": "13.37",
"currency": "USD"
}
},
"pwcb_only": false,
"redirects": {
"cancel_url": "",
"success_url": "",
"will_redirect_after_success": false
},
"timeline": [],
"web3_retail_payments_enabled": true
},
"warnings": []
}
Status Code | Description |
---|---|
400 | Bad Request - Invalid input parameters |
500 | Internal Server Error |
GET
https://api.peanut.me/charges/{payment_id}
Parameter | Type | Description |
---|---|---|
chargeId |
string | The unique identifier of the charge |
Status Code: 200 OK
{
"data": {
"id": "4f77223g-f5be-5e6d-bcb3-443f29gf5f5g",
"hosted_url": "<https://peanut.me/pay/4f77223g-f5be-5e6d-bcb3-443f29gf5f5g>",
"created_at": "2024-11-28T06:45:23.034Z",
"pricing_type": "fixed_price",
"pricing": {
"local": {
"amount": "13.37",
"currency": "USD"
},
"settlement": {
"amount": "13.37",
"currency": "USD"
}
},
"payments": []
},
"warnings": []
}
Status Code | Description |
---|---|
404 | Not Found - Charge not found |
const response = await fetch('<https://api.peanut.me/charges/4f77223g-f5be-5e6d-bcb3-443f29gf5f5g>', {
method: 'GET',
headers: {
'api-key': 'YOUR_API_KEY'
}
});
const data = await response.json();
GET
https://api.peanut.me/charges
Parameter | Type | Description | Default |
---|---|---|---|
limit |
number | Maximum number of charges to return (1-100) | 25 |
starting_after |
string | Cursor for pagination, starting after this charge ID | - |
ending_before |
string | Cursor for pagination, ending before this charge ID | - |
status |
string | Filter charges by status | - |
Status Code: 200 OK
{
"data": [
{
"id": "4f77223g-f5be-5e6d-bcb3-443f29gf5f5g",
"hosted_url": "<https://peanut.me/pay/4f77223g-f5be-5e6d-bcb3-443f29gf5f5g>",
"created_at": "2024-11-28T06:45:23.034Z",
"pricing_type": "fixed_price",
"pricing": {
"local": {
"amount": "13.37",
"currency": "USD"
},
"settlement": {
"amount": "13.37",
"currency": "USD"
}
},
"payments": []
}
],
"pagination": {
"has_more": false,
"total": 1
},
"warnings": []
}
const response = await fetch('<https://api.peanut.me/charges>', {
method: 'GET',
headers: {
'api-key': 'YOUR_API_KEY'
}
});
const data = await response.json();
POST
https://api.peanut.me/api-keys/receiving-wallet
Parameter | Type | Description |
---|---|---|
walletAddress |
string | Destination wallet address |
chainId |
number | Blockchain network ID |
tokenAddress |
string | Token contract address |
const res = await fetch('<https://api.peanut.me/api-keys/receiving-wallet>', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'api-key': 'YOUR_API_KEY'
},
body: JSON.stringify({
walletAddress: '0x742d35Cc6634C0532925a3b844Bc454e4438f44e',
chainId: 10,
tokenAddress: '0xdAC17F958D2ee523a2206206994597C13D831ec7'
})
});
POST
https://api.peanut.me/api-keys/charge-webhook
Endpoint | Type | Description |
---|---|---|
url |
string | your receiving webhook URL |
const res = await fetch('<https://api.peanut.me/api-keys/charge-webhook>', {
method: 'POST',
headers: {
'Content-Type': 'application/json',
'api-key': 'YOUR_API_KEY'
},
body: JSON.stringify({
url: '<https://shopify.com/webhook>'
})
});
Records a payment transaction for a specific charge.
Endpoint: POST /charges/:uuid/payments
Content-Type: application/json