main.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132
  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. console.log(`params:${req.params.be}`);
  68. const be = req.params.be;
  69. try {
  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. res.json({ status: '99', be: be, description: 'General error' });
  85. }
  86. });
  87. app.post("/api/send/:be", async (req, res) => {
  88. console.log(`params:${req.params.be}, body:${JSON.stringify(req.body)}`);
  89. const be = req.params.be;
  90. try {
  91. const client = map.get(be);
  92. if (client == null) {
  93. res.json({ status: '01', be: be, description: 'Unauthorize access' });
  94. return;
  95. }
  96. const to = req.body.to;
  97. const message = req.body.message;
  98. if (Object.hasOwn(message, 'media')) {
  99. const fileName = req.body.message.fileName;
  100. const media = req.body.message.media;
  101. const data = req.body.message.data;
  102. const caption = req.body.message.caption;
  103. let messageMedia = new MessageMedia(media, data, fileName);
  104. to.forEach(it => {
  105. client.sendMessage(`${it}@c.us`, messageMedia, { caption: caption });
  106. });
  107. res.json({ status: '00', be: be });
  108. return;
  109. }
  110. to.forEach(it => {
  111. client.sendMessage(`${it}@c.us`, message);
  112. });
  113. res.json({ status: '00', be: be });
  114. } catch (error) {
  115. console.log(`error:${error}`);
  116. res.json({ status: '99', be: be, description: 'General error' });
  117. }
  118. });
  119. const port = process.env.PORT || 9009;
  120. const options = {
  121. key: fs.readFileSync('./server.key'),
  122. cert: fs.readFileSync('./server.crt'),
  123. rejectUnauthorized: false,
  124. requestCert: true,
  125. agent: false
  126. };
  127. https.createServer(options, app).listen(port, () => {
  128. console.log(`Server running on port ${port}`);
  129. });