From 5977ec23519d742f32b8d9a3159685176dbed561 Mon Sep 17 00:00:00 2001 From: Lei OT Date: Fri, 20 Dec 2024 16:47:31 +0800 Subject: [PATCH] =?UTF-8?q?=E6=B5=8B=E8=AF=95:=20qrcode,=20send=20text?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- wai-server/api/channels/call.controller.js | 67 ------------- wai-server/api/channels/channel.controller.js | 93 ++++++++++--------- wai-server/api/channels/channel.routes.js | 12 +-- wai-server/api/messages/message.controller.js | 71 +++++--------- wai-server/api/messages/message.routes.js | 5 +- wai-server/core/index.js | 4 +- wai-server/core/websocket/services/session.js | 5 +- wai-server/index.js | 11 +-- 8 files changed, 88 insertions(+), 180 deletions(-) delete mode 100644 wai-server/api/channels/call.controller.js diff --git a/wai-server/api/channels/call.controller.js b/wai-server/api/channels/call.controller.js deleted file mode 100644 index 2b19fa7..0000000 --- a/wai-server/api/channels/call.controller.js +++ /dev/null @@ -1,67 +0,0 @@ -const { websocketService, websocketManager } = require('../../core'); // Import from core/index.js -const generateId = require('../../utils/generateId.util'); -// const { createConnection, getConnection } = require('../../core/whatsapp/connection'); -// const { getAvailableConnection } = require('../../core/whatsapp/sessionStore'); - -exports.newConnect = async ctx => { - // try { - // const socketId = generateId(); - // const { qr } = await createConnection(socketId); // Await the Promise here - // return { socketId, qr, message: 'Connection initiated. QR code provided.' }; // Return the QR code - // } catch (error) { - // console.error('create connection error', error); - // ctx.assert(null, 500, 'Failed to create connection or generate QR code.'); - // } -}; - -exports.getIn = async ctx => { - // Wait for at least one connection to be established (or handle the case where no connections are available) - // await new Promise(resolve => { - // const checkConnections = () => { - // if (websocketManager.getConnections().length > 0) { - // resolve(); - // } else { - // setTimeout(checkConnections, 100); // Check again after 100ms - // } - // }; - // checkConnections(); - // }); - - const availableWs = websocketManager.getAvailableConnection(); - - if (!availableWs) { - // ctx.status = 503; - // ctx.body = { message: 'No available connections' }; - ctx.assert(availableWs, 503, 'No available connections'); - return; - } - // return availableWs; - - const { sessionId, url } = websocketService.createSession(availableWs); - return { sessionId, url, message: 'Connection established' }; // availableWs -}; - -exports.sendMsg = ctx => { - const { sessionId, message } = ctx.request.body; - if (!sessionId || !message) { - // ctx.status = 400; - // ctx.body = { message: 'Session ID and message are required' }; - ctx.assert(sessionId, 400, 'Session ID and message are required'); - return; - } - const wsToSend = websocketService.getSession(sessionId); - if (!wsToSend) { - // ctx.status = 404; - // ctx.body = { message: 'Session not found' }; - ctx.assert(wsToSend, 400, 'Session not found'); - return; - } - try { - wsToSend.send(message); - ctx.body = { message: 'Message sent' }; - } catch (error) { - console.error('Error sending message:', error); - ctx.status = 500; - ctx.body = { message: 'Failed to send message' }; - } -}; diff --git a/wai-server/api/channels/channel.controller.js b/wai-server/api/channels/channel.controller.js index 2c250b6..7d0c095 100644 --- a/wai-server/api/channels/channel.controller.js +++ b/wai-server/api/channels/channel.controller.js @@ -1,52 +1,57 @@ -'use strict'; - +const { websocketService, websocketManager, createWhatsApp } = require('../../core'); // Import from core/index.js const generateId = require('../../utils/generateId.util'); +// const { createConnection, getConnection } = require('../../core/whatsapp/connection'); +// const { getAvailableConnection } = require('../../core/whatsapp/sessionStore'); -/** - * Mock database, replace this with your db models import, required to perform query to your database. - */ -const db = { - channels: [ - { - channelId: 1, - phone: 'string', - formattedPhone: 'string', - profilePicture: 'string', - name: 'string', - connectStatus: 'string', - channelStatus: 'string', - createTime: 0, - }, - ], -}; -function sleep(ms) { - return new Promise(resolve => setTimeout(resolve, ms)); -} -exports.qrcode = async ctx => { - return ``; -}; -exports.getOne = async ctx => { - const { id } = ctx.params; - const channel = db.channels.find(channel => channel.channelId === Number(id)); - await sleep(500); - ctx.assert(channel, 200, "The requested channel doesn't exist"); - return channel; +exports.newConnect = async ctx => { + try { + const { phone } = ctx.query; + // return phone; + const connectId = generateId(); + const whatsApp1 = await createWhatsApp(connectId, phone); + ctx.assert(whatsApp1, 503, 'No available connections'); + const { sessionId } = websocketService.createSession(phone, whatsApp1); + return { sessionId, whatsApp1 }; + } catch (error) { + console.error('create connection error', error); + ctx.assert(null, 500, 'Failed to create connection or generate QR code.'); + + // const wa = findConnection('from'); + // wa.senedTextMessage(to, text); + } }; exports.getAll = async ctx => { - return db.channels; + const sessions = websocketService.sessions; + return Array.from(sessions); }; -exports.createOne = async ctx => { - const { name } = ctx.request.body; - ctx.assert(name, 200, 'The channel info is malformed!'); - const id = generateId(); - const newChannel = { - id, - name, - timestamp: Date.now(), - }; - db.channels.push(newChannel); - const createdChannel = db.channels.find(channel => channel.id === id); - return createdChannel; +/** + * @deprecated + */ +exports.getIn = async ctx => { + // Wait for at least one connection to be established (or handle the case where no connections are available) + // await new Promise(resolve => { + // const checkConnections = () => { + // if (websocketManager.getConnections().length > 0) { + // resolve(); + // } else { + // setTimeout(checkConnections, 100); // Check again after 100ms + // } + // }; + // checkConnections(); + // }); + + const availableWs = websocketManager.getAvailableConnection(); + + if (!availableWs) { + // ctx.status = 503; + // ctx.body = { message: 'No available connections' }; + ctx.assert(availableWs, 503, 'No available connections'); + return; + } + // return availableWs; + + const { sessionId, url } = websocketService.createSession(availableWs); + return { sessionId, url, message: 'Connection established' }; // availableWs }; diff --git a/wai-server/api/channels/channel.routes.js b/wai-server/api/channels/channel.routes.js index 9bfb760..8ea4d89 100644 --- a/wai-server/api/channels/channel.routes.js +++ b/wai-server/api/channels/channel.routes.js @@ -1,7 +1,7 @@ 'use strict'; +// const controller = require('./channel.controller.js.bak'); const controller = require('./channel.controller'); -const callController = require('./call.controller'); module.exports = Router => { const router = new Router({ @@ -9,12 +9,12 @@ module.exports = Router => { }); router - .get('/qrcode', callController.newConnect) - .get('/qrcode0', callController.getIn) + .get('/qrcode', controller.newConnect) + // .get('/qrcode0', callController.getIn) // .get('/qrcode', controller.qrcode) - .get('/:id', controller.getOne) - .get('/', controller.getAll) - .post('/', controller.createOne); + // .get('/:id', controller.getOne) + .get('/', controller.getAll); + // .post('/', controller.createOne) // router.post('/get-in', callController.getIn); // router.post('/send-msg', callController.sendMsg); diff --git a/wai-server/api/messages/message.controller.js b/wai-server/api/messages/message.controller.js index 47c553b..533d21e 100644 --- a/wai-server/api/messages/message.controller.js +++ b/wai-server/api/messages/message.controller.js @@ -1,62 +1,37 @@ 'use strict'; const generateId = require('../../utils/generateId.util'); +const { websocketService, websocketManager, createWhatsApp } = require('../../core'); -/** - * Mock database, replace this with your db models import, required to perform query to your database. - */ -const db = { - users: [ - { - id: 'bff28903-042e-47c2-b9ee-07c3954989ec', - name: 'Marco', - created_at: 1558536830937, - }, - { - id: 'dca01a32-36e6-4886-af75-8e7caa0162a9', - name: 'Leonardo', - created_at: 1558536843742, - }, - { - id: 'dca01a32-36e6-4886-af75-8e7caa0162a9', - name: 'Berta', - created_at: 1558536863550, - }, - ], -}; function sleep(ms) { return new Promise(resolve => setTimeout(resolve, ms)); } -exports.getOne = async ctx => { - const { id } = ctx.params; - const user = db.users.find(user => user.id === id); - await sleep(500); - ctx.assert(user, 404, "The requested user doesn't exist"); - return user; -}; - -exports.getAll = async ctx => { - return db.users; -}; -exports.createOne = async ctx => { - const { name } = ctx.request.body; - ctx.assert(name, 400, 'The user info is malformed!'); - const id = generateId(); - const newUser = { - id, - name, - timestamp: Date.now(), - }; - db.users.push(newUser); - const createdUser = db.users.find(user => user.id === id); - return createdUser; -}; - -exports.sendText = async ctx => { +exports.sendText111 = async ctx => { const { type } = ctx.params; const body = ctx.request.body; ctx.assert(null, 400, `debug: content: {${type}} {${body.content}}`); ctx.assert(null, 400, 'The message info is malformed!'); return body; }; + +exports.sendText = ctx => { + const { from, to, content } = ctx.request.body; + if (!from || !content) { + ctx.assert(from, 400, 'From and message are required'); + return; + } + const wsToSend = websocketService.getSession(from); + if (!wsToSend) { + ctx.assert(wsToSend, 400, 'Session not found'); // 404 + return; + } + // return wsToSend; + try { + wsToSend.sendTextMessage(to, content); + return { wsToSend, ret: 'Message sent successfully' }; + } catch (error) { + console.error('Error sending message:', error); + ctx.assert(null, 500, 'Failed to send message'); + } +}; diff --git a/wai-server/api/messages/message.routes.js b/wai-server/api/messages/message.routes.js index 0561e27..cde3508 100644 --- a/wai-server/api/messages/message.routes.js +++ b/wai-server/api/messages/message.routes.js @@ -7,10 +7,7 @@ module.exports = Router => { prefix: `/messages`, }); - router - .get('/:id', controller.getOne) - .get('/', controller.getAll) - .post('/:type', controller.sendText); + router.post('/:type', controller.sendText); return router; }; diff --git a/wai-server/core/index.js b/wai-server/core/index.js index 891eaf1..fbdabc9 100644 --- a/wai-server/core/index.js +++ b/wai-server/core/index.js @@ -98,8 +98,8 @@ const createWhatsApp = async (channelId, phone) => { status: 'connecting', channelId : channelId, phone: phone, - ...sendTextMessage, - ...sendImageMessage + sendTextMessage, + sendImageMessage }) } }) diff --git a/wai-server/core/websocket/services/session.js b/wai-server/core/websocket/services/session.js index b3744ee..ecdcfb7 100644 --- a/wai-server/core/websocket/services/session.js +++ b/wai-server/core/websocket/services/session.js @@ -3,10 +3,9 @@ const generateId = require('../../../utils/generateId.util'); module.exports = () => { const sessions = new Map(); - const createSession = ws => { - const sessionId = generateId(); + const createSession = (sessionId, ws) => { sessions.set(ws, sessionId); - return { sessionId, url: ws.url }; + return { sessionId }; }; const getSession = sessionId => { diff --git a/wai-server/index.js b/wai-server/index.js index e13bf90..5de96ee 100644 --- a/wai-server/index.js +++ b/wai-server/index.js @@ -4,13 +4,13 @@ const http = require('http'); const server = require('./server'); const { port } = require('./config').server; -const { websocketService, websocketManager, createWhatsApp } = require('./core'); +const { createWhatsApp } = require('./core'); async function bootstrap() { - const whatsApp1 = await createWhatsApp('channel_001', '8618777396951') - console.info(whatsApp1) - const whatsApp2 = await createWhatsApp('channel_002', '8613557032060') - console.info(whatsApp2) + // const whatsApp1 = await createWhatsApp('channel_001', '8618777396951'); + // console.info(whatsApp1); + // const whatsApp2 = await createWhatsApp('channel_002', '8613557032060'); + // console.info(whatsApp2); /** * Add external services init as async operations (db, redis, etc...) * e.g. @@ -22,7 +22,6 @@ async function bootstrap() { bootstrap() .then(server => { console.log(`🚀 Server listening on port ${server.address().port}!`); - // websocketManager.connect(); // connect websocket after server start }) .catch(err => { setImmediate(() => {