18 lines
637 B
TypeScript
18 lines
637 B
TypeScript
import { ForbiddenError } from "@spec/relay/mod.ts";
|
|
import { NotFoundError } from "@spec/relay/mod.ts";
|
|
import { getById } from "@spec/schemas/account/routes.ts";
|
|
|
|
import { db } from "~stores/read-store/database.ts";
|
|
|
|
export default getById.access("authenticated").handle(async ({ params: { id } }, { access }) => {
|
|
const account = await db.collection("accounts").findOne({ id });
|
|
if (account === null) {
|
|
return new NotFoundError();
|
|
}
|
|
const decision = await access.isAllowed({ kind: "account", id: account.id, attributes: {} }, "read");
|
|
if (decision === false) {
|
|
return new ForbiddenError();
|
|
}
|
|
return account;
|
|
});
|