Bläddra i källkod

remove support for legacy Fandom

Markus-Rost 4 år sedan
förälder
incheckning
fc2664bece

+ 0 - 1
cmds/link.js

@@ -1,5 +1,4 @@
 const check_wiki = {
 const check_wiki = {
-	fandom: require('./wiki/fandom/general.js'),
 	general: require('./wiki/general.js'),
 	general: require('./wiki/general.js'),
 	test: require('./test.js').run
 	test: require('./test.js').run
 };
 };

+ 0 - 287
cmds/wiki/fandom/diff.js

@@ -1,287 +0,0 @@
-const {MessageEmbed} = require('discord.js');
-const logging = require('../../../util/logging.js');
-const {timeoptions} = require('../../../util/default.json');
-const {toFormatting, htmlToDiscord} = require('../../../util/functions.js');
-const diffParser = require('../../../util/edit_diff.js');
-
-/**
- * Processes a Fandom edit.
- * @param {import('../../../util/i18n.js')} lang - The user language.
- * @param {import('discord.js').Message} msg - The Discord message.
- * @param {String[]} args - The command arguments.
- * @param {import('../../../util/wiki.js')} wiki - The wiki for the edit.
- * @param {import('discord.js').MessageReaction} reaction - The reaction on the message.
- * @param {String} spoiler - If the response is in a spoiler.
- * @param {MessageEmbed} [embed] - The embed for the page.
- */
-function fandom_diff(lang, msg, args, wiki, reaction, spoiler, embed) {
-	if ( args[0] ) {
-		var error = false;
-		var title = '';
-		var revision = 0;
-		var diff = 'prev';
-		if ( /^\d+$/.test(args[0]) ) {
-			revision = args[0];
-			if ( args[1] ) {
-				if ( /^\d+$/.test(args[1]) ) {
-					diff = args[1];
-				}
-				else if ( args[1] === 'prev' || args[1] === 'next' ) {
-					diff = args[1];
-				}
-				else error = true;
-			}
-		}
-		else if ( args[0] === 'prev' || args[0] === 'next' ) {
-			diff = args[0];
-			if ( args[1] ) {
-				if ( /^\d+$/.test(args[1]) ) {
-					revision = args[1];
-				}
-				else error = true;
-			}
-			else error = true;
-		}
-		else title = args.join(' ');
-		
-		if ( error ) msg.reactEmoji('error');
-		else if ( /^\d+$/.test(diff) ) {
-			var argids = [];
-			if ( parseInt(revision, 10) > parseInt(diff, 10) ) argids = [revision, diff];
-			else if ( parseInt(revision, 10) === parseInt(diff, 10) ) argids = [revision];
-			else argids = [diff, revision];
-			fandom_diff_send(lang, msg, argids, wiki, reaction, spoiler);
-		}
-		else {
-			got.get( wiki + 'api.php?action=query&prop=revisions&rvprop=' + ( title ? '&titles=' + encodeURIComponent( title ) : '&revids=' + revision ) + '&rvdiffto=' + diff + '&format=json' ).then( response => {
-				var body = response.body;
-				if ( body && body.warnings ) log_warn(body.warnings);
-				if ( response.statusCode !== 200 || !body || !body.query ) {
-					if ( wiki.noWiki(response.url, response.statusCode) ) {
-						console.log( '- This wiki doesn\'t exist!' );
-						msg.reactEmoji('nowiki');
-					}
-					else {
-						console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
-						msg.sendChannelError( spoiler + '<' + wiki.toLink(title, ( title ? {diff} : {diff,oldid:revision} )) + '>' + spoiler );
-					}
-					
-					if ( reaction ) reaction.removeEmoji();
-				}
-				else {
-					if ( body.query.badrevids ) {
-						msg.replyMsg( lang.get('diff.badrev') );
-						
-						if ( reaction ) reaction.removeEmoji();
-					} else if ( body.query.pages && !body.query.pages[-1] ) {
-						var revisions = Object.values(body.query.pages)[0].revisions[0];
-						if ( revisions.texthidden === undefined ) {
-							var argids = [];
-							var ids = revisions.diff;
-							if ( !ids.from ) argids = [ids.to];
-							else {
-								argids = [ids.to, ids.from];
-								var compare = ['', ''];
-								if ( ids['*'] !== undefined ) {
-									let more = '\n__' + lang.get('diff.info.more') + '__';
-									let whitespace = '__' + lang.get('diff.info.whitespace') + '__';
-									compare = diffParser( ids['*'], more, whitespace );
-								}
-							}
-							fandom_diff_send(lang, msg, argids, wiki, reaction, spoiler, compare);
-						} else {
-							msg.replyMsg( lang.get('diff.badrev') );
-							
-							if ( reaction ) reaction.removeEmoji();
-						}
-					} else {
-						if ( body.query.pages && body.query.pages[-1] ) msg.replyMsg( lang.get('diff.badrev') );
-						else msg.reactEmoji('error');
-						
-						if ( reaction ) reaction.removeEmoji();
-					}
-				}
-			}, error => {
-				if ( wiki.noWiki(error.message) ) {
-					console.log( '- This wiki doesn\'t exist!' );
-					msg.reactEmoji('nowiki');
-				}
-				else {
-					console.log( '- Error while getting the search results: ' + error );
-					msg.sendChannelError( spoiler + '<' + wiki.toLink(title, ( title ? {diff} : {diff,oldid:revision} )) + '>' + spoiler );
-				}
-				
-				if ( reaction ) reaction.removeEmoji();
-			} );
-		}
-	}
-	else {
-		if ( embed ) msg.sendChannel( spoiler + '<' + embed.url + '>' + spoiler, {embed} );
-		else msg.reactEmoji('error');
-		
-		if ( reaction ) reaction.removeEmoji();
-	}
-}
-
-/**
- * Sends a Fandom edit.
- * @param {import('../../../util/i18n.js')} lang - The user language.
- * @param {import('discord.js').Message} msg - The Discord message.
- * @param {String[]} args - The command arguments.
- * @param {import('../../../util/wiki.js')} wiki - The wiki for the edit.
- * @param {import('discord.js').MessageReaction} reaction - The reaction on the message.
- * @param {String} spoiler - If the response is in a spoiler.
- * @param {String[]} [compare] - The edit difference.
- */
-function fandom_diff_send(lang, msg, args, wiki, reaction, spoiler, compare) {
-	got.get( wiki + 'api.php?action=query&meta=siteinfo&siprop=general&list=tags&tglimit=500&tgprop=displayname&prop=revisions&rvprop=ids|timestamp|flags|user|size|comment|tags' + ( args.length === 1 || args[0] === args[1] ? '|content' : '' ) + '&revids=' + args.join('|') + '&format=json' ).then( response => {
-		var body = response.body;
-		if ( body && body.warnings ) log_warn(body.warnings);
-		if ( response.statusCode !== 200 || !body || !body.query ) {
-			if ( wiki.noWiki(response.url, response.statusCode) ) {
-				console.log( '- This wiki doesn\'t exist!' );
-				msg.reactEmoji('nowiki');
-			}
-			else {
-				console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
-				msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Diff/' + ( args[1] ? args[1] + '/' : '' ) + args[0]) + '>' + spoiler );
-			}
-			
-			if ( reaction ) reaction.removeEmoji();
-		}
-		else if ( body.query.badrevids ) {
-			msg.replyMsg( lang.get('diff.badrev') );
-			
-			if ( reaction ) reaction.removeEmoji();
-		}
-		else if ( body.query.pages && !body.query.pages['-1'] ) {
-			wiki.updateWiki(body.query.general);
-			logging(wiki, msg.guild?.id, 'diff', 'legacy');
-			var pages = Object.values(body.query.pages);
-			if ( pages.length !== 1 ) {
-				msg.sendChannel( spoiler + '<' + wiki.toLink('Special:Diff/' + ( args[1] ? args[1] + '/' : '' ) + args[0]) + '>' + spoiler );
-				
-				if ( reaction ) reaction.removeEmoji();
-			}
-			else {
-				var title = pages[0].title;
-				var revisions = pages[0].revisions.sort( (first, second) => Date.parse(second.timestamp) - Date.parse(first.timestamp) );
-				var diff = revisions[0].revid;
-				var oldid = ( revisions[1] ? revisions[1].revid : 0 );
-				var editor = [lang.get('diff.info.editor'), ( revisions[0].userhidden !== undefined ? lang.get('diff.hidden') : revisions[0].user )];
-				try {
-					var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-						timeZone: body.query.general.timezone
-					}, timeoptions));
-				}
-				catch ( error ) {
-					var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-						timeZone: 'UTC'
-					}, timeoptions));
-				}
-				var timestamp = [lang.get('diff.info.timestamp'), dateformat.format(new Date(revisions[0].timestamp))];
-				var difference = revisions[0].size - ( revisions[1] ? revisions[1].size : 0 );
-				var size = [lang.get('diff.info.size'), lang.get('diff.info.bytes', ( difference > 0 ? '+' : '' ) + difference.toLocaleString(lang.get('dateformat')), difference)];
-				var comment = [lang.get('diff.info.comment'), ( revisions[0].commenthidden !== undefined ? lang.get('diff.hidden') : ( revisions[0].comment ? toFormatting(revisions[0].comment, msg.showEmbed(), wiki, title) : lang.get('diff.nocomment') ) )];
-				if ( revisions[0].tags.length ) var tags = [lang.get('diff.info.tags'), body.query.tags.filter( tag => revisions[0].tags.includes( tag.name ) ).map( tag => tag.displayname ).join(', ')];
-				
-				var pagelink = wiki.toLink(title, {diff,oldid});
-				if ( msg.showEmbed() ) {
-					var text = '<' + pagelink + '>';
-					var editorlink = '[' + editor[1] + '](' + wiki.toLink('User:' + editor[1], '', '', true) + ')';
-					if ( revisions[0].anon !== undefined ) {
-						editorlink = '[' + editor[1] + '](' + wiki.toLink('Special:Contributions/' + editor[1], '', '', true) + ')';
-					}
-					if ( editor[1] === lang.get('diff.hidden') ) editorlink = editor[1];
-					var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( ( title + '?diff=' + diff + '&oldid=' + oldid ).escapeFormatting() ).setURL( pagelink ).addField( editor[0], editorlink, true ).addField( size[0], size[1], true ).addField( comment[0], comment[1] ).setFooter( timestamp[1] );
-					if ( tags ) embed.addField( tags[0], htmlToDiscord(tags[1], pagelink, true) );
-					
-					var more = '\n__' + lang.get('diff.info.more') + '__';
-					var whitespace = '__' + lang.get('diff.info.whitespace') + '__';
-					if ( !compare && oldid ) got.get( wiki + 'api.php?action=query&prop=revisions&rvprop=&revids=' + oldid + '&rvdiffto=' + diff + '&format=json' ).then( cpresponse => {
-						var cpbody = cpresponse.body;
-						if ( cpbody && cpbody.warnings ) log_warn(cpbody.warnings);
-						if ( cpresponse.statusCode !== 200 || !cpbody || !cpbody.query || cpbody.query.badrevids || !cpbody.query.pages && cpbody.query.pages[-1] ) {
-							console.log( '- ' + cpresponse.statusCode + ': Error while getting the diff: ' + ( cpbody && cpbody.error && cpbody.error.info ) );
-						}
-						else {
-							var revision = Object.values(cpbody.query.pages)[0].revisions[0];
-							if ( revision.texthidden === undefined && revision.diff && revision.diff['*'] !== undefined ) {
-								let edit_diff = diffParser( revision.diff['*'], more, whitespace )
-								if ( edit_diff[0].length ) {
-									embed.addField( lang.get('diff.info.removed'), edit_diff[0], true );
-								}
-								if ( edit_diff[1].length ) {
-									embed.addField( lang.get('diff.info.added'), edit_diff[1], true );
-								}
-							}
-							else if ( revision.texthidden !== undefined ) {
-								embed.addField( lang.get('diff.info.added'), '__' + lang.get('diff.hidden') + '__', true );
-							}
-							else if ( revision.diff && revision.diff['*'] === undefined ) {
-								embed.addField( lang.get('diff.info.removed'), '__' + lang.get('diff.hidden') + '__', true );
-							}
-						}
-					}, error => {
-						console.log( '- Error while getting the diff: ' + error );
-					} ).finally( () => {
-						msg.sendChannel( spoiler + text + spoiler, {embed} );
-						
-						if ( reaction ) reaction.removeEmoji();
-					} );
-					else {
-						if ( compare ) {
-							if ( compare[0].length ) embed.addField( lang.get('diff.info.removed'), compare[0], true );
-							if ( compare[1].length ) embed.addField( lang.get('diff.info.added'), compare[1], true );
-						}
-						else if ( revisions[0]['*'] ) {
-							var content = revisions[0]['*'].escapeFormatting();
-							if ( content.trim().length ) {
-								if ( content.length <= 1000 ) content = '**' + content + '**';
-								else {
-									content = content.substring(0, 1000 - more.length);
-									content = '**' + content.substring(0, content.lastIndexOf('\n')) + '**' + more;
-								}
-								embed.addField( lang.get('diff.info.added'), content, true );
-							} else embed.addField( lang.get('diff.info.added'), whitespace, true );
-						}
-						
-						msg.sendChannel( spoiler + text + spoiler, {embed} );
-						
-						if ( reaction ) reaction.removeEmoji();
-					}
-				}
-				else {
-					var embed = {};
-					var text = '<' + pagelink + '>\n\n' + editor.join(' ') + '\n' + timestamp.join(' ') + '\n' + size.join(' ') + '\n' + comment.join(' ');
-					if ( tags ) text += htmlToDiscord( '\n' + tags.join(' ') );
-					
-					msg.sendChannel( spoiler + text + spoiler, {embed} );
-					
-					if ( reaction ) reaction.removeEmoji();
-				}
-			}
-		}
-		else {
-			msg.reactEmoji('error');
-			
-			if ( reaction ) reaction.removeEmoji();
-		}
-	}, error => {
-		if ( wiki.noWiki(error.message) ) {
-			console.log( '- This wiki doesn\'t exist!' );
-			msg.reactEmoji('nowiki');
-		}
-		else {
-			console.log( '- Error while getting the search results: ' + error );
-			msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Diff/' + ( args[1] ? args[1] + '/' : '' ) + args[0]) + '>' + spoiler );
-		}
-		
-		if ( reaction ) reaction.removeEmoji();
-	} );
-}
-
-module.exports = {
-	name: 'diff',
-	run: fandom_diff
-};

+ 0 - 516
cmds/wiki/fandom/general.js

@@ -1,516 +0,0 @@
-const htmlparser = require('htmlparser2');
-const {MessageEmbed} = require('discord.js');
-const logging = require('../../../util/logging.js');
-const {limit: {interwiki: interwikiLimit}, wikiProjects} = require('../../../util/default.json');
-const Wiki = require('../../../util/wiki.js');
-
-const fs = require('fs');
-var fn = {
-	special_page: require('../../../functions/special_page.js'),
-	discussion: require('../../../functions/discussion.js')
-};
-fs.readdir( './cmds/wiki/fandom', (error, files) => {
-	if ( error ) return error;
-	files.filter( file => ( file !== 'general.js' && file.endsWith('.js') ) ).forEach( file => {
-		var command = require('./' + file);
-		fn[command.name] = command.run;
-	} );
-} );
-
-/**
- * Checks a Fandom wiki.
- * @param {import('../../../util/i18n.js')} lang - The user language.
- * @param {import('discord.js').Message} msg - The Discord message.
- * @param {String} title - The page title.
- * @param {Wiki} wiki - The wiki for the page.
- * @param {String} cmd - The command at this point.
- * @param {import('discord.js').MessageReaction} reaction - The reaction on the message.
- * @param {String} [spoiler] - If the response is in a spoiler.
- * @param {URLSearchParams} [querystring] - The querystring for the link.
- * @param {String} [fragment] - The section for the link.
- * @param {String} [interwiki] - The fallback interwiki link.
- * @param {Number} [selfcall] - The amount of followed interwiki links.
- */
-function fandom_check_wiki(lang, msg, title, wiki, cmd, reaction, spoiler = '', querystring = new URLSearchParams(), fragment = '', interwiki = '', selfcall = 0) {
-	var full_title = title;
-	if ( title.includes( '#' ) ) {
-		fragment = title.split('#').slice(1).join('#');
-		title = title.split('#')[0];
-	}
-	if ( /\?\w+=/.test(title) ) {
-		var querystart = title.search(/\?\w+=/);
-		querystring = new URLSearchParams(querystring + '&' + title.substring(querystart + 1));
-		title = title.substring(0, querystart);
-	}
-	if ( title.length > 250 ) {
-		title = title.substring(0, 250);
-		msg.reactEmoji('⚠️');
-	}
-	var invoke = title.split(' ')[0].toLowerCase();
-	var aliasInvoke = ( lang.aliases[invoke] || invoke );
-	var args = title.split(' ').slice(1);
-	
-	if ( aliasInvoke === 'random' && !args.join('') && !querystring.toString() && !fragment ) {
-		return fn.random(lang, msg, wiki, reaction, spoiler);
-	}
-	if ( aliasInvoke === 'overview' && !args.join('') && !querystring.toString() && !fragment ) {
-		return fn.overview(lang, msg, wiki, reaction, spoiler);
-	}
-	if ( aliasInvoke === 'test' && !args.join('') && !querystring.toString() && !fragment ) {
-		this.test(lang, msg, args, '', wiki);
-		if ( reaction ) reaction.removeEmoji();
-		return;
-	}
-	if ( aliasInvoke === 'page' ) {
-		msg.sendChannel( spoiler + '<' + wiki.toLink(args.join('_'), querystring, fragment) + '>' + spoiler );
-		if ( reaction ) reaction.removeEmoji();
-		return;
-	}
-	if ( aliasInvoke === 'diff' && args.join('') && !querystring.toString() && !fragment ) {
-		return fn.diff(lang, msg, args, wiki, reaction, spoiler);
-	}
-	var noRedirect = ( querystring.getAll('redirect').pop() === 'no' || ( querystring.has('action') && querystring.getAll('action').pop() !== 'view' ) );
-	got.get( wiki + 'api.php?action=query&meta=allmessages|siteinfo&ammessages=description&amenableparser=true&siprop=general|namespaces|specialpagealiases&iwurl=true' + ( noRedirect ? '' : '&redirects=true' ) + '&prop=imageinfo|categoryinfo&converttitles=true&titles=' + encodeURIComponent( title.replace( /\|/g, '\ufffd' ) ) + '&format=json' ).then( response => {
-		var body = response.body;
-		if ( body && body.warnings ) log_warn(body.warnings);
-		if ( response.statusCode !== 200 || !body || !body.query ) {
-			if ( interwiki ) msg.sendChannel( spoiler + ' ' + interwiki + ' ' + spoiler );
-			else if ( wiki.noWiki(response.url, response.statusCode) ) {
-				console.log( '- This wiki doesn\'t exist!' );
-				msg.reactEmoji('nowiki');
-			}
-			else {
-				console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
-				msg.sendChannelError( spoiler + '<' + wiki.toLink(( querystring.toString() || fragment || !title ? title : 'Special:Search' ), ( querystring.toString() || fragment || !title ? querystring : {search:title} ), fragment) + '>' + spoiler );
-			}
-			
-			if ( reaction ) reaction.removeEmoji();
-			return;
-		}
-		wiki.updateWiki(body.query.general);
-		if ( aliasInvoke === 'search' ) {
-			logging(wiki, msg.guild?.id, 'search', 'legacy');
-			return fn.search(lang, msg, full_title.split(' ').slice(1).join(' '), wiki, body.query, reaction, spoiler);
-		}
-		if ( aliasInvoke === 'discussion' && !querystring.toString() && !fragment ) {
-			logging(wiki, msg.guild?.id, 'discussion', 'legacy');
-			return fn.discussion(lang, msg, wiki, args.join(' '), body.query.general.sitename, reaction, spoiler);
-		}
-		if ( body.query.pages ) {
-			logging(wiki, msg.guild?.id, 'general', 'legacy');
-			var querypages = Object.values(body.query.pages);
-			var querypage = querypages[0];
-			if ( body.query.redirects && body.query.redirects[0].from.split(':')[0] === body.query.namespaces['-1']['*'] && body.query.specialpagealiases.filter( sp => ['Mypage','Mytalk','MyLanguage'].includes( sp.realname ) ).map( sp => sp.aliases[0] ).includes( body.query.redirects[0].from.split(':').slice(1).join(':').split('/')[0].replace( / /g, '_' ) ) ) {
-				querypage.title = body.query.redirects[0].from;
-				delete body.query.redirects[0].tofragment;
-				delete querypage.missing;
-				querypage.ns = -1;
-				querypage.special = '';
-			}
-			
-			var contribs = body.query.namespaces['-1']['*'] + ':' + body.query.specialpagealiases.find( sp => sp.realname === 'Contributions' ).aliases[0] + '/';
-			if ( querypage.ns === 2 && ( !querypage.title.includes( '/' ) || /^[^:]+:(?:(?:\d{1,3}\.){3}\d{1,3}\/\d{2}|(?:[\dA-F]{1,4}:){7}[\dA-F]{1,4}\/\d{2,3})$/.test(querypage.title) ) ) {
-				var userparts = querypage.title.split(':');
-				querypage.noRedirect = noRedirect;
-				fn.user(lang, msg, userparts[0] + ':', userparts.slice(1).join(':'), wiki, querystring, fragment, querypage, contribs, reaction, spoiler);
-			}
-			else if ( querypage.ns === -1 && querypage.title.startsWith( contribs ) && querypage.title.length > contribs.length ) {
-				var username = querypage.title.split('/').slice(1).join('/');
-				got.get( wiki + 'api.php?action=query&titles=User:' + encodeURIComponent( username ) + '&format=json' ).then( uresponse => {
-					var ubody = uresponse.body;
-					if ( uresponse.statusCode !== 200 || !ubody || !ubody.query ) {
-						console.log( '- ' + uresponse.statusCode + ': Error while getting the user: ' + ( ubody && ubody.error && ubody.error.info ) );
-						msg.sendChannelError( spoiler + '<' + wiki.toLink(contribs + username, querystring, fragment) + '>' + spoiler );
-						
-						if ( reaction ) reaction.removeEmoji();
-					}
-					else {
-						querypage = Object.values(ubody.query.pages)[0];
-						if ( querypage.ns === 2 ) {
-							username = querypage.title.split(':').slice(1).join(':');
-							querypage.title = contribs + username;
-							delete querypage.missing;
-							querypage.ns = -1;
-							querypage.special = '';
-							querypage.noRedirect = noRedirect;
-							fn.user(lang, msg, contribs, username, wiki, querystring, fragment, querypage, contribs, reaction, spoiler);
-						}
-						else {
-							msg.reactEmoji('error');
-							
-							if ( reaction ) reaction.removeEmoji();
-						}
-					}
-				}, error => {
-					console.log( '- Error while getting the user: ' + error );
-					msg.sendChannelError( spoiler + '<' + wiki.toLink(contribs + username, querystring, fragment) + '>' + spoiler );
-					
-					if ( reaction ) reaction.removeEmoji();
-				} );
-			}
-			else if ( querypage.ns === 1201 && querypage.missing !== undefined ) {
-				var thread = querypage.title.split(':');
-				got.get( wiki + 'api.php?action=query&prop=revisions&rvprop=user&rvdir=newer&rvlimit=1&pageids=' + thread.slice(1).join(':') + '&format=json' ).then( thresponse => {
-					var thbody = thresponse.body;
-					if ( thresponse.statusCode !== 200 || !thbody || !thbody.query || !thbody.query.pages ) {
-						console.log( '- ' + thresponse.statusCode + ': Error while getting the thread: ' + ( thbody && thbody.error && thbody.error.info ) );
-						msg.sendChannelError( spoiler + '<' + wiki.toLink(querypage.title, querystring, fragment) + '>' + spoiler );
-						
-						if ( reaction ) reaction.removeEmoji();
-					}
-					else {
-						querypage = thbody.query.pages[thread.slice(1).join(':')];
-						if ( querypage.missing !== undefined ) {
-							msg.reactEmoji('🤷');
-							
-							if ( reaction ) reaction.removeEmoji();
-						}
-						else {
-							var pagelink = wiki.toLink(thread.join(':'), querystring, fragment);
-							var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( thread.join(':').escapeFormatting() ).setURL( pagelink ).setFooter( querypage.revisions[0].user );
-							got.get( wiki.toDescLink(querypage.title), {
-								responseType: 'text'
-							} ).then( descresponse => {
-								var descbody = descresponse.body;
-								if ( descresponse.statusCode !== 200 || !descbody ) {
-									console.log( '- ' + descresponse.statusCode + ': Error while getting the description.' );
-								} else {
-									var thumbnail = wiki.toLink('Special:FilePath/Wiki-wordmark.png');
-									var parser = new htmlparser.Parser( {
-										onopentag: (tagname, attribs) => {
-											if ( tagname === 'meta' && attribs.property === 'og:description' ) {
-												var description = attribs.content.escapeFormatting();
-												if ( description.length > 1000 ) description = description.substring(0, 1000) + '\u2026';
-												embed.setDescription( description );
-											}
-											if ( tagname === 'meta' && attribs.property === 'og:image' ) {
-												thumbnail = attribs.content;
-											}
-										}
-									} );
-									parser.write( descbody );
-									parser.end();
-									embed.setThumbnail( thumbnail );
-								}
-							}, error => {
-								console.log( '- Error while getting the description: ' + error );
-							} ).finally( () => {
-								msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-								
-								if ( reaction ) reaction.removeEmoji();
-							} );
-						}
-					}
-				}, error => {
-					console.log( '- Error while getting the thread: ' + error );
-					msg.sendChannelError( spoiler + '<' + wiki.toLink(querypage.title, querystring, fragment) + '>' + spoiler );
-					
-					if ( reaction ) reaction.removeEmoji();
-				} );
-			}
-			else if ( ( querypage.missing !== undefined && querypage.known === undefined && !( noRedirect || querypage.categoryinfo ) ) || querypage.invalid !== undefined ) {
-				got.get( wiki + 'api/v1/Search/List?minArticleQuality=0&namespaces=4,12,14,' + Object.values(body.query.namespaces).filter( ns => ns.content !== undefined ).map( ns => ns.id ).join(',') + '&limit=1&query=' + encodeURIComponent( title ) + '&format=json&cache=' + Date.now() ).then( wsresponse => {
-					var wsbody = wsresponse.body;
-					if ( wsresponse.statusCode !== 200 || !wsbody || wsbody.exception || !wsbody.total || !wsbody.items || !wsbody.items.length ) {
-						if ( wsbody && ( !wsbody.total || ( wsbody.items && !wsbody.items.length ) || ( wsbody.exception && wsbody.exception.code === 404 ) ) ) msg.reactEmoji('🤷');
-						else {
-							console.log( '- ' + wsresponse.statusCode + ': Error while getting the search results: ' + ( wsbody && wsbody.exception && wsbody.exception.details ) );
-							msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Search', {search:title}) + '>' + spoiler );
-						}
-						
-						if ( reaction ) reaction.removeEmoji();
-					}
-					else {
-						querypage = wsbody.items[0];
-						if ( querypage.ns && !querypage.title.startsWith( body.query.namespaces[querypage.ns]['*'] + ':' ) ) {
-							querypage.title = body.query.namespaces[querypage.ns]['*'] + ':' + querypage.title;
-						}
-						
-						var text = '';
-						var prefix = ( msg.channel.isGuild() && patreons[msg.guild.id] || process.env.prefix );
-						var linksuffix = ( querystring.toString() ? '?' + querystring : '' ) + ( fragment ? '#' + fragment : '' );
-						if ( title.replace( /[_-]/g, ' ' ).toLowerCase() === querypage.title.replace( /-/g, ' ' ).toLowerCase() ) {
-							text = '';
-						}
-						else if ( wsbody.total === 1 ) {
-							text = '\n' + lang.get('search.infopage', '`' + prefix + cmd + ( lang.localNames.page || 'page' ) + ' ' + title + linksuffix + '`');
-						}
-						else {
-							text = '\n' + lang.get('search.infosearch', '`' + prefix + cmd + ( lang.localNames.page || 'page' ) + ' ' + title + linksuffix + '`', '`' + prefix + cmd + ( lang.localNames.search || 'search' ) + ' ' + title + linksuffix + '`');
-						}
-						got.get( wiki + 'api.php?action=query&prop=imageinfo|categoryinfo&titles=' + encodeURIComponent( querypage.title ) + '&format=json' ).then( srresponse => {
-							var srbody = srresponse.body;
-							if ( srbody && srbody.warnings ) log_warn(srbody.warnings);
-							if ( srresponse.statusCode !== 200 || !srbody || !srbody.query || !srbody.query.pages ) {
-								console.log( '- ' + srresponse.statusCode + ': Error while getting the search results: ' + ( srbody && srbody.error && srbody.error.info ) );
-								msg.sendChannelError( spoiler + '<' + wiki.toLink(querypage.title, querystring, fragment) + '>' + spoiler );
-								
-								if ( reaction ) reaction.removeEmoji();
-							}
-							else {
-								querypage = Object.values(srbody.query.pages)[0];
-								var pagelink = wiki.toLink(querypage.title, querystring, fragment);
-								var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( querypage.title.escapeFormatting() ).setURL( pagelink );
-								if ( querypage.imageinfo ) {
-									var filename = querypage.title.replace( body.query.namespaces['6']['*'] + ':', '' );
-									var pageimage = wiki.toLink('Special:FilePath/' + filename, {version:Date.now()});
-									if ( msg.showEmbed() && /\.(?:png|jpg|jpeg|gif)$/.test(querypage.title.toLowerCase()) ) embed.setImage( pageimage );
-									else if ( msg.uploadFiles() ) embed.attachFiles( [{attachment:pageimage,name:( spoiler ? 'SPOILER ' : '' ) + filename}] );
-								}
-								if ( querypage.categoryinfo ) {
-									var category = [lang.get('search.category.content')];
-									if ( querypage.categoryinfo.size === 0 ) {
-										category.push(lang.get('search.category.empty'));
-									}
-									if ( querypage.categoryinfo.pages > 0 ) {
-										category.push(lang.get('search.category.pages', querypage.categoryinfo.pages.toLocaleString(lang.get('dateformat')), querypage.categoryinfo.pages));
-									}
-									if ( querypage.categoryinfo.files > 0 ) {
-										category.push(lang.get('search.category.files', querypage.categoryinfo.files.toLocaleString(lang.get('dateformat')), querypage.categoryinfo.files));
-									}
-									if ( querypage.categoryinfo.subcats > 0 ) {
-										category.push(lang.get('search.category.subcats', querypage.categoryinfo.subcats.toLocaleString(lang.get('dateformat')), querypage.categoryinfo.subcats));
-									}
-									if ( msg.showEmbed() ) embed.addField( category[0], category.slice(1).join('\n') );
-									else text += '\n\n' + category.join('\n');
-								}
-								
-								if ( querypage.title === body.query.general.mainpage && body.query.allmessages[0]['*'] ) {
-									embed.setDescription( body.query.allmessages[0]['*'] );
-									embed.setThumbnail( wiki.toLink('Special:FilePath/Wiki-wordmark.png') );
-									
-									msg.sendChannel( spoiler + '<' + pagelink + '>' + text + spoiler, {embed} );
-									
-									if ( reaction ) reaction.removeEmoji();
-								}
-								else got.get( wiki.toDescLink(querypage.title), {
-									responseType: 'text'
-								} ).then( descresponse => {
-									var descbody = descresponse.body;
-									if ( descresponse.statusCode !== 200 || !descbody ) {
-										console.log( '- ' + descresponse.statusCode + ': Error while getting the description.' );
-									} else {
-										var thumbnail = wiki.toLink('Special:FilePath/Wiki-wordmark.png');
-										var parser = new htmlparser.Parser( {
-											onopentag: (tagname, attribs) => {
-												if ( tagname === 'meta' && attribs.property === 'og:description' ) {
-													var description = attribs.content.escapeFormatting();
-													if ( description.length > 1000 ) description = description.substring(0, 1000) + '\u2026';
-													embed.setDescription( description );
-												}
-												if ( tagname === 'meta' && attribs.property === 'og:image' && querypage.title !== body.query.general.mainpage ) {
-													thumbnail = attribs.content;
-												}
-											}
-										}, {decodeEntities:true} );
-										parser.write( descbody );
-										parser.end();
-										if ( !querypage.imageinfo ) embed.setThumbnail( thumbnail );
-									}
-								}, error => {
-									console.log( '- Error while getting the description: ' + error );
-								} ).finally( () => {
-									msg.sendChannel( spoiler + '<' + pagelink + '>' + text + spoiler, {embed} );
-									
-									if ( reaction ) reaction.removeEmoji();
-								} );
-							}
-						}, error => {
-							console.log( '- Error while getting the search results: ' + error );
-							msg.sendChannelError( spoiler + '<' + wiki.toLink(querypage.title, querystring, fragment) + '>' + spoiler );
-							
-							if ( reaction ) reaction.removeEmoji();
-						} );
-					}
-				}, error => {
-					console.log( '- Error while getting the search results: ' + error );
-					msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Search', {search:title}) + '>' + spoiler );
-					
-					if ( reaction ) reaction.removeEmoji();
-				} );
-			}
-			else if ( querypage.ns === -1 ) {
-				var pagelink = wiki.toLink(querypage.title, querystring, fragment);
-				var embed =  new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( querypage.title.escapeFormatting() ).setURL( pagelink ).setThumbnail( wiki.toLink('Special:FilePath/Wiki-wordmark.png') );
-				var specialpage = body.query.specialpagealiases.find( sp => body.query.namespaces['-1']['*'] + ':' + sp.aliases[0].replace( /\_/g, ' ' ) === querypage.title.split('/')[0] );
-				specialpage = ( specialpage ? specialpage.realname : querypage.title.replace( body.query.namespaces['-1']['*'] + ':', '' ).split('/')[0] ).toLowerCase();
-				fn.special_page(lang, msg, querypage.title, specialpage, embed, wiki, reaction, spoiler);
-			}
-			else {
-				var pagelink = wiki.toLink(querypage.title, querystring, ( fragment || ( body.query.redirects && body.query.redirects[0].tofragment || '' ) ));
-				var text = '';
-				var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( querypage.title.escapeFormatting() ).setURL( pagelink );
-				if ( querypage.imageinfo ) {
-					var filename = querypage.title.replace( body.query.namespaces['6']['*'] + ':', '' );
-					var pageimage = wiki.toLink('Special:FilePath/' + filename, {version:Date.now()});
-					if ( msg.showEmbed() && /\.(?:png|jpg|jpeg|gif)$/.test(querypage.title.toLowerCase()) ) embed.setImage( pageimage );
-					else if ( msg.uploadFiles() ) embed.attachFiles( [{attachment:pageimage,name:( spoiler ? 'SPOILER ' : '' ) + filename}] );
-				}
-				if ( querypage.categoryinfo ) {
-					var category = [lang.get('search.category.content')];
-					if ( querypage.categoryinfo.size === 0 ) {
-						category.push(lang.get('search.category.empty'));
-					}
-					if ( querypage.categoryinfo.pages > 0 ) {
-						category.push(lang.get('search.category.pages', querypage.categoryinfo.pages.toLocaleString(lang.get('dateformat')), querypage.categoryinfo.pages));
-					}
-					if ( querypage.categoryinfo.files > 0 ) {
-						category.push(lang.get('search.category.files', querypage.categoryinfo.files.toLocaleString(lang.get('dateformat')), querypage.categoryinfo.files));
-					}
-					if ( querypage.categoryinfo.subcats > 0 ) {
-						category.push(lang.get('search.category.subcats', querypage.categoryinfo.subcats.toLocaleString(lang.get('dateformat')), querypage.categoryinfo.subcats));
-					}
-					if ( msg.showEmbed() ) embed.addField( category[0], category.slice(1).join('\n') );
-					else text += '\n\n' + category.join('\n');
-				}
-				
-				if ( querypage.title === body.query.general.mainpage && body.query.allmessages[0]['*'] ) {
-					embed.setDescription( body.query.allmessages[0]['*'] );
-					embed.setThumbnail( wiki.toLink('Special:FilePath/Wiki-wordmark.png') );
-					
-					msg.sendChannel( spoiler + '<' + pagelink + '>' + text + spoiler, {embed} );
-					
-					if ( reaction ) reaction.removeEmoji();
-				}
-				else got.get( wiki.toDescLink(querypage.title), {
-					responseType: 'text'
-				} ).then( descresponse => {
-					var descbody = descresponse.body;
-					if ( descresponse.statusCode !== 200 || !descbody ) {
-						console.log( '- ' + descresponse.statusCode + ': Error while getting the description.' );
-					} else {
-						var thumbnail = wiki.toLink('Special:FilePath/Wiki-wordmark.png');
-						var parser = new htmlparser.Parser( {
-							onopentag: (tagname, attribs) => {
-								if ( tagname === 'meta' && attribs.property === 'og:description' ) {
-									var description = attribs.content.escapeFormatting();
-									if ( description.length > 1000 ) description = description.substring(0, 1000) + '\u2026';
-									embed.setDescription( description );
-								}
-								if ( tagname === 'meta' && attribs.property === 'og:image' && querypage.title !== body.query.general.mainpage ) {
-									thumbnail = attribs.content;
-								}
-							}
-						}, {decodeEntities:true} );
-						parser.write( descbody );
-						parser.end();
-						if ( !querypage.imageinfo ) embed.setThumbnail( thumbnail );
-					}
-				}, error => {
-					console.log( '- Error while getting the description: ' + error );
-				} ).finally( () => {
-					msg.sendChannel( spoiler + '<' + pagelink + '>' + text + spoiler, {embed} );
-					
-					if ( reaction ) reaction.removeEmoji();
-				} );
-			}
-		}
-		else if ( body.query.interwiki ) {
-			if ( msg.channel.isGuild() && pause[msg.guild.id] ) {
-				if ( reaction ) reaction.removeEmoji();
-				console.log( '- Aborted, paused.' );
-				return;
-			}
-			logging(wiki, msg.guild?.id, 'interwiki', 'legacy');
-			var iw = new URL(body.query.interwiki[0].url.replace( /\\/g, '%5C' ).replace( /@(here|everyone)/g, '%40$1' ), wiki);
-			querystring.forEach( (value, name) => {
-				iw.searchParams.append(name, value);
-			} );
-			if ( fragment ) iw.hash = Wiki.toSection(fragment);
-			else fragment = iw.hash.substring(1);
-			var maxselfcall = interwikiLimit[( patreons[msg.guild?.id] ? 'patreon' : 'default' )];
-			if ( selfcall < maxselfcall && ['http:','https:'].includes( iw.protocol ) ) {
-				selfcall++;
-				if ( iw.hostname.endsWith( '.fandom.com' ) || iw.hostname.endsWith( '.wikia.org' ) ) {
-					let regex = iw.pathname.match( /^(\/(?!wiki\/)[a-z-]{2,12})?(?:\/wiki\/|\/?$)/ );
-					if ( regex ) {
-						let path = ( regex[1] || '' );
-						let iwtitle = decodeURIComponent( iw.pathname.replace( regex[0], '' ) ).replace( /_/g, ' ' );
-						cmd = ( iw.hostname.endsWith( '.wikia.org' ) ? '??' : '?' ) + ( path ? path.substring(1) + '.' : '' ) + iw.hostname.replace( /\.(?:fandom\.com|wikia\.org)/, ' ' );
-						return this.general(lang, msg, iwtitle, new Wiki(iw.origin + path + '/'), cmd, reaction, spoiler, iw.searchParams, fragment, iw.href, selfcall);
-					}
-				}
-				if ( iw.hostname.endsWith( '.gamepedia.com' ) ) {
-					let iwtitle = decodeURIComponent( iw.pathname.substring(1) ).replace( /_/g, ' ' );
-					cmd = '!' + iw.hostname.replace( '.gamepedia.com', ' ' );
-					if ( cmd !== '!www ' ) return this.general(lang, msg, iwtitle, new Wiki(iw.origin), cmd, reaction, spoiler, iw.searchParams, fragment, iw.href, selfcall);
-				}
-				let project = wikiProjects.find( project => iw.hostname.endsWith( project.name ) );
-				if ( project ) {
-					let regex = ( iw.host + iw.pathname ).match( new RegExp( '^' + project.regex + '(?:' + project.articlePath + '|/?$)' ) );
-					if ( regex ) {
-						let iwtitle = decodeURIComponent( ( iw.host + iw.pathname ).replace( regex[0], '' ) ).replace( /_/g, ' ' );
-						cmd = '!!' + regex[1] + ' ';
-						return this.general(lang, msg, iwtitle, new Wiki('https://' + regex[1] + project.scriptPath), cmd, reaction, spoiler, iw.searchParams, fragment, iw.href, selfcall);
-					}
-				}
-			}
-			msg.sendChannel( spoiler + ' ' + iw + ' ' + spoiler ).then( message => {
-				if ( message && selfcall === maxselfcall ) message.reactEmoji('⚠️');
-			} );
-			if ( reaction ) reaction.removeEmoji();
-		}
-		else if ( body.query.redirects ) {
-			logging(wiki, msg.guild?.id, 'general', 'legacy');
-			var pagelink = wiki.toLink(body.query.redirects[0].to, querystring, ( fragment || body.query.redirects[0].tofragment || '' ));
-			var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( body.query.redirects[0].to.escapeFormatting() ).setURL( pagelink ).setThumbnail( wiki.toLink('Special:FilePath/Wiki-wordmark.png') );
-			
-			msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-			
-			if ( reaction ) reaction.removeEmoji();;
-		}
-		else {
-			logging(wiki, msg.guild?.id, 'general', 'legacy');
-			var pagelink = wiki.toLink(body.query.general.mainpage, querystring, fragment);
-			var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( body.query.general.mainpage.escapeFormatting() ).setURL( pagelink ).setThumbnail( wiki.toLink('Special:FilePath/Wiki-wordmark.png') );
-			
-			if ( body.query.allmessages[0]['*'] ) {
-				embed.setDescription( body.query.allmessages[0]['*'] );
-				
-				msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-				
-				if ( reaction ) reaction.removeEmoji();
-			}
-			else got.get( wiki.toDescLink(body.query.general.mainpage), {
-				responseType: 'text'
-			} ).then( descresponse => {
-				var descbody = descresponse.body;
-				if ( descresponse.statusCode !== 200 || !descbody ) {
-					console.log( '- ' + descresponse.statusCode + ': Error while getting the description.' );
-				} else {
-					var parser = new htmlparser.Parser( {
-						onopentag: (tagname, attribs) => {
-							if ( tagname === 'meta' && attribs.property === 'og:description' ) {
-								var description = attribs.content.escapeFormatting();
-								if ( description.length > 1000 ) description = description.substring(0, 1000) + '\u2026';
-								embed.setDescription( description );
-							}
-						}
-					}, {decodeEntities:true} );
-					parser.write( descbody );
-					parser.end();
-				}
-			}, error => {
-				console.log( '- Error while getting the description: ' + error );
-			} ).finally( () => {
-				msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-				
-				if ( reaction ) reaction.removeEmoji();
-			} );
-		}
-	}, error => {
-		if ( interwiki ) msg.sendChannel( spoiler + ' ' + interwiki + ' ' + spoiler );
-		else if ( wiki.noWiki(error.message) ) {
-			console.log( '- This wiki doesn\'t exist!' );
-			msg.reactEmoji('nowiki');
-		}
-		else {
-			console.log( '- Error while getting the search results: ' + error );
-			msg.sendChannelError( spoiler + '<' + wiki.toLink(( querystring.toString() || fragment || !title ? title : 'Special:Search' ), ( querystring.toString() || fragment || !title ? querystring : {search:title} ), fragment) + '>' + spoiler );
-		}
-		
-		if ( reaction ) reaction.removeEmoji();
-	} );
-}
-
-module.exports = fandom_check_wiki;

+ 0 - 176
cmds/wiki/fandom/overview.js

@@ -1,176 +0,0 @@
-const {MessageEmbed} = require('discord.js');
-const logging = require('../../../util/logging.js');
-const {timeoptions} = require('../../../util/default.json');
-
-/**
- * Sends a Fandom wiki overview.
- * @param {import('../../../util/i18n.js')} lang - The user language.
- * @param {import('discord.js').Message} msg - The Discord message.
- * @param {import('../../../util/wiki.js')} wiki - The wiki for the overview.
- * @param {import('discord.js').MessageReaction} reaction - The reaction on the message.
- * @param {String} spoiler - If the response is in a spoiler.
- */
-function fandom_overview(lang, msg, wiki, reaction, spoiler) {
-	got.get( wiki + 'api.php?action=query&meta=allmessages|siteinfo&ammessages=custom-Wiki_Manager|custom-GamepediaNotice|custom-FandomMergeNotice&amenableparser=true&siprop=general|statistics|wikidesc&titles=Special:Statistics&format=json' ).then( response => {
-		var body = response.body;
-		if ( body && body.warnings ) log_warn(body.warnings);
-		if ( response.statusCode !== 200 || !body || !body.query || !body.query.pages ) {
-			if ( wiki.noWiki(response.url, response.statusCode) ) {
-				console.log( '- This wiki doesn\'t exist!' );
-				msg.reactEmoji('nowiki');
-			}
-			else {
-				console.log( '- ' + response.statusCode + ': Error while getting the statistics: ' + ( body && body.error && body.error.info ) );
-				msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Statistics') + '>' + spoiler );
-			}
-			
-			if ( reaction ) reaction.removeEmoji();
-		}
-		else got.get( 'https://community.fandom.com/api/v1/Wikis/Details?ids=' + body.query.wikidesc.id + '&format=json&cache=' + Date.now() ).then( ovresponse => {
-			wiki.updateWiki(body.query.general);
-			logging(wiki, msg.guild?.id, 'overview', 'legacy');
-			var ovbody = ovresponse.body;
-			if ( ovresponse.statusCode !== 200 || !ovbody || ovbody.exception || !ovbody.items || !ovbody.items[body.query.wikidesc.id] ) {
-				console.log( '- ' + ovresponse.statusCode + ': Error while getting the wiki details: ' + ( ovbody && ovbody.exception && ovbody.exception.details ) );
-				msg.sendChannelError( spoiler + '<' + wiki.toLink(body.query.pages['-1'].title) + '>' + spoiler );
-				
-				if ( reaction ) reaction.removeEmoji();
-			}
-			else {
-				var site = ovbody.items[body.query.wikidesc.id];
-				
-				var vertical = [lang.get('overview.vertical'), site.hub];
-				var topic = [lang.get('overview.topic'), site.topic];
-				var founder = [lang.get('overview.founder'), site.founding_user_id];
-				var manager = [lang.get('overview.manager'), body.query.allmessages[0]['*']];
-				var crossover = [lang.get('overview.crossover')];
-				if ( body.query.allmessages[1]['*'] ) {
-					crossover.push('<https://' + body.query.allmessages[1]['*'] + '.gamepedia.com/>');
-				}
-				else if ( body.query.allmessages[2]['*'] ) {
-					let merge = body.query.allmessages[2]['*'].split('/');
-					crossover.push('<https://' + merge[0] + '.fandom.com/' + ( merge[1] ? merge[1] + '/' : '' ) + '>');
-				}
-				try {
-					var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-						timeZone: body.query.general.timezone
-					}, timeoptions));
-				}
-				catch ( error ) {
-					var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-						timeZone: 'UTC'
-					}, timeoptions));
-				}
-				var created = [lang.get('overview.created'), ( site.creation_date ? dateformat.format(new Date(site.creation_date)) : 'Invalid Date' )];
-				var articles = [lang.get('overview.articles'), body.query.statistics.articles.toLocaleString(lang.get('dateformat'))];
-				var pages = [lang.get('overview.pages'), body.query.statistics.pages.toLocaleString(lang.get('dateformat'))];
-				var edits = [lang.get('overview.edits'), body.query.statistics.edits.toLocaleString(lang.get('dateformat'))];
-				var users = [lang.get('overview.users'), body.query.statistics.activeusers.toLocaleString(lang.get('dateformat'))];
-				var description = [lang.get('overview.description'), site.desc];
-				var image = [lang.get('overview.image'), site.image];
-				
-				if ( description[1] ) {
-					description[1] = description[1].escapeFormatting();
-					if ( description[1].length > 1000 ) description[1] = description[1].substring(0, 1000) + '\u2026';
-				}
-				if ( image[1] && image[1].startsWith( '/' ) ) image[1] = new URL(image[1], wiki).href;
-				
-				var title = body.query.pages['-1'].title;
-				var pagelink = wiki.toLink(title);
-				if ( msg.showEmbed() ) {
-					var text = '<' + pagelink + '>';
-					var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( title.escapeFormatting() ).setURL( pagelink ).setThumbnail( ( site.wordmark?.startsWith( 'data:' ) ? wiki.toLink('Special:FilePath/Wiki-wordmark.png') : site.wordmark ) ).addField( vertical[0], vertical[1], true );
-					if ( topic[1] ) embed.addField( topic[0], topic[1], true );
-				}
-				else {
-					var embed = {};
-					var text = '<' + pagelink + '>\n\n' + vertical.join(' ') + ( topic[1] ? '\n' + topic.join(' ') : '' );
-				}
-				
-				if ( founder[1] > 0 ) got.get( wiki + 'api.php?action=query&list=users&usprop=&usids=' + founder[1] + '&format=json' ).then( usresponse => {
-					var usbody = usresponse.body;
-					if ( usbody && usbody.warnings ) log_warn(usbody.warnings);
-					if ( usresponse.statusCode !== 200 || !usbody || !usbody.query || !usbody.query.users || !usbody.query.users[0] ) {
-						console.log( '- ' + usresponse.statusCode + ': Error while getting the wiki founder: ' + ( usbody && usbody.error && usbody.error.info ) );
-						founder[1] = 'ID: ' + founder[1];
-					}
-					else {
-						var user = usbody.query.users[0].name;
-						if ( msg.showEmbed() ) founder[1] = '[' + user + '](' + wiki.toLink('User:' + user, '', '', true) + ')';
-						else founder[1] = user;
-					}
-				}, error => {
-					console.log( '- Error while getting the wiki founder: ' + error );
-					founder[1] = 'ID: ' + founder[1];
-				} ).finally( () => {
-					if ( msg.showEmbed() ) {
-						embed.addField( founder[0], founder[1], true );
-						if ( manager[1] ) embed.addField( manager[0], '[' + manager[1] + '](' + wiki.toLink('User:' + manager[1], '', '', true) + ') ([' + lang.get('overview.talk') + '](' + wiki.toLink('User talk:' + manager[1], '', '', true) + '))', true );
-						embed.addField( created[0], created[1], true ).addField( articles[0], articles[1], true ).addField( pages[0], pages[1], true ).addField( edits[0], edits[1], true ).addField( users[0], users[1], true ).setFooter( lang.get('overview.inaccurate') );
-						if ( crossover[1] ) embed.addField( crossover[0], crossover[1], true );
-						if ( description[1] ) embed.addField( description[0], description[1] );
-						if ( image[1] ) embed.addField( image[0], image[1] ).setImage( image[1] );
-					}
-					else {
-						text += '\n' + founder.join(' ') + ( manager[1] ? '\n' + manager.join(' ') : '' ) + '\n' + created.join(' ') + '\n' + articles.join(' ') + '\n' + pages.join(' ') + '\n' + edits.join(' ') + '\n' + users.join(' ');
-						if ( crossover[1] ) text += '\n' + crossover.join(' ');
-						if ( description[1] ) text += '\n' + description.join(' ');
-						if ( image[1] ) {
-							text += '\n' + image.join(' ');
-							if ( msg.uploadFiles() ) embed.files = [image[1]];
-						}
-						text += '\n\n*' + lang.get('overview.inaccurate') + '*';
-					}
-					
-					msg.sendChannel( spoiler + text + spoiler, {embed} );
-					
-					if ( reaction ) reaction.removeEmoji();
-				} );
-				else {
-					founder[1] = lang.get('overview.none');
-					if ( msg.showEmbed() ) {
-						embed.addField( founder[0], founder[1], true ).addField( created[0], created[1], true ).addField( articles[0], articles[1], true ).addField( pages[0], pages[1], true ).addField( edits[0], edits[1], true ).addField( users[0], users[1], true ).setFooter( lang.get('overview.inaccurate') );
-						if ( crossover[1] ) embed.addField( crossover[0], crossover[1], true );
-						if ( description[1] ) embed.addField( description[0], description[1] );
-						if ( image[1] ) embed.addField( image[0], image[1] ).setImage( image[1] );
-					}
-					else {
-						text += '\n' + founder.join(' ') + '\n' + created.join(' ') + '\n' + articles.join(' ') + '\n' + pages.join(' ') + '\n' + edits.join(' ') + '\n' + users.join(' ');
-						if ( crossover[1] ) text += '\n' + crossover.join(' ');
-						if ( description[1] ) text += '\n' + description.join(' ');
-						if ( image[1] ) {
-							text += '\n' + image.join(' ');
-							if ( msg.uploadFiles() ) embed.files = [image[1]];
-						}
-						text += '\n\n*' + lang.get('overview.inaccurate') + '*';
-					}
-					
-					msg.sendChannel( spoiler + text + spoiler, {embed} );
-					
-					if ( reaction ) reaction.removeEmoji();
-				}
-			}
-		}, error => {
-			console.log( '- Error while getting the wiki details: ' + error );
-			msg.sendChannelError( spoiler + '<' + wiki.updateWiki(body.query.general).toLink(body.query.pages['-1'].title) + '>' + spoiler );
-			
-			if ( reaction ) reaction.removeEmoji();
-		} );
-	}, error => {
-		if ( wiki.noWiki(error.message) ) {
-			console.log( '- This wiki doesn\'t exist!' );
-			msg.reactEmoji('nowiki');
-		}
-		else {
-			console.log( '- Error while getting the statistics: ' + error );
-			msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Statistics') + '>' + spoiler );
-		}
-		
-		if ( reaction ) reaction.removeEmoji();
-	} );
-}
-
-module.exports = {
-	name: 'overview',
-	run: fandom_overview
-};

+ 0 - 92
cmds/wiki/fandom/random.js

@@ -1,92 +0,0 @@
-const htmlparser = require('htmlparser2');
-const {MessageEmbed} = require('discord.js');
-const logging = require('../../../util/logging.js');
-
-/**
- * Sends a random Fandom page.
- * @param {import('../../../util/i18n.js')} lang - The user language.
- * @param {import('discord.js').Message} msg - The Discord message.
- * @param {import('../../../util/wiki.js')} wiki - The wiki for the page.
- * @param {import('discord.js').MessageReaction} reaction - The reaction on the message.
- * @param {String} spoiler - If the response is in a spoiler.
- */
-function fandom_random(lang, msg, wiki, reaction, spoiler) {
-	got.get( wiki + 'api.php?action=query&meta=allmessages|siteinfo&ammessages=description&siprop=general&generator=random&grnnamespace=0&format=json' ).then( response => {
-		var body = response.body;
-		if ( body && body.warnings ) log_warn(body.warnings);
-		if ( response.statusCode !== 200 || !body || !body.query || !body.query.pages ) {
-			if ( wiki.noWiki(response.url, response.statusCode) ) {
-				console.log( '- This wiki doesn\'t exist!' );
-				msg.reactEmoji('nowiki');
-			}
-			else {
-				console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
-				msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Random') + '>' + spoiler );
-			}
-			
-			if ( reaction ) reaction.removeEmoji();
-		}
-		else {
-			wiki.updateWiki(body.query.general);
-			logging(wiki, msg.guild?.id, 'random', 'legacy');
-			var querypage = Object.values(body.query.pages)[0];
-			var pagelink = wiki.toLink(querypage.title);
-			var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( querypage.title.escapeFormatting() ).setURL( pagelink );
-			if ( querypage.title === body.query.general.mainpage && body.query.allmessages[0]['*'] ) {
-				embed.setDescription( body.query.allmessages[0]['*'] );
-				embed.setThumbnail( wiki.toLink('Special:FilePath/Wiki-wordmark.png') );
-				
-				msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-				
-				if ( reaction ) reaction.removeEmoji();
-			}
-			else got.get( wiki.toDescLink(querypage.title), {
-				responseType: 'text'
-			} ).then( descresponse => {
-				var descbody = descresponse.body;
-				if ( descresponse.statusCode !== 200 || !descbody ) {
-					console.log( '- ' + descresponse.statusCode + ': Error while getting the description.' );
-				} else {
-					var thumbnail = wiki.toLink('Special:FilePath/Wiki-wordmark.png');
-					var parser = new htmlparser.Parser( {
-						onopentag: (tagname, attribs) => {
-							if ( tagname === 'meta' && attribs.property === 'og:description' ) {
-								var description = attribs.content.escapeFormatting();
-								if ( description.length > 1000 ) description = description.substring(0, 1000) + '\u2026';
-								embed.setDescription( description );
-							}
-							if ( tagname === 'meta' && attribs.property === 'og:image' && querypage.title !== body.query.general.mainpage ) {
-								thumbnail = attribs.content;
-							}
-						}
-					} );
-					parser.write( descbody );
-					parser.end();
-					embed.setThumbnail( thumbnail );
-				}
-			}, error => {
-				console.log( '- Error while getting the description: ' + error );
-			} ).finally( () => {
-				msg.sendChannel( '🎲 ' + spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-				
-				if ( reaction ) reaction.removeEmoji();
-			} );
-		}
-	}, error => {
-		if ( wiki.noWiki(error.message) ) {
-			console.log( '- This wiki doesn\'t exist!' );
-			msg.reactEmoji('nowiki');
-		}
-		else {
-			console.log( '- Error while getting the search results: ' + error );
-			msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Random') + '>' + spoiler );
-		}
-		
-		if ( reaction ) reaction.removeEmoji();
-	} );
-}
-
-module.exports = {
-	name: 'random',
-	run: fandom_random
-};

+ 0 - 54
cmds/wiki/fandom/search.js

@@ -1,54 +0,0 @@
-const {MessageEmbed, Util} = require('discord.js');
-
-/**
- * Searches a Fandom wiki.
- * @param {import('../../../util/i18n.js')} lang - The user language.
- * @param {import('discord.js').Message} msg - The Discord message.
- * @param {String} searchterm - The searchterm.
- * @param {import('../../../util/wiki.js')} wiki - The wiki for the search.
- * @param {Object} query - The siteinfo from the wiki.
- * @param {import('discord.js').MessageReaction} reaction - The reaction on the message.
- * @param {String} spoiler - If the response is in a spoiler.
- */
-function fandom_search(lang, msg, searchterm, wiki, query, reaction, spoiler) {
-	if ( searchterm.length > 250 ) {
-		searchterm = searchterm.substring(0, 250);
-		msg.reactEmoji('⚠️');
-	}
-	var pagelink = wiki.toLink('Special:Search', {search:searchterm});
-	var embed = new MessageEmbed().setAuthor( query.general.sitename ).setTitle( '`' + searchterm + '`' ).setURL( pagelink );
-	if ( !searchterm.trim() ) {
-		pagelink = wiki.toLink('Special:Search');
-		embed.setTitle( 'Special:Search' ).setURL( pagelink );
-		msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-		
-		if ( reaction ) reaction.removeEmoji();
-		return;
-	}
-	var description = [];
-	got.get( wiki + 'api/v1/Search/List?minArticleQuality=0&namespaces=4,12,14,' + Object.values(query.namespaces).filter( ns => ns.content !== undefined ).map( ns => ns.id ).join(',') + '&limit=10&query=' + encodeURIComponent( searchterm ) + '&format=json&cache=' + Date.now() ).then( response => {
-		var body = response.body;
-		if ( response.statusCode !== 200 || !body || body.exception || !body.items ) {
-			if ( !( body && body.exception && body.exception.code === 404 ) ) {
-				console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.exception && body.exception.details ) );
-			}
-			return;
-		}
-		body.items.forEach( result => {
-			description.push( '• [' + result.title + '](' + wiki.toLink(result.title, '', '', true) + ')' );
-		} );
-		embed.setFooter( lang.get('search.results', body.total.toLocaleString(lang.get('dateformat')), body.total) );
-	}, error => {
-		console.log( '- Error while getting the search results.' + error );
-	} ).finally( () => {
-		embed.setDescription( Util.splitMessage( description.join('\n') )[0] );
-		msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-		
-		if ( reaction ) reaction.removeEmoji();
-	} );
-}
-
-module.exports = {
-	name: 'search',
-	run: fandom_search
-};

+ 0 - 389
cmds/wiki/fandom/user.js

@@ -1,389 +0,0 @@
-const htmlparser = require('htmlparser2');
-const {MessageEmbed} = require('discord.js');
-const global_block = require('../../../functions/global_block.js');
-const {timeoptions, usergroups} = require('../../../util/default.json');
-const {toMarkdown, toPlaintext} = require('../../../util/functions.js');
-
-/**
- * Processes a Fandom user.
- * @param {import('../../../util/i18n.js')} lang - The user language.
- * @param {import('discord.js').Message} msg - The Discord message.
- * @param {String} namespace - The user namespace on the wiki.
- * @param {String} username - The name of the user.
- * @param {import('../../../util/wiki.js')} wiki - The wiki for the page.
- * @param {URLSearchParams} querystring - The querystring for the link.
- * @param {String} fragment - The section for the link.
- * @param {Object} querypage - The user page on the wiki.
- * @param {String} contribs - The contributions page on the wiki.
- * @param {import('discord.js').MessageReaction} reaction - The reaction on the message.
- * @param {String} spoiler - If the response is in a spoiler.
- */
-function fandom_user(lang, msg, namespace, username, wiki, querystring, fragment, querypage, contribs, reaction, spoiler) {
-	if ( /^(?:(?:\d{1,3}\.){3}\d{1,3}(?:\/\d{2})?|(?:[\dA-F]{1,4}:){7}[\dA-F]{1,4}(?:\/\d{2,3})?)$/.test(username) ) {
-		got.get( wiki + 'api.php?action=query&meta=siteinfo&siprop=general&list=blocks&bkprop=user|by|timestamp|expiry|reason&bkip=' + encodeURIComponent( username ) + '&format=json' ).then( response => {
-			var body = response.body;
-			if ( body && body.warnings ) log_warn(body.warnings);
-			if ( response.statusCode !== 200 || !body || !body.query || !body.query.blocks ) {
-				if ( body && body.error && ( body.error.code === 'param_ip' || body.error.code === 'cidrtoobroad' ) ) {
-					if ( querypage.missing !== undefined || querypage.ns === -1 ) {
-						msg.reactEmoji('error');
-						
-						if ( reaction ) reaction.removeEmoji();
-					}
-					else {
-						var pagelink = wiki.toLink(querypage.title, querystring, fragment);
-						var embed = new MessageEmbed().setTitle( querypage.title.escapeFormatting() ).setURL( pagelink );
-						got.get( wiki.toDescLink(querypage.title), {
-							responseType: 'text'
-						} ).then( descresponse => {
-							var descbody = descresponse.body;
-							if ( descresponse.statusCode !== 200 || !descbody ) {
-								console.log( '- ' + descresponse.statusCode + ': Error while getting the description.' );
-							} else {
-								var thumbnail = wiki.toLink('Special:FilePath/Wiki-wordmark.png');
-								var parser = new htmlparser.Parser( {
-									onopentag: (tagname, attribs) => {
-										if ( tagname === 'meta' && attribs.property === 'og:description' ) {
-											var description = attribs.content.escapeFormatting();
-											if ( description.length > 1000 ) description = description.substring(0, 1000) + '\u2026';
-											embed.setDescription( description );
-										}
-										if ( tagname === 'meta' && attribs.property === 'og:image' ) {
-											thumbnail = attribs.content;
-										}
-									}
-								} );
-								parser.write( descbody );
-								parser.end();
-								embed.setThumbnail( thumbnail );
-							}
-						}, error => {
-							console.log( '- Error while getting the description: ' + error );
-						} ).finally( () => {
-							msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-							
-							if ( reaction ) reaction.removeEmoji();
-						} );
-					}
-				}
-				else {
-					console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
-					msg.sendChannelError( spoiler + '<' + wiki.toLink(( querypage.noRedirect ? namespace : contribs ) + username, querystring, fragment) + '>' + spoiler );
-					
-					if ( reaction ) reaction.removeEmoji();
-				}
-			}
-			else {
-				if ( !querypage.noRedirect || ( querypage.missing === undefined && querypage.ns !== -1 ) ) namespace = contribs;
-				try {
-					var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-						timeZone: body.query.general.timezone
-					}, timeoptions));
-				}
-				catch ( error ) {
-					var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-						timeZone: 'UTC'
-					}, timeoptions));
-				}
-				var blocks = body.query.blocks.map( block => {
-					var isBlocked = false;
-					var blockedtimestamp = dateformat.format(new Date(block.timestamp));
-					var blockexpiry = block.expiry;
-					if ( ['infinite', 'indefinite', 'infinity', 'never'].includes(blockexpiry) ) {
-						blockexpiry = lang.get('user.block.until_infinity');
-						isBlocked = true;
-					} else if ( blockexpiry ) {
-						if ( Date.parse(blockexpiry) > Date.now() ) isBlocked = true;
-						blockexpiry = dateformat.format(new Date(blockexpiry));
-					}
-					if ( isBlocked ) return {
-						header: lang.get('user.block.header', block.user, 'unknown').escapeFormatting(),
-						text: lang.get('user.block.' + ( block.reason ? 'text' : 'noreason' ), blockedtimestamp, blockexpiry),
-						by: block.by,
-						reason: block.reason
-					};
-				} ).filter( block => block !== undefined );
-				if ( username.includes( '/' ) ) {
-					var rangeprefix = username;
-					if ( username.includes( ':' ) ) {
-						var range = parseInt(username.replace( /^.+\/(\d{2,3})$/, '$1' ), 10);
-						if ( range === 128 ) username = username.replace( /^(.+)\/\d{2,3}$/, '$1' );
-						else if ( range >= 112 ) rangeprefix = username.replace( /^((?:[\dA-F]{1,4}:){7}).+$/, '$1' );
-						else if ( range >= 96 ) rangeprefix = username.replace( /^((?:[\dA-F]{1,4}:){6}).+$/, '$1' );
-						else if ( range >= 80 ) rangeprefix = username.replace( /^((?:[\dA-F]{1,4}:){5}).+$/, '$1' );
-						else if ( range >= 64 ) rangeprefix = username.replace( /^((?:[\dA-F]{1,4}:){4}).+$/, '$1' );
-						else if ( range >= 48 ) rangeprefix = username.replace( /^((?:[\dA-F]{1,4}:){3}).+$/, '$1' );
-						else if ( range >= 32 ) rangeprefix = username.replace( /^((?:[\dA-F]{1,4}:){2}).+$/, '$1' );
-						else if ( range >= 19 ) rangeprefix = username.replace( /^((?:[\dA-F]{1,4}:){1}).+$/, '$1' );
-					}
-					else {
-						var range = parseInt(username.substring(username.length - 2), 10);
-						if ( range === 32 ) username = username.replace( /^(.+)\/\d{2}$/, '$1' );
-						else if ( range >= 24 ) rangeprefix = username.replace( /^((?:\d{1,3}\.){3}).+$/, '$1' );
-						else if ( range >= 16 ) rangeprefix = username.replace( /^((?:\d{1,3}\.){2}).+$/, '$1' );
-					}
-				}
-				got.get( wiki.updateWiki(body.query.general) + 'api.php?action=query&list=usercontribs&ucprop=&uclimit=50&ucuser=' + encodeURIComponent( username ) + '&format=json' ).then( ucresponse => {
-					var ucbody = ucresponse.body;
-					if ( rangeprefix && !username.includes( '/' ) ) username = rangeprefix;
-					if ( ucbody && ucbody.warnings ) log_warn(ucbody.warnings);
-					if ( ucresponse.statusCode !== 200 || !ucbody || !ucbody.query || !ucbody.query.usercontribs ) {
-						if ( ucbody && ucbody.error && ucbody.error.code === 'baduser_ucuser' ) {
-							msg.reactEmoji('error');
-						}
-						else {
-							console.log( '- ' + ucresponse.statusCode + ': Error while getting the search results: ' + ( ucbody && ucbody.error && ucbody.error.info ) );
-							msg.sendChannelError( spoiler + '<' + wiki.toLink(namespace + username, querystring, fragment) + '>' + spoiler );
-						}
-					}
-					else {
-						var editcount = [lang.get('user.info.editcount'), ( username.includes( '/' ) ? '~' : '' ) + ucbody.query.usercontribs.length.toLocaleString(lang.get('dateformat')) + ( ucbody.continue ? '+' : '' )];
-						
-						var pagelink = wiki.toLink(namespace + username, querystring, fragment);
-						if ( msg.showEmbed() ) {
-							var text = '<' + pagelink + '>';
-							var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( username ).setURL( pagelink ).addField( editcount[0], '[' + editcount[1] + '](' + wiki.toLink(contribs + username, '', '', true) + ')' );
-							if ( blocks.length ) {
-								block.text = block.text.replaceSave( /\$3/g, '[' + block.by.escapeFormatting() + '](' + wiki.toLink('User:' + block.by, '', '', true) + ')' );
-								if ( block.reason ) block.text = block.text.replaceSave( /\$4/g, toMarkdown(block.reason, wiki) );
-								embed.addField( block.header, block.text );
-							}
-						}
-						else {
-							var embed = {};
-							var text = '<' + pagelink + '>\n\n' + editcount.join(' ');
-							if ( blocks.length ) {
-								block.text = block.text.replaceSave( /\$3/g, block.by.escapeFormatting() );
-								if ( block.reason ) block.text = block.text.replaceSave( /\$4/g, toPlaintext(block.reason) );
-								text += '\n\n**' + block.header + '**\n' + block.text;
-							}
-						}
-						
-						if ( msg.channel.isGuild() && patreons[msg.guild?.id] ) {
-							if ( msg.showEmbed() ) embed.addField( '\u200b', '<a:loading:641343250661113886> **' + lang.get('user.info.loading') + '**' );
-							else text += '\n\n<a:loading:641343250661113886> **' + lang.get('user.info.loading') + '**';
-							
-							msg.sendChannel( spoiler + text + spoiler, {embed} ).then( message => global_block(lang, message, username, text, embed, wiki, spoiler) );
-						}
-						else msg.sendChannel( spoiler + text + spoiler, {embed} );
-					}
-				}, error => {
-					if ( rangeprefix && !username.includes( '/' ) ) username = rangeprefix;
-					console.log( '- Error while getting the search results: ' + error );
-					msg.sendChannelError( spoiler + '<' + wiki.toLink(namespace + username, querystring, fragment) + '>' + spoiler );
-				} ).finally( () => {
-					if ( reaction ) reaction.removeEmoji();
-				} );
-			}
-		}, error => {
-			console.log( '- Error while getting the search results: ' + error );
-			msg.sendChannelError( spoiler + '<' + wiki.toLink(( querypage.noRedirect ? namespace : contribs ) + username, querystring, fragment) + '>' + spoiler );
-			
-			if ( reaction ) reaction.removeEmoji();
-		} );
-	} else {
-		got.get( wiki + 'api.php?action=query&meta=allmessages|siteinfo&ammessages=custom-Wiki_Manager&amenableparser=true&siprop=general&list=users&usprop=blockinfo|groups|editcount|registration|gender&ususers=' + encodeURIComponent( username ) + '&format=json' ).then( response => {
-			var body = response.body;
-			if ( body && body.warnings ) log_warn(body.warnings);
-			if ( response.statusCode !== 200 || !body || !body.query || !body.query.users ) {
-				console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
-				msg.sendChannelError( spoiler + '<' + wiki.toLink(namespace + username, querystring, fragment) + '>' + spoiler );
-				
-				if ( reaction ) reaction.removeEmoji();
-			}
-			else {
-				wiki.updateWiki(body.query.general);
-				var queryuser = body.query.users[0];
-				if ( !queryuser ) {
-					if ( querypage.missing !== undefined || querypage.ns === -1 ) {
-						msg.reactEmoji('🤷');
-						
-						if ( reaction ) reaction.removeEmoji();
-					}
-					else {
-						var pagelink = wiki.toLink(querypage.title, querystring, fragment);
-						var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( querypage.title.escapeFormatting() ).setURL( pagelink );
-						got.get( wiki.toDescLink(querypage.title), {
-							responseType: 'text'
-						} ).then( descresponse => {
-							var descbody = descresponse.body;
-							if ( descresponse.statusCode !== 200 || !descbody ) {
-								console.log( '- ' + descresponse.statusCode + ': Error while getting the description.' );
-							} else {
-								var thumbnail = wiki.toLink('Special:FilePath/Wiki-wordmark.png');
-								var parser = new htmlparser.Parser( {
-									onopentag: (tagname, attribs) => {
-										if ( tagname === 'meta' && attribs.property === 'og:description' ) {
-											var description = attribs.content.escapeFormatting();
-											if ( description.length > 1000 ) description = description.substring(0, 1000) + '\u2026';
-											embed.setDescription( description );
-										}
-										if ( tagname === 'meta' && attribs.property === 'og:image' ) {
-											thumbnail = attribs.content;
-										}
-									}
-								} );
-								parser.write( descbody );
-								parser.end();
-								embed.setThumbnail( thumbnail );
-							}
-						}, error => {
-							console.log( '- Error while getting the description: ' + error );
-						} ).finally( () => {
-							msg.sendChannel( spoiler + '<' + pagelink + '>' + spoiler, {embed} );
-							
-							if ( reaction ) reaction.removeEmoji();
-						} );
-					}
-				}
-				else {
-					username = queryuser.name;
-					var gender = [lang.get('user.info.gender')];
-					switch (queryuser.gender) {
-						case 'male':
-							gender.push(lang.get('user.gender.male'));
-							break;
-						case 'female':
-							gender.push(lang.get('user.gender.female'));
-							break;
-						default: 
-							gender.push(lang.get('user.gender.unknown'));
-					}
-					try {
-						var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-							timeZone: body.query.general.timezone
-						}, timeoptions));
-					}
-					catch ( error ) {
-						var dateformat = new Intl.DateTimeFormat(lang.get('dateformat'), Object.assign({
-							timeZone: 'UTC'
-						}, timeoptions));
-					}
-					var registration = [lang.get('user.info.registration'), dateformat.format(new Date(queryuser.registration))];
-					var editcount = [lang.get('user.info.editcount'), queryuser.editcount.toLocaleString(lang.get('dateformat'))];
-					var groups = queryuser.groups;
-					var group = [lang.get('user.info.group', groups.length)];
-					for ( var i = 0; i < usergroups.sorted.length; i++ ) {
-						let usergroup = usergroups.sorted[i];
-						if ( usergroup === '__CUSTOM__' ) {
-							let customgroups = groups.filter( customgroup => {
-								return ( !usergroups.sorted.includes( customgroup ) && !usergroups.ignored.includes( customgroup ) );
-							} );
-							group.push(...customgroups);
-						}
-						else if ( groups.includes( usergroup ) && ( group.length === 1 || !['autoconfirmed', 'user'].includes( usergroup ) ) ) {
-							if ( usergroup === 'wiki-manager' && body.query.allmessages[0]['*'] === username ) {
-								group.push('**' + lang.get('user.groups.' + usergroup, queryuser.gender) + '**');
-							}
-							else group.push(lang.get('user.groups.' + usergroup, queryuser.gender));
-						}
-					}
-					var isBlocked = false;
-					var blockexpiry = queryuser.blockexpiry;
-					if ( ['infinite', 'indefinite', 'infinity', 'never'].includes(blockexpiry) ) {
-						blockexpiry = lang.get('user.block.until_infinity');
-						isBlocked = true;
-					} else if ( blockexpiry ) {
-						var blockexpirydate = blockexpiry.replace( /(\d{4})(\d{2})(\d{2})(\d{2})(\d{2})(\d{2,3})/, '$1-$2-$3T$4:$5:$6Z' );
-						blockexpiry = dateformat.format(new Date(blockexpirydate));
-						if ( Date.parse(blockexpirydate) > Date.now() ) isBlocked = true;
-					}
-					var blockedby = queryuser.blockedby;
-					var blockreason = queryuser.blockreason;
-					var block = {
-						header: lang.get('user.block.header', username, queryuser.gender).escapeFormatting(),
-						text: lang.get('user.block.nofrom' + ( blockreason ? 'text' : 'noreason' ), '', blockexpiry ),
-						by: blockedby,
-						reason: blockreason
-					};
-					
-					var pagelink = wiki.toLink(namespace + username, querystring, fragment);
-					if ( msg.showEmbed() ) {
-						var text = '<' + pagelink + '>';
-						var embed = new MessageEmbed().setAuthor( body.query.general.sitename ).setTitle( username.escapeFormatting() ).setURL( pagelink ).addField( editcount[0], '[' + editcount[1] + '](' + wiki.toLink(contribs + username, '', '', true) + ')', true ).addField( group[0], group.slice(1).join(',\n'), true ).addField( gender[0], gender[1], true ).addField( registration[0], registration[1], true );
-					}
-					else {
-						var embed = {};
-						var text = '<' + pagelink + '>\n\n' + gender.join(' ') + '\n' + registration.join(' ') + '\n' + editcount.join(' ') + '\n' + group[0] + ' ' + group.slice(1).join(', ');
-					}
-					
-					got.get( 'https://services.fandom.com/user-attribute/user/' + queryuser.userid + '?format=json&cache=' + Date.now(), {
-						headers: {
-							Accept: 'application/hal+json'
-						}
-					} ).then( presponse => {
-						var pbody = presponse.body;
-						if ( presponse.statusCode !== 200 || !pbody || pbody.title || !pbody._embedded || !pbody._embedded.properties ) {
-							if ( !( pbody && pbody.status === 404 ) ) {
-								console.log( '- ' + presponse.statusCode + ': Error while getting the user profile: ' + ( pbody && pbody.title ) );
-							}
-						}
-						else {
-							var profile = pbody._embedded.properties;
-							var discordfield = profile.find( field => field.name === 'discordHandle' );
-							var avatarfield = profile.find( field => field.name === 'avatar' );
-							var biofield = profile.find( field => field.name === 'bio' );
-							if ( discordfield && discordfield.value ) {
-								discordfield.value = discordfield.value.replace( /^\s*([^@#:]{2,32}?)\s*#(\d{4,6})\s*$/u, '$1#$2' );
-								if ( discordfield.value.length > 100 ) discordfield.value = discordfield.value.substring(0, 100) + '\u2026';
-								if ( msg.channel.isGuild() ) var discordmember = msg.guild.members.cache.find( member => {
-									return member.user.tag.escapeFormatting() === discordfield.value;
-								} );
-								var discordname = [lang.get('user.info.discord'),discordfield.value];
-								if ( discordmember ) discordname[1] = discordmember.toString();
-								
-								if ( msg.showEmbed() ) embed.addField( discordname[0], discordname[1], true );
-								else text += '\n' + discordname.join(' ');
-							}
-							if ( msg.showEmbed() ) {
-								if ( avatarfield && avatarfield.value ) embed.setThumbnail( avatarfield.value );
-								if ( biofield && biofield.value && !embed.description ) {
-									var bio = biofield.value.escapeFormatting();
-									if ( bio.length > 1000 ) bio = bio.substring(0, 1000) + '\u2026';
-									embed.setDescription( bio );
-								}
-							}
-						}
-					}, error => {
-						console.log( '- Error while getting the user profile: ' + error );
-					} ).finally( () => {
-						if ( msg.showEmbed() ) {
-							if ( isBlocked ) {
-								block.text = block.text.replaceSave( /\$3/g, '[' + block.by.escapeFormatting() + '](' + wiki.toLink('User:' + block.by, '', '', true) + ')' );
-								if ( block.reason ) block.text = block.text.replaceSave( /\$4/g, toMarkdown(block.reason, wiki) );
-								embed.addField( block.header, block.text );
-							}
-						}
-						else {
-							if ( isBlocked ) {
-								block.text = block.text.replaceSave( /\$3/g, block.by.escapeFormatting() );
-								if ( block.reason ) block.text = block.text.replaceSave( /\$4/g, toPlaintext(block.reason) );
-								text += '\n\n**' + block.header + '**\n' + block.text;
-							}
-						}
-						
-						if ( msg.channel.isGuild() && patreons[msg.guild?.id] ) {
-							if ( msg.showEmbed() ) embed.addField( '\u200b', '<a:loading:641343250661113886> **' + lang.get('user.info.loading') + '**' );
-							else text += '\n\n<a:loading:641343250661113886> **' + lang.get('user.info.loading') + '**';
-							
-							msg.sendChannel( spoiler + text + spoiler, {embed} ).then( message => global_block(lang, message, username, text, embed, wiki, spoiler, queryuser.gender) );
-						}
-						else msg.sendChannel( spoiler + text + spoiler, {embed} );
-						
-						if ( reaction ) reaction.removeEmoji();
-					} );
-				}
-			}
-		}, error => {
-			console.log( '- Error while getting the search results: ' + error );
-			msg.sendChannelError( spoiler + '<' + wiki.toLink(namespace + username, querystring, fragment) + '>' + spoiler );
-			
-			if ( reaction ) reaction.removeEmoji();
-		} );
-	}
-}
-
-module.exports = {
-	name: 'user',
-	run: fandom_user
-};

+ 1 - 4
cmds/wiki/general.js

@@ -87,10 +87,7 @@ function gamepedia_check_wiki(lang, msg, title, wiki, cmd, reaction, spoiler = '
 		var body = response.body;
 		var body = response.body;
 		if ( body && body.warnings ) log_warn(body.warnings);
 		if ( body && body.warnings ) log_warn(body.warnings);
 		if ( response.statusCode !== 200 || !body || body.batchcomplete === undefined || !body.query ) {
 		if ( response.statusCode !== 200 || !body || body.batchcomplete === undefined || !body.query ) {
-			if ( body?.query?.general?.generator === 'MediaWiki 1.19.24' && wiki.isFandom(false) ) {
-				return this.fandom(lang, msg, title, wiki, cmd, reaction, spoiler, querystring, fragment, selfcall);
-			}
-			else if ( interwiki ) msg.sendChannel( spoiler + ' ' + interwiki + ' ' + spoiler );
+			if ( interwiki ) msg.sendChannel( spoiler + ' ' + interwiki + ' ' + spoiler );
 			else if ( wiki.noWiki(response.url, response.statusCode) ) {
 			else if ( wiki.noWiki(response.url, response.statusCode) ) {
 				console.log( '- This wiki doesn\'t exist!' );
 				console.log( '- This wiki doesn\'t exist!' );
 				msg.reactEmoji('nowiki');
 				msg.reactEmoji('nowiki');

+ 0 - 4
cmds/wiki/overview.js

@@ -1,5 +1,4 @@
 const {MessageEmbed} = require('discord.js');
 const {MessageEmbed} = require('discord.js');
-const fandom_overview = require('./fandom/overview.js').run;
 const logging = require('../../util/logging.js');
 const logging = require('../../util/logging.js');
 const {timeoptions} = require('../../util/default.json');
 const {timeoptions} = require('../../util/default.json');
 const {toFormatting, toPlaintext} = require('../../util/functions.js');
 const {toFormatting, toPlaintext} = require('../../util/functions.js');
@@ -26,9 +25,6 @@ function gamepedia_overview(lang, msg, wiki, reaction, spoiler) {
 				console.log( '- This wiki doesn\'t exist!' );
 				console.log( '- This wiki doesn\'t exist!' );
 				msg.reactEmoji('nowiki');
 				msg.reactEmoji('nowiki');
 			}
 			}
-			else if ( body?.query?.general?.generator === 'MediaWiki 1.19.24' && wiki.isFandom(false) ) {
-				return fandom_overview(lang, msg, wiki, reaction, spoiler);
-			}
 			else {
 			else {
 				console.log( '- ' + response.statusCode + ': Error while getting the statistics: ' + ( body && body.error && body.error.info ) );
 				console.log( '- ' + response.statusCode + ': Error while getting the statistics: ' + ( body && body.error && body.error.info ) );
 				msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Statistics') + '>' + spoiler );
 				msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Statistics') + '>' + spoiler );

+ 0 - 4
cmds/wiki/random.js

@@ -1,5 +1,4 @@
 const {MessageEmbed} = require('discord.js');
 const {MessageEmbed} = require('discord.js');
-const fandom_random = require('./fandom/random.js').run;
 const parse_page = require('../../functions/parse_page.js');
 const parse_page = require('../../functions/parse_page.js');
 const logging = require('../../util/logging.js');
 const logging = require('../../util/logging.js');
 const {htmlToDiscord} = require('../../util/functions.js');
 const {htmlToDiscord} = require('../../util/functions.js');
@@ -22,9 +21,6 @@ function gamepedia_random(lang, msg, wiki, reaction, spoiler) {
 				console.log( '- This wiki doesn\'t exist!' );
 				console.log( '- This wiki doesn\'t exist!' );
 				msg.reactEmoji('nowiki');
 				msg.reactEmoji('nowiki');
 			}
 			}
-			else if ( body?.query?.general?.generator === 'MediaWiki 1.19.24' && wiki.isFandom(false) ) {
-				return fandom_random(lang, msg, wiki, reaction, spoiler);
-			}
 			else {
 			else {
 				console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
 				console.log( '- ' + response.statusCode + ': Error while getting the search results: ' + ( body && body.error && body.error.info ) );
 				msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Random') + '>' + spoiler );
 				msg.sendChannelError( spoiler + '<' + wiki.toLink('Special:Random') + '>' + spoiler );

+ 0 - 1
util/newMessage.js

@@ -4,7 +4,6 @@ const {partialURIdecode} = require('./functions.js');
 const {limit: {command: commandLimit}, defaultSettings, wikiProjects} = require('./default.json');
 const {limit: {command: commandLimit}, defaultSettings, wikiProjects} = require('./default.json');
 const Wiki = require('./wiki.js');
 const Wiki = require('./wiki.js');
 const check_wiki = {
 const check_wiki = {
-	fandom: require('../cmds/wiki/fandom/general.js'),
 	general: require('../cmds/wiki/general.js'),
 	general: require('../cmds/wiki/general.js'),
 	test: require('../cmds/test.js').run
 	test: require('../cmds/test.js').run
 };
 };

+ 2 - 4
util/wiki.js

@@ -56,7 +56,6 @@ class Wiki extends URL {
 	/**
 	/**
 	 * Updates the wiki url.
 	 * Updates the wiki url.
 	 * @param {Object} siteinfo - Siteinfo from the wiki API.
 	 * @param {Object} siteinfo - Siteinfo from the wiki API.
-	 * @param {String} siteinfo.server - Server of the wiki with protocol. (For legacy Fandom wikis)
 	 * @param {String} siteinfo.servername - Hostname of the wiki.
 	 * @param {String} siteinfo.servername - Hostname of the wiki.
 	 * @param {String} siteinfo.scriptpath - Scriptpath of the wiki.
 	 * @param {String} siteinfo.scriptpath - Scriptpath of the wiki.
 	 * @param {String} siteinfo.articlepath - Articlepath of the wiki.
 	 * @param {String} siteinfo.articlepath - Articlepath of the wiki.
@@ -65,9 +64,8 @@ class Wiki extends URL {
 	 * @param {String} siteinfo.logo - Logo of the wiki.
 	 * @param {String} siteinfo.logo - Logo of the wiki.
 	 * @returns {Wiki}
 	 * @returns {Wiki}
 	 */
 	 */
-	updateWiki({server, servername, scriptpath, articlepath, mainpage, centralidlookupprovider, logo}) {
-		if ( servername ) this.hostname = servername;
-		else this.hostname = server.replace( /^(?:https?:)?\/\//, '' );
+	updateWiki({servername, scriptpath, articlepath, mainpage, centralidlookupprovider, logo}) {
+		this.hostname = servername;
 		this.pathname = scriptpath + '/';
 		this.pathname = scriptpath + '/';
 		this.articlepath = articlepath;
 		this.articlepath = articlepath;
 		this.mainpage = mainpage;
 		this.mainpage = mainpage;