@dofe/infra-common 0.1.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 (373) hide show
  1. package/dist/adapters/base.adapter.d.ts +84 -0
  2. package/dist/adapters/base.adapter.d.ts.map +1 -0
  3. package/dist/adapters/base.adapter.js +19 -0
  4. package/dist/adapters/base.adapter.js.map +1 -0
  5. package/dist/adapters/index.d.ts +35 -0
  6. package/dist/adapters/index.d.ts.map +1 -0
  7. package/dist/adapters/index.js +53 -0
  8. package/dist/adapters/index.js.map +1 -0
  9. package/dist/common.module.d.ts +7 -0
  10. package/dist/common.module.d.ts.map +1 -0
  11. package/dist/common.module.js +26 -0
  12. package/dist/common.module.js.map +1 -0
  13. package/dist/config/agentx.config.d.ts +37 -0
  14. package/dist/config/agentx.config.d.ts.map +1 -0
  15. package/dist/config/agentx.config.js +81 -0
  16. package/dist/config/agentx.config.js.map +1 -0
  17. package/dist/config/configuration.d.ts +55 -0
  18. package/dist/config/configuration.d.ts.map +1 -0
  19. package/dist/config/configuration.js +336 -0
  20. package/dist/config/configuration.js.map +1 -0
  21. package/dist/config/constant/config.constants.d.ts +48 -0
  22. package/dist/config/constant/config.constants.d.ts.map +1 -0
  23. package/dist/config/constant/config.constants.js +86 -0
  24. package/dist/config/constant/config.constants.js.map +1 -0
  25. package/dist/config/dto/config.dto.d.ts +222 -0
  26. package/dist/config/dto/config.dto.d.ts.map +1 -0
  27. package/dist/config/dto/config.dto.js +42 -0
  28. package/dist/config/dto/config.dto.js.map +1 -0
  29. package/dist/config/env-config.service.d.ts +147 -0
  30. package/dist/config/env-config.service.d.ts.map +1 -0
  31. package/dist/config/env-config.service.js +296 -0
  32. package/dist/config/env-config.service.js.map +1 -0
  33. package/dist/config/features/feature-errors.d.ts +13 -0
  34. package/dist/config/features/feature-errors.d.ts.map +1 -0
  35. package/dist/config/features/feature-errors.js +25 -0
  36. package/dist/config/features/feature-errors.js.map +1 -0
  37. package/dist/config/features/feature-registry.d.ts +26 -0
  38. package/dist/config/features/feature-registry.d.ts.map +1 -0
  39. package/dist/config/features/feature-registry.js +172 -0
  40. package/dist/config/features/feature-registry.js.map +1 -0
  41. package/dist/config/features/index.d.ts +4 -0
  42. package/dist/config/features/index.d.ts.map +1 -0
  43. package/dist/config/features/index.js +9 -0
  44. package/dist/config/features/index.js.map +1 -0
  45. package/dist/config/validation/env.validation.d.ts +132 -0
  46. package/dist/config/validation/env.validation.d.ts.map +1 -0
  47. package/dist/config/validation/env.validation.js +304 -0
  48. package/dist/config/validation/env.validation.js.map +1 -0
  49. package/dist/config/validation/index.d.ts +21 -0
  50. package/dist/config/validation/index.d.ts.map +1 -0
  51. package/dist/config/validation/index.js +119 -0
  52. package/dist/config/validation/index.js.map +1 -0
  53. package/dist/config/validation/keys.validation.d.ts +884 -0
  54. package/dist/config/validation/keys.validation.d.ts.map +1 -0
  55. package/dist/config/validation/keys.validation.js +506 -0
  56. package/dist/config/validation/keys.validation.js.map +1 -0
  57. package/dist/config/validation/yaml.validation.d.ts +765 -0
  58. package/dist/config/validation/yaml.validation.d.ts.map +1 -0
  59. package/dist/config/validation/yaml.validation.js +488 -0
  60. package/dist/config/validation/yaml.validation.js.map +1 -0
  61. package/dist/config/vendor.config.d.ts +48 -0
  62. package/dist/config/vendor.config.d.ts.map +1 -0
  63. package/dist/config/vendor.config.js +136 -0
  64. package/dist/config/vendor.config.js.map +1 -0
  65. package/dist/decorators/api-key/api-key.decorator.d.ts +25 -0
  66. package/dist/decorators/api-key/api-key.decorator.d.ts.map +1 -0
  67. package/dist/decorators/api-key/api-key.decorator.js +30 -0
  68. package/dist/decorators/api-key/api-key.decorator.js.map +1 -0
  69. package/dist/decorators/api-key/index.d.ts +2 -0
  70. package/dist/decorators/api-key/index.d.ts.map +1 -0
  71. package/dist/decorators/api-key/index.js +18 -0
  72. package/dist/decorators/api-key/index.js.map +1 -0
  73. package/dist/decorators/app-version/app-version.controller.d.ts +30 -0
  74. package/dist/decorators/app-version/app-version.controller.d.ts.map +1 -0
  75. package/dist/decorators/app-version/app-version.controller.js +159 -0
  76. package/dist/decorators/app-version/app-version.controller.js.map +1 -0
  77. package/dist/decorators/app-version/app-version.interceptor.d.ts +15 -0
  78. package/dist/decorators/app-version/app-version.interceptor.d.ts.map +1 -0
  79. package/dist/decorators/app-version/app-version.interceptor.js +42 -0
  80. package/dist/decorators/app-version/app-version.interceptor.js.map +1 -0
  81. package/dist/decorators/app-version/app-version.module.d.ts +8 -0
  82. package/dist/decorators/app-version/app-version.module.d.ts.map +1 -0
  83. package/dist/decorators/app-version/app-version.module.js +39 -0
  84. package/dist/decorators/app-version/app-version.module.js.map +1 -0
  85. package/dist/decorators/app-version/app-version.service.d.ts +88 -0
  86. package/dist/decorators/app-version/app-version.service.d.ts.map +1 -0
  87. package/dist/decorators/app-version/app-version.service.js +251 -0
  88. package/dist/decorators/app-version/app-version.service.js.map +1 -0
  89. package/dist/decorators/app-version/index.d.ts +8 -0
  90. package/dist/decorators/app-version/index.d.ts.map +1 -0
  91. package/dist/decorators/app-version/index.js +15 -0
  92. package/dist/decorators/app-version/index.js.map +1 -0
  93. package/dist/decorators/audit-log.decorator.d.ts +41 -0
  94. package/dist/decorators/audit-log.decorator.d.ts.map +1 -0
  95. package/dist/decorators/audit-log.decorator.js +19 -0
  96. package/dist/decorators/audit-log.decorator.js.map +1 -0
  97. package/dist/decorators/cache/cache.decorator.d.ts +256 -0
  98. package/dist/decorators/cache/cache.decorator.d.ts.map +1 -0
  99. package/dist/decorators/cache/cache.decorator.js +339 -0
  100. package/dist/decorators/cache/cache.decorator.js.map +1 -0
  101. package/dist/decorators/cache/cache.interceptor.d.ts +43 -0
  102. package/dist/decorators/cache/cache.interceptor.d.ts.map +1 -0
  103. package/dist/decorators/cache/cache.interceptor.js +219 -0
  104. package/dist/decorators/cache/cache.interceptor.js.map +1 -0
  105. package/dist/decorators/cache/cache.module.d.ts +9 -0
  106. package/dist/decorators/cache/cache.module.d.ts.map +1 -0
  107. package/dist/decorators/cache/cache.module.js +36 -0
  108. package/dist/decorators/cache/cache.module.js.map +1 -0
  109. package/dist/decorators/cache/index.d.ts +7 -0
  110. package/dist/decorators/cache/index.d.ts.map +1 -0
  111. package/dist/decorators/cache/index.js +32 -0
  112. package/dist/decorators/cache/index.js.map +1 -0
  113. package/dist/decorators/data-visibility/data-visibility.decorator.d.ts +74 -0
  114. package/dist/decorators/data-visibility/data-visibility.decorator.d.ts.map +1 -0
  115. package/dist/decorators/data-visibility/data-visibility.decorator.js +87 -0
  116. package/dist/decorators/data-visibility/data-visibility.decorator.js.map +1 -0
  117. package/dist/decorators/data-visibility/index.d.ts +2 -0
  118. package/dist/decorators/data-visibility/index.d.ts.map +1 -0
  119. package/dist/decorators/data-visibility/index.js +18 -0
  120. package/dist/decorators/data-visibility/index.js.map +1 -0
  121. package/dist/decorators/event/event.decorator.d.ts +152 -0
  122. package/dist/decorators/event/event.decorator.d.ts.map +1 -0
  123. package/dist/decorators/event/event.decorator.js +158 -0
  124. package/dist/decorators/event/event.decorator.js.map +1 -0
  125. package/dist/decorators/event/event.interceptor.d.ts +23 -0
  126. package/dist/decorators/event/event.interceptor.d.ts.map +1 -0
  127. package/dist/decorators/event/event.interceptor.js +140 -0
  128. package/dist/decorators/event/event.interceptor.js.map +1 -0
  129. package/dist/decorators/event/event.module.d.ts +9 -0
  130. package/dist/decorators/event/event.module.d.ts.map +1 -0
  131. package/dist/decorators/event/event.module.js +59 -0
  132. package/dist/decorators/event/event.module.js.map +1 -0
  133. package/dist/decorators/event/handlers/cache-event.handler.d.ts +55 -0
  134. package/dist/decorators/event/handlers/cache-event.handler.d.ts.map +1 -0
  135. package/dist/decorators/event/handlers/cache-event.handler.js +159 -0
  136. package/dist/decorators/event/handlers/cache-event.handler.js.map +1 -0
  137. package/dist/decorators/event/index.d.ts +8 -0
  138. package/dist/decorators/event/index.d.ts.map +1 -0
  139. package/dist/decorators/event/index.js +26 -0
  140. package/dist/decorators/event/index.js.map +1 -0
  141. package/dist/decorators/feature-flag/feature-flag.decorator.d.ts +144 -0
  142. package/dist/decorators/feature-flag/feature-flag.decorator.d.ts.map +1 -0
  143. package/dist/decorators/feature-flag/feature-flag.decorator.js +135 -0
  144. package/dist/decorators/feature-flag/feature-flag.decorator.js.map +1 -0
  145. package/dist/decorators/feature-flag/feature-flag.interceptor.d.ts +30 -0
  146. package/dist/decorators/feature-flag/feature-flag.interceptor.d.ts.map +1 -0
  147. package/dist/decorators/feature-flag/feature-flag.interceptor.js +127 -0
  148. package/dist/decorators/feature-flag/feature-flag.interceptor.js.map +1 -0
  149. package/dist/decorators/feature-flag/feature-flag.module.d.ts +9 -0
  150. package/dist/decorators/feature-flag/feature-flag.module.d.ts.map +1 -0
  151. package/dist/decorators/feature-flag/feature-flag.module.js +39 -0
  152. package/dist/decorators/feature-flag/feature-flag.module.js.map +1 -0
  153. package/dist/decorators/feature-flag/feature-flag.service.d.ts +102 -0
  154. package/dist/decorators/feature-flag/feature-flag.service.d.ts.map +1 -0
  155. package/dist/decorators/feature-flag/feature-flag.service.js +373 -0
  156. package/dist/decorators/feature-flag/feature-flag.service.js.map +1 -0
  157. package/dist/decorators/feature-flag/feature-flag.service.spec.d.ts +2 -0
  158. package/dist/decorators/feature-flag/feature-flag.service.spec.d.ts.map +1 -0
  159. package/dist/decorators/feature-flag/feature-flag.service.spec.js +264 -0
  160. package/dist/decorators/feature-flag/feature-flag.service.spec.js.map +1 -0
  161. package/dist/decorators/feature-flag/index.d.ts +8 -0
  162. package/dist/decorators/feature-flag/index.d.ts.map +1 -0
  163. package/dist/decorators/feature-flag/index.js +23 -0
  164. package/dist/decorators/feature-flag/index.js.map +1 -0
  165. package/dist/decorators/rate-limit/dto/rate-limit.dto.d.ts +174 -0
  166. package/dist/decorators/rate-limit/dto/rate-limit.dto.d.ts.map +1 -0
  167. package/dist/decorators/rate-limit/dto/rate-limit.dto.js +8 -0
  168. package/dist/decorators/rate-limit/dto/rate-limit.dto.js.map +1 -0
  169. package/dist/decorators/rate-limit/index.d.ts +24 -0
  170. package/dist/decorators/rate-limit/index.d.ts.map +1 -0
  171. package/dist/decorators/rate-limit/index.js +44 -0
  172. package/dist/decorators/rate-limit/index.js.map +1 -0
  173. package/dist/decorators/rate-limit/rate-limit.constants.d.ts +16 -0
  174. package/dist/decorators/rate-limit/rate-limit.constants.d.ts.map +1 -0
  175. package/dist/decorators/rate-limit/rate-limit.constants.js +22 -0
  176. package/dist/decorators/rate-limit/rate-limit.constants.js.map +1 -0
  177. package/dist/decorators/rate-limit/rate-limit.decorator.d.ts +132 -0
  178. package/dist/decorators/rate-limit/rate-limit.decorator.d.ts.map +1 -0
  179. package/dist/decorators/rate-limit/rate-limit.decorator.js +185 -0
  180. package/dist/decorators/rate-limit/rate-limit.decorator.js.map +1 -0
  181. package/dist/decorators/rate-limit/rate-limit.exception.d.ts +39 -0
  182. package/dist/decorators/rate-limit/rate-limit.exception.d.ts.map +1 -0
  183. package/dist/decorators/rate-limit/rate-limit.exception.js +67 -0
  184. package/dist/decorators/rate-limit/rate-limit.exception.js.map +1 -0
  185. package/dist/decorators/rate-limit/rate-limit.module.d.ts +25 -0
  186. package/dist/decorators/rate-limit/rate-limit.module.d.ts.map +1 -0
  187. package/dist/decorators/rate-limit/rate-limit.module.js +48 -0
  188. package/dist/decorators/rate-limit/rate-limit.module.js.map +1 -0
  189. package/dist/decorators/rate-limit/rate-limit.service.d.ts +102 -0
  190. package/dist/decorators/rate-limit/rate-limit.service.d.ts.map +1 -0
  191. package/dist/decorators/rate-limit/rate-limit.service.js +390 -0
  192. package/dist/decorators/rate-limit/rate-limit.service.js.map +1 -0
  193. package/dist/decorators/response.decorator.d.ts +10 -0
  194. package/dist/decorators/response.decorator.d.ts.map +1 -0
  195. package/dist/decorators/response.decorator.js +58 -0
  196. package/dist/decorators/response.decorator.js.map +1 -0
  197. package/dist/decorators/skip-version-check.decorator.d.ts +25 -0
  198. package/dist/decorators/skip-version-check.decorator.d.ts.map +1 -0
  199. package/dist/decorators/skip-version-check.decorator.js +31 -0
  200. package/dist/decorators/skip-version-check.decorator.js.map +1 -0
  201. package/dist/decorators/tenant/index.d.ts +2 -0
  202. package/dist/decorators/tenant/index.d.ts.map +1 -0
  203. package/dist/decorators/tenant/index.js +18 -0
  204. package/dist/decorators/tenant/index.js.map +1 -0
  205. package/dist/decorators/tenant/tenant.decorator.d.ts +82 -0
  206. package/dist/decorators/tenant/tenant.decorator.d.ts.map +1 -0
  207. package/dist/decorators/tenant/tenant.decorator.js +98 -0
  208. package/dist/decorators/tenant/tenant.decorator.js.map +1 -0
  209. package/dist/decorators/transaction/index.d.ts +6 -0
  210. package/dist/decorators/transaction/index.d.ts.map +1 -0
  211. package/dist/decorators/transaction/index.js +12 -0
  212. package/dist/decorators/transaction/index.js.map +1 -0
  213. package/dist/decorators/transaction/transactional.decorator.d.ts +234 -0
  214. package/dist/decorators/transaction/transactional.decorator.d.ts.map +1 -0
  215. package/dist/decorators/transaction/transactional.decorator.js +433 -0
  216. package/dist/decorators/transaction/transactional.decorator.js.map +1 -0
  217. package/dist/decorators/ts-rest-controller.decorator.d.ts +38 -0
  218. package/dist/decorators/ts-rest-controller.decorator.d.ts.map +1 -0
  219. package/dist/decorators/ts-rest-controller.decorator.js +25 -0
  220. package/dist/decorators/ts-rest-controller.decorator.js.map +1 -0
  221. package/dist/decorators/validation.decorator.d.ts +4 -0
  222. package/dist/decorators/validation.decorator.d.ts.map +1 -0
  223. package/dist/decorators/validation.decorator.js +121 -0
  224. package/dist/decorators/validation.decorator.js.map +1 -0
  225. package/dist/decorators/version/index.d.ts +7 -0
  226. package/dist/decorators/version/index.d.ts.map +1 -0
  227. package/dist/decorators/version/index.js +25 -0
  228. package/dist/decorators/version/index.js.map +1 -0
  229. package/dist/decorators/version/version.decorator.d.ts +96 -0
  230. package/dist/decorators/version/version.decorator.d.ts.map +1 -0
  231. package/dist/decorators/version/version.decorator.js +146 -0
  232. package/dist/decorators/version/version.decorator.js.map +1 -0
  233. package/dist/decorators/version/version.interceptor.d.ts +19 -0
  234. package/dist/decorators/version/version.interceptor.d.ts.map +1 -0
  235. package/dist/decorators/version/version.interceptor.js +86 -0
  236. package/dist/decorators/version/version.interceptor.js.map +1 -0
  237. package/dist/decorators/version/version.module.d.ts +8 -0
  238. package/dist/decorators/version/version.module.d.ts.map +1 -0
  239. package/dist/decorators/version/version.module.js +33 -0
  240. package/dist/decorators/version/version.module.js.map +1 -0
  241. package/dist/encryption.service.d.ts +15 -0
  242. package/dist/encryption.service.d.ts.map +1 -0
  243. package/dist/encryption.service.js +35 -0
  244. package/dist/encryption.service.js.map +1 -0
  245. package/dist/enums/action.enum.d.ts +8 -0
  246. package/dist/enums/action.enum.d.ts.map +1 -0
  247. package/dist/enums/action.enum.js +12 -0
  248. package/dist/enums/action.enum.js.map +1 -0
  249. package/dist/enums/error-codes.d.ts +33 -0
  250. package/dist/enums/error-codes.d.ts.map +1 -0
  251. package/dist/enums/error-codes.js +52 -0
  252. package/dist/enums/error-codes.js.map +1 -0
  253. package/dist/enums/role.enum.d.ts +5 -0
  254. package/dist/enums/role.enum.d.ts.map +1 -0
  255. package/dist/enums/role.enum.js +9 -0
  256. package/dist/enums/role.enum.js.map +1 -0
  257. package/dist/filter/exception/api.exception.d.ts +77 -0
  258. package/dist/filter/exception/api.exception.d.ts.map +1 -0
  259. package/dist/filter/exception/api.exception.js +151 -0
  260. package/dist/filter/exception/api.exception.js.map +1 -0
  261. package/dist/filter/exception/exception.d.ts +8 -0
  262. package/dist/filter/exception/exception.d.ts.map +1 -0
  263. package/dist/filter/exception/exception.js +50 -0
  264. package/dist/filter/exception/exception.js.map +1 -0
  265. package/dist/filter/exception/http.exception.d.ts +11 -0
  266. package/dist/filter/exception/http.exception.d.ts.map +1 -0
  267. package/dist/filter/exception/http.exception.js +152 -0
  268. package/dist/filter/exception/http.exception.js.map +1 -0
  269. package/dist/guards/api-key.guard.d.ts +42 -0
  270. package/dist/guards/api-key.guard.d.ts.map +1 -0
  271. package/dist/guards/api-key.guard.js +159 -0
  272. package/dist/guards/api-key.guard.js.map +1 -0
  273. package/dist/guards/auth.guard.d.ts +39 -0
  274. package/dist/guards/auth.guard.d.ts.map +1 -0
  275. package/dist/guards/auth.guard.js +178 -0
  276. package/dist/guards/auth.guard.js.map +1 -0
  277. package/dist/guards/data-visibility.guard.d.ts +18 -0
  278. package/dist/guards/data-visibility.guard.d.ts.map +1 -0
  279. package/dist/guards/data-visibility.guard.js +84 -0
  280. package/dist/guards/data-visibility.guard.js.map +1 -0
  281. package/dist/guards/index.d.ts +7 -0
  282. package/dist/guards/index.d.ts.map +1 -0
  283. package/dist/guards/index.js +23 -0
  284. package/dist/guards/index.js.map +1 -0
  285. package/dist/guards/permission.guard.d.ts +20 -0
  286. package/dist/guards/permission.guard.d.ts.map +1 -0
  287. package/dist/guards/permission.guard.js +141 -0
  288. package/dist/guards/permission.guard.js.map +1 -0
  289. package/dist/guards/tenant-context.guard.d.ts +12 -0
  290. package/dist/guards/tenant-context.guard.d.ts.map +1 -0
  291. package/dist/guards/tenant-context.guard.js +94 -0
  292. package/dist/guards/tenant-context.guard.js.map +1 -0
  293. package/dist/guards/version.guard.d.ts +100 -0
  294. package/dist/guards/version.guard.d.ts.map +1 -0
  295. package/dist/guards/version.guard.js +233 -0
  296. package/dist/guards/version.guard.js.map +1 -0
  297. package/dist/index.d.ts +60 -0
  298. package/dist/index.d.ts.map +1 -0
  299. package/dist/index.js +85 -0
  300. package/dist/index.js.map +1 -0
  301. package/dist/interceptor/audit/audit-log.interceptor.d.ts +16 -0
  302. package/dist/interceptor/audit/audit-log.interceptor.d.ts.map +1 -0
  303. package/dist/interceptor/audit/audit-log.interceptor.js +156 -0
  304. package/dist/interceptor/audit/audit-log.interceptor.js.map +1 -0
  305. package/dist/interceptor/audit/index.d.ts +2 -0
  306. package/dist/interceptor/audit/index.d.ts.map +1 -0
  307. package/dist/interceptor/audit/index.js +18 -0
  308. package/dist/interceptor/audit/index.js.map +1 -0
  309. package/dist/interceptor/mask/index.d.ts +2 -0
  310. package/dist/interceptor/mask/index.d.ts.map +1 -0
  311. package/dist/interceptor/mask/index.js +18 -0
  312. package/dist/interceptor/mask/index.js.map +1 -0
  313. package/dist/interceptor/mask/mask.interceptor.d.ts +79 -0
  314. package/dist/interceptor/mask/mask.interceptor.d.ts.map +1 -0
  315. package/dist/interceptor/mask/mask.interceptor.js +197 -0
  316. package/dist/interceptor/mask/mask.interceptor.js.map +1 -0
  317. package/dist/interceptor/rate-limit/no-rate-limit.interceptor.d.ts +6 -0
  318. package/dist/interceptor/rate-limit/no-rate-limit.interceptor.d.ts.map +1 -0
  319. package/dist/interceptor/rate-limit/no-rate-limit.interceptor.js +20 -0
  320. package/dist/interceptor/rate-limit/no-rate-limit.interceptor.js.map +1 -0
  321. package/dist/interceptor/rate-limit/rate-limit.interceptor.d.ts +45 -0
  322. package/dist/interceptor/rate-limit/rate-limit.interceptor.d.ts.map +1 -0
  323. package/dist/interceptor/rate-limit/rate-limit.interceptor.js +193 -0
  324. package/dist/interceptor/rate-limit/rate-limit.interceptor.js.map +1 -0
  325. package/dist/interceptor/transform/transform.interceptor.d.ts +37 -0
  326. package/dist/interceptor/transform/transform.interceptor.d.ts.map +1 -0
  327. package/dist/interceptor/transform/transform.interceptor.js +72 -0
  328. package/dist/interceptor/transform/transform.interceptor.js.map +1 -0
  329. package/dist/interceptor/transform/transform.interceptor.spec.d.ts +2 -0
  330. package/dist/interceptor/transform/transform.interceptor.spec.d.ts.map +1 -0
  331. package/dist/interceptor/transform/transform.interceptor.spec.js +9 -0
  332. package/dist/interceptor/transform/transform.interceptor.spec.js.map +1 -0
  333. package/dist/interceptor/version/index.d.ts +2 -0
  334. package/dist/interceptor/version/index.d.ts.map +1 -0
  335. package/dist/interceptor/version/index.js +18 -0
  336. package/dist/interceptor/version/index.js.map +1 -0
  337. package/dist/interceptor/version/version-header.interceptor.d.ts +31 -0
  338. package/dist/interceptor/version/version-header.interceptor.d.ts.map +1 -0
  339. package/dist/interceptor/version/version-header.interceptor.js +62 -0
  340. package/dist/interceptor/version/version-header.interceptor.js.map +1 -0
  341. package/dist/middleware/request.middleware.d.ts +27 -0
  342. package/dist/middleware/request.middleware.d.ts.map +1 -0
  343. package/dist/middleware/request.middleware.js +141 -0
  344. package/dist/middleware/request.middleware.js.map +1 -0
  345. package/dist/middleware/tenant-isolation.middleware.d.ts +12 -0
  346. package/dist/middleware/tenant-isolation.middleware.d.ts.map +1 -0
  347. package/dist/middleware/tenant-isolation.middleware.js +51 -0
  348. package/dist/middleware/tenant-isolation.middleware.js.map +1 -0
  349. package/dist/pipes/transform-root.pipe.d.ts +5 -0
  350. package/dist/pipes/transform-root.pipe.d.ts.map +1 -0
  351. package/dist/pipes/transform-root.pipe.js +24 -0
  352. package/dist/pipes/transform-root.pipe.js.map +1 -0
  353. package/dist/ts-rest/index.d.ts +36 -0
  354. package/dist/ts-rest/index.d.ts.map +1 -0
  355. package/dist/ts-rest/index.js +65 -0
  356. package/dist/ts-rest/index.js.map +1 -0
  357. package/dist/ts-rest/response.helper.d.ts +261 -0
  358. package/dist/ts-rest/response.helper.d.ts.map +1 -0
  359. package/dist/ts-rest/response.helper.js +372 -0
  360. package/dist/ts-rest/response.helper.js.map +1 -0
  361. package/dist/utils/audit-log-helper.util.d.ts +41 -0
  362. package/dist/utils/audit-log-helper.util.d.ts.map +1 -0
  363. package/dist/utils/audit-log-helper.util.js +115 -0
  364. package/dist/utils/audit-log-helper.util.js.map +1 -0
  365. package/dist/utils/audit-signature.util.d.ts +64 -0
  366. package/dist/utils/audit-signature.util.d.ts.map +1 -0
  367. package/dist/utils/audit-signature.util.js +155 -0
  368. package/dist/utils/audit-signature.util.js.map +1 -0
  369. package/dist/utils/prisma-error.util.d.ts +160 -0
  370. package/dist/utils/prisma-error.util.d.ts.map +1 -0
  371. package/dist/utils/prisma-error.util.js +342 -0
  372. package/dist/utils/prisma-error.util.js.map +1 -0
  373. package/package.json +54 -0
@@ -0,0 +1,159 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.ApiKeyGuard = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const core_1 = require("@nestjs/core");
18
+ const nest_winston_1 = require("nest-winston");
19
+ const winston_1 = require("winston");
20
+ const api_key_decorator_1 = require("@/common/decorators/api-key/api-key.decorator");
21
+ const API_KEY_HEADER = 'x-api-key';
22
+ const SERVICE_NAME_HEADER = 'x-service-name';
23
+ /**
24
+ * API Key 守卫
25
+ * 允许使用有效的 API Key 跳过部分验证(如用户认证、租户验证等)
26
+ *
27
+ * 安全特性:
28
+ * 1. API Key 必须预定义在环境变量中
29
+ * 2. 记录所有 API Key 调用日志
30
+ * 3. 支持可选的租户强制验证
31
+ */
32
+ let ApiKeyGuard = class ApiKeyGuard {
33
+ reflector;
34
+ logger;
35
+ validApiKeys;
36
+ enabled;
37
+ constructor(reflector, logger) {
38
+ this.reflector = reflector;
39
+ this.logger = logger;
40
+ // 从环境变量加载 API Key(支持多个,逗号分隔)
41
+ const apiKeyString = process.env.INTERNAL_API_KEYS || process.env.INTERNAL_API_KEY || '';
42
+ this.validApiKeys = new Set(apiKeyString
43
+ .split(',')
44
+ .map((k) => k.trim())
45
+ .filter(Boolean));
46
+ this.enabled = this.validApiKeys.size > 0;
47
+ this.logger.info('ApiKeyGuard initialized', {
48
+ keyCount: this.validApiKeys.size,
49
+ });
50
+ }
51
+ async canActivate(context) {
52
+ // 如果没有配置 API Key,跳过此守卫
53
+ if (!this.enabled) {
54
+ return true;
55
+ }
56
+ const request = context.switchToHttp().getRequest();
57
+ // 检查当前处理方法是否允许 API Key 访问
58
+ const allowApiKey = this.reflector.getAllAndOverride(api_key_decorator_1.ALLOW_API_KEY_KEY, [context.getHandler(), context.getClass()]);
59
+ if (!allowApiKey) {
60
+ return true; // 不允许 API Key,继续其他验证
61
+ }
62
+ const apiKey = this.extractApiKey(request);
63
+ if (!apiKey) {
64
+ return true; // 无 API Key,继续正常验证流程
65
+ }
66
+ // 验证 API Key
67
+ if (!this.validateApiKey(apiKey, request)) {
68
+ return false;
69
+ }
70
+ // 设置内部服务标识
71
+ this.setInternalServiceContext(request, apiKey);
72
+ this.logger.info('API key authenticated successfully', {
73
+ service: request.headers[SERVICE_NAME_HEADER] || 'unknown',
74
+ ip: request.ip,
75
+ tenantId: request.headers['x-current-tenant'] || 'none',
76
+ });
77
+ return true;
78
+ }
79
+ /**
80
+ * 从请求中提取 API Key
81
+ * 支持从 header 或 query 参数获取
82
+ */
83
+ extractApiKey(request) {
84
+ // 优先从 header 获取
85
+ const headerApiKey = request.headers[API_KEY_HEADER];
86
+ if (headerApiKey) {
87
+ return headerApiKey;
88
+ }
89
+ // 从 query 参数获取(不推荐,仅用于某些特殊场景)
90
+ const queryApiKey = request.query?.api_key;
91
+ if (queryApiKey) {
92
+ return queryApiKey;
93
+ }
94
+ return undefined;
95
+ }
96
+ /**
97
+ * 验证 API Key
98
+ */
99
+ validateApiKey(apiKey, request) {
100
+ // 检查 API Key 是否有效
101
+ if (!this.validApiKeys.has(apiKey)) {
102
+ this.logger.error('Invalid API key used', {
103
+ apiKey: this.maskApiKey(apiKey),
104
+ ip: request.ip,
105
+ userAgent: request.headers['user-agent'],
106
+ service: request.headers[SERVICE_NAME_HEADER],
107
+ path: request.url,
108
+ });
109
+ return false;
110
+ }
111
+ return true;
112
+ }
113
+ /**
114
+ * 设置内部服务上下文
115
+ */
116
+ setInternalServiceContext(request, apiKey) {
117
+ // 标记为内部服务
118
+ request.isInternalService = true;
119
+ // 设置服务名称
120
+ const serviceName = request.headers[SERVICE_NAME_HEADER];
121
+ request.internalServiceName = serviceName || 'unknown';
122
+ // 设置 API Key 标识(用于审计)
123
+ request.apiKeyId = this.getKeyId(apiKey);
124
+ // 跳过租户验证(但仍需解析租户用于数据隔离)
125
+ request.skipTenantCheck = true;
126
+ // 强制要求租户 Header(防止跨租户访问)
127
+ const headerTenantId = request.headers['x-current-tenant'];
128
+ if (process.env.INTERNAL_API_REQUIRE_TENANT === 'true' && !headerTenantId) {
129
+ this.logger.warn('API key used without required tenant header', {
130
+ service: serviceName,
131
+ path: request.url,
132
+ });
133
+ throw new Error('Tenant header (x-current-tenant) is required');
134
+ }
135
+ }
136
+ /**
137
+ * 遮蔽 API Key 用于日志记录
138
+ */
139
+ maskApiKey(apiKey) {
140
+ if (apiKey.length <= 8) {
141
+ return '****';
142
+ }
143
+ return `${apiKey.substring(0, 4)}...${apiKey.substring(apiKey.length - 4)}`;
144
+ }
145
+ /**
146
+ * 获取 API Key 标识符(用于区分不同的 Key)
147
+ */
148
+ getKeyId(apiKey) {
149
+ return this.maskApiKey(apiKey);
150
+ }
151
+ };
152
+ exports.ApiKeyGuard = ApiKeyGuard;
153
+ exports.ApiKeyGuard = ApiKeyGuard = __decorate([
154
+ (0, common_1.Injectable)(),
155
+ __param(1, (0, common_1.Inject)(nest_winston_1.WINSTON_MODULE_PROVIDER)),
156
+ __metadata("design:paramtypes", [core_1.Reflector,
157
+ winston_1.Logger])
158
+ ], ApiKeyGuard);
159
+ //# sourceMappingURL=api-key.guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api-key.guard.js","sourceRoot":"","sources":["../../src/guards/api-key.guard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ import { CanActivate, ExecutionContext } from '@nestjs/common';
2
+ import { JwtService } from '@nestjs/jwt';
3
+ import { ConfigService } from '@nestjs/config';
4
+ import { Reflector } from '@nestjs/core';
5
+ import { Logger } from 'winston';
6
+ import { RedisService } from '@dofe/infra-redis';
7
+ import { UserInfoService } from '@app/db';
8
+ /**
9
+ * Auth Guard Token - 用于注入 AuthService
10
+ */
11
+ export declare const AUTH_SERVICE_TOKEN = "AUTH_SERVICE";
12
+ /**
13
+ * Auth Service Interface - 用于解耦 infra 和 domain
14
+ */
15
+ export interface IAuthService {
16
+ extractTokenFromHeader(request: {
17
+ headers: Record<string, string | string[] | undefined>;
18
+ }): string | undefined;
19
+ }
20
+ /**
21
+ * AuthGuard - 认证守卫
22
+ *
23
+ * 位于 infra 层,通过依赖注入接收 AuthService 实现
24
+ * 避免直接依赖 domain 层
25
+ */
26
+ export declare class AuthGuard implements CanActivate {
27
+ private readonly auth;
28
+ private readonly jwt;
29
+ private readonly config;
30
+ private readonly reflector;
31
+ private readonly redis;
32
+ private readonly user;
33
+ private readonly logger;
34
+ private readonly outOfAnonymityPathConfig;
35
+ private readonly outOfUserPathConfig;
36
+ constructor(auth: IAuthService, jwt: JwtService, config: ConfigService, reflector: Reflector, redis: RedisService, user: UserInfoService, logger: Logger);
37
+ canActivate(context: ExecutionContext): Promise<boolean>;
38
+ }
39
+ //# sourceMappingURL=auth.guard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.guard.d.ts","sourceRoot":"","sources":["../../src/guards/auth.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,gBAAgB,EAGjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAIjC,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,eAAe,EAAE,MAAM,SAAS,CAAC;AAO1C;;GAEG;AACH,eAAO,MAAM,kBAAkB,iBAAiB,CAAC;AAEjD;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,sBAAsB,CAAC,OAAO,EAAE;QAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,EAAE,GAAG,SAAS,CAAC,CAAA;KAAE,GAAG,MAAM,GAAG,SAAS,CAAC;CACjH;AAED;;;;;GAKG;AACH,qBACa,SAAU,YAAW,WAAW;IAMzC,OAAO,CAAC,QAAQ,CAAC,IAAI;IACrB,OAAO,CAAC,QAAQ,CAAC,GAAG;IACpB,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,KAAK;IACtB,OAAO,CAAC,QAAQ,CAAC,IAAI;IACY,OAAO,CAAC,QAAQ,CAAC,MAAM;IAX1D,OAAO,CAAC,QAAQ,CAAC,wBAAwB,CAAC;IAC1C,OAAO,CAAC,QAAQ,CAAC,mBAAmB,CAAC;gBAIlB,IAAI,EAAE,YAAY,EAClB,GAAG,EAAE,UAAU,EACf,MAAM,EAAE,aAAa,EACrB,SAAS,EAAE,SAAS,EACpB,KAAK,EAAE,YAAY,EACnB,IAAI,EAAE,eAAe,EACY,MAAM,EAAE,MAAM;IAc5D,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;CAyI/D"}
@@ -0,0 +1,178 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ var __importDefault = (this && this.__importDefault) || function (mod) {
15
+ return (mod && mod.__esModule) ? mod : { "default": mod };
16
+ };
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.AuthGuard = exports.AUTH_SERVICE_TOKEN = void 0;
19
+ const common_1 = require("@nestjs/common");
20
+ const jwt_1 = require("@nestjs/jwt");
21
+ const config_1 = require("@nestjs/config");
22
+ const core_1 = require("@nestjs/core");
23
+ const nest_winston_1 = require("nest-winston");
24
+ const winston_1 = require("winston");
25
+ const infra_contracts_1 = require("@dofe/infra-contracts");
26
+ const infra_contracts_2 = require("@dofe/infra-contracts");
27
+ const infra_redis_1 = require("@dofe/infra-redis");
28
+ const db_1 = require("@app/db");
29
+ const string_util_1 = __importDefault(require("@dofe/infra-utils/string.util"));
30
+ const environment_util_1 = __importDefault(require("@dofe/infra-utils/environment.util"));
31
+ const env_config_service_1 = require("@/config/env-config.service");
32
+ const api_exception_1 = require("@/filter/exception/api.exception");
33
+ /**
34
+ * Auth Guard Token - 用于注入 AuthService
35
+ */
36
+ exports.AUTH_SERVICE_TOKEN = 'AUTH_SERVICE';
37
+ /**
38
+ * AuthGuard - 认证守卫
39
+ *
40
+ * 位于 infra 层,通过依赖注入接收 AuthService 实现
41
+ * 避免直接依赖 domain 层
42
+ */
43
+ let AuthGuard = class AuthGuard {
44
+ auth;
45
+ jwt;
46
+ config;
47
+ reflector;
48
+ redis;
49
+ user;
50
+ logger;
51
+ outOfAnonymityPathConfig;
52
+ outOfUserPathConfig;
53
+ constructor(auth, jwt, config, reflector, redis, user, logger) {
54
+ this.auth = auth;
55
+ this.jwt = jwt;
56
+ this.config = config;
57
+ this.reflector = reflector;
58
+ this.redis = redis;
59
+ this.user = user;
60
+ this.logger = logger;
61
+ // 这两个配置在早期版本的 YAML 中存在,但当前模板中是可选的
62
+ // 为了在本地/开发环境下更好地降级,这里给出空对象默认值
63
+ this.outOfAnonymityPathConfig =
64
+ this.config.get('outOfAnonymityPath') ?? {};
65
+ this.outOfUserPathConfig =
66
+ this.config.get('outOfUserPath') ?? {};
67
+ }
68
+ async canActivate(context) {
69
+ const request = context.switchToHttp().getRequest();
70
+ const _response = context.switchToHttp().getResponse();
71
+ const requestMethod = request.method.toLowerCase();
72
+ const requestPath = string_util_1.default.trimSlashes(string_util_1.default.splitString(request.url, '?')[0]);
73
+ // 检查是否在白名单路径中
74
+ if (this.outOfUserPathConfig[requestMethod]?.some((path) => new RegExp(`^${path.replace(/:\w+/g, '[^/]+')}$`).test(requestPath.replace('api/', '')))) {
75
+ return true;
76
+ }
77
+ // 检查是否标记为公开端点(@Public() 装饰器)
78
+ const isPublic = this.reflector.getAllAndOverride(infra_contracts_2.PUBLIC_ENDPOINT_KEY, [context.getHandler(), context.getClass()]);
79
+ if (isPublic)
80
+ return true;
81
+ // 从方法处理器获取元数据
82
+ let authTypes = this.reflector.get('auths', context.getHandler());
83
+ if (!authTypes) {
84
+ authTypes = this.reflector.get('auths', context.getClass());
85
+ }
86
+ const [authType = 'api', guardType = 'api'] = authTypes || ['api', 'api'];
87
+ const isMpTest = request.headers[infra_contracts_2.MPTRAIL_HEADER] === 'true';
88
+ let userId, isAdmin = false, isAnonymity = false;
89
+ if (!env_config_service_1.featureConfig.modeUserId) {
90
+ let access;
91
+ if (guardType === 'sse') {
92
+ access = decodeURIComponent(request.query['access_token']);
93
+ }
94
+ else {
95
+ access = this.auth.extractTokenFromHeader(request);
96
+ if (!access) {
97
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
98
+ }
99
+ }
100
+ if (!access) {
101
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
102
+ }
103
+ let payload;
104
+ try {
105
+ const jwtConfig = this.config.getOrThrow('jwt');
106
+ payload = await this.jwt.verifyAsync(access, {
107
+ secret: jwtConfig.secret,
108
+ });
109
+ }
110
+ catch (_error) {
111
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
112
+ }
113
+ userId = payload?.sub;
114
+ isAnonymity = payload?.isAnonymity;
115
+ isAdmin = payload?.isAdmin;
116
+ if (isAnonymity) {
117
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
118
+ }
119
+ // 将 JWT payload 中的用户信息设置到 request 中
120
+ request.userInfo = {
121
+ id: userId,
122
+ nickname: payload?.nickname,
123
+ code: payload?.code,
124
+ headerImg: payload?.headerImg,
125
+ sex: payload?.sex,
126
+ isAdmin: isAdmin,
127
+ isAnonymity: isAnonymity,
128
+ };
129
+ }
130
+ else {
131
+ if ((0, env_config_service_1.isProduction)()) {
132
+ this.logger.error('CRITICAL SECURITY ERROR: MODE_USER_ID is set in prod environment!');
133
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
134
+ }
135
+ this.logger.warn('Auth Guard is running in insecure bypass mode. DO NOT USE IN PROD.');
136
+ this.logger.warn(`Bypass mode activated with userId: ${env_config_service_1.featureConfig.modeUserId}`);
137
+ userId = env_config_service_1.featureConfig.modeUserId;
138
+ isAdmin = true;
139
+ isAnonymity = false;
140
+ }
141
+ if (!userId) {
142
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
143
+ }
144
+ if (request.method.toLowerCase() === 'post' &&
145
+ process.env?.PREVIEW_MODE === 'true' &&
146
+ environment_util_1.default.isWeChatMiniProgram(request) &&
147
+ isMpTest &&
148
+ process.env?.PREVIEW_USER_ID) {
149
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
150
+ }
151
+ if (authType === 'admin' && !isAdmin) {
152
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
153
+ }
154
+ // 检查匿名用户访问限制
155
+ if (this.outOfAnonymityPathConfig[requestMethod]?.some((path) => new RegExp(`^${path.replace(/:\w+/g, '[^/]+')}$`).test(requestPath.replace('api/', ''))) &&
156
+ request.isAnonymity) {
157
+ throw (0, api_exception_1.apiError)(infra_contracts_1.CommonErrorCode.UnAuthorized);
158
+ }
159
+ // 将用户信息设置到request对象中
160
+ request.userId = userId;
161
+ request.isAnonymity = isAnonymity;
162
+ request.isAdmin = isAdmin;
163
+ return true;
164
+ }
165
+ };
166
+ exports.AuthGuard = AuthGuard;
167
+ exports.AuthGuard = AuthGuard = __decorate([
168
+ (0, common_1.Injectable)(),
169
+ __param(0, (0, common_1.Inject)(exports.AUTH_SERVICE_TOKEN)),
170
+ __param(6, (0, common_1.Inject)(nest_winston_1.WINSTON_MODULE_PROVIDER)),
171
+ __metadata("design:paramtypes", [Object, jwt_1.JwtService,
172
+ config_1.ConfigService,
173
+ core_1.Reflector,
174
+ infra_redis_1.RedisService,
175
+ db_1.UserInfoService,
176
+ winston_1.Logger])
177
+ ], AuthGuard);
178
+ //# sourceMappingURL=auth.guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"auth.guard.js","sourceRoot":"","sources":["../../src/guards/auth.guard.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,18 @@
1
+ import { CanActivate, ExecutionContext } from '@nestjs/common';
2
+ import { Reflector } from '@nestjs/core';
3
+ import { Logger } from 'winston';
4
+ import { OrganizationPermissionService } from '@app/tenant-management/organization-permission';
5
+ /**
6
+ * 数据可见性 Guard
7
+ *
8
+ * 根据用户角色自动解析数据可见范围,并注入到 request.dataScope 中
9
+ * 供后续 Service 层使用
10
+ */
11
+ export declare class DataVisibilityGuard implements CanActivate {
12
+ private readonly reflector;
13
+ private readonly permissionService;
14
+ private readonly logger;
15
+ constructor(reflector: Reflector, permissionService: OrganizationPermissionService, logger: Logger);
16
+ canActivate(context: ExecutionContext): Promise<boolean>;
17
+ }
18
+ //# sourceMappingURL=data-visibility.guard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-visibility.guard.d.ts","sourceRoot":"","sources":["../../src/guards/data-visibility.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,EACX,gBAAgB,EAEjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,6BAA6B,EAAE,MAAM,gDAAgD,CAAC;AAI/F;;;;;GAKG;AACH,qBACa,mBAAoB,YAAW,WAAW;IAEnD,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IACD,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAFvC,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,6BAA6B,EACf,MAAM,EAAE,MAAM;IAG5D,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;CAoD/D"}
@@ -0,0 +1,84 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.DataVisibilityGuard = void 0;
16
+ const common_1 = require("@nestjs/common");
17
+ const core_1 = require("@nestjs/core");
18
+ const nest_winston_1 = require("nest-winston");
19
+ const winston_1 = require("winston");
20
+ const organization_permission_1 = require("@app/tenant-management/organization-permission");
21
+ const data_visibility_1 = require("@/common/decorators/data-visibility");
22
+ /**
23
+ * 数据可见性 Guard
24
+ *
25
+ * 根据用户角色自动解析数据可见范围,并注入到 request.dataScope 中
26
+ * 供后续 Service 层使用
27
+ */
28
+ let DataVisibilityGuard = class DataVisibilityGuard {
29
+ reflector;
30
+ permissionService;
31
+ logger;
32
+ constructor(reflector, permissionService, logger) {
33
+ this.reflector = reflector;
34
+ this.permissionService = permissionService;
35
+ this.logger = logger;
36
+ }
37
+ async canActivate(context) {
38
+ const request = context.switchToHttp().getRequest();
39
+ // 获取资源类型
40
+ const resourceType = this.reflector.getAllAndOverride(data_visibility_1.DATA_VISIBILITY_KEY, [context.getHandler(), context.getClass()]);
41
+ // 如果没有设置资源类型,不需要处理可见性
42
+ if (!resourceType) {
43
+ return true;
44
+ }
45
+ // 获取用户信息
46
+ const userId = request.userId;
47
+ const tenantId = request.tenantId;
48
+ const isAdmin = request.isAdmin;
49
+ // 如果没有用户信息(公共端点),跳过可见性注入
50
+ if (!userId || !tenantId) {
51
+ this.logger.debug('No user context, skipping data visibility resolution', {
52
+ resourceType,
53
+ });
54
+ return true;
55
+ }
56
+ // 解析数据可见范围
57
+ const dataScope = await this.permissionService.resolveDataScope({
58
+ userId,
59
+ tenantId,
60
+ resourceType,
61
+ isSystemAdmin: isAdmin,
62
+ });
63
+ // 注入到请求上下文
64
+ request.dataScope = dataScope;
65
+ this.logger.debug('Data visibility resolved', {
66
+ userId,
67
+ tenantId,
68
+ resourceType,
69
+ scopeType: dataScope.type,
70
+ departmentCount: dataScope.departmentIds?.length ?? 0,
71
+ teamCount: dataScope.teamIds?.length ?? 0,
72
+ });
73
+ return true;
74
+ }
75
+ };
76
+ exports.DataVisibilityGuard = DataVisibilityGuard;
77
+ exports.DataVisibilityGuard = DataVisibilityGuard = __decorate([
78
+ (0, common_1.Injectable)(),
79
+ __param(2, (0, common_1.Inject)(nest_winston_1.WINSTON_MODULE_PROVIDER)),
80
+ __metadata("design:paramtypes", [core_1.Reflector,
81
+ organization_permission_1.OrganizationPermissionService,
82
+ winston_1.Logger])
83
+ ], DataVisibilityGuard);
84
+ //# sourceMappingURL=data-visibility.guard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"data-visibility.guard.js","sourceRoot":"","sources":["../../src/guards/data-visibility.guard.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,2CAKwB;AACxB,uCAAyC;AACzC,+CAAuD;AACvD,qCAAiC;AAEjC,4FAA+F;AAC/F,yEAA0E;AAG1E;;;;;GAKG;AAEI,IAAM,mBAAmB,GAAzB,MAAM,mBAAmB;IAEX;IACA;IACiC;IAHpD,YACmB,SAAoB,EACpB,iBAAgD,EACf,MAAc;QAF/C,cAAS,GAAT,SAAS,CAAW;QACpB,sBAAiB,GAAjB,iBAAiB,CAA+B;QACf,WAAM,GAAN,MAAM,CAAQ;IAC/D,CAAC;IAEJ,KAAK,CAAC,WAAW,CAAC,OAAyB;QACzC,MAAM,OAAO,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,UAAU,EAAkB,CAAC;QAEpE,SAAS;QACT,MAAM,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,iBAAiB,CACnD,qCAAmB,EACnB,CAAC,OAAO,CAAC,UAAU,EAAE,EAAE,OAAO,CAAC,QAAQ,EAAE,CAAC,CAC3C,CAAC;QAEF,sBAAsB;QACtB,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,SAAS;QACT,MAAM,MAAM,GAAI,OAAe,CAAC,MAAM,CAAC;QACvC,MAAM,QAAQ,GAAI,OAAe,CAAC,QAAQ,CAAC;QAC3C,MAAM,OAAO,GAAI,OAAe,CAAC,OAAO,CAAC;QAEzC,yBAAyB;QACzB,IAAI,CAAC,MAAM,IAAI,CAAC,QAAQ,EAAE,CAAC;YACzB,IAAI,CAAC,MAAM,CAAC,KAAK,CACf,sDAAsD,EACtD;gBACE,YAAY;aACb,CACF,CAAC;YACF,OAAO,IAAI,CAAC;QACd,CAAC;QAED,WAAW;QACX,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,iBAAiB,CAAC,gBAAgB,CAAC;YAC9D,MAAM;YACN,QAAQ;YACR,YAAY;YACZ,aAAa,EAAE,OAAO;SACvB,CAAC,CAAC;QAEH,WAAW;QACV,OAAe,CAAC,SAAS,GAAG,SAAS,CAAC;QAEvC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,0BAA0B,EAAE;YAC5C,MAAM;YACN,QAAQ;YACR,YAAY;YACZ,SAAS,EAAE,SAAS,CAAC,IAAI;YACzB,eAAe,EAAE,SAAS,CAAC,aAAa,EAAE,MAAM,IAAI,CAAC;YACrD,SAAS,EAAE,SAAS,CAAC,OAAO,EAAE,MAAM,IAAI,CAAC;SAC1C,CAAC,CAAC;QAEH,OAAO,IAAI,CAAC;IACd,CAAC;CACF,CAAA;AA3DY,kDAAmB;8BAAnB,mBAAmB;IAD/B,IAAA,mBAAU,GAAE;IAKR,WAAA,IAAA,eAAM,EAAC,sCAAuB,CAAC,CAAA;qCAFJ,gBAAS;QACD,uDAA6B;QACP,gBAAM;GAJvD,mBAAmB,CA2D/B"}
@@ -0,0 +1,7 @@
1
+ export * from './version.guard';
2
+ export * from './tenant-context.guard';
3
+ export * from './permission.guard';
4
+ export * from './auth.guard';
5
+ export * from './api-key.guard';
6
+ export * from './data-visibility.guard';
7
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/guards/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,oBAAoB,CAAC;AACnC,cAAc,cAAc,CAAC;AAC7B,cAAc,iBAAiB,CAAC;AAChC,cAAc,yBAAyB,CAAC"}
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
+ for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ __exportStar(require("./version.guard"), exports);
18
+ __exportStar(require("./tenant-context.guard"), exports);
19
+ __exportStar(require("./permission.guard"), exports);
20
+ __exportStar(require("./auth.guard"), exports);
21
+ __exportStar(require("./api-key.guard"), exports);
22
+ __exportStar(require("./data-visibility.guard"), exports);
23
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/guards/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,kDAAgC;AAChC,yDAAuC;AACvC,qDAAmC;AACnC,+CAA6B;AAC7B,kDAAgC;AAChC,0DAAwC"}
@@ -0,0 +1,20 @@
1
+ import { CanActivate, ExecutionContext } from '@nestjs/common';
2
+ import { Reflector } from '@nestjs/core';
3
+ import { Logger } from 'winston';
4
+ import { JwtService } from '@nestjs/jwt';
5
+ import { ConfigService } from '@nestjs/config';
6
+ import { OrganizationPermissionService } from '@app/tenant-management/organization-permission';
7
+ export declare class PermissionGuard implements CanActivate {
8
+ private readonly reflector;
9
+ private readonly permissionService;
10
+ private readonly jwtService;
11
+ private readonly configService;
12
+ private readonly logger;
13
+ constructor(reflector: Reflector, permissionService: OrganizationPermissionService, jwtService: JwtService, configService: ConfigService, logger: Logger);
14
+ /**
15
+ * 从 Authorization header 中提取并验证 JWT token
16
+ */
17
+ private extractUserFromToken;
18
+ canActivate(context: ExecutionContext): Promise<boolean>;
19
+ }
20
+ //# sourceMappingURL=permission.guard.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"permission.guard.d.ts","sourceRoot":"","sources":["../../src/guards/permission.guard.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,WAAW,EACX,gBAAgB,EAIjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAEzC,OAAO,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAEjC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,gBAAgB,CAAC;AAC/C,OAAO,EAAE,6BAA6B,EAAE,MAAM,gDAAgD,CAAC;AAQ/F,qBACa,eAAgB,YAAW,WAAW;IAE/C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAC1B,OAAO,CAAC,QAAQ,CAAC,iBAAiB;IAClC,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,aAAa;IACG,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAJvC,SAAS,EAAE,SAAS,EACpB,iBAAiB,EAAE,6BAA6B,EAChD,UAAU,EAAE,UAAU,EACtB,aAAa,EAAE,aAAa,EACK,MAAM,EAAE,MAAM;IAGlE;;OAEG;YACW,oBAAoB;IA6B5B,WAAW,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO,CAAC,OAAO,CAAC;CAsF/D"}