Merge remote-tracking branch 'origin/main'

dev/supplier-email-drawer
Lei OT 9 months ago
commit 2d2eee7704

@ -5,6 +5,7 @@ const { sessionStore } = require('../../core');
const { objectMapper, pick } = require('../../utils/commons.util'); const { objectMapper, pick } = require('../../utils/commons.util');
const { createOutboundMessage } = require('../../services/outbound_messages.service'); const { createOutboundMessage } = require('../../services/outbound_messages.service');
const waEmitter = require('../../core/emitter');
function sleep(ms) { function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms)); return new Promise(resolve => setTimeout(resolve, ms));
} }
@ -39,7 +40,8 @@ exports.sendText = async ctx => {
await createOutboundMessage({ ...toUpsert }); await createOutboundMessage({ ...toUpsert });
// return 'Message sent successfully'; // { wsToSend, ret: 'Message sent successfully' }; // return 'Message sent successfully'; // { wsToSend, ret: 'Message sent successfully' };
// }); // });
wsToSend.sendTextMessage(to, content, actionId); //wsToSend.sendTextMessage(to, content, actionId);
waEmitter.emit('request.' + from + '.send.text', {to, content, externalId: actionId});
return 'Message sent successfully'; // { wsToSend, ret: 'Message sent successfully' }; return 'Message sent successfully'; // { wsToSend, ret: 'Message sent successfully' };
} catch (error) { } catch (error) {
console.error('Error sending message:', error); console.error('Error sending message:', error);

@ -1,5 +1,6 @@
const { isJidUser, isJidGroup, isJidBroadcast, jidEncode, jidDecode, S_WHATSAPP_NET } = require('@whiskeysockets/baileys'); const { isJidUser, isJidGroup, isJidBroadcast, jidEncode, jidDecode, S_WHATSAPP_NET } = require('@whiskeysockets/baileys');
// -> encodePhoneNo
const formatPhoneNumber = number => { const formatPhoneNumber = number => {
if (number === null || number === undefined) return ''; if (number === null || number === undefined) return '';
@ -10,6 +11,7 @@ const formatPhoneNumber = number => {
} }
}; };
// -> decodePhoneNo
const parsePhoneNumber = number => { const parsePhoneNumber = number => {
if (number === null || number === undefined) return ''; if (number === null || number === undefined) return '';

@ -172,6 +172,11 @@ const createWhatsApp = async phone => {
for (const msg of messageUpdate) { for (const msg of messageUpdate) {
// 没有明确标识状态的更新,忽略
const ignore = msg.update === undefined || msg.update.status === undefined;
if (ignore) continue;
const externalId = msgIdMap.get(msg.key.id); const externalId = msgIdMap.get(msg.key.id);
waEmitter.emit('message:updated', { waEmitter.emit('message:updated', {
id: msg.key.id, id: msg.key.id,
@ -280,7 +285,6 @@ const createWhatsApp = async phone => {
if((lastDisconnect?.error)?.output?.statusCode !== DisconnectReason.loggedOut) { if((lastDisconnect?.error)?.output?.statusCode !== DisconnectReason.loggedOut) {
start(); start();
} else { } else {
waEmitter.emit('connection:close', { waEmitter.emit('connection:close', {
whatsAppNo, channelId, whatsAppNo, channelId,
eventSource: serverConfig.name + '.connection.update.close', eventSource: serverConfig.name + '.connection.update.close',
@ -288,18 +292,16 @@ const createWhatsApp = async phone => {
}); });
} }
} else if (connection === 'open') { } else if (connection === 'open') {
connectionStatus = 'open';
waEmitter.emit('connection:open', { waEmitter.emit('connection:open', {
status: 'open', whatsAppNo, channelId, status: 'open', whatsAppNo, channelId,
eventSource: serverConfig.name + '.connection.update.open', eventSource: serverConfig.name + '.connection.update.open',
}); });
waEmitter.on('request.' + whatsAppNo + '.send.message', event => { waEmitter.on('request.' + whatsAppNo + '.send.text', event => {
// const jid = formatPhoneNumber(event.to);
const {to: number, externalId, content} = event; const {to: number, externalId, content} = event;
console.info('request.' + whatsAppNo + '.send.message:', event) console.info('request.' + whatsAppNo + '.send.message:', event)
// const jid = formatPhoneNumber(event.to);
waSocket.sendMessage( waSocket.sendMessage(
number + '@s.whatsapp.net', number + '@s.whatsapp.net', { text: content }
{ text: content}
).then(msg => { ).then(msg => {
msgIdMap.set(msg.key.id, externalId); msgIdMap.set(msg.key.id, externalId);
}).catch(ex => { }).catch(ex => {
@ -318,6 +320,29 @@ const createWhatsApp = async phone => {
}); });
//sendTextMessage(number, content, externalId); //sendTextMessage(number, content, externalId);
}); });
waEmitter.on('request.' + whatsAppNo + '.send.image', event => {
const {to: number, externalId, content} = event;
const jid = formatPhoneNumber(event.to);
waSocket.sendMessage(
jid, {image: { url: imageUrl }}
).then(msg => {
msgIdMap.set(msg.key.id, externalId);
}).catch(ex => {
console.error('sendMessage.error: ', ex)
waEmitter.emit('message:updated', {
id: generateId(),
externalId,
status: 'failed',
direction: 'outbound',
from: whatsAppNo,
to: number,
error: `发送图片消息出错 ` + ex,
eventSource: serverConfig.name + '.sendMessage.catch',
updateTime: formatTimestamp(new Date().getTime() / 1000),
});
});
});
} else if (qr !== undefined) { } else if (qr !== undefined) {
// WebSocket 创建成功等待扫码,如果没有扫码会更新 qr // WebSocket 创建成功等待扫码,如果没有扫码会更新 qr
// 第一次一分钟,后面是 20 秒更新一次 // 第一次一分钟,后面是 20 秒更新一次

Loading…
Cancel
Save