VAT Calculator API

任意の国のネット、グロス、VAT額、VAT率を単一の整った構造のAPIコールで計算。

何ができますか?
請求書と領収書

請求書、見積書、領収書のVAT行を即座に計算。

ECチェックアウト

チェックアウトで税込価格と明確なVAT内訳を表示。

SaaSとサブスクリプション

国、通貨、エッジケースを跨いでVAT計算を正規化。

99.9 % 稼働時間
2.6ms レスポンス
20 req/s
0.001 クレジット / リクエスト

VAT API


POST https://api.yeb.to/v1/vat
パラメータ 必須 説明
api_key string はい Auth key
action string 任意 calculate (default) | list-countries | country-profile | country-rates
net number|string 任意 Net amount (price excluding VAT). Provide at least two of: net, gross, vat_amount, vat_rate.
gross number|string 任意 Gross amount (price including VAT).
vat_amount number|string 任意 VAT amount.
vat_rate number|string 任意 VAT rate as percentage (e.g. 20) or fraction (e.g. 0.20). If present, this always overrides country defaults.
country_code string 任意 2-letter ISO code (e.g. BG, DE, FR). Used for currency, rounding and default VAT rates.
vat_type string 任意 standard | reduced | super_reduced | zero. Used when deriving rate from country_code.
decimal_separator string 任意 Output decimal separator: . (default) or ,. Input values accept both . and ,.
round bool 任意 Whether to apply rounding as per country profile (default: true).
advanced bool 任意 When true and no explicit vat_rate is provided, returns multi-rate scenarios for the country (scenario_type = "multi_rate").

リクエスト例

# Simple VAT calculation (custom 20% rate)
curl -s -X POST "https://api.yeb.to/v1/vat" ^
  -H "X-API-Key: YOUR_KEY" ^
  -H "Content-Type: application/x-www-form-urlencoded" ^
  --data "action=calculate&net=100&vat_rate=20&country_code=BG&vat_type=standard"
# Let the API pick the default rate for BG (no explicit vat_rate)
curl -s -X POST "https://api.yeb.to/v1/vat" ^
  -H "X-API-Key: YOUR_KEY" ^
  -H "Content-Type: application/x-www-form-urlencoded" ^
  --data "action=calculate&net=100&country_code=BG&vat_type=standard"

API連携

curl -s -X POST "https://api.yeb.to/v1/vat" ^
  -H "X-API-Key: YOUR_KEY" ^
  -H "Content-Type: application/x-www-form-urlencoded" ^
  --data "action=calculate&net=100&vat_rate=20&country_code=BG&vat_type=standard"
use Illuminate\Support\Facades\Http;

Route::post('/vat-example', function () {
    $response = Http::asForm()->post('https://api.yeb.to/v1/vat', [
        'api_key'      => config('services.yeb.key'),
        'action'       => 'calculate',
        'net'          => 100,
        'vat_rate'     => 20,
        'country_code' => 'BG',
        'vat_type'     => 'standard',
    ]);

    return $response->json();
});
$response = Http::asForm()->post('https://api.yeb.to/v1/vat', [
    'api_key'      => 'YOUR_KEY',
    'action'       => 'calculate',
    'net'          => 100,
    'vat_rate'     => 20,
    'country_code' => 'BG',
    'vat_type'     => 'standard',
]);

$data = $response->json();
const params = new URLSearchParams({
  api_key: 'YOUR_KEY',
  action: 'calculate',
  net: '100',
  vat_rate: '20',
  country_code: 'BG',
  vat_type: 'standard'
});

fetch('https://api.yeb.to/v1/vat', {
  method: 'POST',
  headers: { 'Content-Type': 'application/x-www-form-urlencoded' },
  body: params.toString()
})
  .then(r => r.json())
  .then(console.log);
import requests

payload = {
    "api_key": "YOUR_KEY",
    "action": "calculate",
    "net": 100,
    "vat_rate": 20,
    "country_code": "BG",
    "vat_type": "standard",
}

r = requests.post('https://api.yeb.to/v1/vat', data=payload)
print(r.json())

Response Example

{
  "country_code": "BG",
  "vat_type": "standard",
  "scenario_type": "single_rate",
  "net": 100,
  "gross": 120,
  "vat_amount": 20,
  "vat_rate": 0.2,
  "vat_rate_percent": 20,
  "decimal_separator": ".",
  "currency": "BGN",
  "rounding": { "precision": 2, "mode": "half_up" },
  "warnings": [],
  "formatted": {
    "net": "100.00",
    "gross": "120.00",
    "vat_amount": "20.00",
    "vat_rate": "20.00%"
  },
  "response_code": 200,
  "response_time_ms": 5
}
{
  "error": "Missing \"country_code\" parameter",
  "code": 400,
  "response_code": 400,
  "response_time_ms": 3
}

レスポンスコード

コード説明
200 Successリクエスト処理成功。
400 Bad Request入力バリデーション失敗。
401 UnauthorizedAPIキーが不足または不正。
403 Forbiddenキーが無効または許可されていません。
429 Rate Limitリクエストが多すぎます。
500 Server Error予期しないエラー。

Calculate

vat 0.0010 credits

Parameters

API Key
body · string · required
Action
body · string
Net amount
body · string
Gross amount
body · string
VAT amount
body · string
VAT rate
body · string
Country code
body · string
VAT type
body · string
Decimal separator
body · string
Round amounts
body · string
Advanced mode
body · string

Code Samples


                
                
                
            

Response

Status:
Headers

                
Body

                

VAT Calculator API — Practical Guide

A practical guide to VAT Calculator API: how to calculate VAT from any combination of net, gross, VAT amount or rate, how to leverage country profiles, and how to read both single-rate and multi-rate scenarios in your billing or invoicing logic.

#What the VAT API solves

Instead of re-implementing VAT rules in every project, you send net / gross / VAT amount / rate (any two are enough), plus optional country and VAT type. The API calculates the missing numbers, applies country-specific rounding, and can even return multi-rate scenarios when you need to compare standard vs reduced rates.

#Endpoint & actions

#POST https://api.yeb.to/v1/vat

  • Single endpoint with an action parameter.
  • Idempotent: same input → same result; safe for caching and retries.
  • Supports both: form-encoded requests (application/x-www-form-urlencoded) and JSON bodies (when valid JSON is sent from your backend).
ActionUse it forNotes
calculate (default) Compute net/gross/VAT from any two inputs. Typical cart / line-item calculations; supports custom or country-default rates.
list-countries Get a list of configured countries. Returns country code, name and currency; ideal for dropdowns.
country-profile Inspect VAT configuration for a single country. Includes currency, rounding and VAT rates by type.
country-rates Get only the rates grouped by type. Simpler, compact response when you already know the rest.

#Quick start examples

# 1) Custom VAT rate (20%), net → gross
curl -s -X POST "https://api.yeb.to/v1/vat" ^
  -H "X-API-Key: YOUR_KEY" ^
  -H "Content-Type: application/x-www-form-urlencoded" ^
  --data "action=calculate&net=100&vat_rate=20&country_code=BG&vat_type=standard"
# 2) Use default rate from BG profile (no explicit vat_rate)
curl -s -X POST "https://api.yeb.to/v1/vat" ^
  -H "X-API-Key: YOUR_KEY" ^
  -H "Content-Type: application/x-www-form-urlencoded" ^
  --data "action=calculate&net=100&country_code=BG&vat_type=standard"
# 3) Advanced multi-rate scenarios for a country
curl -s -X POST "https://api.yeb.to/v1/vat" ^
  -H "X-API-Key: YOUR_KEY" ^
  -H "Content-Type: application/x-www-form-urlencoded" ^
  --data "action=calculate&advanced=1&net=100&country_code=DE"

#Parameters that actually matter

ParamRequiredWhat to pass in practiceWhy it matters
api_key Yes Send from server/edge, never directly from public JS. Authentication, rate limiting, and credit charging.
action No Default is calculate. Use other actions for metadata only. Controls which logical operation the API performs.
net For calculate: at least 2 of net/gross/vat_amount/vat_rate Net price (excl. VAT), as number or string; , and . are both accepted. Primary monetary input in most billing flows.
gross Same Gross price (incl. VAT). Often known when reverse-engineering net values. Useful for “VAT included” pricing.
vat_amount Same When you know how much VAT was charged and want to infer the rest. Typical for imported accounting data.
vat_rate Same Your own custom rate: 20 (=20%) or 0.2. If present, it overrides country defaults. Gives you full control over the percentage.
country_code No (but required for country-* actions) 2-letter ISO code (e.g. BG, DE, FR). Used for currency, default rates and rounding rules.
vat_type No standard by default; use reduced, super_reduced, or zero where relevant. Selects which rate from the country profile to use.
decimal_separator No . (default) or , for formatted values. Controls the formatted block in the response.
round No 1/true to enable (default), 0/false to disable. Decides whether amounts are rounded according to the country profile.
advanced No Set to 1 to get multi-rate scenarios when no explicit vat_rate is given. Handy for “what-if” comparisons across standard/reduced rates.

#Reading & acting on responses

#Single-rate scenario (scenario_type = "single_rate")

{
  "country_code": "BG",
  "vat_type": "standard",
  "scenario_type": "single_rate",
  "net": 100,
  "gross": 120,
  "vat_amount": 20,
  "vat_rate": 0.2,
  "vat_rate_percent": 20,
  "decimal_separator": ".",
  "currency": "BGN",
  "rounding": { "precision": 2, "mode": "half_up" },
  "warnings": [],
  "formatted": {
    "net": "100.00",
    "gross": "120.00",
    "vat_amount": "20.00",
    "vat_rate": "20.00%"
  },
  "response_code": 200,
  "response_time_ms": 5
}
  • net, gross, vat_amount — numeric fields you can store directly in your DB.
  • vat_rate, vat_rate_percent — the effective rate used (fraction and %).
  • formatted — strings ready for UI/PDF output with the chosen decimal_separator.
  • warnings — non-fatal hints (e.g. not enough data) that you may show to admins or logs.

#Multi-rate scenarios (scenario_type = "multi_rate")

{
  "country_code": "DE",
  "vat_type": "standard",
  "scenario_type": "multi_rate",
  "net": 100,
  "gross": null,
  "vat_amount": null,
  "decimal_separator": ".",
  "currency": "EUR",
  "rounding": { "precision": 2, "mode": "half_up" },
  "warnings": [],
  "scenarios": [
    {
      "vat_type": "standard",
      "vat_rate": 0.19,
      "vat_rate_percent": 19,
      "net": 100,
      "gross": 119,
      "vat_amount": 19,
      "formatted": { "...": "..." }
    },
    {
      "vat_type": "reduced",
      "vat_rate": 0.07,
      "vat_rate_percent": 7,
      "net": 100,
      "gross": 107,
      "vat_amount": 7,
      "formatted": { "...": "..." }
    }
  ]
}
  • Use scenarios to compare different VAT types for the same net amount.
  • Ideal for admin UIs where you show “standard vs reduced” on the same screen.
  • Pick one scenario and persist only that to your invoice rows.

#Typical errors & how to fix them

{ "error": "Missing \"country_code\" parameter", "code": 400 }
{ "error": "Invalid API key", "code": 401 }
{
  "country_code": null,
  "scenario_type": "single_rate",
  "net": null,
  "gross": null,
  "vat_amount": null,
  "vat_rate": null,
  "warnings": [
    "Not enough information to compute VAT. Provide at least two of: net, gross, vat_amount, vat_rate (or a country_code with rates)."
  ],
  "formatted": null
}
  • 401 invalid/missing key: pass api_key or X-API-Key from your backend.
  • 400 missing country_code: required for country-profile and country-rates.
  • Calculation warnings: if you see only a warning and no numbers, send at least two monetary inputs.

#Troubleshooting & field notes

  1. Conflicting inputs: If you send net, gross and vat_amount that don’t match, the API relies on its internal math; log your raw params if you suspect rounding issues.
  2. Zero-rate logic: For vat_rate = 0 or vat_type = zero, net = gross and VAT amount = 0.
  3. Custom vs country rate: A provided vat_rate always wins over country_code/vat_type. Omit vat_rate if you want pure “country default” behaviour.
  4. Locales & separators: You can safely accept user input with , or . — normalization is handled for you.
  5. Batch use: For bulk imports, keep requests ≤ 100 rps, reuse HTTP connections, and cache stable country profiles.

#API Changelog

2025-12-10
Added advanced multi-rate mode and improved warning messages for under-specified inputs.
2025-12-01
First public v1 release of VAT API with calculate, list-countries, country-profile and country-rates actions.

よくある質問

ネット、グロス、VAT額、VAT率のうち少なくとも2つを指定する必要があります。オプションで、country_codeとvat_typeを渡すと、APIが自動的に正しいレートを選択します。

APIはVATプロファイルで設定した任意の国で動作します。国ごとに利用可能なレート、通貨、丸めルールを制御できます。

高度モード(明示的なvat_rateなし)では、APIは国の設定済みレートすべてに対する複数のシナリオを返します:標準、軽減、超軽減、ゼロ。

丸めは各国のプロファイル(精度とhalf_up、half_even、floorなどのモード)に従います。round = falseを送信することで丸めを完全に無効にすることもできます。

各VAT計算はリクエストごとに少量の固定クレジットを消費します。正確な値については上記の料金表とクレジット見積もりツールを参照してください。

はい。エラーが発生したリクエストを含め、すべてのリクエストがクレジットを消費します。クレジットは成功・失敗に関係なくリクエスト数に紐づいています。エラーが明らかに当社のプラットフォーム側の問題による場合は、影響を受けたクレジットを復元します(現金での返金はありません)。

[email protected]までご連絡ください。フィードバックを真摯に受け止めています。バグレポートや機能リクエストが意味のあるものであれば、APIを迅速に修正・改善し、お礼として50の無料クレジットを付与します。

APIやエンドポイントによって異なります。一部のエンドポイントは外部ソースのデータを使用しており、より厳しい制限がある場合があります。また、不正利用の防止とプラットフォームの安定性維持のために制限を設けています。各エンドポイントの具体的な制限についてはドキュメントをご確認ください。

クレジットシステムで運営しています。クレジットは前払いの返金不可の単位で、API呼び出しやツールに使用します。クレジットはFIFO(古いものから順に)消費され、購入日から12か月間有効です。ダッシュボードに各購入日とその有効期限が表示されます。

はい。購入したすべてのクレジット(端数残高を含む)は購入から12か月間有効です。未使用のクレジットは有効期間終了時に自動的に期限切れとなり、永久に削除されます。期限切れのクレジットは復元や現金その他の価値への変換はできません。経過措置:2025年9月22日以前に購入したクレジットは2025年9月22日購入として扱われ、2026年9月22日に期限切れとなります(購入時により早い期限が記載されていない限り)。

はい—有効期間内で繰り越されます。未使用のクレジットは利用可能な状態のまま月ごとに繰り越され、購入後12か月で期限切れになります。

クレジットは返金不可です。必要な分だけ購入してください—後からいつでもチャージできます。プラットフォーム側のエラーで課金に失敗した場合、調査後に影響を受けたクレジットを復元する場合があります。現金での返金はありません。

料金はドルではなくクレジットで設定されています。各エンドポイントには独自のコストがあります—上記の「クレジット / リクエスト」バッジをご覧ください。常に正確な支出額がわかります。
← APIに戻る