main.js 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738
  1. const fs = require('fs');
  2. const Discord = require('discord.js');
  3. var request = require('request');
  4. request = request.defaults({jar: true});
  5. var client = new Discord.Client( {disableEveryone:true} );
  6. var i18n = JSON.parse(fs.readFileSync('i18n.json', 'utf8'));
  7. var pause = {};
  8. var defaultSettings = {
  9. "default": {
  10. "lang": "en",
  11. "wiki": "help"
  12. }
  13. }
  14. var settings = defaultSettings;
  15. function getSettings(callback) {
  16. request( {
  17. uri: process.env.site + process.env.page + '?action=raw&ctype=javascript',
  18. json: true
  19. }, function( error, response, body ) {
  20. if ( error || !response || !body ) {
  21. console.log( 'Fehler beim Erhalten der Einstellungen' + ( error ? ': ' + error.message : '.' ) );
  22. }
  23. else {
  24. console.log( 'Einstellungen erfolgreich ausgelesen' );
  25. settings = body;
  26. }
  27. callback();
  28. } );
  29. }
  30. function setStatus() {
  31. if ( settings == defaultSettings ) client.user.setStatus('invisible');
  32. else client.user.setStatus('online');
  33. }
  34. client.on('ready', () => {
  35. getSettings(setStatus);
  36. console.log( 'Erfolgreich als ' + client.user.username + ' angemeldet!' );
  37. client.user.setActivity( process.env.prefix + 'help' );
  38. } );
  39. var cmdmap = {
  40. help: cmd_help,
  41. test: cmd_test,
  42. invite: cmd_invite,
  43. stop: cmd_stop,
  44. pause: cmd_pause,
  45. server: cmd_serverlist,
  46. say: cmd_multiline,
  47. delete: cmd_multiline,
  48. purge: cmd_multiline,
  49. poll: cmd_multiline,
  50. message: cmd_multiline,
  51. voice: cmd_voice,
  52. settings: cmd_settings,
  53. info: cmd_info
  54. }
  55. var multilinecmdmap = {
  56. say: cmd_say,
  57. delete: cmd_delete,
  58. poll: cmd_umfrage,
  59. message: cmd_message
  60. }
  61. var pausecmdmap = {
  62. test: cmd_test,
  63. stop: cmd_stop,
  64. pause: cmd_pause,
  65. server: cmd_serverlist,
  66. say: cmd_multiline,
  67. delete: cmd_multiline,
  68. message: cmd_multiline
  69. }
  70. function cmd_settings(lang, msg, args, line) {
  71. if ( admin(msg) ) {
  72. if ( msg.guild.id in settings ) var text = lang.settings.current + '\n`' + process.env.prefix + 'settings lang` – ' + settings[msg.guild.id].lang + '\n`' + process.env.prefix + 'settings wiki` – ' + settings[msg.guild.id].wiki;
  73. else var text = lang.settings.missing.replace( '%1$s', '`' + process.env.prefix + 'settings lang`' ).replace( '%2$s', '`' + process.env.prefix + 'settings wiki`' );
  74. if ( args.length ) {
  75. if ( args[0] ) args[0] = args[0].toLowerCase();
  76. if ( args[1] ) args[1] = args[1].toLowerCase();
  77. var langs = '\n' + lang.settings.langs + ' `' + Object.keys(i18n) + '`';
  78. var wikis = '\n' + lang.settings.wikis;
  79. var nolangs = lang.settings.nolangs + langs;
  80. if ( msg.guild.id in settings ) {
  81. if ( args[0] == 'lang' ) {
  82. if ( args[1] ) {
  83. if ( args[1] in i18n ) edit_settings(lang, msg, 'lang', args[1]);
  84. else msg.reply( nolangs );
  85. } else msg.reply( lang.settings.lang + ' `' + settings[msg.guild.id].lang + '`' + langs );
  86. } else if ( args[0] == 'wiki' ) {
  87. if ( args[1] ) edit_settings(lang, msg, 'wiki', args[1]);
  88. else msg.reply( lang.settings.wiki + '\nhttps://' + settings[msg.guild.id].wiki + '.gamepedia.com/' + wikis );
  89. } else msg.reply( text );
  90. } else {
  91. if ( args[0] == 'lang' ) {
  92. if ( args[1] ) {
  93. if ( args[1] in i18n ) edit_settings(lang, msg, 'lang', args[1]);
  94. else msg.reply( nolangs );
  95. } else msg.reply( lang.settings.nolang + langs );
  96. } else if ( args[0] == 'wiki' ) {
  97. if ( args[1] ) edit_settings(lang, msg, 'wiki', args[1]);
  98. else msg.reply( lang.settings.nowiki + wikis );
  99. } else msg.reply( text );
  100. }
  101. } else msg.reply( text );
  102. } else {
  103. msg.react('❌');
  104. }
  105. }
  106. function edit_settings(lang, msg, key, value) {
  107. var hourglass;
  108. msg.react('⏳').then( function( reaction ) {
  109. hourglass = reaction;
  110. var url = process.env.site + 'api.php';
  111. request.get( {
  112. uri: url + '?action=query&format=json&meta=tokens&type=login',
  113. json: true
  114. }, function( error, response, body ) {
  115. if ( error || !response || !body || body.error ) {
  116. console.log( 'Fehler beim Erhalten des Anmeldetoken' + ( error ? ': ' + error.message : ( body ? ': ' + body.error.info : '.' ) ) );
  117. msg.reply( lang.settings.save_failed );
  118. }
  119. else {
  120. request.post( {
  121. uri: url,
  122. form: {
  123. action: 'login',
  124. format: 'json',
  125. lgname: process.env.username,
  126. lgpassword: process.env.password,
  127. lgtoken: body.query.tokens.logintoken
  128. },
  129. json: true
  130. }, function( lerror, lresponse, lbody ) {
  131. if ( lerror || !lresponse || !lbody || lbody.error ) {
  132. console.log( 'Fehler beim Anmelden' + ( lerror ? ': ' + lerror.message : ( lbody ? ': ' + lbody.error.info : '.' ) ) );
  133. msg.reply( lang.settings.save_failed );
  134. }
  135. else {
  136. request.post( {
  137. uri: url,
  138. form: {
  139. action: 'query',
  140. format: 'json',
  141. meta: 'tokens',
  142. type: 'csrf'
  143. },
  144. json: true
  145. }, function( perror, presponse, pbody ) {
  146. if ( perror || !presponse || !pbody || pbody.error ) {
  147. console.log( 'Fehler beim Erhalten des Bearbeitungstoken' + ( perror ? ': ' + perror.message : ( pbody ? ': ' + pbody.error.info : '.' ) ) );
  148. msg.reply( lang.settings.save_failed );
  149. }
  150. else {
  151. var temp_settings = settings;
  152. if ( !( msg.guild.id in temp_settings ) ) temp_settings[msg.guild.id] = defaultSettings['default'];
  153. temp_settings[msg.guild.id][key] = value;
  154. request.post( {
  155. uri: url,
  156. form: {
  157. action: 'edit',
  158. format: 'json',
  159. title: process.env.page,
  160. text: JSON.stringify( temp_settings, null, '\t' ),
  161. summary: 'Einstellungen aktualisiert.',
  162. bot: true,
  163. token: pbody.query.tokens.csrftoken
  164. },
  165. json: true
  166. }, function( eerror, eresponse, ebody ) {
  167. if ( eerror || !eresponse || !ebody || ebody.error ) {
  168. console.log( 'Fehler beim Bearbeiten' + ( eerror ? ': ' + eerror.message : ( ebody ? ': ' + ebody.error.info : '.' ) ) );
  169. msg.reply( lang.settings.save_failed );
  170. }
  171. else {
  172. if ( settings == defaultSettings ) {
  173. msg.reply( lang.settings.save_failed );
  174. } else {
  175. settings = temp_settings;
  176. if ( key == 'lang' ) lang = i18n[value];
  177. cmd_settings(lang, msg, [key], '')
  178. console.log( 'Einstellungen erfolgreich aktualisiert.' );
  179. }
  180. }
  181. } );
  182. }
  183. } );
  184. }
  185. } );
  186. }
  187. if ( hourglass != undefined ) hourglass.remove();
  188. } );
  189. } );
  190. }
  191. function cmd_info(lang, msg, args, line) {
  192. if ( args.length ) cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  193. else msg.channel.send( lang.disclaimer + '\n<@' + process.env.owner + '> <https://help.gamepedia.com/User_talk:MarkusRost?action=edit&preloadtitle=Wiki-Bot&section=new>' );
  194. }
  195. function cmd_help(lang, msg, args, line) {
  196. if ( admin(msg) && !( msg.guild.id in settings ) ) cmd_settings(lang, msg, [], line);
  197. var cmds = lang.help.list;
  198. if ( args.length ) {
  199. if ( args[0].toLowerCase() == 'admin' && ( msg.channel.type != 'text' || admin(msg) ) ) {
  200. if ( args[1] && args[1].toLowerCase() == 'emoji' ) {
  201. var cmdlist = lang.help.emoji + '\n';
  202. var emojis = client.emojis;
  203. var i = 0;
  204. emojis.forEach( function(emoji) {
  205. var br = '\t\t';
  206. if ( i % 3 == 2 ) br = '\n';
  207. cmdlist += emoji.toString() + '`' + emoji.toString().replace(emoji.name + ':', '') + '`' + br;
  208. i++;
  209. } );
  210. msg.channel.send( cmdlist, {split:true} );
  211. }
  212. else {
  213. var cmdlist = lang.help.admin + '\n';
  214. for ( var i = 0; i < cmds.length; i++ ) {
  215. if ( cmds[i].admin && !cmds[i].hide ) {
  216. cmdlist += '🔹 `' + process.env.prefix + cmds[i].cmd + '`\n\t' + cmds[i].desc + '\n';
  217. }
  218. }
  219. msg.channel.send( cmdlist );
  220. }
  221. }
  222. else {
  223. var cmdlist = ''
  224. for ( var i = 0; i < cmds.length; i++ ) {
  225. if ( cmds[i].cmd.split(' ')[0] === args[0].toLowerCase() && !cmds[i].unsearchable && ( msg.channel.type != 'text' || !cmds[i].admin || admin(msg) ) ) {
  226. cmdlist += '🔹 `' + process.env.prefix + cmds[i].cmd + '`\n\t' + cmds[i].desc + '\n';
  227. }
  228. }
  229. if ( cmdlist == '' ) msg.react('❓');
  230. else msg.channel.send( cmdlist );
  231. }
  232. }
  233. else {
  234. var cmdlist = lang.help.all + '\n';
  235. for ( var i = 0; i < cmds.length; i++ ) {
  236. if ( !cmds[i].hide && !cmds[i].admin ) {
  237. cmdlist += '🔹 `' + process.env.prefix + cmds[i].cmd + '`\n\t' + cmds[i].desc + '\n';
  238. }
  239. }
  240. msg.channel.send( cmdlist );
  241. }
  242. }
  243. function cmd_say(lang, msg, args, line) {
  244. if ( admin(msg) ) {
  245. args = emoji(args);
  246. var text = args.join(' ');
  247. if ( args[0] == 'alarm' ) text = '🚨 **' + args.slice(1).join(' ') + '** 🚨';
  248. var imgs = [];
  249. var i = 0;
  250. msg.attachments.forEach( function(img) {
  251. imgs[i] = {attachment:img.proxyURL,name:img.filename};
  252. i++;
  253. } );
  254. if ( text || imgs[0] ) {
  255. msg.channel.send( text, {disableEveryone:false,files:imgs} ).then( message => msg.delete(), error => msg.react('440871715938238494') );
  256. }
  257. } else {
  258. msg.react('❌');
  259. }
  260. }
  261. function cmd_test(lang, msg, args, line) {
  262. if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  263. var text = '';
  264. var x = Math.floor(Math.random() * lang.test.random);
  265. if ( x < lang.test.text.length ) text = lang.test.text[x];
  266. else text = lang.test.default;
  267. msg.reply( text );
  268. console.log( 'Dies ist ein Test: Voll funktionsfähig!' );
  269. } else {
  270. msg.reply( lang.test.pause );
  271. console.log( 'Dies ist ein Test: Pausiert!' );
  272. }
  273. }
  274. function cmd_invite(lang, msg, args, line) {
  275. if ( args.length && args[0].toLowerCase() == '<@' + client.user.id + '>' ) {
  276. client.generateInvite(268954689).then( invite => msg.reply( lang.invite.bot + '\n<' + invite + '>' ) );
  277. } else {
  278. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  279. }
  280. }
  281. function cmd_stop(lang, msg, args, line) {
  282. if ( msg.author.id == process.env.owner && args[0] == '<@' + client.user.id + '>' ) {
  283. msg.reply( 'ich schalte mich nun aus!' );
  284. console.log( 'Ich schalte mich nun aus!' );
  285. client.destroy();
  286. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  287. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  288. }
  289. }
  290. function cmd_pause(lang, msg, args, line) {
  291. if ( msg.channel.type == 'text' && msg.author.id == process.env.owner && args[0] == '<@' + client.user.id + '>' ) {
  292. if ( pause[msg.guild.id] ) {
  293. msg.reply( 'ich bin wieder wach!' );
  294. console.log( 'Ich bin wieder wach!' );
  295. pause[msg.guild.id] = false;
  296. } else {
  297. msg.reply( 'ich lege mich nun schlafen!' );
  298. console.log( 'Ich lege mich nun schlafen!' );
  299. pause[msg.guild.id] = true;
  300. }
  301. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  302. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  303. }
  304. }
  305. function cmd_delete(lang, msg, args, line) {
  306. if ( admin(msg) ) {
  307. if ( /^\d+$/.test(args[0]) && parseInt(args[0], 10) + 1 > 0 ) {
  308. if ( parseInt(args[0], 10) > 99 ) {
  309. msg.reply( lang.delete.big.replace( '%s', '`99`' ) );
  310. }
  311. else {
  312. msg.channel.bulkDelete(parseInt(args[0], 10) + 1, true);
  313. msg.reply( lang.delete.success.replace( '%s', args[0] ) ).then( antwort => antwort.delete(3000) );
  314. console.log( 'Die letzten ' + args[0] + ' Nachrichten in #' + msg.channel.name + ' wurden gelöscht!' );
  315. }
  316. }
  317. else {
  318. msg.reply( lang.delete.invalid );
  319. }
  320. } else {
  321. msg.react('❌');
  322. }
  323. }
  324. function cmd_link(lang, msg, title, wiki, cmd) {
  325. var invoke = title.split(' ')[0].toLowerCase();
  326. var args = title.split(' ').slice(1);
  327. if ( invoke == 'page' || invoke == lang.search.page ) msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + args.join('_') );
  328. else if ( invoke == 'search' || invoke == lang.search.search ) msg.channel.send( 'https://' + wiki + '.gamepedia.com/Special:Search/' + args.join('_') );
  329. else if ( invoke == 'diff' ) cmd_diff(lang, msg, args, wiki);
  330. else if ( title == '' || title.indexOf( '#' ) != -1 || title.indexOf( '?' ) != -1 ) msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title.replace( / /g, '_' ) );
  331. else if ( invoke == 'user' || invoke == lang.search.user.unknown || invoke == lang.search.user.male || invoke == lang.search.user.female ) cmd_user(lang, msg, args.join('_'), wiki, title.replace( / /g, '_' ));
  332. else if ( invoke.startsWith('user:') ) cmd_user(lang, msg, title.substr(5), wiki, title.replace( / /g, '_' ));
  333. else if ( invoke.startsWith('userprofile:') ) cmd_user(lang, msg, title.substr(12), wiki, title.replace( / /g, '_' ));
  334. else if ( invoke.startsWith(lang.search.user.unknown + ':') ) cmd_user(lang, msg, title.substr(lang.search.user.unknown.length + 1), wiki, title.replace( / /g, '_' ));
  335. else if ( invoke.startsWith(lang.search.user.male + ':') ) cmd_user(lang, msg, title.substr(lang.search.user.male.length + 1), wiki, title.replace( / /g, '_' ));
  336. else if ( invoke.startsWith(lang.search.user.female + ':') ) cmd_user(lang, msg, title.substr(lang.search.user.female.length + 1), wiki, title.replace( / /g, '_' ));
  337. else {
  338. var hourglass;
  339. msg.react('⏳').then( function( reaction ) {
  340. hourglass = reaction;
  341. request( {
  342. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&meta=siteinfo&siprop=interwikimap&redirects=true&titles=' + title,
  343. json: true
  344. }, function( error, response, body ) {
  345. if ( error || !response || !body || body.error ) {
  346. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( error ? ': ' + error.message : ( body ? ': ' + body.error.info : '.' ) ) );
  347. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title.replace( / /g, '_' ) ).then( message => message.react('440871715938238494') );
  348. }
  349. else {
  350. if ( body.query.pages ) {
  351. if ( body.query.pages['-1'] && body.query.pages['-1'].missing != undefined ) {
  352. request( {
  353. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&list=search&srnamespace=0|4|6|10|12|14&srsearch=' + title + '&srlimit=1',
  354. json: true
  355. }, function( srerror, srresponse, srbody ) {
  356. if ( srerror || !srresponse || !srbody || !srbody.query || ( !srbody.query.search[0] && srbody.query.searchinfo.totalhits != 0 ) ) {
  357. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( srerror ? ': ' + srerror.message : ( srbody ? ( srbody.error ? ': ' + srbody.error.info : '.' ) : '.' ) ) );
  358. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title.replace( / /g, '_' ) ).then( message => message.react('440871715938238494') );
  359. }
  360. else {
  361. if ( srbody.query.searchinfo.totalhits == 0 ) {
  362. msg.react('🤷');
  363. }
  364. else if ( srbody.query.searchinfo.totalhits == 1 ) {
  365. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + encodeURI( srbody.query.search[0].title.replace( / /g, '_' ) ) );
  366. }
  367. else {
  368. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + encodeURI( srbody.query.search[0].title.replace( / /g, '_' ) ) + '\n' + lang.search.info.replace( '%1$s', '`' + process.env.prefix + cmd + lang.search.search + ' ' + title + '`' ).replace( '%2$s', '`' + process.env.prefix + cmd + lang.search.page + ' ' + title + '`' ) );
  369. }
  370. }
  371. } );
  372. }
  373. else {
  374. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + encodeURI( Object.values(body.query.pages)[0].title.replace( / /g, '_' ) + ( body.query.redirects && body.query.redirects[0].tofragment ? '#' + body.query.redirects[0].tofragment : '' ) ) );
  375. }
  376. }
  377. else if ( body.query.interwiki ) {
  378. var inter = body.query.interwiki[0];
  379. var intertitle = inter.title.substr(inter.iw.length+1);
  380. var regex = /^(?:https?:)?\/\/(.*)\.gamepedia\.com\//
  381. var entry = body.query.interwikimap;
  382. for ( var i = 0; i < entry.length; i++ ) {
  383. if ( entry[i].prefix == inter.iw ) {
  384. if ( regex.test(entry[i].url) ) {
  385. var iwtitle = entry[i].url.replace( '$1', intertitle ).replace( regex.exec(entry[i].url)[0], '' );
  386. var link = regex.exec(entry[i].url)[1];
  387. cmd_link(lang, msg, iwtitle, link, '!' + link + ' ');
  388. }
  389. else msg.channel.send( entry[i].url.replace( '$1', encodeURI( intertitle.replace( / /g, '_' ) ) ) );
  390. break;
  391. }
  392. }
  393. }
  394. else {
  395. msg.react('🤷');
  396. }
  397. }
  398. if ( hourglass != undefined ) hourglass.remove();
  399. } );
  400. } );
  401. }
  402. }
  403. function cmd_serverlist(lang, msg, args, line) {
  404. if ( msg.author.id == process.env.owner && args.join(' ') == 'list all <@' + client.user.id + '>' ) {
  405. var guilds = client.guilds;
  406. var serverlist = 'Ich befinde mich aktuell auf ' + guilds.size + ' Servern:\n\n';
  407. guilds.forEach( function(guild) {
  408. serverlist += '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find('type', 'text').toString() + ' (' + guild.id + ')\n\n';
  409. } );
  410. msg.author.send( serverlist, {split:{char:'\n\n'}} );
  411. } else if ( msg.author.id == process.env.owner && args.join(' ') == 'list all <@' + client.user.id + '> permissions' ) {
  412. var guilds = client.guilds;
  413. var serverlist = 'Ich befinde mich aktuell auf ' + guilds.size + ' Servern:\n\n';
  414. guilds.forEach( function(guild) {
  415. var perms = ' ';
  416. var allperms = Object.entries(guild.me.permissions.serialize());
  417. allperms.forEach( function(perm) {
  418. if ( perm[1] ) perms += perm[0] + ', ';
  419. } );
  420. perms = perms.substr(0, perms.length -2);
  421. serverlist += '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find('type', 'text').toString() + perms + '\n\n';
  422. } );
  423. msg.author.send( serverlist, {split:{char:'\n\n'}} );
  424. } else if ( msg.author.id == process.env.owner && args.join(' ') == 'list all <@' + client.user.id + '> members' ) {
  425. var guilds = client.guilds;
  426. var serverlist = 'Ich befinde mich aktuell auf ' + guilds.size + ' Servern:\n\n';
  427. guilds.forEach( function(guild) {
  428. var members = ' ';
  429. var allmembers = guild.members;
  430. if ( !allmembers.has(process.env.owner) && guild.memberCount < 50 ) {
  431. allmembers.forEach( function(member) {
  432. members += member.toString() + ', ';
  433. } );
  434. }
  435. members = members.substr(0, members.length -2);
  436. serverlist += '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find('type', 'text').toString() + members + '\n\n';
  437. } );
  438. msg.author.send( serverlist, {split:{char:'\n\n'}} );
  439. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  440. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  441. }
  442. }
  443. function cmd_umfrage(lang, msg, args, line) {
  444. if ( admin(msg) ) {
  445. var imgs = [];
  446. var a = 0;
  447. msg.attachments.forEach( function(img) {
  448. imgs[a] = {attachment:img.proxyURL,name:img.filename};
  449. a++;
  450. } );
  451. if ( args.length || imgs[0] ) {
  452. var reactions = [];
  453. args = emoji(args);
  454. for ( var i = 0; ( i < args.length || imgs[0] ); i++ ) {
  455. var reaction = args[i];
  456. var custom = /^<a?:/;
  457. var pattern = /^[\w\säÄöÖüÜßẞ!"#$%&'()*+,./:;<=>?@^`{|}~–[\]\-\\]{2,}/;
  458. if ( !custom.test(reaction) && pattern.test(reaction) ) {
  459. cmd_sendumfrage(lang, msg, args, reactions, imgs, i);
  460. break;
  461. } else if ( reaction == '' ) {
  462. } else {
  463. if ( custom.test(reaction) ) {
  464. reaction = reaction.substring(reaction.lastIndexOf(':')+1, reaction.length-1);
  465. }
  466. reactions[i] = reaction;
  467. if ( i == args.length-1 ) {
  468. cmd_sendumfrage(lang, msg, args, reactions, imgs, i+1);
  469. break;
  470. }
  471. }
  472. }
  473. } else {
  474. args[0] = line.split(' ')[1];
  475. cmd_help(lang, msg, args, line);
  476. }
  477. } else {
  478. msg.react('❌');
  479. }
  480. }
  481. function cmd_sendumfrage(lang, msg, args, reactions, imgs, i) {
  482. msg.channel.send( lang.poll.title + args.slice(i).join(' '), {disableEveryone:false,files:imgs} ).then( poll => {
  483. msg.delete();
  484. if ( reactions.length ) {
  485. reactions.forEach( function(entry) {
  486. poll.react(entry).catch( error => poll.react('440871715938238494') );
  487. } );
  488. } else {
  489. poll.react('448222377009086465');
  490. poll.react('448222455425794059');
  491. }
  492. }, error => msg.react('440871715938238494') );
  493. }
  494. function cmd_user(lang, msg, username, wiki, title) {
  495. if ( !username || username.indexOf( '/' ) != -1 || username.toLowerCase().startsWith('talk:') || username.toLowerCase().startsWith(lang.user.talk) ) {
  496. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title );
  497. } else {
  498. var hourglass;
  499. msg.react('⏳').then( function( reaction ) {
  500. hourglass = reaction;
  501. request( {
  502. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&list=users&usprop=blockinfo|groups|editcount|registration|gender&ususers=' + username,
  503. json: true
  504. }, function( error, response, body ) {
  505. if ( error || !response || !body || !body.query || !body.query.users[0] ) {
  506. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( error ? ': ' + error.message : ( body ? ( body.error ? ': ' + body.error.info : '.' ) : '.' ) ) );
  507. msg.channel.send( '<https://' + wiki + '.gamepedia.com/User:' + username + '>' ).then( message => message.react('440871715938238494') );
  508. }
  509. else {
  510. if ( body.query.users[0].missing == "" || body.query.users[0].invalid == "" ) {
  511. msg.react('🤷');
  512. }
  513. else {
  514. username = body.query.users[0].name.replace( / /g, '_' );
  515. var options = {
  516. year: "numeric",
  517. month: "short",
  518. day: "numeric",
  519. hour: "2-digit",
  520. minute: "2-digit"
  521. }
  522. var gender = body.query.users[0].gender;
  523. switch (gender) {
  524. case 'male':
  525. gender = lang.user.gender.male;
  526. break;
  527. case 'female':
  528. gender = lang.user.gender.female;
  529. break;
  530. default:
  531. gender = lang.user.gender.unknown;
  532. }
  533. var registration = (new Date(body.query.users[0].registration)).toLocaleString(lang.user.dateformat, options);
  534. var editcount = body.query.users[0].editcount;
  535. var groups = body.query.users[0].groups;
  536. var group = '';
  537. for ( var i = 0; i < lang.user.group.length; i++ ) {
  538. if ( groups.includes(lang.user.group[i][0]) ) {
  539. group = lang.user.group[i][1];
  540. break;
  541. }
  542. }
  543. var blockid = body.query.users[0].blockid;
  544. var blockedtimestamp = (new Date(body.query.users[0].blockedtimestamp)).toLocaleString(lang.user.dateformat, options);
  545. var blockexpiry = body.query.users[0].blockexpiry;
  546. if ( blockexpiry == 'infinity' ) {
  547. blockexpiry = lang.user.until_infinity;
  548. } else if ( blockexpiry ) {
  549. blockexpiry = (new Date(blockexpiry.replace(/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2,3})/, '$1-$2-$3T$4:$5:$6Z'))).toLocaleString(lang.user.dateformat, options);
  550. }
  551. var blockedby = body.query.users[0].blockedby;
  552. var blockreason = body.query.users[0].blockreason;
  553. msg.channel.send( '<https://' + wiki + '.gamepedia.com/UserProfile:' + username + '>\n\n' + lang.user.info.replace( '%1$s', gender ).replace( '%2$s', registration ).replace( '%3$s', editcount ).replace( '%4$s', group ) + ( blockid ? '\n\n' + lang.user.blocked.replace( '%1$s', blockedtimestamp ).replace( '%2$s', blockexpiry ).replace( '%3$s', blockedby ).replace( '%4$s', blockreason ) : '' ) );
  554. }
  555. }
  556. if ( hourglass != undefined ) hourglass.remove();
  557. } );
  558. } );
  559. }
  560. }
  561. function cmd_diff(lang, msg, args, wiki) {
  562. if ( args[0] ){
  563. var title = '';
  564. var x;
  565. for ( var i = 0; i < args.length; i++ ) {
  566. if ( parseInt(args[i], 10) || args[i] == 'next' || args[i] == 'prev' ) {
  567. x = i;
  568. i = args.length;
  569. } else {
  570. if ( title ) title += '_';
  571. title += args[i];
  572. }
  573. }
  574. msg.channel.send( '<https://' + wiki + '.gamepedia.com/' + title + '?diff=' + ( args[x] ? args[x] + ( args[x+1] ? '&oldid=' + args[x+1] : '' ) : '' ) + '>' );
  575. }
  576. else msg.react('440871715938238494');
  577. }
  578. function cmd_multiline(lang, msg, args, line) {
  579. msg.react('440871715938238494');
  580. }
  581. function cmd_message(lang, msg, args, line) {
  582. if ( msg.author.id == process.env.owner && args[1] && args[0] == '<@' + client.user.id + '>' ) {
  583. client.guilds.forEach( function(guild) {
  584. guild.owner.send( guild.toString() + ':\n' + args.slice(1).join(' ') + '\n~<@' + process.env.owner + '>' );
  585. } );
  586. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  587. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  588. }
  589. }
  590. function cmd_voice(lang, msg, args, line) {
  591. if ( admin(msg) ) {
  592. msg.reply( lang.voice.text + '\n`' + lang.voice.channel + ' – <' + lang.voice.name + '>`' );
  593. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  594. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  595. }
  596. }
  597. function admin(msg) {
  598. if ( msg.channel.type == 'text' && ( msg.member.permissions.has('MANAGE_GUILD') || msg.author.id == process.env.owner ) ) return true;
  599. else return false;
  600. }
  601. function emoji(args) {
  602. var text = args.join(' ');
  603. var regex = /(<a?:)(\d+)(>)/g;
  604. if ( regex.test(text) ) {
  605. regex.lastIndex = 0;
  606. var emojis = client.emojis;
  607. var entry;
  608. while ( ( entry = regex.exec(text) ) !== null ) {
  609. if ( emojis.has(entry[2]) ) {
  610. text = text.replace(entry[0], emojis.get(entry[2]).toString());
  611. } else {
  612. text = text.replace(entry[0], entry[1] + 'unknown_emoji:' + entry[2] + entry[3]);
  613. }
  614. }
  615. args = text.split(' ');
  616. }
  617. return args;
  618. }
  619. client.on('message', msg => {
  620. var cont = msg.content;
  621. var author = msg.author;
  622. var channel = msg.channel;
  623. if ( settings == defaultSettings ) getSettings(setStatus);
  624. if ( !msg.webhookID && author.id != client.user.id && ( msg.channel.type != 'text' || channel.permissionsFor(client.user).has('SEND_MESSAGES') ) ) {
  625. var setting = settings['default'];
  626. if ( msg.channel.type == 'text' && msg.guild.id in settings ) setting = settings[msg.guild.id];
  627. var lang = i18n[setting.lang];
  628. lang.link = setting.wiki;
  629. if ( cont.toLowerCase().startsWith(process.env.prefix) && cont.split(' ')[1].toLowerCase() in multilinecmdmap ) {
  630. if ( msg.channel.type != 'text' || channel.permissionsFor(client.user).has('MANAGE_MESSAGES') ) {
  631. var invoke = cont.split(' ')[1].toLowerCase();
  632. var args = cont.split(' ').slice(2);
  633. var aliasInvoke = ( invoke in lang.aliase ) ? lang.aliase[invoke] : invoke;
  634. console.log((msg.guild ? msg.guild.name : '@' + author.username) + ': ' + invoke + ' - ' + args);
  635. if ( msg.channel.type != 'text' || !pause[msg.guild.id] || ( author.id == process.env.owner && aliasInvoke in pausecmdmap ) ) multilinecmdmap[aliasInvoke](lang, msg, args, cont);
  636. } else {
  637. msg.reply( lang.missingperm );
  638. }
  639. } else {
  640. cont.split('\n').forEach( function(line) {
  641. if ( line.toLowerCase().startsWith(process.env.prefix) ) {
  642. var invoke = line.split(' ')[1].toLowerCase();
  643. var args = line.split(' ').slice(2);
  644. var aliasInvoke = ( invoke in lang.aliase ) ? lang.aliase[invoke] : invoke;
  645. console.log((msg.guild ? msg.guild.name : '@' + author.username) + ': ' + invoke + ' - ' + args);
  646. if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  647. if ( aliasInvoke in cmdmap ) cmdmap[aliasInvoke](lang, msg, args, line);
  648. else if ( invoke.startsWith('!') ) cmd_link(lang, msg, args.join(' '), invoke.substr(1), invoke + ' ');
  649. else cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, '');
  650. } else if ( msg.channel.type == 'text' && pause[msg.guild.id] && author.id == process.env.owner && aliasInvoke in pausecmdmap ) {
  651. pausecmdmap[aliasInvoke](lang, msg, args, line);
  652. }
  653. }
  654. } );
  655. }
  656. }
  657. });
  658. client.on('voiceStateUpdate', (oldm, newm) => {
  659. if ( settings == defaultSettings ) getSettings(setStatus);
  660. if ( oldm.guild.me.permissions.has('MANAGE_ROLES') && oldm.voiceChannelID != newm.voiceChannelID ) {
  661. var setting = settings['default'];
  662. if ( oldm.guild.id in settings ) setting = settings[oldm.guild.id];
  663. var lang = i18n[setting.lang];
  664. lang.link = setting.wiki;
  665. if ( oldm.voiceChannel ) {
  666. var oldrole = oldm.guild.roles.find('name', lang.voice.channel + ' – ' + oldm.voiceChannel.name);
  667. if ( oldrole && oldrole.comparePositionTo(oldm.guild.me.highestRole) < 0 ) {
  668. oldm.removeRole( oldrole, lang.voice.left.replace( '%1$s', oldm.displayName ).replace( '%2$s', oldm.voiceChannel.name ) );
  669. console.log( oldm.guild.name + ': ' + oldm.displayName + ' hat den Sprachkanal "' + oldm.voiceChannel.name + '" verlassen.' );
  670. }
  671. }
  672. if ( newm.voiceChannel ) {
  673. var newrole = newm.guild.roles.find('name', lang.voice.channel + ' – ' + newm.voiceChannel.name);
  674. if ( newrole && newrole.comparePositionTo(newm.guild.me.highestRole) < 0 ) {
  675. newm.addRole( newrole, lang.voice.join.replace( '%1$s', newm.displayName ).replace( '%2$s', newm.voiceChannel.name ) );
  676. console.log( newm.guild.name + ': ' + newm.displayName + ' hat den Sprachkanal "' + newm.voiceChannel.name + '" betreten.' );
  677. }
  678. }
  679. }
  680. });
  681. client.on('guildCreate', guild => {
  682. client.fetchUser(process.env.owner).then( owner => owner.send( 'Ich wurde zu einem Server hinzugefügt:\n\n' + '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find('type', 'text').toString() + ' (' + guild.id + ')' ) );
  683. console.log( 'Ich wurde zu einem Server hinzugefügt.' );
  684. });
  685. client.on('guildDelete', guild => {
  686. client.fetchUser(process.env.owner).then( owner => owner.send( 'Ich wurde von einem Server entfernt:\n\n' + '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find('type', 'text').toString() + ' (' + guild.id + ')' ) );
  687. console.log( 'Ich wurde von einem Server entfernt.' );
  688. });
  689. client.login(process.env.token);