index.js 8.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307
  1. const Discord = require('discord.js');
  2. const client = new Discord.Client();
  3. const config = require('./config.json');
  4. var mysql = require('mysql');
  5. var urlRegex = /^(ftp|http|https):\/\/[^ "]+$/;
  6. client.on('ready', () => {
  7. if (config.playing !== "") {
  8. client.user.setPresence({ status: 'online', game: { name: config.playing } });
  9. }
  10. console.log(`Logged in as ${client.user.tag}!`);
  11. console.log(`To send missing messages run ${config.prefix}dump [quntity(default and limited to 99)]`);
  12. });
  13. client.on('message', message => {
  14. if (message.author.bot==true) return;
  15. var serverData = undefined;
  16. config.servers.forEach(function(server) {
  17. if (message.channel.id==server.channel) serverData = server;
  18. });
  19. if (serverData==undefined) return;
  20. if (message.content.startsWith(`${config.prefix}dump`)) {
  21. console.log('Warning, dump in progress! May cause slowdows.');
  22. number = message.content.slice(6);
  23. if (number=='') number = 99;
  24. //console.log(number);
  25. message.delete(2);
  26. var channel = message.channel;
  27. async function run() {
  28. var fetched = await channel.fetchMessages({limit: number});
  29. //console.log(fetched);
  30. var connection = mysql.createConnection({
  31. host : serverData.dbHost,
  32. user : serverData.dbUser,
  33. password : serverData.dbPassword,
  34. database : serverData.db
  35. });
  36. var sql = 'SELECT * FROM `'+serverData.dbTable+'`';
  37. connection.connect();
  38. connection.query(sql, function (error, results, fields) {
  39. if (error) throw error;
  40. //console.log('Data recived from db. Result: ', results);
  41. var messages = [];
  42. fetched.forEach(messageNow => {
  43. var found = false;
  44. var edited = true;
  45. results.forEach(function (msg){
  46. if (messageNow.id == msg.id || messageNow.id == message.id ) {
  47. found = true;
  48. }
  49. //console.log('message:' + ((messageNow.editedTimestamp == null) ? "nope" : messageNow.editedTimestamp) + ' db: ' + msg.timeEdit);
  50. if (found == true && (messageNow.editedTimestamp || "") == msg.timeEdit) {
  51. edited = false;
  52. }
  53. });
  54. if (found==true && edited==true) {
  55. messages.push({"message":messageNow, "action":1});
  56. } else if (found==false) {
  57. messages.push({"message":messageNow, "action":0});
  58. }
  59. });
  60. //console.log(messages);
  61. sendLoop(messages, serverData, 1000);
  62. });
  63. connection.end();
  64. }
  65. run();
  66. } else {
  67. sendToDB(message, serverData);
  68. }
  69. });
  70. client.on('messageUpdate', (messageOld, messageNew) => {
  71. if (messageNew.author.bot==true) return;
  72. var serverData = undefined;
  73. config.servers.forEach(function(server) {
  74. if (messageNew.channel.id==server.channel) serverData = server;
  75. });
  76. if (serverData==undefined) return;
  77. var channel = messageNew.channel;
  78. var connection = mysql.createConnection({
  79. host : serverData.dbHost,
  80. user : serverData.dbUser,
  81. password : serverData.dbPassword,
  82. database : serverData.db
  83. });
  84. var sql = 'SELECT * FROM `'+serverData.dbTable+'`';
  85. connection.connect();
  86. connection.query(sql, function (error, results, fields) {
  87. if (error) throw error;
  88. //console.log('Data recived from db. Result: ', results);
  89. var messages = [];
  90. results.forEach(messageNow => {
  91. if (messageNow.id == messageNew.id) {
  92. messages.push({"message":messageNew, "action":1});
  93. }
  94. });
  95. sendLoop(messages, serverData, 1000);
  96. });
  97. connection.end();
  98. });
  99. client.on('messageDelete', message => {
  100. if (message.author.bot==true) return;
  101. var serverData = undefined;
  102. config.servers.forEach(function(server) {
  103. if (message.channel.id==server.channel) serverData = server;
  104. });
  105. if (serverData==undefined) return;
  106. console.log(message);
  107. });
  108. client.login(config.token);
  109. function sendLoop(messages, serverData, delay) {
  110. if (messages.length == 0) {
  111. return;
  112. }
  113. if (messages[0].action == 0) {
  114. sendToDB(messages[0].message, serverData);
  115. } else if (messages[0].action == 1) {
  116. updateDB(messages[0].message, serverData);
  117. }
  118. messages.shift();
  119. setTimeout(sendLoop, delay, messages, serverData, delay);
  120. }
  121. function updateDB(message, serverData) {
  122. var connection = mysql.createConnection({
  123. host : serverData.dbHost,
  124. user : serverData.dbUser,
  125. password : serverData.dbPassword,
  126. database : serverData.db
  127. });
  128. var l = [];
  129. var msgCopy = message.content;
  130. msgCopy.replace(urlRegex, function(url) {
  131. l.push(url);
  132. });
  133. var i = [];
  134. message.attachments.forEach(attachment => {
  135. i.push(attachment.url);
  136. });
  137. var mentions = [];
  138. message.mentions.users.forEach(user => {
  139. mentions.push({"userId": user.id, "username": user.username, "discriminator": user.discriminator});
  140. });
  141. var messageContent = message.content;
  142. for (mention of mentions) {
  143. if(messageContent.includes(mention.userId)) {
  144. if (serverData.mentionsMode == 0) {
  145. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.userId);
  146. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.userId);
  147. } else if (serverData.mentionsMode == 1) {
  148. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username);
  149. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username);
  150. } else {
  151. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  152. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  153. }
  154. }
  155. }
  156. if (serverData.authorMode == 0) {
  157. var author = message.author.id;
  158. } else if (serverData.authorMode == 1) {
  159. var author = message.author.username;
  160. } else {
  161. var author = message.author.tag;
  162. }
  163. var post = {message:messageContent, id:message.id, time:message.createdTimestamp, timeEdit:(message.editedTimestamp || ""), user:author, links:JSON.stringify(l), images:JSON.stringify(i)};
  164. var sql = 'UPDATE '+serverData.dbTable+' SET ? WHERE id='+message.id;
  165. connection.connect();
  166. connection.query(sql, post, function (error, results, fields) {
  167. if (error) throw error;
  168. console.log('Data updated in db. Result: ', results);
  169. });
  170. connection.end();
  171. }
  172. function sendToDB(message, serverData) {
  173. var connection = mysql.createConnection({
  174. host : serverData.dbHost,
  175. user : serverData.dbUser,
  176. password : serverData.dbPassword,
  177. database : serverData.db
  178. });
  179. var l = [];
  180. var msgCopy = message.content;
  181. msgCopy.replace(urlRegex, function(url) {
  182. l.push(url);
  183. });
  184. var i = [];
  185. message.attachments.forEach(attachment => {
  186. i.push(attachment.url);
  187. });
  188. var mentions = [];
  189. message.mentions.users.forEach(user => {
  190. mentions.push({"userId": user.id, "username": user.username, "discriminator": user.discriminator});
  191. });
  192. var messageContent = message.content;
  193. for (mention of mentions) {
  194. if(messageContent.includes(mention.userId)) {
  195. if (serverData.mentionsMode == 0) {
  196. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.userId);
  197. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.userId);
  198. } else if (serverData.mentionsMode == 1) {
  199. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username);
  200. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username);
  201. } else {
  202. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  203. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  204. }
  205. }
  206. }
  207. if (serverData.authorMode == 0) {
  208. var author = message.author.id;
  209. } else if (serverData.authorMode == 1) {
  210. var author = message.author.username;
  211. } else {
  212. var author = message.author.tag;
  213. }
  214. var post = {message:messageContent, id:message.id, time:message.createdTimestamp, timeEdit:(message.editedTimestamp || ""), user:author, links:JSON.stringify(l), images:JSON.stringify(i)};
  215. var sql = 'INSERT INTO '+serverData.dbTable+' SET ?';
  216. connection.connect();
  217. connection.query(sql, post, function (error, results, fields) {
  218. if (error) throw error;
  219. console.log('Data sent to db. Result: ', results);
  220. });
  221. connection.end();
  222. }