diff options
| author | Alee <alee14498@gmail.com> | 2018-03-24 17:35:34 -0400 |
|---|---|---|
| committer | Alee <alee14498@gmail.com> | 2018-03-24 17:35:34 -0400 |
| commit | 53e984dc1f1673a162da1d93a3f3a24c1ea54c34 (patch) | |
| tree | 44801ab0f4ebf727f9c5a919346fb9ea51d0e0f9 | |
| parent | 2835e99139b8b26cae599a73dc7ad4fd85913799 (diff) | |
| download | AleeBot-53e984dc1f1673a162da1d93a3f3a24c1ea54c34.tar.gz AleeBot-53e984dc1f1673a162da1d93a3f3a24c1ea54c34.tar.bz2 AleeBot-53e984dc1f1673a162da1d93a3f3a24c1ea54c34.zip | |
2.2.0 stuff
| -rw-r--r-- | src/bot_discord.js | 4 | ||||
| -rw-r--r-- | src/commands/changelog.js | 8 | ||||
| -rw-r--r-- | src/commands/help.js | 2 | ||||
| -rw-r--r-- | src/commands/play.js | 68 |
4 files changed, 75 insertions, 7 deletions
diff --git a/src/bot_discord.js b/src/bot_discord.js index f195e73..d6ade60 100644 --- a/src/bot_discord.js +++ b/src/bot_discord.js @@ -7,8 +7,8 @@ **********************************************/
const Discord = require('discord.js');
const client = new Discord.Client();
-const abVersion = '2.1.0';
-const prefix = 'ab:';
+const abVersion = '2.2.0 Beta';
+const prefix = 'abb:';
const fs = require('fs');
const config = require('./absettings.json');
console.log('Welcome to AleeBot NodeJS Terminal!');
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', +}; |
