improvement: better names on wbot methods

This commit is contained in:
canove
2020-09-05 15:43:52 -03:00
parent b8ff993e6f
commit 40e2e5e8a6
8 changed files with 160 additions and 92 deletions

View File

@@ -7,7 +7,7 @@ const cors = require("cors");
const multer = require("multer"); const multer = require("multer");
const Sentry = require("@sentry/node"); const Sentry = require("@sentry/node");
const wBot = require("./libs/wbot"); const { initWbot } = require("./libs/wbot");
const wbotMessageListener = require("./services/wbotMessageListener"); const wbotMessageListener = require("./services/wbotMessageListener");
const wbotMonitor = require("./services/wbotMonitor"); const wbotMonitor = require("./services/wbotMonitor");
const Whatsapp = require("./models/Whatsapp"); const Whatsapp = require("./models/Whatsapp");
@@ -61,8 +61,7 @@ const startWhatsAppSessions = async () => {
if (whatsapps.length > 0) { if (whatsapps.length > 0) {
whatsapps.forEach(dbSession => { whatsapps.forEach(dbSession => {
wBot initWbot(dbSession)
.init(dbSession)
.then(() => { .then(() => {
wbotMessageListener(dbSession); wbotMessageListener(dbSession);
wbotMonitor(dbSession); wbotMonitor(dbSession);

View File

@@ -1,6 +1,6 @@
const Contact = require("../models/Contact"); const Contact = require("../models/Contact");
const { getIO } = require("../libs/socket"); const { getIO } = require("../libs/socket");
const { getWbot, init } = require("../libs/wbot"); const { getWbot, initWbot } = require("../libs/wbot");
exports.store = async (req, res, next) => { exports.store = async (req, res, next) => {
const io = getIO(); const io = getIO();

View File

@@ -1,6 +1,8 @@
const Whatsapp = require("../models/Whatsapp"); const Whatsapp = require("../models/Whatsapp");
const { getIO } = require("../libs/socket"); const { getIO } = require("../libs/socket");
const { getWbot } = require("../libs/wbot"); const { getWbot, initWbot, removeWbot } = require("../libs/wbot");
const wbotMessageListener = require("../services/wbotMessageListener");
const wbotMonitor = require("../services/wbotMonitor");
exports.index = async (req, res) => { exports.index = async (req, res) => {
const dbSession = await Whatsapp.findAll(); const dbSession = await Whatsapp.findAll();
@@ -8,6 +10,29 @@ exports.index = async (req, res) => {
return res.status(200).json(dbSession); return res.status(200).json(dbSession);
}; };
exports.store = async (req, res) => {
const io = getIO();
const dbSession = await Whatsapp.create(req.body);
if (!dbSession) {
return res.status(400).json({ error: "Cannot create whatsapp session." });
}
initWbot(dbSession)
.then(() => {
wbotMessageListener(dbSession);
wbotMonitor(dbSession);
})
.catch(err => console.log(err));
io.emit("session", {
action: "update",
session: dbSession,
});
return res.status(200).json({ message: "Session created sucessfully." });
};
exports.show = async (req, res) => { exports.show = async (req, res) => {
const { sessionId } = req.params; const { sessionId } = req.params;
const dbSession = await Whatsapp.findByPk(sessionId); const dbSession = await Whatsapp.findByPk(sessionId);
@@ -20,6 +45,7 @@ exports.show = async (req, res) => {
}; };
exports.update = async (req, res) => { exports.update = async (req, res) => {
const io = getIO();
const { sessionId } = req.params; const { sessionId } = req.params;
const dbSession = await Whatsapp.findByPk(sessionId); const dbSession = await Whatsapp.findByPk(sessionId);
@@ -29,15 +55,37 @@ exports.update = async (req, res) => {
} }
const wbot = getWbot(dbSession.id); const wbot = getWbot(dbSession.id);
const io = getIO(); wbot.logout();
await dbSession.update(req.body); await dbSession.update(req.body);
wbot.logout();
io.emit("session", { io.emit("session", {
action: "update", action: "update",
session: dbSession, session: dbSession,
}); });
return res.status(200).json({ message: "session disconnected" }); return res.status(200).json({ message: "Session updated" });
};
exports.delete = async (req, res) => {
const io = getIO();
const { sessionId } = req.params;
const dbSession = await Whatsapp.findByPk(sessionId);
if (!dbSession) {
return res.status(404).json({ message: "Session not found" });
}
const wbot = getWbot(dbSession.id);
await dbSession.destroy();
removeWbot(dbSession.id);
io.emit("session", {
action: "delete",
sessionId: dbSession.id,
});
return res.status(200).json({ message: "Session deleted." });
}; };

View File

@@ -6,7 +6,8 @@ const { getIO } = require("../libs/socket");
let sessions = []; let sessions = [];
module.exports = { module.exports = {
init: async dbSession => { initWbot: async dbSession => {
try {
const io = getIO(); const io = getIO();
const sessionName = dbSession.name; const sessionName = dbSession.name;
let sessionCfg; let sessionCfg;
@@ -73,22 +74,14 @@ module.exports = {
session: dbSession, session: dbSession,
}); });
// const chats = await wbot.getChats(); // pega as mensagens nao lidas (recebidas quando o bot estava offline)
// let unreadMessages; // todo > salvar isso no DB pra mostrar no frontend
// for (let chat of chats) {
// if (chat.unreadCount > 0) {
// unreadMessages = await chat.fetchMessages({
// limit: chat.unreadCount,
// });
// }
// }
// console.log(unreadMessages);
wbot.sendPresenceAvailable(); wbot.sendPresenceAvailable();
}); });
wbot.id = dbSession.id; wbot.id = dbSession.id;
sessions.push(wbot); sessions.push(wbot);
} catch (err) {
console.log(err);
}
return null; return null;
}, },
@@ -103,4 +96,16 @@ module.exports = {
} }
return sessions[sessionIndex]; return sessions[sessionIndex];
}, },
removeWbot: sessionId => {
try {
const sessionIndex = sessions.findIndex(s => s.id === sessionId);
if (sessionIndex !== -1) {
sessions[sessionIndex].destroy();
sessions.splice(sessionIndex, 1);
}
} catch (err) {
console.log(err);
}
},
}; };

View File

@@ -7,6 +7,8 @@ const routes = express.Router();
routes.get("/whatsapp/session/", isAuth, WhatsAppSessionController.index); routes.get("/whatsapp/session/", isAuth, WhatsAppSessionController.index);
routes.post("/whatsapp/session", isAuth, WhatsAppSessionController.store);
routes.get( routes.get(
"/whatsapp/session/:sessionId", "/whatsapp/session/:sessionId",
isAuth, isAuth,
@@ -19,4 +21,10 @@ routes.put(
WhatsAppSessionController.update WhatsAppSessionController.update
); );
routes.delete(
"/whatsapp/session/:sessionId",
isAuth,
WhatsAppSessionController.delete
);
module.exports = routes; module.exports = routes;

View File

@@ -9,7 +9,7 @@ const Ticket = require("../models/Ticket");
const Message = require("../models/Message"); const Message = require("../models/Message");
const { getIO } = require("../libs/socket"); const { getIO } = require("../libs/socket");
const { getWbot, init } = require("../libs/wbot"); const { getWbot, initWbot } = require("../libs/wbot");
const verifyContact = async (msgContact, profilePicUrl) => { const verifyContact = async (msgContact, profilePicUrl) => {
let contact = await Contact.findOne({ let contact = await Contact.findOne({

View File

@@ -3,7 +3,7 @@ const Sentry = require("@sentry/node");
const wbotMessageListener = require("./wbotMessageListener"); const wbotMessageListener = require("./wbotMessageListener");
const { getIO } = require("../libs/socket"); const { getIO } = require("../libs/socket");
const { getWbot, init } = require("../libs/wbot"); const { getWbot, initWbot } = require("../libs/wbot");
const wbotMonitor = dbSession => { const wbotMonitor = dbSession => {
const io = getIO(); const io = getIO();
@@ -61,7 +61,7 @@ const wbotMonitor = dbSession => {
setTimeout( setTimeout(
() => () =>
init(dbSession) initWbot(dbSession)
.then(() => { .then(() => {
wbotMessageListener(dbSession); wbotMessageListener(dbSession);
wbotMonitor(dbSession); wbotMonitor(dbSession);

View File

@@ -47,6 +47,8 @@ const reducer = (state, action) => {
if (action.type === "DELETE_SESSION") { if (action.type === "DELETE_SESSION") {
const sessionId = action.payload; const sessionId = action.payload;
console.log("cai aqui", sessionId);
const sessionIndex = state.findIndex(s => s.id === sessionId); const sessionIndex = state.findIndex(s => s.id === sessionId);
if (sessionIndex !== -1) { if (sessionIndex !== -1) {
state.splice(sessionIndex, 1); state.splice(sessionIndex, 1);
@@ -123,6 +125,12 @@ const WhatsAuth = () => {
} }
}); });
socket.on("session", data => {
if (data.action === "delete") {
dispatch({ type: "DELETE_SESSION", payload: data.sessionId });
}
});
return () => { return () => {
socket.disconnect(); socket.disconnect();
}; };