UNPKG

studiocms

Version:

Astro Native CMS for AstroDB. Built from the ground up by the Astro community.

72 lines (71 loc) 2.77 kB
import { apiResponseLogger } from "studiocms:logger"; import { SDKCore } from "studiocms:sdk"; import { AllResponse, createEffectAPIRoutes, createJsonResponse, Effect, genLogger, OptionsResponse, readAPIContextJson } from "../../../../../../effect.js"; import { verifyAuthTokenFromHeader } from "../../utils/auth-token.js"; const { GET, PATCH, ALL, OPTIONS } = createEffectAPIRoutes( { GET: (ctx) => genLogger("studioCMS:rest:v1:settings:GET")(function* () { const [sdk, user] = yield* Effect.all([SDKCore, verifyAuthTokenFromHeader(ctx)]); if (user instanceof Response) { return user; } const { rank } = user; if (rank !== "owner") { return apiResponseLogger(401, "Unauthorized"); } const siteConfig = yield* sdk.GET.siteConfig(); return createJsonResponse(siteConfig); }), PATCH: (ctx) => genLogger("studioCMS:rest:v1:settings:PATCH")(function* () { const [sdk, user] = yield* Effect.all([SDKCore, verifyAuthTokenFromHeader(ctx)]); if (user instanceof Response) { return user; } const { rank } = user; if (rank !== "owner") { return apiResponseLogger(401, "Unauthorized"); } const siteConfig = yield* readAPIContextJson(ctx); if (typeof siteConfig.title !== "string" || siteConfig.title.trim() === "") { return apiResponseLogger(400, "Invalid form data, title is required"); } if (typeof siteConfig.description !== "string" || siteConfig.description.trim() === "") { return apiResponseLogger(400, "Invalid form data, description is required"); } if (typeof siteConfig.loginPageBackground !== "string" || siteConfig.loginPageBackground.trim() === "") { return apiResponseLogger(400, "Invalid form data, loginPageBackground is required"); } if (siteConfig.loginPageBackground === "custom" && (typeof siteConfig.loginPageCustomImage !== "string" || siteConfig.loginPageCustomImage.trim() === "")) { return apiResponseLogger(400, "Invalid form data, loginPageCustomImage is required"); } yield* sdk.UPDATE.siteConfig(siteConfig); return apiResponseLogger(200, "Site config updated"); }), OPTIONS: () => Effect.try(() => OptionsResponse({ allowedMethods: ["GET", "PATCH"] })), ALL: () => Effect.try(() => AllResponse()) }, { cors: { methods: ["GET", "PATCH", "OPTIONS"] }, onError: (error) => { console.error("API Error:", error); if (error instanceof SyntaxError) { return createJsonResponse({ error: "Invalid JSON" }, { status: 400 }); } return createJsonResponse({ error: "Something went wrong" }, { status: 500 }); } } ); export { ALL, GET, OPTIONS, PATCH };