index.js 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  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.login(config.token);
  100. function sendLoop(messages, serverData, delay) {
  101. if (messages.length == 0) {
  102. return;
  103. }
  104. if (messages[0].action == 0) {
  105. sendToDB(messages[0].message, serverData);
  106. } else if (messages[0].action == 1) {
  107. updateDB(messages[0].message, serverData);
  108. }
  109. messages.shift();
  110. setTimeout(sendLoop, delay, messages, serverData, delay);
  111. }
  112. function updateDB(message, serverData) {
  113. var connection = mysql.createConnection({
  114. host : serverData.dbHost,
  115. user : serverData.dbUser,
  116. password : serverData.dbPassword,
  117. database : serverData.db
  118. });
  119. var l = [];
  120. var msgCopy = message.content;
  121. msgCopy.replace(urlRegex, function(url) {
  122. l.push(url);
  123. });
  124. var i = [];
  125. message.attachments.forEach(attachment => {
  126. i.push(attachment.url);
  127. });
  128. var mentions = [];
  129. message.mentions.users.forEach(user => {
  130. mentions.push({"userId": user.id, "username": user.username, "discriminator": user.discriminator});
  131. });
  132. var messageContent = message.content;
  133. for (mention of mentions) {
  134. if(messageContent.includes(mention.userId)) {
  135. if (serverData.mentionsMode == 0) {
  136. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.userId);
  137. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.userId);
  138. } else if (serverData.mentionsMode == 1) {
  139. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username);
  140. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username);
  141. } else {
  142. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  143. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  144. }
  145. }
  146. }
  147. if (serverData.authorMode == 0) {
  148. var author = message.author.id;
  149. } else if (serverData.authorMode == 1) {
  150. var author = message.author.username;
  151. } else {
  152. var author = message.author.tag;
  153. }
  154. var post = {message:messageContent, id:message.id, time:message.createdTimestamp, timeEdit:(message.editedTimestamp || ""), user:author, links:JSON.stringify(l), images:JSON.stringify(i)};
  155. var sql = 'UPDATE '+serverData.dbTable+' SET ? WHERE id='+message.id;
  156. connection.connect();
  157. connection.query(sql, post, function (error, results, fields) {
  158. if (error) throw error;
  159. console.log('Data updated in db. Result: ', results);
  160. });
  161. connection.end();
  162. }
  163. function sendToDB(message, serverData) {
  164. var connection = mysql.createConnection({
  165. host : serverData.dbHost,
  166. user : serverData.dbUser,
  167. password : serverData.dbPassword,
  168. database : serverData.db
  169. });
  170. var l = [];
  171. var msgCopy = message.content;
  172. msgCopy.replace(urlRegex, function(url) {
  173. l.push(url);
  174. });
  175. var i = [];
  176. message.attachments.forEach(attachment => {
  177. i.push(attachment.url);
  178. });
  179. var mentions = [];
  180. message.mentions.users.forEach(user => {
  181. mentions.push({"userId": user.id, "username": user.username, "discriminator": user.discriminator});
  182. });
  183. var messageContent = message.content;
  184. for (mention of mentions) {
  185. if(messageContent.includes(mention.userId)) {
  186. if (serverData.mentionsMode == 0) {
  187. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.userId);
  188. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.userId);
  189. } else if (serverData.mentionsMode == 1) {
  190. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username);
  191. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username);
  192. } else {
  193. messageContent = messageContent.replace(new RegExp("<@"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  194. messageContent = messageContent.replace(new RegExp("<@!"+mention.userId+">", 'g'), "@"+mention.username+"#"+mention.discriminator);
  195. }
  196. }
  197. }
  198. if (serverData.authorMode == 0) {
  199. var author = message.author.id;
  200. } else if (serverData.authorMode == 1) {
  201. var author = message.author.username;
  202. } else {
  203. var author = message.author.tag;
  204. }
  205. var post = {message:messageContent, id:message.id, time:message.createdTimestamp, timeEdit:(message.editedTimestamp || ""), user:author, links:JSON.stringify(l), images:JSON.stringify(i)};
  206. var sql = 'INSERT INTO '+serverData.dbTable+' SET ?';
  207. connection.connect();
  208. connection.query(sql, post, function (error, results, fields) {
  209. if (error) throw error;
  210. console.log('Data sent to db. Result: ', results);
  211. });
  212. connection.end();
  213. }