55 lines
1.3 KiB
TypeScript
55 lines
1.3 KiB
TypeScript
import { queryLogs } from "../../../gcloud.js";
|
|
|
|
export async function onRequestGet(context: RequestContext) {
|
|
const robloxUserReq = await fetch(
|
|
"https://users.roblox.com/v1/usernames/users",
|
|
{
|
|
body: JSON.stringify({
|
|
excludeBannedUsers: false,
|
|
usernames: [context.params.user as string],
|
|
}),
|
|
headers: {
|
|
"content-type": "application/json",
|
|
},
|
|
method: "POST",
|
|
},
|
|
);
|
|
|
|
if (!robloxUserReq.ok) {
|
|
console.log(await robloxUserReq.json());
|
|
return new Response('{"error":"Failed to resolve username"}', {
|
|
headers: {
|
|
"content-type": "application/json",
|
|
},
|
|
status: 500,
|
|
});
|
|
}
|
|
|
|
const { data: users }: { data: { [k: string]: any }[] } =
|
|
await robloxUserReq.json();
|
|
|
|
if (!users.length)
|
|
return new Response('{"error":"No user found with that name"}', {
|
|
headers: {
|
|
"content-type": "application/json",
|
|
},
|
|
status: 400,
|
|
});
|
|
|
|
return new Response(
|
|
JSON.stringify(
|
|
(await queryLogs(users[0].id, context)).sort((a, b) =>
|
|
a.entity.properties.executed_at.integerValue >
|
|
b.entity.properties.executed_at.integerValue
|
|
? 1
|
|
: -1,
|
|
),
|
|
),
|
|
{
|
|
headers: {
|
|
"content-type": "application/json",
|
|
},
|
|
},
|
|
);
|
|
}
|