> ## 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.

# Soumettre un paiement Wallet LigdiCash

> Finalise un paiement via wallet LigdiCash en soumettant l'OTP reçu par le client. Deuxième étape du flux wallet.

<Note>
  Cet endpoint est **exclusif au Wallet LigdiCash**, à appeler après [GET /pay/v02/debitotp](/reference/endpoints/debit-otp) qui déclenche l'envoi de l'OTP au client.
</Note>

## 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

Même structure que [POST /pay/v01/straight/checkout-invoice/create](/reference/endpoints/payin-straight-create), avec `customer` renseigné et `otp` contenant le code reçu par le client.

<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. Peut être `[]`.</ParamField>
        <ParamField body="total_amount" type="integer" required>Montant en XOF (entier).</ParamField>
        <ParamField body="devise" type="string" required>Toujours `"XOF"`.</ParamField>
        <ParamField body="description" type="string" required>Description de la commande.</ParamField>
        <ParamField body="customer" type="string" required>Numéro de téléphone du compte LigdiCash client. Format : `22670XXXXXXX`.</ParamField>
        <ParamField body="customer_firstname" type="string">Prénom.</ParamField>
        <ParamField body="customer_lastname" type="string">Nom.</ParamField>
        <ParamField body="customer_email" type="string">Email.</ParamField>
        <ParamField body="external_id" type="string" required>Toujours `""`.</ParamField>
        <ParamField body="otp" type="string" required>OTP reçu par le client sur son application ou par SMS LigdiCash.</ParamField>
      </Expandable>
    </ParamField>

    <ParamField body="store" type="object" required>
      <Expandable title="store" defaultOpen>
        <ParamField body="name" type="string" required>Nom de la boutique.</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>Toujours `""`.</ParamField>
        <ParamField body="return_url" type="string" required>Toujours `""`.</ParamField>
        <ParamField body="callback_url" type="string" required>URL de notification backend. Accessible publiquement.</ParamField>
      </Expandable>
    </ParamField>

    <ParamField body="custom_data" type="object">Métadonnées libres. 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 `confirm`.</ResponseField>
<ResponseField name="response_text" type="string">Succès : `"Votre requête est en cours de traitement"`. Échec : `Echec (CodeXX)`.</ResponseField>
<ResponseField name="wiki" type="string">URL de la documentation des sous-codes.</ResponseField>

<CodeGroup>
  ```json Succès theme={null}
  {
    "response_code": "00",
    "token": "eyJ0eXAiOiJKV1Qi...",
    "response_text": "Votre requête est en cours de traitement",
    "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é

[Wallet LigdiCash](/api-paiement/payin-sans-redirect/operateurs/wallet-ligdicash) — flux complet en deux étapes.
