sendou.ink/app/features/api/actions/api.server.ts
2025-12-29 19:21:11 +02:00

42 lines
1.1 KiB
TypeScript

import type { ActionFunctionArgs } from "react-router";
import { z } from "zod/v4";
import { refreshApiTokensCache } from "~/features/api-public/api-public-utils.server";
import { requireUser } from "~/features/auth/core/user.server";
import { parseRequestPayload, successToast } from "~/utils/remix.server";
import { _action } from "~/utils/zod";
import * as ApiRepository from "../ApiRepository.server";
import { checkUserHasApiAccess } from "../core/perms";
const apiActionSchema = z.object({
_action: _action("GENERATE"),
});
export const action = async ({ request }: ActionFunctionArgs) => {
const data = await parseRequestPayload({
request,
schema: apiActionSchema,
});
const user = await requireUser(request);
const hasApiAccess = await checkUserHasApiAccess(user);
if (!hasApiAccess) {
throw new Response("Forbidden", { status: 403 });
}
switch (data._action) {
case "GENERATE": {
await ApiRepository.generateToken(user.id);
await refreshApiTokensCache();
successToast("API token generated successfully");
break;
}
default: {
throw new Error("Invalid action");
}
}
return null;
};