pollo/app/routes/api.room.presence.get.$roomId.tsx

95 lines
2.5 KiB
TypeScript
Raw Normal View History

2023-04-20 04:20:00 -06:00
import { getAuth } from "@clerk/remix/ssr.server";
2023-12-13 14:52:56 -07:00
import { type LoaderFunctionArgs, json } from "@remix-run/node";
2023-04-20 04:20:00 -06:00
import { and, eq } from "drizzle-orm";
import { eventStream } from "remix-utils/sse/server";
import { db } from "~/services/db.server";
import { emitter } from "~/services/emitter.server";
2023-12-11 22:58:49 -07:00
import { presence } from "~/services/schema.server";
2023-04-20 04:20:00 -06:00
import { createId } from "@paralleldrive/cuid2";
export async function loader({ context, params, request }: LoaderFunctionArgs) {
const { userId, sessionClaims } = await getAuth({ context, params, request });
const roomId = params.roomId;
if (!roomId) {
return json("RoomId Missing!", {
status: 400,
statusText: "BAD REQUEST!",
});
}
if (!userId) {
return json("Not Signed In!", {
status: 403,
statusText: "UNAUTHORIZED!",
});
}
const name = sessionClaims.name as string;
const image = sessionClaims.image as string;
2023-11-22 14:38:16 -07:00
const metadata = sessionClaims.metadata as {
isAdmin: boolean;
isVIP: boolean;
};
2023-04-20 04:20:00 -06:00
return eventStream(request.signal, function setup(send) {
async function handler() {
const presenceData = await db.query.presence.findMany({
where: and(eq(presence.roomId, roomId || "")),
});
send({
event: `${userId}-${params.roomId}`,
2023-11-22 14:38:16 -07:00
data: JSON.stringify(
presenceData.map((presenceItem) => {
return {
...presenceItem,
2024-01-06 00:37:58 -07:00
isAdmin: presenceItem.isAdmin,
isVIP: presenceItem.isVIP,
2023-11-22 14:38:16 -07:00
};
})
),
2023-04-20 04:20:00 -06:00
});
}
db.insert(presence)
.values({
id: `presence_${createId()}`,
roomId: roomId || "",
userFullName: name,
userId: userId,
userImageUrl: image,
2024-01-06 00:37:58 -07:00
isAdmin: metadata.isAdmin,
isVIP: metadata.isVIP,
2023-04-20 04:20:00 -06:00
})
.onConflictDoUpdate({
target: [presence.userId, presence.roomId],
set: {
roomId: roomId || "",
userFullName: name,
userId: userId,
userImageUrl: image,
2024-01-06 00:37:58 -07:00
isAdmin: metadata.isAdmin,
isVIP: metadata.isVIP,
2023-04-20 04:20:00 -06:00
},
})
.then(async () => {
2023-12-01 14:57:31 -07:00
emitter.emit("nodes", "presence");
2023-04-20 04:20:00 -06:00
});
// Initial fetch
emitter.on("presence", handler);
return function clear() {
db.delete(presence)
.where(and(eq(presence.roomId, roomId), eq(presence.userId, userId)))
.returning()
.then(async () => {
2023-12-01 14:57:31 -07:00
emitter.emit("nodes", "presence");
2023-04-20 04:20:00 -06:00
});
emitter.off("presence", handler);
};
});
}