Moved verify to use hypixel api
This commit is contained in:
@@ -8,170 +8,177 @@ const mongoose = require("mongoose");
|
|||||||
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");
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
name: "verify",
|
name: "verify",
|
||||||
description: "Verify yourself as a member of the server.",
|
description: "Verify yourself as a member of the server.",
|
||||||
type: "slash",
|
type: "slash",
|
||||||
|
|
||||||
data: new SlashCommandBuilder()
|
data: new SlashCommandBuilder()
|
||||||
.setName("verify")
|
.setName("verify")
|
||||||
.setDescription("Verify yourself as a member of the server.")
|
.setDescription("Verify yourself as a member of the server.")
|
||||||
.addStringOption((option) => option.setName("ign").setDescription("Your in-game name."))
|
.addStringOption((option) => option.setName("ign").setDescription("Your in-game name."))
|
||||||
.setDMPermission(false),
|
.setDMPermission(false),
|
||||||
|
|
||||||
async execute(interaction) {
|
async execute(interaction) {
|
||||||
await interaction.deferReply();
|
await interaction.deferReply();
|
||||||
|
|
||||||
const user1 = interaction.user
|
const user1 = interaction.user
|
||||||
const user = interaction.guild.members.cache.get(user1.id);
|
const user = interaction.guild.members.cache.get(user1.id);
|
||||||
const ign = interaction.options.getString("ign");
|
const ign = interaction.options.getString("ign");
|
||||||
const mojang = "https://api.mojang.com/users/profiles/minecraft/";
|
const mojang = "https://api.mojang.com/users/profiles/minecraft/";
|
||||||
const slothPixel = "https://api.slothpixel.me/api/players/";
|
const hypixel = "https://api.hypixel.net/player"
|
||||||
const guildAPI = "https://api.slothpixel.me/api/guilds/";
|
const guildAPI = "https://api.hypixel.net/guild"
|
||||||
const minotar = "https://minotar.net/helm/";
|
const minotar = "https://minotar.net/helm/";
|
||||||
const embedColor = Number(color.replace("#", "0x"));
|
const embedColor = Number(color.replace("#", "0x"));
|
||||||
|
const head = minotar + ign;
|
||||||
|
|
||||||
const verifyData = await verify.findOne({ userID: user.id });
|
const verifyData = await verify.findOne({ userID: user.id });
|
||||||
|
|
||||||
if (verifyData) {
|
if (verifyData) {
|
||||||
interaction.editReply("You are already verified.");
|
interaction.editReply("You are already verified.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!ign) {
|
if (!ign) {
|
||||||
interaction.editReply("Please provide a player's IGN.");
|
interaction.editReply("Please provide a player's IGN.");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
try {
|
try {
|
||||||
await fetch(mojang + ign);
|
await fetch(mojang + ign);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
interaction.editReply("That player doesn't exist. [Mojang]");
|
interaction.editReply("That player doesn't exist. [Mojang]");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
const userCheck = await fetch(mojang + ign);
|
const userCheck = await fetch(mojang + ign);
|
||||||
const userUUID = userCheck.data.id;
|
const userUUID = userCheck.data.id;
|
||||||
|
|
||||||
try {
|
const player = hypixel + "?key=" + hypixelApiKey + "&uuid=" + userUUID
|
||||||
await fetch(slothPixel + userUUID);
|
const stats = await fetch(player);
|
||||||
} catch (err) {
|
|
||||||
interaction.editReply("That player doesn't exist. [Hypixel]");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const hypixelCheck = await fetch(slothPixel + userUUID);
|
if (!stats.data.player) {
|
||||||
const head = minotar + ign;
|
interaction.editReply({
|
||||||
|
embeds: [{
|
||||||
|
description: "That player hasn't played Hypixel before.",
|
||||||
|
color: embedColor
|
||||||
|
}]
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (user1.discriminator === "0") {
|
if (user1.discriminator === "0") {
|
||||||
var username = user1.username
|
var username = user1.username
|
||||||
} else {
|
} else {
|
||||||
var username = user1.username + "#" + user1.discriminator
|
var username = user1.username + "#" + user1.discriminator
|
||||||
}
|
}
|
||||||
|
|
||||||
if (hypixelCheck.data.links.DISCORD !== username) {
|
const linkedDiscord = stats.data.player.socialMedia.links.DISCORD
|
||||||
interaction.editReply({
|
|
||||||
embeds: [
|
|
||||||
{
|
|
||||||
description: "<a:cross_a:1087808606897983539> The discord tag for `" + userCheck.data.name + "` is not `" + username + "`. Please link your discord account to your hypixel account.\n" +
|
|
||||||
"**If you are are using a new username then you will have to set your discord on hypixel to the new username without the #** ",
|
|
||||||
color: embedColor
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
try {
|
if (linkedDiscord !== username) {
|
||||||
const guildCheck = await fetch(guildAPI + userUUID);
|
interaction.editReply({
|
||||||
var responseGuildID = guildCheck.data.id;
|
embeds: [
|
||||||
} catch (err) {
|
{
|
||||||
var responseGuildID = null;
|
description: "<a:cross_a:1087808606897983539> The discord tag for `" + userCheck.data.name + "` is not `" + username + "`. Please link your discord account `" + username + "` to your hypixel account.\n" +
|
||||||
}
|
"**If you are are using a new username then you will have to set your discord on hypixel to the new username without the #** ",
|
||||||
|
color: embedColor
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (responseGuildID !== hypixelGuildID) {
|
const guild = guildAPI + "?key=" + hypixelApiKey + "&player=" + userUUID
|
||||||
await user.roles.add(defaultMember, "Verification");
|
const guildCheck = await fetch(guild);
|
||||||
|
|
||||||
await interaction.editReply({
|
if (!guildCheck.data.guild) {
|
||||||
embeds: [
|
var guildID = null
|
||||||
{
|
} else {
|
||||||
title: interaction.guild.name,
|
var guildID = guildCheck.data.guild._id
|
||||||
description: "<a:check_a:1087808632172847134> You have successfully verified `" + username + "` with the account `" + hypixelCheck.data.username + "`.",
|
}
|
||||||
color: embedColor,
|
|
||||||
thumbnail: {
|
|
||||||
url: head
|
|
||||||
},
|
|
||||||
footer: {
|
|
||||||
icon_url: interaction.guild.iconURL(),
|
|
||||||
text: interaction.guild.name + " | Developed by Taken#0002"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
const guildCheck = await fetch(guildAPI + userUUID);
|
if (guildID !== hypixelGuildID) {
|
||||||
const GuildMembers = await guildCheck.data.members;
|
await user.roles.add(defaultMember, "Verification");
|
||||||
const guildRank = GuildMembers.find((member) => member.uuid === hypixelCheck.data.uuid).rank;
|
|
||||||
|
|
||||||
if (guildRank === "Guild Master" && responseGuildID === hypixelGuildID) {
|
await interaction.editReply({
|
||||||
await user.roles.add(gm, "Verification");
|
embeds: [
|
||||||
await user.roles.add(guildRole, "Verification");
|
{
|
||||||
await user.roles.add(guildStaff, "Verification");
|
title: interaction.guild.name,
|
||||||
}
|
description: "<a:check_a:1087808632172847134> You have successfully verified `" + username + "` with the account `" + hypixelCheck.data.username + "`.",
|
||||||
|
color: embedColor,
|
||||||
|
thumbnail: {
|
||||||
|
url: head
|
||||||
|
},
|
||||||
|
footer: {
|
||||||
|
icon_url: interaction.guild.iconURL(),
|
||||||
|
text: interaction.guild.name + " | Developed by Taken#0002"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (guildRank === "Manager" && responseGuildID === hypixelGuildID) {
|
const GuildMembers = guildCheck.data.guild.members
|
||||||
await user.roles.add(manager, "Verification");
|
const guildRank = GuildMembers.find((member) => member.uuid === stats.data.player.uuid).rank;
|
||||||
await user.roles.add(guildRole, "Verification");
|
|
||||||
await user.roles.add(guildStaff, "Verification");
|
|
||||||
}
|
|
||||||
|
|
||||||
if (guildRank === "Moderator" && responseGuildID === hypixelGuildID) {
|
if (guildRank === "Guild Master" && guildID === hypixelGuildID) {
|
||||||
await user.roles.add(moderator, "Verification");
|
await user.roles.add(gm, "Verification");
|
||||||
await user.roles.add(guildRole, "Verification");
|
await user.roles.add(guildRole, "Verification");
|
||||||
await user.roles.add(guildStaff, "Verification");
|
await user.roles.add(guildStaff, "Verification");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (guildRank === "Beast" && responseGuildID === hypixelGuildID) {
|
if (guildRank === "Manager" && guildID === hypixelGuildID) {
|
||||||
await user.roles.add(beast, "Verification");
|
await user.roles.add(manager, "Verification");
|
||||||
await user.roles.add(guildRole, "Verification");
|
await user.roles.add(guildRole, "Verification");
|
||||||
}
|
await user.roles.add(guildStaff, "Verification");
|
||||||
|
}
|
||||||
|
|
||||||
if (guildRank === "Member" && responseGuildID === hypixelGuildID) {
|
if (guildRank === "Moderator" && guildID === hypixelGuildID) {
|
||||||
await user.roles.add(member, "Verification");
|
await user.roles.add(moderator, "Verification");
|
||||||
await user.roles.add(guildRole, "Verification");
|
await user.roles.add(guildRole, "Verification");
|
||||||
}
|
await user.roles.add(guildStaff, "Verification");
|
||||||
|
}
|
||||||
|
|
||||||
if (guildRank === "Trial Member" && responseGuildID === hypixelGuildID) {
|
if (guildRank === "Beast" && guildID === hypixelGuildID) {
|
||||||
await user.roles.add(trialmember, "Verification");
|
await user.roles.add(beast, "Verification");
|
||||||
await user.roles.add(guildRole, "Verification");
|
await user.roles.add(guildRole, "Verification");
|
||||||
}
|
}
|
||||||
|
|
||||||
await user.roles.add(defaultMember, "Verification");
|
if (guildRank === "Member" && guildID === hypixelGuildID) {
|
||||||
|
await user.roles.add(member, "Verification");
|
||||||
|
await user.roles.add(guildRole, "Verification");
|
||||||
|
}
|
||||||
|
|
||||||
const newVerify = new verify({
|
if (guildRank === "Trial Member" && guildID === hypixelGuildID) {
|
||||||
_id: new mongoose.Types.ObjectId(),
|
await user.roles.add(trialmember, "Verification");
|
||||||
userID: user.id,
|
await user.roles.add(guildRole, "Verification");
|
||||||
uuid: userUUID
|
}
|
||||||
});
|
|
||||||
|
|
||||||
await newVerify.save();
|
await user.roles.add(defaultMember, "Verification");
|
||||||
|
|
||||||
await interaction.editReply({
|
const newVerify = new verify({
|
||||||
embeds: [
|
_id: new mongoose.Types.ObjectId(),
|
||||||
{
|
userID: user.id,
|
||||||
title: interaction.guild.name,
|
uuid: userUUID
|
||||||
description: "You have successfully verified `" + username + "` with the account `" + hypixelCheck.data.username + "`.",
|
});
|
||||||
color: embedColor,
|
|
||||||
thumbnail: {
|
await newVerify.save();
|
||||||
url: head
|
|
||||||
},
|
await interaction.editReply({
|
||||||
footer: {
|
embeds: [
|
||||||
icon_url: interaction.guild.iconURL(),
|
{
|
||||||
text: interaction.guild.name + " | Developed by Taken#0002"
|
title: interaction.guild.name,
|
||||||
}
|
description: "You have successfully verified `" + username + "` with the account `" + stats.data.player.displayname + "`.",
|
||||||
}
|
color: embedColor,
|
||||||
]
|
thumbnail: {
|
||||||
});
|
url: head
|
||||||
}
|
},
|
||||||
|
footer: {
|
||||||
|
icon_url: interaction.guild.iconURL(),
|
||||||
|
text: interaction.guild.name + " | Developed by Taken#0002"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user