> ## Documentation Index
> Fetch the complete documentation index at: https://developers.ligdicash.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Créer une facture payin redirect

> Crée une facture de paiement avec redirection et retourne l'URL de la page de paiement LigdiCash.

## En-têtes

<ParamField header="Apikey" type="string" required>
  Clé API du projet LigdiCash.
</ParamField>

<ParamField header="Authorization" type="string" required>
  `Bearer {API_TOKEN}`
</ParamField>

<ParamField header="Accept" type="string" required>
  `application/json`
</ParamField>

<ParamField header="Content-Type" type="string" required>
  `application/json`
</ParamField>

## Corps

<ParamField body="commande" type="object" required>
  <Expandable title="commande" defaultOpen>
    <ParamField body="invoice" type="object" required>
      <Expandable title="invoice" defaultOpen>
        <ParamField body="items" type="array" required>
          Articles de la commande. Peut être `[]` — dans ce cas seul `total_amount` est utilisé.

          <Expandable title="item">
            <ParamField body="name" type="string" required>Nom de l'article.</ParamField>
            <ParamField body="description" type="string">Description.</ParamField>
            <ParamField body="quantity" type="integer" required>Quantité.</ParamField>
            <ParamField body="unit_price" type="integer" required>Prix unitaire en XOF.</ParamField>
            <ParamField body="total_price" type="integer" required>`unit_price × quantity` en XOF.</ParamField>
          </Expandable>
        </ParamField>

        <ParamField body="total_amount" type="integer" required>Montant total en XOF (entier).</ParamField>
        <ParamField body="devise" type="string" required>Toujours `"XOF"`.</ParamField>
        <ParamField body="description" type="string" required>Description affichée sur la page de paiement.</ParamField>
        <ParamField body="customer" type="string" required>Toujours `""`. Un numéro non vide filtre les opérateurs affichés.</ParamField>
        <ParamField body="customer_firstname" type="string">Prénom du client.</ParamField>
        <ParamField body="customer_lastname" type="string">Nom du client.</ParamField>
        <ParamField body="customer_email" type="string">Email du client.</ParamField>
        <ParamField body="external_id" type="string">Identifiant marchand alternatif. `""` si non utilisé.</ParamField>
        <ParamField body="otp" type="string">Toujours `""`.</ParamField>
      </Expandable>
    </ParamField>

    <ParamField body="store" type="object" required>
      <Expandable title="store" defaultOpen>
        <ParamField body="name" type="string" required>Nom de la boutique affiché sur la page de paiement.</ParamField>
        <ParamField body="website_url" type="string" required>URL du site marchand.</ParamField>
      </Expandable>
    </ParamField>

    <ParamField body="actions" type="object" required>
      <Expandable title="actions" defaultOpen>
        <ParamField body="cancel_url" type="string" required>URL de redirection si le client annule.</ParamField>
        <ParamField body="return_url" type="string" required>URL de redirection après paiement réussi.</ParamField>
        <ParamField body="callback_url" type="string" required>URL de notification backend. Doit être accessible publiquement.</ParamField>
      </Expandable>
    </ParamField>

    <ParamField body="custom_data" type="object">Métadonnées libres retournées dans le callback. Recommandé : inclure un `transaction_id` unique.</ParamField>
  </Expandable>
</ParamField>

## Réponse

<ResponseField name="response_code" type="string">
  `"00"` = succès, `"01"` = erreur.
</ResponseField>

<ResponseField name="token" type="string">
  Token de la transaction. **À stocker immédiatement** — requis pour appeler `confirm`.
</ResponseField>

<ResponseField name="response_text" type="string">
  Succès : URL de la page de paiement à ouvrir pour le client. Échec : sous-code `Echec (CodeXX)`.
</ResponseField>

<ResponseField name="wiki" type="string">
  URL de la documentation des sous-codes pour cet endpoint.
</ResponseField>

<CodeGroup>
  ```json Succès theme={null}
  {
    "response_code": "00",
    "token": "eyJ0eXAiOiJKV1Qi...",
    "response_text": "https://app.ligdicash.com/pay/invoice/eyJ0eXAiOiJKV1Qi...",
    "wiki": "https://client.ligdicash.com/wiki/createInvoice"
  }
  ```

  ```json Échec theme={null}
  {
    "response_code": "01",
    "token": "",
    "response_text": "Echec (Code00)",
    "wiki": "https://client.ligdicash.com/wiki/createInvoice"
  }
  ```
</CodeGroup>

## Codes d'erreur

Wiki : `https://client.ligdicash.com/wiki/createInvoice` — voir [Sous-codes par endpoint](/erreurs/sous-codes#createinvoice).

## Guide associé

[Créer une facture](/api-paiement/payin-redirect/creer-facture) — exemples complets et pièges à éviter.
