studiocms
Version:
Astro Native CMS for AstroDB. Built from the ground up by the Astro community.
72 lines (71 loc) • 2.77 kB
JavaScript
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
};