get.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216
  1. import { MessageEmbed, Util, ShardClientUtil, Permissions } from 'discord.js';
  2. import { escapeFormatting } from '../util/functions.js';
  3. import db from '../util/database.js';
  4. import { createRequire } from 'module';
  5. const require = createRequire(import.meta.url);
  6. const {defaultSettings, defaultPermissions} = require('../util/default.json');
  7. const {shardIdForGuildId} = ShardClientUtil;
  8. /**
  9. * Processes the "get" command.
  10. * @param {import('../util/i18n.js').default} lang - The user language.
  11. * @param {import('discord.js').Message} msg - The Discord message.
  12. * @param {String[]} args - The command arguments.
  13. * @param {String} line - The command as plain text.
  14. * @param {import('../util/wiki.js').default} wiki - The wiki for the message.
  15. * @async
  16. */
  17. async function cmd_get(lang, msg, args, line, wiki) {
  18. var id = args.join().replace( /^\\?<(?:@!?|#)(\d+)>$/, '$1' );
  19. if ( !/^\d+$/.test(id) ) {
  20. if ( !msg.inGuild() || !pausedGuilds.has(msg.guildId) ) this.LINK(lang, msg, line, wiki);
  21. return;
  22. }
  23. try {
  24. var guild = await msg.client.shard.broadcastEval( (discordClient, evalData) => {
  25. if ( discordClient.guilds.cache.has(evalData.id) ) {
  26. var guild = discordClient.guilds.cache.get(evalData.id);
  27. return {
  28. name: guild.name, id: guild.id, memberCount: guild.approximateMemberCount ?? guild.memberCount,
  29. ownerId: guild.ownerId, owner: discordClient.users.cache.get(guild.ownerId)?.tag,
  30. channel: guild.publicUpdatesChannelId, icon: guild.iconURL({dynamic:true}),
  31. permissions: guild.me.permissions.missing(evalData.defaultPermissions),
  32. pause: pausedGuilds.has(guild.id), voice: voiceGuildsLang.has(guild.id),
  33. shardId: process.env.SHARDS
  34. };
  35. }
  36. }, {
  37. context: {id, defaultPermissions},
  38. shard: shardIdForGuildId(id, msg.client.shard.count)
  39. } );
  40. if ( guild ) {
  41. var guildname = ['Guild:', escapeFormatting(guild.name) + ' `' + guild.id + '`' + ( guild.pause ? '\\*' : '' )];
  42. var guildowner = ['Owner:', ( guild.owner ? escapeFormatting(guild.owner) + ' ' : '' ) + '`' + guild.ownerId + '` <@' + guild.ownerId + '>'];
  43. var guildsize = ['Size:', guild.memberCount + ' members'];
  44. var guildshard = ['Shard:', guild.shardId];
  45. var guildpermissions = ['Missing permissions:', ( guild.permissions.length ? '`' + guild.permissions.join('`, `') + '`' : '*none*' )];
  46. var guildchannel = ['Updates channel:', '`' + guild.channel + '`'];
  47. var guildsettings = ['Settings:', '*unknown*'];
  48. return db.query( 'SELECT channel, wiki, lang, role, inline, prefix FROM discord WHERE guild = $1 ORDER BY channel ASC NULLS FIRST', [guild.id] ).then( ({rows}) => {
  49. if ( rows.length ) {
  50. let row = rows.find( row => !row.channel );
  51. row.patreon = patreonGuildsPrefix.has(guild.id);
  52. row.voice = guild.voice;
  53. guildsettings[1] = '```json\n' + JSON.stringify( rows, null, '\t' ) + '\n```';
  54. }
  55. else guildsettings[1] = '*default*';
  56. }, dberror => {
  57. console.log( '- Error while getting the settings: ' + dberror );
  58. } ).then( () => {
  59. if ( msg.showEmbed() ) {
  60. var embed = new MessageEmbed().setThumbnail( guild.icon ).addField( guildname[0], guildname[1] ).addField( guildowner[0], guildowner[1] ).addField( guildsize[0], guildsize[1], true ).addField( guildshard[0], guildshard[1], true ).addField( guildpermissions[0], guildpermissions[1] );
  61. if ( guild.channel ) embed.addField( guildchannel[0], guildchannel[1] );
  62. var split = Util.splitMessage( guildsettings[1], {char:',\n',maxLength:1000,prepend:'```json\n',append:',\n```'} );
  63. if ( split.length > 5 ) {
  64. msg.sendChannel( {embeds: [embed]}, true );
  65. Util.splitMessage( guildsettings.join(' '), {
  66. char: ',\n',
  67. maxLength: 2000,
  68. prepend: '```json\n',
  69. append: ',\n```'
  70. } ).forEach( textpart => msg.sendChannel( textpart, true ) );
  71. }
  72. else {
  73. split.forEach( textpart => embed.addField( guildsettings[0], textpart ) );
  74. msg.sendChannel( {embeds: [embed]}, true );
  75. }
  76. }
  77. else {
  78. var text = guildname.join(' ') + '\n' + guildowner.join(' ') + '\n' + guildsize.join(' ') + '\n' + guildshard.join(' ') + '\n' + guildpermissions.join(' ') + ( guild.channel ? '\n' + guildchannel.join(' ') : '' ) + '\n' + guildsettings.join(' ');
  79. Util.splitMessage( text, {
  80. char: ',\n',
  81. maxLength: 2000,
  82. prepend: '```json\n',
  83. append: ',\n```'
  84. } ).forEach( textpart => msg.sendChannel( textpart, true ) );
  85. }
  86. } );
  87. }
  88. var channel = await msg.client.shard.broadcastEval( (discordClient, evalData) => {
  89. if ( discordClient.channels.cache.filter( channel => ( channel.isText() && channel.guildId ) || channel.type === 'GUILD_CATEGORY' ).has(evalData.id) ) {
  90. var channel = discordClient.channels.cache.get(evalData.id);
  91. return {
  92. name: channel.name, id: channel.id, type: channel.type, parentId: channel.parentId,
  93. isThread: channel.isThread(), threadParentId: channel.parent?.parentId,
  94. guild: channel.guild.name, guildId: channel.guildId,
  95. permissions: channel.guild.me.permissionsIn(channel.id).missing(evalData.defaultPermissions),
  96. pause: pausedGuilds.has(channel.guildId),
  97. shardId: process.env.SHARDS
  98. };
  99. }
  100. }, {context: {id, defaultPermissions}} ).then( results => results.find( result => result ) );
  101. if ( channel ) {
  102. var channelguild = ['Guild:', escapeFormatting(channel.guild) + ' `' + channel.guildId + '`' + ( channel.pause ? '\\*' : '' )];
  103. var channelname = ['Channel:', '#' + escapeFormatting(channel.name) + ' `' + channel.id + '` <#' + channel.id + '>'];
  104. var channeldetails = ['Details:', '`' + channel.type + '`' + ( channel.parentId ? ' – `' + channel.parentId + '` <#' + channel.parentId + '>' + ( channel.isThread ? ' – `' + channel.threadParentId + '` <#' + channel.threadParentId + '>' : '' ) : '' )];
  105. var channelpermissions = ['Missing permissions:', ( channel.permissions.length ? '`' + channel.permissions.join('`, `') + '`' : '*none*' )];
  106. var channellang = ['Language:', '*unknown*'];
  107. var channelwiki = ['Default Wiki:', '*unknown*'];
  108. var channelrole = ['Minimal Role:', '*unknown*'];
  109. var channelinline = ['Inline commands:', '*unknown*'];
  110. let sqlargs = [channel.guildId];
  111. if ( channel.isThread ) sqlargs.push(channel.parentId, '#' + channel.threadParentId);
  112. else sqlargs.push(channel.id, '#' + ( channel.type === 'GUILD_CATEGORY' ? channel.id : channel.parentId ));
  113. return db.query( 'SELECT wiki, lang, role, inline 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]}) => {
  114. if ( row ) {
  115. channellang[1] = row.lang;
  116. channelwiki[1] = row.wiki;
  117. channelrole[1] = ( row.role ? '`' + row.role + '` <@&' + row.role + '>' : '@everyone' );
  118. channelinline[1] = ( row.inline ? 'disabled' : 'enabled' );
  119. }
  120. else {
  121. channellang[1] = defaultSettings.lang;
  122. channelwiki[1] = defaultSettings.wiki;
  123. channelrole[1] = '@everyone';
  124. channelinline[1] = 'enabled';
  125. }
  126. }, dberror => {
  127. console.log( '- Error while getting the settings: ' + dberror );
  128. } ).then( () => {
  129. var text = null;
  130. var embed = null;
  131. if ( msg.showEmbed() ) {
  132. embed = new MessageEmbed().addField( channelguild[0], channelguild[1] ).addField( channelname[0], channelname[1] ).addField( channeldetails[0], channeldetails[1] ).addField( channelpermissions[0], channelpermissions[1] ).addField( channellang[0], channellang[1] ).addField( channelwiki[0], channelwiki[1] ).addField( channelrole[0], channelrole[1] ).addField( channelinline[0], channelinline[1] );
  133. }
  134. else {
  135. text = channelguild.join(' ') + '\n' + channelname.join(' ') + '\n' + channeldetails.join(' ') + '\n' + channelpermissions.join(' ') + '\n' + channellang.join(' ') + '\n' + channelwiki[0] + ' <' + channelwiki[1] + '>\n' + channelrole.join(' ') + '\n' + channelinline.join(' ');
  136. }
  137. msg.sendChannel( {content: text, embeds: [embed]}, true );
  138. } );
  139. }
  140. var user = await msg.client.users.fetch(id, false).catch( () => {} );
  141. if ( user ) {
  142. var username = ['User:', escapeFormatting(user.tag) + ' `' + user.id + '` <@' + user.id + '>'];
  143. var guildlist = ['Guilds:', '*none*'];
  144. var guilds = await msg.client.shard.broadcastEval( (discordClient, evalData) => {
  145. return discordClient.guilds.cache.filter( guild => guild.members.cache.has(evalData.user) ).map( guild => {
  146. var member = guild.members.cache.get(evalData.user);
  147. return {
  148. name: guild.name,
  149. id: guild.id,
  150. isAdmin: member.permissions.has(evalData.MANAGE_GUILD),
  151. shardId: process.env.SHARDS
  152. }
  153. } );
  154. }, {context: {user: user.id, MANAGE_GUILD: Permissions.FLAGS.MANAGE_GUILD.toString()}} ).then( results => {
  155. return results.reduce( (acc, val) => acc.concat(val), [] ).map( user_guild => {
  156. return escapeFormatting(user_guild.name) + ' `' + user_guild.id + '`' + ( user_guild.isAdmin ? '\\*' : '' );
  157. } );
  158. } );
  159. if ( guilds.length ) guildlist[1] = guilds.join('\n');
  160. if ( guildlist[1].length > 1000 ) guildlist[1] = guilds.length.toLocaleString();
  161. var text = null;
  162. var embed = null;
  163. if ( msg.showEmbed() ) embed = new MessageEmbed().setThumbnail( user.displayAvatarURL({dynamic:true}) ).addField( username[0], username[1] ).addField( guildlist[0], guildlist[1] );
  164. else text = username.join(' ') + '\n' + guildlist.join('\n');
  165. return msg.sendChannel( {content: text, embeds: [embed]}, true );
  166. }
  167. return db.query( 'SELECT guild, channel, wiki, lang, role, inline, prefix, patreon, voice FROM discord WHERE guild = $1 OR channel = $1 OR channel = $2 ORDER BY guild, channel DESC NULLS LAST LIMIT 1', [id, '#' + id] ).then( ({rows}) => {
  168. if ( !rows.length ) return msg.replyMsg( 'I couldn\'t find a result for `' + id + '`', true );
  169. var result = '```json\n' + JSON.stringify( rows, null, '\t' ) + '\n```';
  170. if ( msg.showEmbed() ) {
  171. var split = Util.splitMessage( result, {char:',\n',maxLength:1000,prepend:'```json\n',append:',\n```'} );
  172. if ( split.length > 5 ) {
  173. Util.splitMessage( '`' + id + '`: ' + result, {
  174. char: ',\n',
  175. maxLength: 2000,
  176. prepend: '```json\n',
  177. append: ',\n```'
  178. } ).forEach( textpart => msg.sendChannel( textpart, true ) );
  179. }
  180. else {
  181. var embed = new MessageEmbed();
  182. split.forEach( textpart => embed.addField( '`' + id + '`: ', textpart ) );
  183. msg.sendChannel( {embeds: [embed]}, true );
  184. }
  185. }
  186. else {
  187. Util.splitMessage( '`' + id + '`: ' + result, {
  188. char: ',\n',
  189. maxLength: 2000,
  190. prepend: '```json\n',
  191. append: ',\n```'
  192. } ).forEach( textpart => msg.sendChannel( textpart, true ) );
  193. }
  194. }, dberror => {
  195. console.log( '- Error while getting the settings: ' + dberror );
  196. msg.reactEmoji('error');
  197. } );
  198. } catch ( error ) {
  199. log_error(error);
  200. msg.reactEmoji('error');
  201. }
  202. }
  203. export default {
  204. name: 'get',
  205. everyone: false,
  206. pause: false,
  207. owner: true,
  208. run: cmd_get
  209. };