sendou.ink/app/features/api/actions/api.server.ts
Kalle 57892fb571
Add read/write API token types (#2756)
Co-authored-by: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-25 13:55:16 +02:00

45 lines
1.3 KiB
TypeScript

import type { ActionFunctionArgs } from "react-router";
import { z } from "zod";
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 * as ApiRepository from "../ApiRepository.server";
import { checkUserHasApiAccess } from "../core/perms";
const apiActionSchema = z.object({
_action: z.enum(["GENERATE_READ", "GENERATE_WRITE"]),
});
export const action = async ({ request }: ActionFunctionArgs) => {
const data = await parseRequestPayload({
request,
schema: apiActionSchema,
});
const user = requireUser();
const hasApiAccess = await checkUserHasApiAccess(user);
if (!hasApiAccess) {
throw new Response("Forbidden", { status: 403 });
}
switch (data._action) {
case "GENERATE_READ": {
await ApiRepository.generateToken(user.id, "read");
await refreshApiTokensCache();
successToast("Read token generated successfully");
break;
}
case "GENERATE_WRITE": {
await ApiRepository.generateToken(user.id, "write");
await refreshApiTokensCache();
successToast("Write token generated successfully");
break;
}
default: {
throw new Error("Invalid action");
}
}
return null;
};