1
0
mirror of https://github.com/musix-org/musix-oss synced 2024-12-23 00:23:17 +00:00

Update index.js

This commit is contained in:
MatteZ02 2019-07-10 13:11:50 +03:00
parent 6a1d049938
commit ad3a5c751d

View File

@ -5,7 +5,7 @@ const ytdl = require('ytdl-core');
const GOOGLE_API_KEY = (process.env.API_KEY) const GOOGLE_API_KEY = (process.env.API_KEY)
const PREFIX = ('-') const PREFIX = ('-')
const client = new Client({ disableEveryone: true }); const client = new Client({ disableEveryone: true });
const youtube = new YouTube(GOOGLE_API_KEY); const youtube = new YouTube('AIzaSyBPFfx6Kq2Nvn9lpB_M2T2Y6V2N-8K9Uvo');
const queue = new Map(); const queue = new Map();
client.on('ready', () => { client.on('ready', () => {
client.user.setActivity('-help', { type: 'LISTENING' }) client.user.setActivity('-help', { type: 'LISTENING' })
@ -253,6 +253,7 @@ Please provide a value to select one of the search results ranging from 1-10.
const videoIndex = parseInt(response.first().content); const videoIndex = parseInt(response.first().content);
var video = await youtube.getVideoByID(videos[videoIndex - 1].id); var video = await youtube.getVideoByID(videos[videoIndex - 1].id);
} catch (err) { } catch (err) {
console.error(err);
return msg.channel.send(':x: I could not obtain any search results.'); return msg.channel.send(':x: I could not obtain any search results.');
} }
} }
@ -314,6 +315,7 @@ Please provide a value to select one of the search results ranging from 1-10.
return undefined; return undefined;
} }
}); });
async function handleVideo(video, msg, voiceChannel, playlist = false) { async function handleVideo(video, msg, voiceChannel, playlist = false) {
const serverQueue = queue.get(msg.guild.id); const serverQueue = queue.get(msg.guild.id);
const song = { const song = {
@ -331,12 +333,15 @@ async function handleVideo(video, msg, voiceChannel, playlist = false) {
playing: true playing: true
}; };
queue.set(msg.guild.id, queueConstruct); queue.set(msg.guild.id, queueConstruct);
queueConstruct.songs.push(song); queueConstruct.songs.push(song);
try { try {
var connection = await voiceChannel.join(); var connection = await voiceChannel.join();
queueConstruct.connection = connection; queueConstruct.connection = connection;
play(msg.guild, queueConstruct.songs[0]); play(msg.guild, queueConstruct.songs[0]);
} catch (error) { } catch (error) {
console.error(`I could not join the voice channel: ${error}`);
queue.delete(msg.guild.id); queue.delete(msg.guild.id);
return msg.channel.send(`:x: I could not join the voice channel: ${error}`); return msg.channel.send(`:x: I could not join the voice channel: ${error}`);
} }
@ -347,23 +352,28 @@ async function handleVideo(video, msg, voiceChannel, playlist = false) {
} }
return undefined; return undefined;
} }
function play(guild, song) { function play(guild, song) {
const serverQueue = queue.get(guild.id); const serverQueue = queue.get(guild.id);
if (!song) { if (!song) {
serverQueue.voiceChannel.leave(); serverQueue.voiceChannel.leave();
queue.delete(guild.id); queue.delete(guild.id);
return; return;
} }
const dispatcher = serverQueue.connection.playStream(ytdl(song.url, { quality: `highestaudio`, filter: 'audioonly' })) const dispatcher = serverQueue.connection.playStream(ytdl(song.url, { quality: `highestaudio`, filter: 'audioonly' }))
.on('end', reason => { .on('end', reason => {
if (reason === 'Stream is not generating quickly enough.') if (reason === 'Stream is not generating quickly enough.') console.log('Song ended.');
else msg.channel.send(reason); else msg.channel.send(reason);
serverQueue.songs.shift(); serverQueue.songs.shift();
play(guild, serverQueue.songs[0]); play(guild, serverQueue.songs[0]);
}) })
.on('error', error => msg.channel.send(error)); .on('error', error => console.error(error));
dispatcher.setVolumeLogarithmic(1 / 5); dispatcher.setVolumeLogarithmic(1 / 5);
serverQueue.volume = 1 serverQueue.volume = 1
serverQueue.textChannel.send(`:musical_note: Start playing: **${song.title}**`); serverQueue.textChannel.send(`:musical_note: Start playing: **${song.title}**`);
} }
client.login(process.env.BOT_TOKEN);
client.login('NTcyNDA1MTM1NjU4MTg4ODAw.XSW4cQ.i_Q6xGM6oIsqxs1oMnIazIcjRBY');