Merge remote-tracking branch 'origin/master'
This commit is contained in:
commit
2028cc8e0b
@ -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;
|
||||||
|
@ -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({
|
||||||
|
@ -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" }];
|
||||||
|
|
||||||
|
@ -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 });
|
||||||
|
@ -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),
|
||||||
]);
|
]);
|
||||||
|
@ -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[];
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user