fixed voiceStateUpdate voiceWebSocket error.

This commit is contained in:
Matte 2021-01-21 14:05:22 +02:00
parent 46b3119f79
commit ff49fbd16c

View File

@ -1,39 +1,59 @@
module.exports = {
name: 'voiceStateUpdate',
name: "voiceStateUpdate",
async execute(client, oldState, newState) {
if (oldState.channel === null) return;
let change = false;
const radio = client.radio.get(newState.guild.id);
if (!radio) return;
/*
if (newState.member.id === client.user.id && oldState.member.id === client.user.id) {
if (
newState.member.id === client.user.id &&
oldState.member.id === client.user.id
) {
if (newState.channel === null) {
client.funcs.statisticsUpdate(client, newState.guild, radio);
return client.radio.delete(newState.guild.id);
}
const newPermissions = newState.channel.permissionsFor(newState.client.user);
if (!newPermissions.has('CONNECT') || !newPermissions.has('SPEAK') || !newPermissions.has('VIEW_CHANNEL')) {
const newPermissions = newState.channel.permissionsFor(
newState.client.user
);
if (
!newPermissions.has("CONNECT") ||
!newPermissions.has("SPEAK") ||
!newPermissions.has("VIEW_CHANNEL")
) {
try {
const connection = await oldState.channel.join();
return radio.connection = connection;
setTimeout(
async () => (radio.connection = await oldState.channel.join()),
1000
);
} catch (error) {
client.funcs.statisticsUpdate(client, newState.guild, radio);
radio.connection.dispatcher.destroy();
radio.voiceChannel.leave();
client.radio.delete(oldState.guild.id);
return;
}
return;
}
if (newState.channel !== radio.voiceChannel) {
change = true;
radio.voiceChannel = newState.channel;
radio.connection = newState.connection;
radio.connection = await newState.channel.join();
}
}*/
if (oldState.channel.members.size === 1 && oldState.channel === radio.voiceChannel || change) {
}
if (
(oldState.channel.members.size === 1 &&
oldState.channel === radio.voiceChannel) ||
change
) {
setTimeout(() => {
if (!radio || !radio.connection.dispatcher || !radio.connection.dispatcher === null) return;
if (
!radio ||
!radio.connection.dispatcher ||
!radio.connection.dispatcher === null
)
return;
if (radio.voiceChannel.members.size === 1) {
client.funcs.statisticsUpdate(client, newState.guild, radio);
radio.connection.dispatcher.destroy();
@ -42,5 +62,5 @@ module.exports = {
}
}, 120000);
}
}
},
};