299 lines
7.4 KiB
Markdown
299 lines
7.4 KiB
Markdown
# Guide de Débogage - Pré-remplissage Signature DocuSeal
|
|
|
|
## Date: 14 octobre 2025
|
|
|
|
## Logs à vérifier dans la console
|
|
|
|
Lorsque vous ouvrez une signature électronique, vous devriez voir cette séquence de logs :
|
|
|
|
### 1. API Backend (`/api/contrats/[id]/signature`)
|
|
|
|
```
|
|
🔍 [API SIGNATURE] Recherche contrat ID: xxx
|
|
✅ [API SIGNATURE] Contrat trouvé: { id, org_id, ... }
|
|
🔍 [API SIGNATURE] org_id présent: xxx
|
|
🔍 [API SIGNATURE] Recherche de signature pour org_id...
|
|
📋 [API SIGNATURE] Résultat requête organization_details: {
|
|
hasData: true/false,
|
|
hasError: true/false,
|
|
hasSignature: true/false,
|
|
signatureLength: xxx,
|
|
signaturePreview: "data:image/png;base64,..."
|
|
}
|
|
✅ [API SIGNATURE] Signature trouvée pour l'organisation
|
|
📏 [API SIGNATURE] Longueur de la signature: xxx
|
|
📤 [API SIGNATURE] Réponse finale: {
|
|
hasSignature: true,
|
|
signatureLength: xxx,
|
|
contractId: xxx,
|
|
orgId: xxx
|
|
}
|
|
```
|
|
|
|
### 2. Frontend - Récupération des données
|
|
|
|
```
|
|
🔍 [SIGNATURE] Debug - data complète: { ... }
|
|
📋 [SIGNATURE] Données contrat depuis API: { success: true, data: {...} }
|
|
🔍 [SIGNATURE] result.data: { ... }
|
|
🔍 [SIGNATURE] result.data.signature_b64: "data:image/png;base64,..."
|
|
📦 [SIGNATURE] contractData extrait: { ... }
|
|
🖊️ [SIGNATURE] signatureB64 extraite: {
|
|
exists: true,
|
|
type: "string",
|
|
length: xxx,
|
|
preview: "data:image/png;base64,..."
|
|
}
|
|
✅ [SIGNATURE] Signature B64 disponible, longueur: xxx
|
|
```
|
|
|
|
### 3. Frontend - Stockage sessionStorage
|
|
|
|
```
|
|
🔍 [SIGNATURE] Tentative de stockage de la signature...
|
|
🔍 [SIGNATURE] signatureB64 value: "data:image/png;base64,..."
|
|
📝 [SIGNATURE] Stockage de la signature dans sessionStorage
|
|
📝 [SIGNATURE] Longueur de la signature: xxx
|
|
📝 [SIGNATURE] Preview: "data:image/png;base64,..."
|
|
✅ [SIGNATURE] Signature stockée avec succès, vérification: {
|
|
stored: true,
|
|
length: xxx,
|
|
matches: true
|
|
}
|
|
✅ [SIGNATURE] URL embed trouvée: https://docuseal.eu/s/xxx
|
|
```
|
|
|
|
### 4. Frontend - Rendu du composant
|
|
|
|
```
|
|
🎨 [SIGNATURE RENDER] Génération du HTML docuseal-form
|
|
🎨 [SIGNATURE RENDER] embedSrc: https://docuseal.eu/s/xxx
|
|
🎨 [SIGNATURE RENDER] Signature depuis sessionStorage: {
|
|
exists: true,
|
|
length: xxx,
|
|
preview: "data:image/png;base64,..."
|
|
}
|
|
🎨 [SIGNATURE RENDER] signatureAttr généré: {
|
|
hasAttr: true,
|
|
attrLength: xxx,
|
|
attrPreview: 'data-signature="data:image/png;base64,...'
|
|
}
|
|
🎨 [SIGNATURE RENDER] HTML final généré
|
|
🎨 [SIGNATURE RENDER] HTML length: xxx
|
|
🎨 [SIGNATURE RENDER] HTML contient data-signature: true
|
|
```
|
|
|
|
## Points de vérification
|
|
|
|
### Étape 1 : Vérifier la base de données
|
|
|
|
```sql
|
|
-- Vérifier que la signature existe
|
|
SELECT
|
|
org_id,
|
|
structure,
|
|
LENGTH(signature_b64) as signature_length,
|
|
SUBSTRING(signature_b64, 1, 50) as signature_preview
|
|
FROM organization_details
|
|
WHERE signature_b64 IS NOT NULL;
|
|
```
|
|
|
|
**Attendu** :
|
|
- Au moins une ligne avec signature_b64 non NULL
|
|
- signature_length > 0
|
|
- signature_preview commence par "data:image/"
|
|
|
|
### Étape 2 : Vérifier que le contrat a un org_id
|
|
|
|
```sql
|
|
-- Vérifier le contrat
|
|
SELECT
|
|
id,
|
|
contract_number,
|
|
org_id,
|
|
signature_status
|
|
FROM cddu_contracts
|
|
WHERE id = 'VOTRE_CONTRACT_ID';
|
|
```
|
|
|
|
**Attendu** :
|
|
- org_id non NULL
|
|
- org_id correspond à une organisation avec signature_b64
|
|
|
|
### Étape 3 : Tester l'API directement
|
|
|
|
```bash
|
|
# Remplacer CONTRACT_ID par l'ID réel
|
|
curl http://localhost:3000/api/contrats/CONTRACT_ID/signature
|
|
```
|
|
|
|
**Attendu dans la réponse** :
|
|
```json
|
|
{
|
|
"success": true,
|
|
"data": {
|
|
"id": "...",
|
|
"org_id": "...",
|
|
"signature_b64": "data:image/png;base64,..."
|
|
}
|
|
}
|
|
```
|
|
|
|
### Étape 4 : Vérifier la console du navigateur
|
|
|
|
**Ouvrir DevTools (F12) → Console**
|
|
|
|
Chercher les logs :
|
|
- ✅ Tous les logs commençant par `[API SIGNATURE]`
|
|
- ✅ Tous les logs commençant par `[SIGNATURE]`
|
|
- ✅ Tous les logs commençant par `[SIGNATURE RENDER]`
|
|
|
|
### Étape 5 : Vérifier sessionStorage
|
|
|
|
**Dans DevTools → Application → Storage → Session Storage**
|
|
|
|
Chercher la clé : `docuseal_signature_b64`
|
|
|
|
**Attendu** :
|
|
- Clé présente
|
|
- Valeur commence par "data:image/"
|
|
- Valeur ressemble à du base64
|
|
|
|
### Étape 6 : Vérifier le HTML généré
|
|
|
|
**Dans DevTools → Elements**
|
|
|
|
Chercher l'élément `<docuseal-form>`
|
|
|
|
**Attendu** :
|
|
```html
|
|
<docuseal-form
|
|
data-src="https://docuseal.eu/s/xxx"
|
|
data-language="fr"
|
|
data-with-title="false"
|
|
data-background-color="#fff"
|
|
data-allow-typed-signature="false"
|
|
data-signature="data:image/png;base64,...">
|
|
</docuseal-form>
|
|
```
|
|
|
|
**Vérifier** :
|
|
- ✅ Attribut `data-signature` présent
|
|
- ✅ Valeur commence par "_BASE64'
|
|
WHERE org_id = 'ID_ORGANISATION';
|
|
```
|
|
|
|
### Problème 2 : Signature trop longue pour sessionStorage
|
|
|
|
**Symptôme** :
|
|
```
|
|
❌ [SIGNATURE] Erreur lors du stockage: QuotaExceededError
|
|
```
|
|
|
|
**Solution** :
|
|
- Compresser l'image de signature
|
|
- Utiliser un format plus léger (PNG optimisé)
|
|
- Limite sessionStorage : ~5-10MB selon le navigateur
|
|
|
|
### Problème 3 : Format de signature incorrect
|
|
|
|
**Symptôme** :
|
|
DocuSeal affiche une erreur ou ne pré-remplit pas
|
|
|
|
**Solution** :
|
|
Vérifier le format :
|
|
- ✅ CORRECT : `...`
|
|
- ❌ INCORRECT : `iVBORw0KGgo...` (manque le préfixe)
|
|
- ❌ INCORRECT : `data:image/png,base64,iVBORw0KGgo...` (virgule au mauvais endroit)
|
|
|
|
### Problème 4 : Le composant se re-render avant le stockage
|
|
|
|
**Symptôme** :
|
|
```
|
|
🎨 [SIGNATURE RENDER] Signature depuis sessionStorage: { exists: false }
|
|
```
|
|
mais plus tôt on a vu :
|
|
```
|
|
✅ [SIGNATURE] Signature stockée avec succès
|
|
```
|
|
|
|
**Solution** :
|
|
Problème de timing React. Le sessionStorage est lu lors du premier rendu avant le stockage.
|
|
|
|
**Fix** : Forcer un re-render après le stockage :
|
|
```tsx
|
|
if (signatureB64) {
|
|
sessionStorage.setItem('docuseal_signature_b64', signatureB64);
|
|
// Forcer un re-render
|
|
setEmbedSrc(null);
|
|
setTimeout(() => setEmbedSrc(embed), 0);
|
|
}
|
|
```
|
|
|
|
## Commandes utiles
|
|
|
|
### Vérifier toutes les organisations avec signature
|
|
|
|
```sql
|
|
SELECT
|
|
o.id,
|
|
o.name,
|
|
od.structure,
|
|
CASE
|
|
WHEN od.signature_b64 IS NOT NULL THEN '✅ Signature présente'
|
|
ELSE '❌ Pas de signature'
|
|
END as statut,
|
|
LENGTH(od.signature_b64) as taille
|
|
FROM organizations o
|
|
LEFT JOIN organization_details od ON od.org_id = o.id
|
|
ORDER BY od.signature_b64 IS NOT NULL DESC, o.name;
|
|
```
|
|
|
|
### Vérifier les contrats prêts pour le pré-remplissage
|
|
|
|
```sql
|
|
SELECT
|
|
c.id,
|
|
c.contract_number,
|
|
c.org_id,
|
|
o.name as organization_name,
|
|
c.signature_status,
|
|
CASE
|
|
WHEN od.signature_b64 IS NOT NULL THEN '✅ Signature dispo'
|
|
ELSE '❌ Pas de signature'
|
|
END as signature_employeur
|
|
FROM cddu_contracts c
|
|
LEFT JOIN organizations o ON o.id = c.org_id
|
|
LEFT JOIN organization_details od ON od.org_id = c.org_id
|
|
WHERE c.signature_status IN ('En attente', 'Signé par l''employeur')
|
|
ORDER BY c.created_at DESC
|
|
LIMIT 20;
|
|
```
|
|
|
|
## Contact
|
|
|
|
Si les logs montrent toutes les étapes OK mais que ça ne fonctionne toujours pas :
|
|
1. Copier tous les logs de la console
|
|
2. Faire une capture d'écran de l'élément `<docuseal-form>` dans DevTools
|
|
3. Vérifier la version de DocuSeal utilisée
|
|
4. Consulter la documentation DocuSeal pour `data-signature`
|