next/lib/server/middlewareButNotReally/storyPrivileges.ts

18 lines
881 B
TypeScript
Raw Normal View History

import type { H3Event, EventHandlerRequest } from "h3";
import { IStory } from "@models/stories";
import { isLoggedIn } from "@server/middlewareButNotReally";
import { IDraft } from "@models/stories/draft";
import { IUser } from "@models/user";
export function canDelete(event: H3Event<EventHandlerRequest>, story: IStory) {
isLoggedIn(event);
2023-12-29 20:53:29 -05:00
return event.context.currentUser?.profile.isAdmin || (story.author as IUser)._id === event.context.currentUser?._id;
}
2023-12-29 20:53:29 -05:00
export function canDeleteDraft(event: H3Event<EventHandlerRequest>, story: IDraft) {
isLoggedIn(event);
return story.author === event.context.currentUser?._id;
}
2023-12-29 20:53:29 -05:00
export function canModify(event: H3Event<EventHandlerRequest>, story: IStory | IDraft) {
isLoggedIn(event);
2023-12-29 20:53:29 -05:00
return event.context.currentUser?._id === (story.author as IUser)._id || (story.coAuthor as IUser)?._id === event.context.currentUser?._id;
}