File size: 1,185 Bytes
0c4cf03 6434339 0c4cf03 |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 |
import { collections } from "$lib/server/database";
import { sha256 } from "$lib/utils/sha256";
import { error } from "@sveltejs/kit";
import { ObjectId } from "mongodb";
export async function GET({ params, locals }) {
const searchId = new ObjectId(params.id);
const search = await collections.webSearches.findOne({
_id: searchId,
});
if (!search) {
throw error(404, "Search query not found");
}
const conv = await collections.conversations.findOne({
_id: search.convId,
});
if (!conv) {
throw error(404, "Conversation not found");
}
// there's no better way to see if a conversation has been shared, so we hash the messages and see if there's a shared conversation with the same hash
const hash = await sha256(JSON.stringify(conv.messages));
const sharedConv = await collections.sharedConversations.findOne({
hash: hash,
});
const userShouldSeeConv =
(conv.userId && locals.user?._id.toString() === conv.userId.toString()) || sharedConv !== null;
if (!userShouldSeeConv) {
throw error(403, "You don't have access to the conversation here.");
}
return new Response(JSON.stringify(search), { headers: { "Content-Type": "application/json" } });
}
|