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',
|
start: 'Write something so i can say it back',
|
||||||
},
|
},
|
||||||
match: 'rest'
|
match: 'rest'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'delete',
|
||||||
|
match: 'flag',
|
||||||
|
flag: ['--del', '--delete', '-d']
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
description: {
|
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]',
|
usage: '[text]',
|
||||||
examples: ['[member] is a big [adverbs] [verbs]']
|
examples: ['[member] is a big [adverbs] [verbs]']
|
||||||
}
|
}
|
||||||
|
@ -134,16 +139,24 @@ class SayCommand extends Command {
|
||||||
.setTimestamp();
|
.setTimestamp();
|
||||||
|
|
||||||
if (attach) {
|
if (attach) {
|
||||||
|
if (args.delete)
|
||||||
|
message.delete();
|
||||||
return message.channel.send(embed, {files: [attach]});
|
return message.channel.send(embed, {files: [attach]});
|
||||||
} else {
|
} else {
|
||||||
|
if (args.delete)
|
||||||
|
message.delete();
|
||||||
return message.channel.send(embed);
|
return message.channel.send(embed);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Send the final text
|
// Send the final text
|
||||||
if (attach) {
|
if (attach) {
|
||||||
|
if (args.delete)
|
||||||
|
message.delete();
|
||||||
return message.channel.send(text, {files: [attach]});
|
return message.channel.send(text, {files: [attach]});
|
||||||
} else {
|
} else {
|
||||||
|
if (args.delete)
|
||||||
|
message.delete();
|
||||||
return message.channel.send(text);
|
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',
|
id: 'alt',
|
||||||
match: 'flag',
|
match: 'flag',
|
||||||
flag: '--alt'
|
flag: '--alt'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'spoiler',
|
||||||
|
match: 'flag',
|
||||||
|
flag: ['--spoil', '--spoiler', '-s']
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
clientPermissions: ['ATTACH_FILES'],
|
clientPermissions: ['ATTACH_FILES'],
|
||||||
description: {
|
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]',
|
usage: '[link]',
|
||||||
examples: ['https://www.youtube.com/watch?v=6n3pFFPSlW4']
|
examples: ['https://www.youtube.com/watch?v=6n3pFFPSlW4']
|
||||||
}
|
}
|
||||||
|
@ -35,25 +40,37 @@ class DownloadCommand extends Command {
|
||||||
async exec(message, args) {
|
async exec(message, args) {
|
||||||
let link = args.link;
|
let link = args.link;
|
||||||
let needCompress = false;
|
let needCompress = false;
|
||||||
|
let fileName;
|
||||||
|
|
||||||
|
if (args.spoiler) {
|
||||||
|
fileName = 'SPOILER_video';
|
||||||
|
} else {
|
||||||
|
fileName = 'video';
|
||||||
|
}
|
||||||
|
|
||||||
if (link.includes('http') || link.includes('www')) {
|
if (link.includes('http') || link.includes('www')) {
|
||||||
if (args.alt) {
|
if (args.alt) {
|
||||||
console.log('alt download!');
|
console.log('alt download!');
|
||||||
fs.unlink('./video.mp4', (err) => {
|
if (fs.existsSync(`./${fileName}.mp4`)) {
|
||||||
|
fs.unlink(`./${fileName}.mp4`, (err) => {
|
||||||
if (err);
|
if (err);
|
||||||
});
|
});
|
||||||
return youtubedl.exec(args.link, ['-o', './video.mp4'], {}, function(err, output) {
|
}
|
||||||
|
return youtubedl.exec(args.link, ['-o', `./${fileName}.mp4`], {}, function(err, output) {
|
||||||
if (err) throw err;
|
if (err) throw err;
|
||||||
console.log(output.join('\n'));
|
console.log(output.join('\n'));
|
||||||
message.delete();
|
message.delete();
|
||||||
message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./video.mp4'] })
|
message.channel.send(`Downloaded by ${message.author.username}`, { files: [`./${fileName}.mp4`] })
|
||||||
.catch(() => message.channel.send('File too big'));
|
.catch(err => {
|
||||||
|
console.error(err);
|
||||||
|
return message.channel.send('File too big');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
let video = youtubedl(link, [`--username=${fbuser}`, `--password=${fbpasswd}`]);
|
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) {
|
video.on('error', function error(err) {
|
||||||
console.log('error 2:', 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('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 () {
|
video.on('end', function () {
|
||||||
if (!needCompress) {
|
if (!needCompress) {
|
||||||
message.delete();
|
message.delete();
|
||||||
return message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./video.mp4'] })
|
return message.channel.send(`Downloaded by ${message.author.username}`, { files: [`./${fileName}.mp4`] })
|
||||||
.catch(() => message.channel.send('File too big'));
|
.catch(err => {
|
||||||
|
console.error(err);
|
||||||
|
return message.channel.send('File too big');
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
const options = {
|
const options = {
|
||||||
input: 'video.mp4',
|
input: `${fileName}.mp4`,
|
||||||
output: 'videoReady.mp4',
|
output: `${fileName}Ready.mp4`,
|
||||||
preset: 'General/Gmail Small 10 Minutes 288p30'
|
preset: 'General/Gmail Small 10 Minutes 288p30'
|
||||||
};
|
};
|
||||||
|
|
||||||
//Compress vid if bigger than 8MB
|
//Compress vid if bigger than 8MB
|
||||||
let handbrake = hbjs.spawn(options);
|
let handbrake = hbjs.spawn(options);
|
||||||
handbrake.on('start', function() {
|
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 => {
|
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 () {
|
handbrake.on('end', async function () {
|
||||||
msg.delete();
|
await msg.delete();
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
handbrake.on('error', err => {
|
handbrake.on('error', err => {
|
||||||
message.channel.send('An error has occured while compressing the video');
|
|
||||||
console.error(err);
|
console.error(err);
|
||||||
|
return message.channel.send('An error has occured while compressing the video');
|
||||||
});
|
});
|
||||||
handbrake.on('progress', progress => {
|
handbrake.on('progress', progress => {
|
||||||
console.log(
|
console.log(
|
||||||
|
@ -119,13 +141,15 @@ class DownloadCommand extends Command {
|
||||||
});
|
});
|
||||||
handbrake.on('end', function () {
|
handbrake.on('end', function () {
|
||||||
message.delete();
|
message.delete();
|
||||||
message.channel.send(`Downloaded by ${message.author.username}`, { files: ['./videoReady.mp4'] })
|
return message.channel.send(`Downloaded by ${message.author.username}`, { files: [`./${fileName}Ready.mp4`] })
|
||||||
.catch(() => message.channel.send('File too big'));
|
.catch(err => {
|
||||||
|
console.error(err);
|
||||||
|
return message.channel.send('File too big');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
|
return message.channel.send('You need to input a valid link');
|
||||||
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