main.js 4.0 KB

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