1
0
Fork 0
cloudservices/src/intervals/checkStaffStatus.ts

31 lines
1.6 KiB
TypeScript

/* eslint-disable no-await-in-loop */
import { Client } from '..';
export default function checkStaffStatus(client: Client) {
setInterval(async () => {
const accounts = await client.db.Account.find();
for (const acc of accounts) {
const user = client.guilds.get('446067825673633794').members.get(acc.userID) ?? await client.guilds.get('446067825673633794').getRESTMember(acc.userID);
if (!acc.permissions.facultyMarshal && user.roles.includes('662163685439045632')) {
await client.db.Account.updateOne({ username: acc.username }, { $set: { 'permissions.facultyMarshal': true } });
}
if (!acc.permissions.sheriff && user.roles.includes('455972169449734144')) {
await client.db.Account.updateOne({ username: acc.username }, { $set: { 'permissions.sheriff': true } });
}
if (!acc.permissions.staff && user.roles.includes('446104438969466890')) {
await client.db.Account.updateOne({ username: acc.username }, { $set: { 'permissions.staff': true } });
}
if (acc.permissions.facultyMarshal && !user.roles.includes('662163685439045632')) {
await client.db.Account.updateOne({ username: acc.username }, { $set: { 'permissions.facultyMarshal': false } });
}
if (acc.permissions.sheriff && !user.roles.includes('455972169449734144')) {
await client.db.Account.updateOne({ username: acc.username }, { $set: { 'permissions.sheriff': false } });
}
if (acc.permissions.staff && !user.roles.includes('446104438969466890')) {
await client.db.Account.updateOne({ username: acc.username }, { $set: { 'permissions.staff': false } });
}
}
}, 300000);
}