summary refs log tree commit diff
path: root/src/routes/users/@me
diff options
context:
space:
mode:
Diffstat (limited to 'src/routes/users/@me')
-rw-r--r--src/routes/users/@me/affinities/guilds.ts10
-rw-r--r--src/routes/users/@me/guilds.ts55
-rw-r--r--src/routes/users/@me/index.ts15
-rw-r--r--src/routes/users/@me/library.ts10
-rw-r--r--src/routes/users/@me/settings.ts10
5 files changed, 100 insertions, 0 deletions
diff --git a/src/routes/users/@me/affinities/guilds.ts b/src/routes/users/@me/affinities/guilds.ts
new file mode 100644

index 00000000..ea0fe59d --- /dev/null +++ b/src/routes/users/@me/affinities/guilds.ts
@@ -0,0 +1,10 @@ +import { Router } from "express"; + +const router = Router(); + +router.get("/", (req, res) => { + // TODO: + res.status(200).send({ guild_affinities: [] }); +}); + +export default router; diff --git a/src/routes/users/@me/guilds.ts b/src/routes/users/@me/guilds.ts new file mode 100644
index 00000000..d0fbaa3e --- /dev/null +++ b/src/routes/users/@me/guilds.ts
@@ -0,0 +1,55 @@ +import { Router, Request, Response } from "express"; +import { GuildModel, MemberModel, UserModel, GuildDeleteEvent, GuildMemberRemoveEvent, toObject } from "fosscord-server-util"; +import { HTTPError } from "lambert-server"; +import { emitEvent } from "../../../util/Event"; +import { getPublicUser } from "../../../util/User"; + +const router: Router = Router(); + +router.get("/", async (req: Request, res: Response) => { + const user = await UserModel.findOne({ id: req.user_id }, { guilds: true }).exec(); + if (!user) throw new HTTPError("User not found", 404); + + var guildIDs = user.guilds || []; + var guild = await GuildModel.find({ id: { $in: guildIDs } }) + .populate({ path: "joined_at", match: { id: req.user_id } }) + .exec(); + + res.json(toObject(guild)); +}); + +// user send to leave a certain guild +router.delete("/:id", async (req: Request, res: Response) => { + const guild_id = req.params.id; + const guild = await GuildModel.findOne({ id: guild_id }, { guild_id: true }).exec(); + + if (!guild) throw new HTTPError("Guild doesn't exist", 404); + if (guild.owner_id === req.user_id) throw new HTTPError("You can't leave your own guild", 400); + + await Promise.all([ + MemberModel.deleteOne({ id: req.user_id, guild_id: guild_id }).exec(), + UserModel.updateOne({ id: req.user_id }, { $pull: { guilds: guild_id } }).exec(), + emitEvent({ + event: "GUILD_DELETE", + data: { + id: guild_id, + }, + user_id: req.user_id, + } as GuildDeleteEvent), + ]); + + const user = await getPublicUser(req.user_id); + + await emitEvent({ + event: "GUILD_MEMBER_REMOVE", + data: { + guild_id: guild_id, + user: user, + }, + guild_id: guild_id, + } as GuildMemberRemoveEvent); + + return res.status(204).send(); +}); + +export default router; diff --git a/src/routes/users/@me/index.ts b/src/routes/users/@me/index.ts new file mode 100644
index 00000000..32877dcc --- /dev/null +++ b/src/routes/users/@me/index.ts
@@ -0,0 +1,15 @@ +import { Router, Request, Response } from "express"; +import { UserModel } from "fosscord-server-util"; +import { HTTPError } from "lambert-server"; + +const router: Router = Router(); + +router.get("/", async (req: Request, res: Response) => { + // TODO: user projection + const user = await UserModel.findOne({ id: req.user_id }).exec(); + if (!user) throw new HTTPError("User not found", 404); + + res.json(user); +}); + +export default router; diff --git a/src/routes/users/@me/library.ts b/src/routes/users/@me/library.ts new file mode 100644
index 00000000..2ffff851 --- /dev/null +++ b/src/routes/users/@me/library.ts
@@ -0,0 +1,10 @@ +import { Router } from "express"; + +const router = Router(); + +router.get("/", (req, res) => { + // TODO: + res.status(200).send([]); +}); + +export default router; diff --git a/src/routes/users/@me/settings.ts b/src/routes/users/@me/settings.ts new file mode 100644
index 00000000..f1d95caf --- /dev/null +++ b/src/routes/users/@me/settings.ts
@@ -0,0 +1,10 @@ +import { Router } from "express"; + +const router = Router(); + +router.patch("/", (req, res) => { + // TODO: + res.sendStatus(204); +}); + +export default router;