diff options
Diffstat (limited to 'commands/mod')
-rw-r--r-- | commands/mod/sticky.js | 84 | ||||
-rw-r--r-- | commands/mod/ticket.js | 1 | ||||
-rw-r--r-- | commands/mod/whois.js | 18 |
3 files changed, 70 insertions, 33 deletions
diff --git a/commands/mod/sticky.js b/commands/mod/sticky.js index b3dc055..f5034de 100644 --- a/commands/mod/sticky.js +++ b/commands/mod/sticky.js @@ -4,6 +4,7 @@ const db = require("../../src/db") let config_loc = __filename+".json" let config = JSON.parse(fs.readFileSync(config_loc)) const {upload_limit} = require("../../src/util") +const options = ["add","remove","dump"] module.exports = { name : "sticky", command: ["sticky"], @@ -14,44 +15,73 @@ module.exports = { switch(args[0]){ case 'add': case 'a': - if(args.length<3){ - message.reply("not enough parameters, try `sns help sticky`") - break; - } - db.Sticky.create({channel:args[1],message:args[2],last_message:'null',embed:args.includes("embed"),embed_color:config.embed_color}); - message.react("✅") + this.p_add(client,Discord,message,args[1],args[2],args.includes("embed")) break; case 'rem': case 'remove': case 'r': - if(args.length<2){ - message.reply("not enough parameters, try `sns help sticky`") - break; - } - let initial = await db.Sticky.count() - await db.Sticky.destroy({ - where: { - channel: args[1] - } - }); - message.reply("removed "+(initial-(await db.Sticky.count()))+" item(s)") + this.p_rem(client,Discord,message,args[1]); break; case 'dump': case 'list': - let list = await db.Sticky.findAll() - let flist = "channelid : message : last message\n" - for(let l of list) - flist+=l.channel+" : "+l.message+" : "+l.last_message+"\n" - let filename = "/tmp/sticky.json" - fs.writeFileSync(filename,flist) - let stats = fs.statSync(filename) - if(stats.size / (1024*1024) > upload_limit(message.guild)) - return message.reply("file too large:( file is "+stats.size / (1024*1024)+"mb") - message.reply({files:[filename]}) + this.p_dump(client,Discord,message); break; default: message.reply("unknown action, try `sns help sticky`") } }, + s_options:[{type:"string",name:"action",desc:"what to do",required:true,autocomplete:["add","remove","dump"]}, + {type:"string",name:"message",desc:"(required for add) message to be sent",required:false,autocomplete:false}, + {type:"channel",name:"chan",desc:"(required for remove and add) channel to clear",required:false,autocomplete:false}, + {type:"bool",name:"embed",desc:"whether or not to use a embed",required:false,autocomplete:false}], + async s_main(client,Discord,interaction){ + let action = interaction.options.getString("action") + let mess = interaction.options.getString("message") + let chan = interaction.options.getChannel("chan") + let embed = interaction.options.getBoolean("embed") + if(!options.includes(action)) + return interaction.reply({content:"please use the autocomplete, (valid values are add, remove, and dump)",ephemeral: true}) + if(action=="add") return this.p_add(client,Discord,interaction,chan.id,mess,embed) + if(action=="remove") return this.p_rem(client,Discord,interaction,chan.id) + if(action=="dump") return this.p_dump(client,Discord,interaction) + }, + async p_dump(client,Discord,message){ + let list = await db.Sticky.findAll() + let flist = "channelid : message : last message\n" + for(let l of list) + flist+=l.channel+" : "+l.message+" : "+l.last_message+"\n" + let filename = "/tmp/sticky.json" + fs.writeFileSync(filename,flist) + let stats = fs.statSync(filename) + if(stats.size / (1024*1024) > upload_limit(message.guild)) + return message.reply("file too large:( file is "+stats.size / (1024*1024)+"mb") + message.reply({files:[filename]}) + }, + async p_rem(client,Discord,message,chan){ + if(chan==null){ + message.reply("no channel provided") + return; + } + let initial = await db.Sticky.count() + await db.Sticky.destroy({ + where: { + channel: chan + } + }); + message.reply("removed "+(initial-(await db.Sticky.count()))+" item(s)") + }, + async p_add(client,Discord,message,chan,mess,embed){ + if(chan==null){ + message.reply("no channel provided") + return; + } + if(mess==null){ + message.reply("no message provided") + return; + } + db.Sticky.create({channel:chan,message:mess,last_message:'null',embed:embed ?? false,embed_color:config.embed_color}); + //message.react("✅") + message.reply("added") + } }
\ No newline at end of file diff --git a/commands/mod/ticket.js b/commands/mod/ticket.js index 5e69ed7..e499dd8 100644 --- a/commands/mod/ticket.js +++ b/commands/mod/ticket.js @@ -78,6 +78,7 @@ module.exports = { break; case 'dump': case 'list': + if(param.ticket_id==null) return param.message.reply("you must provide a ticket id") tickets = await db.Tickets.findAll({where:{ticket:param.ticket_id}}) if(tickets.length==0){ return param.message.reply("ticket not found:c") diff --git a/commands/mod/whois.js b/commands/mod/whois.js index 56d2645..1926885 100644 --- a/commands/mod/whois.js +++ b/commands/mod/whois.js @@ -70,13 +70,19 @@ module.exports = { let created = new Date(parseInt(user.user.createdAt / 1000, 10)*1000).toLocaleDateString(undefined,{ weekday: 'long', year: 'numeric', month: 'long', day: 'numeric' }); let mod = user.permissions!=null&&user.permissions?.has(PermissionsBitField.Flags.KickMembers) let roles = "" - //console.log(message.mentions.users) + let color = {pos:-1,color:settings.defaultColor}; + message.channel.send("loading ids").then(async(m)=>{ await m.edit("<@!"+user.id+">") m.delete() }) - for(let r of user._roles) - roles+="<@&"+r+"> " + for(let r in user._roles){ + let role = message.guild.roles.cache.get(user._roles[r]) + if(role.color!=0&&role.rawPosition>color.pos) + color={pos:role.rawPosition,color:role.color} + roles+="<@&"+user._roles[r]+"> " + } + const embed = new EmbedBuilder() .setAuthor({name:user.user.username,iconURL:user.displayAvatarURL()}) .setThumbnail(user.displayAvatarURL()) @@ -85,12 +91,12 @@ module.exports = { { name: 'Created', value:created , inline: true }, { name: 'Roles ['+user._roles.length+']', value:roles }]) .setFooter({text:"id:"+user.id}) - .setColor(settings.defaultColor) + .setColor(color.color) message.reply({embeds:[embed]}) }, async p_role(client,Discord,message,role){ let members = " " - //console.log(message.guild.members) + let members_m = Object.fromEntries(message.guild.roles.cache.get(role.id).members) let members_a = [] for(let k of Object.keys(members_m)){ @@ -114,7 +120,7 @@ module.exports = { .addFields([{ name: 'Mentionable', value:(role.mentionable?"true":"false"), inline: true }, {name: 'Users ['+role.members.size+"]",value:members}]) .setFooter({text:"id:"+role.id}) - .setColor(settings.defaultColor) + .setColor(role.color) message.reply({embeds:[embed]}) } }; |