Allpay API Reference

API for Israel-based businesses. All requests are POST to https://allpay.to/app/?show=<endpoint>&mode=api12 with a JSON body. The show and mode parameters are passed in the URL query string — not in the JSON body — and are not included in the signature. Authentication uses your API login and a SHA256 signature.

Integration Flows

Choose the flow that matches your use case. Each links to the relevant endpoints.

Most common

Redirect Payment

  1. Call Create Payment → receive payment_url
  2. Redirect the customer to payment_url
  3. Customer enters card details on the Allpay payment page
  4. Allpay POSTs a webhook to your server → verify signature → fulfill order

Best for: standard e-commerce checkout.

Embedded form

Hosted Fields

  1. Call Create Payment with client_name and client_email → receive payment_url
  2. Embed the Hosted Fields iframe on your page using that URL
  3. Customer enters card details directly on your site
  4. Allpay POSTs a webhook → verify signature → fulfill order

Best for: keeping customers on your site. Hosted Fields guide →

Platform-managed billing

Token Billing

  1. Obtain an allpay_token: use Capture Token to save a card without charging, or Get Token from a completed payment
  2. Store the token securely on your side
  3. Whenever you need to charge, call Create Payment with allpay_token
  4. The charge is processed immediately — result returned synchronously; a webhook is sent to webhook_url (if provided)

Best for: SaaS, marketplaces — when you control the billing schedule and amounts.

Allpay-managed billing

Native Allpay Subscription

  1. Call Create Subscription → redirect customer to payment_url
  2. Customer authorizes the first charge
  3. Allpay charges automatically every month and sends a webhook for each charge
  4. Manage via Cancel, Status, and List endpoints

Best for: fixed monthly subscriptions — no billing logic needed on your side.

Two-step payment

Pre-authorization (J5)

  1. Call Create Payment with preauthorize: true → customer authorizes the reservation
  2. Allpay sends a webhook — amount is reserved on the card, not charged
  3. Within 7 days: call Charge Pre-auth to capture (up to reserved amount) — or Refund to void

Best for: deliveries, rentals, variable-weight goods — when the final amount is unknown at authorization time.

Authentication

Every request must include two fields in the JSON body:

FieldTypeDescription
login* string required Your API login — found in Settings → Integrations
sign* string required SHA256 signature of the request body (see algorithm below)

Signature Algorithm

The signature is generated from the request parameters using your private API key.

  1. Remove the sign field from the request.
  2. Exclude all parameters with empty values ("", null, missing).
  3. Sort the remaining keys in alphabetical order (A–Z). Alphabetical sorting must be applied everywhere — to top-level parameters, and to the keys inside each object within array parameters (such as items and subscription).
  4. From the sorted list, take only the parameter values and join them into a single string using a colon : as the separator.
  5. Append your API key to the end of the string, preceded by a colon.
  6. Apply SHA256 to the final string encoded as UTF-8.
Worked Example

Request body (before signing):

{
  "items": [
    {
      "name": "Test payment",
      "price": "1000",
      "qty": "1",
      "discount_val": "0",
      "discount_type": "fixed",
      "vat": "1"
    }
  ],
  "order_id": "1589758an",
  "client_name": "Jason Statham",
  "client_email": "[email protected]",
  "client_tehudat": "000000000",
  "currency": "ILS",
  "currency_display": "ILS",
  "lang": "AUTO",
  "preauthorize": "0",
  "allpay_token": "",       ← excluded (empty string)
  "inst": "",               ← excluded (empty string)
  "doc_type": "",           ← excluded (empty string)
  "button_title": "pay",
  "success_url": "https://example.com/success",
  "webhook_url": "https://example.com/hook/allpay",
  "backlink_url": "",       ← excluded (empty string)
  "login": "pp1008795"
}

Sorted keys A–Z with their values (items[] fields also sorted A–Z and flattened inline):

button_title      → "pay"
client_email      → "[email protected]"
client_name       → "Jason Statham"
client_tehudat    → "000000000"
currency          → "ILS"
currency_display  → "ILS"
items[0]          → discount_type="fixed", discount_val="0", name="Test payment", price="1000", qty="1", vat="1"
lang              → "AUTO"
login             → "pp1008795"
order_id          → "1589758an"
preauthorize      → "0"  ← included ("0" is not empty)
success_url       → "https://example.com/success"
webhook_url       → "https://example.com/hook/allpay"

String to sign (values joined with :, API key appended):

pay:[email protected]:Jason Statham:000000000:ILS:ILS:fixed:0:Test payment:1000:1:1:AUTO:pp1008795:1589758an:0:https://example.com/success:https://example.com/hook/allpay:CB545B50989469F7258C8E043462B30C

SHA256 result:

c3c5458724d88837bd60879b5130c860589e42248360b4ca42c2539ebf8a7803
⚠️ Make sure you follow these steps exactly. 99% of "Invalid signature" errors are caused by: trimming spaces from values, treating 0 as empty (it is a valid value and is included in the signature), or omitting parameters from the signature function. Empty values are "", null, and missing fields only.

Errors

All errors return HTTP 200 with a JSON body containing error_code and error_msg:

{
  "error_code": 3,
  "error_msg":  "Signature is incorrect"
}
error_codeerror_msgDescription
2 Missing required parameters: ... A required parameter is missing, has an invalid value, or failed validation (price, qty, discount, email format, doc_type eligibility). The error message lists the specific fields.
3 Signature is incorrect The sign parameter does not match the expected SHA256 signature.
5 Login incorrect The login parameter does not match any Allpay account.
6 Order not found / Subscription not found No order or subscription with the given order_id was found for this account.
9 Incorrect token The allpay_token does not exist or is invalid.
12 <processor message> The payment processor declined the token charge. The message contains the processor's reason.
13 Token creation error Failed to retrieve a token for the given order (gettoken endpoint).
15 Order ID ... has already been paid An order with this order_id already exists and has been paid. Use a unique order_id for each payment.
16 Same order can not be charged twice / Refund error: wrong order status Attempted to charge a J5 pre-authorization that was already captured, or to refund an order that is not in a paid state.
17 Processor refund error: ... The payment processor returned an error when processing the refund.
18 Subscription can only include one item The items array contains more than one item in a subscription request.
19 Payment error: wrong order status The payment processor returned an unexpected status when capturing a J5 pre-authorization.
20 Incorrect method The show parameter in the URL contains an unknown or unsupported endpoint name.
21 Amount must be at least 5 ILS The total payment amount (after applying currency rate) is below the minimum of 5 ILS. Applies only to ILS payments (currency = ILS or not specified).
const crypto = require('crypto');

function allpaySign(data, apiKey) {
  const d = Object.fromEntries(
    Object.entries({...data})
      .filter(([k, v]) => k !== 'sign' && v !== '' && v != null)
  );
  const chunks = [];
  for (const key of Object.keys(d).sort()) {
    const val = d[key];
    if (Array.isArray(val)) {
      for (const item of val)
        for (const k of Object.keys(item).sort())
          if (item[k] !== '' && item[k] != null)
            chunks.push(String(item[k]));
    } else {
      chunks.push(String(val));
    }
  }
  chunks.push(apiKey);
  return crypto
    .createHash('sha256')
    .update(chunks.join(':'))
    .digest('hex');
}
function allpay_sign(array $data, string $api_key): string {
  unset($data['sign']);
  $data = array_filter($data, fn($v) => $v !== '' && $v !== null);
  ksort($data);
  $chunks = [];
  foreach ($data as $val) {
    if (is_array($val)) {
      foreach ($val as $item) {
        ksort($item);
        foreach ($item as $v)
          if ($v !== '' && $v !== null) $chunks[] = (string)$v;
      }
    } else {
      $chunks[] = (string)$val;
    }
  }
  $chunks[] = $api_key;
  return hash('sha256', implode(':', $chunks));
}
import hashlib

def allpay_sign(data: dict, api_key: str) -> str:
    d = {k: v for k, v in data.items()
         if k != 'sign' and v not in ('', None)}
    chunks = []
    for key in sorted(d):
        val = d[key]
        if isinstance(val, list):
            for item in val:
                for k in sorted(item):
                    if item[k] not in ('', None):
                        chunks.append(str(item[k]))
        else:
            chunks.append(str(val))
    chunks.append(api_key)
    return hashlib.sha256(':'.join(chunks).encode()).hexdigest()

Payments

Create payment links, check status, issue refunds.

Create Payment

POSThttps://allpay.to/app/?show=getpayment&mode=api12

The payment process follows three steps: (1) send a signed POST request to create a payment link, (2) redirect the customer to the returned payment_url, (3) receive a webhook notification at your webhook_url once payment is complete.

Parameters

NameTypeDescription
login*stringrequiredYour API login from Settings → Integrations
order_id*stringrequiredUnique order identifier in your system. Use a unique order_id for each new payment — do not reuse an order_id from a previous paid payment (see error 15).
items*arrayrequiredList of products/services. Displayed in your Allpay account and on accounting documents. The total charge is calculated from item prices × quantities.
FieldTypeRequiredDescription
name* string required Product or service name
qty* number required Quantity
price* number required Unit price. VAT must already be included in the price — it is not added on top.
vat* integer required VAT rate included in the price: 0 — no VAT (VAT-exempt), 1 — 18% VAT, 3 — 0% VAT
discount_val number optional Discount value — deducted from item price
discount_type string optional Whether discount_val is a fixed amount or a percentage: fixed or perc. Required when discount_val is provided.
sign*stringrequiredSHA256 signature
currencystringoptionalThe billing (settlement) currency — the currency in which the customer is charged and your account is settled. If your account does not have permission to process USD or EUR, the amount is automatically converted to ILS using Google Finance exchange rates.
ILSUSDEUR
currency_displaystringoptionalThe display currency shown to the customer on the payment page. The price values in the request must be provided in this currency — Allpay automatically converts the amount to the billing currency. Examples: CAD, AED, RUB. Full list of supported currencies → When currency_display is used, the webhook amount reflects the display currency value (as specified in the request items), while the currency field reflects the billing currency — they refer to different currencies.
langstringoptionalPayment page language.
AUTOENHERUARESITDEFR
button_titlestringoptionalText on the payment button.
paydonatesubscribe
doc_typeintegeroptionalType of the document issued after a successful payment — applies to one-time payments, token payments, and subscription charges. If not provided, the default value is taken from your account settings.
320 — Tax Invoice Receipt400 — Receipt405 — Receipt for donation
⚠️ The payment will not be created and an error will be returned if: the account has no active accounting system integration, or the requested document type is one your business is not eligible to issue.
webhook_urlstringoptionalAfter a successful or failed payment, Allpay sends a POST webhook with payment details to this URL. If not provided, the transaction will be visible only in your Allpay dashboard.
success_urlstringoptionalThe customer is redirected to this URL after successful payment. If not provided, the customer is redirected to the default Allpay success page.
backlink_urlstringoptionalURL for the "Return to site" button displayed at the bottom of the payment page — allows the customer to return to your checkout. Note: there is no fail URL — payment errors are displayed directly on the payment page, prompting the customer to make a new attempt.
instintegeroptionalMax installment payments offered (1–12)
inst_fixedintegeroptional
0 — customer chooses from 1 up to the inst value1 — number of payments is fixed at the inst value; customer cannot change it
allpay_tokenstringoptionalCharge a card using a saved token — the customer does not need to re-enter card details. The payment is processed immediately and the result is returned synchronously in the API response. A webhook is sent to webhook_url (if provided), same as for regular payments. Use a new, unique order_id for each charge — do not reuse order_ids across recurring charges. On success: {"order_id","status":1}. On failure: {"error_code","error_msg"}.
preauthorizebooleanoptionalIf true, creates a J5 pre-authorization — the amount is reserved on the customer's card for up to 168 hours (7 days), but no charge is made. To collect the funds, a separate Charge Pre-auth request must be sent within this period.
subscriptionobjectoptionalAdd to create a recurring subscription. See Create Subscription.
client_namestringoptionalCustomer's full name (any language). If not provided, the customer will be asked to enter it on the payment page. Required when using Hosted Fields integration.
client_emailstringoptionalCustomer's email address. Used to send an invoice if a digital invoicing service is enabled. If not provided, the customer will be asked to enter it on the payment page. Required when using Hosted Fields integration.
client_phonestringoptionalCustomer's phone number.
client_tehudatstringoptionalFor private customers — Social ID (Tehudat Zehut); for companies — Company Number (Mispar Het Pey). Pass "000000000" to hide this field and skip the ID request for non-Israeli customers.
show_applepaybooleanoptionalShow Apple Pay button (module must be active)
show_bitbooleanoptionalShow Bit payment button (module must be active)
add_field_1stringoptionalAny additional data about the order or customer — returned unchanged in the webhook.
add_field_2stringoptionalAny additional data about the order or customer — returned unchanged in the webhook.
expireintegeroptionalUnix timestamp when the payment link expires (default: 1 week)

Response

Redirect flow (no allpay_token):

FieldTypeDescription
payment_urlstringURL to redirect the customer to

Token payment flow (allpay_token provided) — on success:

FieldTypeDescription
order_idstringOrder identifier
statusinteger1 — charge successful

A webhook is sent to webhook_url (if provided) — identical in structure to webhooks from regular (redirect-flow) payments.

On failure:

FieldTypeDescription
error_codeintegerError code from the payment processor
error_msgstringHuman-readable error description
// Redirect flow
{ "payment_url": "https://allpay.to/~login/pay/?payment_id=abc123&code=xyz" }

// Token flow — success
{ "order_id": "ORDER-001", "status": 1 }

// Token flow — failure
{ "error_code": 12, "error_msg": "Payment declined" }
curl https://allpay.to/app/?show=getpayment&mode=api12 \
  -X POST \
  -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "ORDER-001",
    "items": [{
      "name": "Product A",
      "qty": 1,
      "price": 100,
      "vat": 1
    }],
    "currency": "ILS",
    "webhook_url": "https://yoursite.com/webhook",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
const crypto = require('crypto');

function allpaySign(data, apiKey) {
  const d = Object.fromEntries(
    Object.entries({...data})
      .filter(([k, v]) => k !== 'sign' && v !== '' && v != null)
  );
  const chunks = [];
  for (const key of Object.keys(d).sort()) {
    const val = d[key];
    if (Array.isArray(val)) {
      for (const item of val)
        for (const k of Object.keys(item).sort())
          if (item[k] !== '' && item[k] != null) chunks.push(String(item[k]));
    } else chunks.push(String(val));
  }
  chunks.push(apiKey);
  return crypto.createHash('sha256').update(chunks.join(':')).digest('hex');
}

const body = {
  login: 'your_login',
  order_id: 'ORDER-001',
  items: [{ name: 'Product A', qty: '1', price: '100', vat: '1' }],
  currency: 'ILS',
  webhook_url: 'https://yoursite.com/webhook'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');

const res = await fetch('https://allpay.to/app/?show=getpayment&mode=api12', {
  method: 'POST',
  headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(body)
});
const { payment_url } = await res.json();
function allpay_sign(array $data, string $api_key): string {
  unset($data['sign']);
  $data = array_filter($data, fn($v) => $v !== '' && $v !== null);
  ksort($data);
  $chunks = [];
  foreach ($data as $val) {
    if (is_array($val)) {
      foreach ($val as $item) {
        ksort($item);
        foreach ($item as $v)
          if ($v !== '' && $v !== null) $chunks[] = (string)$v;
      }
    } else { $chunks[] = (string)$val; }
  }
  $chunks[] = $api_key;
  return hash('sha256', implode(':', $chunks));
}

$body = [
  'login'    => 'your_login',
  'order_id' => 'ORDER-001',
  'items'    => [[
    'name' => 'Product A', 'qty' => '1',
    'price' => '100',       'vat' => '1'
  ]],
  'currency'    => 'ILS',
  'webhook_url' => 'https://yoursite.com/webhook'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');

$ch = curl_init('https://allpay.to/app/?show=getpayment&mode=api12');
curl_setopt_array($ch, [
  CURLOPT_POST           => true,
  CURLOPT_POSTFIELDS     => json_encode($body),
  CURLOPT_HTTPHEADER     => ['Content-Type: application/json'],
  CURLOPT_RETURNTRANSFER => true
]);
$response = json_decode(curl_exec($ch), true);
$payment_url = $response['payment_url'];
import hashlib, requests

def allpay_sign(data: dict, api_key: str) -> str:
    d = {k: v for k, v in data.items()
         if k != 'sign' and v not in ('', None)}
    chunks = []
    for key in sorted(d):
        val = d[key]
        if isinstance(val, list):
            for item in val:
                for k in sorted(item):
                    if item[k] not in ('', None):
                        chunks.append(str(item[k]))
        else: chunks.append(str(val))
    chunks.append(api_key)
    return hashlib.sha256(':'.join(chunks).encode()).hexdigest()

body = {
    'login': 'your_login',
    'order_id': 'ORDER-001',
    'items': [{'name': 'Product A', 'qty': '1',
               'price': '100', 'vat': '1'}],
    'currency': 'ILS',
    'webhook_url': 'https://yoursite.com/webhook'
}
body['sign'] = allpay_sign(body, 'YOUR_API_KEY')
res = requests.post('https://allpay.to/app/?show=getpayment&mode=api12', json=body)
payment_url = res.json()['payment_url']
# cURL
curl https://allpay.to/app/?show=getpayment&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "ORDER-002",
    "items": [{"name": "Monthly CRM plan", "qty": "1", "price": "49.00", "vat": "1"}],
    "currency": "ILS",
    "allpay_token": "TOKEN_VALUE",
    "sign": "YOUR_COMPUTED_SIGN"
  }'

// Node.js
const body = {
  login: 'your_login',
  order_id: 'ORDER-002',
  items: [{ name: 'Monthly CRM plan', qty: '1', price: '49.00', vat: '1' }],
  currency: 'ILS',
  allpay_token: 'TOKEN_VALUE'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const res = await (await fetch('https://allpay.to/app/?show=getpayment&mode=api12', {
  method: 'POST', headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(body)
})).json();
// success: { order_id, status: 1 }
// failure: { error_code, error_msg }

// PHP
$body = [
  'login'        => 'your_login',
  'order_id'     => 'ORDER-002',
  'items'        => [['name' => 'Monthly CRM plan', 'qty' => '1', 'price' => '49.00', 'vat' => '1']],
  'currency'     => 'ILS',
  'allpay_token' => 'TOKEN_VALUE'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=getpayment&mode=api12
// success: ['order_id' => ..., 'status' => 1]
// failure: ['error_code' => 12, 'error_msg' => '...']

Payment Webhook

Allpay sends a POST request with Content-Type: application/json and a JSON body to your webhook_url after every payment attempt — both successful and failed. Respond with HTTP 200 to acknowledge. Allpay makes up to 10 delivery attempts total — the first retry 1 minute after the initial failure, then with progressively increasing intervals, with the final attempt within 24 hours.

✅ Always verify the signature before processing. A payment is confirmed only when status == 1.

Payload Fields

FieldTypeDescription
order_idstringYour order identifier
statusinteger
0 — unpaid / failed1 — successful
amountnumberPayment amount
currencystringILS / USD / EUR
instintegerNumber of installment payments
card_maskstringMasked card number, e.g. 465901******7049
card_brandstringVisa / Mastercard / AmEx / Diners
foreign_cardinteger
0 — local card (issued by an Israeli bank)1 — foreign card
receiptstringURL to the digital receipt. Generated only if the Receipts module is active in your Allpay account.
client_namestringCustomer name
client_emailstringCustomer email
client_phonestringCustomer phone
client_tehudatstringCustomer Social ID (if provided)
add_field_1stringCustom data from request (unchanged)
add_field_2stringCustom data from request (unchanged)
signstringSHA256 signature — verify using your API key
Important: status = 0 in a webhook means that this payment attempt failed. It does not mean the order is permanently cancelled — the customer may still retry payment on the same payment page. Fulfill the order only when status = 1 and the signature is valid.
{
  "order_id":      "ORDER-001",
  "status":       1,
  "amount":       100.00,
  "currency":     "ILS",
  "inst":         1,
  "card_mask":    "465901******7049",
  "card_brand":   "Visa",
  "foreign_card": 0,
  "client_name":  "Joe Doe",
  "client_email": "[email protected]",
  "add_field_1":  "your-data",
  "sign":         "abc123..."
}
$payload = json_decode(file_get_contents('php://input'), true);
$received_sign = $payload['sign'] ?? '';

// Verify signature first
$expected = allpay_sign($payload, 'YOUR_API_KEY');
if (!hash_equals($expected, $received_sign)) {
  http_response_code(400);
  exit;
}

// Fulfill order only on successful payment
if ((int)$payload['status'] === 1) {
  fulfill_order($payload['order_id'], $payload['amount']);
}

// Always acknowledge receipt — including failed payment attempts
http_response_code(200);
echo 'OK';
app.post('/webhook', (req, res) => {
  const payload = req.body;
  const expected = allpaySign(payload, 'YOUR_API_KEY');

  // Use timing-safe comparison
  if (!crypto.timingSafeEqual(Buffer.from(expected), Buffer.from(payload.sign))) {
    return res.sendStatus(400);
  }

  if (payload.status === 1) {
    fulfillOrder(payload.order_id, payload.amount);
  }

  // Always respond 200 — including failed payment attempts
  res.sendStatus(200);
});

Check Payment Status

POSThttps://allpay.to/app/?show=paymentstatus&mode=api12

Check the status of a payment. Call at least 2 seconds after the payment attempt.

Parameters

NameTypeDescription
login*stringrequiredAPI login
order_id*stringrequiredOrder identifier
sign*stringrequiredSHA256 signature

Response

FieldTypeDescription
order_idstringOrder identifier
statusinteger
0 — unpaid / not yet completed (payment attempt may have failed; customer can still retry)1 — successful3 — refunded4 — partially refunded
amountnumberPayment amount
currencystringBilling currency
instintegerInstallment count
card_maskstringMasked card number
card_brandstringCard brand
foreign_cardinteger
0 — local card (issued by an Israeli bank)1 — foreign card
receiptstringURL to the digital receipt. Generated only if the Receipts module is active in your Allpay account.
client_name / email / phone / tehudatstringCustomer details
{
  "order_id":      "ORDER-001",
  "status":       1,
  "amount":       100.00,
  "inst":         1,
  "currency":     "ILS",
  "foreign_card": 0,
  "card_mask":    "465901******7049",
  "card_brand":   "Visa",
  "receipt":      "",
  "client_name":  "Joe Doe",
  "client_email": "[email protected]",
  "client_phone": "+972501234567",
  "client_tehudat": "123456789"
}
curl https://allpay.to/app/?show=paymentstatus&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "ORDER-001",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'    => 'your_login',
  'order_id' => 'ORDER-001'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=paymentstatus&mode=api12
// $response['status']: 0=unpaid, 1=paid, 3=refunded, 4=partial refund
const body = {
  login: 'your_login', order_id: 'ORDER-001'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { status, amount, currency } = await (await fetch('https://allpay.to/app/?show=paymentstatus&mode=api12', {
  method: 'POST', headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(body)
})).json();
// status: 0=unpaid, 1=paid, 3=refunded, 4=partial refund

Refund Payment

POSThttps://allpay.to/app/?show=refund&mode=api12

Issue a full or partial refund. Refunds are processed from your available withdrawal balance.

Parameters

NameTypeDescription
login*stringrequiredAPI login
order_id*stringrequiredOrder identifier
amount*stringrequiredTotal refund amount as a string (e.g. "100.00"). Must be a string for correct signature calculation.
sign*stringrequiredSHA256 signature
itemsarrayoptionalFor partial refund: array matching original items count/order. Each object has one field: amount (string). Use "0" to skip an item. Amounts must be strings.

Response

FieldTypeDescription
order_idstringOrder identifier
statusinteger
3 — fully refunded4 — partially refunded
# Full refund — omit items
curl https://allpay.to/app/?show=refund&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "ORDER-001",
    "amount": "100.00",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
// Partial refund: 3 original items, refund only 2nd
$body = [
  'login'    => 'your_login',
  'order_id' => 'ORDER-001',
  'amount'   => '200.00',
  'items'    => [
    ['amount' => '0'],    // item 1: skip
    ['amount' => '200'],  // item 2: refund 200
    ['amount' => '0'],    // item 3: skip
  ]
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=refund&mode=api12
// Full refund
const body = {
  login: 'your_login', order_id: 'ORDER-001',
  amount: '100.00'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { status } = await (await fetch('https://allpay.to/app/?show=refund&mode=api12', {
  method: 'POST', headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(body)
})).json();
// status 3 = fully refunded, 4 = partially refunded

Subscriptions

Create and manage recurring billing. Currently, only monthly frequency is supported. Requires the Subscriptions module to be active on your account.

Create Subscription

POSThttps://allpay.to/app/?show=getpayment&mode=api12

Same as Create Payment but with an additional subscription object. Returns a payment_url for the customer to authorize the first charge. Subsequent charges happen automatically each month with webhooks sent for each. If the subscription object is omitted, the request is processed as a regular one-time payment.

subscription object

NameTypeDescription
start_type*integerrequiredWhen first charge occurs:
1 — immediately (the customer is charged when they complete the payment page)2 — specific date (start_date)3 — after N days (start_n)
start_dateintegeroptionalUnix timestamp (required if start_type=2)
start_nintegeroptionalNumber of days (required if start_type=3)
end_type*integerrequiredWhen subscription ends:
1 — infinite2 — specific date (end_date)3 — after N charges (end_n)
end_dateintegeroptionalUnix timestamp (required if end_type=2)
end_nintegeroptionalNumber of charges (required if end_type=3)
Note: Subscriptions can include only one item in the items array (see error 18). If you need to describe multiple components, combine them into one item name or manage billing on your side using tokens.

Additional top-level parameter

NameTypeDescription
button_titlestringoptionalButton text. Default for subscriptions is subscribe.
subscribepaydonate
Subscription charge webhooks use the same structure as Payment Webhook. The order_id in every webhook — including the first charge and all recurring charges — is the original subscription order_id. Each successful charge has status = 1; a failed charge has status = 0. There is no field in the webhook payload that identifies the specific recurring charge or distinguishes it from the first charge.
curl https://allpay.to/app/?show=getpayment&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "SUB-001",
    "items": [{"name": "Monthly Plan", "qty": "1", "price": "49", "vat": "1"}],
    "currency": "ILS",
    "webhook_url": "https://yoursite.com/webhook",
    "button_title": "subscribe",
    "subscription": {"start_type": 1, "end_type": 1},
    "sign": "YOUR_COMPUTED_SIGN"
  }'
const body = {
  login: 'your_login',
  order_id: 'SUB-001',
  items: [{ name: 'Monthly Plan', qty: '1', price: '49', vat: '1' }],
  currency: 'ILS',
  webhook_url: 'https://yoursite.com/webhook',
  button_title: 'subscribe',
  subscription: {
    start_type: 1,   // immediately
    end_type:   1    // infinite
  }
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
$body = [
  'login'    => 'your_login',
  'order_id' => 'SUB-001',
  'items'    => [['name' => 'Monthly Plan', 'qty' => '1', 'price' => '49', 'vat' => '1']],
  'currency'  => 'ILS',
  'webhook_url' => 'https://yoursite.com/webhook',
  'subscription' => [
    'start_type' => 3, 'start_n' => 7,  // first charge after 7 days
    'end_type'   => 3, 'end_n'   => 12  // cancel after 12 charges
  ]
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=getpayment&mode=api12
body = {
    'login': 'your_login',
    'order_id': 'SUB-001',
    'items': [{'name': 'Monthly Plan', 'qty': '1',
               'price': '49', 'vat': '1'}],
    'currency': 'ILS',
    'subscription': {
        'start_type': '1', 'end_type': '1'
    }
}
body['sign'] = allpay_sign(body, 'YOUR_API_KEY')
# POST to https://allpay.to/app/?show=getpayment&mode=api12

Cancel Subscription

POSThttps://allpay.to/app/?show=cancelsubscription&mode=api12

Parameters

NameTypeDescription
login*stringrequiredAPI login
order_id*stringrequiredSubscription order ID
sign*stringrequiredSHA256 signature

Response

FieldTypeDescription
statusintegerAfter cancellation you can expect 4 or 2 (subscription was already completed — no cancellation needed).
1 — active2 — completed3 — error4 — cancelled
curl https://allpay.to/app/?show=cancelsubscription&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "SUB-001",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'    => 'your_login',
  'order_id' => 'SUB-001'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=cancelsubscription&mode=api12
// status 4 = cancelled, 2 = already completed
const body = {
  login: 'your_login', order_id: 'SUB-001'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { status } = await (await fetch('https://allpay.to/app/?show=cancelsubscription&mode=api12', {
  method: 'POST', headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(body)
})).json();
// status 4 = cancelled, 2 = already completed

Subscription Status

POSThttps://allpay.to/app/?show=subscriptionstatus&mode=api12

Get detailed status and full charge history of a subscription.

Parameters

NameTypeDescription
login*stringrequiredAPI login
order_id*stringrequiredSubscription order ID
sign*stringrequiredSHA256 signature

Response

FieldTypeDescription
order_idstringSubscription ID
statusinteger
1 — active2 — completed3 — error (last charge failed, retry tomorrow)4 — cancelled
amountnumberAmount per charge
currencystringILS / USD / EUR
payments_nintegerNumber of successful charges
paid_totalnumberTotal amount charged
paymentsarrayCharge history: each item has ts (Unix timestamp), amount, receipt (URL)
{
  "order_id":    "SUB-001",
  "status":     1,
  "amount":     49.00,
  "currency":   "ILS",
  "payments_n": 3,
  "paid_total": 147.00,
  "payments": [
    { "ts": 1748131200, "amount": 49.00, "receipt": "" },
    { "ts": 1745539200, "amount": 49.00, "receipt": "" },
    { "ts": 1742947200, "amount": 49.00, "receipt": "" }
  ]
}
curl https://allpay.to/app/?show=subscriptionstatus&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "SUB-001",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'    => 'your_login',
  'order_id' => 'SUB-001'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=subscriptionstatus&mode=api12
// $response['status']: 1=active, 2=completed, 3=error, 4=cancelled
// $response['payments_n'] — successful charges count
// $response['paid_total'] — total charged amount
const body = {
  login: 'your_login', order_id: 'SUB-001'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { status, payments_n, paid_total } =
  await (await fetch('https://allpay.to/app/?show=subscriptionstatus&mode=api12',
    { method: 'POST', headers: {'Content-Type':'application/json'}, body: JSON.stringify(body) }
  )).json();
// status: 1=active, 2=completed, 3=error, 4=cancelled

List Subscriptions

POSThttps://allpay.to/app/?show=getsubscriptions&mode=api12

Returns a paginated list of subscriptions created via API under this API login (100 per page). Subscriptions created from the dashboard or under a different API login are not included.

Parameters

NameTypeDescription
login*stringrequiredAPI login
sign*stringrequiredSHA256 signature
statusintegeroptionalFilter by subscription status. If omitted or set to 0, returns all subscriptions regardless of status.
0 — any1 — active2 — completed3 — error4 — cancelled
pageintegeroptionalPage number to retrieve. If not provided, the first page is returned. Each page contains up to 100 subscriptions.

Response

FieldTypeDescription
total_nintegerTotal subscriptions returned
next_pageintegerNext page number, or 0 if no more pages
subscriptionsarrayArray of subscription objects.
FieldTypeDescription
order_idstringSubscription order identifier
namestringSubscription name (from the first item)
statusinteger
1 — active2 — completed3 — error4 — cancelled
amountnumberAmount per charge
currencystringILS / USD / EUR
payments_nintegerNumber of successful charges made
paid_totalnumberTotal amount charged to date
date_startintegerUnix timestamp of the first charge
date_endintegerUnix timestamp of the last charge; 0 for infinite subscriptions
next_paymentintegerUnix timestamp of the next scheduled charge
client_namestringCustomer name
client_emailstringCustomer email
client_phonestringCustomer phone
client_tehudatstringCustomer Social ID (if provided)
add_field_1stringCustom data from the original request (if provided)
add_field_2stringCustom data from the original request (if provided)
{
  "total_n":  1,
  "next_page": 0,
  "subscriptions": [{
    "order_id":      "SUB-001",
    "name":         "Monthly Plan",
    "status":       1,
    "amount":       49.00,
    "currency":     "ILS",
    "payments_n":   3,
    "paid_total":   147.00,
    "date_start":   1742947200,
    "date_end":     0,  // 0 = infinite
    "next_payment": 1750723200,
    "client_name":  "Joe Doe",
    "client_email": "[email protected]",
    "client_phone": "+972501234567",
    "client_tehudat": "123456789",
    "add_field_1":  "custom-data",
    "add_field_2":  ""
  }]
}
curl https://allpay.to/app/?show=getsubscriptions&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "status": "1",
    "page": "1",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'  => 'your_login',
  'status' => '1', // active only
  'page'   => '1'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=getsubscriptions&mode=api12
// $response['subscriptions'] — array of subscriptions
// $response['next_page'] — 0 if no more pages
const body = {
  login: 'your_login', status: '1', page: '1'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { subscriptions, total_n, next_page } = await (await fetch('https://allpay.to/app/?show=getsubscriptions&mode=api12', {
  method: 'POST', headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(body)
})).json();

Subscription Statistics

POSThttps://allpay.to/app/?show=subscriptionsinfo&mode=api12

Statistical breakdown of subscriptions grouped by status.

Parameters

NameTypeDescription
login*stringrequiredAPI login
sign*stringrequiredSHA256 signature

Response

info — array, one entry per status group:

FieldTypeDescription
statusinteger
1 — active2 — completed3 — error4 — cancelled
total_nintegerNumber of subscriptions with this status
total_amountnumberSum of all subscription amounts for this status group
{
  "info": [
    { "status": 1, "total_n": 42, "total_amount": 2058.00 },
    { "status": 2, "total_n":  5, "total_amount":  245.00 },
    { "status": 4, "total_n":  7, "total_amount":  343.00 }
  ]
}
curl https://allpay.to/app/?show=subscriptionsinfo&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login' => 'your_login'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=subscriptionsinfo&mode=api12
// $response['info'][0] = ['status' => 1, 'total_n' => 42, 'total_amount' => 2058.00]
const body = { login: 'your_login' };
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { info } = await (await fetch('https://allpay.to/app/?show=subscriptionsinfo&mode=api12', {
  method: 'POST', headers: {'Content-Type': 'application/json'},
  body: JSON.stringify(body)
})).json();
// info[0] = { status: 1, total_n: 42, total_amount: 2058.00 }

Tokens

Save a card without charging, then reuse it for future payments without requiring the customer to re-enter card details.

⚠️ Bit and Apple Pay do not support tokenization.
🔒 Before charging a customer's card using a token, ensure you have their explicit consent. Unauthorized charges may result in withdrawal of your acquiring permission and blocking of your Allpay account.

Capture Token Without Payment

POSThttps://allpay.to/app/?show=capturetoken&mode=api12

Creates a card capture session. Returns a payment_url where the customer enters their card details — no charge is made. In case of a successful card capture, Allpay sends a POST webhook to your webhook_url. The webhook includes the allpay_token, which can be used to initiate a new payment or a subscription.

Parameters

NameTypeDescription
login*stringrequiredAPI login
order_id*stringrequiredUnique identifier in your system. Use a unique order_id for each capture session — do not reuse an order_id from a previous capture.
items*arrayrequiredItems for display only (no charge). Only name field is required per item.
sign*stringrequiredSHA256 signature
button_titlestringoptionalSubmit button text.
submitsavesubscribepaydonate
langstringoptionalPage language (AUTO, EN, HE, RU, AR, ES, IT, DE, FR)
webhook_urlstringoptionalAllpay sends a POST webhook with card details, capture status, and allpay_token to this URL. If not provided, the token will only be visible in your Allpay dashboard.
success_urlstringoptionalThe customer is redirected to this URL after the token is captured. If not provided, the customer is redirected to the default Allpay success page.
backlink_urlstringoptionalURL for the "Return to site" button displayed at the bottom of the page. Note: there is no fail URL — errors are displayed directly on the page, prompting the customer to try again.
client_name / email / phone / tehudatstringoptionalPrefill customer fields
add_field_1 / add_field_2stringoptionalCustom data — returned in webhook
expireintegeroptionalUnix timestamp when link expires (default: 1 week)

API Response

payment_urlstringRedirect the customer here

Webhook (after customer submits card)

Success (status = 1):

FieldTypeDescription
order_idstringYour order identifier
statusinteger1 — token captured successfully
allpay_tokenstringToken representing the customer's card — use in future Create Payment calls or Create Subscription
itemsarrayItems from the request
card_maskstringMasked card number, e.g. 465901******7049
card_brandstringVisa / Mastercard / AmEx / Diners
foreign_cardinteger
0 — local card (issued by an Israeli bank)1 — foreign card
client_namestringCustomer name (if provided in request)
client_emailstringCustomer email (if provided in request)
client_phonestringCustomer phone (if provided in request)
client_tehudatstringCustomer Social ID (if provided in request)
signstringSHA256 signature — verify using your API key

Failed (status = 0):

FieldTypeDescription
order_idstringYour order identifier
statusinteger0 — capture failed
errorstringError description from the processor
signstringSHA256 signature — verify using your API key
// success (status = 1)
{
  "order_id":      "TOKEN-001",
  "status":        1,
  "allpay_token":  "6A0874314DCA42-79412113",
  "items":         [{ "name": "Save payment method" }],
  "card_mask":     "465901******7049",
  "card_brand":   "Visa",
  "foreign_card": 0,
  "client_name":  "Joe Doe",
  "client_email": "[email protected]",
  "sign":         "abc123..."
}

// failed (status = 0)
{
  "order_id": "TOKEN-001",
  "status":   0,
  "error":    "Card declined",
  "sign":     "abc123..."
}
curl https://allpay.to/app/?show=capturetoken&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "TOKEN-001",
    "items": [{"name": "Save payment method"}],
    "button_title": "save",
    "webhook_url": "https://yoursite.com/token-webhook",
    "lang": "EN",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'       => 'your_login',
  'order_id'    => 'TOKEN-001',
  'items'       => [['name' => 'Save payment method']],
  'button_title' => 'save',
  'webhook_url' => 'https://yoursite.com/token-webhook'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=capturetoken&mode=api12
// redirect to $response['payment_url']
// webhook: { status:1, order_id:'TOKEN-001', allpay_token:'6A0874314DCA42-...', card_mask:'465901******7049', card_brand:'Visa', ... }
const body = {
  login: 'your_login',
  order_id: 'TOKEN-001',
  items: [{ name: 'Save payment method' }],
  button_title: 'save',
  webhook_url: 'https://yoursite.com/token-webhook',
  lang: 'EN'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { payment_url } = await (await fetch('https://allpay.to/app/?show=capturetoken&mode=api12', {
  method: 'POST', headers: {'Content-Type': 'application/json'},
  body: JSON.stringify(body)
})).json();
// redirect customer to payment_url
// webhook: { status: 1, order_id: 'TOKEN-001', allpay_token: '6A0874314DCA42-...', card_mask: '465901******7049', card_brand: 'Visa', ... }

Get Token for Existing Payment

POSThttps://allpay.to/app/?show=gettoken&mode=api12

Retrieve a reusable token from a completed payment.

ℹ️ Bit payments do not support tokenization.

Parameters

NameTypeDescription
login*stringrequiredAPI login
order_id*stringrequiredOrder ID of the completed payment
sign*stringrequiredSHA256 signature

Response

FieldTypeDescription
order_idstringOrder identifier
allpay_tokenstringToken for future payments
card_maskstringMasked card number
card_brandstringCard brand
foreign_cardinteger
0 — local card (issued by an Israeli bank)1 — foreign card
curl https://allpay.to/app/?show=gettoken&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "ORDER-001",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'    => 'your_login',
  'order_id' => 'ORDER-001'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=gettoken&mode=api12
// $response['allpay_token'] — use in future getpayment calls
const body = {
  login: 'your_login', order_id: 'ORDER-001'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { allpay_token, card_mask } = await (await fetch('https://allpay.to/app/?show=gettoken&mode=api12', {
  method: 'POST', headers: { 'Content-Type': 'application/json' },
  body: JSON.stringify(body)
})).json();
// pass allpay_token in future Create Payment calls

J5 / Pre-authorization

Reserve an amount on a card without charging it. The reservation is valid for 7 days (168 hours). You can charge an amount equal to or less than the reserved amount — but only once. To void a reservation without charging, call the Refund endpoint.

Pre-authorize (Reserve)

POSThttps://allpay.to/app/?show=getpayment&mode=api12

Same as Create Payment with preauthorize: true. Reserves the amount on the customer's card — no charge is made. Returns payment_url.

⚠️ The reservation expires after 168 hours (7 days). Charge or void it before then.
preauthorizebooleanSet to true
curl https://allpay.to/app/?show=getpayment&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "J5-001",
    "items": [{"name": "Hotel reservation", "qty": "1", "price": "500", "vat": "1"}],
    "preauthorize": true,
    "webhook_url": "https://yoursite.com/webhook",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'        => 'your_login',
  'order_id'     => 'J5-001',
  'items'        => [['name' => 'Hotel reservation', 'qty' => '1', 'price' => '500', 'vat' => '1']],
  'preauthorize' => true,
  'webhook_url'  => 'https://yoursite.com/webhook'
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=getpayment&mode=api12
// redirect to $response['payment_url']
const body = {
  login: 'your_login', order_id: 'J5-001',
  items: [{ name: 'Hotel reservation', qty: '1', price: '500', vat: '1' }],
  preauthorize: true,
  webhook_url: 'https://yoursite.com/webhook'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');

Charge Pre-authorized Payment

POSThttps://allpay.to/app/?show=runauthorizedpayment&mode=api12

Charge a reserved amount. Can only be done once, must not exceed the reserved amount, and must happen within 168 hours.

ℹ️ To void a reservation without charging, call Refund without an items field.

Parameters

NameTypeDescription
login*stringrequiredAPI login
order_id*stringrequiredOrder ID from the original pre-authorization
amount*numberrequiredAmount to charge (≤ reserved amount)
sign*stringrequiredSHA256 signature

Response

FieldTypeDescription
order_idstringOrder identifier
statusinteger
0 — failed1 — successful
amountnumberAmount charged
curl https://allpay.to/app/?show=runauthorizedpayment&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "your_login",
    "order_id": "J5-001",
    "amount": 450.00,
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login'    => 'your_login',
  'order_id' => 'J5-001',
  'amount'   => 450.00  // charge less than reserved
];
$body['sign'] = allpay_sign($body, 'YOUR_API_KEY');
// POST to https://allpay.to/app/?show=runauthorizedpayment&mode=api12
const body = {
  login: 'your_login', order_id: 'J5-001',
  amount: '450.00'
};
body.sign = allpaySign(body, 'YOUR_API_KEY');
const { status } = await (await fetch('https://allpay.to/app/?show=runauthorizedpayment&mode=api12', {
  method: 'POST', headers: {'Content-Type': 'application/json'},
  body: JSON.stringify(body)
})).json();

Verify API Credentials

POSThttps://allpay.to/app/?show=checkkeys&mode=api12

Verify that an API login + key pair is valid, without making a payment. Useful for onboarding flows where you're connecting a merchant's account.

Parameters

NameTypeDescription
login*stringrequiredAPI login to verify
sign*stringrequiredSHA256 signature generated with the API key

Response (valid credentials)

FieldTypeDescription
last_paid_order_idstringLast paid order ID, or "-1" if none
last_paid_order_datestringUnix timestamp of last payment, or "-1" if none

Response (invalid credentials)

{ "error_code": 3, "error_msg": "Signature is incorrect" }
curl https://allpay.to/app/?show=checkkeys&mode=api12 \
  -X POST -H "Content-Type: application/json" \
  -d '{
    "login": "their_login",
    "sign": "YOUR_COMPUTED_SIGN"
  }'
$body = [
  'login' => 'their_login'
];
$body['sign'] = allpay_sign($body, 'THEIR_API_KEY');
// POST to https://allpay.to/app/?show=checkkeys&mode=api12
// isset($response['error_code']) → invalid credentials
const body = { login: 'their_login' };
body.sign = allpaySign(body, 'THEIR_API_KEY');
const res = await (await fetch('https://allpay.to/app/?show=checkkeys&mode=api12', {
  method: 'POST', headers: {'Content-Type': 'application/json'},
  body: JSON.stringify(body)
})).json();

if (res.error_code) {
  // invalid credentials
} else {
  // valid — res.last_paid_order_id
}

Test Cards

Enable test mode in your account settings, then use the card numbers below. Use any future date as the expiration date and any three digits for the CVV.

Card Numbers

BrandNumberResult
Visa 4557430402053431 ✓ Success
Mastercard 5326105300985846 ✓ Success
American Express 375516193000090 ✓ Success
Any brand 4000000000000002 ✗ Failure simulation
ℹ️ Test mode is enabled in settings of each integration. Real cards are not charged in test mode.

Changelog

API updates, new endpoints and parameters, and breaking changes — in reverse chronological order.

May 25, 2026 v12

Added new error code 21Amount must be at least 5 ILS. Returned when the payment amount (after applying currency rate) is below 5 ILS. Previously this case was not enforced via the API.

May 16, 2026 v12

API v12 released: support for donation receipts and donation payment buttons.

In light of the new reporting requirements for non-profit organizations in Israel, Allpay API v12 now supports two new parameters for payment creation.

doc_type

Document type for the document issued after payment. If not provided, the default value is taken from your account settings.

Available values: 320 — Tax Invoice Receipt, 400 — Receipt, 405 — Receipt for donation.

button_title

Text displayed on the payment button. Available values: pay (default), donate, subscribe.

This update allows non-profit organizations to create payments that issue the correct donation document and display a more suitable payment button for donation flows.

April 10, 2026 v11

API v11 released. We've introduced several updates to improve flexibility and control over payments and card handling.

New capturetoken endpoint

Allows saving a customer's card without charging it. Works with both redirect flow and Hosted Fields.

Webhook error notifications

Webhook notifications are now sent to webhook_url in case of payment errors. The customer remains on the payment page, allowing them to retry with another card.

Webhook delivery and retries

Your server must return an HTTP 200 OK response to confirm successful receipt of a webhook. If any other status is returned, or the request fails due to a timeout or network error, Allpay will automatically retry delivery.

Allpay performs up to 10 delivery attempts in total. The first retry is made 1 minute after the initial failure. Subsequent retries are sent with progressively increasing intervals, with the final attempt occurring within 24 hours of the original request. If all delivery attempts fail, the webhook will be marked as failed and no further retries will be made.

Custom payment button text

You can now customize the payment button label using the new button_title parameter. Available options: "Pay" or "Donate".

January 22, 2026

The notifications_url parameter has been renamed to webhook_url. notifications_url remains valid and fully supported for all API versions below v10.

January 16, 2026 v10

We've released API v10, introducing the new currency_display parameter. This parameter allows you to display prices to customers in one currency while charging in the billing currency. It helps show prices in a familiar currency for customers, while keeping settlement and payouts in the merchant's preferred currency.

No changes are required if you do not need multi-currency price display.

November 20, 2025 v9

API version 9 introduces support for item-level discounts. Two new optional parameters have been added: discount_val — discount amount for the item, and discount_type — defines whether the discount is a fixed amount or a percentage. These parameters allow displaying the discount directly on the payment page and automatically deducting it from the item price.

August 25, 2025

Added new value 4 — partially refunded to the payment status parameter in responses to Refund requests and Payment status verification requests.

July 25, 2025

Added API Keys Verification endpoint that allows developers of various platforms integrating with Allpay to verify the validity and authenticity of a user's Allpay API login and key without initiating a payment.

July 15, 2025

Added support for partial refunds by introducing the optional items array in the refund request.

May 8, 2025

Introducing New J5 Transaction Flow. J5 is a two-step payment process used in Israeli payment systems. It begins with a pre-authorization (reservation) of funds on a customer's card for up to 168 hours (7 days). During this time, you can charge the reserved amount — fully or partially. If no charge is made, the funds are automatically released.

This is applicable for use cases like deliveries, rentals, variable-weight goods, or custom orders. Read more about J5 →

March 12, 2025

Allpay introduces Hosted Fields — a secure way to embed a payment form on a website or in an application, fully adapting it to your design. Tutorial →

February 13, 2025

Added a new parameter show_applepay to the payment request, allowing control over the Apple Pay button visibility on the payment page. The Apple Pay module must be activated in your account first. This parameter is useful in order to hide the button when creating a card token, as Apple Pay payments cannot be used for tokenization.

January 29, 2025

We're introducing two new tools for developers to test payments via API:

Allpay API Tester

With the Allpay API Tester, you can send requests for new payments, refunds, subscriptions, and other operations in both live and test modes, simulating requests from your server.

API Tag

Every transaction processed via the API is marked with an "API" tag in the Allpay dashboard. Clicking on the tag allows you to view the associated API request and response.

November 22, 2024

Language support updates. New lang parameter values:

AUTO — automatically sets the payment page language based on the client's browser settings. This is now the default value.

AR — added support for Arabic language.

If the lang parameter is not provided or set to AUTO, the payment page will automatically display in the client's browser language. Providing EN, RU, HE, or AR will display the payment page in that language for all clients, regardless of their browser settings.

A language switcher is now available on the payment page, allowing clients to change the language at any time, regardless of the initial lang parameter setting.

November 15, 2024 v6

API updated to version 6.

New parameters introduced

items — an array containing product details, including names, quantities, prices, and VAT attributes. This information will appear in the Allpay app and in the digital invoice if digital invoice integration is enabled.

expire — a Unix timestamp that defines the lifetime of the payment link. Once the link expires, it becomes invalid for payment. This helps avoid situations where customers pay for products or services that are no longer available.

Removed parameters

name (product name) and amount (total payment amount).

Key changes

The items array replaces the need for the name and amount parameters. The final amount is calculated based on the prices and quantities provided in the items array. Using the vat parameter inside the items array, Allpay will either display the VAT amount on the payment page or indicate that VAT is not included.

Important: Prices provided in the items array must already include VAT (if applicable). The vat parameter is used only to specify whether VAT is included in the item's price or not. We do not add VAT on top of the prices.

The old API version will continue to function as before.

October 6, 2024

Added support for full or partial refunds via the API. See the Refund endpoint.

August 3, 2024

The new payment request parameter show_bit allows you to enable or disable the display of the Bit payment button on the payment page. The Bit module must be activated in your Allpay account first.

March 14, 2024

The receipt parameter is included in both payment notification and payment verification response. This parameter provides the URL to the digital receipt, which is generated by the EasyCount module when the module is activated in the account settings.

Please note that the request URL changed to ...api4.

February 9, 2024

Added new optional parameter for Payment Request: client_tehudat, representing the client's Social ID Number (Teudat Zehut). If provided, Allpay won't prompt the client for manual entry. If not provided, it will be requested on the payment page, as required by law. For non-Israeli citizens, submit 000000000.

December 24, 2023

fail_url parameter will no longer be applied because payment errors are displayed directly on the payment page, prompting the customer to make a new payment attempt.

New parameter added: backlink_url — a URL for the new "Return to site" button on the bottom of the payment page.

December 21, 2023

New parameters added in the responses for payment protocol, status verification and token requests: card_mask (example: 465901******7049), card_brand (example: Visa, Mastercard etc.) and foreign_card (issued in Israel or abroad).

Request URLs changed from ...api1 to ...api2.

September 9, 2023

Added endpoint for creating and using tokens.

June 30, 2023

When submitting the currency parameter in USD or EUR, the amount will be auto-converted to ILS on the Allpay side. Exchange rates are taken in real time from Google Finance.

June 29, 2023

Added payment verification method to check transaction status.

Resources & Support

Tools, guides, and contact information to help with your integration.

Tools

API Tester Interactive tool to send API requests and inspect responses without writing code
Hosted Fields Embed a PCI-compliant card input directly in your page without redirecting the customer

Guides

Webhooks Guide How to configure per-integration webhook URLs — in addition to the webhook_url passed per request, you can set a fixed URL in your integration settings that Allpay will also notify after every payment
API Q&A Answers to the most common integration questions
Currencies List All supported currencies and their codes for currency / currency_display
J5 / Pre-auth Guide In-depth explanation of the two-step pre-authorization flow
Token UI Recommendations UX guidelines for building a saved-card interface using tokens

Support & Updates

[email protected] Technical support over email
@allpay_israel Technical support over Telegram
@allpay_api Telegram channel to track API updates