49 lines
		
	
	
		
			No EOL
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			No EOL
		
	
	
		
			1.7 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| import { execFile } from 'node:child_process';
 | |
| const { statusChannel, NODE_ENV } = process.env;
 | |
| import { version } from 'discord.js';
 | |
| 
 | |
| export default {
 | |
| 	name: 'ready',
 | |
| 	once: true,
 | |
| 	async execute(client) {
 | |
| 		// Init global variables.
 | |
| 		global.boards = {};
 | |
| 
 | |
| 		const ytdlpVersion = await new Promise((resolve, reject) => {
 | |
| 			execFile('./bin/yt-dlp', ['--version'], (err, stdout, stderr) => {
 | |
| 				if (err) {
 | |
| 					reject(stderr);
 | |
| 				}
 | |
| 				if (stderr) {
 | |
| 					console.error(stderr);
 | |
| 				}
 | |
| 				resolve(stdout);
 | |
| 			});
 | |
| 		});
 | |
| 
 | |
| 		const commandSize = client.commands.size;
 | |
| 		const clientTag = client.user.username;
 | |
| 		const guildSize = client.guilds.cache.size;
 | |
| 		const channelSize = client.channels.cache.size;
 | |
| 		const clientID = client.user.id;
 | |
| 
 | |
| 		console.log('===========[ READY ]===========');
 | |
| 		console.log(`\x1b[32mLogged in as \x1b[34m${clientTag}\x1b[0m! (\x1b[33m${clientID}\x1b[0m)`);
 | |
| 		console.log(`Ready to serve in \x1b[33m${channelSize}\x1b[0m channels on \x1b[33m${guildSize}\x1b[0m servers.`);
 | |
| 		console.log(`${client.readyAt}`);
 | |
| 		console.log(`There is \x1b[33m${commandSize}\x1b[0m command loaded.`);
 | |
| 		console.log(`Running yt-dlp \x1b[33m${ytdlpVersion.replace('\n', '')}\x1b[0m`);
 | |
| 		console.log(`Running Discord.js \x1b[33m${version}\x1b[0m`);
 | |
| 		console.log('===========[ READY ]===========');
 | |
| 
 | |
| 		// If stats channel settings exist, send bot stats to it
 | |
| 		if (statusChannel && NODE_ENV !== 'development') {
 | |
| 			const channel = client.channels.resolve(statusChannel);
 | |
| 			channel.send(
 | |
| 				`Ready to serve in ${channelSize} channels on ${guildSize} servers.\n` +
 | |
| 				`There is ${commandSize} command loaded.\n` +
 | |
| 				`Running yt-dlp ${ytdlpVersion.replace('\n', '')}\n` +
 | |
| 				`${client.readyAt}`);
 | |
| 		}
 | |
| 	},
 | |
| }; |