mirror of
https://github.com/musix-org/musix-oss
synced 2025-01-22 16:53:26 +00:00
Update 3.0.3
All messages reworked.
This commit is contained in:
parent
f985744170
commit
a64f9d2325
@ -9,14 +9,15 @@ module.exports = {
|
||||
category: 'music',
|
||||
execute(msg, args, client, Discord, prefix, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (!args[1] && serverQueue) return msg.channel.send(`:loud_sound: The current bass is: **${serverQueue.bass}**`);
|
||||
if (!args[1] && serverQueue) return msg.channel.send(`${client.messages.currentBass}**${serverQueue.bass}**`);
|
||||
const bass = parseFloat(args[1]);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (isNaN(bass)) return msg.channel.send('<:redx:674263474704220182> I\'m sorry, But you need to enter a valid __number__.');
|
||||
if (bass > 100) return msg.channel.send('<:redx:674263474704220182> The max bass is `100`!');
|
||||
if (bass < 0) return msg.channel.send('<:redx:674263474704220182> The volume needs to be a positive number!');
|
||||
if (isNaN(bass)) return msg.channel.send(client.messages.validNumber);
|
||||
if (bass > 100) return msg.channel.send(client.messages.maxBass);
|
||||
if (bass < 0) return msg.channel.send(client.messages.positiveBass);
|
||||
serverQueue.bass = bass;
|
||||
return msg.channel.send(`<:volumehigh:674685637626167307> The bass level **${bass}** will be applied when the next song starts playing!`);
|
||||
client.messages.bassApplied = client.messages.bassApplied.replace("%BASS%", bass);
|
||||
return msg.channel.send(client.messages.bassApplied);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -9,7 +9,7 @@ module.exports = {
|
||||
async execute(msg, args, client, Discord, prefix) {
|
||||
const embed = new Discord.MessageEmbed()
|
||||
.setTitle(`Found a bug with ${client.user.username}?\nDM the core developer:`)
|
||||
.setDescription(`Matte#0002\nOr join the support server: https://discord.gg/rvHuJtB`)
|
||||
.setDescription(client.messages.bug)
|
||||
.setColor(client.config.embedColor);
|
||||
msg.channel.send(embed);
|
||||
},
|
||||
|
@ -8,6 +8,6 @@ module.exports = {
|
||||
category: 'util',
|
||||
async execute(msg, args, client, Discord, prefix, command) {
|
||||
client.queue.delete(msg.guild.id);
|
||||
msg.channel.send('Queue deleted!');
|
||||
msg.channel.send(client.messages.queueDeleted);
|
||||
}
|
||||
};
|
||||
|
@ -14,11 +14,11 @@ module.exports = {
|
||||
if (serverQueue) {
|
||||
serverQueue.connection = connection;
|
||||
}
|
||||
msg.channel.send(`<:green_check_mark:674265384777416705> Joined ${voiceChannel.name}!`);
|
||||
msg.channel.send(`${client.messages.joined} ${voiceChannel.name}!`);
|
||||
} catch (error) {
|
||||
client.queue.delete(msg.guild.id);
|
||||
client.channels.get(client.config.debug_channel).send("Error with connecting to voice channel: " + error);
|
||||
return msg.channel.send(`<:redx:674263474704220182> An error occured: ${error}`);
|
||||
client.channels.get(client.config.debug_channel).send(client.messages.errorConnecting + error);
|
||||
return msg.channel.send(client.messages.error);
|
||||
}
|
||||
}
|
||||
};
|
@ -11,10 +11,10 @@ module.exports = {
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (!serverQueue.looping) {
|
||||
serverQueue.looping = true;
|
||||
msg.channel.send('<:repeat1:674685561377914892> Looping the queue now!');
|
||||
msg.channel.send(client.messages.looping);
|
||||
} else {
|
||||
serverQueue.looping = false;
|
||||
msg.channel.send('<:repeat1:674685561377914892> No longer looping the queue!');
|
||||
msg.channel.send(client.messages.noLooping);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -11,10 +11,11 @@ module.exports = {
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (!serverQueue.songLooping) {
|
||||
serverQueue.songLooping = true;
|
||||
msg.channel.send(`<:repeatsong:674685573419761716> Looping **${serverQueue.songs[0].title}** now!`);
|
||||
client.messages.loopingSong = client.messages.loopingSong.replace("%TITLE%", serverQueue.songs[0].title);
|
||||
msg.channel.send(client.messages.loopingSong);
|
||||
} else {
|
||||
serverQueue.songLooping = false;
|
||||
msg.channel.send('<:repeatsong:674685573419761716> No longer looping the song!');
|
||||
msg.channel.send(client.messages.noLoopingSong);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -10,8 +10,7 @@ module.exports = {
|
||||
const getThumb = require('video-thumbnail-url');
|
||||
const ytdl = require('ytdl-core');
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (!serverQueue) return msg.channel.send('<:redx:674263474704220182> There is nothing playing.');
|
||||
if (!serverQueue.playing) return msg.channel.send('<:redx:674263474704220182> There is nothing playing.');
|
||||
if (!serverQueue || !serverQueue.playing) return msg.channel.send(client.messages.noServerQueue);
|
||||
let data = await Promise.resolve(ytdl.getInfo(serverQueue.songs[0].url));
|
||||
let songtime = (data.length_seconds * 1000).toFixed(0);
|
||||
serverQueue.time = serverQueue.connection.dispatcher.streamTime;
|
||||
@ -21,7 +20,7 @@ module.exports = {
|
||||
let array = []; for (let i = 0; i < completedpercent - 1; i++) { array.push('⎯'); } array.push('⭗'); for (let i = 0; i < barlength - completedpercent - 1; i++) { array.push('⎯'); }
|
||||
const thumbnail = getThumb(serverQueue.songs[0].url);
|
||||
const embed = new Discord.MessageEmbed()
|
||||
.setTitle("__Now playing__")
|
||||
.setTitle(client.messages.nowPlaying)
|
||||
.setDescription(`<a:aNotes:674602408105476106>**Now playing:** ${serverQueue.songs[0].title}\n${array.join('')} | \`${client.funcs.msToTime(completed, "hh:mm:ss")} / ${client.funcs.msToTime(songtime, "hh:mm:ss")}\``)
|
||||
.setFooter(`Queued by ${serverQueue.songs[0].author.tag}`)
|
||||
.setURL(serverQueue.songs[0].url)
|
||||
|
@ -9,10 +9,10 @@ module.exports = {
|
||||
execute(msg, args, client, Discord, prefix, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (serverQueue.paused) return msg.channel.send('<:redx:674263474704220182> The music is already paused!');
|
||||
if (serverQueue.paused) return msg.channel.send(client.messages.alreadyPaused);
|
||||
serverQueue.paused = true;
|
||||
serverQueue.connection.dispatcher.pause(true);
|
||||
return msg.channel.send('<:pause:674685548610322462> Paused the music!');
|
||||
return msg.channel.send(client.messages.paused);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -15,31 +15,28 @@ module.exports = {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
const voiceChannel = msg.member.voice.channel;
|
||||
if (!serverQueue) {
|
||||
if (!msg.member.voice.channel) return msg.channel.send('<:redx:674263474704220182> I\'m sorry but you need to be in a voice channel to play music!');
|
||||
if (!msg.member.voice.channel) return msg.channel.send(client.messages.noVoiceChannel);
|
||||
} else {
|
||||
if (voiceChannel !== serverQueue.voiceChannel) return msg.channel.send('<:redx:674263474704220182> I\'m sorry but you need to be in the same voice channel as Musix to play music!');
|
||||
if (voiceChannel !== serverQueue.voiceChannel) return msg.channel.send(client.messages.wrongVoiceChannel);
|
||||
}
|
||||
if (!args[1]) return msg.channel.send('<:redx:674263474704220182> You need to use a link or search for a song!');
|
||||
if (!args[1]) return msg.channel.send(client.messages.noQuery);
|
||||
const permissions = voiceChannel.permissionsFor(msg.client.user);
|
||||
if (!permissions.has('CONNECT')) {
|
||||
return msg.channel.send('<:redx:674263474704220182> I cannot connect to your voice channel, make sure I have the proper permissions!');
|
||||
return msg.channel.send(client.messages.noPermsConnect);
|
||||
}
|
||||
if (!permissions.has('SPEAK')) {
|
||||
return msg.channel.send('<:redx:674263474704220182> I cannot speak in your voice channel, make sure I have the proper permissions!');
|
||||
return msg.channel.send(client.messages.noPermsSpeak);
|
||||
}
|
||||
if (url.match(/^https?:\/\/(www.youtube.com|youtube.com)\/playlist(.*)$/)) {
|
||||
const lmsg = await msg.channel.send('<a:loading:674284196700618783> Loading song(s)');
|
||||
const lmsg = await msg.channel.send(client.messages.loadingSongs);
|
||||
const playlist = await youtube.getPlaylist(url);
|
||||
const videos = await playlist.getVideos();
|
||||
for (const video of Object.values(videos)) {
|
||||
const video2 = await youtube.getVideoByID(video.id)
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
return lmsg.edit(`<:redx:674263474704220182> Error loading songs!\nNot all songs we're loaded! This may have been caused by the playlist containing privated/deleted videos!`);
|
||||
});
|
||||
const video2 = await youtube.getVideoByID(video.id);
|
||||
await client.funcs.handleVideo(video2, msg, voiceChannel, client, true);
|
||||
}
|
||||
return lmsg.edit(`<:green_check_mark:674265384777416705> Playlist: **${playlist.title}** has been added to the queue!`);
|
||||
client.messages.playlistAdded = client.messages.playlistAdded.replace("%TITLE%", playlist.title);
|
||||
return lmsg.edit(client.messages.playlistAdded);
|
||||
} else {
|
||||
try {
|
||||
var video = await youtube.getVideo(url);
|
||||
@ -49,7 +46,7 @@ module.exports = {
|
||||
var video = await youtube.getVideoByID(videos[0].id);
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
return msg.channel.send('<:redx:674263474704220182> I could not obtain any search results!');
|
||||
return msg.channel.send(client.messages.noResults);
|
||||
}
|
||||
}
|
||||
return client.funcs.handleVideo(video, msg, voiceChannel, client, false);
|
||||
|
@ -8,9 +8,9 @@ module.exports = {
|
||||
category: 'music',
|
||||
async execute(msg, args, client, Discord, prefix) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (!serverQueue) return msg.channel.send('<:redx:674263474704220182> There is nothing playing.');
|
||||
if (!serverQueue) return msg.channel.send(client.messages.noServerQueue);
|
||||
if (args[1]) {
|
||||
if (isNaN(args[1])) return msg.channel.send('<:redx:674263474704220182> I\'m sorry, But you need to enter a valid __number__.');
|
||||
if (isNaN(args[1])) return msg.channel.send(client.messages.validNumber);
|
||||
}
|
||||
let page = parseInt(args[1]);
|
||||
if (!page) page = 1;
|
||||
|
@ -25,6 +25,6 @@ module.exports = {
|
||||
/*fs.readdirSync(path.join(__dirname, 'funcs')).forEach(filename => {
|
||||
this.funcs[filename.slice(0, -3)] = require(`../struct/funcs/${filename}`);
|
||||
});*/
|
||||
msg.channel.send('All files reloaded!');
|
||||
msg.channel.send(client.messages.reloaded);
|
||||
}
|
||||
};
|
||||
|
@ -9,12 +9,14 @@ module.exports = {
|
||||
execute(msg, args, client, Discord, prefix, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (!args[1]) return msg.channel.send('<:redx:674263474704220182> Please provide a song position in queue for me to remove!');
|
||||
if (!args[1]) return msg.channel.send(client.messages.provideASong);
|
||||
const pos = parseInt(args[1]);
|
||||
if (isNaN(pos)) return msg.channel.send('<:redx:674263474704220182> You need to enter a number!');
|
||||
if (pos < 1) return msg.channel.send('<:redx:674263474704220182> That songs does not exist!');
|
||||
if (pos > serverQueue.songs.length) return msg.channel.send(`<:redx:674263474704220182> There is only ${serverQueue.songs.length} amount of songs in the queue!`);
|
||||
msg.channel.send(`🗑️ removed \`${serverQueue.songs[pos].title}\` from the queue!`);
|
||||
if (isNaN(pos)) return msg.channel.send(client.messages.validNumber);
|
||||
if (pos < 1) return msg.channel.send(client.messages.noSongs);
|
||||
client.messages.queueLength = client.messages.queueLength.replace("%LENGTH%", serverQueue.songs.length);
|
||||
if (pos > serverQueue.songs.length) return msg.channel.send(client.messages.queueLength);
|
||||
client.messages.removed = client.messages.removed.replace("%SONG%", serverQueue.songs[pos].title);
|
||||
msg.channel.send(client.messages.removed);
|
||||
return serverQueue.songs.splice(pos, 1);
|
||||
}
|
||||
}
|
||||
|
@ -9,6 +9,6 @@ module.exports = {
|
||||
async execute(msg, args, client, Discord, prefix, command) {
|
||||
client.destroy();
|
||||
require('../index.js');
|
||||
msg.channel.send('restarted!');
|
||||
msg.channel.send(client.messages.restart);
|
||||
}
|
||||
};
|
||||
|
@ -9,10 +9,10 @@ module.exports = {
|
||||
execute(msg, args, client, Discord, prefix, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (!serverQueue.paused) return msg.channel.send('<:redx:674263474704220182> The music in not paused!');
|
||||
if (!serverQueue.paused) return msg.channel.send(client.messages.notPaused);
|
||||
serverQueue.paused = false;
|
||||
serverQueue.connection.dispatcher.resume(true);
|
||||
return msg.channel.send('<:resume:674685585478254603> Resumed the music!');
|
||||
return msg.channel.send(client.messages.resumed);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -16,27 +16,28 @@ module.exports = {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
const voiceChannel = msg.member.voice.channel;
|
||||
if (!serverQueue) {
|
||||
if (!msg.member.voice.channel) return msg.channel.send('<:redx:674263474704220182> I\'m sorry but you need to be in a voice channel to play music!');
|
||||
if (!msg.member.voice.channel) return msg.channel.send(client.messages.noVoiceChannel);
|
||||
} else {
|
||||
if (voiceChannel !== serverQueue.voiceChannel) return msg.channel.send('<:redx:674263474704220182> I\'m sorry but you need to be in the same voice channel as Musix to play music!');
|
||||
if (voiceChannel !== serverQueue.voiceChannel) return msg.channel.send(client.messages.wrongVoiceChannel);
|
||||
}
|
||||
if (!args[1]) return msg.channel.send('<:redx:674263474704220182> You need to use a link or search for a song!');
|
||||
if (!args[1]) return msg.channel.send(client.messages.noQuery);
|
||||
const permissions = voiceChannel.permissionsFor(msg.client.user);
|
||||
if (!permissions.has('CONNECT')) {
|
||||
return msg.channel.send('<:redx:674263474704220182> I cannot connect to your voice channel, make sure I have the proper permissions!');
|
||||
return msg.channel.send(client.messages.noPermsConnect);
|
||||
}
|
||||
if (!permissions.has('SPEAK')) {
|
||||
return msg.channel.send('<:redx:674263474704220182> I cannot speak in your voice channel, make sure I have the proper permissions!');
|
||||
return msg.channel.send(client.messages.noPermsSpeak);
|
||||
}
|
||||
if (url.match(/^https?:\/\/(www.youtube.com|youtube.com)\/playlist(.*)$/)) {
|
||||
const lmsg = await msg.channel.send('<a:loading:674284196700618783> Loading song(s)');
|
||||
const lmsg = await msg.channel.send(client.messages.loadingSongs);
|
||||
const playlist = await youtube.getPlaylist(url);
|
||||
const videos = await playlist.getVideos();
|
||||
for (const video of Object.values(videos)) {
|
||||
const video2 = await youtube.getVideoByID(video.id);
|
||||
await client.funcs.handleVideo(video2, msg, voiceChannel, client, true);
|
||||
}
|
||||
return lmsg.edit(`<:green_check_mark:674265384777416705> Playlist: **${playlist.title}** has been added to the queue!`);
|
||||
client.messages.playlistAdded = client.messages.playlistAdded.replace("%TITLE%", playlist.title);
|
||||
return lmsg.edit(client.messages.playlistAdded);
|
||||
} else {
|
||||
try {
|
||||
var video = await youtube.getVideo(url);
|
||||
@ -45,9 +46,9 @@ module.exports = {
|
||||
var videos = await youtube.searchVideos(searchString, 10);
|
||||
let index = 0;
|
||||
const embed = new Discord.MessageEmbed()
|
||||
.setTitle("__Song Selection__")
|
||||
.setTitle(client.messages.songSelection)
|
||||
.setDescription(`${videos.map(video2 => `**${++index}** ${he.decode(video2.title)} `).join('\n')}`)
|
||||
.setFooter("Please provide a number ranging from 1-10 to select one of the search results.")
|
||||
.setFooter(client.messages.provideANumber)
|
||||
.setColor(client.config.embedColor)
|
||||
msg.channel.send(embed);
|
||||
try {
|
||||
@ -58,13 +59,13 @@ module.exports = {
|
||||
});
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
return msg.channel.send('<:redx:674263474704220182> Cancelling video selection');
|
||||
return msg.channel.send(client.messages.cancellingVideoSelection);
|
||||
}
|
||||
const videoIndex = parseInt(response.first().content);
|
||||
var video = await youtube.getVideoByID(videos[videoIndex - 1].id);
|
||||
} catch (err) {
|
||||
console.error(err);
|
||||
return msg.channel.send('<:redx:674263474704220182> I could not obtain any search results!');
|
||||
return msg.channel.send(client.messages.noResults);
|
||||
}
|
||||
}
|
||||
return client.funcs.handleVideo(video, msg, voiceChannel, client, false);
|
||||
|
@ -1,7 +1,7 @@
|
||||
module.exports = {
|
||||
name: 'seek',
|
||||
alias: 'none',
|
||||
usage: '<point in song(seconds)>',
|
||||
usage: '<point in song>',
|
||||
description: 'Seek to a specific point in the currently playing song.',
|
||||
onlyDev: true,
|
||||
permission: 'MANAGE_MESSAGES',
|
||||
@ -11,12 +11,13 @@ module.exports = {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
let data = await Promise.resolve(ytdl.getInfo(serverQueue.songs[0].url));
|
||||
if (!args[1]) return msg.channel.send(`<:redx:674263474704220182> Correct usage: \`${prefix}seek <seeking point in seconds>\``);
|
||||
if (!args[1]) return msg.channel.send(`${client.messages.correctUsage}\`${prefix}seek ${command.usage}\``);
|
||||
let point = args[1];
|
||||
const pos = parseInt(args[1]);
|
||||
if (isNaN(pos)) {
|
||||
if (pos < 0) return msg.channel.send('<:redx:674263474704220182> The seeking point needs to be a positive number!');
|
||||
if (pos > data.length_seconds) return msg.channel.send(`<:redx:674263474704220182> The lenght of this song is ${data.length_seconds} seconds! You can't seek further than that!`);
|
||||
if (pos < 0) return msg.channel.send(client.messages.seekingPointPositive);
|
||||
client.messages.seekMax = client.messages.seekMax.replace("%LENGTH%", data.length_seconds);
|
||||
if (pos > data.length_seconds) return msg.channel.send(client.messages.seekMax);
|
||||
point = pos;
|
||||
}
|
||||
serverQueue.connection.dispatcher.end();
|
||||
|
@ -20,7 +20,7 @@ module.exports = {
|
||||
.setColor(client.embedColor)
|
||||
const permissions = msg.channel.permissionsFor(msg.author);
|
||||
if (msg.author.id !== client.config.devId) {
|
||||
if (!permissions.has(command.permission)) return msg.channel.send('<:redx:674263474704220182> You need the `MANAGE_SERVER` permission to change the settings!');
|
||||
if (!permissions.has(command.permission)) return msg.channel.send(client.messages.noPermsManageSettings);
|
||||
}
|
||||
if (args[1]) {
|
||||
const optionName = args[1].toLowerCase();
|
||||
@ -29,7 +29,7 @@ module.exports = {
|
||||
try {
|
||||
option.execute(msg, args, client, Discord, prefix);
|
||||
} catch (error) {
|
||||
msg.reply(`<:redx:674263474704220182> there was an error trying to execute that option! Please contact support with \`${prefix}bug\`!`);
|
||||
msg.reply(client.messages.errorExeOpt);
|
||||
const embed = new Discord.MessageEmbed()
|
||||
.setTitle(`Musix ${error.toString()}`)
|
||||
.setDescription(error.stack.replace(/at /g, '**at **'))
|
||||
|
@ -3,10 +3,10 @@ module.exports = {
|
||||
async execute(msg, args, client, Discord, prefix) {
|
||||
if (client.global.db.guilds[msg.guild.id].startPlaying) {
|
||||
client.global.db.guilds[msg.guild.id].startPlaying = false;
|
||||
return msg.channel.send('<:green_check_mark:674265384777416705> announcesongs now set to `false`!');
|
||||
return msg.channel.send(client.messages.announceSongsFalse);
|
||||
} else {
|
||||
client.global.db.guilds[msg.guild.id].startPlaying = true;
|
||||
return msg.channel.send('<:green_check_mark:674265384777416705> announcesongs now set to `true`!');
|
||||
return msg.channel.send(client.messages.announceSongsTrue);
|
||||
}
|
||||
}
|
||||
};
|
@ -1,14 +1,14 @@
|
||||
module.exports = {
|
||||
name: 'bass',
|
||||
async execute(msg, args, client, Discord, prefix) {
|
||||
if (!args[2]) return msg.channel.send('Currect bass level: ' + client.global.db.guilds[msg.guild.id].bass);
|
||||
if (!args[2]) return msg.channel.send(client.messages.currentDefaultBass + client.global.db.guilds[msg.guild.id].bass);
|
||||
if (args[2] === "false") {
|
||||
client.global.db.guilds[msg.guild.id].bass = false;
|
||||
msg.channel.send(`Bass is now false!`);
|
||||
msg.channel.send(client.messages.bassFalse);
|
||||
}
|
||||
const level = parseInt(args[2]);
|
||||
if (isNaN(level)) return msg.channel.send('You need to provide a number?');
|
||||
if (isNaN(level)) return msg.channel.send(client.messages.validNumber);
|
||||
client.global.db.guilds[msg.guild.id].bass = level;
|
||||
msg.channel.send(`Bass level is now ${level}!`);
|
||||
msg.channel.send(`${client.messages.bassLevel} ${level}!`);
|
||||
}
|
||||
};
|
@ -1,17 +1,17 @@
|
||||
module.exports = {
|
||||
name: 'permissions',
|
||||
async execute(msg, args, client, Discord, prefix) {
|
||||
if (!args[2]) return msg.channel.send(`🔒 Permission requirement: \`${client.global.db.guilds[msg.guild.id].permissions}\``);
|
||||
if (!args[2]) return msg.channel.send(`${client.messages.permissions} \`${client.global.db.guilds[msg.guild.id].permissions}\``);
|
||||
if (args[2] === 'true') {
|
||||
if (!client.global.db.guilds[msg.guild.id].permissions) {
|
||||
client.global.db.guilds[msg.guild.id].permissions = true;
|
||||
msg.channel.send(`<:green_check_mark:674265384777416705> Permissions requirement now set to: \`true\``);
|
||||
} else return msg.channel.send('<:redx:674263474704220182> That value is already `true`!');
|
||||
msg.channel.send(client.messages.permissionsSetTrue);
|
||||
} else return msg.channel.send(client.messages.permissionsTrue);
|
||||
} else if (args[2] === 'false') {
|
||||
if (client.global.db.guilds[msg.guild.id].permissions) {
|
||||
client.global.db.guilds[msg.guild.id].permissions = false;
|
||||
msg.channel.send(`<:green_check_mark:674265384777416705> Permissions requirement now set to: \`false\``);
|
||||
} else return msg.channel.send('<:redx:674263474704220182> That value is already `false`!');
|
||||
} else return msg.channel.send('<:redx:674263474704220182> Please define a boolean! (true/false)');
|
||||
msg.channel.send(client.messages.permissionsSetFalse);
|
||||
} else return msg.channel.send(client.messages.permissionsFalse);
|
||||
} else return msg.channel.send(client.messages.boolean);
|
||||
}
|
||||
};
|
@ -3,6 +3,6 @@ module.exports = {
|
||||
async execute(msg, args, client, Discord, prefix) {
|
||||
if (!args[2]) return msg.channel.send(`Current prefix: \`${client.global.db.guilds[msg.guild.id].prefix}\``);
|
||||
client.global.db.guilds[msg.guild.id].prefix = args[2];
|
||||
msg.channel.send(`<:green_check_mark:674265384777416705> New prefix set to: \`${args[2]}\``);
|
||||
msg.channel.send(`${client.messages.prefixSet} \`${args[2]}\``);
|
||||
}
|
||||
};
|
@ -9,6 +9,6 @@ module.exports = {
|
||||
dj: false,
|
||||
djrole: null
|
||||
};
|
||||
msg.channel.send('<:green_check_mark:674265384777416705> Reset __all__ guild settings!');
|
||||
msg.channel.send(client.messages.reset);
|
||||
}
|
||||
};
|
@ -7,22 +7,22 @@ module.exports = {
|
||||
}
|
||||
if (msg.guild.roles.cache.find(x => x.name === "DJ")) {
|
||||
client.global.db.guilds[msg.guild.id].djrole = msg.guild.roles.cache.find(x => x.name === "DJ").id;
|
||||
msg.channel.send('<:green_check_mark:674265384777416705> I found a `DJ` role from this guild! This role is now the DJ role.');
|
||||
msg.channel.send(client.messages.djRoleFound);
|
||||
client.global.db.guilds[msg.guild.id].dj = true;
|
||||
} else {
|
||||
const permissions = msg.channel.permissionsFor(msg.client.user);
|
||||
if (!permissions.has('MANAGE_ROLES')) return msg.channel.send('<:redx:674263474704220182> I cannot create roles (Manage roles), make sure I have the proper permissions! I will need this permission to create a `DJ` role since i did not find one!');
|
||||
if (!permissions.has('MANAGE_ROLES')) return msg.channel.send(client.messages.noPermsManageRoles);
|
||||
msg.guild.createRole({
|
||||
name: 'DJ',
|
||||
})
|
||||
.then(role => client.global.db.guilds[msg.guild.id].djrole = role.id)
|
||||
.catch(console.error)
|
||||
client.global.db.guilds[msg.guild.id].dj = true;
|
||||
msg.channel.send('<:green_check_mark:674265384777416705> I did not find a role `DJ` so i have created one for you!');
|
||||
msg.channel.send(client.messages.djRoleCreated);
|
||||
}
|
||||
} else {
|
||||
client.global.db.guilds[msg.guild.id].dj = false;
|
||||
msg.channel.send('<:green_check_mark:674265384777416705> `DJ` now set to `false`');
|
||||
msg.channel.send(client.messages.djFalse);
|
||||
}
|
||||
}
|
||||
};
|
@ -1,10 +1,10 @@
|
||||
module.exports = {
|
||||
name: 'volume',
|
||||
async execute(msg, args, client, Discord, prefix) {
|
||||
if (!args[2]) return msg.channel.send(`:speaker: Current default volume is: \`${client.global.db.guilds[msg.guild.id].defaultVolume}\``);
|
||||
if (isNaN(args[2])) return msg.channel.send('<:redx:674263474704220182> I\'m sorry, But the default volume needs to be a valid __number__.');
|
||||
if (args[2].length > 2) return msg.channel.send('<:redx:674263474704220182> The default volume must be below `100` for quality and safety resons.');
|
||||
if (!args[2]) return msg.channel.send(`${client.messages.currentDefaultVolume} \`${client.global.db.guilds[msg.guild.id].defaultVolume}\``);
|
||||
if (isNaN(args[2])) return msg.channel.send(client.messages.defaultVolumeNumber);
|
||||
if (args[2].length > 2) return msg.channel.send(client.messages.defaultVolumeMax);
|
||||
client.global.db.guilds[msg.guild.id].defaultVolume = args[2];
|
||||
msg.channel.send(`<:green_check_mark:674265384777416705> Default volume set to: \`${args[2]}\``);
|
||||
msg.channel.send(`${client.messages.defaultVolumeSet} \`${args[2]}\``);
|
||||
}
|
||||
};
|
@ -10,7 +10,7 @@ module.exports = {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
client.funcs.shuffle(serverQueue.songs);
|
||||
msg.channel.send('<:shuffle:674685595980791871> Queue suffled!');
|
||||
msg.channel.send(client.messages.shuffled);
|
||||
}
|
||||
}
|
||||
};
|
@ -9,33 +9,33 @@ module.exports = {
|
||||
execute(msg, args, client, Discord, prefix, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
const permissions = msg.channel.permissionsFor(msg.author);
|
||||
if (!serverQueue || !serverQueue.playing) return msg.channel.send('<:redx:674263474704220182> There is nothing playing!');
|
||||
if (!serverQueue || !serverQueue.playing) return msg.channel.send(client.messages.noServerQueue);
|
||||
if (msg.author.id !== client.config.devId) {
|
||||
if (msg.member.voice.channel !== serverQueue.voiceChannel) return msg.channel.send('<:redx:674263474704220182> I\'m sorry but you need to be in the same voice channel as Musix!');
|
||||
if (msg.member.voice.channel !== serverQueue.voiceChannel) return msg.channel.send(client.messages.wrongVoiceChannel);
|
||||
if (client.global.db.guilds[msg.guild.id].permissions) {
|
||||
if (!msg.member.roles.cache.has(client.global.db.guilds[msg.guild.id].djrole) || !permissions.has(command.permission)) {
|
||||
return vote(serverQueue, msg, client);
|
||||
} else {
|
||||
return skipSong(serverQueue, msg);
|
||||
return skipSong(serverQueue, msg, client);
|
||||
}
|
||||
} else {
|
||||
return skipSong(serverQueue, msg);
|
||||
return skipSong(serverQueue, msg, client);
|
||||
}
|
||||
} else {
|
||||
return skipSong(serverQueue, msg);
|
||||
return skipSong(serverQueue, msg, client);
|
||||
}
|
||||
}
|
||||
};
|
||||
function skipSong(serverQueue, msg) {
|
||||
msg.channel.send('<:skip:674685614221688832> Skipped the song!');
|
||||
function skipSong(serverQueue, msg, client) {
|
||||
msg.channel.send(client.messages.skipped);
|
||||
serverQueue.endReason = "skip";
|
||||
serverQueue.connection.dispatcher.end();
|
||||
};
|
||||
function vote(serverQueue, msg) {
|
||||
function vote(serverQueue, msg, client) {
|
||||
serverQueue.votesNeeded = Math.floor(serverQueue.voiceChannel.members.size / 2);
|
||||
serverQueue.votesNeeded.toFixed();
|
||||
if (serverQueue.voiceChannel.members.size > 2) {
|
||||
if (serverQueue.voters.includes(msg.member.id)) return msg.channel.send('<:redx:674263474704220182> You have already voted to skip!');
|
||||
if (serverQueue.voters.includes(msg.member.id)) return msg.channel.send(client.messages.alreadyVoted);
|
||||
serverQueue.votes++;
|
||||
serverQueue.voters.push(msg.member.id);
|
||||
if (serverQueue.votes >= serverQueue.votesNeeded) {
|
||||
@ -43,7 +43,7 @@ function vote(serverQueue, msg) {
|
||||
serverQueue.votes = 0;
|
||||
serverQueue.votesNeeded = null;
|
||||
return skipSong(serverQueue, msg);
|
||||
} else return msg.channel.send(`<:redx:674263474704220182> Not enough votes! ${serverQueue.votes} / ${serverQueue.votesNeeded}!`);
|
||||
} else return msg.channel.send(`${client.messages.notEnoughVotes} ${serverQueue.votes} / ${serverQueue.votesNeeded}!`);
|
||||
} else {
|
||||
return skipSong(serverQueue, msg);
|
||||
}
|
||||
|
@ -9,11 +9,11 @@ module.exports = {
|
||||
async execute(msg, args, client, Discord, prefix, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (!args[1]) return msg.channel.send(`<:redx:674263474704220182> correct usage: \`${command.usage}\``);
|
||||
if (!args[1]) return msg.channel.send(`${client.messages.correctUsage}\`${command.usage}\``);
|
||||
const point = parseInt(args[1] - 1);
|
||||
if (isNaN(point)) return msg.channel.send('<:redx:674263474704220182> I\'m sorry, But you need to enter a valid __number__.');
|
||||
if (point > serverQueue.songs.size) return msg.channel.send('<:redx:674263474704220182> That song does not exist!');
|
||||
if (point < 1) return msg.channel.send('<:redx:674263474704220182> You can\'t skip to the song currently playing!');
|
||||
if (isNaN(point)) return msg.channel.send(client.messages.validNumber);
|
||||
if (point > serverQueue.songs.size) return msg.channel.send(client.messages.noSongs);
|
||||
if (point < 1) return msg.channel.send(client.messages.cantSkipToCurrent);
|
||||
let i = 0;
|
||||
while (i < point) {
|
||||
i++;
|
||||
|
@ -8,7 +8,7 @@ module.exports = {
|
||||
category: 'info',
|
||||
execute(msg, args, client, Discord, prefix) {
|
||||
const uptime = client.funcs.msToTime(client.uptime, "dd:hh:mm:ss");
|
||||
msg.channel.send('<a:loading:674284196700618783> Pinging...').then(m => {
|
||||
msg.channel.send(client.messages.pinging).then(m => {
|
||||
const latency = m.createdTimestamp - msg.createdTimestamp;
|
||||
|
||||
const embed = new Discord.MessageEmbed()
|
||||
|
@ -13,7 +13,7 @@ module.exports = {
|
||||
serverQueue.looping = false;
|
||||
serverQueue.endReason = "stop";
|
||||
serverQueue.connection.dispatcher.end();
|
||||
msg.channel.send('<:stop:674685626108477519> Stopped the music!')
|
||||
msg.channel.send(client.messages.stop)
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -9,15 +9,15 @@ module.exports = {
|
||||
category: 'music',
|
||||
execute(msg, args, client, Discord, prefix, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
if (!args[1] && serverQueue) return msg.channel.send(`:loud_sound: The current volume is: **${serverQueue.volume}**`);
|
||||
if (!args[1] && serverQueue) return msg.channel.send(`${client.messages.currentVolume}**${serverQueue.volume}**`);
|
||||
const volume = parseFloat(args[1]);
|
||||
if (client.funcs.check(client, msg, command)) {
|
||||
if (isNaN(volume)) return msg.channel.send('<:redx:674263474704220182> I\'m sorry, But you need to enter a valid __number__.');
|
||||
if (volume > 100) return msg.channel.send('<:redx:674263474704220182> The max volume is `100`!');
|
||||
if (volume < 0) return msg.channel.send('<:redx:674263474704220182> The volume needs to be a positive number!');
|
||||
if (isNaN(volume)) return msg.channel.send(client.messages.validNumber);
|
||||
if (volume > 100) return msg.channel.send(client.messages.maxVolume);
|
||||
if (volume < 0) return msg.channel.send(client.messages.positiveVolume);
|
||||
serverQueue.volume = volume;
|
||||
serverQueue.connection.dispatcher.setVolume(volume / 5);
|
||||
return msg.channel.send(`<:volumehigh:674685637626167307> I set the volume to: **${volume}**`);
|
||||
return msg.channel.send(`${client.messages.setVolume}**${volume}**`);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -8,7 +8,7 @@ module.exports = {
|
||||
if (msg.mentions.users.first()) {
|
||||
if (msg.mentions.users.first().id === client.user.id) {
|
||||
if (!args[1]) return;
|
||||
if (args[1] === 'prefix') return msg.channel.send(`My prefix here is: \`${prefix}\`.`);
|
||||
if (args[1] === 'prefix') return msg.channel.send(`${client.messages.prefixHere}\`${prefix}\`.`);
|
||||
if (args[1] === 'help') {
|
||||
const command = client.commands.get("help");
|
||||
return client.funcs.exe(msg, args, client, Discord, prefix, command);
|
||||
@ -21,8 +21,8 @@ module.exports = {
|
||||
if (commandName === "none") return;
|
||||
const command = client.commands.get(commandName) || client.commands.find(cmd => cmd.aliases && cmd.aliases.includes(commandName)) || client.commandAliases.get(commandName);
|
||||
if (!command && msg.content !== `${prefix}`) return;
|
||||
if (command.onlyDev && msg.author.id !== client.config.devId) return msg.channel.send('<:redx:674263474704220182> You are not allowed to do that!');
|
||||
if (client.config.devMode && msg.member.id !== client.config.devId) return msg.channel.send('<:redx:674263474704220182> Dev mode has been turned on! Commands are only available to developer(s)!');
|
||||
if (command.onlyDev && msg.author.id !== client.config.devId) return msg.channel.send(client.messages.notAllowed);
|
||||
if (client.config.devMode && msg.member.id !== client.config.devId) return msg.channel.send(client.messages.devMode);
|
||||
client.funcs.exe(msg, args, client, Discord, prefix, command);
|
||||
}
|
||||
}
|
57
package-lock.json
generated
57
package-lock.json
generated
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "musix",
|
||||
"version": "3.0.2",
|
||||
"version": "3.0.3",
|
||||
"lockfileVersion": 1,
|
||||
"requires": true,
|
||||
"dependencies": {
|
||||
@ -19,9 +19,9 @@
|
||||
}
|
||||
},
|
||||
"@firebase/analytics": {
|
||||
"version": "0.2.15",
|
||||
"resolved": "https://registry.npmjs.org/@firebase/analytics/-/analytics-0.2.15.tgz",
|
||||
"integrity": "sha512-pNRyLU6PndZa0iO+HN+GwY1HobsyU584a1KN5ZWBuwaqbUOB/99uChn2n6XaPrlD/G07uzv6dpw558IQXahhow==",
|
||||
"version": "0.2.16",
|
||||
"resolved": "https://registry.npmjs.org/@firebase/analytics/-/analytics-0.2.16.tgz",
|
||||
"integrity": "sha512-t4lwd8SxigKULvt8a+VA1cVj7Aml/tUNECV9vzz3G9wusxDE76d7rTw+HexKTNPRbD2E9+JtRKUVPKlJpox9bw==",
|
||||
"requires": {
|
||||
"@firebase/analytics-types": "0.2.7",
|
||||
"@firebase/component": "0.1.6",
|
||||
@ -152,12 +152,12 @@
|
||||
}
|
||||
},
|
||||
"@firebase/firestore": {
|
||||
"version": "1.11.2",
|
||||
"resolved": "https://registry.npmjs.org/@firebase/firestore/-/firestore-1.11.2.tgz",
|
||||
"integrity": "sha512-WWTKQGUYvZ7BELzEeIhINVm+iKL2ki/f0y16Qc3kABCW4kdXtiUHak6uWMFQ3IXHtnpDGzcNTyDAKOWeZx+TzA==",
|
||||
"version": "1.12.0",
|
||||
"resolved": "https://registry.npmjs.org/@firebase/firestore/-/firestore-1.12.0.tgz",
|
||||
"integrity": "sha512-GWFU3pPs0xyp2ynFQIyvlmTtg4goGvOkT/lhVCu/Bq6/78xbl395nCPBMjF7IpUl+aVqQVUCwtF/cxrtNXgjMA==",
|
||||
"requires": {
|
||||
"@firebase/component": "0.1.6",
|
||||
"@firebase/firestore-types": "1.9.2",
|
||||
"@firebase/firestore-types": "1.10.0",
|
||||
"@firebase/logger": "0.1.36",
|
||||
"@firebase/util": "0.2.41",
|
||||
"@firebase/webchannel-wrapper": "0.2.36",
|
||||
@ -191,9 +191,9 @@
|
||||
}
|
||||
},
|
||||
"@firebase/firestore-types": {
|
||||
"version": "1.9.2",
|
||||
"resolved": "https://registry.npmjs.org/@firebase/firestore-types/-/firestore-types-1.9.2.tgz",
|
||||
"integrity": "sha512-D264aOrssdbD3PE0JuJdbwBI9zXDTd5HASjJYtYc3AIGC526R+w+TDWes4GsE/zi0dSWqMfgiceVKL0PekjqZw=="
|
||||
"version": "1.10.0",
|
||||
"resolved": "https://registry.npmjs.org/@firebase/firestore-types/-/firestore-types-1.10.0.tgz",
|
||||
"integrity": "sha512-/Pvmu5hpc0pceB96X2mEOAdEB0Xyn6+IQliBl7dUhu23AztnjBq+9uKcsgMB+k34RCApFQfNm1m24E4e+fUSVg=="
|
||||
},
|
||||
"@firebase/functions": {
|
||||
"version": "0.4.36",
|
||||
@ -957,9 +957,9 @@
|
||||
"optional": true
|
||||
},
|
||||
"dblapi.js": {
|
||||
"version": "2.3.1",
|
||||
"resolved": "https://registry.npmjs.org/dblapi.js/-/dblapi.js-2.3.1.tgz",
|
||||
"integrity": "sha512-SmaEknbWCPPyPX269hD2EARdkGlMp2PFsgjF8FsnaTLkWagQKtXO+K+aVF6FZqJvRrLIrpjv3y1bhK9KWq+coA=="
|
||||
"version": "2.4.0",
|
||||
"resolved": "https://registry.npmjs.org/dblapi.js/-/dblapi.js-2.4.0.tgz",
|
||||
"integrity": "sha512-SqDYVcV1DBQnyhySTjd+Qvzu7jFr+4eKwl56fGpIti7OlXGF5dmDPeo3jQfRlOXTRn5/I5997MDIJukoDxE3Mg=="
|
||||
},
|
||||
"debug": {
|
||||
"version": "4.1.1",
|
||||
@ -1033,9 +1033,9 @@
|
||||
}
|
||||
},
|
||||
"discord.js": {
|
||||
"version": "12.0.1",
|
||||
"resolved": "https://registry.npmjs.org/discord.js/-/discord.js-12.0.1.tgz",
|
||||
"integrity": "sha512-lUlrkAWSb5YTB1WpSZHjeUXxGlHK8VDjrlHLEP4lJj+etFAellURpmRYl29OPJ/7arQWB879pP4rvhhzpdOF7w==",
|
||||
"version": "12.0.2",
|
||||
"resolved": "https://registry.npmjs.org/discord.js/-/discord.js-12.0.2.tgz",
|
||||
"integrity": "sha512-iZiEA4Y61gqq/EjFfLXnkRK9pLapnax/vTVDUhs/mAhyqozAy0GOlk/MZI9rSa1iIoKTWRq6P9CRKhLNT2wUnA==",
|
||||
"requires": {
|
||||
"@discordjs/collection": "^0.1.5",
|
||||
"abort-controller": "^3.0.0",
|
||||
@ -1056,11 +1056,6 @@
|
||||
"combined-stream": "^1.0.8",
|
||||
"mime-types": "^2.1.12"
|
||||
}
|
||||
},
|
||||
"prism-media": {
|
||||
"version": "1.2.1",
|
||||
"resolved": "https://registry.npmjs.org/prism-media/-/prism-media-1.2.1.tgz",
|
||||
"integrity": "sha512-R3EbKwJiYlTvGwcG1DpUt+06DsxOGS5W4AMEHT7oVOjG93MjpdhGX1whHyjnqknylLMupKAsKMEXcTNRbPe6Vw=="
|
||||
}
|
||||
}
|
||||
},
|
||||
@ -1257,16 +1252,16 @@
|
||||
}
|
||||
},
|
||||
"firebase": {
|
||||
"version": "7.9.3",
|
||||
"resolved": "https://registry.npmjs.org/firebase/-/firebase-7.9.3.tgz",
|
||||
"integrity": "sha512-9tIxZvA8/Tf5p7nPMEE9zFklbmwqny4qHxGzwG3Hus4TInkxyYeiGY2L1mNTV+WuTJzQYuo9NtCRZLBnsChpqQ==",
|
||||
"version": "7.10.0",
|
||||
"resolved": "https://registry.npmjs.org/firebase/-/firebase-7.10.0.tgz",
|
||||
"integrity": "sha512-j80k8wsgg0N/t8uOkpGK6OT1MHHZ3Y/98nyZJJ+6lNodA6O79mXgyvI4AwXlPYd8qfmYeXwHz1f19sC+EqnZZg==",
|
||||
"requires": {
|
||||
"@firebase/analytics": "0.2.15",
|
||||
"@firebase/analytics": "0.2.16",
|
||||
"@firebase/app": "0.5.5",
|
||||
"@firebase/app-types": "0.5.2",
|
||||
"@firebase/auth": "0.13.6",
|
||||
"@firebase/database": "0.5.22",
|
||||
"@firebase/firestore": "1.11.2",
|
||||
"@firebase/firestore": "1.12.0",
|
||||
"@firebase/functions": "0.4.36",
|
||||
"@firebase/installations": "0.4.4",
|
||||
"@firebase/messaging": "0.6.8",
|
||||
@ -2823,7 +2818,7 @@
|
||||
"integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns="
|
||||
},
|
||||
"prism-media": {
|
||||
"version": "github:hydrabolt/prism-media#bbf60e0e22f9194586a4b30ffb9f49d20255041c",
|
||||
"version": "github:hydrabolt/prism-media#56b3dc34435ac320688148bef030b5c6822b7483",
|
||||
"from": "github:hydrabolt/prism-media"
|
||||
},
|
||||
"process-nextick-args": {
|
||||
@ -3395,9 +3390,9 @@
|
||||
}
|
||||
},
|
||||
"ws": {
|
||||
"version": "7.2.1",
|
||||
"resolved": "https://registry.npmjs.org/ws/-/ws-7.2.1.tgz",
|
||||
"integrity": "sha512-sucePNSafamSKoOqoNfBd8V0StlkzJKL2ZAhGQinCfNQ+oacw+Pk7lcdAElecBF2VkLNZRiIb5Oi1Q5lVUVt2A=="
|
||||
"version": "7.2.3",
|
||||
"resolved": "https://registry.npmjs.org/ws/-/ws-7.2.3.tgz",
|
||||
"integrity": "sha512-HTDl9G9hbkNDk98naoR/cHDws7+EyYMOdL1BmjsZXRUjf7d+MficC4B7HLUPlSiho0vg+CWKrGIt/VJBd1xunQ=="
|
||||
},
|
||||
"xdg-basedir": {
|
||||
"version": "4.0.0",
|
||||
|
@ -1,6 +1,6 @@
|
||||
{
|
||||
"name": "musix",
|
||||
"version": "3.0.2",
|
||||
"version": "3.0.3",
|
||||
"description": "V3 for Musix the discord music bot",
|
||||
"main": "./index.js",
|
||||
"scripts": {
|
||||
@ -18,11 +18,11 @@
|
||||
"homepage": "https://github.com/MatteZ02/Musix-V3#readme",
|
||||
"dependencies": {
|
||||
"@discordjs/opus": "^0.1.0",
|
||||
"dblapi.js": "^2.3.1",
|
||||
"discord.js": "^12.0.1",
|
||||
"dblapi.js": "^2.4.0",
|
||||
"discord.js": "^12.0.2",
|
||||
"dotenv": "^8.2.0",
|
||||
"ffmpeg": "0.0.4",
|
||||
"firebase": "^7.9.3",
|
||||
"firebase": "^7.10.0",
|
||||
"firebase-admin": "^8.9.2",
|
||||
"fs": "0.0.1-security",
|
||||
"he": "^1.2.0",
|
||||
|
@ -19,6 +19,7 @@ module.exports = class extends Client {
|
||||
this.funcs = {};
|
||||
this.dispatcher = {};
|
||||
this.config = require('./config/config.js');
|
||||
this.messages = require('./config/messages.js');
|
||||
this.dispatcher.finish = require('../events/dispatcher/finish.js');
|
||||
|
||||
fs.readdirSync(path.join(__dirname, 'funcs')).forEach(filename => {
|
||||
|
92
struct/config/messages.js
Normal file
92
struct/config/messages.js
Normal file
@ -0,0 +1,92 @@
|
||||
/*
|
||||
THIS FILE CONTAINS ALL MESSAGES THAT MUSIX SENDS!
|
||||
THIS IS MUSIX BRANDING AND YOU'RE NOT PERMITTED TO COPY ALL THE VISUALS FROM MUSIX!
|
||||
IF YOU CLONED THIS REPOSITORY PLEASE MODIFY THESE MESSAGES!
|
||||
*/
|
||||
module.exports = {
|
||||
restart: "restarted!",
|
||||
reloaded: "All files reloaded!",
|
||||
validNumber: "<:redx:674263474704220182> I\'m sorry, But you need to enter a valid __number__.",
|
||||
boolean: "<:redx:674263474704220182> Please define a boolean! (true/false)",
|
||||
correctUsage: "<:redx:674263474704220182> correct usage: ",
|
||||
wrongVoiceChannel: "<:redx:674263474704220182> I'm sorry but you need to be in the same voice channel as Musix to use this command!",
|
||||
noQuery: "<:redx:674263474704220182> You need to use a link or search for a song!",
|
||||
noResults: "<:redx:674263474704220182> I could not obtain any search results!",
|
||||
noServerQueue: "<:redx:674263474704220182> There is nothing playing!",
|
||||
noVoiceChannel: "<:redx:674263474704220182> I\'m sorry but you need to be in a voice channel to play music!",
|
||||
noDj: "<:redx:674263474704220182> You need the `DJ` role to use this command!",
|
||||
noPerms: `<:redx:674263474704220182> You need the %PERMS% permission to use this command!`,
|
||||
noPermsManageSettings: "<:redx:674263474704220182> You need the `MANAGE_SERVER` permission to change the settings!",
|
||||
noPermsEmbed: "<:redx:674263474704220182> I cannot send embeds (Embed links), make sure I have the proper permissions!",
|
||||
noPermsUseExternalEmojis: "<:redx:674263474704220182> I cannot use external emojis, make sure I have the proper permissions!",
|
||||
noPermsConnect: "<:redx:674263474704220182> I cannot connect to your voice channel, make sure I have the proper permissions!",
|
||||
noPermsSpeak: "<:redx:674263474704220182> I cannot speak in your voice channel, make sure I have the proper permissions!",
|
||||
noPermsManageRoles: "<:redx:674263474704220182> I cannot create roles (Manage roles), make sure I have the proper permissions! I will need this permission to create a `DJ` role since i did not find one!",
|
||||
notAllowed: "<:redx:674263474704220182> You are not allowed to do that!",
|
||||
devMode: "<:redx:674263474704220182> Dev mode has been turned on! Commands are only available to developer(s)!",
|
||||
error: "<:redx:674263474704220182> An error occured!",
|
||||
errorExe: "<:redx:674263474704220182> there was an error trying to execute that command! Please contact support with the \`bug\` command!",
|
||||
errorExeOpt: "<:redx:674263474704220182> there was an error trying to execute that option! Please contact support with the \`bug\` command!",
|
||||
errorConnecting: "Error with connecting to voice channel: ",
|
||||
errorDispatcher: "<:redx:674263474704220182> An error has occured while playing music! The queue has been deleted.",
|
||||
songAdded: "<:green_check_mark:674265384777416705> **%TITLE%** has been added to the queue!",
|
||||
playlistAdded: "<:green_check_mark:674265384777416705> Playlist: **%TITLE%** has been added to the queue!",
|
||||
startPlaying: "<a:aNotes:674602408105476106> Start playing: ",
|
||||
loadingSongs: "<a:loading:674284196700618783> Loading song(s)",
|
||||
prefixHere: "My prefix here is: ",
|
||||
prefixSet: "<:green_check_mark:674265384777416705> New prefix set to:",
|
||||
pinging: "<a:loading:674284196700618783> Pinging...",
|
||||
currentVolume: ":loud_sound: The current volume is: ",
|
||||
currentBass: ":loud_sound: The current bass is: ",
|
||||
maxVolume: "<:redx:674263474704220182> The max volume is `100`!",
|
||||
maxBass: "<:redx:674263474704220182> The max bass is `100`!",
|
||||
positiveVolume: "<:redx:674263474704220182> The volume needs to be a positive number!",
|
||||
positiveBass: "<:redx:674263474704220182> The bass needs to be a positive number!",
|
||||
setVolume: "<:volumehigh:674685637626167307> I set the volume to: ",
|
||||
bassApplied: "<:volumehigh:674685637626167307> The bass level **%BASS%** will be applied when the next song starts playing!",
|
||||
stop: "<:stop:674685626108477519> Stopped the music!",
|
||||
noSongs: "'<:redx:674263474704220182> That song does not exist!",
|
||||
cantSkipToCurrent: "<:redx:674263474704220182> You can\'t skip to the song currently playing!",
|
||||
skipped: "<:skip:674685614221688832> Skipped the song!",
|
||||
alreadyVoted: "<:redx:674263474704220182> You have already voted to skip!",
|
||||
notEnoughVotes: "<:redx:674263474704220182> Not enough votes!",
|
||||
shuffled: "<:shuffle:674685595980791871> Queue suffled!",
|
||||
seekingPointPositive: "<:redx:674263474704220182> The seeking point needs to be a positive number!",
|
||||
seekMax: "<:redx:674263474704220182> The lenght of this song is %LENGTH% seconds! You can't seek further than that!",
|
||||
songSelection: "__Song Selection__",
|
||||
nowPlaying: "__Now playing__",
|
||||
provideANumber: "Please provide a number ranging from 1-10 to select one of the search results.",
|
||||
cancellingVideoSelection: "'<:redx:674263474704220182> Cancelling video selection",
|
||||
notPaused: "<:redx:674263474704220182> The music in not paused!",
|
||||
alreadyPaused: "<:redx:674263474704220182> The music is already paused!",
|
||||
resumed: "<:resume:674685585478254603> Resumed the music!",
|
||||
paused: "<:pause:674685548610322462> Paused the music!",
|
||||
provideASong: "<:redx:674263474704220182> Please provide a song position in queue for me to remove!",
|
||||
queueLength: "<:redx:674263474704220182> There are only %SONGS% amount of songs in the queue!",
|
||||
removed: "🗑️ removed \`%SONG%\` from the queue!",
|
||||
loopingSong: "<:repeatsong:674685573419761716> Looping **%TITLE%** now!",
|
||||
noLoopingSong: "<:repeatsong:674685573419761716> No longer looping the song!",
|
||||
looping: "<:repeat1:674685561377914892> Looping the queue now!",
|
||||
noLooping: "<:repeat1:674685561377914892> No longer looping the queue!",
|
||||
joined: "<:green_check_mark:674265384777416705> Joined",
|
||||
queueDeleted: "Queue deleted!",
|
||||
bug: "Matte#0002\nOr join the support server: https://discord.gg/rvHuJtB",
|
||||
currentDefaultVolume: ":speaker: Current default volume is:",
|
||||
defaultVolumeNumber: "<:redx:674263474704220182> I\'m sorry, But the default volume needs to be a valid __number__.",
|
||||
defaultVolumeMax: "<:redx:674263474704220182> The default volume must be below `100` for quality and safety resons.",
|
||||
defaultVolumeSet: "<:green_check_mark:674265384777416705> Default volume set to:",
|
||||
djRoleFound: "<:green_check_mark:674265384777416705> I found a `DJ` role from this guild! This role is now the DJ role.",
|
||||
djRoleCreated: "<:green_check_mark:674265384777416705> I did not find a role `DJ` so i have created one for you!",
|
||||
djFalse: "<:green_check_mark:674265384777416705> `DJ` now set to `false`",
|
||||
reset: "<:green_check_mark:674265384777416705> Reset __all__ guild settings!",
|
||||
permission: "🔒 Permission requirement:",
|
||||
permissionsSetTrue: "<:green_check_mark:674265384777416705> Permissions requirement now set to: \`true\`",
|
||||
permissionsTrue: "<:redx:674263474704220182> That value is already `true`!",
|
||||
permissionsSetFalse: "<:green_check_mark:674265384777416705> Permissions requirement now set to: \`false\`",
|
||||
permissionsFalse: "<:redx:674263474704220182> That value is already `false`!",
|
||||
currentDefaultBass: ":speaker: Currect default bass level:",
|
||||
bassFalse: "<:green_check_mark:674265384777416705> Bass is now false!",
|
||||
bassLevel: "<:green_check_mark:674265384777416705> Bass level is now",
|
||||
announceSongsFalse: "<:green_check_mark:674265384777416705> announcesongs now set to `false`!",
|
||||
announceSongsTrue: "<:green_check_mark:674265384777416705> announcesongs now set to `true`!"
|
||||
};
|
@ -1,17 +1,18 @@
|
||||
module.exports = function (client, msg, command) {
|
||||
const serverQueue = client.queue.get(msg.guild.id);
|
||||
const permissions = msg.channel.permissionsFor(msg.author);
|
||||
if (!serverQueue || !serverQueue.playing) return msg.channel.send('<:redx:674263474704220182> There is nothing playing!');
|
||||
if (!serverQueue || !serverQueue.playing) return msg.channel.send(client.messages.noServerQueue);
|
||||
if (msg.author.id !== client.config.devId) {
|
||||
if (msg.member.voice.channel !== serverQueue.voiceChannel) return msg.channel.send(`<:redx:674263474704220182> I'm sorry but you need to be in the same voice channel as Musix to use this command!`);
|
||||
if (msg.member.voice.channel !== serverQueue.voiceChannel) return msg.channel.send(client.messages.wrongVoiceChannel);
|
||||
if (client.global.db.guilds[msg.guild.id].permissions === true) {
|
||||
if (client.global.db.guilds[msg.guild.id].dj) {
|
||||
if (!msg.member.roles.cache.has(client.global.db.guilds[msg.guild.id].djrole)) {
|
||||
msg.channel.send('<:redx:674263474704220182> You need the `DJ` role to use this command!');
|
||||
msg.channel.send(client.messages.noDj);
|
||||
return false;
|
||||
} else return true;
|
||||
} else if (!permissions.has(command.permission)) {
|
||||
msg.channel.send(`<:redx:674263474704220182> You need the \`${command.permission}\` permission to use this command!`);
|
||||
client.messages.noPerms = client.messages.noPerms.replace("%PERMS%", commands.permissions);
|
||||
msg.channel.send(client.messages.noPerms);
|
||||
return false;
|
||||
} else return true;
|
||||
} else return true;
|
||||
|
@ -1,13 +1,13 @@
|
||||
module.exports = function (msg, args, client, Discord, prefix, command) {
|
||||
const permissions = msg.channel.permissionsFor(msg.client.user);
|
||||
if (!permissions.has('EMBED_LINKS')) return msg.channel.send('<:redx:674263474704220182> I cannot send embeds (Embed links), make sure I have the proper permissions!');
|
||||
if (!permissions.has('USE_EXTERNAL_EMOJIS')) return msg.channel.send('<:redx:674263474704220182> I cannot use external emojis, make sure I have the proper permissions!');
|
||||
if (!permissions.has('EMBED_LINKS')) return msg.channel.send(client.messages.noPermsEmbed);
|
||||
if (!permissions.has('USE_EXTERNAL_EMOJIS')) return msg.channel.send(client.noPermsUseExternalEmojis);
|
||||
try {
|
||||
command.uses++;
|
||||
command.execute(msg, args, client, Discord, prefix, command);
|
||||
} catch (error) {
|
||||
const date = new Date();
|
||||
msg.reply(`<:redx:674263474704220182> there was an error trying to execute that command! Please contact support with \`${prefix}bug\`!`);
|
||||
msg.reply(client.messages.errorExe);
|
||||
const embed = new Discord.MessageEmbed()
|
||||
.setTitle(`Musix ${error.toString()}`)
|
||||
.setDescription(error.stack.replace(/at /g, '**at **'))
|
||||
|
@ -12,7 +12,8 @@ module.exports = async function (video, msg, voiceChannel, client, playlist = fa
|
||||
if (serverQueue) {
|
||||
serverQueue.songs.push(song);
|
||||
if (playlist) return;
|
||||
return msg.channel.send(`<:green_check_mark:674265384777416705> **${song.title}** has been added to the queue!`);
|
||||
client.messages.songsAdded = client.messages.songAdded.replace("%TITLE%", song.title);
|
||||
return msg.channel.send(client.messages.songAdded);
|
||||
}
|
||||
|
||||
const construct = require("../config/queueConfig.js");
|
||||
@ -32,8 +33,8 @@ module.exports = async function (video, msg, voiceChannel, client, playlist = fa
|
||||
client.funcs.play(msg.guild, construct.songs[0], client, 0, true);
|
||||
} catch (error) {
|
||||
client.queue.delete(msg.guild.id);
|
||||
client.debug_channel.send("Error with connecting to voice channel: " + error);
|
||||
return msg.channel.send(`<:redx:674263474704220182> An error occured: ${error}`);
|
||||
client.debug_channel.send(client.messages.errorConnecting + error);
|
||||
return msg.channel.send(client.messages.error);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
@ -22,7 +22,7 @@ module.exports = async function (guild, song, client, seek, play) {
|
||||
client.debug_channel.send('Error with the dispatcher: ' + error);
|
||||
serverQueue.voiceChannel.leave();
|
||||
client.queue.delete(guild.id);
|
||||
return serverQueue.textChannel.send('<:redx:674263474704220182> An error has occured while playing music! The queue has been deleted.');
|
||||
return serverQueue.textChannel.send(client.messages.errorDispatcher);
|
||||
});
|
||||
dispatcher.setVolume(serverQueue.volume / 10);
|
||||
if (client.global.db.guilds[guild.id].startPlaying || play) {
|
||||
@ -30,7 +30,7 @@ module.exports = async function (guild, song, client, seek, play) {
|
||||
const songtime = (data.length_seconds * 1000).toFixed(0);
|
||||
const thumbnail = getThumb(serverQueue.songs[0].url);
|
||||
const embed = new Discord.MessageEmbed()
|
||||
.setTitle(`<a:aNotes:674602408105476106> Start playing: **${song.title}**`)
|
||||
.setTitle(`${client.messages.startPlaying}**${song.title}**`)
|
||||
.setDescription(`Song duration: \`${client.funcs.msToTime(songtime, "hh:mm:ss")}\``)
|
||||
.setThumbnail(thumbnail._rejectionHandler0)
|
||||
.setColor(client.config.embedColor)
|
||||
|
@ -1,16 +1,16 @@
|
||||
module.exports = async function (client, msg, youtube, voiceChannel, url) {
|
||||
if (url.match(/^https?:\/\/(www.youtube.com|youtube.com)\/playlist(.*)$/)) {
|
||||
const lmsg = await msg.channel.send('<a:loading:674284196700618783> Loading song(s)');
|
||||
const lmsg = await msg.channel.send(client.messages.loadingSongs);
|
||||
const playlist = await youtube.getPlaylist(url);
|
||||
const videos = await playlist.getVideos();
|
||||
for (const video of Object.values(videos)) {
|
||||
const video2 = await youtube.getVideoByID(video.id);
|
||||
await client.funcs.handleVideo(video2, msg, voiceChannel, client, true);
|
||||
}
|
||||
lmsg.edit(`<:green_check_mark:674265384777416705> Playlist: **${playlist.title}** has been added to the queue!`);
|
||||
client.messages.playlistAdded = client.messages.playlistAdded.replace("%TITLE%", playlist.title);
|
||||
lmsg.edit(client.messages.playlistAdded);
|
||||
return true;
|
||||
} else {
|
||||
console.log('return false')
|
||||
return false;
|
||||
}
|
||||
};
|
Loading…
Reference in New Issue
Block a user