Merge branch 'dev'
commit
d19b21c27c
|
@ -3,7 +3,7 @@ import { createPaginationEmbed } from 'eris-pagination';
|
||||||
import { Client, Command, RichEmbed } from '../class';
|
import { Client, Command, RichEmbed } from '../class';
|
||||||
import { members } from '.';
|
import { members } from '.';
|
||||||
|
|
||||||
export default class extends Command {
|
export default class Members extends Command {
|
||||||
constructor(client: Client) {
|
constructor(client: Client) {
|
||||||
super(client);
|
super(client);
|
||||||
this.name = 'members';
|
this.name = 'members';
|
||||||
|
|
|
@ -75,17 +75,18 @@ function logNewPager(client: Client, num: string, member: Member): void {
|
||||||
channel.createMessage(`__**'${member.user.username}#${member.user.discriminator}' assigned to pager number '${num}'.**__`);
|
channel.createMessage(`__**'${member.user.username}#${member.user.discriminator}' assigned to pager number '${num}'.**__`);
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function departmentPager(client: Client): NodeJS.Timeout {
|
export default async function departmentPager(client: Client): Promise<NodeJS.Timeout> {
|
||||||
setupDepartmentCodes(client);
|
setupDepartmentCodes(client);
|
||||||
interval = setInterval(async () => {
|
async function start() {
|
||||||
const acknowledgements = require(`${__dirname}/../configs/acknowledgements.json`);
|
const acknowledgements = require(`${__dirname}/../configs/acknowledgements.json`);
|
||||||
function resolveStaffInformation(id: string) {
|
function resolveStaffInformation(id: string) {
|
||||||
return acknowledgements.find((m) => m.id === id);
|
return acknowledgements.find((m) => m.id === id);
|
||||||
}
|
}
|
||||||
await client.guilds.get(client.config.guildID).fetchAllMembers();
|
// await client.guilds.get(client.config.guildID).fetchAllMembers();
|
||||||
const { members } = client.guilds.get(client.config.guildID);
|
const { members } = client.guilds.get(client.config.guildID);
|
||||||
|
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
const pager = await client.db.PagerNumber.findOne({ individualAssignID: member.id }).lean().exec();
|
const pager = await client.db.PagerNumber.findOne({ individualAssignID: member.id }).lean().exec();
|
||||||
if (!pager) continue;
|
if (!pager) continue;
|
||||||
if (pager.num.startsWith('00') && !member.roles.includes('662163685439045632')) {
|
if (pager.num.startsWith('00') && !member.roles.includes('662163685439045632')) {
|
||||||
|
@ -116,7 +117,8 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
|
|
||||||
// const takenPagers = new Set<string>();
|
// const takenPagers = new Set<string>();
|
||||||
|
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
let pager = await client.db.PagerNumber.findOne({ individualAssignID: member.id }).lean().exec();
|
let pager = await client.db.PagerNumber.findOne({ individualAssignID: member.id }).lean().exec();
|
||||||
// Directors
|
// Directors
|
||||||
if (!pager && member.roles.includes('662163685439045632')) {
|
if (!pager && member.roles.includes('662163685439045632')) {
|
||||||
|
@ -277,7 +279,8 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
|
|
||||||
// Associates
|
// Associates
|
||||||
const associatePagers = await client.db.PagerNumber.findOne({ num: '22' });
|
const associatePagers = await client.db.PagerNumber.findOne({ num: '22' });
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
if (member.roles.includes('701481967149121627') && !associatePagers.discordIDs.includes(member.id)) {
|
if (member.roles.includes('701481967149121627') && !associatePagers.discordIDs.includes(member.id)) {
|
||||||
await associatePagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
await associatePagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
||||||
const acknowledgement = resolveStaffInformation(member.id);
|
const acknowledgement = resolveStaffInformation(member.id);
|
||||||
|
@ -291,7 +294,8 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
}
|
}
|
||||||
// Core Team
|
// Core Team
|
||||||
const coreTeamPagers = await client.db.PagerNumber.findOne({ num: '21' });
|
const coreTeamPagers = await client.db.PagerNumber.findOne({ num: '21' });
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
if (member.roles.includes('453689940140883988') && !coreTeamPagers.discordIDs.includes(member.id)) {
|
if (member.roles.includes('453689940140883988') && !coreTeamPagers.discordIDs.includes(member.id)) {
|
||||||
await coreTeamPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
await coreTeamPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
||||||
const acknowledgement = resolveStaffInformation(member.id);
|
const acknowledgement = resolveStaffInformation(member.id);
|
||||||
|
@ -305,7 +309,8 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
}
|
}
|
||||||
// Moderator
|
// Moderator
|
||||||
const moderatorPagers = await client.db.PagerNumber.findOne({ num: '20' });
|
const moderatorPagers = await client.db.PagerNumber.findOne({ num: '20' });
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
if (member.roles.includes('455972169449734144') && !moderatorPagers.discordIDs.includes(member.id)) {
|
if (member.roles.includes('455972169449734144') && !moderatorPagers.discordIDs.includes(member.id)) {
|
||||||
await moderatorPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
await moderatorPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
||||||
const acknowledgement = resolveStaffInformation(member.id);
|
const acknowledgement = resolveStaffInformation(member.id);
|
||||||
|
@ -319,7 +324,8 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
}
|
}
|
||||||
// Technician
|
// Technician
|
||||||
const technicianPagers = await client.db.PagerNumber.findOne({ num: '10' });
|
const technicianPagers = await client.db.PagerNumber.findOne({ num: '10' });
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
if (member.roles.includes('701454780828221450') && !technicianPagers.discordIDs.includes(member.id)) {
|
if (member.roles.includes('701454780828221450') && !technicianPagers.discordIDs.includes(member.id)) {
|
||||||
await technicianPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
await technicianPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
||||||
const acknowledgement = resolveStaffInformation(member.id);
|
const acknowledgement = resolveStaffInformation(member.id);
|
||||||
|
@ -333,7 +339,8 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
}
|
}
|
||||||
// Supervisor
|
// Supervisor
|
||||||
const supervisorPagers = await client.db.PagerNumber.findOne({ num: '01' });
|
const supervisorPagers = await client.db.PagerNumber.findOne({ num: '01' });
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
if (member.roles.includes('701454855952138300') && !supervisorPagers.discordIDs.includes(member.id)) {
|
if (member.roles.includes('701454855952138300') && !supervisorPagers.discordIDs.includes(member.id)) {
|
||||||
await supervisorPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
await supervisorPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
||||||
const acknowledgement = resolveStaffInformation(member.id);
|
const acknowledgement = resolveStaffInformation(member.id);
|
||||||
|
@ -347,7 +354,8 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
}
|
}
|
||||||
// Board of Directors
|
// Board of Directors
|
||||||
const directorPagers = await client.db.PagerNumber.findOne({ num: '00' });
|
const directorPagers = await client.db.PagerNumber.findOne({ num: '00' });
|
||||||
for (const member of members.values()) {
|
for (let member of members.values()) {
|
||||||
|
member = await client.guilds.get(client.config.guildID).getRESTMember(member.id);
|
||||||
if (member.roles.includes('662163685439045632') && !directorPagers.discordIDs.includes(member.id)) {
|
if (member.roles.includes('662163685439045632') && !directorPagers.discordIDs.includes(member.id)) {
|
||||||
await directorPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
await directorPagers.updateOne({ $addToSet: { discordIDs: member.id } });
|
||||||
const acknowledgement = resolveStaffInformation(member.id);
|
const acknowledgement = resolveStaffInformation(member.id);
|
||||||
|
@ -359,6 +367,14 @@ export default function departmentPager(client: Client): NodeJS.Timeout {
|
||||||
if (acknowledgement?.emailAddress) await directorPagers.updateOne({ $pull: { emailAddresses: acknowledgement.emailAddress } });
|
if (acknowledgement?.emailAddress) await directorPagers.updateOne({ $pull: { emailAddresses: acknowledgement.emailAddress } });
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
client.util.signale.time('pagerint');
|
||||||
|
await start();
|
||||||
|
client.util.signale.timeEnd('pagerint');
|
||||||
|
interval = setInterval(async () => {
|
||||||
|
client.util.signale.time('pagerint');
|
||||||
|
await start();
|
||||||
|
client.util.signale.timeEnd('pagerint');
|
||||||
}, 300000);
|
}, 300000);
|
||||||
return interval;
|
return interval;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue