aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlee <alee14498@gmail.com>2018-03-29 15:24:11 -0400
committerAlee <alee14498@gmail.com>2018-03-29 15:24:11 -0400
commit322bf0ae247eaed29e62953ae4274612f694de92 (patch)
tree86c7952c07f99b5ff3647fb700ef59b4dd7050d7
parent70826e2aad2e18ef9dc533b81e302678eecfe3ee (diff)
downloadAleeBot-322bf0ae247eaed29e62953ae4274612f694de92.tar.gz
AleeBot-322bf0ae247eaed29e62953ae4274612f694de92.tar.bz2
AleeBot-322bf0ae247eaed29e62953ae4274612f694de92.zip
It's not the music commands fault :/
-rw-r--r--bot_discord.js2
-rw-r--r--commands/play.js95
-rw-r--r--music.js92
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];
+};