瀏覽代碼

fix crashes

Markus-Rost 3 年之前
父節點
當前提交
b7110c807e
共有 6 個文件被更改,包括 18 次插入3 次删除
  1. 1 1
      bot.js
  2. 1 0
      cmds/eval.js
  3. 12 2
      dashboard/oauth.js
  4. 2 0
      dashboard/rcscript.js
  5. 1 0
      dashboard/settings.js
  6. 1 0
      util/wiki.js

+ 1 - 1
bot.js

@@ -282,7 +282,7 @@ function messageCreate(msg) {
 				console.log( msg.guildId + ': Missing permissions - ' + missing.join(', ') );
 				console.log( msg.guildId + ': Missing permissions - ' + missing.join(', ') );
 				if ( !missing.includes( 'SEND_MESSAGES' ) && !missing.includes( 'SEND_MESSAGES_IN_THREADS' ) ) {
 				if ( !missing.includes( 'SEND_MESSAGES' ) && !missing.includes( 'SEND_MESSAGES_IN_THREADS' ) ) {
 					db.query( 'SELECT lang FROM discord WHERE guild = $1 AND (channel = $2 OR channel = $3 OR channel IS NULL) ORDER BY channel DESC NULLS LAST LIMIT 1', sqlargs ).then( ({rows:[row]}) => {
 					db.query( 'SELECT lang FROM discord WHERE guild = $1 AND (channel = $2 OR channel = $3 OR channel IS NULL) ORDER BY channel DESC NULLS LAST LIMIT 1', sqlargs ).then( ({rows:[row]}) => {
-						return row.lang;
+						return row?.lang;
 					}, dberror => {
 					}, dberror => {
 						console.log( '- Error while getting the lang: ' + dberror );
 						console.log( '- Error while getting the lang: ' + dberror );
 					} ).then( lang => {
 					} ).then( lang => {

+ 1 - 0
cmds/eval.js

@@ -59,6 +59,7 @@ function database(sql, sqlargs = []) {
  */
  */
 function checkWiki(wiki) {
 function checkWiki(wiki) {
 	wiki = Wiki.fromInput(wiki);
 	wiki = Wiki.fromInput(wiki);
+	if ( !wiki ) return `Couldn't resolve "${wiki}" into a valid url.`;
 	return got.get( wiki + 'api.php?&action=query&meta=siteinfo&siprop=general&list=recentchanges&rcshow=!bot&rctype=edit|new|log|categorize&rcprop=ids|timestamp&rclimit=100&format=json' ).then( response => {
 	return got.get( wiki + 'api.php?&action=query&meta=siteinfo&siprop=general&list=recentchanges&rcshow=!bot&rctype=edit|new|log|categorize&rcprop=ids|timestamp&rclimit=100&format=json' ).then( response => {
 		if ( response.statusCode === 404 && typeof response.body === 'string' ) {
 		if ( response.statusCode === 404 && typeof response.body === 'string' ) {
 			let api = cheerio.load(response.body)('head link[rel="EditURI"]').prop('href');
 			let api = cheerio.load(response.body)('head link[rel="EditURI"]').prop('href');

+ 12 - 2
dashboard/oauth.js

@@ -255,14 +255,24 @@ function dashboard_api(res, input) {
 		api: true,
 		api: true,
 		error: false,
 		error: false,
 		error_code: '',
 		error_code: '',
-		wiki: wiki.href,
+		wiki: wiki?.href,
 		base: '',
 		base: '',
 		sitename: '',
 		sitename: '',
 		logo: '',
 		logo: '',
 		MediaWiki: false,
 		MediaWiki: false,
 		RcGcDw: '',
 		RcGcDw: '',
-		customRcGcDw: wiki.toLink('MediaWiki:Custom-RcGcDw', 'action=edit')
+		customRcGcDw: wiki?.toLink('MediaWiki:Custom-RcGcDw', 'action=edit')
 	};
 	};
+	if ( !wiki ) {
+		result.error = true;
+		let body = JSON.stringify(result);
+		res.writeHead(200, {
+			'Content-Length': Buffer.byteLength(body),
+			'Content-Type': 'application/json'
+		});
+		res.write( body );
+		return res.end();
+	}
 	return got.get( wiki + 'api.php?&action=query&meta=allmessages|siteinfo&ammessages=custom-RcGcDw&amenableparser=true&siprop=general&format=json', {
 	return got.get( wiki + 'api.php?&action=query&meta=allmessages|siteinfo&ammessages=custom-RcGcDw&amenableparser=true&siprop=general&format=json', {
 		responseType: 'text'
 		responseType: 'text'
 	} ).then( response => {
 	} ).then( response => {

+ 2 - 0
dashboard/rcscript.js

@@ -378,6 +378,7 @@ function update_rcscript(res, userSettings, guild, type, settings) {
 				return res(`/guild/${guild}/rcscript`, 'savefail');
 				return res(`/guild/${guild}/rcscript`, 'savefail');
 			}
 			}
 			var wiki = Wiki.fromInput(settings.wiki);
 			var wiki = Wiki.fromInput(settings.wiki);
+			if ( !wiki ) return res(`/guild/${guild}/rcscript/new`, 'savefail');
 			return got.get( wiki + 'api.php?&action=query&meta=allmessages|siteinfo&ammessages=custom-RcGcDw|recentchanges&amenableparser=true&siprop=general&titles=Special:RecentChanges&format=json', {
 			return got.get( wiki + 'api.php?&action=query&meta=allmessages|siteinfo&ammessages=custom-RcGcDw|recentchanges&amenableparser=true&siprop=general&titles=Special:RecentChanges&format=json', {
 				responseType: 'text'
 				responseType: 'text'
 			} ).then( fresponse => {
 			} ).then( fresponse => {
@@ -622,6 +623,7 @@ function update_rcscript(res, userSettings, guild, type, settings) {
 				if ( ( row.postid === '-1' ) !== !settings.feeds ) hasDiff = true;
 				if ( ( row.postid === '-1' ) !== !settings.feeds ) hasDiff = true;
 				if ( !hasDiff ) return res(`/guild/${guild}/rcscript/${type}`, 'save');
 				if ( !hasDiff ) return res(`/guild/${guild}/rcscript/${type}`, 'save');
 				var wiki = Wiki.fromInput(settings.wiki);
 				var wiki = Wiki.fromInput(settings.wiki);
+				if ( !wiki ) return res(`/guild/${guild}/rcscript/${type}`, 'savefail');
 				return got.get( wiki + 'api.php?&action=query&meta=allmessages|siteinfo&ammessages=custom-RcGcDw&amenableparser=true&siprop=general&format=json', {
 				return got.get( wiki + 'api.php?&action=query&meta=allmessages|siteinfo&ammessages=custom-RcGcDw&amenableparser=true&siprop=general&format=json', {
 					responseType: 'text'
 					responseType: 'text'
 				} ).then( fresponse => {
 				} ).then( fresponse => {

+ 1 - 0
dashboard/settings.js

@@ -346,6 +346,7 @@ function update_settings(res, userSettings, guild, type, settings) {
 			return res(`/guild/${guild}/settings/${type}`, 'savefail');
 			return res(`/guild/${guild}/settings/${type}`, 'savefail');
 		} );
 		} );
 		var wiki = Wiki.fromInput(settings.wiki);
 		var wiki = Wiki.fromInput(settings.wiki);
+		if ( !wiki ) return res(`/guild/${guild}/settings`, 'savefail');
 		var embed;
 		var embed;
 		return got.get( wiki + 'api.php?&action=query&meta=siteinfo&siprop=general&format=json', {
 		return got.get( wiki + 'api.php?&action=query&meta=siteinfo&siprop=general&format=json', {
 			responseType: 'text'
 			responseType: 'text'

+ 1 - 0
util/wiki.js

@@ -255,6 +255,7 @@ export default class Wiki extends URL {
 				if ( !input.includes( '.' ) ) return new Wiki('https://' + input + '.fandom.com/');
 				if ( !input.includes( '.' ) ) return new Wiki('https://' + input + '.fandom.com/');
 				else return new Wiki('https://' + input.split('.')[1] + '.fandom.com/' + input.split('.')[0] + '/');
 				else return new Wiki('https://' + input.split('.')[1] + '.fandom.com/' + input.split('.')[0] + '/');
 			}
 			}
+			return null;
 		}
 		}
 		catch {
 		catch {
 			return null;
 			return null;