import { ContentfulStatusCode } from "hono/utils/http-status"; import { apiResponse } from "../../modules/api-utils/apiResponse"; import { createRoute } from "../../modules/api-utils/createRoute"; import { authMiddleware } from "../middleware/authorization"; import { users } from "../../managers/users"; import GenericError from "../../Errors/GenericError"; /* GET /v1/user/users/:identifier/roles */ export default createRoute( "get", ["/users/:identifier/roles"], async (c) => { const identifier = c.req.param("identifier"); const user = await users.fetchUser({ id: identifier }); if (!user) throw new GenericError({ name: "UserNotFound", message: `User with identifier '${identifier}' was not found.`, status: 404, }); const roles = await user.fetchRoles(); const rolesArray = roles.map((r) => r.toJson({ viewPermissions: true })); const response = apiResponse.successful( "User Roles Fetched Successfully!", rolesArray, ); return c.json(response, response.status as ContentfulStatusCode); }, authMiddleware({ permissions: ["user.read.other", "role.read"] }), );