Skip to content
Log in

DGFiP e-Invoicing and e-Reporting

From September 2026, all French companies must route their invoices and VAT data through a certified platform. B2Brouter simplifies this: you send your invoice data via a REST API call, and B2Brouter handles PPF registration, document generation (UBL/CII/Factur-X), routing to your clients, and tax reporting to the DGFiP — all through a single integration.

B2Brouter is a certified Plateforme Agréée (PA) for the French DGFiP e-invoicing reform. Connect via REST API and B2Brouter handles the entire compliance stack on your behalf:

What B2Brouter does for youDetails
PPF registrationPublishes your SIREN/SIRET to the Annuaire automatically on activation
Flux 1 — B2B e-invoicingGenerates UBL/CII/Factur-X, transmits to PPF, routes to buyer’s platform
Flux 6 — Invoice lifecycleManages CDAR status messages (Déposée, Reçue, Approuvée, Refusée, Encaissée)
Flux 10 — e-ReportingAggregates B2C and cross-border B2B transactions (intra-EU and extra-EU) into daily Ledgers sent to PPF
Peppol 0225 receptionReceives invoices from any French or Peppol-connected platform
Document generationYou send invoice data as JSON — B2Brouter generates the compliant UBL/CII/Factur-X document and transmits it to the PPF. No XML generation required on your side
Input formatsJSON REST API, Factur-X PDF/A-3 (with embedded CII XML), UBL 2.1 XML, CII XML
Legal archivingAll transmitted documents (invoices, tax reports, CDAR messages) are stored by B2Brouter for the legally required 10-year retention period. No additional storage setup required on your side

To integrate, you need 4 steps: create your accountactivate DGFiPcreate a contactsend your first invoice.


Regulatory context: The French e-invoicing reform mandates that all French companies use a certified Plateforme Agréée (PA) or the government’s PPF (Portail Public de Facturation) to transmit invoices and report VAT data to the DGFiP, starting September 2026. As a certified PA, B2Brouter handles the PPF connection entirely on your behalf — no SFTP, no electronic certificates, no direct PPF integration required.

There are two main use cases for integrating with B2Brouter for France e-invoicing:

eDocExchange — For companies or groups of companies that integrate their management software (ERP, accounting platform) directly with B2Brouter. The onboarding process (account creation, Tax Report Settings configuration) is typically performed once per company through the web UI. Day-to-day operations (issuing invoices, tracking their lifecycle) happen through the API. To add further company accounts to your integration group, follow the same onboarding wizard from the same B2Brouter user account — no separate API call required.

eDocSync — For software vendors and ERP providers who want to offer DGFiP compliance to their own customers from within their product. This is B2Brouter’s white-label / embedded / marque blanche model: B2Brouter operates entirely in the background, end customers interact exclusively with the vendor’s interface and are unaware of B2Brouter. The software vendor is responsible for account provisioning, invoice submission, and lifecycle tracking via the B2Brouter API. End customers do not need a B2Brouter login or subscription.

For eDocSync, account provisioning volume determines the right plan:

  • Few companies (reseller model): Add each client company as an account in your B2Brouter integration group via the web UI, following the standard onboarding wizard. This works well for tens of companies and shares a single API key.
  • 100+ companies: Contact our Sales team or open a Support Ticket to discuss a dedicated eDocSync plan with bulk provisioning (volume-based pricing for editors).

In both cases, all France-specific compliance features (Annuaire registration, Flux 1/6/10 transmission, CDAR lifecycle) work identically.

B2Brouter is itself a Plateforme Agréée: you integrate with B2Brouter — it is not a relay or connector to another PA. If your SIREN/SIRET is currently registered with a different PA, activating B2Brouter (Step 2) transfers the Annuaire entry automatically. You cannot use B2Brouter as a pass-through to submit invoices under a different PA’s certification.

Routing to recipients on other PAs: When your buyer is registered with a different PA, B2Brouter routes the invoice via the standard Peppol four-corner model (C2 → C3): B2Brouter’s Peppol access point (C2) looks up the recipient’s Peppol address in the Annuaire and delivers the document to the buyer’s access point (C3) — regardless of which PA they use. No additional configuration is required on your side.


Testing environments: Use sandbox for initial API testing and payload validation — DGFiP submissions are simulated in sandbox, no fictitious SIRET required. For full end-to-end testing with the DGFiP QAS (qualification) environment, use B2Brouter’s staging environment as described below.

EnvironmentB2Brouter appB2Brouter APIChorus Pro portal
Productionapp.b2brouter.nethttps://api.b2brouter.netchorus-pro.gouv.fr
Staging (test)app-staging.b2brouter.nethttps://api-staging.b2brouter.netqualif.chorus-pro.gouv.fr

Do not mix environments. Production uses real SIREN/SIRET numbers and connects to the DGFiP production Annuaire. Staging uses fictitious test identifiers and connects to the DGFiP QAS (qualification) environment. API keys, accounts, and contacts are not shared between environments.

Register at app.b2brouter.net to start a production integration. When you activate the DGFiP Tax Report Setting, your company’s SIREN/SIRET is published to the real PPF Annuaire, making it discoverable by any platform in the French e-invoicing ecosystem.

This option is designed for real B2B invoices starting September 2026. In the meantime, the DGFiP will clear QAS-period records before the reform goes live — so any invoices you send during your pilot will not create compliance obligations. This is the right starting point if you have already chosen B2Brouter and want to test the full integration with your actual company data.

Section titled “Option B — Staging (recommended for evaluation)”

Register at app-staging.b2brouter.net to use B2Brouter’s test environment, which is connected to the DGFiP’s QAS (qualification) environment.

This is the best option if:

  • You are evaluating multiple platforms before committing
  • Your SIREN/SIRET is already published in the Annuaire with another PA (activating B2Brouter in production would transfer the entry)
  • You prefer not to associate your company identifier with test activity

The staging environment is self-provisioned: once you have test identifiers (see below), you can start end-to-end testing in under 24 hours.

Staging SIRET validation: In the staging environment, any valid 14-digit number is accepted as a SIRET without checksum validation. The fictitious identifiers from the Chorus Pro QAS CSV are pre-registered in the DGFiP QAS annuaire and work end-to-end. In production, SIRET format and checksum are validated.

Important: The DGFiP does not allow real SIREN or SIRET numbers in their QAS environment. You must use fictitious test identifiers. You can obtain these yourself via the Chorus Pro QAS portal (free, 5-minute process) or request a pre-assigned set by opening a Support Ticket in the staging app.

One account per SIREN: B2Brouter creates one account per SIREN (the VAT number key is derived from the SIREN). If you provide a SIRET, the SIREN is extracted from it. Two different SIRETs from the same company (same SIREN) will resolve to the same account. If your company operates from multiple establishments (different SIRETs), these are modelled as organisational units within the same B2Brouter account — not as separate accounts. Contact Support if you need to configure multi-establishment invoicing. Keep this in mind when selecting rows from the CSV: pick SIRETs with distinct SIRENs (first 9 digits) for each independent company you need to test.

Getting test identifiers via Chorus Pro QAS

Section titled “Getting test identifiers via Chorus Pro QAS”

The Chorus Pro QAS portal lets you generate a “Matelas de données” (data set) — a CSV file containing fictitious SIREN/SIRET identifiers pre-registered in the DGFiP test environment. Follow these steps:

  1. Go to qualif.chorus-pro.gouv.frEntreprise tab → Créer mon compte.
    • You can use a temporary email address (e.g. temp-mail.io).
    • Use any name; this account is purely for obtaining test identifiers.
  2. Check your inbox for the “Initialisation de mot de passe Chorus Pro” email and set your password (link valid 60 minutes).
  3. Log in → go to DomainesMatelas de données → click Générer un matelas de données and confirm.
  4. Go to Consultation du matelas de données. Wait until both statuses show “Disponible”:
    • Statut pour Chorus Pro: Disponible
    • Statut pour l’annuaire de facturation PPF: Disponible
    • Generation typically takes a few minutes. Refresh the page to check.
  5. Click “Générer et télécharger le fichier CSV du matelas structures et utilisateurs” to download your test identifiers.

The CSV contains multiple fictitious SIREN/SIRET numbers in rows labelled “Privé” and “Public”. Use only rows from the “Privé” (private sector) section for your test accounts. Public sector entities (SIREN 'Public') are rejected by the DGFiP QAS annuaire — attempting to activate e-Reporting on a public-sector account returns HTTP 422 (“La création d’une ligne annuaire n’est pas possible pour une entité associée à un SIREN ‘Public’”). This is correct behaviour: public entities use Chorus Pro directly, not a PA.

Use one private-sector SIREN for your emitter account and another for your test contact.

Once you have your test identifiers:

  1. Register at app-staging.b2brouter.net and activate your account.
  2. Create your company account using a SIREN from the CSV (see Step 1).
  3. Subscribe to an eDocExchange plan (staging subscriptions are simulated — no charge).
  4. Enable DGFiP Tax Report Settings (see Step 2).
    • ⚠️ After activating the DGFiP Tax Report Setting, your company’s Annuaire registration takes up to 24 hours to propagate — both in staging and in production. This is a DGFiP infrastructure constraint, not a B2Brouter delay. You will not be able to send invoices until the following day.
  5. The following day: create a test contact using a second SIREN from the CSV (see Step 3).
  6. Send your first invoice (see Issuing Invoices).

Authentication uses a static API key passed in the X-B2B-API-Key HTTP header. There is no OAuth2 flow — generate your API key in the B2Brouter UI under Settings → API Keys. Keep it confidential and never include it in client-side code. Also set X-B2B-API-Version in every request.

Base URL: All examples below use https://api-staging.b2brouter.net. For production, replace with https://api.b2brouter.net.


Step 1: Retrieve or Create your Company Account

Section titled “Step 1: Retrieve or Create your Company Account”

If you already have a B2Brouter account for your company, retrieve its id with the List Accounts endpoint and skip the creation step.

If you haven’t yet created one, use the Create Account endpoint (eDocSync/API path) or the web UI onboarding wizard (eDocExchange path). Both produce the same result.

When creating a French company account:

  • cin_scheme: "0002" for SIREN (9 digits) or "0009" for SIRET (14 digits). Use SIRET when available — it identifies a specific establishment and is preferred by the PPF.
  • cin_value: The SIREN or SIRET of your company.
  • tin_value: French VAT number in the format FR{kk}{siren}, where kk is the two-digit checksum (e.g. FR32123456789). This field is optional at account creation: if omitted, B2Brouter automatically derives and sets it from the SIREN when you activate the DGFiP Tax Report Setting. It is mandatory for DGFiP invoicing but you do not need to calculate it yourself.
  • country: "fr".

Example request:

Terminal window
curl --request POST \
--url https://api-staging.b2brouter.net/accounts \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}' \
--header 'Content-Type: application/json' \
--data '{
"account": {
"country": "fr",
"name": "Exemplar SAS",
"address": "10 Rue Imaginaire",
"city": "Paris",
"postalcode": "75001",
"province": "Île-de-France",
"email": "john.doe@example.com",
"tin_value": "FR32123456789",
"tin_scheme": 9957,
"cin_scheme": "0009",
"cin_value": "12345678900012",
"rounding_method": "half_up"
}
}'

Sample response:

{
"account": {
"id": 83428,
"name": "Exemplar SAS",
"tin_value": "FR32123456789",
"tin_scheme": 9957,
"cin_scheme": "0009",
"cin_value": "12345678900012",
"address": "10 Rue Imaginaire",
"city": "Paris",
"postalcode": "75001",
"province": "Île-de-France",
"country": "fr",
"currency": "EUR",
"email": "john.doe@example.com",
"rounding_method": "half_up",
"archived": false,
"created_at": "2026-06-10T09:54:38.000Z",
"updated_at": "2026-06-10T09:54:38.000Z"
}
}

POST Account - API Reference


Step 2: Enable Tax Report Settings for DGFiP

Section titled “Step 2: Enable Tax Report Settings for DGFiP”

This is the key onboarding step. When you create a Tax Report Setting with code: "dgfip", B2Brouter automatically:

  1. Registers your company in the PPF’s Annuaire — your SIREN/SIRET becomes discoverable by any platform in the French e-invoicing ecosystem.
  2. Creates a Peppol 0225 transport — enabling your company to receive electronic invoices from any Peppol-connected platform in France.

⚠️ Transport replacement: If your account already has a Peppol transport, it will be replaced by the new 0225 (FRCTC Electronic Address) transport during activation. If your SIREN/SIRET was previously registered with another PA, B2Brouter will close the existing Annuaire entry and open a new one. Update any existing integration that references the old transport identifier.

The start_date determines when tax reporting begins. From that date, invoices you issue will generate tax reports and be transmitted to the PPF.

Example request:

Terminal window
curl --request POST \
--url https://api-staging.b2brouter.net/accounts/{ACCOUNT_ID}/tax_report_settings \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}' \
--header 'Content-Type: application/json' \
--data '{
"tax_report_setting": {
"code": "dgfip",
"start_date": "2026-09-01",
"type_operation": "services",
"naf_code": "62",
"enterprise_size": "eti",
"email": "jane.doe@example.com"
}
}'

Sample response:

{
"tax_report_setting": {
"code": "dgfip",
"start_date": "2026-09-01",
"auto_generate": true,
"auto_send": true,
"enabled": true,
"type_operation": "services",
"naf_code": "62",
"enterprise_size": "eti",
"email": "jane.doe@example.com",
"locked": false,
"created_at": "2026-06-10T10:15:22.000Z",
"updated_at": "2026-06-10T10:15:22.000Z"
}
}
FieldTypeRequiredDescription
codestringYesMust be "dgfip".
start_datedateYesWhen tax reporting begins. Must be today or a future date. Defaults to tomorrow if omitted.
type_operationstringYesDefault operation type for this company: "services", "goods", or "mixed". Determines the DGFiP process code (S1/B1/M1 etc.) used in tax reports. Choose "mixed" if your company sells both goods and services. This setting can be updated after activation.
naf_codestringYesThe company’s NAF/APE code (Nomenclature d’Activités Française). This is the 2-digit section code assigned by INSEE that identifies the company’s main economic activity (e.g. "62" for IT and software services, "47" for retail, "86" for health). The DGFiP uses this code for tax reporting classification. You can find your NAF code on your company’s Kbis extract or on sirene.fr.
enterprise_sizestringYesThe company’s size category as defined by INSEE. Allowed values: "micro" (Microentreprise — < 10 employees, CA ≤ 2 M€), "pme" (PME — 10 to 249 employees, CA ≤ 50 M€), "eti" (ETI — 250 to 4 999 employees, CA ≤ 1.5 Md€), or "ge" (Grande Entreprise — 5 000+ employees or CA > 1.5 Md€).
reason_vat_exemptstringNoDefault VAT exemption reason code for this company. Defaults to "VATEX-FR-FRANCHISE" (franchise en base de TVA). Set this if your company operates under a specific VAT exemption regime. See VAT-exempt lines and Franchise en base de TVA for the full list of accepted codes.
emailstringNoContact email for tax-related notifications.
auto_generatebooleanNoAlways true for DGFiP (legal obligation). Cannot be changed.
auto_sendbooleanNoAutomatically transmit tax reports to the PPF. Defaults to true.
enabledbooleanNoWhether the setting is active. Defaults to true. Annuaire registration only occurs when true.

If the Annuaire registration fails (invalid SIREN/SIRET, or a temporary DGFiP service outage), the Tax Report Setting creation is rolled back and an error is returned. Correct the issue and retry.

Tax Report Settings - API Reference


A French B2B contact needs routing identifiers (how the invoice reaches the recipient) and tax identification (how the recipient appears in the UBL XML).

FieldValuePurpose
cin_scheme"0009" (SIRET) or "0002" (SIREN)Organisation ID — used to look up the recipient in the Annuaire
cin_valueSIRET or SIRENOrganisation ID — the identifier registered in the Annuaire
tin_scheme9957Tax ID — ISO 6523 code for French fiscal identifier
tin_valueFR{kk}{siren} (e.g. "FR78225214234")Tax ID — French VAT number in the UBL XML
country"fr"Required for DGFiP routing logic
currency"EUR"Default currency for this contact’s invoices
transport_type_code"peppol"Recommended — ensures delivery via the Peppol network
document_type_code"xml.ubl.invoice.frcius.v1"Recommended — France CIUS UBL invoice format

Transport and document type: For French contacts registered in the Annuaire, we recommend explicitly setting transport_type_code: "peppol" and document_type_code: "xml.ubl.invoice.frcius.v1". The PIN scheme (Peppol participant identifier) for registered French companies is 0225 (FRCTC Electronic Address). You can verify that a contact is registered in the Annuaire before creating it by using the Directory lookup or the official Peppol Directory. B2Brouter handles the correct structuring for both domestic and international contacts, but explicitly defining the transport ensures consistent delivery routing.

Contacts in Belgium, Germany, and other EU countries: For B2B invoices to non-French companies, use their national identifier scheme (e.g. "0208" for Belgian KBO/BCE, "0190" for German Leitweg-ID, "0184" for Dutch KVK) and the appropriate country code. If the recipient has an active Peppol access point, B2Brouter routes the invoice via standard Peppol BIS 3.0 — no configuration needed. For transactions with any non-"fr" contact, Flux 10 cross-border e-Reporting is generated automatically.

Example request:

Terminal window
curl --request POST \
--url https://api-staging.b2brouter.net/accounts/{ACCOUNT_ID}/contacts \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}' \
--header 'Content-Type: application/json' \
--data '{
"contact": {
"name": "Client Exemple SARL",
"address": "25 Avenue de la République",
"city": "Lyon",
"postalcode": "69001",
"country": "fr",
"currency": "EUR",
"language": "fr",
"is_client": true,
"cin_scheme": "0009",
"cin_value": "98765432100011",
"tin_scheme": 9957,
"tin_value": "FR05987654321",
"transport_type_code": "peppol",
"document_type_code": "xml.ubl.invoice.frcius.v1"
}
}'

POST Contact - API Reference

Optional: Verify recipient routing (Directory lookup)

Section titled “Optional: Verify recipient routing (Directory lookup)”

B2Brouter routes invoices automatically. To inspect how a recipient will be routed before sending — for example to confirm they are registered in the Annuaire — use the Directory lookup:

Terminal window
curl --request GET \
--url https://api-staging.b2brouter.net/directory/fr/0009/98765432100011 \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}'

GET Lookup Directory - API Reference

Annuaire verification and tax report generation

Section titled “Annuaire verification and tax report generation”

B2Brouter automatically verifies whether French contacts (country: "fr") are registered in the DGFiP Annuaire. This verification determines the tax reporting flow:

  • Contact registered in Annuaire (in_dgfip_annuaire: true or not yet verified): the invoice generates a Flux 1 tax report (domestic B2B e-invoicing).
  • Contact NOT registered in Annuaire (in_dgfip_annuaire: false): the invoice does not generate a tax report. This prevents invalid Flux 1 submissions for recipients that the PPF cannot route to.
  • Contact not yet verified (in_dgfip_annuaire: nil): B2Brouter is permissive — the invoice proceeds and generates a tax report. Verification happens asynchronously in the background.

If you create a French contact and immediately send an invoice, the Annuaire verification may not have completed yet. This is by design — B2Brouter does not block invoice creation while verification is pending. If the contact turns out to be unregistered, future invoices to that contact will not generate Flux 1 tax reports until the contact registers with a PA.

The Annuaire check only applies to French domestic contacts (country: "fr"). Non-French contacts always follow the Flux 10 e-Reporting path regardless of Annuaire status.


Once your company is onboarded and the DGFiP Tax Report Setting is enabled, creating invoices works through the standard Invoice API. B2Brouter handles all France-specific requirements automatically: tax report generation, UBL/CII/Factur-X formatting, and PPF transmission via Flux 1.

Use send_after_import: true to create and transmit in one step. Set it to false if you want to create the invoice first and review it before sending — in that case, the invoice stays in new state until you trigger transmission via a separate call or through the B2Brouter UI.

Sequential invoicing: The API processes one invoice per request. For bulk or batch scenarios, iterate through your invoice list and call the endpoint for each document. The API supports concurrent requests — you can parallelise multiple POSTs without waiting for each response before starting the next.

The most common case: a domestic French B2B invoice with standard TVA (20%).

Terminal window
curl --request POST \
--url https://api-staging.b2brouter.net/accounts/{ACCOUNT_ID}/invoices \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}' \
--header 'Content-Type: application/json' \
--data '{
"send_after_import": true,
"invoice": {
"type": "IssuedInvoice",
"contact_id": 1313228381,
"number": "FA-2026-0048",
"date": "2026-09-15",
"due_date": "2026-10-15",
"currency": "EUR",
"payment_method": 4,
"remittance_information": "FA-2026-0048 — Exemplar SAS, SAS au capital de 50 000 EUR, RCS Paris 123 456 789",
"payment_method_text": "Virement bancaire, IBAN FR00 0000 0000 0000 0000 0000 000, BIC XXXXFRPP",
"payment_terms": "Net 30 jours à compter de la date de facture. Pénalité de retard : 12% annuel.",
"invoice_lines_attributes": [
{
"quantity": 10.0,
"description": "Consulting services — architecture review",
"price": 150.0,
"unit": 9,
"taxes_attributes": [
{ "name": "TVA", "percent": 20.0, "category": "S" }
]
},
{
"quantity": 5.0,
"description": "Training sessions — API integration",
"price": 200.0,
"unit": 9,
"taxes_attributes": [
{ "name": "TVA", "percent": 20.0, "category": "S" }
]
}
]
}
}'

The tax_report_ids array in the response contains the ID of the generated tax report. Use it to track the submission lifecycle (see Check the state of a Tax Report).

POST Invoice - API Reference

Payment information (required native fields)

Section titled “Payment information (required native fields)”

Three payment fields are mandatory for French B2B e-invoices (IssuedInvoice). Provide them as direct API fields:

FieldDGFiP fieldDescriptionRequired
remittance_informationPMDPayment reference and legal mentions (company registration, share capital, RCS)Yes — B2B domestic and cross-border
payment_method_textPMTPayment method code + IBAN/BIC detailsYes — B2B domestic and cross-border
payment_termsAABDue date, late payment penalties, discount conditionsYes — B2B domestic and cross-border

If any of the three fields is missing, the request returns HTTP 422 with explicit error messages for each absent field. These are not silent — the invoice is never created. Correct the missing fields and resubmit.

B2C invoices (IssuedSimplifiedInvoice) do not require these fields.

Importing from other formats (UBL, CII, Factur-X): For these integrations, use the extra_info field with structured tags:

#PMD# FA-2026-0048 — Exemplar SAS, RCS Paris 123 456 789
#PMT# Credit Transfer, IBAN FR00 0000 0000 0000 0000 0000 000, BIC XXXXFRPP
#AAB# Net 30 jours. Pénalité de retard : 12% annuel.

B2Brouter extracts these tags and maps them to the corresponding native fields automatically.

When a line has category: "E" (VAT-exempt), you must also provide a comment with the applicable VATEX-FR-CGI261-* exemption code (DGFiP BT-121):

⚠️ Silent blocking: If comment is omitted on a category E line, the invoice is created (HTTP 200) but never transmitted to the PPF. The response will contain a non-empty errors array — check it even on successful responses.

DGFiP VAT exemption codes (BT-121)

CodeLegal referenceTax categoryDescription
VATEX-FR-FRANCHISEArt. 293 B CGIZ (zero-rate)Franchise en base de TVA
VATEX-FR-CNWVATE (exempt)Non-established in France
VATEX-FR-AEE (exempt)Autoliquidation (reverse charge)
VATEX-FR-CGI261-1Art. 261-1° CGIE (exempt)Soins et services médicaux
VATEX-FR-CGI261-2Art. 261-2° CGIE (exempt)Services paramédicaux
VATEX-FR-CGI261-3Art. 261-3° CGIE (exempt)Enseignement scolaire, universitaire et formation professionnelle

Franchise en base de TVA (VATEX-FR-FRANCHISE)

Section titled “Franchise en base de TVA (VATEX-FR-FRANCHISE)”

Companies operating under the franchise en base de TVA regime operate at zero-rate (tax category Z), not exempt (category E). For franchise invoices, set percent: 0.0 and category: "E" with comment: "VATEX-FR-FRANCHISE" on each tax line — B2Brouter transcodes the category to Z automatically:

{
"taxes_attributes": [
{
"name": "TVA",
"percent": 0.0,
"category": "E",
"comment": "VATEX-FR-FRANCHISE"
}
]
}

To issue a credit note, set is_amend: true and reference the original invoice using amended_number and amended_date. B2Brouter generates a UBL CreditNote with type code 381 and includes the billing reference.

Terminal window
curl --request POST \
--url https://api-staging.b2brouter.net/accounts/{ACCOUNT_ID}/invoices \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}' \
--header 'Content-Type: application/json' \
--data '{
"send_after_import": true,
"invoice": {
"type": "IssuedInvoice",
"contact_id": 1313228381,
"number": "NC-2026-001",
"date": "2026-09-25",
"due_date": "2026-10-25",
"is_credit_note": true,
"is_amend": true,
"amended_number": "FA-2026-0048",
"amended_date": "2026-09-15",
"currency": "EUR",
"payment_method": 4,
"remittance_information": "NC-2026-001 — annule et remplace FA-2026-0048. Exemplar SAS",
"payment_method_text": "Virement bancaire, IBAN FR00 0000 0000 0000 0000 0000 000, BIC XXXXFRPP",
"payment_terms": "Remboursement sous 30 jours.",
"invoice_lines_attributes": [
{
"quantity": -1.0,
"description": "Annulation partielle — Consulting services",
"price": 500.0,
"unit": 9,
"taxes_attributes": [
{ "name": "TVA", "percent": 20.0, "category": "S" }
]
}
]
}
}'

The process code determines the PPF flux cadre. B2Brouter assigns it automatically based on type_operation in the Tax Report Setting and the invoice characteristics.

Process CodeType of OperationDescription
S1ServicesStandard invoice for services
B1GoodsStandard invoice for goods
M1MixedStandard invoice for mixed operations
S2ServicesPaid invoice for services
B2GoodsPaid invoice for goods
M2MixedPaid invoice for mixed operations
S4ServicesInvoice with payments on account (services)
B4GoodsInvoice with payments on account (goods)
M4MixedInvoice with payments on account (mixed)
S7ServicesCorrection of a registered invoice (services)
B7GoodsCorrection of a registered invoice (goods)
Document Type CodeFormatDescription
xml.ubl.invoice.frcius.v1UBL XMLFrance CIUS Peppol invoice (Flux 1 / Annuaire)
xml.cii.cross_industry_invoice.frcius.v1CII XMLFrance CIUS CII invoice
pdf.a.invoice.with.xml.cii.cross_industry_invoice.facturx.fr.all_profiles.v1Factur-XPDF/A with embedded CII XML

If your system already generates Factur-X or UBL XML invoices, submit them directly using the document import endpoint:

POST /accounts/{id}/invoices/import

Set Content-Type to:

  • application/pdf — for Factur-X (PDF/A-3 with embedded CII XML)
  • application/xml — for standalone UBL 2.1 or CII XML

StateDescription
sendingThe invoice has been created and is queued for PPF transmission.
sentThe invoice XML has been successfully uploaded to the PPF (Flux 1 deposit confirmed).
registeredThe PPF has validated and accepted the invoice (CDV Flux 1 positive).
acceptedThe buyer has approved the invoice.
refusedThe buyer has rejected the invoice.
allegedly_paidThe buyer has reported the invoice as paid (corresponds to CDAR 212 — Encaissée).
errorAn error occurred during transmission or PPF validation. The errors field in the invoice response contains the PPF rejection reason. Delete the invoice, correct the issue, and submit a new one — errored invoices cannot be retransmitted directly.

Configure webhook endpoints in the B2Brouter UI under Settings → Webhooks. Once configured, B2Brouter sends an HTTP POST to your endpoint each time the invoice reaches a new state.

Invoice Status WebHooks - API Reference

Terminal window
curl --request GET \
--url https://api-staging.b2brouter.net/invoices/{INVOICE_ID} \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}' \
--header 'Accept: application/json'

GET Invoice - API Reference

After an invoice reaches sent state, the GET /invoices/{id} response includes a download_legal_url field. Use it to download the invoice document that was transmitted:

Terminal window
curl --request GET \
--url https://api-staging.b2brouter.net{download_legal_url} \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}'

The tax report tracks the technical lifecycle of the submission to the PPF. Both XML generation and PPF transmission are asynchronous.

Flux 1 — Domestic B2B invoices:

StateDescription
newTax report created, queued for transmission
sentDocument deposited to PPF via SFTP
acknowledgedPPF has received and validated the file (CDV condition 500 — Reçue)
registeredTerminal — Invoice accepted and registered by the DGFiP (CDV condition 300)
refusedTerminal — Rejected by the DGFiP (CDV condition 301)
errorTerminal — Transmission or PPF processing error
annulledInvoice has been annulled after registration

Flux 10 — Cross-border B2B and B2C invoices (e-Reporting):

StateDescription
newTax report created, accumulated for the daily ledger batch
sentLedger deposited to PPF via SFTP
acknowledgedPPF has received the ledger (CDV condition 500 — Reçue)
registeredTerminal — Ledger accepted and registered by the DGFiP (CDV condition 300)
refusedTerminal — Rejected by the DGFiP (CDV condition 301)
errorTerminal — Transmission or PPF processing error

Query the state using the tax report ID from tax_report_ids in the invoice response:

Terminal window
curl --request GET \
--url https://api-staging.b2brouter.net/tax_reports/{TAX_REPORT_ID} \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}'

GET Tax Report - API Reference


Flux 10 covers transactions outside the scope of the domestic B2B e-invoicing obligation that must still be reported to the DGFiP. B2Brouter handles Flux 10 automatically.

Sales to non-VAT-registered individuals in France. Use "type": "IssuedSimplifiedInvoice". The contact_id and payment fields are not required for B2C invoices.

Cross-border transactions (B2B intra-EU and extra-EU)

Section titled “Cross-border transactions (B2B intra-EU and extra-EU)”

Sales to or purchases from companies established outside France must be reported via Flux 10. Use the standard IssuedInvoice or ReceivedInvoice type and set the counterparty’s country to the relevant non-"fr" value. B2Brouter detects the cross-border nature automatically.

B2Brouter groups all Flux 10 tax reports from a calendar day into Ledgers sent to the PPF once per day (scheduled at 02:00 AM server time). You can identify Flux 10 tax reports by a non-null ledger_id in the tax report response.


As a French company registered in the Annuaire with a Peppol 0225 transport, you automatically receive electronic invoices from other French and Peppol-connected platforms.

When you receive an invoice, report its status to the PPF by updating the invoice state:

Terminal window
curl --request POST \
--url https://api-staging.b2brouter.net/invoices/{INVOICE_ID}/mark_as \
--header 'X-B2B-API-Key: {YOUR_API_KEY}' \
--header 'X-B2B-API-Version: {YOUR_API_VERSION}' \
--header 'accept: application/json' \
--header 'content-type: application/json' \
--data '{"state":"accepted"}'

Valid target states for received invoices: accepted (205 Approuvée), refused (210 Refusée).

Switch invoice state - API Reference