🎨 improve guilds
This commit is contained in:
parent
008f2615e6
commit
1dd1e5724f
@ -65,7 +65,7 @@ router.delete("/:userid", async (req: Request, res: Response) => {
|
|||||||
var banned_user_id = BigInt(req.params.userid);
|
var banned_user_id = BigInt(req.params.userid);
|
||||||
|
|
||||||
const banned_user = await getPublicUser(banned_user_id);
|
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);
|
if (!guild) throw new HTTPError("Guild not found", 404);
|
||||||
|
|
||||||
const perms = await getPermission(req.userid, guild.id);
|
const perms = await getPermission(req.userid, guild.id);
|
||||||
|
@ -1,5 +1,16 @@
|
|||||||
import { Request, Response, Router } from "express";
|
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 { HTTPError } from "lambert-server";
|
||||||
import { GuildUpdateSchema } from "../../../../../schema/Guild";
|
import { GuildUpdateSchema } from "../../../../../schema/Guild";
|
||||||
import { emitEvent } from "../../../../../util/Event";
|
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_id = BigInt(req.params.id);
|
||||||
|
|
||||||
const guild = await GuildModel.findOne({ id: guild_id }).exec();
|
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();
|
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);
|
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) => {
|
router.delete("/", async (req: Request, res: Response) => {
|
||||||
var guild_id = BigInt(req.params.id);
|
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) 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);
|
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);
|
} as GuildDeleteEvent);
|
||||||
|
|
||||||
await GuildModel.deleteOne({ id: guild_id }).exec();
|
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();
|
return res.status(204).send();
|
||||||
});
|
});
|
||||||
|
@ -1,9 +1,9 @@
|
|||||||
import { Request, Response, Router } from "express";
|
import { Request, Response, Router } from "express";
|
||||||
import { GuildModel, MemberModel } from "fosscord-server-util";
|
import { GuildModel, MemberModel } from "fosscord-server-util";
|
||||||
import { HTTPError } from "lambert-server";
|
import { HTTPError } from "lambert-server";
|
||||||
import { instanceOf, Length } from "../../../../../../util/instanceOf";
|
import { instanceOf, Length } from "../../../../../util/instanceOf";
|
||||||
import { PublicMemberProjection } from "../../../../../../util/Member";
|
import { PublicMemberProjection } from "../../../../../util/Member";
|
||||||
import { PublicUserProjection } from "../../../../../../util/User";
|
import { PublicUserProjection } from "../../../../../util/User";
|
||||||
|
|
||||||
const router = Router();
|
const router = Router();
|
||||||
|
|
||||||
@ -21,7 +21,7 @@ router.get("/", async (req: Request, res: Response) => {
|
|||||||
ref: { obj: null, key: "" },
|
ref: { obj: null, key: "" },
|
||||||
});
|
});
|
||||||
} catch (error) {
|
} 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
|
// @ts-ignore
|
||||||
@ -41,9 +41,7 @@ router.get("/:member", async (req: Request, res: Response) => {
|
|||||||
const guild_id = BigInt(req.params.id);
|
const guild_id = BigInt(req.params.id);
|
||||||
const user_id = BigInt(req.params.member);
|
const user_id = BigInt(req.params.member);
|
||||||
|
|
||||||
const member = await MemberModel.findOne({ id: user_id, guild_id })
|
const member = await MemberModel.findOne({ id: user_id, guild_id }).populate({ path: "user", select: PublicUserProjection }).exec();
|
||||||
.populate({ path: "user", select: PublicUserProjection })
|
|
||||||
.exec();
|
|
||||||
if (!member) throw new HTTPError("Member not found", 404);
|
if (!member) throw new HTTPError("Member not found", 404);
|
||||||
|
|
||||||
return res.json(member);
|
return res.json(member);
|
@ -59,8 +59,8 @@ router.post("/", check(GuildCreateSchema), async (req: Request, res: Response) =
|
|||||||
};
|
};
|
||||||
|
|
||||||
await Promise.all([
|
await Promise.all([
|
||||||
await new GuildModel(guild).save(),
|
new GuildModel(guild).save(),
|
||||||
await new RoleModel({
|
new RoleModel({
|
||||||
id: guild_id,
|
id: guild_id,
|
||||||
guild_id: guild_id,
|
guild_id: guild_id,
|
||||||
color: 0,
|
color: 0,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user