summary refs log tree commit diff
diff options
context:
space:
mode:
authorFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-03-04 22:01:25 +0100
committerFlam3rboy <34555296+Flam3rboy@users.noreply.github.com>2021-03-04 22:01:25 +0100
commit1dd1e5724f8d654f3e7e4f3ed3eccf017391e7f7 (patch)
treee97efbd961576167b5dbe8781f5e6215b8c60a5a
parent:sparkles: [Guild] channels (diff)
downloadserver-1dd1e5724f8d654f3e7e4f3ed3eccf017391e7f7.tar.xz
:art: improve guilds
-rw-r--r--src/routes/api/v8/guilds/#id/bans.ts2
-rw-r--r--src/routes/api/v8/guilds/#id/index.ts23
-rw-r--r--src/routes/api/v8/guilds/#id/members.ts (renamed from src/routes/api/v8/guilds/#id/members/index.ts)12
-rw-r--r--src/routes/api/v8/guilds/index.ts4
4 files changed, 28 insertions, 13 deletions
diff --git a/src/routes/api/v8/guilds/#id/bans.ts b/src/routes/api/v8/guilds/#id/bans.ts

index 8e6e35de..aaae39cb 100644 --- a/src/routes/api/v8/guilds/#id/bans.ts +++ b/src/routes/api/v8/guilds/#id/bans.ts
@@ -65,7 +65,7 @@ router.delete("/:userid", async (req: Request, res: Response) => { var banned_user_id = BigInt(req.params.userid); const banned_user = await getPublicUser(banned_user_id); - const guild = await GuildModel.findOne({ id: guild_id }).exec(); + const guild = await GuildModel.findOne({ id: guild_id }, { id: true }).exec(); if (!guild) throw new HTTPError("Guild not found", 404); const perms = await getPermission(req.userid, guild.id); diff --git a/src/routes/api/v8/guilds/#id/index.ts b/src/routes/api/v8/guilds/#id/index.ts
index 38fbd5f2..09f2a5c2 100644 --- a/src/routes/api/v8/guilds/#id/index.ts +++ b/src/routes/api/v8/guilds/#id/index.ts
@@ -1,5 +1,16 @@ import { Request, Response, Router } from "express"; -import { getPermission, GuildDeleteEvent, GuildModel, MemberModel } from "fosscord-server-util"; +import { + ChannelModel, + EmojiModel, + getPermission, + GuildDeleteEvent, + GuildModel, + InviteModel, + MemberModel, + MessageModel, + RoleModel, + UserModel, +} from "fosscord-server-util"; import { HTTPError } from "lambert-server"; import { GuildUpdateSchema } from "../../../../../schema/Guild"; import { emitEvent } from "../../../../../util/Event"; @@ -11,7 +22,7 @@ router.get("/", async (req: Request, res: Response) => { const guild_id = BigInt(req.params.id); const guild = await GuildModel.findOne({ id: guild_id }).exec(); - if (!guild) throw new HTTPError("Guild does not exist"); + if (!guild) throw new HTTPError("Guild does not exist", 404); const member = await MemberModel.findOne({ guild_id: guild_id, id: req.userid }, "id").exec(); if (!member) throw new HTTPError("You are not a member of the guild you are trying to access", 401); @@ -36,7 +47,7 @@ router.patch("/", check(GuildUpdateSchema), async (req: Request, res: Response) router.delete("/", async (req: Request, res: Response) => { var guild_id = BigInt(req.params.id); - const guild = await GuildModel.findOne({ id: BigInt(req.params.id) }, "owner_id").exec(); + const guild = await GuildModel.findOne({ id: guild_id }, "owner_id").exec(); if (!guild) throw new HTTPError("This guild does not exist", 404); if (guild.owner_id !== req.userid) throw new HTTPError("You are not the owner of this guild", 401); @@ -49,6 +60,12 @@ router.delete("/", async (req: Request, res: Response) => { } as GuildDeleteEvent); await GuildModel.deleteOne({ id: guild_id }).exec(); + await UserModel.updateMany({ guilds: guild_id }, { $pull: { guilds: guild_id } }).exec(); + await RoleModel.deleteMany({ guild_id }).exec(); + await ChannelModel.deleteMany({ guild_id }).exec(); + await EmojiModel.deleteMany({ guild_id }).exec(); + await InviteModel.deleteMany({ guild_id }).exec(); + await MessageModel.deleteMany({ guild_id }).exec(); return res.status(204).send(); }); diff --git a/src/routes/api/v8/guilds/#id/members/index.ts b/src/routes/api/v8/guilds/#id/members.ts
index 3b422dd0..0aed61ae 100644 --- a/src/routes/api/v8/guilds/#id/members/index.ts +++ b/src/routes/api/v8/guilds/#id/members.ts
@@ -1,9 +1,9 @@ import { Request, Response, Router } from "express"; import { GuildModel, MemberModel } from "fosscord-server-util"; import { HTTPError } from "lambert-server"; -import { instanceOf, Length } from "../../../../../../util/instanceOf"; -import { PublicMemberProjection } from "../../../../../../util/Member"; -import { PublicUserProjection } from "../../../../../../util/User"; +import { instanceOf, Length } from "../../../../../util/instanceOf"; +import { PublicMemberProjection } from "../../../../../util/Member"; +import { PublicUserProjection } from "../../../../../util/User"; const router = Router(); @@ -21,7 +21,7 @@ router.get("/", async (req: Request, res: Response) => { ref: { obj: null, key: "" }, }); } catch (error) { - return res.status(400).json({ code: 50035, message: "Invalid Form Body", success: false, errors: error }); + return res.status(400).json({ code: 50035, message: "Invalid Query", success: false, errors: error }); } // @ts-ignore @@ -41,9 +41,7 @@ router.get("/:member", async (req: Request, res: Response) => { const guild_id = BigInt(req.params.id); const user_id = BigInt(req.params.member); - const member = await MemberModel.findOne({ id: user_id, guild_id }) - .populate({ path: "user", select: PublicUserProjection }) - .exec(); + const member = await MemberModel.findOne({ id: user_id, guild_id }).populate({ path: "user", select: PublicUserProjection }).exec(); if (!member) throw new HTTPError("Member not found", 404); return res.json(member); diff --git a/src/routes/api/v8/guilds/index.ts b/src/routes/api/v8/guilds/index.ts
index 54b2d2a4..7179ea9e 100644 --- a/src/routes/api/v8/guilds/index.ts +++ b/src/routes/api/v8/guilds/index.ts
@@ -59,8 +59,8 @@ router.post("/", check(GuildCreateSchema), async (req: Request, res: Response) = }; await Promise.all([ - await new GuildModel(guild).save(), - await new RoleModel({ + new GuildModel(guild).save(), + new RoleModel({ id: guild_id, guild_id: guild_id, color: 0,