forked from Supositware/Haha-Yes
replace sayd and downloadspoiler with flag
This commit is contained in:
parent
b6e4387c73
commit
4a169b3dae
4 changed files with 58 additions and 198 deletions
|
@ -15,10 +15,15 @@ class SayCommand extends Command {
|
|||
start: 'Write something so i can say it back',
|
||||
},
|
||||
match: 'rest'
|
||||
},
|
||||
{
|
||||
id: 'delete',
|
||||
match: 'flag',
|
||||
flag: ['--del', '--delete', '-d']
|
||||
}
|
||||
],
|
||||
description: {
|
||||
content: 'Repeat what you say, [Click here to see the complete list of "tag"](https://cdn.discordapp.com/attachments/502198809355354133/561043193949585418/unknown.png)',
|
||||
content: 'Repeat what you say, (Use "-d" to delete the message you sent) [Click here to see the complete list of "tag"](https://cdn.discordapp.com/attachments/502198809355354133/561043193949585418/unknown.png)',
|
||||
usage: '[text]',
|
||||
examples: ['[member] is a big [adverbs] [verbs]']
|
||||
}
|
||||
|
@ -134,16 +139,24 @@ class SayCommand extends Command {
|
|||
.setTimestamp();
|
||||
|
||||
if (attach) {
|
||||
if (args.delete)
|
||||
message.delete();
|
||||
return message.channel.send(embed, {files: [attach]});
|
||||
} else {
|
||||
if (args.delete)
|
||||
message.delete();
|
||||
return message.channel.send(embed);
|
||||
}
|
||||
}
|
||||
|
||||
// Send the final text
|
||||
if (attach) {
|
||||
if (args.delete)
|
||||
message.delete();
|
||||
return message.channel.send(text, {files: [attach]});
|
||||
} else {
|
||||
if (args.delete)
|
||||
message.delete();
|
||||
return message.channel.send(text);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,44 +0,0 @@
|
|||
const { Command } = require('discord-akairo');
|
||||
const rand = require('../../rand.js');
|
||||
|
||||
class SaydCommand extends Command {
|
||||
constructor() {
|
||||
super('sayd', {
|
||||
aliases: ['sayd'],
|
||||
category: 'general',
|
||||
clientPermissions: 'MANAGE_MESSAGES',
|
||||
args: [
|
||||
{
|
||||
id: 'text',
|
||||
type: 'string',
|
||||
prompt: {
|
||||
start: 'Write something so i can say it back',
|
||||
},
|
||||
match: 'rest'
|
||||
}
|
||||
],
|
||||
description: {
|
||||
content: 'Repeat what you say but delete the text you sent, [Click here to see the complete list of "tag"](https://cdn.discordapp.com/attachments/502198809355354133/561043193949585418/unknown.png)',
|
||||
usage: '[text]',
|
||||
examples: ['[member] is a big [adverbs] [verbs]']
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
async exec(message, args) {
|
||||
let text = args.text;
|
||||
if (!text)
|
||||
return;
|
||||
|
||||
text = rand.random(text, message);
|
||||
|
||||
// Send the final text
|
||||
message.delete();
|
||||
return message.util.send('===ANTI-SNIPE MESSAGE===')
|
||||
.then(() => {
|
||||
message.util.edit(text);
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = SaydCommand;
|
|
@ -21,11 +21,16 @@ class DownloadCommand extends Command {
|
|||
id: 'alt',
|
||||
match: 'flag',
|
||||
flag: '--alt'
|
||||
},
|
||||
{
|
||||
id: 'spoiler',
|
||||
match: 'flag',
|
||||
flag: ['--spoil', '--spoiler', '-s']
|
||||
}
|
||||
],
|
||||
clientPermissions: ['ATTACH_FILES'],
|
||||
description: {
|
||||
content: 'Download videos from different website from the link you provided',
|
||||
content: 'Download videos from different website from the link you provided ( use "-s" to make the vid a spoiler )',
|
||||
usage: '[link]',
|
||||
examples: ['https://www.youtube.com/watch?v=6n3pFFPSlW4']
|
||||
}
|
||||
|
@ -35,25 +40,37 @@ class DownloadCommand extends Command {
|
|||
async exec(message, args) {
|
||||
let link = args.link;
|
||||
let needCompress = false;
|
||||
let fileName;
|
||||
|
||||
if (args.spoiler) {
|
||||
fileName = 'SPOILER_video';
|
||||
} else {
|
||||
fileName = 'video';
|
||||
}
|
||||
|
||||
if (link.includes('http') || link.includes('www')) {
|
||||
if (args.alt) {
|
||||
console.log('alt download!');
|
||||
fs.unlink('./video.mp4', (err) => {
|
||||
if (err);
|
||||
});
|
||||
return youtubedl.exec(args.link, ['-o', './video.mp4'], {}, function(err, output) {
|
||||
if (fs.existsSync(`./${fileName}.mp4`)) {
|
||||
fs.unlink(`./${fileName}.mp4`, (err) => {
|
||||
if (err);
|
||||
});
|
||||
}
|
||||
return youtubedl.exec(args.link, ['-o', `./${fileName}.mp4`], {}, function(err, output) {
|
||||
if (err) throw err;
|
||||
console.log(output.join('\n'));
|
||||
message.delete();
|
||||
message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./video.mp4'] })
|
||||
.catch(() => message.channel.send('File too big'));
|
||||
message.channel.send(`Downloaded by ${message.author.username}`, { files: [`./${fileName}.mp4`] })
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
return message.channel.send('File too big');
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
let video = youtubedl(link, [`--username=${fbuser}`, `--password=${fbpasswd}`]);
|
||||
video.pipe(fs.createWriteStream('./video.mp4'));
|
||||
video.pipe(fs.createWriteStream(`./${fileName}.mp4`));
|
||||
video.on('error', function error(err) {
|
||||
console.log('error 2:', err);
|
||||
message.channel.send('An error has occured, I can\'t download from the link you provided.');
|
||||
|
@ -89,26 +106,31 @@ class DownloadCommand extends Command {
|
|||
video.on('end', function () {
|
||||
if (!needCompress) {
|
||||
message.delete();
|
||||
return message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./video.mp4'] })
|
||||
.catch(() => message.channel.send('File too big'));
|
||||
return message.channel.send(`Downloaded by ${message.author.username}`, { files: [`./${fileName}.mp4`] })
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
return message.channel.send('File too big');
|
||||
});
|
||||
}
|
||||
|
||||
const options = {
|
||||
input: 'video.mp4',
|
||||
output: 'videoReady.mp4',
|
||||
input: `${fileName}.mp4`,
|
||||
output: `${fileName}Ready.mp4`,
|
||||
preset: 'General/Gmail Small 10 Minutes 288p30'
|
||||
};
|
||||
|
||||
//Compress vid if bigger than 8MB
|
||||
let handbrake = hbjs.spawn(options);
|
||||
handbrake.on('start', function() {
|
||||
message.channel.send('Video bigger than 8MB compressing now <a:loadingmin:527579785212329984> (This can take a long time!)\nWant it to go faster? Donate to the dev with the donate command, so i can get a better server and do it faster!').then(msg => {
|
||||
handbrake.on('end', function () {
|
||||
msg.delete();
|
||||
handbrake.on('end', async function () {
|
||||
await msg.delete();
|
||||
});
|
||||
});
|
||||
});
|
||||
handbrake.on('error', err => {
|
||||
message.channel.send('An error has occured while compressing the video');
|
||||
console.error(err);
|
||||
return message.channel.send('An error has occured while compressing the video');
|
||||
});
|
||||
handbrake.on('progress', progress => {
|
||||
console.log(
|
||||
|
@ -119,13 +141,15 @@ class DownloadCommand extends Command {
|
|||
});
|
||||
handbrake.on('end', function () {
|
||||
message.delete();
|
||||
message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./videoReady.mp4'] })
|
||||
.catch(() => message.channel.send('File too big'));
|
||||
return message.channel.send(`Downloaded by ${message.author.username}`, { files: [`./${fileName}Ready.mp4`] })
|
||||
.catch(err => {
|
||||
console.error(err);
|
||||
return message.channel.send('File too big');
|
||||
});
|
||||
});
|
||||
});
|
||||
} else {
|
||||
|
||||
message.channel.send('You need to input a valid link');
|
||||
return message.channel.send('You need to input a valid link');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,133 +0,0 @@
|
|||
const { Command } = require('discord-akairo');
|
||||
const fs = require('fs');
|
||||
const youtubedl = require('youtube-dl');
|
||||
const hbjs = require('handbrake-js');
|
||||
const { fbuser, fbpasswd } = require('../../config.json');
|
||||
|
||||
class DownloadspoilerCommand extends Command {
|
||||
constructor() {
|
||||
super('downloadspoiler', {
|
||||
aliases: ['downloadspoiler', 'dls'],
|
||||
category: 'utility',
|
||||
args: [
|
||||
{
|
||||
id: 'link',
|
||||
type: 'string',
|
||||
prompt: {
|
||||
start: 'Send the link of wich video you want to download',
|
||||
}
|
||||
},
|
||||
{
|
||||
id: 'alt',
|
||||
match: 'flag',
|
||||
flag: '--alt'
|
||||
}
|
||||
],
|
||||
clientPermissions: ['ATTACH_FILES'],
|
||||
description: {
|
||||
content: 'Download videos from different website from the link you provided (The video will be in spoiler)',
|
||||
usage: '[link]',
|
||||
examples: ['https://www.youtube.com/watch?v=6n3pFFPSlW4']
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
async exec(message, args) {
|
||||
let link = args.link;
|
||||
let needCompress = false;
|
||||
|
||||
if (link.includes('http') || link.includes('www')) {
|
||||
if (args.alt) {
|
||||
console.log('alt download!');
|
||||
fs.unlink('./SPOILER_video.mp4', (err) => {
|
||||
if (err);
|
||||
});
|
||||
return youtubedl.exec(args.link, ['-o', './SPOILER_video.mp4'], {}, function(err, output) {
|
||||
if (err) throw err;
|
||||
console.log(output.join('\n'));
|
||||
message.delete();
|
||||
message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./SPOILER_video.mp4'] })
|
||||
.catch(() => message.channel.send('File too big'));
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
let video = youtubedl(link, [`--username=${fbuser}`, `--password=${fbpasswd}`]);
|
||||
video.pipe(fs.createWriteStream('./SPOILER_video.mp4'));
|
||||
video.on('error', function error(err) {
|
||||
console.log('error 2:', err);
|
||||
message.channel.send('An error has occured, I can\'t download from the link you provided.');
|
||||
});
|
||||
|
||||
message.channel.send('Downloading <a:loadingmin:527579785212329984>').then(msg => {
|
||||
video.on('end', function () {
|
||||
msg.delete();
|
||||
});
|
||||
});
|
||||
|
||||
video.on('info', function(info) {
|
||||
let duration = info.duration;
|
||||
if (duration) {
|
||||
duration = duration.replace(/:/g, '');
|
||||
|
||||
if (duration > 500) {
|
||||
video.pause();
|
||||
video.unpipe();
|
||||
return message.channel.send('Can\'t download video longer than 5 minutes');
|
||||
}
|
||||
}
|
||||
|
||||
console.log('Download started');
|
||||
console.log('filename: ' + info._filename);
|
||||
console.log('size: ' + info.size);
|
||||
|
||||
|
||||
if (info.size >= 8000000) {
|
||||
needCompress = true;
|
||||
}
|
||||
});
|
||||
video.on('end', function () {
|
||||
if (!needCompress) {
|
||||
message.delete();
|
||||
return message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./SPOILER_video.mp4'] })
|
||||
.catch(() => message.channel.send('File too big'));
|
||||
}
|
||||
const options = {
|
||||
input: 'SPOILER_video.mp4',
|
||||
output: 'SPOILER_videoReady.mp4',
|
||||
preset: 'General/Gmail Small 10 Minutes 288p30'
|
||||
};
|
||||
//Compress vid if bigger than 8MB
|
||||
let handbrake = hbjs.spawn(options);
|
||||
handbrake.on('start', function() {
|
||||
message.channel.send('Video bigger than 8MB compressing now <a:loadingmin:527579785212329984> (This can take a long time!)\nWant it to go faster? Donate to the dev with the donate command, so i can get a better server and do it faster!').then(msg => {
|
||||
handbrake.on('end', function () {
|
||||
msg.delete();
|
||||
});
|
||||
});
|
||||
});
|
||||
handbrake.on('error', err => {
|
||||
message.channel.send('An error has occured while compressing the video');
|
||||
console.error(err);
|
||||
});
|
||||
handbrake.on('progress', progress => {
|
||||
console.log(
|
||||
'Percent complete: %s, ETA: %s',
|
||||
progress.percentComplete,
|
||||
progress.eta
|
||||
);
|
||||
});
|
||||
handbrake.on('end', function () {
|
||||
message.delete();
|
||||
message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./SPOILER_videoReady.mp4'] })
|
||||
.catch(() => message.channel.send('File too big'));
|
||||
});
|
||||
});
|
||||
} else {
|
||||
|
||||
message.channel.send('You need to input a valid link');
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
module.exports = DownloadspoilerCommand;
|
Loading…
Reference in a new issue