mirror of
https://github.com/spacebarchat/server.git
synced 2024-11-11 13:14:06 +01:00
✨ Channel permission overwrites
This commit is contained in:
parent
5aaf803837
commit
c534248e0f
@ -1,16 +1,17 @@
|
|||||||
import { ChannelModel, ChannelPermissionOverwrite, getPermission, MemberModel, RoleModel } from "@fosscord/server-util";
|
import { ChannelModel, ChannelPermissionOverwrite, ChannelUpdateEvent, getPermission, MemberModel, RoleModel } from "@fosscord/server-util";
|
||||||
import { Router } from "express";
|
import { Router } from "express";
|
||||||
import { HTTPError } from "lambert-server";
|
import { HTTPError } from "lambert-server";
|
||||||
|
import { emitEvent } from "../../../util/Event";
|
||||||
import { check } from "../../../util/instanceOf";
|
import { check } from "../../../util/instanceOf";
|
||||||
const router: Router = Router();
|
const router: Router = Router();
|
||||||
|
|
||||||
// TODO: Only permissions your bot has in the guild or channel can be allowed/denied (unless your bot has a MANAGE_ROLES overwrite in the channel)
|
// TODO: Only permissions your bot has in the guild or channel can be allowed/denied (unless your bot has a MANAGE_ROLES overwrite in the channel)
|
||||||
|
|
||||||
router.put("/:overwrite_id", check({ allow: BigInt, deny: BigInt, type: Number }), async (req, res) => {
|
router.put("/:overwrite_id", check({ allow: String, deny: String, type: Number, id: String }), async (req, res) => {
|
||||||
const { channel_id, overwrite_id } = req.params;
|
const { channel_id, overwrite_id } = req.params;
|
||||||
const body = req.body as { allow: bigint; deny: bigint; type: number };
|
const body = req.body as { allow: bigint; deny: bigint; type: number; id: string };
|
||||||
|
|
||||||
const channel = await ChannelModel.findOne({ id: channel_id }).exec();
|
var channel = await ChannelModel.findOne({ id: channel_id }, { guild_id: true, permission_overwrites: true }).exec();
|
||||||
if (!channel || !channel.guild_id) throw new HTTPError("Channel not found", 404);
|
if (!channel || !channel.guild_id) throw new HTTPError("Channel not found", 404);
|
||||||
|
|
||||||
const permissions = await getPermission(req.user_id, channel.guild_id, channel_id);
|
const permissions = await getPermission(req.user_id, channel.guild_id, channel_id);
|
||||||
@ -19,7 +20,7 @@ router.put("/:overwrite_id", check({ allow: BigInt, deny: BigInt, type: Number }
|
|||||||
if (body.type === 0) {
|
if (body.type === 0) {
|
||||||
if (!(await RoleModel.exists({ id: overwrite_id }))) throw new HTTPError("role not found", 404);
|
if (!(await RoleModel.exists({ id: overwrite_id }))) throw new HTTPError("role not found", 404);
|
||||||
} else if (body.type === 1) {
|
} else if (body.type === 1) {
|
||||||
if (await MemberModel.exists({ id: overwrite_id })) throw new HTTPError("user not found", 404);
|
if (!(await MemberModel.exists({ id: overwrite_id }))) throw new HTTPError("user not found", 404);
|
||||||
} else throw new HTTPError("type not supported");
|
} else throw new HTTPError("type not supported");
|
||||||
|
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
@ -28,14 +29,44 @@ router.put("/:overwrite_id", check({ allow: BigInt, deny: BigInt, type: Number }
|
|||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
overwrite = {
|
overwrite = {
|
||||||
id: overwrite_id,
|
id: overwrite_id,
|
||||||
type: body.type
|
type: body.type,
|
||||||
|
allow: body.allow,
|
||||||
|
deny: body.deny
|
||||||
};
|
};
|
||||||
channel.permission_overwrites.push(overwrite);
|
channel.permission_overwrites.push(overwrite);
|
||||||
}
|
}
|
||||||
overwrite.allow = body.allow;
|
overwrite.allow = body.allow;
|
||||||
overwrite.deny = body.deny;
|
overwrite.deny = body.deny;
|
||||||
|
|
||||||
await ChannelModel.updateOne({ id: channel_id }, channel).exec();
|
channel = await ChannelModel.findOneAndUpdate({ id: channel_id }, channel).exec();
|
||||||
|
if (!channel) throw new HTTPError("Channel not found", 404);
|
||||||
|
|
||||||
|
await emitEvent({
|
||||||
|
event: "CHANNEL_UPDATE",
|
||||||
|
channel_id,
|
||||||
|
guild_id: channel.guild_id,
|
||||||
|
data: channel
|
||||||
|
} as ChannelUpdateEvent);
|
||||||
|
|
||||||
|
return res.sendStatus(204);
|
||||||
|
});
|
||||||
|
|
||||||
|
// TODO: check permission hierarchy
|
||||||
|
router.delete("/:overwrite_id", async (req, res) => {
|
||||||
|
const { channel_id, overwrite_id } = req.params;
|
||||||
|
|
||||||
|
const permissions = await getPermission(req.user_id, undefined, channel_id);
|
||||||
|
permissions.hasThrow("MANAGE_ROLES");
|
||||||
|
|
||||||
|
const channel = await ChannelModel.findOneAndUpdate({ id: channel_id }, { $pull: { permission_overwrites: { id: overwrite_id } } });
|
||||||
|
if (!channel || !channel.guild_id) throw new HTTPError("Channel not found", 404);
|
||||||
|
|
||||||
|
await emitEvent({
|
||||||
|
event: "CHANNEL_UPDATE",
|
||||||
|
channel_id,
|
||||||
|
guild_id: channel.guild_id,
|
||||||
|
data: channel
|
||||||
|
} as ChannelUpdateEvent);
|
||||||
|
|
||||||
return res.sendStatus(204);
|
return res.sendStatus(204);
|
||||||
});
|
});
|
||||||
|
Loading…
Reference in New Issue
Block a user