main.js 43 KB

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