🐛 fix vanity url

This commit is contained in:
Flam3rboy 2021-08-19 21:28:57 +02:00
parent 30a2937d65
commit ec83db3d4e
4 changed files with 52 additions and 34 deletions

View File

@ -1,4 +1,4 @@
import { getPermission, GuildModel, InviteModel, trimSpecial } from "@fosscord/util"; import { ChannelModel, ChannelType, getPermission, GuildModel, InviteModel, trimSpecial } from "@fosscord/util";
import { Router, Request, Response } from "express"; import { Router, Request, Response } from "express";
import { HTTPError } from "lambert-server"; import { HTTPError } from "lambert-server";
import { check, Length } from "../../../util/instanceOf"; import { check, Length } from "../../../util/instanceOf";
@ -11,11 +11,14 @@ const InviteRegex = /\W/g;
router.get("/", async (req: Request, res: Response) => { router.get("/", async (req: Request, res: Response) => {
const { guild_id } = req.params; const { guild_id } = req.params;
await isMember(req.user_id, guild_id); const permission = await getPermission(req.user_id, guild_id);
const guild = await GuildModel.findOne({ id: guild_id }).exec(); permission.hasThrow("MANAGE_GUILD");
if (!guild.vanity_url) throw new HTTPError("This guild has no vanity url", 204);
return res.json({ code: guild.vanity_url.code }); const guild = await GuildModel.findOne({ id: guild_id }).exec();
if (!guild.vanity_url_code) return res.json({ code: null });
const { uses } = await InviteModel.findOne({ code: guild.vanity_url_code }).exec();
return res.json({ code: guild.vanity_url_code, uses });
}); });
// TODO: check if guild is elgible for vanity url // TODO: check if guild is elgible for vanity url
@ -24,11 +27,12 @@ router.patch("/", check({ code: new Length(String, 0, 20) }), async (req: Reques
var code = req.body.code.replace(InviteRegex); var code = req.body.code.replace(InviteRegex);
if (!code) code = null; if (!code) code = null;
const permission = await getPermission(req.user_id, guild_id); const guild = await GuildModel.findOne({ id: guild_id }).exec();
const permission = await getPermission(req.user_id, guild_id, undefined, { guild });
permission.hasThrow("MANAGE_GUILD"); permission.hasThrow("MANAGE_GUILD");
const alreadyExists = await Promise.all([ const alreadyExists = await Promise.all([
GuildModel.findOne({ "vanity_url.code": code }) GuildModel.findOne({ vanity_url_code: code })
.exec() .exec()
.catch(() => null), .catch(() => null),
InviteModel.findOne({ code: code }) InviteModel.findOne({ code: code })
@ -37,7 +41,19 @@ router.patch("/", check({ code: new Length(String, 0, 20) }), async (req: Reques
]); ]);
if (alreadyExists.some((x) => x)) throw new HTTPError("Vanity url already exists", 400); if (alreadyExists.some((x) => x)) throw new HTTPError("Vanity url already exists", 400);
await GuildModel.updateOne({ id: guild_id }, { "vanity_url.code": code }).exec(); await GuildModel.updateOne({ id: guild_id }, { vanity_url_code: code }).exec();
const { id } = await ChannelModel.findOne({ guild_id, type: ChannelType.GUILD_TEXT }).exec();
await InviteModel.updateOne(
{ code: guild.vanity_url_code },
{
code: code,
uses: 0,
created_at: new Date(),
guild_id,
channel_id: id
},
{ upsert: true }
).exec();
return res.json({ code: code }); return res.json({ code: code });
}); });

View File

@ -53,7 +53,7 @@ router.post("/", check(GuildCreateSchema), async (req: Request, res: Response) =
system_channel_flags: 0, system_channel_flags: 0,
system_channel_id: undefined, system_channel_id: undefined,
unavailable: false, unavailable: false,
vanity_url: undefined, vanity_url_code: undefined,
verification_level: 0, verification_level: 0,
welcome_screen: { welcome_screen: {
enabled: false, enabled: false,

View File

@ -1,5 +1,5 @@
import { Router, Request, Response } from "express"; import { Router, Request, Response } from "express";
import { getPermission, InviteModel, toObject } from "@fosscord/util"; import { getPermission, GuildModel, InviteModel, toObject } from "@fosscord/util";
import { HTTPError } from "lambert-server"; import { HTTPError } from "lambert-server";
import { addMember } from "../../util/Member"; import { addMember } from "../../util/Member";
const router: Router = Router(); const router: Router = Router();
@ -18,6 +18,7 @@ router.post("/:code", async (req: Request, res: Response) => {
const invite = await InviteModel.findOneAndUpdate({ code }, { $inc: { uses: 1 } }, { new: true }).exec(); const invite = await InviteModel.findOneAndUpdate({ code }, { $inc: { uses: 1 } }, { new: true }).exec();
if (!invite) throw new HTTPError("Unknown Invite", 404); if (!invite) throw new HTTPError("Unknown Invite", 404);
if (invite.uses >= invite.max_uses) await InviteModel.deleteOne({ code });
await addMember(req.user_id, invite.guild_id); await addMember(req.user_id, invite.guild_id);
@ -27,17 +28,20 @@ router.post("/:code", async (req: Request, res: Response) => {
router.delete("/:code", async (req: Request, res: Response) => { router.delete("/:code", async (req: Request, res: Response) => {
const { code } = req.params; const { code } = req.params;
const invite = await InviteModel.findOne({ code }).exec(); const invite = await InviteModel.findOne({ code }).exec();
if (!invite) throw new HTTPError("Unknown Invite", 404);
const { guild_id, channel_id } = invite; const { guild_id, channel_id } = invite;
const perms = await getPermission(req.user_id, guild_id, channel_id);
if (!perms.has("MANAGE_GUILD") && !perms.has("MANAGE_CHANNELS")) const guild = await GuildModel.findOne({ id: guild_id }).exec();
const permission = await getPermission(req.user_id, guild_id, channel_id, { guild });
if (!permission.has("MANAGE_GUILD") && !permission.has("MANAGE_CHANNELS"))
throw new HTTPError("You missing the MANAGE_GUILD or MANAGE_CHANNELS permission", 401); throw new HTTPError("You missing the MANAGE_GUILD or MANAGE_CHANNELS permission", 401);
await InviteModel.deleteOne({ code }).exec(); await InviteModel.deleteOne({ code }).exec();
await GuildModel.updateOne({ vanity_url_code: code }, { $unset: { vanity_url_code: 1 } })
.exec()
.catch((e) => {});
res.status(200).send({ invite: toObject(invite) }); res.status(200).send({ invite: toObject(invite) });
}); });

View File

@ -47,10 +47,7 @@ export interface Guild {
system_channel_flags?: number; system_channel_flags?: number;
system_channel_id?: string; system_channel_id?: string;
unavailable?: boolean; unavailable?: boolean;
vanity_url?: { vanity_url_code?: string;
code: string;
uses: number;
};
verification_level?: number; verification_level?: number;
welcome_screen: { welcome_screen: {
enabled: boolean; enabled: boolean;
@ -59,7 +56,8 @@ export interface Guild {
description: string; description: string;
emoji_id?: string; emoji_id?: string;
emoji_name: string; emoji_name: string;
channel_id: string }[]; channel_id: string;
}[];
}; };
widget_channel_id?: string; widget_channel_id?: string;
widget_enabled?: boolean; widget_enabled?: boolean;
@ -97,20 +95,20 @@ export const GuildSchema = new Schema({
system_channel_flags: Number, system_channel_flags: Number,
system_channel_id: String, system_channel_id: String,
unavailable: Boolean, unavailable: Boolean,
vanity_url: { vanity_url_code: String,
code: String,
uses: Number
},
verification_level: Number, verification_level: Number,
voice_states: { type: [Object], default: [] }, voice_states: { type: [Object], default: [] },
welcome_screen: { welcome_screen: {
enabled: Boolean, enabled: Boolean,
description: String, description: String,
welcome_channels: [{ welcome_channels: [
{
description: String, description: String,
emoji_id: String, emoji_id: String,
emoji_name: String, emoji_name: String,
channel_id: String }], channel_id: String,
},
],
}, },
widget_channel_id: String, widget_channel_id: String,
widget_enabled: Boolean, widget_enabled: Boolean,