main.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. const { WhasAppClient } = require('./whatsapp-client.js');
  2. const { MessageMedia } = require('whatsapp-web.js');
  3. const express = require('express');
  4. // const qrcode = require('qrcode-terminal');
  5. const axios = require('axios');
  6. const https = require('https');
  7. const fs = require('fs');
  8. const map = new Map();
  9. const duplicateMap = new Map();
  10. function createWa(be, res) {
  11. const wa = new WhasAppClient(be);
  12. wa.client.on('qr', async qr => {
  13. console.log(`be:${wa.clientId}:qr:${qr}`);
  14. // if (res == null) {
  15. // try {
  16. // await wa.client.destroy();
  17. // fs.rm(`.wwebjs_auth/session-${wa.clientId}`, { recursive: true, force: true }, (error) => {
  18. // });
  19. // } catch (error) {
  20. // console.log(error);
  21. // }
  22. // return;
  23. // }
  24. if (!wa.isGenerateQr) {
  25. if (res != null) res.json({ status: '00', be: wa.clientId, qr: qr });
  26. }
  27. wa.isGenerateQr = true;
  28. // generate qr terminal
  29. // qrcode.generate(qr, { small: true });
  30. // kirim ke abi untuk update qr
  31. axios.post('https://nexilis.io/dashboardv2/logics/insert_whatsapp_qrcode', {
  32. be: wa.clientId,
  33. qrcode: qr
  34. })
  35. .then(function (response) {
  36. console.log(`response: ${response.data}`);
  37. })
  38. .catch(function (error) {
  39. console.log(error);
  40. });
  41. });
  42. wa.client.on('ready', () => {
  43. console.log(`be:${wa.clientId}:Client is ready!`);
  44. map.set(wa.clientId, wa.client);
  45. if (!wa.isGenerateQr) {
  46. if (res != null) res.json({ status: '00', be: wa.clientId });
  47. }
  48. });
  49. wa.client.on('disconnected', async (reason) => {
  50. console.log(`be:${wa.clientId}:Client was logged out`, reason);
  51. await wa.client.destroy();
  52. map.delete(wa.clientId);
  53. });
  54. }
  55. fs.readdir('.wwebjs_auth', (err, files) => {
  56. if (files != null) {
  57. files.forEach(file => {
  58. console.log(`Read session: ${file}`);
  59. const be = file.split('-')[1];
  60. createWa(be);
  61. });
  62. }
  63. });
  64. const app = express();
  65. app.use(express.json({ limit: '50mb' }));
  66. app.get("/api/qr/:be", (req, res) => {
  67. try {
  68. console.log(`params:${req.params.be}`);
  69. const be = req.params.be;
  70. const client = map.get(be);
  71. if (client != null) {
  72. res.json({ status: '00', be: be });
  73. return;
  74. }
  75. const duplicate = duplicateMap.get(be);
  76. if (duplicate != null) {
  77. res.json({ status: '02', be: be, description: 'Duplicate request' });
  78. return;
  79. }
  80. duplicateMap.set(be, be);
  81. createWa(be, res);
  82. } catch (error) {
  83. console.log(`error:${error}`);
  84. }
  85. });
  86. app.post("/api/send/:be", async (req, res) => {
  87. try {
  88. console.log(`params:${req.params.be}, body:${JSON.stringify(req.body)}`);
  89. const be = req.params.be;
  90. const client = map.get(be);
  91. if (client == null) {
  92. res.json({ status: '01', be: be, description: 'Unauthorize access' });
  93. return;
  94. }
  95. const to = req.body.to;
  96. const message = req.body.message;
  97. if (Object.hasOwn(message, 'media')) {
  98. const fileName = req.body.message.fileName;
  99. const media = req.body.message.media;
  100. const data = req.body.message.data;
  101. const caption = req.body.message.caption;
  102. let messageMedia = new MessageMedia(media, data, fileName);
  103. to.forEach( it => {
  104. client.sendMessage(`${it}@c.us`, messageMedia, { caption: caption });
  105. });
  106. res.json({ status: '00', be: be });
  107. return;
  108. }
  109. to.forEach( it => {
  110. client.sendMessage(`${it}@c.us`, messageMedia, { caption: caption });
  111. });
  112. res.json({ status: '00', be: be });
  113. } catch (error) {
  114. console.log(`error:${error}`);
  115. }
  116. });
  117. const port = process.env.PORT || 9009;
  118. const options = {
  119. key: fs.readFileSync('./server.key'),
  120. cert: fs.readFileSync('./server.crt'),
  121. rejectUnauthorized: false,
  122. requestCert: true,
  123. agent: false
  124. };
  125. https.createServer(options, app).listen(port, () => {
  126. console.log(`Server running on port ${port}`);
  127. });