This commit is contained in:
Hirzi
2022-05-29 19:28:04 +07:00
committed by GitHub
parent c8df400a8a
commit 7c9ab231bc
8 changed files with 529 additions and 428 deletions

125
handlers/checkStatus.js Normal file
View File

@@ -0,0 +1,125 @@
const axios = require('axios')
const chalk = require('chalk')
const postStatus = require('./postStatus')
module.exports = async function checkStatus(client) {
const nodes = []
const panel = {
id: 1,
status: false,
total_servers: -1,
total_users: -1,
}
console.log(chalk.cyan('[PteroStats]') + chalk.green(' Getting nodes stats'))
const panelStats = new Promise((resolve, reject) => {
axios(client.config.panel.url + '/api/application/users', {
method: 'GET',
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
Authorization: 'Bearer ' + client.config.panel.key
}
}).then(usr => {
axios(client.config.panel.url + '/api/application/servers', {
method: 'GET',
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
Authorization: 'Bearer ' + client.config.panel.key
}
}).then(async (ser) => {
panel.total_users = usr.data.meta.pagination.total
panel.total_servers = ser.data.meta.pagination.total
panel.status = true
resolve()
})
}).catch(async (err) => {
if (err.response) {
if (err.response.status === 403) {
console.log('[PteroStats] Err! Invalid apikey')
console.log('[PteroStats] 1. Make sure the apikey is from admin page not account page')
console.log('[PteroStats] 2. Make sure the apikey has read permission on all options')
console.log('[PteroStats] 3. Make sure the apikey is exist')
} else if (err.response.status === 404) {
console.log('[PteroStats] Err! Invalid URL Panel')
console.log('[PteroStats] 1. Make sure the panel url is like "https://panel.example.com"')
} else {
console.log(err)
}
} else {
console.log('[PteroStats] ' + err)
}
resolve()
})
})
const nodeStats = new Promise((resolve, reject) => {
axios(client.config.panel.url + '/api/application/nodes?include=servers,location,allocations', {
method: 'GET',
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
Authorization: 'Bearer ' + client.config.panel.key
}
}).then(async (res) => {
res.data.data.forEach(async (node, i) => {
axios(client.config.panel.url + '/api/application/nodes/' + node.attributes.id + '/configuration', {
method: 'GET',
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
Authorization: 'Bearer ' + client.config.panel.key
}
}).then(async (data) => {
const body = {
id: node.attributes.id,
name: node.attributes.name,
location: node.attributes.relationships.location.attributes.short,
allocations: node.attributes.relationships.allocations.data.length,
status: true,
maintenance: node.attributes.maintenance_mode,
total_servers: node.attributes.relationships.servers.data.length,
memory_min: node.attributes.allocated_resources.memory,
memory_max: node.attributes.memory,
disk_min: node.attributes.allocated_resources.disk,
disk_max: node.attributes.disk,
}
const stats = new Promise((statsResolve, statsReject) => {
axios(node.attributes.scheme + '://' + node.attributes.fqdn + ':' + node.attributes.daemon_listen + '/api/servers', {
method: 'GET',
headers: {
Accept: 'application/json',
'Content-Type': 'application/json',
Authorization: 'Bearer ' + data.data.token
}
}).then(async (status) => {
statsResolve()
}).catch(async (err) => {
body.status = false
statsResolve()
})
})
stats.then(() => {
nodes.push(body)
resolve()
})
}).catch(async (err) => {
resolve()
})
})
}).catch(async (err) => {
resolve()
})
})
panelStats.then(() => {
nodeStats.then(() => {
postStatus(client, panel, nodes)
})
})
}

153
handlers/postStatus.js Normal file
View File

@@ -0,0 +1,153 @@
const { MessageEmbed, Formatters, MessageActionRow, MessageButton } = require('discord.js')
const chalk = require('chalk')
module.exports = async function postStatus(client, panel, nodes) {
const channel = await client.channels.cache.get(client.config.channel)
if (!channel) return console.log('Invalid Channel ID')
let messages = await channel.messages.fetch({ limit: 10 })
messages = messages.filter(m => m.author.id === client.user.id).last();
if (messages && messages.embeds.length === 0) {
messages.delete()
messages = null
}
const format = await Formatters.time(new Date(Date.now() + client.config.refresh * 1000), 'R')
const embed = new MessageEmbed()
let text = ''
let desc = ''
if (client.config.embed.title) embed.setTitle(client.config.embed.title)
if (client.config.embed.description) desc = client.config.embed.description.replaceAll('{{time}}', format) + '\n'
if (client.config.embed.color) embed.setColor(client.config.embed.color)
if (client.config.embed.footer) embed.setFooter({ text: client.config.embed.footer })
if (client.config.embed.thumbnail) embed.setThumbnail(client.config.embed.thumbnail)
if (client.config.embed.image) embed.setImage(client.config.embed.image)
panel.total_users = panel.total_users.toLocaleString()
panel.total_servers = panel.total_servers.toLocaleString()
const stats = new Promise((resolve, reject) => {
if (nodes.length !== 0) {
nodes.forEach((data, i) => {
const title = data.name + ': ' + String(data.status).replace('true', client.config.status.online).replace('false', client.config.status.offline)
let description = '```' + '\n' +
'Status : ' + String(data.status).replace('true', client.config.status.online).replace('false', client.config.status.offline) + '\n'
switch (client.config.resource.unit) {
case 'gb':
description = description +
'Memory : ' + Math.floor(data.memory_min / 1000).toLocaleString() + ' Gb /' + Math.floor(data.memory_max / 1000).toLocaleString() + ' Gb\n' +
'Disk : ' + Math.floor(data.disk_min / 1000).toLocaleString() + 'Gb /' + Math.floor(data.disk_max / 1000).toLocaleString() + ' Gb\n'
break;
case 'percent':
description = description +
'Memory : ' + Math.floor(data.memory_min / data.memory_max * 100) + ' %\n' +
'Disk : ' + Math.floor(data.disk_min / data.disk_max * 100) + ' %\n'
break;
default:
description = description +
'Memory : ' + data.memory_min.toLocaleString() + ' Mb /' + data.memory_max.toLocaleString() + ' Mb\n' +
'Disk : ' + data.disk_min.toLocaleString() + 'Mb /' + data.disk_max.toLocaleString() + ' Mb\n'
}
if (client.config.resource.location) description = description + 'Location: ' + data.location + '\n'
if (client.config.resource.allocations) description = description + 'Servers : ' + data.allocations.toLocaleString() + '\n'
if (client.config.resource.servers) description = description + 'Servers : ' + data.total_servers.toLocaleString() + '\n'
description = description + '```'
if (client.config.resource.enable) {
text = text + '\n**' + title.replace(':', ':**') + '\n' + description
} else {
text = text + '\n**' + title.replace(':', ':**')
}
if (i + 1 === nodes.length) resolve()
})
} else if (nodes.length === 0) {
if (!messages) {
text = 'There is no nodes to display'
resolve()
} else {
text = messages.embeds[0].fields[0].value.replaceAll(client.config.status.online, client.config.status.offline)
if (!panel.status && String(String(messages.embeds[0].fields[1].value).split('\n')[2]).split('')[String(String(messages.embeds[0].fields[1].value).split('\n')[2]).length - 1] !== '`') {
panel.total_users = String(String(messages.embeds[0].fields[1].value).split('\n')[2]).split('')[String(String(messages.embeds[0].fields[1].value).split('\n')[2]).length - 1]
panel.total_servers = String(String(messages.embeds[0].fields[1].value).split('\n')[3]).split('')[String(String(messages.embeds[0].fields[1].value).split('\n')[3]).length - 1]
}
resolve()
}
}
})
stats.then(async () => {
embed.setDescription(desc + '\n**Nodes Stats [' + nodes.length + ']**' + text)
embed.addField('Panel Stats',
'**Status:** ' + String(panel.status).replace('true', client.config.status.online).replace('false', client.config.status.offline) + '\n\n' +
'Users: ' + String(panel.total_users).replace('-1', '`Unknown`') + '\n' +
'Servers: ' + String(panel.total_servers).replace('-1', '`Unknown`')
)
if (client.config.embed.field.enable) {
embed.addField(client.config.embed.field.title, client.config.embed.field.description.replaceAll('{{time}}', format))
}
embed.setTimestamp()
let row = []
if (client.config.button.enable) {
row = new MessageActionRow
if (client.config.button.btn1.label.length !== 0 && client.config.button.btn1.label.link.length !== 0) {
row.addComponents(
new MessageButton()
.setLabel(client.config.button.btn1.label)
.setStyle('LINK')
.setURL(client.config.button.btn1.url)
)
}
if (client.config.button.btn2.label.length !== 0 && client.config.button.btn2.label.link.length !== 0) {
row.addComponents(
new MessageButton()
.setLabel(client.config.button.btn2.label)
.setStyle('LINK')
.setURL(client.config.button.btn2.url)
)
}
if (client.config.button.btn3.label.length !== 0 && client.config.button.btn3.label.link.length !== 0) {
row.addComponents(
new MessageButton()
.setLabel(client.config.button.btn3.label)
.setStyle('LINK')
.setURL(client.config.button.btn3.url)
)
}
if (client.config.button.btn4.label.length !== 0 && client.config.button.btn4.label.link.length !== 0) {
row.addComponents(
new MessageButton()
.setLabel(client.config.button.btn4.label)
.setStyle('LINK')
.setURL(client.config.button.btn4.url)
)
}
if (client.config.button.btn5.label.length !== 0 && client.config.button.btn5.label.link.length !== 0) {
row.addComponents(
new MessageButton()
.setLabel(client.config.button.btn5.label)
.setStyle('LINK')
.setURL(client.config.button.btn5.url)
)
}
row = [row]
}
if (!messages) channel.send({ embeds: [embed] })
else messages.edit({ embeds: [embed], components: row })
console.log(chalk.cyan('[PteroStats]') + chalk.green(' stats posted!'))
})
}