card.schema.ts 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. import { z } from '@hono/zod-openapi';
  2. import { UserSchema } from '@/server/modules/users/user.schema';
  3. export const CardSchema = z.object({
  4. id: z.number().int().positive().openapi({ description: '卡ID' }),
  5. agentId: z.number().int().positive().nullable().openapi({
  6. description: '代理商ID',
  7. example: 1
  8. }),
  9. cardType: z.number().int().min(1).max(2).openapi({
  10. description: '卡类型 1盛京通卡 2通用联名电子卡',
  11. example: 1
  12. }),
  13. cardNo: z.string().min(1, '卡号不能为空').max(20, '卡号最多20个字符').openapi({
  14. description: '卡号',
  15. example: '1234567890'
  16. }),
  17. password: z.string().min(1, '密码不能为空').max(255, '密码最多255个字符').openapi({
  18. description: '密码',
  19. example: 'hashed_password'
  20. }),
  21. state: z.number().int().min(1).max(2).default(1).openapi({
  22. description: '状态 1绑定 2解绑 通用联名电子卡不可解绑',
  23. example: 1
  24. }),
  25. faceValue: z.coerce.number().multipleOf(0.01, '面值最多保留两位小数').min(0, '面值不能为负数').default(0).openapi({
  26. description: '面值',
  27. example: 100.00
  28. }),
  29. agent: UserSchema.nullable().optional().openapi({
  30. description: '代理商信息'
  31. }),
  32. createdAt: z.coerce.date().openapi({
  33. description: '创建时间',
  34. example: '2024-01-01T12:00:00Z'
  35. }),
  36. updatedAt: z.coerce.date().openapi({
  37. description: '更新时间',
  38. example: '2024-01-01T12:00:00Z'
  39. }),
  40. createdBy: z.number().int().positive().nullable().openapi({
  41. description: '创建用户ID',
  42. example: 1
  43. }),
  44. updatedBy: z.number().int().positive().nullable().openapi({
  45. description: '更新用户ID',
  46. example: 1
  47. }),
  48. });
  49. export const CreateCardDto = z.object({
  50. cardType: z.number().int().min(1, '卡类型必须在1-2之间').max(2, '卡类型必须在1-2之间').openapi({
  51. description: '卡类型 1盛京通卡 2通用联名电子卡',
  52. example: 1
  53. }),
  54. cardNo: z.string().min(1, '卡号不能为空').max(20, '卡号最多20个字符').openapi({
  55. description: '卡号',
  56. example: '1234567890'
  57. }),
  58. password: z.string().min(1, '密码不能为空').max(255, '密码最多255个字符').openapi({
  59. description: '密码',
  60. example: 'password123'
  61. }),
  62. faceValue: z.coerce.number().multipleOf(0.01, '面值最多保留两位小数').min(0, '面值不能为负数').default(0).openapi({
  63. description: '面值',
  64. example: 100.00
  65. }),
  66. agentId: z.number().int().positive().nullable().optional().openapi({
  67. description: '代理商ID',
  68. example: 1
  69. })
  70. });
  71. export const UpdateCardDto = z.object({
  72. cardType: z.number().int().min(1).max(2).optional().openapi({
  73. description: '卡类型 1盛京通卡 2通用联名电子卡',
  74. example: 1
  75. }),
  76. cardNo: z.string().min(1, '卡号不能为空').max(20, '卡号最多20个字符').optional().openapi({
  77. description: '卡号',
  78. example: '1234567890'
  79. }),
  80. password: z.string().min(1, '密码不能为空').max(255, '密码最多255个字符').optional().openapi({
  81. description: '密码',
  82. example: 'hashed_password'
  83. }),
  84. state: z.number().int().min(1).max(2).optional().openapi({
  85. description: '状态 1绑定 2解绑 通用联名电子卡不可解绑',
  86. example: 1
  87. }),
  88. faceValue: z.coerce.number().multipleOf(0.01, '面值最多保留两位小数').min(0, '面值不能为负数').optional().openapi({
  89. description: '面值',
  90. example: 100.00
  91. }),
  92. agentId: z.number().int().positive().nullable().optional().openapi({
  93. description: '代理商ID',
  94. example: 1
  95. })
  96. });