try to fix no work

This commit is contained in:
valentijn
2024-01-04 16:33:20 +01:00
parent 78a9688276
commit d2e488d4ea
2 changed files with 18 additions and 14 deletions

3
bot.js
View File

@@ -33,7 +33,8 @@ client.on(Events.InteractionCreate, async interaction => {
const command = client.commands.get(interaction.commandName); const command = client.commands.get(interaction.commandName);
if (command) { if (command) {
try { try {
await command.execute(interaction); console.log(`executing ${interaction.commandName}`)
await command.execute(interaction);
} catch (error) { } catch (error) {
console.error(error); console.error(error);

View File

@@ -8,17 +8,20 @@ module.exports = {
.setDescription('shows you some information about the minecraft server'), .setDescription('shows you some information about the minecraft server'),
async execute(interaction) { async execute(interaction) {
try { try {
const serverInfo = await getServerInfo(server_ip, server_port); const serverInfo = await getServerInfo('your_server_ip', your_server_port);
const embed = new EmbedBuilder() const embed = {
.setColor('#0099ff') color: 0x0099ff,
.setTitle('Minecraft Server Status') title: 'Minecraft Server Status',
.addField('Description', serverInfo.description.text) fields: [
.addField('Players', `${serverInfo.players.online}/${serverInfo.players.max}`, true) { name: 'Description', value: serverInfo.description.text },
.addField('Version', serverInfo.version.name, true) { name: 'Players', value: `${serverInfo.players.online}/${serverInfo.players.max}`, inline: true },
.addField('Online Players', serverInfo.players.sample.map(player => player.name).join(', ')); { name: 'Version', value: serverInfo.version.name, inline: true },
{ name: 'Online Players', value: serverInfo.players.sample.map(player => player.name).join(', ') },
],
};
await interaction.reply({ embeds: [embed] }); await interaction.reply({ embeds: [embed], content: '```json\n' + JSON.stringify(serverInfo, null, 2) + '```' });
} catch (error) { } catch (error) {
console.error(error.message || 'Failed to retrieve Minecraft server info.'); console.error(error.message || 'Failed to retrieve Minecraft server info.');
await interaction.reply('Failed to retrieve Minecraft server info.'); await interaction.reply('Failed to retrieve Minecraft server info.');
@@ -30,8 +33,8 @@ module.exports = {
async function getServerInfo(ip, port) { async function getServerInfo(ip, port) {
const client = dgram.createSocket('udp4'); const client = dgram.createSocket('udp4');
// Send a Handshake packet to the server // Send an empty payload for a status request
const handshakePacket = Buffer.from([0xFE, 0xFD, 0x09, 0x74, 0x65, 0x73, 0x74, 0x00, 0x4D, 0x49, 0x4E, 0x45, 0x43, 0x52, 0x41, 0x46, 0x54, 0x00]); const handshakePacket = Buffer.from([0xFE, 0xFD, 0x00]);
client.send(handshakePacket, port, ip); client.send(handshakePacket, port, ip);
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
@@ -42,10 +45,10 @@ async function getServerInfo(ip, port) {
const parsedResponse = JSON.parse(jsonResponse); const parsedResponse = JSON.parse(jsonResponse);
resolve(parsedResponse); resolve(parsedResponse);
} catch (error) { } catch (error) {
reject(new Error('Failed to parse player list.')); reject(new Error('Failed to parse server info.'));
} }
} else { } else {
reject(new Error('Failed to retrieve player list.')); reject(new Error('Failed to retrieve server info.'));
} }
client.close(); client.close();