main.js 38 KB

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