mirror of
https://github.com/veganhacktivists/arabot.git
synced 2025-05-19 06:24:15 +02:00
Merge pull request #81 from veganhacktivists/main
Update nonvegan_access commits
This commit is contained in:
commit
e57fa26f6b
@ -19,7 +19,7 @@
|
|||||||
|
|
||||||
import { Listener } from '@sapphire/framework';
|
import { Listener } from '@sapphire/framework';
|
||||||
import type { GuildMember } from 'discord.js';
|
import type { GuildMember } from 'discord.js';
|
||||||
// import { fetchRoles } from '#utils/database/dbExistingUser';
|
import { fetchRoles } from '#utils/database/dbExistingUser';
|
||||||
import IDs from '#utils/ids';
|
import IDs from '#utils/ids';
|
||||||
import { blockTime } from '#utils/database/verification';
|
import { blockTime } from '#utils/database/verification';
|
||||||
import { checkActive, getSection } from '#utils/database/restriction';
|
import { checkActive, getSection } from '#utils/database/restriction';
|
||||||
@ -35,8 +35,7 @@ export class RolesJoinServerListener extends Listener {
|
|||||||
public async run(member: GuildMember) {
|
public async run(member: GuildMember) {
|
||||||
// Add basic roles
|
// Add basic roles
|
||||||
|
|
||||||
const roles = [];
|
const roles = await fetchRoles(member.id);
|
||||||
// const roles = await fetchRoles(member.id);
|
|
||||||
|
|
||||||
// Check if the user is restricted
|
// Check if the user is restricted
|
||||||
if (await checkActive(member.id)) {
|
if (await checkActive(member.id)) {
|
||||||
|
@ -38,6 +38,7 @@ import {
|
|||||||
ActionRowBuilder,
|
ActionRowBuilder,
|
||||||
EmbedBuilder,
|
EmbedBuilder,
|
||||||
} from 'discord.js';
|
} from 'discord.js';
|
||||||
|
import { createVerificationText, createVerificationVoice } from '#utils/verification';
|
||||||
import { maxVCs, questionInfo, serverFind } from '#utils/verificationConfig';
|
import { maxVCs, questionInfo, serverFind } from '#utils/verificationConfig';
|
||||||
import { joinVerification, startVerification, finishVerification } from '#utils/database/verification';
|
import { joinVerification, startVerification, finishVerification } from '#utils/database/verification';
|
||||||
import { findNotes } from '#utils/database/sus';
|
import { findNotes } from '#utils/database/sus';
|
||||||
@ -139,73 +140,19 @@ export class VerificationJoinVCListener extends Listener {
|
|||||||
.filter((c) => c.type === ChannelType.GuildVoice);
|
.filter((c) => c.type === ChannelType.GuildVoice);
|
||||||
|
|
||||||
// Create a text channel for verifiers only
|
// Create a text channel for verifiers only
|
||||||
// Checks if there are more than 10 voice channels
|
|
||||||
if (!verifier) {
|
if (!verifier) {
|
||||||
// TODO refactor this mess to circumvent
|
|
||||||
// "Contains words not allowed for servers in Server Discovery."
|
|
||||||
let verificationText: TextChannel;
|
let verificationText: TextChannel;
|
||||||
let bannedName = false;
|
let bannedName = false;
|
||||||
try {
|
try {
|
||||||
verificationText = await guild.channels.create({
|
verificationText = await createVerificationText(member, channel, category);
|
||||||
name: `✅┃${member.displayName}-verification`,
|
|
||||||
type: ChannelType.GuildText,
|
|
||||||
topic: `Channel for verifiers only. ${member.id} ${channel.id} (Please do not change this)`,
|
|
||||||
parent: category.id,
|
|
||||||
userLimit: 1,
|
|
||||||
permissionOverwrites: [
|
|
||||||
{
|
|
||||||
id: guild.roles.everyone,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.verifyBlock,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.verifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.trialVerifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
} catch {
|
} catch {
|
||||||
verificationText = await guild.channels.create({
|
|
||||||
name: `✅┃${member.displayName}-verification`,
|
|
||||||
type: ChannelType.GuildText,
|
|
||||||
topic: `Channel for verifiers only. ${member.id} ${channel.id} (Please do not change this)`,
|
|
||||||
parent: category.id,
|
|
||||||
userLimit: 1,
|
|
||||||
permissionOverwrites: [
|
|
||||||
{
|
|
||||||
id: guild.roles.everyone,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.verifyBlock,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.verifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.trialVerifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
bannedName = true;
|
bannedName = true;
|
||||||
|
verificationText = await createVerificationText(
|
||||||
|
member,
|
||||||
|
channel,
|
||||||
|
category,
|
||||||
|
bannedName,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!bannedName) {
|
if (!bannedName) {
|
||||||
@ -230,102 +177,9 @@ export class VerificationJoinVCListener extends Listener {
|
|||||||
|
|
||||||
// Checks if there are more than 10 voice channels
|
// Checks if there are more than 10 voice channels
|
||||||
if (listVoiceChannels.size > maxVCs - 1) {
|
if (listVoiceChannels.size > maxVCs - 1) {
|
||||||
await guild.channels.create({
|
await createVerificationVoice(category, true);
|
||||||
name: 'Verification',
|
|
||||||
type: ChannelType.GuildVoice,
|
|
||||||
parent: category.id,
|
|
||||||
userLimit: 1,
|
|
||||||
permissionOverwrites: [
|
|
||||||
{
|
|
||||||
id: guild.roles.everyone,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Stream],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.verifyBlock,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.SendMessages],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.nonvegan.nonvegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
deny: [PermissionsBitField.Flags.Connect],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.vegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
deny: [PermissionsBitField.Flags.Connect],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.activist,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.verifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.trialVerifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
} else {
|
} else {
|
||||||
await guild.channels.create({
|
await createVerificationVoice(category);
|
||||||
name: 'Verification',
|
|
||||||
type: ChannelType.GuildVoice,
|
|
||||||
parent: category.id,
|
|
||||||
userLimit: 1,
|
|
||||||
permissionOverwrites: [
|
|
||||||
{
|
|
||||||
id: guild.roles.everyone,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.SendMessages],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.verifyBlock,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.SendMessages],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.nonvegan.nonvegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.vegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.activist,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel, PermissionsBitField.Flags.Connect],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.verifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.trialVerifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Change permissions to join the current channel
|
// Change permissions to join the current channel
|
||||||
|
@ -21,7 +21,8 @@ import { Listener } from '@sapphire/framework';
|
|||||||
import type {
|
import type {
|
||||||
VoiceState, CategoryChannel, VoiceChannel, TextChannel,
|
VoiceState, CategoryChannel, VoiceChannel, TextChannel,
|
||||||
} from 'discord.js';
|
} from 'discord.js';
|
||||||
import { time, ChannelType, PermissionsBitField } from 'discord.js';
|
import { time, ChannelType } from 'discord.js';
|
||||||
|
import { createVerificationVoice } from '#utils/verification';
|
||||||
import { maxVCs, leaveBan } from '#utils/verificationConfig';
|
import { maxVCs, leaveBan } from '#utils/verificationConfig';
|
||||||
import { getUser, checkFinish, countIncomplete } from '#utils/database/verification';
|
import { getUser, checkFinish, countIncomplete } from '#utils/database/verification';
|
||||||
import { fetchRoles } from '#utils/database/dbExistingUser';
|
import { fetchRoles } from '#utils/database/dbExistingUser';
|
||||||
@ -126,52 +127,7 @@ export class VerificationLeaveVCListener extends Listener {
|
|||||||
// If there are no VCs left in verification after having the channel deleted
|
// If there are no VCs left in verification after having the channel deleted
|
||||||
if (listVoiceChannels.size - 1 === 0) {
|
if (listVoiceChannels.size - 1 === 0) {
|
||||||
// Create a verification channel
|
// Create a verification channel
|
||||||
await guild.channels.create({
|
await createVerificationVoice(category);
|
||||||
name: 'Verification',
|
|
||||||
type: ChannelType.GuildVoice,
|
|
||||||
parent: category.id,
|
|
||||||
userLimit: 1,
|
|
||||||
permissionOverwrites: [
|
|
||||||
{
|
|
||||||
id: guild.roles.everyone,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.SendMessages],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.verifyBlock,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.SendMessages],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.nonvegan.nonvegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.vegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.activist,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel, PermissionsBitField.Flags.Connect],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.verifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.trialVerifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// If there are less than 10, stop
|
// If there are less than 10, stop
|
||||||
|
@ -24,7 +24,8 @@ import type {
|
|||||||
TextChannel,
|
TextChannel,
|
||||||
VoiceChannel,
|
VoiceChannel,
|
||||||
} from 'discord.js';
|
} from 'discord.js';
|
||||||
import { ChannelType, PermissionsBitField } from 'discord.js';
|
import { ChannelType } from 'discord.js';
|
||||||
|
import { createVerificationVoice } from '#utils/verification';
|
||||||
import IDs from '#utils/ids';
|
import IDs from '#utils/ids';
|
||||||
|
|
||||||
export class VerificationReady extends Listener {
|
export class VerificationReady extends Listener {
|
||||||
@ -84,52 +85,7 @@ export class VerificationReady extends Listener {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
if (!verification) {
|
if (!verification) {
|
||||||
await category.guild.channels.create({
|
await createVerificationVoice(category);
|
||||||
name: 'Verification',
|
|
||||||
type: ChannelType.GuildVoice,
|
|
||||||
parent: category.id,
|
|
||||||
userLimit: 1,
|
|
||||||
permissionOverwrites: [
|
|
||||||
{
|
|
||||||
id: category.guild.roles.everyone,
|
|
||||||
deny: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.SendMessages],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.verifyBlock,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.SendMessages],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.nonvegan.nonvegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.vegan,
|
|
||||||
allow: [PermissionsBitField.Flags.ViewChannel],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.vegan.activist,
|
|
||||||
deny: [PermissionsBitField.Flags.ViewChannel, PermissionsBitField.Flags.Connect],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.verifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
{
|
|
||||||
id: IDs.roles.staff.trialVerifier,
|
|
||||||
allow: [PermissionsBitField.Flags.SendMessages,
|
|
||||||
PermissionsBitField.Flags.ViewChannel,
|
|
||||||
PermissionsBitField.Flags.Connect,
|
|
||||||
PermissionsBitField.Flags.MuteMembers],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
127
src/utils/verification.ts
Normal file
127
src/utils/verification.ts
Normal file
@ -0,0 +1,127 @@
|
|||||||
|
// SPDX-License-Identifier: GPL-3.0-or-later
|
||||||
|
/*
|
||||||
|
Animal Rights Advocates Discord Bot
|
||||||
|
Copyright (C) 2022 Anthony Berg
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
import {
|
||||||
|
CategoryChannel,
|
||||||
|
ChannelType,
|
||||||
|
GuildMember,
|
||||||
|
PermissionsBitField,
|
||||||
|
VoiceBasedChannel,
|
||||||
|
} from 'discord.js';
|
||||||
|
import IDs from '#utils/ids';
|
||||||
|
|
||||||
|
export async function createVerificationText(
|
||||||
|
member: GuildMember,
|
||||||
|
voiceChannel: VoiceBasedChannel,
|
||||||
|
category: CategoryChannel,
|
||||||
|
bannedName = false,
|
||||||
|
) {
|
||||||
|
const { guild } = category;
|
||||||
|
|
||||||
|
const channel = await guild.channels.create({
|
||||||
|
name: `✅┃${!bannedName ? member.displayName : member.id}-verification`,
|
||||||
|
type: ChannelType.GuildText,
|
||||||
|
topic: `Channel for verifiers only. ${member.id} ${voiceChannel.id} (Please do not change this)`,
|
||||||
|
parent: category.id,
|
||||||
|
userLimit: 1,
|
||||||
|
permissionOverwrites: [
|
||||||
|
{
|
||||||
|
id: guild.roles.everyone,
|
||||||
|
deny: [PermissionsBitField.Flags.SendMessages,
|
||||||
|
PermissionsBitField.Flags.ViewChannel],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.verifyBlock,
|
||||||
|
deny: [PermissionsBitField.Flags.SendMessages,
|
||||||
|
PermissionsBitField.Flags.ViewChannel],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.staff.verifier,
|
||||||
|
allow: [PermissionsBitField.Flags.SendMessages,
|
||||||
|
PermissionsBitField.Flags.ViewChannel],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.staff.trialVerifier,
|
||||||
|
allow: [PermissionsBitField.Flags.SendMessages,
|
||||||
|
PermissionsBitField.Flags.ViewChannel],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
return channel;
|
||||||
|
}
|
||||||
|
|
||||||
|
export async function createVerificationVoice(
|
||||||
|
category: CategoryChannel,
|
||||||
|
full = false,
|
||||||
|
) {
|
||||||
|
const { guild } = category;
|
||||||
|
|
||||||
|
const channel = await guild.channels.create({
|
||||||
|
name: 'Verification',
|
||||||
|
type: ChannelType.GuildVoice,
|
||||||
|
parent: category.id,
|
||||||
|
userLimit: 1,
|
||||||
|
permissionOverwrites: [
|
||||||
|
{
|
||||||
|
id: guild.roles.everyone,
|
||||||
|
deny: [PermissionsBitField.Flags.SendMessages,
|
||||||
|
PermissionsBitField.Flags.ViewChannel,
|
||||||
|
PermissionsBitField.Flags.Stream],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.verifyBlock,
|
||||||
|
deny: [PermissionsBitField.Flags.ViewChannel,
|
||||||
|
PermissionsBitField.Flags.Connect,
|
||||||
|
PermissionsBitField.Flags.SendMessages],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.nonvegan.nonvegan,
|
||||||
|
allow: [PermissionsBitField.Flags.ViewChannel],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.vegan.vegan,
|
||||||
|
allow: [PermissionsBitField.Flags.ViewChannel],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.vegan.activist,
|
||||||
|
deny: [PermissionsBitField.Flags.ViewChannel,
|
||||||
|
PermissionsBitField.Flags.Connect],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.staff.verifier,
|
||||||
|
allow: [PermissionsBitField.Flags.SendMessages,
|
||||||
|
PermissionsBitField.Flags.ViewChannel,
|
||||||
|
PermissionsBitField.Flags.Connect,
|
||||||
|
PermissionsBitField.Flags.MuteMembers],
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: IDs.roles.staff.trialVerifier,
|
||||||
|
allow: [PermissionsBitField.Flags.SendMessages,
|
||||||
|
PermissionsBitField.Flags.ViewChannel,
|
||||||
|
PermissionsBitField.Flags.Connect,
|
||||||
|
PermissionsBitField.Flags.MuteMembers],
|
||||||
|
},
|
||||||
|
],
|
||||||
|
});
|
||||||
|
|
||||||
|
if (full) {
|
||||||
|
await channel.permissionOverwrites.edit(IDs.roles.nonvegan.nonvegan, { Connect: false });
|
||||||
|
await channel.permissionOverwrites.edit(IDs.roles.vegan.vegan, { Connect: false });
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user