verify.js 3.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. var db = require('../util/database.js');
  2. var verify = require('../functions/verify.js');
  3. /**
  4. * Processes the "verify" command.
  5. * @param {import('../util/i18n.js')} lang - The user language.
  6. * @param {import('discord.js').Message} msg - The Discord message.
  7. * @param {String[]} args - The command arguments.
  8. * @param {String} line - The command as plain text.
  9. * @param {import('../util/wiki.js')} wiki - The wiki for the message.
  10. */
  11. function cmd_verify(lang, msg, args, line, wiki) {
  12. if ( !msg.channel.isGuild() || msg.defaultSettings ) return this.LINK(lang, msg, line, wiki);
  13. if ( !msg.guild.me.permissions.has('MANAGE_ROLES') ) {
  14. if ( msg.isAdmin() ) {
  15. console.log( msg.guild.id + ': Missing permissions - MANAGE_ROLES' );
  16. msg.replyMsg( lang.get('general.missingperm') + ' `MANAGE_ROLES`' );
  17. }
  18. else if ( !msg.onlyVerifyCommand ) this.LINK(lang, msg, line, wiki);
  19. return;
  20. }
  21. 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}) => {
  22. if ( !rows.length ) {
  23. if ( msg.onlyVerifyCommand ) return;
  24. return msg.replyMsg( lang.get('verify.missing') + ( msg.isAdmin() ? '\n`' + ( patreons[msg.guild.id] || process.env.prefix ) + 'verification`' : '' ) );
  25. }
  26. var username = args.join(' ').replace( /_/g, ' ' ).trim().replace( /^<\s*(.*)\s*>$/, '$1' ).replace( /^@/, '' ).split('#')[0].substring(0, 250).trim();
  27. if ( /^(?:https?:)?\/\/([a-z\d-]{1,50})\.(?:gamepedia\.com\/|(?:fandom\.com|wikia\.org)\/(?:[a-z-]{1,8}\/)?(?:wiki\/)?)/.test(username) ) {
  28. username = decodeURIComponent( username.replace( /^(?:https?:)?\/\/([a-z\d-]{1,50})\.(?:gamepedia\.com\/|(?:fandom\.com|wikia\.org)\/(?:[a-z-]{1,8}\/)?(?:wiki\/)?)/, '' ) );
  29. }
  30. if ( wiki.isGamepedia() ) username = username.replace( /^userprofile\s*:\s*/i, '' );
  31. if ( !username.trim() ) {
  32. args[0] = line.split(' ')[0];
  33. if ( args[0] === 'verification' ) args[0] = ( lang.localNames.verify || 'verify' );
  34. return this.help(lang, msg, args, line, wiki);
  35. }
  36. msg.reactEmoji('⏳').then( reaction => {
  37. verify(lang, msg.channel, msg.member, username, wiki, rows).then( result => {
  38. if ( result.reaction ) msg.reactEmoji(result.reaction);
  39. else msg.replyMsg( result.content, {embed: result.embed}, false, false ).then( message => {
  40. if ( !result.logging.channel || !msg.guild.channels.cache.has(result.logging.channel) ) return;
  41. if ( message ) {
  42. if ( result.logging.embed ) result.logging.embed.addField(message.url, '<#' + msg.channel.id + '>');
  43. else result.logging.content += '\n<#' + msg.channel.id + '> – <' + message.url + '>';
  44. }
  45. msg.guild.channels.cache.get(result.logging.channel).send(result.logging.content, {
  46. embed: result.logging.embed,
  47. allowedMentions: {parse: []}
  48. }).catch(log_error);
  49. } );
  50. if ( reaction ) reaction.removeEmoji();
  51. }, error => {
  52. console.log( '- Error during the verifications: ' + error );
  53. msg.replyMsg( lang.get('verify.error_reply'), {}, false, false ).then( message => {
  54. if ( message ) message.reactEmoji('error');
  55. } );
  56. } );
  57. } );
  58. }, dberror => {
  59. console.log( '- Error while getting the verifications: ' + dberror );
  60. msg.replyMsg( lang.get('verify.error_reply'), {}, false, false ).then( message => {
  61. if ( message ) message.reactEmoji('error');
  62. } );
  63. } );
  64. }
  65. module.exports = {
  66. name: 'verify',
  67. everyone: true,
  68. pause: false,
  69. owner: false,
  70. run: cmd_verify
  71. };