Merge remote-tracking branch 'origin/master'

This commit is contained in:
AlTech98 2021-09-03 13:36:22 +02:00
commit 2028cc8e0b
6 changed files with 43 additions and 21 deletions

View File

@ -2,7 +2,6 @@ DROP TABLE applications;
DROP TABLE attachments; DROP TABLE attachments;
DROP TABLE audit_logs; DROP TABLE audit_logs;
DROP TABLE bans; DROP TABLE bans;
DROP TABLE channels;
DROP TABLE connected_accounts; DROP TABLE connected_accounts;
DROP TABLE emojis; DROP TABLE emojis;
DROP TABLE invites; DROP TABLE invites;
@ -24,6 +23,7 @@ DROP TABLE teams;
DROP TABLE templates; DROP TABLE templates;
DROP TABLE voice_states; DROP TABLE voice_states;
DROP TABLE webhooks; DROP TABLE webhooks;
DROP TABLE channels;
DROP TABLE members; DROP TABLE members;
DROP TABLE guilds; DROP TABLE guilds;
-- DROP TABLE users; -- DROP TABLE users;

View File

@ -30,18 +30,14 @@ router.patch("/", check(MemberChangeSchema), async (req: Request, res: Response)
const { guild_id, member_id } = req.params; const { guild_id, member_id } = req.params;
const body = req.body as MemberChangeSchema; const body = req.body as MemberChangeSchema;
const member = await Member.findOneOrFail({ where: { id: member_id, guild_id }, relations: ["roles", "user"] });
const permission = await getPermission(req.user_id, guild_id); const permission = await getPermission(req.user_id, guild_id);
if (body.roles) { if (body.roles) {
permission.hasThrow("MANAGE_ROLES"); permission.hasThrow("MANAGE_ROLES");
member.roles = body.roles.map((x) => new Role({ id: x })); // foreign key constraint will fail if role doesn't exist
const roles = await Role.find({ id: In(body.roles) });
if (body.roles.length !== roles.length) throw new HTTPError("Roles not found", 404);
} }
const member = await Member.findOneOrFail({ id: member_id, guild_id });
member.assign(req.body);
Promise.all([ Promise.all([
member.save(), member.save(),
emitEvent({ emitEvent({

View File

@ -20,7 +20,7 @@ router.post("/", check(GuildCreateSchema), async (req: Request, res: Response) =
const guild_id = Snowflake.generate(); const guild_id = Snowflake.generate();
const guild = await new Guild({ await Guild.insert({
name: body.name, name: body.name,
region: Config.get().regions.default, region: Config.get().regions.default,
owner_id: req.user_id, owner_id: req.user_id,
@ -47,10 +47,10 @@ router.post("/", check(GuildCreateSchema), async (req: Request, res: Response) =
welcome_channels: [] welcome_channels: []
}, },
widget_enabled: false widget_enabled: false
}).save(); });
// we have to create the role _after_ the guild because else we would get a "SQLITE_CONSTRAINT: FOREIGN KEY constraint failed" error // we have to create the role _after_ the guild because else we would get a "SQLITE_CONSTRAINT: FOREIGN KEY constraint failed" error
const role = await new Role({ await Role.insert({
id: guild_id, id: guild_id,
guild_id: guild_id, guild_id: guild_id,
color: 0, color: 0,
@ -60,7 +60,7 @@ router.post("/", check(GuildCreateSchema), async (req: Request, res: Response) =
name: "@everyone", name: "@everyone",
permissions: String("2251804225"), permissions: String("2251804225"),
position: 0 position: 0
}).save(); });
if (!body.channels || !body.channels.length) body.channels = [{ id: "01", type: 0, name: "general" }]; if (!body.channels || !body.channels.length) body.channels = [{ id: "01", type: 0, name: "general" }];

View File

@ -33,7 +33,7 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) {
const roles = await Role.find({ const roles = await Role.find({
where: { guild_id: guild_id }, where: { guild_id: guild_id },
order: { order: {
position: "ASC", position: "DESC",
}, },
}); });
@ -47,7 +47,7 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) {
); );
const group = { const group = {
count: role_members.length, count: role_members.length,
id: role.id === guild_id ? "online" : role.name, id: role.id === guild_id ? "online" : role.id,
}; };
items.push({ group }); items.push({ group });

View File

@ -54,13 +54,14 @@ export class Member extends BaseClassWithoutId {
@JoinTable({ @JoinTable({
name: "member_roles", name: "member_roles",
joinColumn: { name: "id", referencedColumnName: "index" },
joinColumn: { name: "index", referencedColumnName: "index" },
inverseJoinColumn: { inverseJoinColumn: {
name: "role_id", name: "role_id",
referencedColumnName: "id", referencedColumnName: "id",
}, },
}) })
@ManyToMany(() => Role) @ManyToMany(() => Role, { cascade: true })
roles: Role[]; roles: Role[];
@Column() @Column()
@ -208,7 +209,7 @@ export class Member extends BaseClassWithoutId {
where: { where: {
id: guild_id, id: guild_id,
}, },
relations: ["channels", "emojis", "members", "roles", "stickers"], relations: ["channels", "emojis", "members", "roles", "stickers", "voice_states"],
}); });
if (await Member.count({ id: user.id, guild: { id: guild_id } })) if (await Member.count({ id: user.id, guild: { id: guild_id } }))
@ -225,11 +226,9 @@ export class Member extends BaseClassWithoutId {
mute: false, mute: false,
pending: false, pending: false,
}; };
// @ts-ignore
guild.joined_at = member.joined_at.toISOString();
await Promise.all([ await Promise.all([
Member.insert({ new Member({
...member, ...member,
roles: [new Role({ id: guild_id })], roles: [new Role({ id: guild_id })],
// read_state: {}, // read_state: {},
@ -242,7 +241,8 @@ export class Member extends BaseClassWithoutId {
suppress_roles: false, suppress_roles: false,
version: 0, version: 0,
}, },
}), // Member.save is needed because else the roles relations wouldn't be updated
}).save(),
Guild.increment({ id: guild_id }, "member_count", 1), Guild.increment({ id: guild_id }, "member_count", 1),
emitEvent({ emitEvent({
event: "GUILD_MEMBER_ADD", event: "GUILD_MEMBER_ADD",
@ -255,7 +255,22 @@ export class Member extends BaseClassWithoutId {
} as GuildMemberAddEvent), } as GuildMemberAddEvent),
emitEvent({ emitEvent({
event: "GUILD_CREATE", event: "GUILD_CREATE",
data: { ...guild, members: [...guild.members, { ...member, user }] }, data: {
...guild,
members: [...guild.members, { ...member, user }],
member_count: (guild.member_count || 0) + 1,
guild_hashes: {
channels: { omitted: false, hash: "nkMQJ5nl5Cg" },
metadata: { omitted: false, hash: "+5ybMfcb8iw" },
roles: { omitted: false, hash: "Idhc6P9ktfM" },
version: 1,
},
guild_scheduled_events: [],
joined_at: member.joined_at,
presences: [],
stage_instances: [],
threads: [],
},
user_id, user_id,
} as GuildCreateEvent), } as GuildCreateEvent),
]); ]);

View File

@ -125,6 +125,17 @@ export interface GuildCreateEvent extends Event {
event: "GUILD_CREATE"; event: "GUILD_CREATE";
data: Guild & { data: Guild & {
joined_at: Date; joined_at: Date;
// TODO: add them to guild
guild_scheduled_events: never[];
guild_hashes: {
channels: { omitted: boolean; hash: string };
metadata: { omitted: boolean; hash: string };
roles: { omitted: boolean; hash: string };
version: number;
};
presences: never[];
stage_instances: never[];
threads: never[];
}; };
} }