@pcontext/api 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (342) hide show
  1. package/README.md +151 -0
  2. package/dist/app.d.mts +44779 -0
  3. package/dist/app.d.mts.map +1 -0
  4. package/dist/app.mjs +37 -0
  5. package/dist/app.mjs.map +1 -0
  6. package/dist/client.d.mts +22428 -0
  7. package/dist/client.d.mts.map +1 -0
  8. package/dist/client.mjs +15 -0
  9. package/dist/client.mjs.map +1 -0
  10. package/dist/dev.d.mts +11 -0
  11. package/dist/dev.d.mts.map +1 -0
  12. package/dist/dev.mjs +16 -0
  13. package/dist/dev.mjs.map +1 -0
  14. package/dist/index.d.mts +3 -0
  15. package/dist/index.mjs +10 -0
  16. package/dist/index.mjs.map +1 -0
  17. package/dist/modules/doc/chat.route.d.mts +18 -0
  18. package/dist/modules/doc/chat.route.d.mts.map +1 -0
  19. package/dist/modules/doc/chat.route.mjs +20 -0
  20. package/dist/modules/doc/chat.route.mjs.map +1 -0
  21. package/dist/modules/doc/chat.service.d.mts +10 -0
  22. package/dist/modules/doc/chat.service.d.mts.map +1 -0
  23. package/dist/modules/doc/chat.service.mjs +29 -0
  24. package/dist/modules/doc/chat.service.mjs.map +1 -0
  25. package/dist/modules/doc/doc.dto.d.mts +67 -0
  26. package/dist/modules/doc/doc.dto.d.mts.map +1 -0
  27. package/dist/modules/doc/doc.dto.mjs +43 -0
  28. package/dist/modules/doc/doc.dto.mjs.map +1 -0
  29. package/dist/modules/doc/doc.entity.d.mts +19 -0
  30. package/dist/modules/doc/doc.entity.d.mts.map +1 -0
  31. package/dist/modules/doc/doc.entity.mjs +1 -0
  32. package/dist/modules/doc/doc.repo.interface.d.mts +28 -0
  33. package/dist/modules/doc/doc.repo.interface.d.mts.map +1 -0
  34. package/dist/modules/doc/doc.repo.interface.mjs +1 -0
  35. package/dist/modules/doc/doc.route.d.mts +14193 -0
  36. package/dist/modules/doc/doc.route.d.mts.map +1 -0
  37. package/dist/modules/doc/doc.route.mjs +100 -0
  38. package/dist/modules/doc/doc.route.mjs.map +1 -0
  39. package/dist/modules/doc/doc.service.d.mts +38 -0
  40. package/dist/modules/doc/doc.service.d.mts.map +1 -0
  41. package/dist/modules/doc/doc.service.mjs +134 -0
  42. package/dist/modules/doc/doc.service.mjs.map +1 -0
  43. package/dist/modules/doc/doc.vo.d.mts +17 -0
  44. package/dist/modules/doc/doc.vo.d.mts.map +1 -0
  45. package/dist/modules/doc/doc.vo.mjs +1 -0
  46. package/dist/modules/doc/infrastructure/agent/engine/chat.d.mts +21 -0
  47. package/dist/modules/doc/infrastructure/agent/engine/chat.d.mts.map +1 -0
  48. package/dist/modules/doc/infrastructure/agent/engine/chat.mjs +36 -0
  49. package/dist/modules/doc/infrastructure/agent/engine/chat.mjs.map +1 -0
  50. package/dist/modules/doc/infrastructure/agent/engine/generate.d.mts +28 -0
  51. package/dist/modules/doc/infrastructure/agent/engine/generate.d.mts.map +1 -0
  52. package/dist/modules/doc/infrastructure/agent/engine/generate.mjs +135 -0
  53. package/dist/modules/doc/infrastructure/agent/engine/generate.mjs.map +1 -0
  54. package/dist/modules/doc/infrastructure/agent/engine/query-filter.d.mts +7 -0
  55. package/dist/modules/doc/infrastructure/agent/engine/query-filter.d.mts.map +1 -0
  56. package/dist/modules/doc/infrastructure/agent/engine/query-filter.mjs +12 -0
  57. package/dist/modules/doc/infrastructure/agent/engine/query-filter.mjs.map +1 -0
  58. package/dist/modules/doc/infrastructure/agent/loaders/git-repository-reader.d.mts +54 -0
  59. package/dist/modules/doc/infrastructure/agent/loaders/git-repository-reader.d.mts.map +1 -0
  60. package/dist/modules/doc/infrastructure/agent/loaders/git-repository-reader.mjs +142 -0
  61. package/dist/modules/doc/infrastructure/agent/loaders/git-repository-reader.mjs.map +1 -0
  62. package/dist/modules/doc/infrastructure/agent/loaders/index.d.mts +3 -0
  63. package/dist/modules/doc/infrastructure/agent/loaders/index.mjs +4 -0
  64. package/dist/modules/doc/infrastructure/agent/loaders/website-crawl-reader.d.mts +42 -0
  65. package/dist/modules/doc/infrastructure/agent/loaders/website-crawl-reader.d.mts.map +1 -0
  66. package/dist/modules/doc/infrastructure/agent/loaders/website-crawl-reader.mjs +104 -0
  67. package/dist/modules/doc/infrastructure/agent/loaders/website-crawl-reader.mjs.map +1 -0
  68. package/dist/modules/doc/infrastructure/agent/settings.d.mts +5 -0
  69. package/dist/modules/doc/infrastructure/agent/settings.d.mts.map +1 -0
  70. package/dist/modules/doc/infrastructure/agent/settings.mjs +72 -0
  71. package/dist/modules/doc/infrastructure/agent/settings.mjs.map +1 -0
  72. package/dist/modules/doc/infrastructure/agent/storage/index.d.mts +7 -0
  73. package/dist/modules/doc/infrastructure/agent/storage/index.d.mts.map +1 -0
  74. package/dist/modules/doc/infrastructure/agent/storage/index.mjs +12 -0
  75. package/dist/modules/doc/infrastructure/agent/storage/index.mjs.map +1 -0
  76. package/dist/modules/doc/infrastructure/agent/storage/vector-store.d.mts +14 -0
  77. package/dist/modules/doc/infrastructure/agent/storage/vector-store.d.mts.map +1 -0
  78. package/dist/modules/doc/infrastructure/agent/storage/vector-store.mjs +35 -0
  79. package/dist/modules/doc/infrastructure/agent/storage/vector-store.mjs.map +1 -0
  80. package/dist/modules/doc/infrastructure/doc.po.d.mts +570 -0
  81. package/dist/modules/doc/infrastructure/doc.po.d.mts.map +1 -0
  82. package/dist/modules/doc/infrastructure/doc.po.mjs +54 -0
  83. package/dist/modules/doc/infrastructure/doc.po.mjs.map +1 -0
  84. package/dist/modules/doc/infrastructure/doc.repo.pg.d.mts +32 -0
  85. package/dist/modules/doc/infrastructure/doc.repo.pg.d.mts.map +1 -0
  86. package/dist/modules/doc/infrastructure/doc.repo.pg.mjs +157 -0
  87. package/dist/modules/doc/infrastructure/doc.repo.pg.mjs.map +1 -0
  88. package/dist/modules/doc/infrastructure/doc.repo.sqlite.d.mts +32 -0
  89. package/dist/modules/doc/infrastructure/doc.repo.sqlite.d.mts.map +1 -0
  90. package/dist/modules/doc/infrastructure/doc.repo.sqlite.mjs +153 -0
  91. package/dist/modules/doc/infrastructure/doc.repo.sqlite.mjs.map +1 -0
  92. package/dist/modules/doc/mcp.route.d.mts +18 -0
  93. package/dist/modules/doc/mcp.route.d.mts.map +1 -0
  94. package/dist/modules/doc/mcp.route.mjs +39 -0
  95. package/dist/modules/doc/mcp.route.mjs.map +1 -0
  96. package/dist/modules/doc/mcp.service.d.mts +22 -0
  97. package/dist/modules/doc/mcp.service.d.mts.map +1 -0
  98. package/dist/modules/doc/mcp.service.mjs +119 -0
  99. package/dist/modules/doc/mcp.service.mjs.map +1 -0
  100. package/dist/modules/rank/rank.dto.d.mts +10 -0
  101. package/dist/modules/rank/rank.dto.d.mts.map +1 -0
  102. package/dist/modules/rank/rank.dto.mjs +8 -0
  103. package/dist/modules/rank/rank.dto.mjs.map +1 -0
  104. package/dist/modules/rank/rank.route.d.mts +2033 -0
  105. package/dist/modules/rank/rank.route.d.mts.map +1 -0
  106. package/dist/modules/rank/rank.route.mjs +20 -0
  107. package/dist/modules/rank/rank.route.mjs.map +1 -0
  108. package/dist/modules/rank/rank.service.d.mts +32 -0
  109. package/dist/modules/rank/rank.service.d.mts.map +1 -0
  110. package/dist/modules/rank/rank.service.mjs +3 -0
  111. package/dist/modules/rank/rank.vo.d.mts +9 -0
  112. package/dist/modules/rank/rank.vo.d.mts.map +1 -0
  113. package/dist/modules/rank/rank.vo.mjs +1 -0
  114. package/dist/modules/task/infrastructure/mq/task-context.d.mts +29 -0
  115. package/dist/modules/task/infrastructure/mq/task-context.d.mts.map +1 -0
  116. package/dist/modules/task/infrastructure/mq/task-context.mjs +70 -0
  117. package/dist/modules/task/infrastructure/mq/task-context.mjs.map +1 -0
  118. package/dist/modules/task/infrastructure/mq/task-queue.d.mts +10 -0
  119. package/dist/modules/task/infrastructure/mq/task-queue.d.mts.map +1 -0
  120. package/dist/modules/task/infrastructure/mq/task-queue.mjs +12 -0
  121. package/dist/modules/task/infrastructure/mq/task-queue.mjs.map +1 -0
  122. package/dist/modules/task/infrastructure/mq/task-worker.d.mts +13 -0
  123. package/dist/modules/task/infrastructure/mq/task-worker.d.mts.map +1 -0
  124. package/dist/modules/task/infrastructure/mq/task-worker.mjs +35 -0
  125. package/dist/modules/task/infrastructure/mq/task-worker.mjs.map +1 -0
  126. package/dist/modules/task/infrastructure/task.po.d.mts +1147 -0
  127. package/dist/modules/task/infrastructure/task.po.d.mts.map +1 -0
  128. package/dist/modules/task/infrastructure/task.po.mjs +55 -0
  129. package/dist/modules/task/infrastructure/task.po.mjs.map +1 -0
  130. package/dist/modules/task/infrastructure/task.repo.pg.d.mts +21 -0
  131. package/dist/modules/task/infrastructure/task.repo.pg.d.mts.map +1 -0
  132. package/dist/modules/task/infrastructure/task.repo.pg.mjs +86 -0
  133. package/dist/modules/task/infrastructure/task.repo.pg.mjs.map +1 -0
  134. package/dist/modules/task/infrastructure/task.repo.sqlite.d.mts +21 -0
  135. package/dist/modules/task/infrastructure/task.repo.sqlite.d.mts.map +1 -0
  136. package/dist/modules/task/infrastructure/task.repo.sqlite.mjs +89 -0
  137. package/dist/modules/task/infrastructure/task.repo.sqlite.mjs.map +1 -0
  138. package/dist/modules/task/task.dto.d.mts +26 -0
  139. package/dist/modules/task/task.dto.d.mts.map +1 -0
  140. package/dist/modules/task/task.dto.mjs +25 -0
  141. package/dist/modules/task/task.dto.mjs.map +1 -0
  142. package/dist/modules/task/task.entity.d.mts +43 -0
  143. package/dist/modules/task/task.entity.d.mts.map +1 -0
  144. package/dist/modules/task/task.entity.mjs +1 -0
  145. package/dist/modules/task/task.repo.interface.d.mts +17 -0
  146. package/dist/modules/task/task.repo.interface.d.mts.map +1 -0
  147. package/dist/modules/task/task.repo.interface.mjs +1 -0
  148. package/dist/modules/task/task.route.d.mts +4087 -0
  149. package/dist/modules/task/task.route.d.mts.map +1 -0
  150. package/dist/modules/task/task.route.mjs +63 -0
  151. package/dist/modules/task/task.route.mjs.map +1 -0
  152. package/dist/modules/task/task.service.d.mts +28 -0
  153. package/dist/modules/task/task.service.d.mts.map +1 -0
  154. package/dist/modules/task/task.service.mjs +202 -0
  155. package/dist/modules/task/task.service.mjs.map +1 -0
  156. package/dist/modules/task/task.vo.d.mts +18 -0
  157. package/dist/modules/task/task.vo.d.mts.map +1 -0
  158. package/dist/modules/task/task.vo.mjs +1 -0
  159. package/dist/modules/user/application/user.service.d.mts +24 -0
  160. package/dist/modules/user/application/user.service.d.mts.map +1 -0
  161. package/dist/modules/user/application/user.service.mjs +153 -0
  162. package/dist/modules/user/application/user.service.mjs.map +1 -0
  163. package/dist/modules/user/domain/user.entity.d.mts +24 -0
  164. package/dist/modules/user/domain/user.entity.d.mts.map +1 -0
  165. package/dist/modules/user/domain/user.entity.mjs +35 -0
  166. package/dist/modules/user/domain/user.entity.mjs.map +1 -0
  167. package/dist/modules/user/domain/user.repo.interface.d.mts +27 -0
  168. package/dist/modules/user/domain/user.repo.interface.d.mts.map +1 -0
  169. package/dist/modules/user/domain/user.repo.interface.mjs +1 -0
  170. package/dist/modules/user/infrastructure/casbin/adapter.d.mts +7 -0
  171. package/dist/modules/user/infrastructure/casbin/adapter.d.mts.map +1 -0
  172. package/dist/modules/user/infrastructure/casbin/adapter.mjs +13 -0
  173. package/dist/modules/user/infrastructure/casbin/adapter.mjs.map +1 -0
  174. package/dist/modules/user/infrastructure/casbin/adapter.pg.d.mts +19 -0
  175. package/dist/modules/user/infrastructure/casbin/adapter.pg.d.mts.map +1 -0
  176. package/dist/modules/user/infrastructure/casbin/adapter.pg.mjs +129 -0
  177. package/dist/modules/user/infrastructure/casbin/adapter.pg.mjs.map +1 -0
  178. package/dist/modules/user/infrastructure/casbin/adapter.sqlite.d.mts +19 -0
  179. package/dist/modules/user/infrastructure/casbin/adapter.sqlite.d.mts.map +1 -0
  180. package/dist/modules/user/infrastructure/casbin/adapter.sqlite.mjs +129 -0
  181. package/dist/modules/user/infrastructure/casbin/adapter.sqlite.mjs.map +1 -0
  182. package/dist/modules/user/infrastructure/casbin/enforcer.d.mts +9 -0
  183. package/dist/modules/user/infrastructure/casbin/enforcer.d.mts.map +1 -0
  184. package/dist/modules/user/infrastructure/casbin/enforcer.mjs +150 -0
  185. package/dist/modules/user/infrastructure/casbin/enforcer.mjs.map +1 -0
  186. package/dist/modules/user/infrastructure/casbin-rule.po.d.mts +643 -0
  187. package/dist/modules/user/infrastructure/casbin-rule.po.d.mts.map +1 -0
  188. package/dist/modules/user/infrastructure/casbin-rule.po.mjs +30 -0
  189. package/dist/modules/user/infrastructure/casbin-rule.po.mjs.map +1 -0
  190. package/dist/modules/user/infrastructure/user.po.d.mts +392 -0
  191. package/dist/modules/user/infrastructure/user.po.d.mts.map +1 -0
  192. package/dist/modules/user/infrastructure/user.po.mjs +34 -0
  193. package/dist/modules/user/infrastructure/user.po.mjs.map +1 -0
  194. package/dist/modules/user/infrastructure/user.repo.pg.d.mts +24 -0
  195. package/dist/modules/user/infrastructure/user.repo.pg.d.mts.map +1 -0
  196. package/dist/modules/user/infrastructure/user.repo.pg.mjs +90 -0
  197. package/dist/modules/user/infrastructure/user.repo.pg.mjs.map +1 -0
  198. package/dist/modules/user/infrastructure/user.repo.sqlite.d.mts +24 -0
  199. package/dist/modules/user/infrastructure/user.repo.sqlite.d.mts.map +1 -0
  200. package/dist/modules/user/infrastructure/user.repo.sqlite.mjs +88 -0
  201. package/dist/modules/user/infrastructure/user.repo.sqlite.mjs.map +1 -0
  202. package/dist/modules/user/interfaces/admin.route.d.mts +8270 -0
  203. package/dist/modules/user/interfaces/admin.route.d.mts.map +1 -0
  204. package/dist/modules/user/interfaces/admin.route.mjs +74 -0
  205. package/dist/modules/user/interfaces/admin.route.mjs.map +1 -0
  206. package/dist/modules/user/interfaces/role.route.d.mts +102 -0
  207. package/dist/modules/user/interfaces/role.route.d.mts.map +1 -0
  208. package/dist/modules/user/interfaces/role.route.mjs +60 -0
  209. package/dist/modules/user/interfaces/role.route.mjs.map +1 -0
  210. package/dist/modules/user/interfaces/user.dto.d.mts +106 -0
  211. package/dist/modules/user/interfaces/user.dto.d.mts.map +1 -0
  212. package/dist/modules/user/interfaces/user.dto.mjs +32 -0
  213. package/dist/modules/user/interfaces/user.dto.mjs.map +1 -0
  214. package/dist/modules/user/interfaces/user.route.d.mts +2093 -0
  215. package/dist/modules/user/interfaces/user.route.d.mts.map +1 -0
  216. package/dist/modules/user/interfaces/user.route.mjs +69 -0
  217. package/dist/modules/user/interfaces/user.route.mjs.map +1 -0
  218. package/dist/modules/user/interfaces/user.vo.d.mts +28 -0
  219. package/dist/modules/user/interfaces/user.vo.d.mts.map +1 -0
  220. package/dist/modules/user/interfaces/user.vo.mjs +18 -0
  221. package/dist/modules/user/interfaces/user.vo.mjs.map +1 -0
  222. package/dist/rank.service-D2h-2iJA.mjs +109 -0
  223. package/dist/rank.service-D2h-2iJA.mjs.map +1 -0
  224. package/dist/settings.d.mts +12 -0
  225. package/dist/settings.d.mts.map +1 -0
  226. package/dist/settings.mjs +27 -0
  227. package/dist/settings.mjs.map +1 -0
  228. package/dist/shared/create-app.d.mts +13 -0
  229. package/dist/shared/create-app.d.mts.map +1 -0
  230. package/dist/shared/create-app.mjs +45 -0
  231. package/dist/shared/create-app.mjs.map +1 -0
  232. package/dist/shared/db/bootstrap.d.mts +5 -0
  233. package/dist/shared/db/bootstrap.d.mts.map +1 -0
  234. package/dist/shared/db/bootstrap.mjs +51 -0
  235. package/dist/shared/db/bootstrap.mjs.map +1 -0
  236. package/dist/shared/db/connection.d.mts +1567 -0
  237. package/dist/shared/db/connection.d.mts.map +1 -0
  238. package/dist/shared/db/connection.mjs +59 -0
  239. package/dist/shared/db/connection.mjs.map +1 -0
  240. package/dist/shared/db/migrations/pg/0000_init.sql +74 -0
  241. package/dist/shared/db/migrations/pg/0001_snippets & tokens.sql +6 -0
  242. package/dist/shared/db/migrations/pg/0002_change_task_id_to_uuid_v7.sql +3 -0
  243. package/dist/shared/db/migrations/pg/meta/0000_snapshot.json +498 -0
  244. package/dist/shared/db/migrations/pg/meta/0001_snapshot.json +513 -0
  245. package/dist/shared/db/migrations/pg/meta/0002_snapshot.json +514 -0
  246. package/dist/shared/db/migrations/pg/meta/_journal.json +27 -0
  247. package/dist/shared/db/migrations/sqlite/0000_init.sql +72 -0
  248. package/dist/shared/db/migrations/sqlite/0001_snippets & tokens.sql +2 -0
  249. package/dist/shared/db/migrations/sqlite/0002_change_task_id_to_uuid_v7.sql +35 -0
  250. package/dist/shared/db/migrations/sqlite/meta/0000_snapshot.json +493 -0
  251. package/dist/shared/db/migrations/sqlite/meta/0001_snapshot.json +509 -0
  252. package/dist/shared/db/migrations/sqlite/meta/0002_snapshot.json +509 -0
  253. package/dist/shared/db/migrations/sqlite/meta/_journal.json +27 -0
  254. package/dist/shared/db/seed.d.mts +5 -0
  255. package/dist/shared/db/seed.d.mts.map +1 -0
  256. package/dist/shared/db/seed.mjs +42 -0
  257. package/dist/shared/db/seed.mjs.map +1 -0
  258. package/dist/shared/deps.d.mts +28 -0
  259. package/dist/shared/deps.d.mts.map +1 -0
  260. package/dist/shared/deps.mjs +69 -0
  261. package/dist/shared/deps.mjs.map +1 -0
  262. package/dist/shared/dto/index.d.mts +11 -0
  263. package/dist/shared/dto/index.d.mts.map +1 -0
  264. package/dist/shared/dto/index.mjs +11 -0
  265. package/dist/shared/dto/index.mjs.map +1 -0
  266. package/dist/shared/logger.d.mts +14 -0
  267. package/dist/shared/logger.d.mts.map +1 -0
  268. package/dist/shared/logger.mjs +37 -0
  269. package/dist/shared/logger.mjs.map +1 -0
  270. package/dist/shared/mcp/createTool.d.mts +15 -0
  271. package/dist/shared/mcp/createTool.d.mts.map +1 -0
  272. package/dist/shared/mcp/createTool.mjs +8 -0
  273. package/dist/shared/mcp/createTool.mjs.map +1 -0
  274. package/dist/shared/middleware/authorization.d.mts +15 -0
  275. package/dist/shared/middleware/authorization.d.mts.map +1 -0
  276. package/dist/shared/middleware/authorization.mjs +46 -0
  277. package/dist/shared/middleware/authorization.mjs.map +1 -0
  278. package/dist/shared/middleware/http-logger.d.mts +7 -0
  279. package/dist/shared/middleware/http-logger.d.mts.map +1 -0
  280. package/dist/shared/middleware/http-logger.mjs +40 -0
  281. package/dist/shared/middleware/http-logger.mjs.map +1 -0
  282. package/dist/shared/middleware/jwt.d.mts +7 -0
  283. package/dist/shared/middleware/jwt.d.mts.map +1 -0
  284. package/dist/shared/middleware/jwt.mjs +34 -0
  285. package/dist/shared/middleware/jwt.mjs.map +1 -0
  286. package/dist/shared/middleware/limiter.d.mts +7 -0
  287. package/dist/shared/middleware/limiter.d.mts.map +1 -0
  288. package/dist/shared/middleware/limiter.mjs +10 -0
  289. package/dist/shared/middleware/limiter.mjs.map +1 -0
  290. package/dist/shared/middleware/services.d.mts +8 -0
  291. package/dist/shared/middleware/services.d.mts.map +1 -0
  292. package/dist/shared/middleware/services.mjs +19 -0
  293. package/dist/shared/middleware/services.mjs.map +1 -0
  294. package/dist/shared/redis/decorator.d.mts +113 -0
  295. package/dist/shared/redis/decorator.d.mts.map +1 -0
  296. package/dist/shared/redis/decorator.mjs +203 -0
  297. package/dist/shared/redis/decorator.mjs.map +1 -0
  298. package/dist/shared/redis/factory.d.mts +18 -0
  299. package/dist/shared/redis/factory.d.mts.map +1 -0
  300. package/dist/shared/redis/factory.mjs +41 -0
  301. package/dist/shared/redis/factory.mjs.map +1 -0
  302. package/dist/shared/redis/index.d.mts +12 -0
  303. package/dist/shared/redis/index.d.mts.map +1 -0
  304. package/dist/shared/redis/index.mjs +14 -0
  305. package/dist/shared/redis/index.mjs.map +1 -0
  306. package/dist/shared/types.d.mts +36 -0
  307. package/dist/shared/types.d.mts.map +1 -0
  308. package/dist/shared/types.mjs +1 -0
  309. package/dist/shared/utils/date.d.mts +1 -0
  310. package/dist/shared/utils/date.mjs +1 -0
  311. package/dist/shared/utils/error-handler.d.mts +7 -0
  312. package/dist/shared/utils/error-handler.d.mts.map +1 -0
  313. package/dist/shared/utils/error-handler.mjs +22 -0
  314. package/dist/shared/utils/error-handler.mjs.map +1 -0
  315. package/dist/shared/utils/format.d.mts +8 -0
  316. package/dist/shared/utils/format.d.mts.map +1 -0
  317. package/dist/shared/utils/format.mjs +24 -0
  318. package/dist/shared/utils/format.mjs.map +1 -0
  319. package/dist/shared/utils/pagination.d.mts +9 -0
  320. package/dist/shared/utils/pagination.d.mts.map +1 -0
  321. package/dist/shared/utils/pagination.mjs +12 -0
  322. package/dist/shared/utils/pagination.mjs.map +1 -0
  323. package/dist/shared/utils/response-template.d.mts +69 -0
  324. package/dist/shared/utils/response-template.d.mts.map +1 -0
  325. package/dist/shared/utils/response-template.mjs +96 -0
  326. package/dist/shared/utils/response-template.mjs.map +1 -0
  327. package/dist/shared/utils/url.d.mts +18 -0
  328. package/dist/shared/utils/url.d.mts.map +1 -0
  329. package/dist/shared/utils/url.mjs +39 -0
  330. package/dist/shared/utils/url.mjs.map +1 -0
  331. package/dist/shared/utils/user.d.mts +8 -0
  332. package/dist/shared/utils/user.d.mts.map +1 -0
  333. package/dist/shared/utils/user.mjs +11 -0
  334. package/dist/shared/utils/user.mjs.map +1 -0
  335. package/dist/shared/utils/validator.d.mts +5984 -0
  336. package/dist/shared/utils/validator.d.mts.map +1 -0
  337. package/dist/shared/utils/validator.mjs +34 -0
  338. package/dist/shared/utils/validator.mjs.map +1 -0
  339. package/dist/shared/vo/index.d.mts +11 -0
  340. package/dist/shared/vo/index.d.mts.map +1 -0
  341. package/dist/shared/vo/index.mjs +1 -0
  342. package/package.json +86 -0
@@ -0,0 +1,392 @@
1
+ import * as drizzle_orm_pg_core0 from "drizzle-orm/pg-core";
2
+ import * as drizzle_orm_sqlite_core0 from "drizzle-orm/sqlite-core";
3
+
4
+ //#region src/modules/user/infrastructure/user.po.d.ts
5
+ declare const userRoleEnum: drizzle_orm_pg_core0.PgEnum<["admin", "user"]>;
6
+ declare const userPg: drizzle_orm_pg_core0.PgTableWithColumns<{
7
+ name: "user";
8
+ schema: undefined;
9
+ columns: {
10
+ id: drizzle_orm_pg_core0.PgColumn<{
11
+ name: "id";
12
+ tableName: "user";
13
+ dataType: "number";
14
+ columnType: "PgSerial";
15
+ data: number;
16
+ driverParam: number;
17
+ notNull: true;
18
+ hasDefault: true;
19
+ isPrimaryKey: true;
20
+ isAutoincrement: false;
21
+ hasRuntimeDefault: false;
22
+ enumValues: undefined;
23
+ baseColumn: never;
24
+ identity: undefined;
25
+ generated: undefined;
26
+ }, {}, {}>;
27
+ username: drizzle_orm_pg_core0.PgColumn<{
28
+ name: "username";
29
+ tableName: "user";
30
+ dataType: "string";
31
+ columnType: "PgVarchar";
32
+ data: string;
33
+ driverParam: string;
34
+ notNull: true;
35
+ hasDefault: false;
36
+ isPrimaryKey: false;
37
+ isAutoincrement: false;
38
+ hasRuntimeDefault: false;
39
+ enumValues: [string, ...string[]];
40
+ baseColumn: never;
41
+ identity: undefined;
42
+ generated: undefined;
43
+ }, {}, {
44
+ length: 64;
45
+ }>;
46
+ password: drizzle_orm_pg_core0.PgColumn<{
47
+ name: "password";
48
+ tableName: "user";
49
+ dataType: "string";
50
+ columnType: "PgVarchar";
51
+ data: string;
52
+ driverParam: string;
53
+ notNull: true;
54
+ hasDefault: false;
55
+ isPrimaryKey: false;
56
+ isAutoincrement: false;
57
+ hasRuntimeDefault: false;
58
+ enumValues: [string, ...string[]];
59
+ baseColumn: never;
60
+ identity: undefined;
61
+ generated: undefined;
62
+ }, {}, {
63
+ length: 128;
64
+ }>;
65
+ name: drizzle_orm_pg_core0.PgColumn<{
66
+ name: "name";
67
+ tableName: "user";
68
+ dataType: "string";
69
+ columnType: "PgVarchar";
70
+ data: string;
71
+ driverParam: string;
72
+ notNull: true;
73
+ hasDefault: false;
74
+ isPrimaryKey: false;
75
+ isAutoincrement: false;
76
+ hasRuntimeDefault: false;
77
+ enumValues: [string, ...string[]];
78
+ baseColumn: never;
79
+ identity: undefined;
80
+ generated: undefined;
81
+ }, {}, {
82
+ length: 128;
83
+ }>;
84
+ phone: drizzle_orm_pg_core0.PgColumn<{
85
+ name: "phone";
86
+ tableName: "user";
87
+ dataType: "string";
88
+ columnType: "PgVarchar";
89
+ data: string;
90
+ driverParam: string;
91
+ notNull: true;
92
+ hasDefault: false;
93
+ isPrimaryKey: false;
94
+ isAutoincrement: false;
95
+ hasRuntimeDefault: false;
96
+ enumValues: [string, ...string[]];
97
+ baseColumn: never;
98
+ identity: undefined;
99
+ generated: undefined;
100
+ }, {}, {
101
+ length: 32;
102
+ }>;
103
+ email: drizzle_orm_pg_core0.PgColumn<{
104
+ name: "email";
105
+ tableName: "user";
106
+ dataType: "string";
107
+ columnType: "PgVarchar";
108
+ data: string;
109
+ driverParam: string;
110
+ notNull: true;
111
+ hasDefault: false;
112
+ isPrimaryKey: false;
113
+ isAutoincrement: false;
114
+ hasRuntimeDefault: false;
115
+ enumValues: [string, ...string[]];
116
+ baseColumn: never;
117
+ identity: undefined;
118
+ generated: undefined;
119
+ }, {}, {
120
+ length: 254;
121
+ }>;
122
+ role: drizzle_orm_pg_core0.PgColumn<{
123
+ name: "role";
124
+ tableName: "user";
125
+ dataType: "string";
126
+ columnType: "PgEnumColumn";
127
+ data: "user" | "admin";
128
+ driverParam: string;
129
+ notNull: true;
130
+ hasDefault: true;
131
+ isPrimaryKey: false;
132
+ isAutoincrement: false;
133
+ hasRuntimeDefault: false;
134
+ enumValues: ["admin", "user"];
135
+ baseColumn: never;
136
+ identity: undefined;
137
+ generated: undefined;
138
+ }, {}, {}>;
139
+ status: drizzle_orm_pg_core0.PgColumn<{
140
+ name: "status";
141
+ tableName: "user";
142
+ dataType: "string";
143
+ columnType: "PgVarchar";
144
+ data: string;
145
+ driverParam: string;
146
+ notNull: true;
147
+ hasDefault: true;
148
+ isPrimaryKey: false;
149
+ isAutoincrement: false;
150
+ hasRuntimeDefault: false;
151
+ enumValues: [string, ...string[]];
152
+ baseColumn: never;
153
+ identity: undefined;
154
+ generated: undefined;
155
+ }, {}, {
156
+ length: 16;
157
+ }>;
158
+ createdAt: drizzle_orm_pg_core0.PgColumn<{
159
+ name: "created_at";
160
+ tableName: "user";
161
+ dataType: "number";
162
+ columnType: "PgBigInt53";
163
+ data: number;
164
+ driverParam: string | number;
165
+ notNull: true;
166
+ hasDefault: true;
167
+ isPrimaryKey: false;
168
+ isAutoincrement: false;
169
+ hasRuntimeDefault: false;
170
+ enumValues: undefined;
171
+ baseColumn: never;
172
+ identity: undefined;
173
+ generated: undefined;
174
+ }, {}, {}>;
175
+ updatedAt: drizzle_orm_pg_core0.PgColumn<{
176
+ name: "updated_at";
177
+ tableName: "user";
178
+ dataType: "number";
179
+ columnType: "PgBigInt53";
180
+ data: number;
181
+ driverParam: string | number;
182
+ notNull: true;
183
+ hasDefault: true;
184
+ isPrimaryKey: false;
185
+ isAutoincrement: false;
186
+ hasRuntimeDefault: false;
187
+ enumValues: undefined;
188
+ baseColumn: never;
189
+ identity: undefined;
190
+ generated: undefined;
191
+ }, {}, {}>;
192
+ };
193
+ dialect: "pg";
194
+ }>;
195
+ type UserPgPO = typeof userPg.$inferSelect;
196
+ type InsertUserPgPO = typeof userPg.$inferInsert;
197
+ declare const userSqlite: drizzle_orm_sqlite_core0.SQLiteTableWithColumns<{
198
+ name: "user";
199
+ schema: undefined;
200
+ columns: {
201
+ id: drizzle_orm_sqlite_core0.SQLiteColumn<{
202
+ name: "id";
203
+ tableName: "user";
204
+ dataType: "number";
205
+ columnType: "SQLiteInteger";
206
+ data: number;
207
+ driverParam: number;
208
+ notNull: true;
209
+ hasDefault: true;
210
+ isPrimaryKey: true;
211
+ isAutoincrement: false;
212
+ hasRuntimeDefault: false;
213
+ enumValues: undefined;
214
+ baseColumn: never;
215
+ identity: undefined;
216
+ generated: undefined;
217
+ }, {}, {}>;
218
+ username: drizzle_orm_sqlite_core0.SQLiteColumn<{
219
+ name: "username";
220
+ tableName: "user";
221
+ dataType: "string";
222
+ columnType: "SQLiteText";
223
+ data: string;
224
+ driverParam: string;
225
+ notNull: true;
226
+ hasDefault: false;
227
+ isPrimaryKey: false;
228
+ isAutoincrement: false;
229
+ hasRuntimeDefault: false;
230
+ enumValues: [string, ...string[]];
231
+ baseColumn: never;
232
+ identity: undefined;
233
+ generated: undefined;
234
+ }, {}, {
235
+ length: number | undefined;
236
+ }>;
237
+ password: drizzle_orm_sqlite_core0.SQLiteColumn<{
238
+ name: "password";
239
+ tableName: "user";
240
+ dataType: "string";
241
+ columnType: "SQLiteText";
242
+ data: string;
243
+ driverParam: string;
244
+ notNull: true;
245
+ hasDefault: false;
246
+ isPrimaryKey: false;
247
+ isAutoincrement: false;
248
+ hasRuntimeDefault: false;
249
+ enumValues: [string, ...string[]];
250
+ baseColumn: never;
251
+ identity: undefined;
252
+ generated: undefined;
253
+ }, {}, {
254
+ length: number | undefined;
255
+ }>;
256
+ name: drizzle_orm_sqlite_core0.SQLiteColumn<{
257
+ name: "name";
258
+ tableName: "user";
259
+ dataType: "string";
260
+ columnType: "SQLiteText";
261
+ data: string;
262
+ driverParam: string;
263
+ notNull: true;
264
+ hasDefault: false;
265
+ isPrimaryKey: false;
266
+ isAutoincrement: false;
267
+ hasRuntimeDefault: false;
268
+ enumValues: [string, ...string[]];
269
+ baseColumn: never;
270
+ identity: undefined;
271
+ generated: undefined;
272
+ }, {}, {
273
+ length: number | undefined;
274
+ }>;
275
+ phone: drizzle_orm_sqlite_core0.SQLiteColumn<{
276
+ name: "phone";
277
+ tableName: "user";
278
+ dataType: "string";
279
+ columnType: "SQLiteText";
280
+ data: string;
281
+ driverParam: string;
282
+ notNull: true;
283
+ hasDefault: false;
284
+ isPrimaryKey: false;
285
+ isAutoincrement: false;
286
+ hasRuntimeDefault: false;
287
+ enumValues: [string, ...string[]];
288
+ baseColumn: never;
289
+ identity: undefined;
290
+ generated: undefined;
291
+ }, {}, {
292
+ length: number | undefined;
293
+ }>;
294
+ email: drizzle_orm_sqlite_core0.SQLiteColumn<{
295
+ name: "email";
296
+ tableName: "user";
297
+ dataType: "string";
298
+ columnType: "SQLiteText";
299
+ data: string;
300
+ driverParam: string;
301
+ notNull: true;
302
+ hasDefault: false;
303
+ isPrimaryKey: false;
304
+ isAutoincrement: false;
305
+ hasRuntimeDefault: false;
306
+ enumValues: [string, ...string[]];
307
+ baseColumn: never;
308
+ identity: undefined;
309
+ generated: undefined;
310
+ }, {}, {
311
+ length: number | undefined;
312
+ }>;
313
+ role: drizzle_orm_sqlite_core0.SQLiteColumn<{
314
+ name: "role";
315
+ tableName: "user";
316
+ dataType: "string";
317
+ columnType: "SQLiteText";
318
+ data: string;
319
+ driverParam: string;
320
+ notNull: true;
321
+ hasDefault: true;
322
+ isPrimaryKey: false;
323
+ isAutoincrement: false;
324
+ hasRuntimeDefault: false;
325
+ enumValues: [string, ...string[]];
326
+ baseColumn: never;
327
+ identity: undefined;
328
+ generated: undefined;
329
+ }, {}, {
330
+ length: number | undefined;
331
+ }>;
332
+ status: drizzle_orm_sqlite_core0.SQLiteColumn<{
333
+ name: "status";
334
+ tableName: "user";
335
+ dataType: "string";
336
+ columnType: "SQLiteText";
337
+ data: string;
338
+ driverParam: string;
339
+ notNull: true;
340
+ hasDefault: true;
341
+ isPrimaryKey: false;
342
+ isAutoincrement: false;
343
+ hasRuntimeDefault: false;
344
+ enumValues: [string, ...string[]];
345
+ baseColumn: never;
346
+ identity: undefined;
347
+ generated: undefined;
348
+ }, {}, {
349
+ length: number | undefined;
350
+ }>;
351
+ createdAt: drizzle_orm_sqlite_core0.SQLiteColumn<{
352
+ name: "created_at";
353
+ tableName: "user";
354
+ dataType: "number";
355
+ columnType: "SQLiteInteger";
356
+ data: number;
357
+ driverParam: number;
358
+ notNull: true;
359
+ hasDefault: true;
360
+ isPrimaryKey: false;
361
+ isAutoincrement: false;
362
+ hasRuntimeDefault: false;
363
+ enumValues: undefined;
364
+ baseColumn: never;
365
+ identity: undefined;
366
+ generated: undefined;
367
+ }, {}, {}>;
368
+ updatedAt: drizzle_orm_sqlite_core0.SQLiteColumn<{
369
+ name: "updated_at";
370
+ tableName: "user";
371
+ dataType: "number";
372
+ columnType: "SQLiteInteger";
373
+ data: number;
374
+ driverParam: number;
375
+ notNull: true;
376
+ hasDefault: true;
377
+ isPrimaryKey: false;
378
+ isAutoincrement: false;
379
+ hasRuntimeDefault: false;
380
+ enumValues: undefined;
381
+ baseColumn: never;
382
+ identity: undefined;
383
+ generated: undefined;
384
+ }, {}, {}>;
385
+ };
386
+ dialect: "sqlite";
387
+ }>;
388
+ type UserSqlitePO = typeof userSqlite.$inferSelect;
389
+ type InsertUserSqlitePO = typeof userSqlite.$inferInsert;
390
+ //#endregion
391
+ export { InsertUserPgPO, InsertUserSqlitePO, UserPgPO, UserSqlitePO, userPg, userRoleEnum, userSqlite };
392
+ //# sourceMappingURL=user.po.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.po.d.mts","names":[],"sources":["../../../../src/modules/user/infrastructure/user.po.ts"],"mappings":";;;;cAIa,YAAA,EAAqD,oBAAA,CAAzC,MAAA;AAAA,cAEZ,MAAA,uBAAM,kBAAA;;;;QAWjB,oBAAA,CAAA,QAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAEU,QAAA,UAAkB,MAAA,CAAO,YAAA;AAAA,KACzB,cAAA,UAAwB,MAAA,CAAO,YAAA;AAAA,cAE9B,UAAA,2BAAU,sBAAA;;;;QAWrB,wBAAA,CAAA,YAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;KAEU,YAAA,UAAsB,UAAA,CAAW,YAAA;AAAA,KACjC,kBAAA,UAA4B,UAAA,CAAW,YAAA"}
@@ -0,0 +1,34 @@
1
+ import { sql } from "drizzle-orm";
2
+ import { bigint, pgEnum, pgTable, serial, varchar } from "drizzle-orm/pg-core";
3
+ import { integer as integer$1, sqliteTable, text as text$1 } from "drizzle-orm/sqlite-core";
4
+
5
+ //#region src/modules/user/infrastructure/user.po.ts
6
+ const userRoleEnum = pgEnum("user_role", ["admin", "user"]);
7
+ const userPg = pgTable("user", {
8
+ id: serial("id").primaryKey(),
9
+ username: varchar("username", { length: 64 }).notNull().unique(),
10
+ password: varchar("password", { length: 128 }).notNull(),
11
+ name: varchar("name", { length: 128 }).notNull(),
12
+ phone: varchar("phone", { length: 32 }).notNull().unique(),
13
+ email: varchar("email", { length: 254 }).notNull().unique(),
14
+ role: userRoleEnum("role").notNull().default("user"),
15
+ status: varchar("status", { length: 16 }).notNull().default("active"),
16
+ createdAt: bigint("created_at", { mode: "number" }).notNull().default(sql`EXTRACT(EPOCH FROM NOW()) * 1000`),
17
+ updatedAt: bigint("updated_at", { mode: "number" }).notNull().default(sql`EXTRACT(EPOCH FROM NOW()) * 1000`)
18
+ });
19
+ const userSqlite = sqliteTable("user", {
20
+ id: integer$1("id").primaryKey({ autoIncrement: true }),
21
+ username: text$1("username").notNull().unique(),
22
+ password: text$1("password").notNull(),
23
+ name: text$1("name").notNull(),
24
+ phone: text$1("phone").notNull().unique(),
25
+ email: text$1("email").notNull().unique(),
26
+ role: text$1("role").notNull().default("user"),
27
+ status: text$1("status").notNull().default("active"),
28
+ createdAt: integer$1("created_at").notNull().default(sql`(strftime('%s','now') * 1000)`),
29
+ updatedAt: integer$1("updated_at").notNull().default(sql`(strftime('%s','now') * 1000)`)
30
+ });
31
+
32
+ //#endregion
33
+ export { userPg, userRoleEnum, userSqlite };
34
+ //# sourceMappingURL=user.po.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.po.mjs","names":["integer","text"],"sources":["../../../../src/modules/user/infrastructure/user.po.ts"],"sourcesContent":["import { sql } from 'drizzle-orm'\nimport { bigint, pgEnum, pgTable, serial, varchar } from 'drizzle-orm/pg-core'\nimport { integer, sqliteTable, text } from 'drizzle-orm/sqlite-core'\n\nexport const userRoleEnum = pgEnum('user_role', ['admin', 'user'])\n\nexport const userPg = pgTable('user', {\n id: serial('id').primaryKey(),\n username: varchar('username', { length: 64 }).notNull().unique(),\n password: varchar('password', { length: 128 }).notNull(),\n name: varchar('name', { length: 128 }).notNull(),\n phone: varchar('phone', { length: 32 }).notNull().unique(),\n email: varchar('email', { length: 254 }).notNull().unique(),\n role: userRoleEnum('role').notNull().default('user'),\n status: varchar('status', { length: 16 }).notNull().default('active'),\n createdAt: bigint('created_at', { mode: 'number' }).notNull().default(sql`EXTRACT(EPOCH FROM NOW()) * 1000`),\n updatedAt: bigint('updated_at', { mode: 'number' }).notNull().default(sql`EXTRACT(EPOCH FROM NOW()) * 1000`),\n})\n\nexport type UserPgPO = typeof userPg.$inferSelect\nexport type InsertUserPgPO = typeof userPg.$inferInsert\n\nexport const userSqlite = sqliteTable('user', {\n id: integer('id').primaryKey({ autoIncrement: true }),\n username: text('username').notNull().unique(),\n password: text('password').notNull(),\n name: text('name').notNull(),\n phone: text('phone').notNull().unique(),\n email: text('email').notNull().unique(),\n role: text('role').notNull().default('user'),\n status: text('status').notNull().default('active'),\n createdAt: integer('created_at').notNull().default(sql`(strftime('%s','now') * 1000)`),\n updatedAt: integer('updated_at').notNull().default(sql`(strftime('%s','now') * 1000)`),\n})\n\nexport type UserSqlitePO = typeof userSqlite.$inferSelect\nexport type InsertUserSqlitePO = typeof userSqlite.$inferInsert\n"],"mappings":";;;;;AAIA,MAAa,eAAe,OAAO,aAAa,CAAC,SAAS,OAAO,CAAC;AAElE,MAAa,SAAS,QAAQ,QAAQ;CACpC,IAAI,OAAO,KAAK,CAAC,YAAY;CAC7B,UAAU,QAAQ,YAAY,EAAE,QAAQ,IAAI,CAAC,CAAC,SAAS,CAAC,QAAQ;CAChE,UAAU,QAAQ,YAAY,EAAE,QAAQ,KAAK,CAAC,CAAC,SAAS;CACxD,MAAM,QAAQ,QAAQ,EAAE,QAAQ,KAAK,CAAC,CAAC,SAAS;CAChD,OAAO,QAAQ,SAAS,EAAE,QAAQ,IAAI,CAAC,CAAC,SAAS,CAAC,QAAQ;CAC1D,OAAO,QAAQ,SAAS,EAAE,QAAQ,KAAK,CAAC,CAAC,SAAS,CAAC,QAAQ;CAC3D,MAAM,aAAa,OAAO,CAAC,SAAS,CAAC,QAAQ,OAAO;CACpD,QAAQ,QAAQ,UAAU,EAAE,QAAQ,IAAI,CAAC,CAAC,SAAS,CAAC,QAAQ,SAAS;CACrE,WAAW,OAAO,cAAc,EAAE,MAAM,UAAU,CAAC,CAAC,SAAS,CAAC,QAAQ,GAAG,mCAAmC;CAC5G,WAAW,OAAO,cAAc,EAAE,MAAM,UAAU,CAAC,CAAC,SAAS,CAAC,QAAQ,GAAG,mCAAmC;CAC7G,CAAC;AAKF,MAAa,aAAa,YAAY,QAAQ;CAC5C,IAAIA,UAAQ,KAAK,CAAC,WAAW,EAAE,eAAe,MAAM,CAAC;CACrD,UAAUC,OAAK,WAAW,CAAC,SAAS,CAAC,QAAQ;CAC7C,UAAUA,OAAK,WAAW,CAAC,SAAS;CACpC,MAAMA,OAAK,OAAO,CAAC,SAAS;CAC5B,OAAOA,OAAK,QAAQ,CAAC,SAAS,CAAC,QAAQ;CACvC,OAAOA,OAAK,QAAQ,CAAC,SAAS,CAAC,QAAQ;CACvC,MAAMA,OAAK,OAAO,CAAC,SAAS,CAAC,QAAQ,OAAO;CAC5C,QAAQA,OAAK,SAAS,CAAC,SAAS,CAAC,QAAQ,SAAS;CAClD,WAAWD,UAAQ,aAAa,CAAC,SAAS,CAAC,QAAQ,GAAG,gCAAgC;CACtF,WAAWA,UAAQ,aAAa,CAAC,SAAS,CAAC,QAAQ,GAAG,gCAAgC;CACvF,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { PaginationVO } from "../../../shared/vo/index.mjs";
2
+ import { CreateUserDTO, UpdateSelfDTO, UpdateUserDTO } from "../interfaces/user.dto.mjs";
3
+ import { PostgresqlDB } from "../../../shared/db/connection.mjs";
4
+ import { UserEntity } from "../domain/user.entity.mjs";
5
+ import { IUserRepository } from "../domain/user.repo.interface.mjs";
6
+
7
+ //#region src/modules/user/infrastructure/user.repo.pg.d.ts
8
+ declare class PgUserRepository implements IUserRepository {
9
+ private db;
10
+ constructor(db: PostgresqlDB);
11
+ findById(id: number): Promise<UserEntity | null>;
12
+ findByUsername(usernameValue: string): Promise<UserEntity | null>;
13
+ findByPhone(phoneValue: string): Promise<UserEntity | null>;
14
+ findByEmail(emailValue: string): Promise<UserEntity | null>;
15
+ list(page: number, pageSize: number, filters?: {
16
+ name?: string;
17
+ }): Promise<PaginationVO<UserEntity>>;
18
+ create(input: CreateUserDTO): Promise<UserEntity>;
19
+ updateById(id: number, input: UpdateUserDTO): Promise<UserEntity | null>;
20
+ updateSelf(id: number, input: UpdateSelfDTO): Promise<UserEntity | null>;
21
+ }
22
+ //#endregion
23
+ export { PgUserRepository };
24
+ //# sourceMappingURL=user.repo.pg.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.repo.pg.d.mts","names":[],"sources":["../../../../src/modules/user/infrastructure/user.repo.pg.ts"],"mappings":";;;;;;;cAaa,gBAAA,YAA4B,eAAA;EAAA,QAC/B,EAAA;cAEI,EAAA,EAAI,YAAA;EAIV,QAAA,CAAS,EAAA,WAAa,OAAA,CAAQ,UAAA;EAK9B,cAAA,CAAe,aAAA,WAAwB,OAAA,CAAQ,UAAA;EAK/C,WAAA,CAAY,UAAA,WAAqB,OAAA,CAAQ,UAAA;EAKzC,WAAA,CAAY,UAAA,WAAqB,OAAA,CAAQ,UAAA;EAKzC,IAAA,CAAK,IAAA,UAAc,QAAA,UAAkB,OAAA;IAAY,IAAA;EAAA,IAAkB,OAAA,CAAQ,YAAA,CAAa,UAAA;EAuBxF,MAAA,CAAO,KAAA,EAAO,aAAA,GAAgB,OAAA,CAAQ,UAAA;EAatC,UAAA,CAAW,EAAA,UAAY,KAAA,EAAO,aAAA,GAAgB,OAAA,CAAQ,UAAA;EActD,UAAA,CAAW,EAAA,UAAY,KAAA,EAAO,aAAA,GAAgB,OAAA,CAAQ,UAAA;AAAA"}
@@ -0,0 +1,90 @@
1
+ import { userPg } from "./user.po.mjs";
2
+ import { UserEntity } from "../domain/user.entity.mjs";
3
+ import { count, eq, like } from "drizzle-orm";
4
+
5
+ //#region src/modules/user/infrastructure/user.repo.pg.ts
6
+ function mapper(row) {
7
+ return new UserEntity(row);
8
+ }
9
+ var PgUserRepository = class {
10
+ db;
11
+ constructor(db) {
12
+ this.db = db;
13
+ }
14
+ async findById(id) {
15
+ const row = await this.db.query.user.findFirst({ where: eq(userPg.id, id) });
16
+ return row ? mapper(row) : null;
17
+ }
18
+ async findByUsername(usernameValue) {
19
+ const row = await this.db.query.user.findFirst({ where: eq(userPg.username, usernameValue) });
20
+ return row ? mapper(row) : null;
21
+ }
22
+ async findByPhone(phoneValue) {
23
+ const row = await this.db.query.user.findFirst({ where: eq(userPg.phone, phoneValue) });
24
+ return row ? mapper(row) : null;
25
+ }
26
+ async findByEmail(emailValue) {
27
+ const row = await this.db.query.user.findFirst({ where: eq(userPg.email, emailValue) });
28
+ return row ? mapper(row) : null;
29
+ }
30
+ async list(page, pageSize, filters) {
31
+ const offset = (page - 1) * pageSize;
32
+ const where = (fields) => {
33
+ return filters?.name ? like(fields.name, `%${filters.name}%`) : void 0;
34
+ };
35
+ const [rows, [totalResult]] = await Promise.all([this.db.query.user.findMany({
36
+ limit: pageSize,
37
+ offset,
38
+ where,
39
+ orderBy: (fields, { desc }) => [desc(fields.createdAt)]
40
+ }), this.db.select({ value: count() }).from(userPg).where(where(userPg))]);
41
+ const list = rows.map(mapper);
42
+ const total = Number(totalResult?.value ?? 0);
43
+ return {
44
+ list,
45
+ total,
46
+ page,
47
+ pageSize,
48
+ totalPages: Math.max(1, Math.ceil(total / pageSize))
49
+ };
50
+ }
51
+ async create(input) {
52
+ const [row] = await this.db.insert(userPg).values({
53
+ username: input.username,
54
+ password: input.password,
55
+ name: input.name,
56
+ phone: input.phone,
57
+ email: input.email,
58
+ role: input.role ?? "user",
59
+ status: input.status ?? "active"
60
+ }).returning();
61
+ return mapper(row);
62
+ }
63
+ async updateById(id, input) {
64
+ const [row] = await this.db.update(userPg).set({
65
+ username: input.username,
66
+ password: input.password,
67
+ name: input.name,
68
+ phone: input.phone,
69
+ email: input.email,
70
+ role: input.role,
71
+ status: input.status,
72
+ updatedAt: Date.now()
73
+ }).where(eq(userPg.id, id)).returning();
74
+ return row ? mapper(row) : null;
75
+ }
76
+ async updateSelf(id, input) {
77
+ const [row] = await this.db.update(userPg).set({
78
+ name: input.name,
79
+ password: input.password,
80
+ phone: input.phone,
81
+ email: input.email,
82
+ updatedAt: Date.now()
83
+ }).where(eq(userPg.id, id)).returning();
84
+ return row ? mapper(row) : null;
85
+ }
86
+ };
87
+
88
+ //#endregion
89
+ export { PgUserRepository };
90
+ //# sourceMappingURL=user.repo.pg.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.repo.pg.mjs","names":[],"sources":["../../../../src/modules/user/infrastructure/user.repo.pg.ts"],"sourcesContent":["import type { UserPgPO } from './user.po'\nimport type { AuthUserRecord, IUserRepository } from '@/modules/user/domain/user.repo.interface'\nimport type { CreateUserDTO, UpdateSelfDTO, UpdateUserDTO } from '@/modules/user/interfaces/user.dto'\nimport type { PostgresqlDB } from '@/shared/db/connection'\nimport type { PaginationVO } from '@/shared/vo'\nimport { and, count, eq, like } from 'drizzle-orm'\nimport { UserEntity } from '@/modules/user/domain/user.entity'\nimport { userPg } from './user.po'\n\nfunction mapper(row: UserPgPO): UserEntity {\n return new UserEntity(row)\n}\n\nexport class PgUserRepository implements IUserRepository {\n private db: PostgresqlDB\n\n constructor(db: PostgresqlDB) {\n this.db = db\n }\n\n async findById(id: number): Promise<UserEntity | null> {\n const row = await this.db.query.user.findFirst({ where: eq(userPg.id, id) })\n return row ? mapper(row) : null\n }\n\n async findByUsername(usernameValue: string): Promise<UserEntity | null> {\n const row = await this.db.query.user.findFirst({ where: eq(userPg.username, usernameValue) })\n return row ? mapper(row) : null\n }\n\n async findByPhone(phoneValue: string): Promise<UserEntity | null> {\n const row = await this.db.query.user.findFirst({ where: eq(userPg.phone, phoneValue) })\n return row ? mapper(row) : null\n }\n\n async findByEmail(emailValue: string): Promise<UserEntity | null> {\n const row = await this.db.query.user.findFirst({ where: eq(userPg.email, emailValue) })\n return row ? mapper(row) : null\n }\n\n async list(page: number, pageSize: number, filters?: { name?: string }): Promise<PaginationVO<UserEntity>> {\n const offset = (page - 1) * pageSize\n\n const where = (fields: any) => {\n return filters?.name ? like(fields.name, `%${filters.name}%`) : undefined\n }\n\n const [rows, [totalResult]] = await Promise.all([\n this.db.query.user.findMany({\n limit: pageSize,\n offset,\n where,\n orderBy: (fields, { desc }) => [desc(fields.createdAt)],\n }),\n this.db.select({ value: count() }).from(userPg).where(where(userPg)),\n ])\n\n const list = rows.map(mapper)\n const total = Number(totalResult?.value ?? 0)\n const totalPages = Math.max(1, Math.ceil(total / pageSize))\n return { list, total, page, pageSize, totalPages }\n }\n\n async create(input: CreateUserDTO): Promise<UserEntity> {\n const [row] = await this.db.insert(userPg).values({\n username: input.username,\n password: input.password,\n name: input.name,\n phone: input.phone,\n email: input.email,\n role: input.role ?? 'user',\n status: input.status ?? 'active',\n }).returning()\n return mapper(row)\n }\n\n async updateById(id: number, input: UpdateUserDTO): Promise<UserEntity | null> {\n const [row] = await this.db.update(userPg).set({\n username: input.username,\n password: input.password,\n name: input.name,\n phone: input.phone,\n email: input.email,\n role: input.role,\n status: input.status,\n updatedAt: Date.now(),\n }).where(eq(userPg.id, id)).returning()\n return row ? mapper(row) : null\n }\n\n async updateSelf(id: number, input: UpdateSelfDTO): Promise<UserEntity | null> {\n const [row] = await this.db.update(userPg).set({\n name: input.name,\n password: input.password,\n phone: input.phone,\n email: input.email,\n updatedAt: Date.now(),\n }).where(eq(userPg.id, id)).returning()\n return row ? mapper(row) : null\n }\n}\n"],"mappings":";;;;;AASA,SAAS,OAAO,KAA2B;AACzC,QAAO,IAAI,WAAW,IAAI;;AAG5B,IAAa,mBAAb,MAAyD;CACvD,AAAQ;CAER,YAAY,IAAkB;AAC5B,OAAK,KAAK;;CAGZ,MAAM,SAAS,IAAwC;EACrD,MAAM,MAAM,MAAM,KAAK,GAAG,MAAM,KAAK,UAAU,EAAE,OAAO,GAAG,OAAO,IAAI,GAAG,EAAE,CAAC;AAC5E,SAAO,MAAM,OAAO,IAAI,GAAG;;CAG7B,MAAM,eAAe,eAAmD;EACtE,MAAM,MAAM,MAAM,KAAK,GAAG,MAAM,KAAK,UAAU,EAAE,OAAO,GAAG,OAAO,UAAU,cAAc,EAAE,CAAC;AAC7F,SAAO,MAAM,OAAO,IAAI,GAAG;;CAG7B,MAAM,YAAY,YAAgD;EAChE,MAAM,MAAM,MAAM,KAAK,GAAG,MAAM,KAAK,UAAU,EAAE,OAAO,GAAG,OAAO,OAAO,WAAW,EAAE,CAAC;AACvF,SAAO,MAAM,OAAO,IAAI,GAAG;;CAG7B,MAAM,YAAY,YAAgD;EAChE,MAAM,MAAM,MAAM,KAAK,GAAG,MAAM,KAAK,UAAU,EAAE,OAAO,GAAG,OAAO,OAAO,WAAW,EAAE,CAAC;AACvF,SAAO,MAAM,OAAO,IAAI,GAAG;;CAG7B,MAAM,KAAK,MAAc,UAAkB,SAAgE;EACzG,MAAM,UAAU,OAAO,KAAK;EAE5B,MAAM,SAAS,WAAgB;AAC7B,UAAO,SAAS,OAAO,KAAK,OAAO,MAAM,IAAI,QAAQ,KAAK,GAAG,GAAG;;EAGlE,MAAM,CAAC,MAAM,CAAC,gBAAgB,MAAM,QAAQ,IAAI,CAC9C,KAAK,GAAG,MAAM,KAAK,SAAS;GAC1B,OAAO;GACP;GACA;GACA,UAAU,QAAQ,EAAE,WAAW,CAAC,KAAK,OAAO,UAAU,CAAC;GACxD,CAAC,EACF,KAAK,GAAG,OAAO,EAAE,OAAO,OAAO,EAAE,CAAC,CAAC,KAAK,OAAO,CAAC,MAAM,MAAM,OAAO,CAAC,CACrE,CAAC;EAEF,MAAM,OAAO,KAAK,IAAI,OAAO;EAC7B,MAAM,QAAQ,OAAO,aAAa,SAAS,EAAE;AAE7C,SAAO;GAAE;GAAM;GAAO;GAAM;GAAU,YADnB,KAAK,IAAI,GAAG,KAAK,KAAK,QAAQ,SAAS,CAAC;GACT;;CAGpD,MAAM,OAAO,OAA2C;EACtD,MAAM,CAAC,OAAO,MAAM,KAAK,GAAG,OAAO,OAAO,CAAC,OAAO;GAChD,UAAU,MAAM;GAChB,UAAU,MAAM;GAChB,MAAM,MAAM;GACZ,OAAO,MAAM;GACb,OAAO,MAAM;GACb,MAAM,MAAM,QAAQ;GACpB,QAAQ,MAAM,UAAU;GACzB,CAAC,CAAC,WAAW;AACd,SAAO,OAAO,IAAI;;CAGpB,MAAM,WAAW,IAAY,OAAkD;EAC7E,MAAM,CAAC,OAAO,MAAM,KAAK,GAAG,OAAO,OAAO,CAAC,IAAI;GAC7C,UAAU,MAAM;GAChB,UAAU,MAAM;GAChB,MAAM,MAAM;GACZ,OAAO,MAAM;GACb,OAAO,MAAM;GACb,MAAM,MAAM;GACZ,QAAQ,MAAM;GACd,WAAW,KAAK,KAAK;GACtB,CAAC,CAAC,MAAM,GAAG,OAAO,IAAI,GAAG,CAAC,CAAC,WAAW;AACvC,SAAO,MAAM,OAAO,IAAI,GAAG;;CAG7B,MAAM,WAAW,IAAY,OAAkD;EAC7E,MAAM,CAAC,OAAO,MAAM,KAAK,GAAG,OAAO,OAAO,CAAC,IAAI;GAC7C,MAAM,MAAM;GACZ,UAAU,MAAM;GAChB,OAAO,MAAM;GACb,OAAO,MAAM;GACb,WAAW,KAAK,KAAK;GACtB,CAAC,CAAC,MAAM,GAAG,OAAO,IAAI,GAAG,CAAC,CAAC,WAAW;AACvC,SAAO,MAAM,OAAO,IAAI,GAAG"}
@@ -0,0 +1,24 @@
1
+ import { PaginationVO } from "../../../shared/vo/index.mjs";
2
+ import { CreateUserDTO, UpdateSelfDTO, UpdateUserDTO } from "../interfaces/user.dto.mjs";
3
+ import { SqliteDB } from "../../../shared/db/connection.mjs";
4
+ import { UserEntity } from "../domain/user.entity.mjs";
5
+ import { IUserRepository } from "../domain/user.repo.interface.mjs";
6
+
7
+ //#region src/modules/user/infrastructure/user.repo.sqlite.d.ts
8
+ declare class SqliteUserRepository implements IUserRepository {
9
+ private db;
10
+ constructor(db: SqliteDB);
11
+ findById(id: number): Promise<UserEntity | null>;
12
+ findByUsername(usernameValue: string): Promise<UserEntity | null>;
13
+ findByPhone(phoneValue: string): Promise<UserEntity | null>;
14
+ findByEmail(emailValue: string): Promise<UserEntity | null>;
15
+ list(page: number, pageSize: number, filters?: {
16
+ name?: string;
17
+ }): Promise<PaginationVO<UserEntity>>;
18
+ create(input: CreateUserDTO): Promise<UserEntity>;
19
+ updateById(id: number, input: UpdateUserDTO): Promise<UserEntity | null>;
20
+ updateSelf(id: number, input: UpdateSelfDTO): Promise<UserEntity | null>;
21
+ }
22
+ //#endregion
23
+ export { SqliteUserRepository };
24
+ //# sourceMappingURL=user.repo.sqlite.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"user.repo.sqlite.d.mts","names":[],"sources":["../../../../src/modules/user/infrastructure/user.repo.sqlite.ts"],"mappings":";;;;;;;cAaa,oBAAA,YAAgC,eAAA;EAAA,QACnC,EAAA;cAEI,EAAA,EAAI,QAAA;EAIV,QAAA,CAAS,EAAA,WAAa,OAAA,CAAQ,UAAA;EAK9B,cAAA,CAAe,aAAA,WAAwB,OAAA,CAAQ,UAAA;EAK/C,WAAA,CAAY,UAAA,WAAqB,OAAA,CAAQ,UAAA;EAKzC,WAAA,CAAY,UAAA,WAAqB,OAAA,CAAQ,UAAA;EAKzC,IAAA,CAAK,IAAA,UAAc,QAAA,UAAkB,OAAA;IAAY,IAAA;EAAA,IAAkB,OAAA,CAAQ,YAAA,CAAa,UAAA;EAiBxF,MAAA,CAAO,KAAA,EAAO,aAAA,GAAgB,OAAA,CAAQ,UAAA;EAatC,UAAA,CAAW,EAAA,UAAY,KAAA,EAAO,aAAA,GAAgB,OAAA,CAAQ,UAAA;EActD,UAAA,CAAW,EAAA,UAAY,KAAA,EAAO,aAAA,GAAgB,OAAA,CAAQ,UAAA;AAAA"}