From d85701a5b7fde84fa482de49c0f06a9ec90e1815 Mon Sep 17 00:00:00 2001 From: Flam3rboy <34555296+Flam3rboy@users.noreply.github.com> Date: Wed, 3 Mar 2021 21:24:34 +0100 Subject: :art: getPermission cache --- src/util/Permissions.ts | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) (limited to 'src/util') diff --git a/src/util/Permissions.ts b/src/util/Permissions.ts index 6d14e9a3..96a1a27c 100644 --- a/src/util/Permissions.ts +++ b/src/util/Permissions.ts @@ -1,10 +1,11 @@ // https://github.com/discordjs/discord.js/blob/master/src/util/Permissions.js // Apache License Version 2.0 Copyright 2015 - 2021 Amish Shah -import { MemberModel } from "../models/Member"; +import { MemberDocument, MemberModel } from "../models/Member"; import { ChannelDocument, ChannelModel } from "../models/Channel"; import { ChannelPermissionOverwrite } from "../models/Channel"; import { Role, RoleModel } from "../models/Role"; import { BitField } from "./BitField"; +import { GuildDocument } from "../models/Guild"; export type PermissionResolvable = bigint | number | Permissions | PermissionResolvable[] | PermissionString; @@ -142,12 +143,18 @@ export class Permissions extends BitField { } } -export async function getPermission(user_id: bigint, guild_id: bigint, channel_id?: bigint) { - var member = await MemberModel.findOne({ guild_id, id: user_id }, "roles").exec(); +export async function getPermission( + user_id: bigint, + guild_id: bigint, + channel_id?: bigint, + cache?: { channel: ChannelDocument | null; member: MemberDocument | null } +) { + var { channel, member } = cache || {}; + + member = await MemberModel.findOne({ guild_id, id: user_id }, "roles").exec(); if (!member) throw new Error("Member not found"); var roles = await RoleModel.find({ guild_id, id: { $in: member.roles } }).exec(); - let channel: ChannelDocument | null = null; if (channel_id) { channel = await ChannelModel.findOne({ id: channel_id }, "permission_overwrites").exec(); } -- cgit 1.5.1