Small updates
This commit is contained in:
parent
05eddc7734
commit
7f93f53cd6
6 changed files with 56 additions and 6 deletions
|
@ -1,5 +1,38 @@
|
|||
const Strings = require('../locales/english.json');
|
||||
const Config = require('../props/config.json');
|
||||
const os = require('os');
|
||||
|
||||
function formatUptime(uptime) {
|
||||
const hours = Math.floor(uptime / 3600);
|
||||
const minutes = Math.floor((uptime % 3600) / 60);
|
||||
const seconds = Math.floor(uptime % 60);
|
||||
return `${hours}h ${minutes}m ${seconds}s`;
|
||||
}
|
||||
|
||||
function getSystemInfo() {
|
||||
const platform = os.platform();
|
||||
const release = os.release();
|
||||
const arch = os.arch();
|
||||
const cpuModel = os.cpus()[0].model;
|
||||
const cpuCores = os.cpus().length;
|
||||
const totalMemory = (os.totalmem() / (1024 ** 3)).toFixed(2) + ' GB';
|
||||
const freeMemory = (os.freemem() / (1024 ** 3)).toFixed(2) + ' GB';
|
||||
const loadAverage = os.loadavg().map(avg => avg.toFixed(2)).join(', ');
|
||||
const uptime = formatUptime(os.uptime());
|
||||
const nodeVersion = process.version;
|
||||
|
||||
return `*Server Stats*\n\n` +
|
||||
`*OS:* \`${platform} ${release}\`\n` +
|
||||
`*Arch:* \`${arch}\`\n` +
|
||||
`*Node.js Version:* \`${nodeVersion}\`\n` +
|
||||
`*CPU:* \`${cpuModel}\`\n` +
|
||||
`*CPU Cores:* \`${cpuCores} cores\`\n` +
|
||||
`*RAM:* \`${freeMemory} / ${totalMemory}\`\n` +
|
||||
`*Load Average:* \`${loadAverage}\`\n` +
|
||||
`*Uptime:* \`${uptime}\`\n\n`;
|
||||
}
|
||||
|
||||
// Função para obter informações do usuário
|
||||
async function getUserInfo(ctx) {
|
||||
let userInfoTemplate = Strings.userInfo;
|
||||
|
||||
|
@ -21,6 +54,7 @@ async function getUserInfo(ctx) {
|
|||
return userInfoTemplate;
|
||||
}
|
||||
|
||||
// Função para obter informações do chat
|
||||
async function getChatInfo(ctx) {
|
||||
if (ctx.chat.type === 'group' || ctx.chat.type === 'supergroup') {
|
||||
let chatInfoTemplate = Strings.chatInfo;
|
||||
|
@ -30,7 +64,6 @@ async function getChatInfo(ctx) {
|
|||
const chatHandle = ctx.chat.username ? `@${ctx.chat.username}` : Strings.varNone;
|
||||
const chatType = ctx.chat.type || Strings.unKnown;
|
||||
|
||||
// Aguarde a contagem de membros ser resolvida
|
||||
const chatMembersCount = await ctx.telegram.getChatMembersCount(chatId);
|
||||
const isForum = ctx.chat.is_forum ? Strings.varYes : Strings.varNo;
|
||||
|
||||
|
@ -49,6 +82,20 @@ async function getChatInfo(ctx) {
|
|||
}
|
||||
|
||||
module.exports = (bot) => {
|
||||
bot.command('stats', (ctx) => {
|
||||
const userId = ctx.from.id || Strings.unKnown;
|
||||
if (Config.admins.includes(userId)) {
|
||||
const machineStats = getSystemInfo();
|
||||
ctx.reply(
|
||||
machineStats, {
|
||||
parse_mode: 'Markdown'
|
||||
}
|
||||
);
|
||||
} else {
|
||||
ctx.reply(Strings.noPermission);
|
||||
}
|
||||
});
|
||||
|
||||
bot.command('chatinfo', async (ctx) => {
|
||||
const chatInfo = await getChatInfo(ctx);
|
||||
ctx.reply(
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue