diff options
| author | Alee <alee14498@gmail.com> | 2018-03-29 15:24:11 -0400 |
|---|---|---|
| committer | Alee <alee14498@gmail.com> | 2018-03-29 15:24:11 -0400 |
| commit | 322bf0ae247eaed29e62953ae4274612f694de92 (patch) | |
| tree | 86c7952c07f99b5ff3647fb700ef59b4dd7050d7 | |
| parent | 70826e2aad2e18ef9dc533b81e302678eecfe3ee (diff) | |
| download | AleeBot-322bf0ae247eaed29e62953ae4274612f694de92.tar.gz AleeBot-322bf0ae247eaed29e62953ae4274612f694de92.tar.bz2 AleeBot-322bf0ae247eaed29e62953ae4274612f694de92.zip | |
It's not the music commands fault :/
| -rw-r--r-- | bot_discord.js | 2 | ||||
| -rw-r--r-- | commands/play.js | 95 | ||||
| -rw-r--r-- | music.js | 92 |
3 files changed, 188 insertions, 1 deletions
diff --git a/bot_discord.js b/bot_discord.js index ce451be..2d9a488 100644 --- a/bot_discord.js +++ b/bot_discord.js @@ -31,7 +31,7 @@ const fs = require('fs'); const config = require('./absettings.json');
console.log('Welcome to AleeBot NodeJS Terminal!');
-// client.apikey = config.ytapikey;
+client.apikey = config.ytapikey;
client.commands = new Discord.Collection();
client.aliases = new Discord.Collection();
client.servers = {};
diff --git a/commands/play.js b/commands/play.js new file mode 100644 index 0000000..cab6329 --- /dev/null +++ b/commands/play.js @@ -0,0 +1,95 @@ +/******************************** + * + * Play: Command for AleeBot + * + * Copyright (c) 2018 AleeCorp & jtsshieh + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in all + * copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + ********************************/ +module.exports.run = async (client, message, args) => { + if (!args[0]) return await message.channel.send('A name of the song of a link is needed.'); + if (!message.member.voiceChannelID) return await message.channel.send('You are not in a voice channel'); + const YouTube = require('simple-youtube-api'); + const moment = require('moment'); + const youtube = new YouTube(client.apikey); + const url = args.join(' ').replace(/<(.+)>/g, '$1'); + if (!url) return; + await youtube.getVideo(url) + .then(results => { + YTVideo(results); + }) + .catch(() => { + youtube.searchVideos(args.join(' '), 1) + .then(results => { + youtube.getVideo(results[0].url) + .then(vid => { + YTVideo(vid); + }); + }); + }); + + const music = require('../music.js'); + async function YTVideo(video) { + if (video.durationSeconds === 0) { + return message.channel.send('Live streams are not available'); + } + const d = moment.duration({ + s: video.durationSeconds + }); + + const server = music.MusicVariables(client, message.member.guild.id); + const time = moment().startOf('day').add(d).format('HH:mm:ss'); + server.queue.push({ + url: video.url, + title: video.title, + thumbnail: video.thumbnails.high.url, + duration: video.durationSeconds, + requested: message.author.mention, + playing: false + }); + const { RichEmbed } = require('discord.js'); + + const embed = new RichEmbed() + .setTitle('A song has been queued') + .setAuthor(video.title, video.thumbnails.high.url) + .setColor(0x00afff) + .setTimestamp() + .addField('Title', video.title) + .addField('Link', video.url) + .addField('Duration', time) + .setThumbnail(video.thumbnails.high.url) + .setFooter('AleeBot Music Player'); + await message.channel.send({embed}); + if (!client.voiceConnections.get(message.member.guild.id)) + message.member.voiceChannel.join().then(function(connection) { + music.playYT(client, connection, message); + }); + return null; + }}; + +exports.conf = { + aliases: [], + guildOnly: true, +}; +exports.help = { + name: 'play', + description: 'Plays music', + usage: 'play [args]', + category: '- Music Commands', +}; diff --git a/music.js b/music.js new file mode 100644 index 0000000..a4e0b90 --- /dev/null +++ b/music.js @@ -0,0 +1,92 @@ +/******************************** + * + * Music: Plugin for AleeBot + * + * Copyright (c) 2018 AleeCorp & jtsshieh + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in all + * copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + ********************************/ +// Created by jtsshieh#6434 in the BonGon project: https://github.com/jtsshieh/BonGon + +const YTDL = require('ytdl-core'); +module.exports.playYT = async (bot, connection, msg) => { + const EventEmitter = require('events'); + class MyEmitter extends EventEmitter {} + bot.musicEmit = new MyEmitter(); + + const musicvariables = require('./music.js').MusicVariables; + const server = musicvariables(bot, msg.member.guild.id); + + server.dispatcher = connection; + + connection.playStream(YTDL(server.queue[0].url, { + filter: 'audioonly' + })); + + server.nowPlaying = server.queue[0]; + server.beforeNowPlaying = server.nowPlaying; + + + server.queue.shift(); + + server.nowPlaying.playing = true; + + let time = 0; + let counter = setInterval( + function() { + time = time + 1; + server.dispatcher.time = time; + }, 1000); + + bot.musicEmit.on('paused', () => { + clearInterval(counter); + }); + + bot.musicEmit.on('resumed',() =>{ + counter = setInterval( + function() { + time = time + 1; + server.dispatcher.time = time; + }, 1000); + }); + + connection.once('end', function() { + clearInterval(counter); + + if (server.queue[0] || server.beforeNowPlaying) { + if (server.repeat) { + server.queue.push(server.beforeNowPlaying); + } + + server.nowPlaying = null; + bot.playYT(connection, msg); + } + + else { + bot.leaveVoiceChannel(connection.channelID); + bot.servers[msg.member.guild.id] = null; + } + }); +}; +module.exports.MusicVariables = (bot, guildID) => { + if (!bot.servers[guildID]) { + bot.servers[guildID] = {'queue' : [], 'dispatcher': null, 'repeat': false}; + } + return bot.servers[guildID]; +}; |
