diff --git a/commands/forceupdate.js b/commands/forceupdate.js index aaf1848..22d7270 100644 --- a/commands/forceupdate.js +++ b/commands/forceupdate.js @@ -1,9 +1,9 @@ const { SlashCommandBuilder, PermissionFlagsBits, userMention } = require('discord.js'); const { hypixelGuildID, color } = require('../config/options.json'); -const { gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff, defaultMember } = require('../config/roles.json'); +const { gm, manager, moderator, beast, elite, member, trialmember, guildRole, guildStaff, defaultMember } = require('../config/roles.json'); const verify = require('../schemas/verifySchema.js') const fetch = require('axios'); -const removeThese = [gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff] +const removeThese = [gm, manager, moderator, beast, elite, member, trialmember, guildRole, guildStaff] module.exports = { name: 'forceupdate', @@ -29,6 +29,7 @@ module.exports = { const usermentioned = userMention(user.id); const guild = interaction.guild; const verifyData = await verify.findOne({ userID: user.id }) + const embedColor = Number(color.replace("#", "0x")); const user1 = guild.members.cache.get(user.id); const roleManage = user1.roles; @@ -43,9 +44,6 @@ module.exports = { embeds: [{ description: usermentioned + " was given the the Default Member role.", color: embedColor, - thumbnail: { - url: head - }, footer: { text: interaction.guild.name + " | Developed by @Taken#0002", icon_url: interaction.guild.iconURL({ dynamic: true }) @@ -96,7 +94,6 @@ module.exports = { } const guildCheck = await fetch(guildAPI + verifyData.uuid); - const embedColor = Number(color.replace("#", "0x")); const GuildMembers = await guildCheck.data.members; const guildRank = GuildMembers.find(member => member.uuid === verifyData.uuid).rank; @@ -209,6 +206,33 @@ module.exports = { return } + if (guildRank === 'Elite' && responseGuildID === hypixelGuildID) { + + for (let i = 0; i < removeThese.length; i++) { + await roleManage.remove(removeThese[i], "Auto role removal. (Force Update)") + } + + await roleManage.add(guildRole, "User was force updated.") + await roleManage.add(elite, "User was force updated.") + await roleManage.add(defaultMember, "User was force updated.") + + + await interaction.editReply({ + embeds: [{ + description: usermentioned + "'s rank has been updated to `Elite`.", + color: embedColor, + thumbnail: { + url: head + }, + footer: { + text: interaction.guild.name + " | Developed by @Taken#0002", + icon_url: interaction.guild.iconURL({ dynamic: true }) + } + }] + }) + return + } + if (guildRank === 'Member' && responseGuildID === hypixelGuildID) { for (let i = 0; i < removeThese.length; i++) { @@ -263,4 +287,4 @@ module.exports = { return } } -} \ No newline at end of file +} diff --git a/commands/forceverify.js b/commands/forceverify.js index abe3039..ae4b806 100644 --- a/commands/forceverify.js +++ b/commands/forceverify.js @@ -5,7 +5,7 @@ const fetch = require('axios'); const { color, hypixelGuildID } = require('../config/options.json'); const verify = require('../schemas/verifySchema.js') const {mongoose} = require('mongoose'); -const { gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff, defaultMember } = require('../config/roles.json'); +const { gm, manager, moderator, beast, elite, member, trialmember, guildRole, guildStaff, defaultMember } = require('../config/roles.json'); module.exports = { @@ -146,6 +146,11 @@ module.exports = { await user.roles.add(guildRole, "User was force verified by " + modName) } + if (guildRank === "Elite" && guildCheck.data.id === hypixelGuildID) { + await user.roles.add(elite, "User was force verified by " + modName); + await user.roles.add(guildRole, "User was force verified by " + modName) + } + if (guildRank === "Member" && guildCheck.data.id === hypixelGuildID) { await user.roles.add(member, "User was force verified by " + modName); await user.roles.add(guildRole, "User was force verified by " + modName) diff --git a/commands/update.js b/commands/update.js index 30d26a1..ceb3b95 100644 --- a/commands/update.js +++ b/commands/update.js @@ -4,8 +4,8 @@ const hypixelApiKey = process.env.HYPIXELAPIKEY; const fetch = require('axios'); const verify = require('../schemas/verifySchema.js') const { color, hypixelGuildID } = require('../config/options.json'); -const { gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff, defaultMember } = require('../config/roles.json'); -const removeThese = [gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff]; +const { gm, manager, moderator, beast, elite, member, trialmember, guildRole, guildStaff, defaultMember } = require('../config/roles.json'); +const removeThese = [gm, manager, moderator, beast, elite, member, trialmember, guildRole, guildStaff]; module.exports = { name: 'update', @@ -198,6 +198,33 @@ module.exports = { return } + if (guildRank === 'Elite' && guildID === hypixelGuildID) { + + for (let i = 0; i < removeThese.length; i++) { + await roleManage.remove(removeThese[i], "Auto role removal. (Update)") + } + + await roleManage.add(guildRole, "User used the update command") + await roleManage.add(elite, "User used the update command") + await roleManage.add(defaultMember, "User used the update command") + + + await interaction.editReply({ + embeds: [{ + description: "Your rank has been updated to `Elite`.", + color: embedColor, + thumbnail: { + url: head + }, + footer: { + text: interaction.guild.name + " | Developed by @Taken#0002", + icon_url: interaction.guild.iconURL({ dynamic: true }) + } + }] + }) + return + } + if (guildRank === 'Member' && guildID === hypixelGuildID) { for (let i = 0; i < removeThese.length; i++) { diff --git a/commands/verify.js b/commands/verify.js index f92c55b..5074c0c 100644 --- a/commands/verify.js +++ b/commands/verify.js @@ -5,7 +5,7 @@ const fetch = require("axios"); const { color, hypixelGuildID } = require("../config/options.json"); const verify = require("../schemas/verifySchema.js"); const mongoose = require("mongoose"); -const { gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff, defaultMember } = require("../config/roles.json"); +const { gm, manager, moderator, beast, elite, member, trialmember, guildRole, guildStaff, defaultMember } = require("../config/roles.json"); module.exports = { name: "verify", @@ -148,6 +148,11 @@ module.exports = { await user.roles.add(guildRole, "Verification"); } + if (guildRank === "Elite" && guildID === hypixelGuildID) { + await user.roles.add(elite, "Verification"); + await user.roles.add(guildRole, "Verification"); + } + if (guildRank === "Member" && guildID === hypixelGuildID) { await user.roles.add(member, "Verification"); await user.roles.add(guildRole, "Verification");