SquadJS/squad-server/utils/admin-lists.js

80 lines
2.3 KiB
JavaScript
Raw Normal View History

2020-11-10 10:31:24 -06:00
import fs from 'fs';
import path from 'path';
import { fileURLToPath } from 'url';
2020-11-07 17:43:08 -06:00
import axios from 'axios';
import Logger from 'core/logger';
2020-11-10 10:31:24 -06:00
const __dirname = fileURLToPath(import.meta.url);
2020-11-07 18:10:55 -06:00
export default async function fetchAdminLists(adminLists) {
2020-11-07 19:23:21 -06:00
Logger.verbose('SquadServer', 2, `Fetching Admin Lists...`);
2020-11-07 18:10:55 -06:00
const groups = {};
const admins = {};
for (let idx = 0; idx < adminLists.length; idx++) {
const list = adminLists[idx];
2020-11-10 10:31:24 -06:00
try {
let data = '';
2020-11-07 18:10:55 -06:00
2020-11-10 10:31:24 -06:00
switch (list.type) {
case 'remote': {
const resp = await axios({
method: 'GET',
2020-12-08 11:26:31 -06:00
url: `${list.source}`
2020-11-10 10:31:24 -06:00
});
data = resp.data;
break;
}
case 'local': {
2020-12-08 11:26:31 -06:00
const listPath = path.resolve(__dirname, '../../../', list.source);
2020-11-10 10:31:24 -06:00
if (!fs.existsSync(listPath)) throw new Error(`Could not find Admin List at ${listPath}`);
data = fs.readFileSync(listPath, 'utf8');
break;
}
default:
throw new Error(`Unsupported AdminList type:${list.type}`);
2020-11-07 18:10:55 -06:00
}
2020-11-07 17:43:08 -06:00
2020-11-10 10:31:24 -06:00
const groupRgx = /(?<=Group=)(.*?):(.*)(?=(?:\r\n|\r|\n))/g;
const adminRgx = /(?<=Admin=)(\d+):(\S+)(?=\s)/g;
2020-11-07 18:10:55 -06:00
2020-11-10 10:31:24 -06:00
/* eslint-disable no-unused-vars */
for (const [match, groupID, groupPerms] of data.matchAll(groupRgx)) {
groups[`${idx}-${groupID}`] = groupPerms.split(',');
}
for (const [match, steamID, groupID] of data.matchAll(adminRgx)) {
const perms = {};
for (const perm of groups[`${idx}-${groupID}`]) perms[perm] = true;
2020-11-07 18:10:55 -06:00
2020-11-10 10:31:24 -06:00
if (steamID in admins) {
admins[steamID] = Object.assign(admins[steamID], perms);
Logger.verbose(
'SquadServer',
3,
`Merged duplicate Admin ${steamID} to ${Object.keys(admins[steamID])}`
);
} else {
admins[steamID] = Object.assign(perms);
Logger.verbose(
'SquadServer',
3,
`Added Admin ${steamID} with ${Object.keys(admins[steamID])}`
);
}
}
/* eslint-enable no-unused-vars */
} catch (error) {
2020-11-07 18:10:55 -06:00
Logger.verbose(
'SquadServer',
2020-11-10 10:31:24 -06:00
1,
2020-12-08 11:26:31 -06:00
`Error fetching ${list.type} admin list: ${list.source}`,
2020-11-10 10:31:24 -06:00
error
2020-11-07 18:10:55 -06:00
);
}
}
2020-11-10 10:31:24 -06:00
Logger.verbose('SquadServer', 1, `${Object.keys(admins).length} admins loaded...`);
2020-11-07 18:10:55 -06:00
return admins;
}