KJOJP
This commit is contained in:
parent
758cba09b6
commit
3d83216978
56
index.js
56
index.js
@ -1,9 +1,16 @@
|
|||||||
const { default: makeWASocket, useMultiFileAuthState, DisconnectReason, fetchLatestBaileysVersion, proto, generateWAMessageFromContent, generateWAMessageContent ,prepareWAMessageMedia} = require('@fizzxydev/baileys-pro');
|
|
||||||
const express = require('express');
|
const express = require('express');
|
||||||
const { Boom } = require('@hapi/boom');
|
|
||||||
const qrcode = require('qrcode');
|
const qrcode = require('qrcode');
|
||||||
const path = require('path');
|
const path = require('path');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
|
const NodeCache = require('node-cache');
|
||||||
|
const {
|
||||||
|
default: makeWASocket,
|
||||||
|
useMultiFileAuthState,
|
||||||
|
DisconnectReason,
|
||||||
|
fetchLatestBaileysVersion,
|
||||||
|
proto,
|
||||||
|
generateWAMessageFromContent
|
||||||
|
} = require('@fizzxydev/baileys-pro');
|
||||||
|
|
||||||
const app = express();
|
const app = express();
|
||||||
app.use(express.json());
|
app.use(express.json());
|
||||||
@ -13,6 +20,15 @@ let sock;
|
|||||||
let qrData = null;
|
let qrData = null;
|
||||||
let isConnected = false;
|
let isConnected = false;
|
||||||
|
|
||||||
|
// 💾 Group Metadata Cache (5 minutes)
|
||||||
|
const groupCache = new NodeCache({ stdTTL: 300, useClones: false });
|
||||||
|
|
||||||
|
// Simule une récupération de message depuis un store pour getMessage
|
||||||
|
async function getMessageFromStore(key) {
|
||||||
|
// À adapter selon ta logique réelle
|
||||||
|
return { conversation: "Message temporaire pour retry" };
|
||||||
|
}
|
||||||
|
|
||||||
const initBaileys = async () => {
|
const initBaileys = async () => {
|
||||||
const { version } = await fetchLatestBaileysVersion();
|
const { version } = await fetchLatestBaileysVersion();
|
||||||
const { state, saveCreds } = await useMultiFileAuthState('auth');
|
const { state, saveCreds } = await useMultiFileAuthState('auth');
|
||||||
@ -20,23 +36,21 @@ const initBaileys = async () => {
|
|||||||
sock = makeWASocket({
|
sock = makeWASocket({
|
||||||
version,
|
version,
|
||||||
auth: state,
|
auth: state,
|
||||||
printQRInTerminal: false
|
markOnlineOnConnect: false,
|
||||||
|
getMessage: async (key) => await getMessageFromStore(key),
|
||||||
|
cachedGroupMetadata: async (jid) => groupCache.get(jid)
|
||||||
});
|
});
|
||||||
|
|
||||||
sock.ev.on('connection.update', async (update) => {
|
sock.ev.on('connection.update', async ({ connection, lastDisconnect, qr }) => {
|
||||||
const { connection, lastDisconnect, qr } = update;
|
|
||||||
if (qr) {
|
if (qr) {
|
||||||
qrData = await qrcode.toDataURL(qr);
|
qrData = await qrcode.toDataURL(qr);
|
||||||
isConnected = false;
|
isConnected = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (connection === 'close') {
|
if (connection === 'close') {
|
||||||
const shouldReconnect = lastDisconnect?.error?.output?.statusCode !== DisconnectReason.loggedOut;
|
const shouldReconnect = lastDisconnect?.error?.output?.statusCode !== DisconnectReason.loggedOut;
|
||||||
if (shouldReconnect) {
|
console.log(shouldReconnect ? '🔁 Reconnexion...' : '❌ Déconnecté.');
|
||||||
console.log('🔁 Reconnexion...');
|
if (shouldReconnect) initBaileys();
|
||||||
initBaileys();
|
|
||||||
} else {
|
|
||||||
console.log('❌ Déconnecté.');
|
|
||||||
}
|
|
||||||
} else if (connection === 'open') {
|
} else if (connection === 'open') {
|
||||||
console.log('✅ Connecté à WhatsApp');
|
console.log('✅ Connecté à WhatsApp');
|
||||||
isConnected = true;
|
isConnected = true;
|
||||||
@ -44,9 +58,29 @@ const initBaileys = async () => {
|
|||||||
});
|
});
|
||||||
|
|
||||||
sock.ev.on('creds.update', saveCreds);
|
sock.ev.on('creds.update', saveCreds);
|
||||||
|
|
||||||
|
// 📌 Caching des groupes
|
||||||
|
sock.ev.on('groups.update', async ([event]) => {
|
||||||
|
const metadata = await sock.groupMetadata(event.id);
|
||||||
|
groupCache.set(event.id, metadata);
|
||||||
|
});
|
||||||
|
|
||||||
|
sock.ev.on('group-participants.update', async (event) => {
|
||||||
|
const metadata = await sock.groupMetadata(event.id);
|
||||||
|
groupCache.set(event.id, metadata);
|
||||||
|
});
|
||||||
|
|
||||||
|
// (Facultatif) Gestion des messages reçus
|
||||||
|
sock.ev.on('messages.upsert', async ({ messages }) => {
|
||||||
|
const msg = messages[0];
|
||||||
|
if (!msg.key.fromMe && msg.message?.conversation) {
|
||||||
|
console.log('💬 Message reçu de', msg.key.remoteJid, ':', msg.message.conversation);
|
||||||
|
}
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
initBaileys();
|
initBaileys();
|
||||||
|
|
||||||
app.use('/static', express.static(path.join(__dirname, 'public')));
|
app.use('/static', express.static(path.join(__dirname, 'public')));
|
||||||
|
|
||||||
app.get('/login', (req, res) => {
|
app.get('/login', (req, res) => {
|
||||||
|
|||||||
@ -12,6 +12,8 @@
|
|||||||
"axios": "^1.4.0",
|
"axios": "^1.4.0",
|
||||||
"express": "^4.18.4",
|
"express": "^4.18.4",
|
||||||
"qrcode": "^1.5.1",
|
"qrcode": "^1.5.1",
|
||||||
"sharp": "^0.33.0"
|
"sharp": "^0.33.0",
|
||||||
|
"node-cache": "^5.1.2"
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user