sendou.ink/app/features/admin/loaders/admin.server.ts
Kalle fef1ffc955
Design refresh + a bunch of stuff (#2864)
Co-authored-by: hfcRed <hfcred@gmx.net>
2026-03-19 17:51:42 +02:00

39 lines
1.2 KiB
TypeScript

import type { LoaderFunctionArgs } from "react-router";
import {
getRealUserId,
isImpersonating,
requireUser,
} from "~/features/auth/core/user.server";
import * as UserRepository from "~/features/user-page/UserRepository.server";
import { isAdmin, isDev, isStaff } from "~/modules/permissions/utils";
import { parseSafeSearchParams } from "~/utils/remix.server";
import { adminActionSearchParamsSchema } from "../admin-schemas";
import { DANGEROUS_CAN_ACCESS_DEV_CONTROLS } from "../core/dev-controls";
export const loader = async ({ request }: LoaderFunctionArgs) => {
if (!DANGEROUS_CAN_ACCESS_DEV_CONTROLS) {
const user = requireUser();
const realUserId = await getRealUserId(request);
const userToCheck =
realUserId && realUserId !== user.id ? { id: realUserId } : user;
if (!isAdmin(userToCheck) && !isStaff(userToCheck) && !isDev(userToCheck)) {
throw new Response("Forbidden", { status: 403 });
}
}
const parsedSearchParams = parseSafeSearchParams({
request,
schema: adminActionSearchParamsSchema,
});
return {
isImpersonating: await isImpersonating(request),
friendCodeSearchUsers: parsedSearchParams.success
? await UserRepository.findByFriendCode(
parsedSearchParams.data.friendCode,
)
: [],
};
};