mirror of
https://github.com/toast-ts/Daggerbot-TS.git
synced 2024-11-17 04:10:59 -05:00
Trim some unnecessary stuff
This commit is contained in:
parent
624560e684
commit
eef4a72315
@ -208,16 +208,8 @@ export default class MP {
|
|||||||
if (!interaction.member.roles.cache.has(client.config.dcServer.roles.mpmanager) && !interaction.member.roles.cache.has(client.config.dcServer.roles.bottech)) return MessageTool.youNeedRole(interaction, 'mpmanager');
|
if (!interaction.member.roles.cache.has(client.config.dcServer.roles.mpmanager) && !interaction.member.roles.cache.has(client.config.dcServer.roles.bottech)) return MessageTool.youNeedRole(interaction, 'mpmanager');
|
||||||
}
|
}
|
||||||
const toggleFlag = interaction.options.getBoolean('is_active');
|
const toggleFlag = interaction.options.getBoolean('is_active');
|
||||||
const submitFlagUpdate = await client.MPServer.toggleServerUsability(choiceSelector, toggleFlag);
|
Logger.console('log', logPrefix, `Toggling isActive flag for "${choiceSelector}" to ${toggleFlag}`);
|
||||||
Logger.console('log', logPrefix, `Toggling isActive flag for ${choiceSelector} to ${toggleFlag}`);
|
await client.MPServer.toggleServerUsability(choiceSelector, toggleFlag).then(async()=>await interaction.reply(`**${choiceSelector}** is now ${toggleFlag ? 'visible to' : 'hidden from'} public`));
|
||||||
let visibilityTxt = `**${choiceSelector}** is now `;
|
|
||||||
if (toggleFlag) {
|
|
||||||
submitFlagUpdate
|
|
||||||
await interaction.reply(visibilityTxt += 'visible to public');
|
|
||||||
} else if (!toggleFlag) {
|
|
||||||
submitFlagUpdate
|
|
||||||
await interaction.reply(visibilityTxt += 'hidden from public');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
})[interaction.options.getSubcommand() ?? interaction.options.getSubcommandGroup()]();
|
})[interaction.options.getSubcommand() ?? interaction.options.getSubcommandGroup()]();
|
||||||
}
|
}
|
||||||
|
@ -37,14 +37,13 @@ export default async(client:TClient)=>{
|
|||||||
timeScale: isNaN(Number(csg?.settings?.timeScale)) ? dataUnavailable : formatTimescale(Number(csg?.settings?.timeScale), 0, 'x')
|
timeScale: isNaN(Number(csg?.settings?.timeScale)) ? dataUnavailable : formatTimescale(Number(csg?.settings?.timeScale), 0, 'x')
|
||||||
}
|
}
|
||||||
|
|
||||||
function slotUsageFillbar(curr:number, max:number, barLength:number):string {
|
function slotUsageFillbar(curr:number, max:number):string {
|
||||||
const filled = Math.floor(curr/max*barLength);
|
let barLen:number = 10;
|
||||||
return '▏' + '━'.repeat(filled) + '▪' + '╍'.repeat(barLength-filled) + '▕';
|
const filled = Math.floor(curr/max*barLen);
|
||||||
}
|
return '▏' + '━'.repeat(filled) + '▪' + '╍'.repeat(barLen-filled) + '▕';
|
||||||
const slotUsage = {
|
|
||||||
consoleLimit: Number(csg?.slotSystem?.slotUsage) >= 2600 ? 4400 : 2600,
|
|
||||||
text: `**${Intl.NumberFormat('en-us').format(Number(dataObj.slotSys))}**/**${Intl.NumberFormat('en-us').format(Number(csg?.slotSystem?.slotUsage) >= 2600 ? 4400 : 2600)}**`,
|
|
||||||
}
|
}
|
||||||
|
const consoleLimit = Number(csg?.slotSystem?.slotUsage) >= 2600 ? 4400 : 2600;
|
||||||
|
const slotUsageRatio = `**${Intl.NumberFormat('en-us').format(Number(dataObj.slotSys))}**/**${Intl.NumberFormat('en-us').format(consoleLimit)}**`;
|
||||||
|
|
||||||
// Format the raw players data into Discord format
|
// Format the raw players data into Discord format
|
||||||
let playerData:string[] = [];
|
let playerData:string[] = [];
|
||||||
@ -65,7 +64,7 @@ export default async(client:TClient)=>{
|
|||||||
{name: 'Map', value: dataObj.map, inline: true},
|
{name: 'Map', value: dataObj.map, inline: true},
|
||||||
{name: 'Version', value: dataObj.version, inline: true},
|
{name: 'Version', value: dataObj.version, inline: true},
|
||||||
{name: 'Time', value: dataObj.time, inline: true},
|
{name: 'Time', value: dataObj.time, inline: true},
|
||||||
{name: 'Slot usage', value: isNaN(Number(dataObj.slotSys)) ? dataUnavailable : `${slotUsage.text}\n\`${slotUsageFillbar(Number(csg?.slotSystem?.slotUsage), slotUsage.consoleLimit, 10)}\``, inline: true},
|
{name: 'Slot usage', value: isNaN(Number(dataObj.slotSys)) ? dataUnavailable : `${slotUsageRatio}\n\`${slotUsageFillbar(Number(csg?.slotSystem?.slotUsage), consoleLimit)}\``, inline: true},
|
||||||
{name: 'Autosave', value: dataObj.autoSave+' mins', inline: true},
|
{name: 'Autosave', value: dataObj.autoSave+' mins', inline: true},
|
||||||
{name: 'Timescale', value: dataObj.timeScale, inline: true}
|
{name: 'Timescale', value: dataObj.timeScale, inline: true}
|
||||||
];
|
];
|
||||||
@ -91,26 +90,10 @@ export default async(client:TClient)=>{
|
|||||||
|
|
||||||
async function multifarmWebhook(client:TClient, server:IServer, webhookId:string, messageId:string) {
|
async function multifarmWebhook(client:TClient, server:IServer, webhookId:string, messageId:string) {
|
||||||
const txtMapping = {
|
const txtMapping = {
|
||||||
genericBools: {
|
genericBools: { 'false': 'Off', 'true': 'On' },
|
||||||
'false': 'Off',
|
growthMode: { '1': 'Yes', '2': 'No', '3': 'Growth paused' },
|
||||||
'true': 'On'
|
fuelUsage: { '1': 'Low', '2': 'Normal', '3': 'High' },
|
||||||
},
|
dirtInterval: { '1': 'Off', '2': 'Slow', '3': 'Normal', '4': 'Fast' }
|
||||||
growthMode: {
|
|
||||||
'1': 'Yes',
|
|
||||||
'2': 'No',
|
|
||||||
'3': 'Growth paused'
|
|
||||||
},
|
|
||||||
fuelUsage: {
|
|
||||||
'1': 'Low',
|
|
||||||
'2': 'Normal',
|
|
||||||
'3': 'High'
|
|
||||||
},
|
|
||||||
dirtInterval: {
|
|
||||||
'1': 'Off',
|
|
||||||
'2': 'Slow',
|
|
||||||
'3': 'Normal',
|
|
||||||
'4': 'Fast'
|
|
||||||
}
|
|
||||||
};
|
};
|
||||||
const getMappedValue =<T>(map:Record<string, T>, key:string, fallback:T):T=>map[key] ?? fallback;
|
const getMappedValue =<T>(map:Record<string, T>, key:string, fallback:T):T=>map[key] ?? fallback;
|
||||||
const data = await requestServerData(client, server);
|
const data = await requestServerData(client, server);
|
||||||
@ -127,8 +110,8 @@ async function multifarmWebhook(client:TClient, server:IServer, webhookId:string
|
|||||||
{name: 'Dirt Interval', value: getMappedValue(txtMapping.dirtInterval, csg?.settings.dirtInterval, dataUnavailable), inline: true}
|
{name: 'Dirt Interval', value: getMappedValue(txtMapping.dirtInterval, csg?.settings.dirtInterval, dataUnavailable), inline: true}
|
||||||
];
|
];
|
||||||
return new HookMgr(client, 'multifarm_chat', webhookId).edit(messageId, {
|
return new HookMgr(client, 'multifarm_chat', webhookId).edit(messageId, {
|
||||||
content: refreshIntrvlTxt, embeds: [
|
content: refreshIntrvlTxt, embeds: [new client.embed()
|
||||||
new client.embed().setColor(client.config.embedColor).setTitle(`Savegame Settings - ${csg?.settings?.mapTitle}`).addFields(fields).setFooter({text: 'Last updated'}).setTimestamp()
|
.setColor(client.config.embedColor).setTitle(`Savegame Settings - ${csg?.settings?.mapTitle}`).addFields(fields).setFooter({text: 'Last updated'}).setTimestamp()
|
||||||
]
|
]
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -138,8 +121,9 @@ async function storePlayerCount(client:TClient, server:IServer, playerCount:numb
|
|||||||
}
|
}
|
||||||
|
|
||||||
export async function requestServerData(client:TClient, server:IServer):Promise<{dss:FSData, csg:FSCareerSavegame}|undefined>{
|
export async function requestServerData(client:TClient, server:IServer):Promise<{dss:FSData, csg:FSCareerSavegame}|undefined>{
|
||||||
async function retryReqs(url:string, maxRetries:number) {
|
async function retryReqs(url:string) {
|
||||||
// Attempt to reduce the failure rate of the requests before giving up and retrying in next refresh.
|
// Attempt to reduce the failure rate of the requests before giving up and retrying in next refresh.
|
||||||
|
let maxRetries:number = 3;
|
||||||
for (let i = 0; i < maxRetries; i++) {
|
for (let i = 0; i < maxRetries; i++) {
|
||||||
try {
|
try {
|
||||||
const data = await Undici.fetch(url, {keepalive: true, signal: AbortSignal.timeout(12000), headers: {'User-Agent': `${client.user.username} - MPModule/undici`}});
|
const data = await Undici.fetch(url, {keepalive: true, signal: AbortSignal.timeout(12000), headers: {'User-Agent': `${client.user.username} - MPModule/undici`}});
|
||||||
@ -154,8 +138,8 @@ export async function requestServerData(client:TClient, server:IServer):Promise<
|
|||||||
}
|
}
|
||||||
try {
|
try {
|
||||||
const [DSSR, CSGR] = await Promise.allSettled([
|
const [DSSR, CSGR] = await Promise.allSettled([
|
||||||
retryReqs('http://'+server.ip+'/feed/dedicated-server-stats.json?code='+server.code, 3).then(x=>x.json() as Promise<FSData>),
|
retryReqs('http://'+server.ip+'/feed/dedicated-server-stats.json?code='+server.code).then(x=>x.json() as Promise<FSData>),
|
||||||
retryReqs('http://'+server.ip+'/feed/dedicated-server-savegame.html?code='+server.code+'&file=careerSavegame', 3).then(async x=>(new XMLParser({ignoreAttributes: false, attributeNamePrefix: ''}).parse(await x.text())).careerSavegame as FSCareerSavegame)
|
retryReqs('http://'+server.ip+'/feed/dedicated-server-savegame.html?code='+server.code+'&file=careerSavegame').then(async x=>(new XMLParser({ignoreAttributes: false, attributeNamePrefix: ''}).parse(await x.text())).careerSavegame as FSCareerSavegame)
|
||||||
]);
|
]);
|
||||||
const dss = DSSR.status === 'fulfilled' && DSSR.value && DSSR.value.server ? DSSR.value : null;
|
const dss = DSSR.status === 'fulfilled' && DSSR.value && DSSR.value.server ? DSSR.value : null;
|
||||||
const csg = CSGR.status === 'fulfilled' && CSGR.value && CSGR.value.slotSystem ? CSGR.value : null;
|
const csg = CSGR.status === 'fulfilled' && CSGR.value && CSGR.value.slotSystem ? CSGR.value : null;
|
||||||
|
Loading…
Reference in New Issue
Block a user