ccc
This commit is contained in:
parent
c0c1d67cf4
commit
89f2f5d5e9
79
index.js
79
index.js
@ -1,4 +1,4 @@
|
||||
const { default: makeWASocket, useMultiFileAuthState, DisconnectReason, fetchLatestBaileysVersion } = require('@whiskeysockets/baileys');
|
||||
const { default: makeWASocket, useMultiFileAuthState, DisconnectReason, fetchLatestBaileysVersion, proto, generateWAMessageFromContent, generateWAMessageContent } = require('@whiskeysockets/baileys');
|
||||
const express = require('express');
|
||||
const { Boom } = require('@hapi/boom');
|
||||
const qrcode = require('qrcode');
|
||||
@ -46,6 +46,60 @@ const initBaileys = async () => {
|
||||
sock.ev.on('creds.update', saveCreds);
|
||||
};
|
||||
|
||||
async function generateMediaMessage(sock, type, url) {
|
||||
const generated = await generateWAMessageContent(
|
||||
{ [type]: { url } },
|
||||
{ upload: sock.waUploadToServer }
|
||||
);
|
||||
return generated[`${type}Message`];
|
||||
}
|
||||
|
||||
async function sendInteractive(sock, jid, imageUrl) {
|
||||
const imageMsg = await generateMediaMessage(sock, 'image', imageUrl);
|
||||
|
||||
const content = {
|
||||
viewOnceMessage: {
|
||||
message: {
|
||||
messageContextInfo: {
|
||||
deviceListMetadata: {},
|
||||
deviceListMetadataVersion: 2,
|
||||
},
|
||||
interactiveMessage: proto.Message.InteractiveMessage.create({
|
||||
body: { text: 'Quel produit vous intéresse ?' },
|
||||
footer: { text: 'Répondez via un bouton' },
|
||||
header: {
|
||||
title: 'Menu produits',
|
||||
hasMediaAttachment: true,
|
||||
imageMessage: imageMsg,
|
||||
},
|
||||
nativeFlowMessage: {
|
||||
buttons: [
|
||||
{
|
||||
name: 'quick_reply',
|
||||
buttonParamsJson: JSON.stringify({
|
||||
display_text: '📦 Voir produits',
|
||||
id: '.produits',
|
||||
}),
|
||||
},
|
||||
{
|
||||
name: 'ctl_url',
|
||||
buttonParamsJson: JSON.stringify({
|
||||
display_text: '🛒 Visiter boutique',
|
||||
url: 'https://canguidev.fr',
|
||||
merchant_url: 'https://canguidev.fr',
|
||||
}),
|
||||
},
|
||||
],
|
||||
},
|
||||
}),
|
||||
},
|
||||
},
|
||||
};
|
||||
|
||||
const msg = generateWAMessageFromContent(jid, content, {});
|
||||
await sock.relayMessage(jid, msg.message, { messageId: msg.key.id });
|
||||
}
|
||||
|
||||
initBaileys();
|
||||
|
||||
app.get('/login', (req, res) => {
|
||||
@ -60,7 +114,6 @@ app.post('/sendText', async (req, res) => {
|
||||
const { phone, message } = req.body;
|
||||
if (!sock || !isConnected) return res.status(400).json({ error: 'Non connecté' });
|
||||
try {
|
||||
|
||||
await sock.sendMessage(`${phone}@s.whatsapp.net`, { text: message });
|
||||
res.json({ success: true });
|
||||
} catch (e) {
|
||||
@ -69,29 +122,13 @@ app.post('/sendText', async (req, res) => {
|
||||
});
|
||||
|
||||
app.post('/sendButtons', async (req, res) => {
|
||||
const { phone, message, buttons } = req.body;
|
||||
const { phone } = req.body;
|
||||
if (!sock || !isConnected) return res.status(400).json({ error: 'Non connecté' });
|
||||
try {
|
||||
const btnMsg = {
|
||||
text: 'Choisis une option :',
|
||||
buttons: [
|
||||
{
|
||||
buttonId: 'produits',
|
||||
buttonText: { displayText: 'Voir produits' },
|
||||
type: 1
|
||||
},
|
||||
{
|
||||
buttonId: 'support',
|
||||
buttonText: { displayText: 'Contacter support' },
|
||||
type: 1
|
||||
}
|
||||
],
|
||||
headerType: 1
|
||||
};
|
||||
console.log(btnMsg);
|
||||
await sock.sendMessage(`${phone}@s.whatsapp.net`, btnMsg);
|
||||
await sendInteractive(sock, `${phone}@s.whatsapp.net`, 'https://placekitten.com/300/200');
|
||||
res.json({ success: true });
|
||||
} catch (e) {
|
||||
console.error(e);
|
||||
res.status(500).json({ error: e.message });
|
||||
}
|
||||
});
|
||||
|
||||
Loading…
Reference in New Issue
Block a user