mov_blacklist_super
This commit is contained in:
parent
8014b881e3
commit
17a271e76e
|
@ -8,6 +8,7 @@ import get_blacklist from "./commands/get_blacklist.js";
|
||||||
import get_file from "./commands/get_file.js";
|
import get_file from "./commands/get_file.js";
|
||||||
import get_members from "./commands/get_members.js";
|
import get_members from "./commands/get_members.js";
|
||||||
import get_raw_file from "./commands/get_raw_file.js";
|
import get_raw_file from "./commands/get_raw_file.js";
|
||||||
|
import mov_blacklist_super from "./commands/mov_blacklist_super.js";
|
||||||
import ping from "./commands/ping.js";
|
import ping from "./commands/ping.js";
|
||||||
|
|
||||||
const commands: TCommand[] = [
|
const commands: TCommand[] = [
|
||||||
|
@ -19,6 +20,7 @@ const commands: TCommand[] = [
|
||||||
get_file,
|
get_file,
|
||||||
get_members,
|
get_members,
|
||||||
get_raw_file,
|
get_raw_file,
|
||||||
|
mov_blacklist_super,
|
||||||
ping,
|
ping,
|
||||||
];
|
];
|
||||||
export default commands;
|
export default commands;
|
||||||
|
|
|
@ -1,53 +0,0 @@
|
||||||
const { SlashCommandBuilder, PermissionFlagsBits } = require("discord.js");
|
|
||||||
|
|
||||||
const firebase_admin = require("firebase-admin");
|
|
||||||
const { getDatabase } = require("firebase-admin/database");
|
|
||||||
const serviceAccount = require("../firebase/conf.json");
|
|
||||||
if (!firebase_admin.apps.length) {
|
|
||||||
firebase_admin.initializeApp({
|
|
||||||
credential: firebase_admin.credential.cert(serviceAccount),
|
|
||||||
databaseURL: process.env.FIREBASE_URL,
|
|
||||||
databaseAuthVariableOverride: {
|
|
||||||
uid: process.env.FIREBASE_UID,
|
|
||||||
},
|
|
||||||
});
|
|
||||||
}
|
|
||||||
const firebase = getDatabase().ref("/");
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
data: new SlashCommandBuilder()
|
|
||||||
.setName("mov_blacklist_super")
|
|
||||||
.setDescription("add user to blacklist")
|
|
||||||
.addUserOption((option) =>
|
|
||||||
option
|
|
||||||
.setName("discord")
|
|
||||||
.setDescription("discord id of blacklister")
|
|
||||||
.setRequired(true)
|
|
||||||
)
|
|
||||||
.setDefaultMemberPermissions(PermissionFlagsBits.Administrator)
|
|
||||||
.setDMPermission(false),
|
|
||||||
async execute(interaction) {
|
|
||||||
await interaction.deferReply({ ephemeral: true });
|
|
||||||
let data = (await firebase.get()).val();
|
|
||||||
const discord_id = interaction.options.getUser("discord_id").id;
|
|
||||||
for (let discord_search_point in data["members"]) {
|
|
||||||
if (data["members"][discord_search_point].discord == discord_id) {
|
|
||||||
//이미 등록된 디코가 있을경우
|
|
||||||
const blackListing = data["members"][discord_search_point];
|
|
||||||
data["members"].splice(discord_search_point, 1);
|
|
||||||
data["blacklist"].push(blackListing);
|
|
||||||
await firebase.set(data);
|
|
||||||
await interaction.editReply({
|
|
||||||
content:
|
|
||||||
"성공적으로 해당 discord id와 minecraft id를 블렉리스팅 했어요!",
|
|
||||||
ephemeral: true,
|
|
||||||
});
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
} //등록되지 않았을경우
|
|
||||||
await interaction.editReply({
|
|
||||||
content: "`에러`:해당 discord id를 찾을 수 없었어요",
|
|
||||||
ephemeral: true,
|
|
||||||
});
|
|
||||||
},
|
|
||||||
};
|
|
47
src/command/commands/mov_blacklist_super.ts
Executable file
47
src/command/commands/mov_blacklist_super.ts
Executable file
|
@ -0,0 +1,47 @@
|
||||||
|
import {
|
||||||
|
SlashCommandBuilder,
|
||||||
|
PermissionFlagsBits,
|
||||||
|
ChatInputCommandInteraction,
|
||||||
|
} from "discord.js";
|
||||||
|
|
||||||
|
import firebase from "../../wrapper/firebase.js";
|
||||||
|
import { TUser } from "../../functions.js";
|
||||||
|
|
||||||
|
export default {
|
||||||
|
data: new SlashCommandBuilder()
|
||||||
|
.setName("mov_blacklist_super")
|
||||||
|
.setDescription("add user to blacklist")
|
||||||
|
.addUserOption((option) =>
|
||||||
|
option
|
||||||
|
.setName("discord")
|
||||||
|
.setDescription("discord id of blacklister")
|
||||||
|
.setRequired(true)
|
||||||
|
)
|
||||||
|
.setDefaultMemberPermissions(PermissionFlagsBits.Administrator)
|
||||||
|
.setDMPermission(false),
|
||||||
|
async execute(interaction: ChatInputCommandInteraction) {
|
||||||
|
const discord_id = interaction.options.getUser("discord_id").id;
|
||||||
|
const blacklist = firebase.collection("blacklist");
|
||||||
|
const members = firebase.collection("members");
|
||||||
|
const target = await members.where("discord_id", "==", discord_id).get();
|
||||||
|
if (target.empty) {
|
||||||
|
await interaction.editReply({
|
||||||
|
content: "`에러`:해당 discord id로 등록된 유저를 찾을 수 없었어요",
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const target_datas: TUser[] = [];
|
||||||
|
target.forEach((doc) => {
|
||||||
|
target_datas.push(doc.data() as TUser);
|
||||||
|
members.doc(doc.id).delete();
|
||||||
|
});
|
||||||
|
target_datas.forEach((user) => {
|
||||||
|
blacklist.add(user);
|
||||||
|
});
|
||||||
|
|
||||||
|
await interaction.editReply({
|
||||||
|
content: "성공적으로 해당 discord id와 minecraft id를 블랙리스팅 했어요.",
|
||||||
|
});
|
||||||
|
},
|
||||||
|
};
|
Loading…
Reference in a new issue