sddsdsdsds

This commit is contained in:
julien 2025-05-06 16:52:28 +02:00
parent ccfe2cf3b5
commit 73f9ea74d5

View File

@ -121,57 +121,70 @@ app.post('/sendButtons', async (req, res) => {
res.status(500).json({ error: e.message }); res.status(500).json({ error: e.message });
} }
}); });
// Votre route POST
app.post('/sendInteractiveImage', async (req, res) => { app.post('/sendInteractiveImage', async (req, res) => {
const { phone, caption, footer } = req.body; const { phone, caption, footer } = req.body;
if (!sock || !isConnected) { if (!sock || !isConnected) {
return res.status(400).json({ error: 'Non connecté' }); return res.status(400).json({ error: 'Non connecté à WhatsApp' });
} }
try { try {
// URL publique de votre image (hébergée dans ./public via express.static) // 1) Construire l'URL publique de l'image
const BASE_URL = process.env.BASE_URL || 'https://wa.canguidev.fr'; const BASE_URL = process.env.BASE_URL || 'https://wa.canguidev.fr';
const imageUrl = `${BASE_URL}/static/logo-merlo-cs-FR.jpg`; const imageUrl = `${BASE_URL}/static/logo-merlo-cs-FR.jpg`;
// **Envoi 100% “interactive”** — format officiel pris en charge par iOS // 2) Préparer le contenu brut du message
await sock.sendMessage( const rawMessage = {
`${phone}@s.whatsapp.net`, viewOnceMessage: {
{ message: {
interactive: { messageContextInfo: {
type: 'button', deviceListMetadata: {},
header: { deviceListMetadataVersion: 2
type: 'IMAGE',
image: { url: imageUrl }
}, },
body: { interactiveMessage: proto.Message.InteractiveMessage.create({
text: caption || 'Description par défaut' header: proto.Message.InteractiveMessage.Header.create({
}, type: proto.Message.InteractiveMessage.HeaderType.IMAGE,
footer: { imageMessage: { url: imageUrl }
text: footer || 'Pied de page' }),
}, body: proto.Message.InteractiveMessage.Body.create({
action: { text: caption || 'Description par défaut'
buttons: [ }),
{ footer: proto.Message.InteractiveMessage.Footer.create({
type: 'url', text: footer || 'Pied de page'
title: '📄 Proposition', }),
url: 'https://merlo-ch.com/uploads/proposition/f_p_250505_0000136_00008_EB00001909.pdf' action: proto.Message.InteractiveMessage.Action.create({
}, buttons: [
{ {
type: 'url', urlButton: proto.Message.InteractiveMessage.URLButton.create({
title: '🔧 Spécifications', displayText: '📄 Voir proposition',
url: 'https://merlo-ch.com/uploads/proposition/d_p_250505_0000136_00008_EB00001909.pdf' url: 'https://merlo-ch.com/uploads/proposition/f_p_250505_0000136_00008_EB00001909.pdf'
} })
] },
} {
urlButton: proto.Message.InteractiveMessage.URLButton.create({
displayText: '🔧 Spécifications',
url: 'https://merlo-ch.com/uploads/proposition/d_p_250505_0000136_00008_EB00001909.pdf'
})
}
]
})
})
} }
} }
); };
// 3) Générer et relayer le message
const jid = `${phone}@s.whatsapp.net`;
const msg = generateWAMessageFromContent(jid, rawMessage, {});
await sock.relayMessage(jid, msg.message, { messageId: msg.key.id });
return res.json({ success: true }); return res.json({ success: true });
} catch (e) { } catch (e) {
console.error('❌ Erreur interactive image :', e); console.error('❌ Erreur /sendInteractiveImage :', e);
return res.status(500).json({ error: e.message }); return res.status(500).json({ error: e.message });
} }
}); });
// app.post('/sendInteractiveImage', async (req, res) => { // app.post('/sendInteractiveImage', async (req, res) => {
// const { phone, caption, title, subtitle, footer } = req.body; // const { phone, caption, title, subtitle, footer } = req.body;
// if (!sock || !isConnected) return res.status(400).json({ error: 'Non connecté' }); // if (!sock || !isConnected) return res.status(400).json({ error: 'Non connecté' });