main.js 43 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039
  1. const fs = require('fs');
  2. const Discord = require('discord.js');
  3. var request = require('request');
  4. var client = new Discord.Client( {disableEveryone:true} );
  5. var i18n = JSON.parse(fs.readFileSync('i18n.json', 'utf8'));
  6. var minecraft = JSON.parse(fs.readFileSync('minecraft.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.read + process.env.file + process.env.access,
  18. json: true
  19. }, function( error, response, body ) {
  20. if ( error || !response || !body || body.error ) {
  21. console.log( 'Fehler beim Erhalten der Einstellungen' + ( error ? ': ' + error.message : ( body ? ( body.error ? ': ' + body.error : '.' ) : '.' ) ) );
  22. }
  23. else {
  24. console.log( 'Einstellungen erfolgreich ausgelesen.' );
  25. settings = Object.assign({}, 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. poll: cmd_multiline,
  49. voice: cmd_voice,
  50. settings: cmd_settings,
  51. info: cmd_info,
  52. eval: cmd_multiline
  53. }
  54. var multilinecmdmap = {
  55. say: cmd_say,
  56. delete: cmd_delete,
  57. poll: cmd_umfrage,
  58. eval: cmd_eval
  59. }
  60. var pausecmdmap = {
  61. test: cmd_test,
  62. stop: cmd_stop,
  63. pause: cmd_pause,
  64. server: cmd_serverlist,
  65. say: cmd_multiline,
  66. delete: cmd_multiline,
  67. eval: cmd_multiline
  68. }
  69. var minecraftcmdmap = {
  70. command: cmd_befehl2,
  71. bug: cmd_bug
  72. }
  73. function cmd_settings(lang, msg, args, line) {
  74. if ( admin(msg) ) {
  75. 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;
  76. else var text = lang.settings.missing.replace( '%1$s', '`' + process.env.prefix + ' settings lang`' ).replace( '%2$s', '`' + process.env.prefix + ' settings wiki`' );
  77. if ( args.length ) {
  78. if ( args[0] ) args[0] = args[0].toLowerCase();
  79. if ( args[1] ) args[1] = args[1].toLowerCase();
  80. var langs = '\n' + lang.settings.langs + ' `' + Object.keys(i18n).join(', ') + '`';
  81. var wikis = '\n' + lang.settings.wikis;
  82. var nolangs = lang.settings.nolangs + langs;
  83. var regex = /^(?:(?:https?:)?\/\/)?([a-z\d-]{1,30})/
  84. if ( msg.guild.id in settings ) {
  85. if ( args[0] == 'lang' ) {
  86. if ( args[1] ) {
  87. if ( args[1] in i18n ) edit_settings(lang, msg, 'lang', args[1]);
  88. else msg.reply( nolangs );
  89. } else msg.reply( lang.settings.lang + ' `' + settings[msg.guild.id].lang + '`' + langs );
  90. } else if ( args[0] == 'wiki' ) {
  91. if ( args[1] ) {
  92. if ( regex.test(args[1]) ) edit_settings(lang, msg, 'wiki', regex.exec(args[1])[1]);
  93. else cmd_settings(lang, msg, ['wiki'], line);
  94. } else msg.reply( lang.settings.wiki + '\nhttps://' + settings[msg.guild.id].wiki + '.gamepedia.com/' + wikis );
  95. } else if ( args[0] == 'channel' ) {
  96. if ( args[1] ) {
  97. if ( regex.test(args[1]) ) edit_settings(lang, msg, 'channel', regex.exec(args[1])[1]);
  98. else cmd_settings(lang, msg, ['channel'], line);
  99. } else if ( settings[msg.guild.id].channels && msg.channel.id in settings[msg.guild.id].channels ) {
  100. msg.reply( lang.settings.channel + '\nhttps://' + settings[msg.guild.id].channels[msg.channel.id] + '.gamepedia.com/' + wikis );
  101. } else msg.reply( lang.settings.channel + '\nhttps://' + settings[msg.guild.id].wiki + '.gamepedia.com/' + wikis );
  102. } else msg.reply( text );
  103. } else {
  104. if ( args[0] == 'lang' ) {
  105. if ( args[1] ) {
  106. if ( args[1] in i18n ) edit_settings(lang, msg, 'lang', args[1]);
  107. else msg.reply( nolangs );
  108. } else msg.reply( lang.settings.lang + ' `' + settings['default'].lang + '`' + langs );
  109. } else if ( args[0] == 'wiki' ) {
  110. if ( args[1] ) {
  111. if ( regex.test(args[1]) ) edit_settings(lang, msg, 'wiki', regex.exec(args[1])[1]);
  112. else cmd_settings(lang, msg, ['wiki'], line);
  113. } else msg.reply( lang.settings.nowiki + wikis );
  114. } else msg.reply( text );
  115. }
  116. } else msg.reply( text );
  117. } else {
  118. msg.react('❌');
  119. }
  120. }
  121. function edit_settings(lang, msg, key, value) {
  122. var hourglass;
  123. msg.react('⏳').then( function( reaction ) {
  124. hourglass = reaction;
  125. if ( settings == defaultSettings ) {
  126. console.log( 'Fehler beim Erhalten bestehender Einstellungen.' );
  127. msg.reply( lang.settings.save_failed );
  128. if ( hourglass != undefined ) hourglass.remove();
  129. }
  130. else {
  131. var temp_settings = Object.assign({}, settings);
  132. if ( !( msg.guild.id in temp_settings ) ) temp_settings[msg.guild.id] = Object.assign({}, defaultSettings['default']);
  133. if ( key == 'channel' ) {
  134. if ( !temp_settings[msg.guild.id].channels ) temp_settings[msg.guild.id].channels = {};
  135. temp_settings[msg.guild.id].channels[msg.channel.id] = value;
  136. } else temp_settings[msg.guild.id][key] = value;
  137. Object.keys(temp_settings).forEach( function(guild) {
  138. if ( !client.guilds.has(guild) && guild != 'default' ) {
  139. delete temp_settings[guild];
  140. } else {
  141. var channels = temp_settings[guild].channels;
  142. if ( channels ) {
  143. Object.keys(channels).forEach( function(channel) {
  144. if ( channels[channel] == temp_settings[guild].wiki || !client.guilds.get(guild).channels.has(channel) ) delete channels[channel];
  145. } );
  146. if ( !Object.keys(channels).length ) delete temp_settings[guild].channels;
  147. }
  148. }
  149. } );
  150. request.post( {
  151. uri: process.env.save + process.env.access,
  152. body: {
  153. branch: 'master',
  154. commit_message: 'Wiki-Bot: Einstellungen aktualisiert.',
  155. actions: [
  156. {
  157. action: 'update',
  158. file_path: process.env.file,
  159. content: JSON.stringify( temp_settings, null, '\t' )
  160. }
  161. ]
  162. },
  163. json: true
  164. }, function( error, response, body ) {
  165. if ( error || !response || response.statusCode != 201 || !body || body.error ) {
  166. console.log( 'Fehler beim Bearbeiten' + ( error ? ': ' + error.message : ( body ? ( body.message ? ': ' + body.message : ( body.error ? ': ' + body.error : '.' ) ) : '.' ) ) );
  167. msg.reply( lang.settings.save_failed );
  168. }
  169. else {
  170. settings = Object.assign({}, temp_settings);
  171. if ( key == 'lang' ) lang = i18n[value];
  172. cmd_settings(lang, msg, [key], '');
  173. console.log( 'Einstellungen erfolgreich aktualisiert.' );
  174. }
  175. if ( hourglass != undefined ) hourglass.remove();
  176. } );
  177. }
  178. } );
  179. }
  180. function cmd_info(lang, msg, args, line) {
  181. if ( args.length ) cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, ' ');
  182. else {
  183. var owner = '*MarkusRost*';
  184. if ( msg.channel.type == 'text' && msg.guild.members.has(process.env.owner) ) owner = '<@' + process.env.owner + '>';
  185. msg.channel.send( lang.disclaimer.replace( '%s', owner ) );
  186. cmd_helpserver(lang, msg);
  187. cmd_invite(lang, msg, args, line);
  188. }
  189. }
  190. function cmd_helpserver(lang, msg) {
  191. msg.channel.send( lang.helpserver + '\nhttps://discord.gg/v77RTk5' );
  192. }
  193. function cmd_help(lang, msg, args, line) {
  194. if ( admin(msg) && !( msg.guild.id in settings ) ) cmd_settings(lang, msg, [], line);
  195. var cmds = lang.help.list;
  196. var isMinecraft = ( lang.link == minecraft[lang.lang].link );
  197. if ( args.length ) {
  198. if ( mention(args[0]) ) cmd_helpserver(lang, msg);
  199. else if ( args[0].toLowerCase() == 'admin' ) {
  200. if ( msg.channel.type != 'text' || admin(msg) ) {
  201. if ( args[1] && args[1].toLowerCase() == 'emoji' && msg.author.id == process.env.owner ) {
  202. var cmdlist = lang.help.emoji + '\n';
  203. var i = 0;
  204. client.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, {split:true} );
  220. }
  221. }
  222. else {
  223. msg.reply( lang.help.noadmin );
  224. }
  225. }
  226. else {
  227. var cmdlist = ''
  228. for ( var i = 0; i < cmds.length; i++ ) {
  229. if ( cmds[i].cmd.split(' ')[0] === args[0].toLowerCase() && !cmds[i].unsearchable && ( msg.channel.type != 'text' || !cmds[i].admin || admin(msg) ) && ( !cmds[i].minecraft || isMinecraft ) ) {
  230. cmdlist += '🔹 `' + process.env.prefix + ' ' + cmds[i].cmd + '`\n\t' + cmds[i].desc + '\n';
  231. }
  232. }
  233. if ( cmdlist == '' ) msg.react('❓');
  234. else msg.channel.send( cmdlist, {split:true} );
  235. }
  236. }
  237. else {
  238. var cmdlist = lang.help.all + '\n';
  239. for ( var i = 0; i < cmds.length; i++ ) {
  240. if ( !cmds[i].hide && !cmds[i].admin && ( !cmds[i].minecraft || isMinecraft ) ) {
  241. cmdlist += '🔹 `' + process.env.prefix + ' ' + cmds[i].cmd + '`\n\t' + cmds[i].desc + '\n';
  242. }
  243. }
  244. msg.channel.send( cmdlist, {split:true} );
  245. }
  246. }
  247. function cmd_say(lang, msg, args, line) {
  248. if ( admin(msg) ) {
  249. args = emoji(args);
  250. var text = args.join(' ');
  251. if ( args[0] == 'alarm' ) text = '🚨 **' + args.slice(1).join(' ') + '** 🚨';
  252. var imgs = [];
  253. var i = 0;
  254. msg.attachments.forEach( function(img) {
  255. imgs[i] = {attachment:img.proxyURL,name:img.filename};
  256. i++;
  257. } );
  258. if ( msg.author.id == process.env.owner ) {
  259. try {
  260. text = eval( '`' + text + '`' );
  261. } catch ( error ) {
  262. console.log( error.name + ': ' + error.message );
  263. }
  264. }
  265. if ( text || imgs[0] ) {
  266. msg.channel.send( text, {disableEveryone:false,files:imgs} ).then( message => msg.delete().catch( error => console.log( error.name + ': ' + error.message ) ), error => msg.react('440871715938238494') );
  267. }
  268. } else {
  269. msg.react('❌');
  270. }
  271. }
  272. function cmd_test(lang, msg, args, line) {
  273. if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  274. var text = '';
  275. var x = Math.floor(Math.random() * lang.test.random);
  276. if ( x < lang.test.text.length ) text = lang.test.text[x];
  277. else text = lang.test.default;
  278. msg.reply( text );
  279. console.log( 'Dies ist ein Test: Voll funktionsfähig!' );
  280. } else {
  281. msg.reply( lang.test.pause );
  282. console.log( 'Dies ist ein Test: Pausiert!' );
  283. }
  284. }
  285. function cmd_invite(lang, msg, args, line) {
  286. if ( args.length ) {
  287. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, ' ');
  288. } else {
  289. client.generateInvite(268954689).then( invite => msg.channel.send( lang.invite.bot + '\n<' + invite + '>' ) );
  290. }
  291. }
  292. function cmd_eval(lang, msg, args, line) {
  293. if ( msg.author.id == process.env.owner && args.length ) {
  294. try {
  295. var text = eval( args.join(' ') );
  296. } catch ( error ) {
  297. var text = error.name + ': ' + error.message;
  298. }
  299. console.log( text );
  300. msg.channel.send( '```js\n' + text + '```', {split:{prepend:'```js\n',append:'```'}} ).catch( err => msg.channel.send( '```js\n' + err.name + ': ' + err.message + '```', {split:{prepend:'```js\n',append:'```'}} ) );
  301. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  302. msg.react('❌');
  303. }
  304. }
  305. function cmd_stop(lang, msg, args, line) {
  306. if ( msg.author.id == process.env.owner && args.length && mention(args[0]) ) {
  307. msg.reply( 'ich schalte mich nun aus!' );
  308. console.log( 'Ich schalte mich nun aus!' );
  309. client.destroy();
  310. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  311. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, ' ');
  312. }
  313. }
  314. function cmd_pause(lang, msg, args, line) {
  315. if ( msg.channel.type == 'text' && msg.author.id == process.env.owner && args.length && mention(args[0]) ) {
  316. if ( pause[msg.guild.id] ) {
  317. msg.reply( 'ich bin wieder wach!' );
  318. console.log( 'Ich bin wieder wach!' );
  319. pause[msg.guild.id] = false;
  320. } else {
  321. msg.reply( 'ich lege mich nun schlafen!' );
  322. console.log( 'Ich lege mich nun schlafen!' );
  323. pause[msg.guild.id] = true;
  324. }
  325. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  326. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, ' ');
  327. }
  328. }
  329. function cmd_delete(lang, msg, args, line) {
  330. if ( admin(msg) ) {
  331. if ( /^\d+$/.test(args[0]) && parseInt(args[0], 10) + 1 > 0 ) {
  332. if ( parseInt(args[0], 10) > 99 ) {
  333. msg.reply( lang.delete.big.replace( '%s', '`99`' ) );
  334. }
  335. else {
  336. msg.channel.bulkDelete(parseInt(args[0], 10) + 1, true).then( messages => {
  337. msg.reply( lang.delete.success.replace( '%s', messages.size - 1 ) ).then( antwort => antwort.delete(3000) );
  338. console.log( 'Die letzten ' + ( messages.size - 1 ) + ' Nachrichten in #' + msg.channel.name + ' wurden gelöscht!' );
  339. } );
  340. }
  341. }
  342. else {
  343. msg.reply( lang.delete.invalid );
  344. }
  345. } else {
  346. msg.react('❌');
  347. }
  348. }
  349. function cmd_link(lang, msg, title, wiki, cmd) {
  350. if ( cmd == ' ' && admin(msg) && !( msg.guild.id in settings ) ) cmd_settings(lang, msg, [], '');
  351. var invoke = title.split(' ')[0].toLowerCase();
  352. var args = title.split(' ').slice(1);
  353. var mclang = minecraft[lang.lang];
  354. var aliasInvoke = ( invoke in mclang.aliase ) ? mclang.aliase[invoke] : invoke;
  355. if ( !msg.notminecraft && wiki == mclang.link && ( aliasInvoke in minecraftcmdmap || invoke.startsWith('/') ) ) {
  356. if ( aliasInvoke in minecraftcmdmap ) minecraftcmdmap[aliasInvoke](lang, mclang, msg, args, title, cmd);
  357. else cmd_befehl(lang, mclang, msg, invoke.substr(1), args, title, cmd);
  358. }
  359. else if ( ( invoke == 'random' || invoke == '🎲' ) && !args.join('') ) cmd_random(lang, msg, wiki);
  360. else if ( invoke == 'page' || invoke == lang.search.page ) msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + args.join('_') );
  361. else if ( invoke == 'search' || invoke == lang.search.search ) msg.channel.send( 'https://' + wiki + '.gamepedia.com/Special:Search/' + args.join('_').replace( /\?/g, '%3F' ) );
  362. else if ( invoke == 'diff' ) cmd_diff(lang, msg, args, wiki);
  363. else if ( title.includes( '#' ) ) msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title.toTitle() );
  364. 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, '_' ));
  365. else if ( invoke.startsWith('user:') ) cmd_user(lang, msg, title.substr(5), wiki, title.replace( / /g, '_' ));
  366. else if ( invoke.startsWith('userprofile:') ) cmd_user(lang, msg, title.substr(12), wiki, title.replace( / /g, '_' ));
  367. else if ( invoke.startsWith(lang.search.user.unknown + ':') ) cmd_user(lang, msg, title.substr(lang.search.user.unknown.length + 1), wiki, title.replace( / /g, '_' ));
  368. else if ( invoke.startsWith(lang.search.user.male + ':') ) cmd_user(lang, msg, title.substr(lang.search.user.male.length + 1), wiki, title.replace( / /g, '_' ));
  369. else if ( invoke.startsWith(lang.search.user.female + ':') ) cmd_user(lang, msg, title.substr(lang.search.user.female.length + 1), wiki, title.replace( / /g, '_' ));
  370. else {
  371. var hourglass;
  372. msg.react('⏳').then( function( reaction ) {
  373. hourglass = reaction;
  374. request( {
  375. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&meta=siteinfo&siprop=general&iwurl=true&redirects=true&titles=' + encodeURI( title ),
  376. json: true
  377. }, function( error, response, body ) {
  378. if ( error || !response || !body || !body.query ) {
  379. if ( response && response.request && response.request.uri && response.request.uri.href == 'https://www.gamepedia.com/' ) {
  380. console.log( 'Dieses Wiki existiert nicht! ' + ( error ? error.message : ( body ? ( body.error ? body.error.info : '' ) : '' ) ) );
  381. msg.react('440871715938238494');
  382. }
  383. else {
  384. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( error ? ': ' + error.message : ( body ? ( body.error ? ': ' + body.error.info : '.' ) : '.' ) ) );
  385. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title.toTitle() ).then( message => message.react('440871715938238494') );
  386. }
  387. }
  388. else {
  389. if ( body.query.pages ) {
  390. if ( body.query.pages['-1'] && body.query.pages['-1'].missing != undefined ) {
  391. request( {
  392. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&list=search&srnamespace=0|4|12|14|10000|10002|10004|10006|10008|10010&srsearch=' + encodeURI( title ) + '&srlimit=1',
  393. json: true
  394. }, function( srerror, srresponse, srbody ) {
  395. if ( srerror || !srresponse || !srbody || !srbody.query || ( !srbody.query.search[0] && srbody.query.searchinfo.totalhits != 0 ) ) {
  396. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( srerror ? ': ' + srerror.message : ( srbody ? ( srbody.error ? ': ' + srbody.error.info : '.' ) : '.' ) ) );
  397. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title.toTitle() ).then( message => message.react('440871715938238494') );
  398. }
  399. else {
  400. if ( srbody.query.searchinfo.totalhits == 0 ) {
  401. msg.react('🤷');
  402. }
  403. else if ( srbody.query.searchinfo.totalhits == 1 ) {
  404. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + srbody.query.search[0].title.toTitle() + '\n' + lang.search.infopage.replace( '%s', '`' + process.env.prefix + cmd + lang.search.page + ' ' + title + '`' ) );
  405. }
  406. else {
  407. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + srbody.query.search[0].title.toTitle() + '\n' + lang.search.infosearch.replace( '%1$s', '`' + process.env.prefix + cmd + lang.search.page + ' ' + title + '`' ).replace( '%2$s', '`' + process.env.prefix + cmd + lang.search.search + ' ' + title + '`' ) );
  408. }
  409. }
  410. } );
  411. }
  412. else {
  413. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + Object.values(body.query.pages)[0].title.toTitle() + ( body.query.redirects && body.query.redirects[0].tofragment ? '#' + encodeURIComponent( body.query.redirects[0].tofragment.replace( / /g, '_' ) ).replace( /\%/g, '.' ) : '' ) );
  414. }
  415. }
  416. else if ( body.query.interwiki ) {
  417. var inter = body.query.interwiki[0];
  418. var intertitle = inter.title.substr(inter.iw.length+1);
  419. var regex = /^(?:https?:)?\/\/(.*)\.gamepedia\.com\//.exec(inter.url);
  420. if ( regex != null ) {
  421. var iwtitle = decodeURIComponent( inter.url.replace( regex[0], '' ) ).replace( /\_/g, ' ' ).replace( intertitle.replace( /\_/g, ' ' ), intertitle );
  422. cmd_link(lang, msg, iwtitle, regex[1], ' !' + regex[1] + ' ');
  423. } else msg.channel.send( inter.url );
  424. }
  425. else {
  426. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + body.query.general.mainpage.toTitle() );
  427. }
  428. }
  429. if ( hourglass != undefined ) hourglass.remove();
  430. } );
  431. } );
  432. }
  433. }
  434. function cmd_serverlist(lang, msg, args, line) {
  435. if ( msg.author.id == process.env.owner && args.join(' ') == 'list all <@' + client.user.id + '>' ) {
  436. var guilds = client.guilds;
  437. var serverlist = 'Ich befinde mich aktuell auf ' + guilds.size + ' Servern:\n\n';
  438. guilds.forEach( function(guild) {
  439. serverlist += '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find( channel => channel.type == 'text' ).toString() + ' (' + guild.id + ')\n\n';
  440. } );
  441. msg.author.send( serverlist, {split:{char:'\n\n'}} );
  442. } else if ( msg.author.id == process.env.owner && args.join(' ') == 'list all <@' + client.user.id + '> permissions' ) {
  443. var guilds = client.guilds;
  444. var serverlist = 'Ich befinde mich aktuell auf ' + guilds.size + ' Servern:\n\n';
  445. guilds.forEach( function(guild) {
  446. var perms = ' ';
  447. var allperms = Object.entries(guild.me.permissions.serialize());
  448. allperms.forEach( function(perm) {
  449. if ( perm[1] ) perms += perm[0] + ', ';
  450. } );
  451. perms = perms.substr(0, perms.length -2);
  452. serverlist += '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find( channel => channel.type == 'text' ).toString() + perms + '\n\n';
  453. } );
  454. msg.author.send( serverlist, {split:{char:'\n\n'}} );
  455. } else if ( msg.author.id == process.env.owner && args.join(' ') == 'list all <@' + client.user.id + '> members' ) {
  456. var guilds = client.guilds;
  457. var serverlist = 'Ich befinde mich aktuell auf ' + guilds.size + ' Servern:\n\n';
  458. guilds.forEach( function(guild) {
  459. var members = ' ';
  460. var allmembers = guild.members;
  461. if ( !allmembers.has(process.env.owner) && guild.memberCount < 50 ) {
  462. allmembers.forEach( function(member) {
  463. members += member.toString() + ', ';
  464. } );
  465. }
  466. members = members.substr(0, members.length -2);
  467. serverlist += '"' + guild.toString() + '" von ' + guild.owner.toString() + ' mit ' + guild.memberCount + ' Mitgliedern\n' + guild.channels.find( channel => channel.type == 'text' ).toString() + members + '\n\n';
  468. } );
  469. msg.author.send( serverlist, {split:{char:'\n\n'}} );
  470. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  471. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, ' ');
  472. }
  473. }
  474. function cmd_umfrage(lang, msg, args, line) {
  475. if ( admin(msg) ) {
  476. var imgs = [];
  477. var a = 0;
  478. msg.attachments.forEach( function(img) {
  479. imgs[a] = {attachment:img.proxyURL,name:img.filename};
  480. a++;
  481. } );
  482. if ( args.length || imgs[0] ) {
  483. var reactions = [];
  484. args = emoji(args);
  485. for ( var i = 0; ( i < args.length || imgs[0] ); i++ ) {
  486. var reaction = args[i];
  487. var custom = /^<a?:/;
  488. var pattern = /^[\w\säÄöÖüÜßẞ!"#$%&'()*+,./:;<=>?@^`{|}~–[\]\-\\]{2,}/;
  489. if ( !custom.test(reaction) && pattern.test(reaction) ) {
  490. cmd_sendumfrage(lang, msg, args, reactions, imgs, i);
  491. break;
  492. } else if ( reaction == '' ) {
  493. } else {
  494. if ( custom.test(reaction) ) {
  495. reaction = reaction.substring(reaction.lastIndexOf(':')+1, reaction.length-1);
  496. }
  497. reactions[i] = reaction;
  498. if ( i == args.length-1 ) {
  499. cmd_sendumfrage(lang, msg, args, reactions, imgs, i+1);
  500. break;
  501. }
  502. }
  503. }
  504. } else {
  505. args[0] = line.split(' ')[1];
  506. cmd_help(lang, msg, args, line);
  507. }
  508. } else {
  509. msg.react('❌');
  510. }
  511. }
  512. function cmd_sendumfrage(lang, msg, args, reactions, imgs, i) {
  513. msg.channel.send( lang.poll.title + args.slice(i).join(' '), {disableEveryone:false,files:imgs} ).then( poll => {
  514. msg.delete().catch( error => console.log( error.name + ': ' + error.message ) );
  515. if ( reactions.length ) {
  516. reactions.forEach( function(entry) {
  517. poll.react(entry).catch( error => poll.react('440871715938238494') );
  518. } );
  519. } else {
  520. poll.react('448222377009086465');
  521. poll.react('448222455425794059');
  522. }
  523. }, error => msg.react('440871715938238494') );
  524. }
  525. function cmd_user(lang, msg, username, wiki, title) {
  526. if ( !username || username.includes( '/' ) || username.toLowerCase().startsWith('talk:') || username.toLowerCase().startsWith(lang.user.talk) ) {
  527. msg.channel.send( 'https://' + wiki + '.gamepedia.com/' + title );
  528. } else {
  529. var hourglass;
  530. msg.react('⏳').then( function( reaction ) {
  531. hourglass = reaction;
  532. request( {
  533. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&list=users&usprop=blockinfo|groups|editcount|registration|gender&ususers=' + encodeURI( username ),
  534. json: true
  535. }, function( error, response, body ) {
  536. if ( error || !response || !body || !body.query || !body.query.users[0] ) {
  537. if ( response && response.request && response.request.uri && response.request.uri.href == 'https://www.gamepedia.com/' ) {
  538. console.log( 'Dieses Wiki existiert nicht! ' + ( error ? error.message : ( body ? ( body.error ? body.error.info : '' ) : '' ) ) );
  539. msg.react('440871715938238494');
  540. }
  541. else {
  542. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( error ? ': ' + error.message : ( body ? ( body.error ? ': ' + body.error.info : '.' ) : '.' ) ) );
  543. msg.channel.send( '<https://' + wiki + '.gamepedia.com/User:' + username + '>' ).then( message => message.react('440871715938238494') );
  544. }
  545. }
  546. else {
  547. if ( body.query.users[0].missing == "" || body.query.users[0].invalid == "" ) {
  548. msg.react('🤷');
  549. }
  550. else {
  551. username = body.query.users[0].name.replace( / /g, '_' );
  552. var timeoptions = {
  553. year: "numeric",
  554. month: "short",
  555. day: "numeric",
  556. hour: "2-digit",
  557. minute: "2-digit"
  558. }
  559. var gender = body.query.users[0].gender;
  560. switch (gender) {
  561. case 'male':
  562. gender = lang.user.gender.male;
  563. break;
  564. case 'female':
  565. gender = lang.user.gender.female;
  566. break;
  567. default:
  568. gender = lang.user.gender.unknown;
  569. }
  570. var registration = (new Date(body.query.users[0].registration)).toLocaleString(lang.user.dateformat, timeoptions);
  571. var editcount = body.query.users[0].editcount;
  572. var groups = body.query.users[0].groups;
  573. var group = '';
  574. for ( var i = 0; i < lang.user.group.length; i++ ) {
  575. if ( groups.includes(lang.user.group[i][0]) ) {
  576. group = lang.user.group[i][1];
  577. break;
  578. }
  579. }
  580. var isBlocked = false;
  581. var blockedtimestamp = (new Date(body.query.users[0].blockedtimestamp)).toLocaleString(lang.user.dateformat, timeoptions);
  582. var blockexpiry = body.query.users[0].blockexpiry;
  583. if ( blockexpiry == 'infinity' ) {
  584. blockexpiry = lang.user.until_infinity;
  585. isBlocked = true;
  586. } else if ( blockexpiry ) {
  587. var blockexpirydate = blockexpiry.replace(/(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2,3})/, '$1-$2-$3T$4:$5:$6Z');
  588. blockexpiry = (new Date(blockexpirydate)).toLocaleString(lang.user.dateformat, timeoptions);
  589. if ( Date.parse(blockexpirydate) > Date.now() ) isBlocked = true;
  590. }
  591. var blockedby = body.query.users[0].blockedby;
  592. var blockreason = body.query.users[0].blockreason;
  593. 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 ) + ( isBlocked ? '\n\n' + lang.user.blocked.replace( '%1$s', blockedtimestamp ).replace( '%2$s', blockexpiry ).replace( '%3$s', blockedby ).replace( '%4$s', blockreason.wikicode() ) : '' ) );
  594. }
  595. }
  596. if ( hourglass != undefined ) hourglass.remove();
  597. } );
  598. } );
  599. }
  600. }
  601. function cmd_diff(lang, msg, args, wiki) {
  602. if ( args[0] ) {
  603. var error = false;
  604. var title = '';
  605. var revision = 0;
  606. var diff = 'prev';
  607. if ( /^\d+$/.test(args[0]) ) {
  608. revision = args[0];
  609. if ( args[1] ) {
  610. if ( /^\d+$/.test(args[1]) ) {
  611. diff = args[1];
  612. }
  613. else if ( args[1] == 'prev' || args[1] == 'next' ) {
  614. diff = args[1];
  615. }
  616. else error = true;
  617. }
  618. }
  619. else if ( args[0] == 'prev' || args[0] == 'next' ) {
  620. diff = args[0];
  621. if ( args[1] ) {
  622. if ( /^\d+$/.test(args[1]) ) {
  623. revision = args[1];
  624. }
  625. else error = true;
  626. }
  627. else error = true;
  628. }
  629. else title = args.join('_').replace( /\?/g, '%3F' );
  630. if ( error ) msg.react('440871715938238494');
  631. else if ( /^\d+$/.test(diff) ) {
  632. var argids = [];
  633. if ( parseInt(revision, 10) > parseInt(diff, 10) ) argids = [revision, diff];
  634. else if ( parseInt(revision, 10) == parseInt(diff, 10) ) argids = [revision];
  635. else argids = [diff, revision];
  636. cmd_diffsend(lang, msg, argids, wiki);
  637. }
  638. else {
  639. var hourglass;
  640. msg.react('⏳').then( function( reaction ) {
  641. hourglass = reaction;
  642. request( {
  643. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&prop=revisions&rvprop=' + ( title ? '&titles=' + title : '&revids=' + revision ) + '&rvdiffto=' + diff,
  644. json: true
  645. }, function( error, response, body ) {
  646. if ( error || !response || !body || !body.query ) {
  647. if ( response && response.request && response.request.uri && response.request.uri.href == 'https://www.gamepedia.com/' ) {
  648. console.log( 'Dieses Wiki existiert nicht! ' + ( error ? error.message : ( body ? ( body.error ? body.error.info : '' ) : '' ) ) );
  649. msg.react('440871715938238494');
  650. }
  651. else {
  652. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( error ? ': ' + error.message : ( body ? ( body.error ? ': ' + body.error.info : '.' ) : '.' ) ) );
  653. msg.channel.send( '<https://' + wiki + '.gamepedia.com/' + title + '?diff=' + diff + ( title ? '' : '&oldid=' + revision ) + '>' ).then( message => message.react('440871715938238494') );
  654. }
  655. }
  656. else {
  657. if ( body.query.badrevids ) msg.reply( lang.diff.badrev );
  658. else if ( body.query.pages && body.query.pages[-1] ) msg.react('440871715938238494');
  659. else if ( body.query.pages ) {
  660. var argids = [];
  661. var ids = Object.values(body.query.pages)[0].revisions[0].diff;
  662. if ( ids.from ) {
  663. if ( ids.from > ids.to ) argids = [ids.from, ids.to];
  664. else if ( ids.from == ids.to ) argids = [ids.to];
  665. else argids = [ids.to, ids.from];
  666. }
  667. else argids = [ids.to];
  668. cmd_diffsend(lang, msg, argids, wiki);
  669. }
  670. else msg.react('440871715938238494');
  671. }
  672. if ( hourglass != undefined ) hourglass.remove();
  673. } );
  674. } );
  675. }
  676. }
  677. else msg.react('440871715938238494');
  678. }
  679. function cmd_diffsend(lang, msg, args, wiki) {
  680. request( {
  681. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&list=tags&tglimit=500&tgprop=displayname&prop=revisions&rvprop=ids|timestamp|flags|user|size|comment|tags&revids=' + args.join('|'),
  682. json: true
  683. }, function( error, response, body ) {
  684. if ( error || !response || !body || !body.query ) {
  685. if ( response && response.request && response.request.uri && response.request.uri.href == 'https://www.gamepedia.com/' ) {
  686. console.log( 'Dieses Wiki existiert nicht! ' + ( error ? error.message : ( body ? ( body.error ? body.error.info : '' ) : '' ) ) );
  687. msg.react('440871715938238494');
  688. }
  689. else {
  690. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( error ? ': ' + error.message : ( body ? ( body.error ? ': ' + body.error.info : '.' ) : '.' ) ) );
  691. msg.channel.send( '<https://' + wiki + '.gamepedia.com/?diff=' + args[0] + ( args[1] ? '&oldid=' + args[1] : '' ) + '>' ).then( message => message.react('440871715938238494') );
  692. }
  693. }
  694. else {
  695. if ( body.query.badrevids ) msg.reply( lang.diff.badrev );
  696. else if ( body.query.pages ) {
  697. var pages = Object.values(body.query.pages);
  698. if ( pages.length != 1 ) msg.channel.send( '<https://' + wiki + '.gamepedia.com/?diff=' + args[0] + ( args[1] ? '&oldid=' + args[1] : '' ) + '>' );
  699. else {
  700. var title = pages[0].title.toTitle();
  701. var revisions = [];
  702. if ( pages[0].revisions[1] ) revisions = [pages[0].revisions[1], pages[0].revisions[0]];
  703. else revisions = [pages[0].revisions[0]];
  704. var diff = revisions[0].revid;
  705. var oldid = ( revisions[1] ? revisions[1].revid : 0 );
  706. var editor = ( revisions[0].userhidden != undefined ? lang.diff.hidden : revisions[0].user );
  707. var timeoptions = {
  708. year: "numeric",
  709. month: "short",
  710. day: "numeric",
  711. hour: "2-digit",
  712. minute: "2-digit"
  713. }
  714. var timestamp = (new Date(revisions[0].timestamp)).toLocaleString(lang.user.dateformat, timeoptions);
  715. var size = revisions[0].size - ( revisions[1] ? revisions[1].size : 0 );
  716. var comment = ( revisions[0].commenthidden != undefined ? lang.diff.hidden : revisions[0].comment );
  717. if ( !comment ) comment = lang.diff.nocomment;
  718. var tags = [lang.diff.notags];
  719. var entry = body.query.tags;
  720. revisions[0].tags.forEach( function(tag, t) {
  721. for ( var i = 0; i < entry.length; i++ ) {
  722. if ( entry[i].name == tag ) {
  723. tags[t] = entry[i].displayname;
  724. break;
  725. }
  726. }
  727. } );
  728. msg.channel.send( '<https://' + wiki + '.gamepedia.com/' + title + '?diff=' + diff + '&oldid=' + oldid + '>\n\n' + lang.diff.info.replace( '%1$s', editor ).replace( '%2$s', timestamp ).replace( '%3$s', size ).replace( '%4$s', comment.wikicode() ).replace( '%5$s', tags.join(', ').replace( /<[^>]+>(.+)<\/[^>]+>/g, '$1' ) ) );
  729. }
  730. }
  731. else msg.react('440871715938238494');
  732. }
  733. } );
  734. }
  735. function cmd_random(lang, msg, wiki) {
  736. var hourglass;
  737. msg.react('⏳').then( function( reaction ) {
  738. hourglass = reaction;
  739. request( {
  740. uri: 'https://' + wiki + '.gamepedia.com/api.php?action=query&format=json&list=random&rnnamespace=0',
  741. json: true
  742. }, function( error, response, body ) {
  743. if ( error || !response || !body || !body.query || !body.query.random[0] ) {
  744. if ( response && response.request && response.request.uri && response.request.uri.href == 'https://www.gamepedia.com/' ) {
  745. console.log( 'Dieses Wiki existiert nicht! ' + ( error ? error.message : ( body ? ( body.error ? body.error.info : '' ) : '' ) ) );
  746. msg.react('440871715938238494');
  747. }
  748. else {
  749. console.log( 'Fehler beim Erhalten der Suchergebnisse' + ( error ? ': ' + error.message : ( body ? ( body.error ? ': ' + body.error.info : '.' ) : '.' ) ) );
  750. msg.channel.send( 'https://' + wiki + '.gamepedia.com/Special:Random' ).then( message => message.react('440871715938238494') );
  751. }
  752. }
  753. else {
  754. msg.channel.send( '🎲 https://' + wiki + '.gamepedia.com/' + body.query.random[0].title.toTitle() );
  755. }
  756. if ( hourglass != undefined ) hourglass.remove();
  757. } );
  758. } );
  759. }
  760. function cmd_bug(lang, mclang, msg, args, title, cmd) {
  761. if ( args.length && /\d+$/.test(args[0]) && !args[1] ) {
  762. var hourglass;
  763. msg.react('⏳').then( function( reaction ) {
  764. hourglass = reaction;
  765. var project = '';
  766. if ( /^\d+$/.test(args[0]) ) project = 'MC-';
  767. request( {
  768. uri: 'https://bugs.mojang.com/rest/api/2/issue/' + project + args[0] + '?fields=summary',
  769. json: true
  770. }, function( error, response, body ) {
  771. if ( error || !response || !body ) {
  772. console.log( 'Fehler beim Erhalten der Zusammenfassung' + ( error ? ': ' + error.message : '.' ) );
  773. msg.channel.send( 'https://bugs.mojang.com/browse/' + project + args[0] ).then( message => message.react('440871715938238494') );
  774. }
  775. else {
  776. if ( body.errorMessages || body.errors ) {
  777. if ( body.errorMessages && body.errorMessages[0] == 'Issue Does Not Exist' ) {
  778. msg.react('❓');
  779. }
  780. else {
  781. msg.channel.send( mclang.bug.private + '\nhttps://bugs.mojang.com/browse/' + project + args[0] );
  782. }
  783. }
  784. else {
  785. msg.channel.send( body.fields.summary + '\nhttps://bugs.mojang.com/browse/' + body.key );
  786. }
  787. }
  788. if ( hourglass != undefined ) hourglass.remove();
  789. } );
  790. } );
  791. }
  792. else {
  793. msg.notminecraft = true;
  794. cmd_link(lang, msg, title, mclang.link, cmd);
  795. }
  796. }
  797. function cmd_befehl(lang, mclang, msg, befehl, args, title, cmd) {
  798. var aliasCmd = ( ( befehl in mclang.cmd.aliase ) ? mclang.cmd.aliase[befehl] : befehl ).toLowerCase();
  799. if ( aliasCmd in mclang.cmd.list ) {
  800. var regex = new RegExp('/' + aliasCmd, 'g');
  801. var cmdSyntax = mclang.cmd.list[aliasCmd].join( '\n' ).replace( regex, '/' + befehl );
  802. msg.channel.send( '```md\n' + cmdSyntax + '```<https://' + mclang.link + '.gamepedia.com/' + mclang.cmd.page + aliasCmd + '>', {split:{maxLength:2000,prepend:'```md\n',append:'```'}} );
  803. }
  804. else {
  805. msg.react('❓');
  806. msg.notminecraft = true;
  807. cmd_link(lang, msg, title, mclang.link, cmd);
  808. }
  809. }
  810. function cmd_befehl2(lang, mclang, msg, args, title, cmd) {
  811. if ( args.length ) {
  812. if ( args[0].startsWith('/') ) cmd_befehl(lang, mclang, msg, args[0].substr(1), args.slice(1), title, cmd);
  813. else cmd_befehl(lang, mclang, msg, args[0], args.slice(1), title, cmd);
  814. }
  815. else {
  816. msg.notminecraft = true;
  817. cmd_link(lang, msg, title, mclang.link, cmd);
  818. }
  819. }
  820. function cmd_multiline(lang, msg, args, line) {
  821. msg.react('440871715938238494');
  822. }
  823. function cmd_voice(lang, msg, args, line) {
  824. if ( admin(msg) ) {
  825. msg.reply( lang.voice.text + '\n`' + lang.voice.channel + ' – <' + lang.voice.name + '>`' );
  826. } else if ( msg.channel.type != 'text' || !pause[msg.guild.id] ) {
  827. cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, ' ');
  828. }
  829. }
  830. function mention(arg) {
  831. if ( arg == '<@' + client.user.id + '>' || arg == '<@!' + client.user.id + '>' ) return true;
  832. else return false;
  833. }
  834. function admin(msg) {
  835. if ( msg.channel.type == 'text' && ( ( msg.member && msg.member.permissions.has('MANAGE_GUILD') ) || msg.author.id == process.env.owner ) ) return true;
  836. else return false;
  837. }
  838. function emoji(args) {
  839. var text = args.join(' ');
  840. var regex = /(<a?:)(\d+)(>)/g;
  841. if ( regex.test(text) ) {
  842. regex.lastIndex = 0;
  843. var emojis = client.emojis;
  844. var entry;
  845. while ( ( entry = regex.exec(text) ) !== null ) {
  846. if ( emojis.has(entry[2]) ) {
  847. text = text.replace(entry[0], emojis.get(entry[2]).toString());
  848. } else {
  849. text = text.replace(entry[0], entry[1] + 'unknown_emoji:' + entry[2] + entry[3]);
  850. }
  851. }
  852. args = text.split(' ');
  853. }
  854. return args;
  855. }
  856. String.prototype.toTitle = function() {
  857. return this.replace( / /g, '_' ).replace( /\%/g, '%25' ).replace( /\?/g, '%3F' );
  858. };
  859. String.prototype.wikicode = function() {
  860. return this.replace( /\[\[(?:[^\|\]]+\|)?([^\]]+)\]\]/g, '$1' ).replace( /\/\*\s*([^\*]+?)\s*\*\//g, '→$1:' );
  861. };
  862. function prefix(text) {
  863. if ( text.toLowerCase().startsWith( process.env.prefix + ' ' ) || text.toLowerCase() == process.env.prefix ) return true;
  864. else return false;
  865. }
  866. client.on('message', msg => {
  867. var cont = msg.content;
  868. var author = msg.author;
  869. var channel = msg.channel;
  870. if ( cont.toLowerCase().includes( process.env.prefix ) && !msg.webhookID && author.id != client.user.id && ( channel.type != 'text' || channel.permissionsFor(client.user).has(['SEND_MESSAGES','ADD_REACTIONS','USE_EXTERNAL_EMOJIS']) ) ) {
  871. if ( settings == defaultSettings ) getSettings(setStatus);
  872. var setting = Object.assign({}, settings['default']);
  873. if ( channel.type == 'text' && msg.guild.id in settings ) setting = Object.assign({}, settings[msg.guild.id]);
  874. var lang = i18n[setting.lang];
  875. lang.link = setting.wiki;
  876. if ( setting.channels && channel.id in setting.channels ) lang.link = setting.channels[channel.id];
  877. var invoke = cont.split(' ')[1] ? cont.split(' ')[1].toLowerCase() : '';
  878. var aliasInvoke = ( invoke in lang.aliase ) ? lang.aliase[invoke] : invoke;
  879. if ( prefix( cont ) && aliasInvoke in multilinecmdmap ) {
  880. if ( channel.type != 'text' || channel.permissionsFor(client.user).has('MANAGE_MESSAGES') ) {
  881. var args = cont.split(' ').slice(2);
  882. console.log((msg.guild ? msg.guild.name : '@' + author.username) + ': ' + invoke + ' - ' + args);
  883. if ( channel.type != 'text' || !pause[msg.guild.id] || ( author.id == process.env.owner && aliasInvoke in pausecmdmap ) ) multilinecmdmap[aliasInvoke](lang, msg, args, cont);
  884. } else {
  885. msg.reply( lang.missingperm + ' `MANAGE_MESSAGES`' );
  886. }
  887. } else {
  888. cont.split('\n').forEach( function(line) {
  889. if ( prefix( line ) ) {
  890. invoke = line.split(' ')[1] ? line.split(' ')[1].toLowerCase() : '';
  891. var args = line.split(' ').slice(2);
  892. aliasInvoke = ( invoke in lang.aliase ) ? lang.aliase[invoke] : invoke;
  893. console.log((msg.guild ? msg.guild.name : '@' + author.username) + ': ' + invoke + ' - ' + args);
  894. if ( channel.type != 'text' || !pause[msg.guild.id] ) {
  895. if ( aliasInvoke in cmdmap ) cmdmap[aliasInvoke](lang, msg, args, line);
  896. else if ( invoke.startsWith('!') ) cmd_link(lang, msg, args.join(' '), invoke.substr(1), ' ' + invoke + ' ');
  897. else cmd_link(lang, msg, line.split(' ').slice(1).join(' '), lang.link, ' ');
  898. } else if ( channel.type == 'text' && pause[msg.guild.id] && author.id == process.env.owner && aliasInvoke in pausecmdmap ) {
  899. pausecmdmap[aliasInvoke](lang, msg, args, line);
  900. }
  901. }
  902. } );
  903. }
  904. }
  905. });
  906. client.on('voiceStateUpdate', (oldm, newm) => {
  907. if ( settings == defaultSettings ) getSettings(setStatus);
  908. if ( oldm.guild.me.permissions.has('MANAGE_ROLES') && oldm.voiceChannelID != newm.voiceChannelID ) {
  909. var setting = Object.assign({}, settings['default']);
  910. if ( oldm.guild.id in settings ) setting = Object.assign({}, settings[oldm.guild.id]);
  911. var lang = i18n[setting.lang];
  912. if ( oldm.voiceChannel ) {
  913. var oldrole = oldm.guild.roles.find( role => role.name == lang.voice.channel + ' – ' + oldm.voiceChannel.name );
  914. if ( oldrole && oldrole.comparePositionTo(oldm.guild.me.highestRole) < 0 ) {
  915. oldm.removeRole( oldrole, lang.voice.left.replace( '%1$s', oldm.displayName ).replace( '%2$s', oldm.voiceChannel.name ) );
  916. console.log( oldm.guild.name + ': ' + oldm.displayName + ' hat den Sprachkanal "' + oldm.voiceChannel.name + '" verlassen.' );
  917. }
  918. }
  919. if ( newm.voiceChannel ) {
  920. var newrole = newm.guild.roles.find( role => role.name == lang.voice.channel + ' – ' + newm.voiceChannel.name );
  921. if ( newrole && newrole.comparePositionTo(newm.guild.me.highestRole) < 0 ) {
  922. newm.addRole( newrole, lang.voice.join.replace( '%1$s', newm.displayName ).replace( '%2$s', newm.voiceChannel.name ) );
  923. console.log( newm.guild.name + ': ' + newm.displayName + ' hat den Sprachkanal "' + newm.voiceChannel.name + '" betreten.' );
  924. }
  925. }
  926. }
  927. });
  928. client.on('guildCreate', guild => {
  929. 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( channel => channel.type == 'text' ).toString() + ' (' + guild.id + ')' ) );
  930. console.log( 'Ich wurde zu einem Server hinzugefügt.' );
  931. });
  932. client.on('guildDelete', guild => {
  933. 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( channel => channel.type == 'text' ).toString() + ' (' + guild.id + ')' ) );
  934. console.log( 'Ich wurde von einem Server entfernt.' );
  935. if ( !guild.available ) {
  936. console.log( 'Dieser Server ist nicht erreichbar.' );
  937. }
  938. else if ( settings == defaultSettings ) {
  939. console.log( 'Fehler beim Erhalten bestehender Einstellungen.' );
  940. }
  941. else {
  942. var temp_settings = Object.assign({}, settings);
  943. Object.keys(temp_settings).forEach( function(guild) {
  944. if ( !client.guilds.has(guild) && guild != 'default' ) delete temp_settings[guild];
  945. } );
  946. request.post( {
  947. uri: process.env.save + process.env.access,
  948. body: {
  949. branch: 'master',
  950. commit_message: 'Wiki-Bot: Einstellungen entfernt.',
  951. actions: [
  952. {
  953. action: 'update',
  954. file_path: process.env.file,
  955. content: JSON.stringify( temp_settings, null, '\t' )
  956. }
  957. ]
  958. },
  959. json: true
  960. }, function( error, response, body ) {
  961. if ( error || !response || response.statusCode != 201 || !body || body.error ) {
  962. console.log( 'Fehler beim Bearbeiten' + ( error ? ': ' + error.message : ( body ? ( body.message ? ': ' + body.message : ( body.error ? ': ' + body.error : '.' ) ) : '.' ) ) );
  963. }
  964. else {
  965. settings = Object.assign({}, temp_settings);
  966. console.log( 'Einstellungen erfolgreich aktualisiert.' );
  967. }
  968. } );
  969. }
  970. });
  971. client.login(process.env.token);