Fix issues with requesting presences
This commit is contained in:
parent
f8a21eff0c
commit
ea3047890b
@ -50,7 +50,7 @@ export async function Close(this: WebSocket, code: number, reason: Buffer) {
|
|||||||
} as SessionsReplace);
|
} as SessionsReplace);
|
||||||
const session = sessions.first() || {
|
const session = sessions.first() || {
|
||||||
activities: [],
|
activities: [],
|
||||||
client_info: {},
|
client_status: {},
|
||||||
status: "offline",
|
status: "offline",
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -68,7 +68,7 @@ export async function Close(this: WebSocket, code: number, reason: Buffer) {
|
|||||||
data: {
|
data: {
|
||||||
user: userOrId,
|
user: userOrId,
|
||||||
activities: session.activities,
|
activities: session.activities,
|
||||||
client_status: session?.client_info,
|
client_status: session?.client_status,
|
||||||
status: session.status,
|
status: session.status,
|
||||||
},
|
},
|
||||||
} as PresenceUpdateEvent);
|
} as PresenceUpdateEvent);
|
||||||
|
@ -122,8 +122,8 @@ export async function onIdentify(this: WebSocket, data: Payload) {
|
|||||||
session_id: this.session_id,
|
session_id: this.session_id,
|
||||||
status: identify.presence?.status || "online",
|
status: identify.presence?.status || "online",
|
||||||
client_info: {
|
client_info: {
|
||||||
client: identify.properties?.$device,
|
client: identify.properties?.device || identify.properties?.$device,
|
||||||
os: identify.properties?.os,
|
os: identify.properties?.os || identify.properties?.$os,
|
||||||
version: 0,
|
version: 0,
|
||||||
},
|
},
|
||||||
activities: identify.presence?.activities, // TODO: validation
|
activities: identify.presence?.activities, // TODO: validation
|
||||||
@ -372,7 +372,7 @@ export async function onIdentify(this: WebSocket, data: Payload) {
|
|||||||
data: {
|
data: {
|
||||||
user: user.toPublicUser(),
|
user: user.toPublicUser(),
|
||||||
activities: session.activities,
|
activities: session.activities,
|
||||||
client_status: session.client_info,
|
client_status: session.client_status,
|
||||||
status: session.status,
|
status: session.status,
|
||||||
},
|
},
|
||||||
} as PresenceUpdateEvent),
|
} as PresenceUpdateEvent),
|
||||||
|
@ -248,7 +248,7 @@ export async function onLazyRequest(this: WebSocket, { d }: Payload) {
|
|||||||
d: {
|
d: {
|
||||||
user: user,
|
user: user,
|
||||||
activities: session?.activities || [],
|
activities: session?.activities || [],
|
||||||
client_status: session?.client_info,
|
client_status: session?.client_status,
|
||||||
status: session?.status || "offline",
|
status: session?.status || "offline",
|
||||||
} as Presence,
|
} as Presence,
|
||||||
});
|
});
|
||||||
|
@ -35,14 +35,19 @@ export async function onPresenceUpdate(this: WebSocket, { d }: Payload) {
|
|||||||
{ status: presence.status, activities: presence.activities },
|
{ status: presence.status, activities: presence.activities },
|
||||||
);
|
);
|
||||||
|
|
||||||
|
const session = await Session.findOneOrFail({
|
||||||
|
select: ["client_status"],
|
||||||
|
where: { session_id: this.session_id },
|
||||||
|
});
|
||||||
|
|
||||||
await emitEvent({
|
await emitEvent({
|
||||||
event: "PRESENCE_UPDATE",
|
event: "PRESENCE_UPDATE",
|
||||||
user_id: this.user_id,
|
user_id: this.user_id,
|
||||||
data: {
|
data: {
|
||||||
user: await User.getPublicUser(this.user_id),
|
user: await User.getPublicUser(this.user_id),
|
||||||
activities: presence.activities,
|
|
||||||
client_status: {}, // TODO:
|
|
||||||
status: presence.status,
|
status: presence.status,
|
||||||
|
activities: presence.activities,
|
||||||
|
client_status: session.client_status,
|
||||||
},
|
},
|
||||||
} as PresenceUpdateEvent);
|
} as PresenceUpdateEvent);
|
||||||
}
|
}
|
||||||
|
@ -22,6 +22,7 @@ import {
|
|||||||
Member,
|
Member,
|
||||||
Presence,
|
Presence,
|
||||||
RequestGuildMembersSchema,
|
RequestGuildMembersSchema,
|
||||||
|
Session,
|
||||||
} from "@spacebar/util";
|
} from "@spacebar/util";
|
||||||
import { WebSocket, Payload, OPCODES, Send } from "@spacebar/gateway";
|
import { WebSocket, Payload, OPCODES, Send } from "@spacebar/gateway";
|
||||||
import { check } from "./instanceOf";
|
import { check } from "./instanceOf";
|
||||||
@ -63,7 +64,7 @@ export async function onRequestGuildMembers(this: WebSocket, { d }: Payload) {
|
|||||||
...whereQuery,
|
...whereQuery,
|
||||||
guild_id,
|
guild_id,
|
||||||
},
|
},
|
||||||
relations: ["roles", ...(presences ? ["presence"] : [])],
|
relations: ["users", "roles"],
|
||||||
};
|
};
|
||||||
if (limit) memberFind.take = Math.abs(Number(limit || 100));
|
if (limit) memberFind.take = Math.abs(Number(limit || 100));
|
||||||
const members = await Member.find(memberFind);
|
const members = await Member.find(memberFind);
|
||||||
@ -83,13 +84,21 @@ export async function onRequestGuildMembers(this: WebSocket, { d }: Payload) {
|
|||||||
|
|
||||||
const chunks: GuildMembersChunkEvent["data"][] = [];
|
const chunks: GuildMembersChunkEvent["data"][] = [];
|
||||||
while (members.length > 0) {
|
while (members.length > 0) {
|
||||||
const chunk = members.splice(0, 1000);
|
const chunk: Member[] = members.splice(0, 1000);
|
||||||
|
|
||||||
const presenceList: Presence[] = [];
|
const presenceList: Presence[] = [];
|
||||||
if (presences) {
|
if (presences) {
|
||||||
for await (const member of chunk) {
|
for await (const member of chunk) {
|
||||||
presenceList.push(member.presence);
|
const session = await Session.findOne({
|
||||||
delete member.presence;
|
where: { user_id: member.id },
|
||||||
|
});
|
||||||
|
if (session)
|
||||||
|
presenceList.push({
|
||||||
|
user: member.user.toPublicUser(),
|
||||||
|
status: session.status,
|
||||||
|
activities: session.activities,
|
||||||
|
client_status: session.client_status,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -19,7 +19,7 @@
|
|||||||
import { User } from "./User";
|
import { User } from "./User";
|
||||||
import { BaseClass } from "./BaseClass";
|
import { BaseClass } from "./BaseClass";
|
||||||
import { Column, Entity, JoinColumn, ManyToOne, RelationId } from "typeorm";
|
import { Column, Entity, JoinColumn, ManyToOne, RelationId } from "typeorm";
|
||||||
import { Status } from "../interfaces/Status";
|
import { ClientStatus, Status } from "../interfaces/Status";
|
||||||
import { Activity } from "../interfaces/Activity";
|
import { Activity } from "../interfaces/Activity";
|
||||||
|
|
||||||
//TODO we need to remove all sessions on server start because if the server crashes without closing websockets it won't delete them
|
//TODO we need to remove all sessions on server start because if the server crashes without closing websockets it won't delete them
|
||||||
@ -43,7 +43,6 @@ export class Session extends BaseClass {
|
|||||||
@Column({ type: "simple-json", nullable: true })
|
@Column({ type: "simple-json", nullable: true })
|
||||||
activities: Activity[];
|
activities: Activity[];
|
||||||
|
|
||||||
// TODO client_status
|
|
||||||
@Column({ type: "simple-json", select: false })
|
@Column({ type: "simple-json", select: false })
|
||||||
client_info: {
|
client_info: {
|
||||||
client: string;
|
client: string;
|
||||||
@ -51,6 +50,9 @@ export class Session extends BaseClass {
|
|||||||
version: number;
|
version: number;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@Column({ type: "simple-json" })
|
||||||
|
client_status: ClientStatus;
|
||||||
|
|
||||||
@Column({ nullable: false, type: "varchar" })
|
@Column({ nullable: false, type: "varchar" })
|
||||||
status: Status; //TODO enum
|
status: Status; //TODO enum
|
||||||
}
|
}
|
||||||
|
@ -21,5 +21,6 @@ export type Status = "idle" | "dnd" | "online" | "offline" | "invisible";
|
|||||||
export interface ClientStatus {
|
export interface ClientStatus {
|
||||||
desktop?: string; // e.g. Windows/Linux/Mac
|
desktop?: string; // e.g. Windows/Linux/Mac
|
||||||
mobile?: string; // e.g. iOS/Android
|
mobile?: string; // e.g. iOS/Android
|
||||||
web?: string; // e.g. browser, bot account
|
web?: string; // e.g. browser, bot account, unknown
|
||||||
|
embedded?: string; // e.g. embedded
|
||||||
}
|
}
|
||||||
|
17
src/util/migration/mariadb/1723347738541-client_status.ts
Normal file
17
src/util/migration/mariadb/1723347738541-client_status.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import { MigrationInterface, QueryRunner } from "typeorm";
|
||||||
|
|
||||||
|
export class client_status1723347738541 implements MigrationInterface {
|
||||||
|
name = "client_status1723347738541";
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(
|
||||||
|
"ALTER TABLE `sessions` ADD `client_status` text NULL AFTER `client_info`",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(
|
||||||
|
"ALTER TABLE `sessions` DROP COLUMN `client_status`",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
17
src/util/migration/mysql/1723347738541-client_status.ts
Normal file
17
src/util/migration/mysql/1723347738541-client_status.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import { MigrationInterface, QueryRunner } from "typeorm";
|
||||||
|
|
||||||
|
export class client_status1723347738541 implements MigrationInterface {
|
||||||
|
name = "client_status1723347738541";
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(
|
||||||
|
"ALTER TABLE `sessions` ADD `client_status` text NULL AFTER `client_info`",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(
|
||||||
|
"ALTER TABLE `sessions` DROP COLUMN `client_status`",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
17
src/util/migration/postgres/1723347738541-client_status.ts
Normal file
17
src/util/migration/postgres/1723347738541-client_status.ts
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
import { MigrationInterface, QueryRunner } from "typeorm";
|
||||||
|
|
||||||
|
export class client_status1723347738541 implements MigrationInterface {
|
||||||
|
name = "client_status1723347738541";
|
||||||
|
|
||||||
|
public async up(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(
|
||||||
|
"ALTER TABLE sessions ADD client_status text NULL",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
public async down(queryRunner: QueryRunner): Promise<void> {
|
||||||
|
await queryRunner.query(
|
||||||
|
"ALTER TABLE sessions DROP COLUMN client_status",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user