studiocms
Version:
Astro Native CMS for AstroDB. Built from the ground up by the Astro community.
83 lines (82 loc) • 2.97 kB
JavaScript
import { developerConfig } from "studiocms:config";
import { apiResponseLogger } from "studiocms:logger";
import { SDKCore } from "studiocms:sdk";
import {
AllResponse,
createEffectAPIRoutes,
createJsonResponse,
Effect,
genLogger,
OptionsResponse,
readAPIContextJson
} from "../../../effect.js";
const { POST, DELETE, OPTIONS, ALL } = createEffectAPIRoutes(
{
POST: (ctx) => genLogger("studiocms/routes/api/dashboard/api-tokens.POST")(function* () {
const sdk = yield* SDKCore;
if (developerConfig.demoMode !== false) {
return apiResponseLogger(403, "Demo mode is enabled, this action is not allowed.");
}
const userData = ctx.locals.StudioCMS.security?.userSessionData;
if (!userData?.isLoggedIn) {
return apiResponseLogger(403, "Unauthorized");
}
const isAuthorized = ctx.locals.StudioCMS.security?.userPermissionLevel.isEditor;
if (!isAuthorized) {
return apiResponseLogger(403, "Unauthorized");
}
const jsonData = yield* readAPIContextJson(ctx);
if (!jsonData.description) {
return apiResponseLogger(400, "Invalid form data, description is required");
}
if (!jsonData.user) {
return apiResponseLogger(400, "Invalid form data, user is required");
}
const newToken = yield* sdk.REST_API.tokens.new(jsonData.user, jsonData.description);
return createJsonResponse({ token: newToken.key });
}),
DELETE: (ctx) => genLogger("studiocms/routes/api/dashboard/api-tokens.DELETE")(function* () {
const sdk = yield* SDKCore;
if (developerConfig.demoMode !== false) {
return apiResponseLogger(403, "Demo mode is enabled, this action is not allowed.");
}
const userData = ctx.locals.StudioCMS.security?.userSessionData;
if (!userData?.isLoggedIn) {
return apiResponseLogger(403, "Unauthorized");
}
const isAuthorized = ctx.locals.StudioCMS.security?.userPermissionLevel.isEditor;
if (!isAuthorized) {
return apiResponseLogger(403, "Unauthorized");
}
const jsonData = yield* readAPIContextJson(ctx);
if (!jsonData.tokenID) {
return apiResponseLogger(400, "Invalid form data, tokenID is required");
}
if (!jsonData.userID) {
return apiResponseLogger(400, "Invalid form data, userID is required");
}
yield* sdk.REST_API.tokens.delete(jsonData.userID, jsonData.tokenID);
return apiResponseLogger(200, "Token deleted");
}),
OPTIONS: () => Effect.try(() => OptionsResponse({ allowedMethods: ["POST", "DELETE"] })),
ALL: () => Effect.try(() => AllResponse())
},
{
cors: { methods: ["POST", "DELETE", "OPTIONS"] },
onError: (error) => {
console.error("API Error:", error);
return createJsonResponse(
{ error: "Internal Server Error" },
{
status: 500
}
);
}
}
);
export {
ALL,
DELETE,
OPTIONS,
POST
};