sendou.ink/app/features/admin/loaders/admin.server.ts
Kalle 9e0f36d90c Refactor requireRole/requirePermission to resolve user internally
Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
2026-02-24 20:02:37 +02:00

28 lines
940 B
TypeScript

import type { LoaderFunctionArgs } from "react-router";
import { isImpersonating } from "~/features/auth/core/user.server";
import * as UserRepository from "~/features/user-page/UserRepository.server";
import { requireRole } from "~/modules/permissions/guards.server";
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) {
requireRole("STAFF");
}
const parsedSearchParams = parseSafeSearchParams({
request,
schema: adminActionSearchParamsSchema,
});
return {
isImpersonating: await isImpersonating(request),
friendCodeSearchUsers: parsedSearchParams.success
? await UserRepository.findByFriendCode(
parsedSearchParams.data.friendCode,
)
: [],
};
};