1
0
mirror of https://github.com/musix-org/musix-oss synced 2025-01-09 12:04:49 +00:00

Update 3.6

This commit is contained in:
MatteZ02 2020-06-09 21:25:55 +03:00
parent a0662fdf90
commit 635d7953b2
9 changed files with 96 additions and 22 deletions

View File

@ -1,6 +1,6 @@
{ {
"name": "musix", "name": "musix",
"version": "3.5.2", "version": "3.6.0",
"description": "V3 for Musix the discord music bot", "description": "V3 for Musix the discord music bot",
"main": "./index.js", "main": "./index.js",
"scripts": { "scripts": {
@ -37,11 +37,11 @@
"node-spotify-api": "^1.1.1", "node-spotify-api": "^1.1.1",
"prism-media": "github:hydrabolt/prism-media", "prism-media": "github:hydrabolt/prism-media",
"request": "^2.88.2", "request": "^2.88.2",
"similar-songs": "^0.1.3",
"simple-youtube-api": "^5.2.1", "simple-youtube-api": "^5.2.1",
"soundcloud-api-client": "0.0.9", "soundcloud-api-client": "0.0.9",
"spotify-web-api-node": "^4.0.0", "spotify-web-api-node": "^4.0.0",
"utf-8-validate": "^5.0.2", "utf-8-validate": "^5.0.2",
"video-thumbnail-url": "^1.0.1",
"yt-search": "^1.1.2", "yt-search": "^1.1.2",
"ytdl-core": "^3.1.0", "ytdl-core": "^3.1.0",
"zlib-sync": "^0.1.6" "zlib-sync": "^0.1.6"

View File

@ -7,41 +7,39 @@ module.exports = {
permission: "none", permission: "none",
category: "music", category: "music",
async execute(msg, args, client, Discord, command) { async execute(msg, args, client, Discord, command) {
const getThumb = require("video-thumbnail-url");
const queue = client.queue.get(msg.guild.id); const queue = client.queue.get(msg.guild.id);
if (!queue) return msg.channel.send(client.messages.noServerQueue); if (!queue) return msg.channel.send(client.messages.noServerQueue);
let songTime = (queue.songs[0].songLength * 1000).toFixed(0); let songTime = (queue.songs[0].info.lengthSeconds * 1000).toFixed(0);
let completed = ( let completed = (
queue.connection.dispatcher.streamTime + queue.time queue.connection.dispatcher.streamTime + queue.time
).toFixed(0); ).toFixed(0);
let barlength = 20; let barlength = 30;
let completedpercent = ((completed / songTime) * barlength).toFixed(0); let completedpercent = ((completed / songTime) * barlength).toFixed(0);
let array = []; let array = [];
for (let i = 0; i < completedpercent - 1; i++) { for (let i = 0; i < completedpercent - 1; i++) {
array.push("⎯"); array.push("⎯");
} }
array.push(""); array.push("🔘");
for (let i = 0; i < barlength - completedpercent - 1; i++) { for (let i = 0; i < barlength - completedpercent - 1; i++) {
array.push("⎯"); array.push("⎯");
} }
const thumbnail = getThumb(queue.songs[0].url);
const embed = new Discord.MessageEmbed() const embed = new Discord.MessageEmbed()
.setTitle(client.messages.nowPlaying) .setTitle(client.messages.nowPlaying)
.setDescription( .setDescription(
`${client.messages.nowPlayingDesc} ${ `${client.messages.nowPlayingDesc} ${
queue.songs[0].title queue.songs[0].title
}\n${array.join("")} | \`${client.funcs.msToTime( }\n\`${array.join("")}\`\n\`${client.funcs.msToTime(
completed, completed,
"hh:mm:ss" "hh:mm:ss"
)} / ${client.funcs.msToTime(songTime, "hh:mm:ss")}\`\nchannel: \`${queue.songs[0].channel.name}\`` )} / ${client.funcs.msToTime(songTime, "hh:mm:ss")}\`\nchannel: \`${queue.songs[0].info.author.name}\``
) )
.setFooter(`Queued by ${queue.songs[0].author.tag}`) .setFooter(`Queued by ${queue.songs[0].author.tag}`)
.setURL(queue.songs[0].url) .setURL(queue.songs[0].url)
.setThumbnail(thumbnail._rejectionHandler0) .setThumbnail(queue.songs[0].info.thumbnail.thumbnails[4].url)
.setColor(client.config.embedColor); .setColor(client.config.embedColor);
if (queue.nigthCore) if (queue.nigthCore)
embed.setDescription( embed.setDescription(
`${client.messages.nowPlayingDesc} ${queue.songs[0].title} \nchannel: \`${queue.songs[0].channel.name}\`` `${client.messages.nowPlayingDesc} ${queue.songs[0].title} \nchannel: \`${queue.songs[0].info.author.name}\``
); );
return msg.channel.send(embed); return msg.channel.send(embed);
}, },

View File

@ -43,11 +43,9 @@ module.exports = {
if (!voiceChannel.speakable) if (!voiceChannel.speakable)
return msg.channel.send(client.messages.noPermsSpeak); return msg.channel.send(client.messages.noPermsSpeak);
if (ytdl.validateURL(url)) { if (ytdl.validateURL(url)) {
const resource = { client.funcs.handleVideo({
url: url url: url
} },
client.funcs.handleVideo(
resource,
msg, msg,
voiceChannel, voiceChannel,
client, client,
@ -81,8 +79,7 @@ module.exports = {
"ytdl" "ytdl"
); );
} }
let message; const message = client.messages.playlistAdded.replace(
message = client.messages.playlistAdded.replace(
"%TITLE%", "%TITLE%",
playlist.title playlist.title
); );

View File

@ -0,0 +1,65 @@
const similarSongs = require("similar-songs");
module.exports = {
name: "searchsimilar",
alias: ["none"],
usage: "<song name>, <artist>",
description: "a command to search similar songs (in developement)",
onlyDev: false,
permission: "none",
category: "music",
async execute(msg, args, client, Discord, command) {
const searchString = args.slice(1).join(" ");
const query = searchString.split(",");
const queue = client.queue.get(msg.guild.id);
const voiceChannel = msg.member.voice.channel;
if (
client.global.db.guilds[msg.guild.id].blacklist.includes(
msg.member.voice.channelID
)
)
return msg.channel.send(client.messages.blackListedVC);
if (!queue) {
if (!msg.member.voice.channel)
return msg.channel.send(client.messages.noVoiceChannel);
} else {
if (voiceChannel !== queue.voiceChannel)
return msg.channel.send(client.messages.wrongVoiceChannel);
}
if (!query[0] || !query[1]) {
const message = client.messages.searchSimilarUsage.replace("%USAGE%", command.usage);
return msg.channel.send(message);
}
if (voiceChannel.full) return msg.channel.send(client.messages.channelFull);
if (!voiceChannel.joinable)
return msg.channel.send(client.messages.noPermsConnect);
if (!voiceChannel.speakable)
return msg.channel.send(client.messages.noPermsSpeak);
similarSongs.find({
title: query[0],
artist: query[1].slice(1),
limit: 10,
lastfmAPIKey: client.config.lastfm_api_key,
lastfmAPISecret: client.config.lastfm_secret,
youtubeAPIKey: client.config.api_key,
},
async function (err, songs) {
if (err) return msg.channel.send(err.message);
if (songs.length !== 0) {
const lmsg = await msg.channel.send(client.messages.loadingSongs);
for (let i = 0; i < songs.length; i++) {
client.funcs.handleVideo({
url: `https://www.youtube.com/watch?v=${songs[i].youtubeId}`
}, msg, voiceChannel, client, true, "ytdl");
}
const message = client.messages.songsAdded.replace(
"%AMOUNT%",
songs.length
);
return lmsg.edit(message);
} else return msg.channel.send(client.messages.noSimilarResults);
}
);
},
};

View File

@ -9,11 +9,20 @@ module.exports = {
execute(msg, args, client, Discord, command) { execute(msg, args, client, Discord, command) {
const queue = client.queue.get(msg.guild.id); const queue = client.queue.get(msg.guild.id);
if (client.funcs.check(client, msg, command)) { if (client.funcs.check(client, msg, command)) {
if (msg.content.contains("-force")) {
if (queue) {
queue.voiceChannel.leave();
queue.exists = false;
}
if (msg.guild.voice.channel) msg.guild.voice.channel.leave();
client.queue.delete(guild.id);
return msg.channel.send(client.messages.stop);
}
queue.songs = []; queue.songs = [];
queue.looping = false; queue.looping = false;
queue.endReason = "stop"; queue.endReason = "stop";
queue.connection.dispatcher.end(); queue.connection.dispatcher.end();
msg.channel.send(client.messages.stop) msg.channel.send(client.messages.stop);
} }
} }
}; };

View File

@ -12,6 +12,8 @@ module.exports = {
spotify_client_secret: process.env.SPOTIFY_CLIENT_SECRET, spotify_client_secret: process.env.SPOTIFY_CLIENT_SECRET,
spotify_client_id: process.env.SPOTIFY_CLIENT_ID, spotify_client_id: process.env.SPOTIFY_CLIENT_ID,
spotify_refresh_token: process.env.SPOTIFY_REFRESH_TOKEN, spotify_refresh_token: process.env.SPOTIFY_REFRESH_TOKEN,
lastfm_api_key: process.env.LASTFM_API_KEY,
lastfm_secret: process.env.LASTFM_SECRET,
port: 8888, port: 8888,
redirectUri: "http://localhost:8888/callback/", redirectUri: "http://localhost:8888/callback/",
testServer: "489111553321336832", testServer: "489111553321336832",

View File

@ -1,6 +1,7 @@
const emojis = require("./emojis.js"); const emojis = require("./emojis.js");
module.exports = { module.exports = {
emojis: emojis,
alreadyPaused: emojis.redx + "The music is already paused!", alreadyPaused: emojis.redx + "The music is already paused!",
alreadyVoted: emojis.redx + "You have already voted to skip!", alreadyVoted: emojis.redx + "You have already voted to skip!",
announceSongs: emojis.megaPhone + "Current setting:", announceSongs: emojis.megaPhone + "Current setting:",
@ -100,6 +101,7 @@ module.exports = {
noResultsSpotify: emojis.redx + noResultsSpotify: emojis.redx +
"I could not obtain any results!", "I could not obtain any results!",
noServerQueue: emojis.redx + "There is nothing playing!", noServerQueue: emojis.redx + "There is nothing playing!",
noSimilarResults: emojis.redx + "No similar songs found!",
noSongs: emojis.redx + "That song does not exist!", noSongs: emojis.redx + "That song does not exist!",
noSongsInQueue: emojis.redx + "There are no songs in the queue!", noSongsInQueue: emojis.redx + "There are no songs in the queue!",
notPremium: emojis.redx + "This is not a premium guild!", notPremium: emojis.redx + "This is not a premium guild!",
@ -142,6 +144,7 @@ module.exports = {
reset: emojis.green_check_mark + "Reset __all__ guild settings!", reset: emojis.green_check_mark + "Reset __all__ guild settings!",
restart: "restarting all shards...", restart: "restarting all shards...",
resumed: emojis.resume + "Resumed the music!", resumed: emojis.resume + "Resumed the music!",
searchSimilarUsage: emojis.redx + "Correct usage: %USAGE%",
seekingPointPositive: emojis.redx + "The seeking point needs to be a positive number!", seekingPointPositive: emojis.redx + "The seeking point needs to be a positive number!",
seekMax: emojis.redx + seekMax: emojis.redx +
"The lenght of this song is %LENGTH% seconds! You can't seek further than that!", "The lenght of this song is %LENGTH% seconds! You can't seek further than that!",
@ -167,6 +170,7 @@ module.exports = {
songAdded: emojis.green_check_mark + "**%TITLE%** has been added to the queue!", songAdded: emojis.green_check_mark + "**%TITLE%** has been added to the queue!",
songBlockedWMG: emojis.redx + songBlockedWMG: emojis.redx +
"This song had been blocked by WMG (Warner Music Groud).\n<:skip:674685614221688832> Skipped to next song.", "This song had been blocked by WMG (Warner Music Groud).\n<:skip:674685614221688832> Skipped to next song.",
songsAdded: emojis.green_check_mark + "%AMOUNT% songs added to the queue!",
songSelection: "__Song Selection__", songSelection: "__Song Selection__",
startPlaying: emojis.notes + "Start playing: ", startPlaying: emojis.notes + "Start playing: ",
statusField1: emojis.signal + "Ping", statusField1: emojis.signal + "Ping",

View File

@ -14,9 +14,8 @@ module.exports = async function (
title: Discord.Util.escapeMarkdown(songInfo.videoDetails.title), title: Discord.Util.escapeMarkdown(songInfo.videoDetails.title),
url: resource.url, url: resource.url,
author: msg.author, author: msg.author,
songLength: songInfo.videoDetails.lengthSeconds,
type: type, type: type,
channel: songInfo.videoDetails.author info: songInfo.videoDetails
}; };
const queue = client.queue.get(msg.guild.id); const queue = client.queue.get(msg.guild.id);

View File

@ -80,7 +80,7 @@ module.exports = async function (guild, song, client, seek, play) {
const embed = new Discord.MessageEmbed() const embed = new Discord.MessageEmbed()
.setTitle(`${client.messages.startPlaying}**${song.title}**`) .setTitle(`${client.messages.startPlaying}**${song.title}**`)
.setDescription( .setDescription(
`Song duration: \`${client.funcs.msToTime(queue.songs[0].songLength * 1000, "hh:mm:ss")}\`` `Song duration: \`${client.funcs.msToTime(queue.songs[0].info.lengthSeconds * 1000, "hh:mm:ss")}\``
) )
.setColor(client.config.embedColor); .setColor(client.config.embedColor);
queue.textChannel.send(embed); queue.textChannel.send(embed);