Added force update and verify

This commit is contained in:
2023-03-29 14:38:19 +02:00
parent eb4f7143b9
commit ec34b1ce0e
4 changed files with 316 additions and 35 deletions

View File

@@ -39,6 +39,10 @@ module.exports = {
subcommand subcommand
.setName('sendrules-info') .setName('sendrules-info')
.setDescription('Send the rules and info message to a channel.')) .setDescription('Send the rules and info message to a channel.'))
.addSubcommand(subcommand =>
subcommand
.setName('reload')
.setDescription('Reload the bot.'))
.setDefaultMemberPermissions(PermissionFlagsBits.Administrator) .setDefaultMemberPermissions(PermissionFlagsBits.Administrator)
.setDMPermission(false), .setDMPermission(false),
@@ -49,6 +53,10 @@ module.exports = {
const subcommand = interaction.options.getSubcommand(); const subcommand = interaction.options.getSubcommand();
const embedColor = Number(color.replace("#", "0x")); const embedColor = Number(color.replace("#", "0x"));
if (subcommand === 'reload') {
await interaction.reply({ content: "In development.", ephemeral: true });
}
if (subcommand === 'sendguildapplication') { if (subcommand === 'sendguildapplication') {
const channel = interaction.options.getChannel('channel'); const channel = interaction.options.getChannel('channel');
@@ -109,5 +117,9 @@ module.exports = {
await interaction.reply({ content: 'Message sent', ephemeral: true }) await interaction.reply({ content: 'Message sent', ephemeral: true })
} }
if (subcommand !== "sendguildinfo" || "sendrequirements" || "sendrules-info") {
await interaction.reply({ content: 'In development.', ephemeral: true });
}
} }
}; };

238
commands/forceupdate.js Normal file
View File

@@ -0,0 +1,238 @@
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 mongoose = require('mongoose');
const verify = require('../schemas/verifySchema.js')
const fetch = require('axios');
const removeThese = [gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff]
module.exports = {
name: 'forceupdate',
description: 'Force update the user',
type: 'slash',
data: new SlashCommandBuilder()
.setName('forceupdate')
.setDescription('Force update the user')
.addUserOption(option =>
option
.setName('user')
.setDescription('The user to force update')
.setRequired(true))
.setDefaultMemberPermissions(PermissionFlagsBits.Administrator)
.setDMPermission(false),
async execute(interaction) {
await interaction.deferReply();
const user = interaction.options.getUser('user');
const usermentioned = userMention(user.id);
const guild = interaction.guild;
const verifyData = await verify.findOne({ userID: user.id })
const user1 = guild.members.cache.get(user.id);
const roleManage = user1.roles;
if (!verifyData) {
interaction.editReply('That user is not verified.')
return
}
const slothPixel = "https://api.slothpixel.me/api/players/";
const guildAPI = "https://api.slothpixel.me/api/guilds/"
const mojangAPI = "https://api.mojang.com/user/profile/"
const minotar = "https://minotar.net/helm/";
const userCheck = await fetch(mojangAPI + verifyData.uuid);
const hypixelCheck = await fetch(slothPixel + verifyData.uuid);
const guildCheck = await fetch(guildAPI + verifyData.uuid);
const head = minotar + userCheck.data.name;
const embedColor = Number(color.replace("#", "0x"));
const GuildMembers = await guildCheck.data.members;
const guildRank = GuildMembers.find(member => member.uuid === verifyData.uuid).rank;
if (guildCheck.data.id !== hypixelGuildID) {
interaction.editReply({
embeds: [{
description: usermentioned + " was given the the Member role.",
color: embedColor,
thumbnail: {
url: head
},
footer: {
text: interaction.guild.name + " | Developed by @Taken#0002",
icon_url: interaction.guild.iconURL({ dynamic: true })
}
}]
})
await roleManage.add(defaultMember)
return
}
if (guildRank === 'Guild Master') {
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole)
await roleManage.add(guildStaff)
await roleManage.add(gm)
await roleManage.add(defaultMember)
interaction.editReply({
embeds: [{
description: usermentioned + "'s rank has been updated to `Guild Master`",
color: embedColor,
thumbnail: {
url: head
},
footer: {
text: interaction.guild.name + " | Developed by @Taken#0002",
icon_url: interaction.guild.iconURL({ dynamic: true })
}
}]
})
}
if (guildRank === 'Manager') {
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole)
await roleManage.add(guildStaff)
await roleManage.add(manager)
await roleManage.add(defaultMember)
interaction.editReply({
embeds: [{
description: usermentioned + "'s rank has been updated to `Manager`",
color: embedColor,
thumbnail: {
url: head
},
footer: {
text: interaction.guild.name + " | Developed by @Taken#0002",
icon_url: interaction.guild.iconURL({ dynamic: true })
}
}]
})
}
if (guildRank === 'Moderator') {
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole)
await roleManage.add(guildStaff)
await roleManage.add(moderator)
await roleManage.add(defaultMember)
interaction.editReply({
embeds: [{
description: usermentioned + "'s rank has been updated to `Moderator`",
color: embedColor,
thumbnail: {
url: head
},
footer: {
text: interaction.guild.name + " | Developed by @Taken#0002",
icon_url: interaction.guild.iconURL({ dynamic: true })
}
}]
})
}
if (guildRank === 'Beast') {
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole)
await roleManage.add(beast)
await roleManage.add(defaultMember)
interaction.editReply({
embeds: [{
description: usermentioned + "'s rank has been updated to `Beast`.",
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') {
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole)
await roleManage.add(member)
await roleManage.add(defaultMember)
interaction.editReply({
embeds: [{
description: usermentioned + "'s rank has been updated to `Member`.",
color: embedColor,
thumbnail: {
url: head
},
footer: {
text: interaction.guild.name + " | Developed by @Taken#0002",
icon_url: interaction.guild.iconURL({ dynamic: true })
}
}]
})
return
}
if (guildRank === 'Trial Member') {
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.remove(gm && manager && moderator && beast && member && trialmember && guildRole && guildStaff)
await roleManage.add(guildRole)
await roleManage.add(trialmember)
await roleManage.add(defaultMember)
interaction.editReply({
embeds: [{
description: usermentioned + "'s rank has been updated to `Trial Member`.",
color: embedColor,
thumbnail: {
url: head
},
footer: {
text: interaction.guild.name + " | Developed by @Taken#0002",
icon_url: interaction.guild.iconURL({ dynamic: true })
}
}]
})
return
}
}
}

View File

@@ -41,6 +41,37 @@ module.exports = {
const minotar = "https://minotar.net/helm/"; const minotar = "https://minotar.net/helm/";
const embedColor = Number(color.replace("#", "0x")); const embedColor = Number(color.replace("#", "0x"));
if (!user) {
interaction.editReply('Please provide a user to force verify.')
return
}
if (!ign) {
interaction.editReply('Please provide a player\'s IGN.')
return
}
const verifyData = await verify.findOne({ userID: user.id })
if (verifyData) {
interaction.editReply('That user is already verified.')
return
}
try {
await fetch(mojang + ign);
} catch (err) {
interaction.editReply('That player doesn\'t exist. [Mojang]')
return
}
try {
await fetch(slothPixel + ign);
} catch (err) {
interaction.editReply('That player doesn\'t exist. [Hypixel]')
return
}
const userCheck = await fetch(mojang + ign); const userCheck = await fetch(mojang + ign);
const userUUID = userCheck.data.id; const userUUID = userCheck.data.id;
@@ -51,26 +82,6 @@ module.exports = {
const GuildMembers = await guildCheck.data.members; const GuildMembers = await guildCheck.data.members;
const guildRank = GuildMembers.find(member => member.uuid === hypixelCheck.data.uuid).rank; const guildRank = GuildMembers.find(member => member.uuid === hypixelCheck.data.uuid).rank;
if (!user) {
interaction.reply('Please provide a user to force verify.')
return
}
if (!ign) {
interaction.reply('Please provide a player\'s IGN.')
return
}
if (!userUUID) {
interaction.reply('That player doesn\'t exist. [Mojang]')
return
}
if (!hypixelCheck.data.uuid) {
interaction.reply('That player doesn\'t exist. [Hypixel]')
return
}
if (guildRank === "Guild Master" && guildCheck.data.id === hypixelGuildID) { if (guildRank === "Guild Master" && guildCheck.data.id === hypixelGuildID) {
await user.roles.add(gm); await user.roles.add(gm);
await user.roles.add(guildRole) await user.roles.add(guildRole)
@@ -106,21 +117,15 @@ module.exports = {
await user.roles.add(defaultMember); await user.roles.add(defaultMember);
const verifyData = await verify.findOne({ userID: user.id })
const newVerify = new verify({ const newVerify = new verify({
_id: new mongoose.Types.ObjectId(), _id: new mongoose.Types.ObjectId(),
userID: user.id, userID: user.id,
uuid: userUUID uuid: userUUID
}) })
if (verifyData) { await newVerify.save();
await verify.findOneAndUpdate({ userID: user.id }, { uuid: userUUID })
} else {
await newVerify.save()
}
await interaction.reply({ await interaction.editReply({
embeds: [{ embeds: [{
title: interaction.guild.name, title: interaction.guild.name,
description: "You have successfully force verified `" + fullUsername + "` with the account `" + hypixelCheck.data.username + "`.", description: "You have successfully force verified `" + fullUsername + "` with the account `" + hypixelCheck.data.username + "`.",

View File

@@ -6,6 +6,8 @@ const mongoose = require('mongoose');
const { color, hypixelGuildID } = require('../config/options.json'); const { color, hypixelGuildID } = require('../config/options.json');
const { gm, manager, moderator, beast, member, trialmember, guildRole, guildStaff, defaultMember } = require('../config/roles.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];
module.exports = { module.exports = {
name: 'update', name: 'update',
description: 'Update your guild rank.', description: 'Update your guild rank.',
@@ -26,7 +28,7 @@ module.exports = {
const roleManage = user.roles; const roleManage = user.roles;
if (!verifyData) { if (!verifyData) {
interaction.reply('You are not verified.') interaction.editReply('You are not verified.')
return return
} }
@@ -62,7 +64,11 @@ module.exports = {
} }
if (guildRank === 'Guild Master') { if (guildRank === 'Guild Master') {
await roleManage.remove(gm || manager || moderator || beast || member || trialmember || guildRole || guildStaff || defaultMember)
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole) await roleManage.add(guildRole)
await roleManage.add(guildStaff) await roleManage.add(guildStaff)
await roleManage.add(gm) await roleManage.add(gm)
@@ -85,7 +91,11 @@ module.exports = {
} }
if (guildRank === 'Manager') { if (guildRank === 'Manager') {
await roleManage.remove(gm || manager || moderator || beast || member || trialmember || guildRole || guildStaff)
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole) await roleManage.add(guildRole)
await roleManage.add(guildStaff) await roleManage.add(guildStaff)
await roleManage.add(manager) await roleManage.add(manager)
@@ -108,7 +118,11 @@ module.exports = {
} }
if (guildRank === 'Moderator') { if (guildRank === 'Moderator') {
await roleManage.remove(gm || manager || moderator || beast || member || trialmember || guildRole || guildStaff)
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole) await roleManage.add(guildRole)
await roleManage.add(guildStaff) await roleManage.add(guildStaff)
await roleManage.add(moderator) await roleManage.add(moderator)
@@ -132,7 +146,11 @@ module.exports = {
} }
if (guildRank === 'Beast') { if (guildRank === 'Beast') {
await roleManage.remove(gm || manager || moderator || beast || member || trialmember || guildRole)
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole) await roleManage.add(guildRole)
await roleManage.add(beast) await roleManage.add(beast)
await roleManage.add(defaultMember) await roleManage.add(defaultMember)
@@ -155,7 +173,11 @@ module.exports = {
} }
if (guildRank === 'Member') { if (guildRank === 'Member') {
await roleManage.remove(gm || manager || moderator || beast || member || trialmember || guildRole)
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole) await roleManage.add(guildRole)
await roleManage.add(member) await roleManage.add(member)
await roleManage.add(defaultMember) await roleManage.add(defaultMember)
@@ -178,7 +200,11 @@ module.exports = {
} }
if (guildRank === 'Trial Member') { if (guildRank === 'Trial Member') {
await roleManage.remove(gm || manager || moderator || beast || member || trialmember || guildRole)
for (let i = 0; i < removeThese.length; i++) {
await roleManage.remove(removeThese[i])
}
await roleManage.add(guildRole) await roleManage.add(guildRole)
await roleManage.add(trialmember) await roleManage.add(trialmember)
await roleManage.add(defaultMember) await roleManage.add(defaultMember)