Add initial dl command
All checks were successful
CI / CI (push) Successful in 1m24s

This commit is contained in:
SileNce5k 2025-06-17 01:55:20 +02:00
parent 600173771e
commit d27c1bad55
Signed by: SileNce
GPG key ID: B0A142BB4291B204

65
commands/misc/dl.js Normal file
View file

@ -0,0 +1,65 @@
const { execSync } = require('child_process');
const path = require('path');
const fs = require('fs')
module.exports = {
name: 'dl',
description: 'Download a video',
moreHelp: [
"Usage: <prefix>dl <url>"
],
async execute({message, args}) {
const downloadsDir = path.resolve(process.cwd(), 'data', 'downloads', Math.floor(new Date).toString());
fs.mkdirSync(downloadsDir, {recursive: true});
let url;
if(args[0] && args[0].startsWith("https://") ){
url = args[0];
} else {
return message.channel.send("No url")
}
if(this.executeCommand(`yt-dlp "${url}" -P ${downloadsDir}`).error === false){
message.channel.send("An error occured when executing the command");
this.cleanUp(downloadsDir);
return;
}
let files = fs.readdirSync(downloadsDir);
if(files < 1) {
this.cleanUp(downloadsDir);
message.channel.send("Something went wrong when downloading the video.")
return;
}
const filename = files[0];
await message.channel.send({files: [{
attachment: path.resolve(`${downloadsDir}/${filename}`)
}]})
this.cleanUp(downloadsDir);
},
cleanUp(downloadsDir){
fs.rmSync(downloadsDir);
},
executeCommand(command) {
console.log("Executing:", command)
try {
const output = execSync(command, { encoding: 'utf-8' })
if (output.length != 0)
console.log(output)
} catch (error) {
console.error(`Error executing ${command.split(" ")[0]} command:`, error);
return { error: true };
}
return { error: false };
},
}