aboutsummaryrefslogtreecommitdiff
path: root/src/commands
diff options
context:
space:
mode:
authorAlee <alee14498@gmail.com>2018-03-24 17:35:34 -0400
committerAlee <alee14498@gmail.com>2018-03-24 17:35:34 -0400
commit53e984dc1f1673a162da1d93a3f3a24c1ea54c34 (patch)
tree44801ab0f4ebf727f9c5a919346fb9ea51d0e0f9 /src/commands
parent2835e99139b8b26cae599a73dc7ad4fd85913799 (diff)
downloadAleeBot-53e984dc1f1673a162da1d93a3f3a24c1ea54c34.tar.gz
AleeBot-53e984dc1f1673a162da1d93a3f3a24c1ea54c34.tar.bz2
AleeBot-53e984dc1f1673a162da1d93a3f3a24c1ea54c34.zip
2.2.0 stuff
Diffstat (limited to 'src/commands')
-rw-r--r--src/commands/changelog.js8
-rw-r--r--src/commands/help.js2
-rw-r--r--src/commands/play.js68
3 files changed, 73 insertions, 5 deletions
diff --git a/src/commands/changelog.js b/src/commands/changelog.js
index 0fff14a..0095517 100644
--- a/src/commands/changelog.js
+++ b/src/commands/changelog.js
@@ -1,10 +1,10 @@
module.exports.run = async (client, message) => {
const Discord = require('discord.js');
const embed = new Discord.RichEmbed()
- .setAuthor('AleeBot ' + '2.1.0 Beta ' + 'Changelog', 'https://cdn.discordapp.com/avatars/282547024547545109/6c147a444ae328c38145ef1f74169e38.png?size=2048')
- .setDescription('What\'s new in AleeBot 2.1 Beta?')
- .addField('! Coming soon music commands!', true)
- .addField('! Coming soon moderation commands!', true)
+ .setAuthor('AleeBot ' + '2.2.0 Beta ' + 'Changelog', 'https://cdn.discordapp.com/avatars/282547024547545109/6c147a444ae328c38145ef1f74169e38.png?size=2048')
+ .setDescription('What\'s new in AleeBot 2.2 Beta?')
+ .addField('[!] Coming soon music commands!', true)
+ .addField('[!] Coming soon moderation commands!', true)
.addField('And even more!', true)
.setFooter('AleeCorp Copyright 2017')
.setColor('#1fd619');
diff --git a/src/commands/help.js b/src/commands/help.js
index 27add92..40e4f19 100644
--- a/src/commands/help.js
+++ b/src/commands/help.js
@@ -11,7 +11,7 @@ module.exports.run = async (client, message) => {
const embed = new Discord.RichEmbed()
.setTitle('AleeBot Help')
- .setAuthor('AleeBot 2.1.0' + ` Help and on ${client.guilds.size} servers`, 'https://cdn.discordapp.com/avatars/282547024547545109/6c147a444ae328c38145ef1f74169e38.png?size=2048')
+ .setAuthor('AleeBot 2.2.0 Beta' + ` Help and on ${client.guilds.size} servers`, 'https://cdn.discordapp.com/avatars/282547024547545109/6c147a444ae328c38145ef1f74169e38.png?size=2048')
.setDescription('Every command you input into AleeBot is `' + require('../absettings.json').prefix + '`')
.setColor('#1fd619')
.setFooter('AleeCorp Copyright 2018');
diff --git a/src/commands/play.js b/src/commands/play.js
new file mode 100644
index 0000000..a53a8de
--- /dev/null
+++ b/src/commands/play.js
@@ -0,0 +1,68 @@
+module.exports.run = async (client, message, args) => {
+if (!args[0]) return await message.channel.createMessage('A name of the song of a link is needed.');
+if (!message.member.voiceState.channelID) return await message.channel.createMessage('You are not in a voice channel');
+const YouTube = require('simple-youtube-api');
+const moment = require('moment');
+const youtube = new YouTube(process.env.GOOGLE);
+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);
+ });
+ });
+ });
+async function YTVideo(video) {
+ if (video.durationSeconds === 0) {
+ return message.channel.createMessage('Live streams are not available');
+ }
+ const d = moment.duration({
+ s: video.durationSeconds
+ });
+
+ const server = bot.MusicVariables(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 embed = new bot.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)
+ .setFootor('Beat Music Player');
+ await message.channel.createMessage({embed});
+ if (!bot.voiceConnections.get(message.member.guild.id))
+ bot.joinVoiceChannel(message.member.voiceState.channelID).then(function(connection) {
+ //Pass the song into the music handler
+ bot.playYT(connection, message);
+ });
+ return null;
+}};
+
+exports.conf = {
+ aliases: [],
+ guildOnly: false,
+};
+exports.help = {
+ name: 'play',
+ description: 'Plays music',
+ usage: 'play [args]',
+ category: '- Music Commands',
+};