1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- var db = require('../util/database.js');
- var verify = require('../functions/verify.js');
- /**
- * Processes the "verify" command.
- * @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 {String} line - The command as plain text.
- * @param {import('../util/wiki.js')} wiki - The wiki for the message.
- */
- function cmd_verify(lang, msg, args, line, wiki) {
- if ( !msg.channel.isGuild() || msg.defaultSettings ) return this.LINK(lang, msg, line, wiki);
- if ( !msg.guild.me.permissions.has('MANAGE_ROLES') ) {
- if ( msg.isAdmin() ) {
- console.log( msg.guild.id + ': Missing permissions - MANAGE_ROLES' );
- msg.replyMsg( lang.get('general.missingperm') + ' `MANAGE_ROLES`' );
- }
- else if ( !msg.onlyVerifyCommand ) this.LINK(lang, msg, line, wiki);
- return;
- }
-
- var username = args.join(' ').replace( /_/g, ' ' ).trim().replace( /^<\s*(.*)\s*>$/, '$1' ).replace( /^@/, '' ).split('#')[0].substring(0, 250).trim();
- if ( /^(?:https?:)?\/\/([a-z\d-]{1,50})\.(?:gamepedia\.com\/|(?:fandom\.com|wikia\.org)\/(?:[a-z-]{1,8}\/)?wiki\/)/.test(username) ) {
- username = decodeURIComponent( username.replace( /^(?:https?:)?\/\/([a-z\d-]{1,50})\.(?:gamepedia\.com\/|(?:fandom\.com|wikia\.org)\/(?:[a-z-]{1,8}\/)?wiki\/)/, '' ) );
- }
- if ( wiki.isGamepedia() ) username = username.replace( /^userprofile\s*:/i, '' );
-
- db.query( 'SELECT role, editcount, postcount, usergroup, accountage, rename FROM verification WHERE guild = $1 AND channel LIKE $2 ORDER BY configid ASC', [msg.guild.id, '%|' + msg.channel.id + '|%'] ).then( ({rows}) => {
- if ( !rows.length ) {
- if ( msg.onlyVerifyCommand ) return;
- return msg.replyMsg( lang.get('verify.missing') + ( msg.isAdmin() ? '\n`' + ( patreons[msg.guild.id] || process.env.prefix ) + 'verification`' : '' ) );
- }
-
- if ( !username.trim() ) {
- args[0] = line.split(' ')[0];
- if ( args[0] === 'verification' ) args[0] = ( lang.localNames.verify || 'verify' );
- return this.help(lang, msg, args, line, wiki);
- }
- msg.reactEmoji('⏳').then( reaction => {
- verify(lang, msg, username, wiki, rows).then( result => {
- if ( result.reaction ) {
- if ( result.content ) msg.replyMsg( result.content, result.options, false, false ).then( message => {
- if ( message ) message.reactEmoji(result.reaction);
- } );
- else msg.reactEmoji(result.reaction);
- }
- else msg.replyMsg( result.content, result.options, false, false );
- if ( reaction ) reaction.removeEmoji();
- }, error => {
- console.log( '- Error during the verifications: ' + error );
- msg.replyMsg( lang.get('verify.error_reply'), {}, false, false ).then( message => {
- if ( message ) message.reactEmoji('error');
- } );
- } );
- } );
- }, dberror => {
- console.log( '- Error while getting the verifications: ' + dberror );
- msg.replyMsg( lang.get('verify.error_reply'), {}, false, false ).then( message => {
- if ( message ) message.reactEmoji('error');
- } );
- } );
- }
- module.exports = {
- name: 'verify',
- everyone: true,
- pause: false,
- owner: false,
- run: cmd_verify
- };
|