post.ts 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. import { createRoute, OpenAPIHono } from '@hono/zod-openapi';
  2. import { UserService } from '../../modules/users/user.service';
  3. import { z } from '@hono/zod-openapi';
  4. import { authMiddleware } from '../../middleware/auth.middleware';
  5. import { ErrorSchema } from '../../utils/errorHandler';
  6. import { AppDataSource } from '../../data-source';
  7. import { AuthContext } from '../../types/context';
  8. import { UserSchema } from '@/server/modules/users/user.entity';
  9. const userService = new UserService(AppDataSource);
  10. const CreateUserSchema = UserSchema.omit({
  11. id: true,
  12. createdAt: true,
  13. updatedAt: true,
  14. roles: true,
  15. defaultDepartmentId: true,
  16. dataScopeType: true,
  17. }).extend({
  18. phone: UserSchema.shape.phone.optional(),
  19. email: UserSchema.shape.email.optional(),
  20. nickname: UserSchema.shape.nickname.optional(),
  21. name: UserSchema.shape.name.optional(),
  22. avatar: UserSchema.shape.avatar.optional(),
  23. roleIds: z.array(z.number().int().positive()).optional().openapi({
  24. description: '角色ID列表',
  25. example: [1, 2]
  26. }),
  27. defaultDepartmentId: z.number().int().positive().optional().openapi({
  28. description: '默认部门ID',
  29. example: 1
  30. }),
  31. dataScopeType: z.enum(['PERSONAL', 'DEPARTMENT', 'SUB_DEPARTMENT', 'COMPANY', 'CUSTOM']).optional().openapi({
  32. description: '数据范围类型',
  33. example: 'PERSONAL'
  34. }),
  35. })
  36. const createUserRoute = createRoute({
  37. method: 'post',
  38. path: '/',
  39. middleware: authMiddleware,
  40. request: {
  41. body: {
  42. content: {
  43. 'application/json': {
  44. schema: CreateUserSchema
  45. }
  46. }
  47. }
  48. },
  49. responses: {
  50. 201: {
  51. description: '创建成功',
  52. content: {
  53. 'application/json': {
  54. schema: UserSchema
  55. }
  56. }
  57. },
  58. 400: {
  59. description: '输入数据无效',
  60. content: {
  61. 'application/json': {
  62. schema: ErrorSchema
  63. }
  64. }
  65. },
  66. 500: {
  67. description: '服务器错误',
  68. content: {
  69. 'application/json': {
  70. schema: ErrorSchema
  71. }
  72. }
  73. }
  74. }
  75. });
  76. const app = new OpenAPIHono<AuthContext>().openapi(createUserRoute, async (c) => {
  77. try {
  78. const data = c.req.valid('json');
  79. const { roleIds, ...userData } = data;
  80. // 创建用户
  81. const user = await userService.createUser(userData);
  82. // 分配角色
  83. if (roleIds && roleIds.length > 0) {
  84. await userService.assignRoles(user.id, roleIds);
  85. }
  86. // 重新获取用户(包含角色信息)
  87. const userWithRoles = await userService.getUserById(user.id);
  88. return c.json(userWithRoles, 201);
  89. } catch (error) {
  90. const message = error instanceof Error ? error.message : '服务器错误';
  91. return c.json({ code: 500, message }, 500);
  92. }
  93. });
  94. export default app;