forked from Supositware/Haha-Yes
slightly better hapi integration idk, probably should move that into utils/download.js
This commit is contained in:
parent
3527ded36f
commit
db4f058fb4
1 changed files with 182 additions and 172 deletions
|
@ -1,6 +1,7 @@
|
||||||
const { Command } = require('discord-akairo');
|
const { Command } = require('discord-akairo');
|
||||||
const downloader = require('../../utils/download');
|
const downloader = require('../../utils/download');
|
||||||
const compress = require('../../utils/compress');
|
const compress = require('../../utils/compress');
|
||||||
|
const checkHapi = require('../../utils/checkHapi');
|
||||||
const { proxy, Hapi } = require('../../config.json');
|
const { proxy, Hapi } = require('../../config.json');
|
||||||
const os = require('os');
|
const os = require('os');
|
||||||
const fs = require('fs');
|
const fs = require('fs');
|
||||||
|
@ -52,108 +53,7 @@ class DownloadCommand extends Command {
|
||||||
}
|
}
|
||||||
|
|
||||||
async exec(message, args) {
|
async exec(message, args) {
|
||||||
let Embed = this.client.util.embed()
|
if (!args.link) return message.channel.send('Please try again with a valid URL.');
|
||||||
.setColor(message.member ? message.member.displayHexColor : 'NAVY')
|
|
||||||
.setAuthor(`Downloaded by ${message.author.username}`, message.author.displayAvatarURL(), args.link)
|
|
||||||
.setDescription(args.caption ? args.caption : '')
|
|
||||||
.setFooter(`You can get the original video by clicking on the "downloaded by ${message.author.username}" message!`);
|
|
||||||
|
|
||||||
let compressEmbed = this.client.util.embed()
|
|
||||||
.setColor(message.member ? message.member.displayHexColor : 'NAVY')
|
|
||||||
.setTitle('This one will need compression!')
|
|
||||||
.setDescription('Starting compression now!')
|
|
||||||
.setFooter('Want it to go faster? Donate to the dev with the donate command, so i can get a better server and do it faster!');
|
|
||||||
|
|
||||||
let loadingmsg = await message.channel.send('Downloading <a:loadingmin:527579785212329984>');
|
|
||||||
|
|
||||||
|
|
||||||
if (Hapi) {
|
|
||||||
let error = false;
|
|
||||||
|
|
||||||
const params = new URLSearchParams();
|
|
||||||
params.append('url', args.link.href);
|
|
||||||
fetch(`${Hapi}/download`, {method: 'POST', body: params})
|
|
||||||
.then(async res => {
|
|
||||||
Embed.setFooter(`Using Hapi | ${Embed.footer.text}`);
|
|
||||||
compressEmbed.setFooter(`Using Hapi | ${compressEmbed.footer.text}`);
|
|
||||||
|
|
||||||
if (res.headers.get('content-type') == 'application/json; charset=utf-8') {
|
|
||||||
let json = await res.json();
|
|
||||||
let compressmsg = await message.channel.send(compressEmbed);
|
|
||||||
|
|
||||||
console.log(json);
|
|
||||||
|
|
||||||
let editmsg = setInterval(() => {
|
|
||||||
console.log('a');
|
|
||||||
fetch(json.status)
|
|
||||||
.then(res => res.json())
|
|
||||||
.then(json => {
|
|
||||||
console.log(json);
|
|
||||||
compressEmbed.setDescription(`Ready in ${json.eta === '' ? 'soon enough' : json.eta}. ${json.percent}% complete.`);
|
|
||||||
compressmsg.edit(compressEmbed);
|
|
||||||
})
|
|
||||||
.catch (e=> {
|
|
||||||
console.error(e);
|
|
||||||
clearInterval(editmsg);
|
|
||||||
return message.channel.send('Hapi server returned an error.');
|
|
||||||
});
|
|
||||||
}, 5000);
|
|
||||||
|
|
||||||
|
|
||||||
let retry = 0;
|
|
||||||
let interval = setInterval(() => {
|
|
||||||
fetch(`${json.final}`)
|
|
||||||
.then(res => {
|
|
||||||
if (res.status == 200) {
|
|
||||||
clearInterval(editmsg);
|
|
||||||
clearInterval(interval);
|
|
||||||
const dest = fs.createWriteStream(`${os.tmpdir()}/${message.id}compressed.mp4`);
|
|
||||||
res.body.pipe(dest);
|
|
||||||
dest.on('finish', () => {
|
|
||||||
compressmsg.delete();
|
|
||||||
message.channel.send({
|
|
||||||
embed: Embed,
|
|
||||||
files: [`${os.tmpdir()}/${message.id}compressed.mp4`]
|
|
||||||
})
|
|
||||||
.catch(err => {
|
|
||||||
console.error(err);
|
|
||||||
return message.channel.send(`${err.name}: ${err.message} ${err.message === 'Request entity too large' ? 'The file size is too big' : ''}`);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
} else {
|
|
||||||
retry++;
|
|
||||||
if (retry >= 5)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
console.log(`try #${retry} status ${res.status}`);
|
|
||||||
})
|
|
||||||
.catch (e=> {
|
|
||||||
console.error(e);
|
|
||||||
clearInterval(interval);
|
|
||||||
return message.channel.send('Hapi server returned an error.');
|
|
||||||
});
|
|
||||||
}, 5000);
|
|
||||||
} else {
|
|
||||||
const dest = fs.createWriteStream(`${os.tmpdir()}/${message.id}.mp4`);
|
|
||||||
res.body.pipe(dest);
|
|
||||||
dest.on('finish', () => {
|
|
||||||
message.channel.send({embed: Embed, files: [`${os.tmpdir()}/${message.id}.mp4`]});
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
message.delete();
|
|
||||||
loadingmsg.delete();
|
|
||||||
return;
|
|
||||||
})
|
|
||||||
.catch(e => {
|
|
||||||
console.error(e);
|
|
||||||
error = true;
|
|
||||||
message.channel.send('Hapi server returned an error or is unreachable. Trying standalone download.');
|
|
||||||
});
|
|
||||||
|
|
||||||
if (!error)
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (args.listproxy) {
|
if (args.listproxy) {
|
||||||
let proxys = [];
|
let proxys = [];
|
||||||
|
@ -173,105 +73,215 @@ class DownloadCommand extends Command {
|
||||||
return message.channel.send(Embed);
|
return message.channel.send(Embed);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!args.link) return message.channel.send('Please try again with a valid URL.');
|
|
||||||
let filename = `${message.id}_video`;
|
|
||||||
|
|
||||||
if (args.proxy && !args.proxyAuto) { // args.proxyAuto is only provided when the command is run after a error 429
|
let Embed = this.client.util.embed()
|
||||||
args.proxy = args.proxy - 1;
|
.setColor(message.member ? message.member.displayHexColor : 'NAVY')
|
||||||
if (!proxy[args.proxy]) args.proxy = 0;
|
.setAuthor(`Downloaded by ${message.author.username}`, message.author.displayAvatarURL(), args.link)
|
||||||
}
|
.setDescription(args.caption ? args.caption : '')
|
||||||
|
.setFooter(`You can get the original video by clicking on the "downloaded by ${message.author.username}" message!`);
|
||||||
|
|
||||||
if (args.spoiler) {
|
let compressEmbed = this.client.util.embed()
|
||||||
filename = `SPOILER_${message.id}_video`;
|
.setColor(message.member ? message.member.displayHexColor : 'NAVY')
|
||||||
}
|
.setTitle('This one will need compression!')
|
||||||
|
.setDescription('Starting compression now!')
|
||||||
|
.setFooter('Want it to go faster? Donate to the dev with the donate command, so i can get a better server and do it faster!');
|
||||||
|
|
||||||
downloader(args.link.href, args.proxy != null ? ['--proxy', proxy[args.proxy].ip] : null, `${os.tmpdir()}/${filename}.mp4`)
|
let loadingmsg = await message.channel.send('Downloading <a:loadingmin:527579785212329984>');
|
||||||
.on('error', async err => {
|
|
||||||
if (err.includes('HTTP Error 429: Too Many Requests')) {
|
|
||||||
if (args.proxy != null) {
|
const spoiler = args.spoiler;
|
||||||
args.proxy = args.proxy + 1;
|
let filePath = `${os.tmpdir()}/${message.id}.mp4`;
|
||||||
} else {
|
|
||||||
args.proxy = 0;
|
if (spoiler)
|
||||||
args.proxyAuto = true;
|
filePath = `SPOILER_${filePath}`;
|
||||||
|
|
||||||
|
const isHapiOnline = await checkHapi();
|
||||||
|
|
||||||
|
if (isHapiOnline) { // I should move that into the download utility file
|
||||||
|
console.log(`[Download] Hapi server is online at: ${Hapi}`);
|
||||||
|
Embed.setFooter(`Using Hapi | ${Embed.footer.text}`);
|
||||||
|
compressEmbed.setFooter(`Using Hapi | ${compressEmbed.footer.text}`);
|
||||||
|
|
||||||
|
const params = new URLSearchParams();
|
||||||
|
params.append('url', args.link.href);
|
||||||
|
|
||||||
|
fetch(`${Hapi}/download`, {method: 'POST', body: params})
|
||||||
|
.then(async res => {
|
||||||
|
console.log(`status is ${res.status}`);
|
||||||
|
if (res.status !== 200) {
|
||||||
|
console.log('Status is not 200. Abort');
|
||||||
|
return message.channel.send('An error has occurred.');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!proxy[args.proxy]) return message.channel.send('`HTTP Error 429: Too Many Requests.`\nThe website you tried to download from probably has the bot blocked along with its proxy');
|
if (res.headers.get('content-type') === 'application/json; charset=utf-8') { // If we receive JSON it mean it started compressing the video
|
||||||
|
console.log('Compressing');
|
||||||
|
let json = await res.json();
|
||||||
|
let compressmsg = await message.channel.send(compressEmbed);
|
||||||
|
|
||||||
loadingmsg.delete();
|
console.log(`Got json!\n${json}`);
|
||||||
return this.client.commandHandler.runCommand(message, this.client.commandHandler.findCommand('download'), args);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (err.includes('Error: status code 403')) return message.channel.send('`HTTP Error 403: Forbidden.`\nThe video you tried to download is not publicly available therefor the bot can\'t download it.');
|
// Edit compression embed progress
|
||||||
|
let editmsg = setInterval(() => {
|
||||||
|
fetch(json.status)
|
||||||
|
.then(res => res.json())
|
||||||
|
.then(json => {
|
||||||
|
compressEmbed.setDescription(`Ready in ${json.eta === '' ? 'soon enough' : json.eta}. ${json.percent}% complete.`);
|
||||||
|
compressmsg.edit(compressEmbed);
|
||||||
|
})
|
||||||
|
.catch (e=> {
|
||||||
|
console.error(e);
|
||||||
|
clearInterval(editmsg);
|
||||||
|
return message.channel.send('Hapi server returned an error.');
|
||||||
|
});
|
||||||
|
}, 5000);
|
||||||
|
|
||||||
return message.channel.send(err, { code: true });
|
// Check if the file is at the final location ( end result once it get compressed ) give up after 100 try
|
||||||
})
|
let retry = 0;
|
||||||
.on('end', async output => {
|
let interval = setInterval(() => {
|
||||||
let file = fs.statSync(output);
|
fetch(`${json.final}`)
|
||||||
let fileSize = file.size / 1000000.0;
|
.then(res => {
|
||||||
|
if (res.status !== 200) {
|
||||||
|
console.log(`try #${retry} status ${res.status}`);
|
||||||
|
retry++;
|
||||||
|
if (retry >= 100) {
|
||||||
|
clearInterval(editmsg);
|
||||||
|
clearInterval(interval);
|
||||||
|
return message.channel.send('Timed out, your video was probably too big to get compressed.');
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
clearInterval(editmsg);
|
||||||
|
clearInterval(interval);
|
||||||
|
|
||||||
if (fileSize > 8) {
|
const dest = fs.createWriteStream(filePath);
|
||||||
loadingmsg.delete();
|
res.body.pipe(dest);
|
||||||
|
|
||||||
let compressmsg = await message.channel.send(compressEmbed);
|
dest.on('finish', () => {
|
||||||
|
compressmsg.delete();
|
||||||
|
loadingmsg.delete();
|
||||||
|
message.delete();
|
||||||
|
message.channel.send({
|
||||||
|
embed: Embed,
|
||||||
|
files: [filePath]
|
||||||
|
})
|
||||||
|
.catch(err => {
|
||||||
|
console.error(err);
|
||||||
|
return message.channel.send(`${err.name}: ${err.message} ${err.message === 'Request entity too large' ? 'The file size is too big' : ''}`);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.catch (e=> {
|
||||||
|
console.error(e);
|
||||||
|
clearInterval(interval);
|
||||||
|
return message.channel.send('Hapi server returned an error.');
|
||||||
|
});
|
||||||
|
}, 5000);
|
||||||
|
|
||||||
let handbrake = compress(output, `${os.tmpdir()}/${filename}compressed.mp4`);
|
} else {
|
||||||
|
console.log('finished download');
|
||||||
|
const dest = fs.createWriteStream(filePath);
|
||||||
|
res.body.pipe(dest);
|
||||||
|
dest.on('finish', () => {
|
||||||
|
message.channel.send({embed: Embed, files: [filePath]});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else { // No Hapi server, let the bot download it
|
||||||
|
if (args.proxy && !args.proxyAuto) { // args.proxyAuto is only provided when the command is run after a error 429
|
||||||
|
args.proxy = args.proxy - 1;
|
||||||
|
if (!proxy[args.proxy]) args.proxy = 0;
|
||||||
|
}
|
||||||
|
|
||||||
let percentComplete;
|
downloader(args.link.href, args.proxy != null ? ['--proxy', proxy[args.proxy].ip] : null, filePath)
|
||||||
let eta;
|
.on('error', async err => {
|
||||||
|
if (err.includes('HTTP Error 429: Too Many Requests')) {
|
||||||
|
if (args.proxy != null) {
|
||||||
|
args.proxy = args.proxy + 1;
|
||||||
|
} else {
|
||||||
|
args.proxy = 0;
|
||||||
|
args.proxyAuto = true;
|
||||||
|
}
|
||||||
|
|
||||||
handbrake.on('progress', progress => {
|
if (!proxy[args.proxy]) return message.channel.send('`HTTP Error 429: Too Many Requests.`\nThe website you tried to download from probably has the bot blocked along with its proxy');
|
||||||
percentComplete = progress.percentComplete;
|
|
||||||
eta = progress.eta;
|
|
||||||
});
|
|
||||||
|
|
||||||
// Every 5 seconds update the compress message with the %
|
loadingmsg.delete();
|
||||||
let editmsg = setInterval(() => {
|
return this.client.commandHandler.runCommand(message, this.client.commandHandler.findCommand('download'), args);
|
||||||
compressEmbed.setDescription(`Ready in ${eta === '' ? 'soon enough' : eta}. ${percentComplete}% complete.`);
|
}
|
||||||
compressmsg.edit(compressEmbed);
|
|
||||||
}, 5000);
|
|
||||||
|
|
||||||
handbrake.on('err', (err) => {
|
if (err.includes('Error: status code 403')) return message.channel.send('`HTTP Error 403: Forbidden.`\nThe video you tried to download is not publicly available therefor the bot can\'t download it.');
|
||||||
clearInterval(editmsg);
|
|
||||||
compressmsg.delete();
|
|
||||||
return message.channel.send(err, { code: true });
|
|
||||||
});
|
|
||||||
|
|
||||||
handbrake.on('end', (output) => {
|
return message.channel.send(err, { code: true });
|
||||||
clearInterval(editmsg);
|
})
|
||||||
file = fs.statSync(output);
|
.on('end', async output => {
|
||||||
fileSize = file.size / 1000000.0;
|
let file = fs.statSync(output);
|
||||||
|
let fileSize = file.size / 1000000.0;
|
||||||
|
|
||||||
if (fileSize > 8) return message.channel.send('End results is too big for discord.');
|
if (fileSize > 8) { // File bigger than 8 mb, it need compressing
|
||||||
|
filePath = `${filePath.substring(0, filePath.length - 4)}compressed.mp4`;
|
||||||
|
loadingmsg.delete();
|
||||||
|
|
||||||
|
let compressmsg = await message.channel.send(compressEmbed);
|
||||||
|
|
||||||
|
let handbrake = compress(output, filePath);
|
||||||
|
|
||||||
|
let percentComplete;
|
||||||
|
let eta;
|
||||||
|
|
||||||
|
handbrake.on('progress', progress => {
|
||||||
|
percentComplete = progress.percentComplete;
|
||||||
|
eta = progress.eta;
|
||||||
|
});
|
||||||
|
|
||||||
|
// Every 5 seconds update the compress message with the %
|
||||||
|
let editmsg = setInterval(() => {
|
||||||
|
compressEmbed.setDescription(`Ready in ${eta === '' ? 'soon enough' : eta}. ${percentComplete}% complete.`);
|
||||||
|
compressmsg.edit(compressEmbed);
|
||||||
|
}, 5000);
|
||||||
|
|
||||||
|
handbrake.on('err', (err) => {
|
||||||
|
clearInterval(editmsg);
|
||||||
|
compressmsg.delete();
|
||||||
|
return message.channel.send(err, { code: true });
|
||||||
|
});
|
||||||
|
|
||||||
|
handbrake.on('end', (output) => {
|
||||||
|
clearInterval(editmsg);
|
||||||
|
file = fs.statSync(output);
|
||||||
|
fileSize = file.size / 1000000.0;
|
||||||
|
|
||||||
|
if (fileSize > 8) return message.channel.send('End results is too big for discord.');
|
||||||
|
|
||||||
|
return message.channel.send({embed: Embed, files: [output]})
|
||||||
|
.catch(err => {
|
||||||
|
compressmsg.delete();
|
||||||
|
console.error(err);
|
||||||
|
return message.channel.send(`${err.name}: ${err.message} ${err.message === 'Request entity too large' ? 'The file size is too big' : ''}`);
|
||||||
|
})
|
||||||
|
.then(() => {
|
||||||
|
compressmsg.delete();
|
||||||
|
// Delete file after it has been sent
|
||||||
|
fs.unlinkSync(output);
|
||||||
|
message.delete();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
} else {
|
||||||
return message.channel.send({embed: Embed, files: [output]})
|
return message.channel.send({embed: Embed, files: [output]})
|
||||||
.catch(err => {
|
.catch(err => {
|
||||||
compressmsg.delete();
|
loadingmsg.delete();
|
||||||
console.error(err);
|
console.error(err);
|
||||||
return message.channel.send(`${err.name}: ${err.message} ${err.message === 'Request entity too large' ? 'The file size is too big' : ''}`);
|
return message.channel.send(`${err.name}: ${err.message} ${err.message === 'Request entity too large' ? 'The file size is too big' : ''}`);
|
||||||
})
|
})
|
||||||
.then(() => {
|
.then(() => {
|
||||||
compressmsg.delete();
|
loadingmsg.delete();
|
||||||
// Delete file after it has been sent
|
// Delete file after it has been sent
|
||||||
fs.unlinkSync(output);
|
fs.unlinkSync(output);
|
||||||
message.delete();
|
message.delete();
|
||||||
});
|
});
|
||||||
});
|
}
|
||||||
} else {
|
});
|
||||||
return message.channel.send({embed: Embed, files: [output]})
|
}
|
||||||
.catch(err => {
|
|
||||||
loadingmsg.delete();
|
|
||||||
console.error(err);
|
|
||||||
return message.channel.send(`${err.name}: ${err.message} ${err.message === 'Request entity too large' ? 'The file size is too big' : ''}`);
|
|
||||||
})
|
|
||||||
.then(() => {
|
|
||||||
loadingmsg.delete();
|
|
||||||
// Delete file after it has been sent
|
|
||||||
fs.unlinkSync(output);
|
|
||||||
message.delete();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
module.exports = DownloadCommand;
|
module.exports = DownloadCommand;
|
Loading…
Reference in a new issue