@nest-omni/core 4.1.3-2 → 4.1.3-20

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 (386) hide show
  1. package/audit/audit.module.d.ts +10 -0
  2. package/audit/audit.module.js +63 -1
  3. package/audit/controllers/audit.controller.d.ts +88 -0
  4. package/audit/controllers/audit.controller.js +74 -0
  5. package/audit/decorators/audit-action.decorator.d.ts +74 -0
  6. package/audit/decorators/audit-action.decorator.js +42 -0
  7. package/audit/decorators/audit-controller.decorator.d.ts +9 -1
  8. package/audit/decorators/audit-controller.decorator.js +11 -2
  9. package/audit/decorators/audit-operation.decorator.d.ts +45 -0
  10. package/audit/decorators/audit-operation.decorator.js +49 -0
  11. package/audit/decorators/entity-audit.decorator.d.ts +85 -1
  12. package/audit/decorators/entity-audit.decorator.js +153 -3
  13. package/audit/decorators/index.d.ts +2 -0
  14. package/audit/decorators/index.js +2 -0
  15. package/audit/dto/audit-log-query.dto.d.ts +3 -0
  16. package/audit/dto/audit-log-query.dto.js +3 -0
  17. package/audit/dto/begin-transaction.dto.d.ts +3 -0
  18. package/audit/dto/begin-transaction.dto.js +3 -0
  19. package/audit/dto/compare-entities.dto.d.ts +3 -0
  20. package/audit/dto/compare-entities.dto.js +3 -0
  21. package/audit/dto/pre-check-restore.dto.d.ts +3 -0
  22. package/audit/dto/pre-check-restore.dto.js +3 -0
  23. package/audit/dto/restore-entity.dto.d.ts +3 -0
  24. package/audit/dto/restore-entity.dto.js +3 -0
  25. package/audit/entities/audit-action-summary.entity.d.ts +23 -0
  26. package/audit/entities/audit-action-summary.entity.js +101 -0
  27. package/audit/entities/entity-audit-log.entity.d.ts +11 -0
  28. package/audit/entities/entity-audit-log.entity.js +57 -2
  29. package/audit/entities/entity-transaction.entity.d.ts +11 -2
  30. package/audit/entities/entity-transaction.entity.js +42 -3
  31. package/audit/entities/index.d.ts +3 -0
  32. package/audit/entities/index.js +3 -0
  33. package/audit/entities/manual-operation-log.entity.d.ts +4 -0
  34. package/audit/entities/manual-operation-log.entity.js +12 -1
  35. package/audit/entities/operation-template.entity.d.ts +4 -0
  36. package/audit/entities/operation-template.entity.js +4 -0
  37. package/audit/enums/audit.enums.d.ts +37 -6
  38. package/audit/enums/audit.enums.js +40 -7
  39. package/audit/index.d.ts +4 -1
  40. package/audit/index.js +34 -1
  41. package/audit/interceptors/audit-action.interceptor.d.ts +38 -0
  42. package/audit/interceptors/audit-action.interceptor.js +215 -0
  43. package/audit/interceptors/audit.interceptor.d.ts +15 -0
  44. package/audit/interceptors/audit.interceptor.js +23 -1
  45. package/audit/interceptors/index.d.ts +1 -0
  46. package/audit/interceptors/index.js +1 -0
  47. package/audit/interfaces/audit.interfaces.d.ts +187 -2
  48. package/audit/services/audit-action.service.d.ts +141 -0
  49. package/audit/services/audit-action.service.js +244 -0
  50. package/audit/services/audit-context.service.d.ts +97 -0
  51. package/audit/services/audit-context.service.js +185 -0
  52. package/audit/services/audit-strategy.service.d.ts +6 -0
  53. package/audit/services/audit-strategy.service.js +13 -0
  54. package/audit/services/entity-audit.service.d.ts +230 -3
  55. package/audit/services/entity-audit.service.js +607 -14
  56. package/audit/services/index.d.ts +3 -0
  57. package/audit/services/index.js +3 -0
  58. package/audit/services/manual-audit-log.service.d.ts +134 -9
  59. package/audit/services/manual-audit-log.service.js +157 -40
  60. package/audit/services/multi-database.service.d.ts +9 -2
  61. package/audit/services/multi-database.service.js +9 -21
  62. package/audit/services/operation-description.service.d.ts +71 -2
  63. package/audit/services/operation-description.service.js +231 -20
  64. package/audit/services/transaction-audit.service.d.ts +30 -0
  65. package/audit/services/transaction-audit.service.js +53 -5
  66. package/audit/subscribers/entity-audit.subscriber.d.ts +19 -0
  67. package/audit/subscribers/entity-audit.subscriber.js +76 -1
  68. package/cache/cache-metrics.service.d.ts +67 -0
  69. package/cache/cache-metrics.service.js +68 -4
  70. package/cache/cache-serialization.service.d.ts +31 -0
  71. package/cache/cache-serialization.service.js +25 -0
  72. package/cache/cache.constants.d.ts +9 -0
  73. package/cache/cache.constants.js +9 -0
  74. package/cache/cache.health.d.ts +26 -0
  75. package/cache/cache.health.js +30 -0
  76. package/cache/cache.module.d.ts +82 -2
  77. package/cache/cache.module.js +76 -5
  78. package/cache/cache.service.d.ts +140 -0
  79. package/cache/cache.service.js +169 -0
  80. package/cache/cache.warmup.service.d.ts +39 -0
  81. package/cache/cache.warmup.service.js +32 -0
  82. package/cache/decorators/cache-evict.decorator.d.ts +47 -0
  83. package/cache/decorators/cache-evict.decorator.js +56 -0
  84. package/cache/decorators/cache-put.decorator.d.ts +34 -0
  85. package/cache/decorators/cache-put.decorator.js +39 -0
  86. package/cache/decorators/cacheable.decorator.d.ts +40 -0
  87. package/cache/decorators/cacheable.decorator.js +55 -0
  88. package/cache/dependencies/callback.dependency.d.ts +33 -0
  89. package/cache/dependencies/callback.dependency.js +39 -1
  90. package/cache/dependencies/chain.dependency.d.ts +28 -0
  91. package/cache/dependencies/chain.dependency.js +34 -0
  92. package/cache/dependencies/db.dependency.d.ts +83 -7
  93. package/cache/dependencies/db.dependency.js +89 -14
  94. package/cache/dependencies/file.dependency.d.ts +32 -0
  95. package/cache/dependencies/file.dependency.js +34 -0
  96. package/cache/dependencies/tag.dependency.d.ts +75 -4
  97. package/cache/dependencies/tag.dependency.js +145 -11
  98. package/cache/dependencies/time.dependency.d.ts +43 -0
  99. package/cache/dependencies/time.dependency.js +43 -0
  100. package/cache/examples/basic-usage.d.ts +15 -0
  101. package/cache/examples/basic-usage.js +62 -8
  102. package/cache/index.js +9 -0
  103. package/cache/interfaces/cache-dependency.interface.d.ts +53 -0
  104. package/cache/interfaces/cache-options.interface.d.ts +89 -0
  105. package/cache/interfaces/cache-options.interface.js +6 -0
  106. package/cache/interfaces/cache-provider.interface.d.ts +78 -0
  107. package/cache/providers/base-cache.provider.d.ts +14 -0
  108. package/cache/providers/base-cache.provider.js +16 -0
  109. package/cache/providers/cls-cache.provider.d.ts +20 -0
  110. package/cache/providers/cls-cache.provider.js +28 -0
  111. package/cache/providers/memory-cache.provider.d.ts +43 -0
  112. package/cache/providers/memory-cache.provider.js +66 -0
  113. package/cache/providers/redis-cache.provider.d.ts +26 -0
  114. package/cache/providers/redis-cache.provider.js +29 -0
  115. package/cache/utils/dependency-manager.util.d.ts +52 -0
  116. package/cache/utils/dependency-manager.util.js +59 -0
  117. package/cache/utils/key-generator.util.d.ts +42 -0
  118. package/cache/utils/key-generator.util.js +53 -1
  119. package/common/abstract.entity.d.ts +14 -0
  120. package/common/abstract.entity.js +14 -0
  121. package/common/boilerplate.polyfill.d.ts +142 -0
  122. package/common/boilerplate.polyfill.js +18 -1
  123. package/common/dto/dto-container.d.ts +16 -0
  124. package/common/dto/dto-container.js +20 -0
  125. package/common/dto/dto-decorators.d.ts +18 -0
  126. package/common/dto/dto-decorators.js +14 -0
  127. package/common/dto/dto-extensions.d.ts +11 -0
  128. package/common/dto/dto-extensions.js +9 -0
  129. package/common/dto/dto-service-accessor.d.ts +17 -0
  130. package/common/dto/dto-service-accessor.js +18 -0
  131. package/common/dto/dto-transformer.d.ts +12 -0
  132. package/common/dto/dto-transformer.js +9 -0
  133. package/common/dto/index.js +2 -0
  134. package/common/examples/paginate-and-map.example.d.ts +6 -0
  135. package/common/examples/paginate-and-map.example.js +26 -0
  136. package/common/utils.d.ts +15 -0
  137. package/common/utils.js +15 -0
  138. package/constants/language-code.js +1 -0
  139. package/decorators/field.decorators.d.ts +1 -1
  140. package/decorators/field.decorators.js +8 -1
  141. package/decorators/property.decorators.js +1 -0
  142. package/decorators/public-route.decorator.js +1 -0
  143. package/decorators/transform.decorators.d.ts +27 -0
  144. package/decorators/transform.decorators.js +29 -0
  145. package/decorators/translate.decorator.js +1 -0
  146. package/decorators/user.decorator.js +1 -0
  147. package/decorators/validator.decorators.d.ts +8 -18
  148. package/decorators/validator.decorators.js +22 -190
  149. package/file-upload/controllers/file-access.controller.d.ts +23 -0
  150. package/file-upload/controllers/file-access.controller.js +128 -0
  151. package/file-upload/decorators/column.decorator.d.ts +151 -0
  152. package/file-upload/decorators/column.decorator.js +273 -0
  153. package/file-upload/decorators/csv-data.decorator.d.ts +30 -0
  154. package/file-upload/decorators/csv-data.decorator.js +85 -0
  155. package/file-upload/decorators/csv-import.decorator.d.ts +34 -0
  156. package/file-upload/decorators/csv-import.decorator.js +24 -0
  157. package/file-upload/decorators/examples/column-mapping.example.d.ts +76 -0
  158. package/file-upload/decorators/examples/column-mapping.example.js +122 -0
  159. package/file-upload/decorators/excel-data.decorator.d.ts +30 -0
  160. package/file-upload/decorators/excel-data.decorator.js +85 -0
  161. package/file-upload/decorators/file-upload.decorator.d.ts +83 -0
  162. package/file-upload/decorators/file-upload.decorator.js +172 -0
  163. package/file-upload/decorators/index.d.ts +5 -0
  164. package/file-upload/decorators/index.js +38 -0
  165. package/file-upload/decorators/process.decorator.d.ts +40 -0
  166. package/file-upload/decorators/process.decorator.js +52 -0
  167. package/file-upload/decorators/validate-data.decorator.d.ts +91 -0
  168. package/file-upload/decorators/validate-data.decorator.js +39 -0
  169. package/file-upload/dto/create-file.dto.d.ts +24 -0
  170. package/file-upload/dto/create-file.dto.js +112 -0
  171. package/file-upload/dto/find-files.dto.d.ts +15 -0
  172. package/file-upload/dto/find-files.dto.js +76 -0
  173. package/file-upload/dto/index.d.ts +4 -0
  174. package/file-upload/dto/index.js +20 -0
  175. package/file-upload/dto/pagination.dto.d.ts +7 -0
  176. package/file-upload/dto/pagination.dto.js +39 -0
  177. package/file-upload/dto/update-file.dto.d.ts +15 -0
  178. package/file-upload/dto/update-file.dto.js +67 -0
  179. package/file-upload/entities/file-metadata.entity.d.ts +25 -0
  180. package/file-upload/entities/file-metadata.entity.js +76 -0
  181. package/file-upload/entities/file.entity.d.ts +114 -0
  182. package/file-upload/entities/file.entity.js +350 -0
  183. package/file-upload/entities/index.d.ts +2 -0
  184. package/file-upload/entities/index.js +18 -0
  185. package/file-upload/enums/file-type.enum.d.ts +72 -0
  186. package/file-upload/enums/file-type.enum.js +212 -0
  187. package/file-upload/exceptions/file-upload.exception.d.ts +57 -0
  188. package/file-upload/exceptions/file-upload.exception.js +120 -0
  189. package/file-upload/exceptions/index.d.ts +1 -0
  190. package/file-upload/exceptions/index.js +17 -0
  191. package/file-upload/file-upload.module.d.ts +89 -0
  192. package/file-upload/file-upload.module.js +292 -0
  193. package/file-upload/index.d.ts +37 -0
  194. package/file-upload/index.js +77 -0
  195. package/file-upload/interceptors/file-upload.interceptor.d.ts +101 -0
  196. package/file-upload/interceptors/file-upload.interceptor.js +594 -0
  197. package/file-upload/interceptors/index.d.ts +1 -0
  198. package/file-upload/interceptors/index.js +17 -0
  199. package/file-upload/interfaces/custom-file-type.interface.d.ts +72 -0
  200. package/file-upload/interfaces/custom-file-type.interface.js +2 -0
  201. package/file-upload/interfaces/file-buffer.interface.d.ts +72 -0
  202. package/file-upload/interfaces/file-buffer.interface.js +2 -0
  203. package/file-upload/interfaces/file-entity.interface.d.ts +142 -0
  204. package/file-upload/interfaces/file-entity.interface.js +28 -0
  205. package/file-upload/interfaces/file-metadata.interface.d.ts +21 -0
  206. package/file-upload/interfaces/file-metadata.interface.js +2 -0
  207. package/file-upload/interfaces/file-processor.interface.d.ts +93 -0
  208. package/file-upload/interfaces/file-processor.interface.js +2 -0
  209. package/file-upload/interfaces/file-upload-options.interface.d.ts +74 -0
  210. package/file-upload/interfaces/file-upload-options.interface.js +5 -0
  211. package/file-upload/interfaces/index.d.ts +7 -0
  212. package/file-upload/interfaces/index.js +24 -0
  213. package/file-upload/interfaces/processor-options.interface.d.ts +102 -0
  214. package/file-upload/interfaces/processor-options.interface.js +2 -0
  215. package/file-upload/interfaces/storage-provider.interface.d.ts +239 -0
  216. package/file-upload/interfaces/storage-provider.interface.js +2 -0
  217. package/file-upload/interfaces/upload-options.interface.d.ts +19 -0
  218. package/file-upload/interfaces/upload-options.interface.js +2 -0
  219. package/file-upload/processors/csv.processor.d.ts +98 -0
  220. package/file-upload/processors/csv.processor.js +391 -0
  221. package/file-upload/processors/excel.processor.d.ts +130 -0
  222. package/file-upload/processors/excel.processor.js +547 -0
  223. package/file-upload/processors/image.processor.d.ts +199 -0
  224. package/file-upload/processors/image.processor.js +377 -0
  225. package/file-upload/providers/index.d.ts +2 -0
  226. package/file-upload/providers/index.js +18 -0
  227. package/file-upload/providers/local-storage.provider.d.ts +98 -0
  228. package/file-upload/providers/local-storage.provider.js +484 -0
  229. package/file-upload/providers/s3-storage.provider.d.ts +87 -0
  230. package/file-upload/providers/s3-storage.provider.js +455 -0
  231. package/file-upload/services/file-signature-validator.service.d.ts +118 -0
  232. package/file-upload/services/file-signature-validator.service.js +376 -0
  233. package/file-upload/services/file.service.d.ts +193 -0
  234. package/file-upload/services/file.service.js +638 -0
  235. package/file-upload/services/index.d.ts +4 -0
  236. package/file-upload/services/index.js +20 -0
  237. package/file-upload/services/malicious-file-detector.service.d.ts +300 -0
  238. package/file-upload/services/malicious-file-detector.service.js +1234 -0
  239. package/file-upload/services/mime-registry.service.d.ts +47 -0
  240. package/file-upload/services/mime-registry.service.js +167 -0
  241. package/file-upload/utils/checksum.util.d.ts +28 -0
  242. package/file-upload/utils/checksum.util.js +65 -0
  243. package/file-upload/utils/dynamic-import.util.d.ts +54 -0
  244. package/file-upload/utils/dynamic-import.util.js +156 -0
  245. package/file-upload/utils/filename.util.d.ts +59 -0
  246. package/file-upload/utils/filename.util.js +184 -0
  247. package/file-upload/utils/filepath.util.d.ts +70 -0
  248. package/file-upload/utils/filepath.util.js +152 -0
  249. package/file-upload/utils/index.d.ts +4 -0
  250. package/file-upload/utils/index.js +20 -0
  251. package/filters/constraint-errors.js +1 -0
  252. package/helpers/common.helper.d.ts +13 -0
  253. package/helpers/common.helper.js +13 -0
  254. package/http-client/config/http-client.config.d.ts +20 -0
  255. package/http-client/config/http-client.config.js +48 -21
  256. package/http-client/decorators/http-client.decorators.d.ts +55 -14
  257. package/http-client/decorators/http-client.decorators.js +154 -78
  258. package/http-client/entities/http-log.entity.d.ts +217 -8
  259. package/http-client/entities/http-log.entity.js +7 -22
  260. package/http-client/errors/http-client.errors.d.ts +57 -0
  261. package/http-client/errors/http-client.errors.js +58 -0
  262. package/http-client/examples/advanced-usage.example.d.ts +40 -0
  263. package/http-client/examples/advanced-usage.example.js +53 -61
  264. package/http-client/examples/auth-with-waiting-lock.example.d.ts +31 -0
  265. package/http-client/examples/auth-with-waiting-lock.example.js +52 -5
  266. package/http-client/examples/basic-usage.example.d.ts +60 -0
  267. package/http-client/examples/basic-usage.example.js +60 -0
  268. package/http-client/examples/multi-api-configuration.example.d.ts +60 -0
  269. package/http-client/examples/multi-api-configuration.example.js +76 -5
  270. package/http-client/examples/proxy-from-environment.example.d.ts +133 -0
  271. package/http-client/examples/proxy-from-environment.example.js +409 -0
  272. package/http-client/http-client.module.d.ts +48 -2
  273. package/http-client/http-client.module.js +147 -68
  274. package/http-client/index.d.ts +1 -1
  275. package/http-client/index.js +8 -0
  276. package/http-client/interfaces/api-client-config.interface.d.ts +80 -45
  277. package/http-client/interfaces/api-client-config.interface.js +3 -0
  278. package/http-client/interfaces/http-client-config.interface.d.ts +109 -52
  279. package/http-client/services/api-client-registry.service.d.ts +50 -11
  280. package/http-client/services/api-client-registry.service.js +90 -250
  281. package/http-client/services/circuit-breaker.service.d.ts +115 -2
  282. package/http-client/services/circuit-breaker.service.js +237 -7
  283. package/http-client/services/http-client.service.d.ts +124 -14
  284. package/http-client/services/http-client.service.js +437 -148
  285. package/http-client/services/http-log-query.service.d.ts +83 -0
  286. package/http-client/services/http-log-query.service.js +121 -13
  287. package/http-client/services/http-replay.service.d.ts +101 -0
  288. package/http-client/services/http-replay.service.js +86 -0
  289. package/http-client/services/index.d.ts +0 -1
  290. package/http-client/services/index.js +0 -1
  291. package/http-client/services/log-cleanup.service.d.ts +63 -0
  292. package/http-client/services/log-cleanup.service.js +54 -2
  293. package/http-client/services/logging.service.d.ts +116 -7
  294. package/http-client/services/logging.service.js +349 -86
  295. package/http-client/utils/call-stack-extractor.util.d.ts +63 -0
  296. package/http-client/utils/call-stack-extractor.util.js +83 -0
  297. package/http-client/utils/context-extractor.util.d.ts +49 -0
  298. package/http-client/utils/context-extractor.util.js +52 -0
  299. package/http-client/utils/curl-generator.util.d.ts +21 -0
  300. package/http-client/utils/curl-generator.util.js +44 -3
  301. package/http-client/utils/index.d.ts +1 -0
  302. package/http-client/utils/index.js +1 -0
  303. package/http-client/utils/proxy-environment.util.d.ts +42 -0
  304. package/http-client/utils/proxy-environment.util.js +148 -0
  305. package/http-client/utils/request-id.util.d.ts +18 -0
  306. package/http-client/utils/request-id.util.js +20 -0
  307. package/http-client/utils/retry-recorder.util.d.ts +42 -0
  308. package/http-client/utils/retry-recorder.util.js +44 -0
  309. package/http-client/utils/security-validator.util.d.ts +118 -0
  310. package/http-client/utils/security-validator.util.js +352 -0
  311. package/index.d.ts +3 -1
  312. package/index.js +12 -1
  313. package/interceptors/translation-interceptor.service.js +5 -0
  314. package/package.json +11 -7
  315. package/providers/context.provider.js +2 -0
  316. package/providers/generator.provider.d.ts +4 -0
  317. package/providers/generator.provider.js +4 -0
  318. package/redis-lock/comprehensive-lock-cleanup.service.d.ts +94 -0
  319. package/redis-lock/comprehensive-lock-cleanup.service.js +253 -0
  320. package/redis-lock/examples/lock-strategy.examples.d.ts +89 -0
  321. package/redis-lock/examples/lock-strategy.examples.js +130 -15
  322. package/redis-lock/index.d.ts +2 -0
  323. package/redis-lock/index.js +8 -1
  324. package/redis-lock/lock-heartbeat.service.d.ts +80 -0
  325. package/redis-lock/lock-heartbeat.service.js +232 -0
  326. package/redis-lock/redis-lock.decorator.d.ts +101 -0
  327. package/redis-lock/redis-lock.decorator.js +120 -0
  328. package/redis-lock/redis-lock.module.d.ts +66 -0
  329. package/redis-lock/redis-lock.module.js +175 -70
  330. package/redis-lock/redis-lock.service.d.ts +282 -0
  331. package/redis-lock/redis-lock.service.js +343 -20
  332. package/setup/bootstrap.setup.d.ts +1 -0
  333. package/setup/bootstrap.setup.js +21 -0
  334. package/setup/index.d.ts +1 -0
  335. package/setup/index.js +1 -0
  336. package/setup/mode.setup.d.ts +44 -0
  337. package/setup/mode.setup.js +44 -0
  338. package/setup/run-in-mode.decorator.d.ts +56 -0
  339. package/setup/run-in-mode.decorator.js +92 -0
  340. package/setup/schedule.decorator.d.ts +227 -0
  341. package/setup/schedule.decorator.js +240 -12
  342. package/setup/worker.decorator.d.ts +86 -0
  343. package/setup/worker.decorator.js +97 -0
  344. package/shared/index.d.ts +1 -1
  345. package/shared/index.js +1 -1
  346. package/shared/{serviceRegistryModule.js → service-registry.module.js} +19 -17
  347. package/shared/services/api-config.service.d.ts +3 -0
  348. package/shared/services/api-config.service.js +21 -9
  349. package/shared/services/index.d.ts +0 -1
  350. package/shared/services/index.js +0 -1
  351. package/validator-json/decorators.d.ts +17 -0
  352. package/validator-json/decorators.js +17 -2
  353. package/validator-json/default.d.ts +6 -0
  354. package/validator-json/default.js +30 -2
  355. package/validator-json/defaultConverters.js +1 -0
  356. package/validator-json/options.d.ts +23 -0
  357. package/validators/common-validators.d.ts +143 -0
  358. package/validators/common-validators.js +249 -0
  359. package/validators/custom-validate.examples.d.ts +23 -0
  360. package/validators/custom-validate.examples.js +78 -6
  361. package/validators/custom-validate.validator.d.ts +108 -0
  362. package/validators/custom-validate.validator.js +85 -0
  363. package/validators/file-mimetype.validator.d.ts +0 -2
  364. package/validators/file-mimetype.validator.js +4 -6
  365. package/validators/index.d.ts +1 -0
  366. package/validators/index.js +1 -0
  367. package/validators/is-exists.validator.d.ts +26 -6
  368. package/validators/is-exists.validator.js +30 -7
  369. package/validators/is-unique.validator.d.ts +33 -7
  370. package/validators/is-unique.validator.js +59 -17
  371. package/validators/skip-empty.validator.d.ts +5 -0
  372. package/validators/skip-empty.validator.js +5 -0
  373. package/vault/interfaces/vault-options.interface.d.ts +9 -0
  374. package/vault/vault-config.loader.d.ts +30 -0
  375. package/vault/vault-config.loader.js +48 -1
  376. package/vault/vault-config.service.d.ts +53 -0
  377. package/vault/vault-config.service.js +57 -0
  378. package/vault/vault.module.d.ts +4 -0
  379. package/vault/vault.module.js +4 -0
  380. package/decorators/examples/validation-decorators.example.d.ts +0 -69
  381. package/decorators/examples/validation-decorators.example.js +0 -331
  382. package/http-client/services/cache.service.d.ts +0 -24
  383. package/http-client/services/cache.service.js +0 -264
  384. package/shared/services/validator.service.d.ts +0 -3
  385. package/shared/services/validator.service.js +0 -20
  386. /package/shared/{serviceRegistryModule.d.ts → service-registry.module.d.ts} +0 -0
@@ -1,7 +1,17 @@
1
1
  import { DynamicModule } from '@nestjs/common';
2
2
  import { AuditConfig } from './interfaces';
3
+ /**
4
+ * 审计模块
5
+ */
3
6
  export declare class AuditModule {
7
+ /**
8
+ * 注册审计模块
9
+ * @param config 审计配置
10
+ */
4
11
  static forRoot(config?: AuditConfig): DynamicModule;
12
+ /**
13
+ * 注册审计模块(异步)
14
+ */
5
15
  static forRootAsync(options: {
6
16
  imports?: any[];
7
17
  inject?: any[];
@@ -25,11 +25,22 @@ const services_1 = require("./services");
25
25
  const subscribers_1 = require("./subscribers");
26
26
  const interceptors_1 = require("./interceptors");
27
27
  const controllers_1 = require("./controllers");
28
+ /**
29
+ * 审计模块
30
+ */
28
31
  let AuditModule = AuditModule_1 = class AuditModule {
32
+ /**
33
+ * 注册审计模块
34
+ * @param config 审计配置
35
+ */
29
36
  static forRoot(config) {
30
37
  var _a, _b;
31
38
  const auditConnectionName = ((_a = config === null || config === void 0 ? void 0 : config.connections) === null || _a === void 0 ? void 0 : _a.audit) || 'default';
32
39
  const monitoredConnections = ((_b = config === null || config === void 0 ? void 0 : config.connections) === null || _b === void 0 ? void 0 : _b.monitored) || ['default'];
40
+ console.log('[AuditModule] auditConnectionName:', auditConnectionName);
41
+ console.log('[AuditModule] monitoredConnections:', monitoredConnections);
42
+ console.log('[AuditModule] config:', JSON.stringify(config === null || config === void 0 ? void 0 : config.connections));
43
+ // 创建多个订阅者提供者,每个监听的数据库连接一个
33
44
  const subscriberProviders = monitoredConnections.map((connectionName) => ({
34
45
  provide: `AUDIT_SUBSCRIBER_${connectionName}`,
35
46
  useFactory: (auditService, contextService, auditStrategy, dataSource) => {
@@ -43,6 +54,7 @@ let AuditModule = AuditModule_1 = class AuditModule {
43
54
  (0, typeorm_1.getDataSourceToken)(connectionName),
44
55
  ],
45
56
  }));
57
+ // 创建repository别名提供者,使service能够注入正确连接的repository
46
58
  const repositoryProviders = [
47
59
  {
48
60
  provide: (0, typeorm_1.getRepositoryToken)(entities_1.EntityAuditLogEntity),
@@ -58,6 +70,27 @@ let AuditModule = AuditModule_1 = class AuditModule {
58
70
  },
59
71
  inject: [(0, typeorm_1.getDataSourceToken)(auditConnectionName)],
60
72
  },
73
+ {
74
+ provide: (0, typeorm_1.getRepositoryToken)(entities_1.OperationTemplateEntity),
75
+ useFactory: (dataSource) => {
76
+ return dataSource.getRepository(entities_1.OperationTemplateEntity);
77
+ },
78
+ inject: [(0, typeorm_1.getDataSourceToken)(auditConnectionName)],
79
+ },
80
+ {
81
+ provide: (0, typeorm_1.getRepositoryToken)(entities_1.ManualOperationLogEntity),
82
+ useFactory: (dataSource) => {
83
+ return dataSource.getRepository(entities_1.ManualOperationLogEntity);
84
+ },
85
+ inject: [(0, typeorm_1.getDataSourceToken)(auditConnectionName)],
86
+ },
87
+ {
88
+ provide: (0, typeorm_1.getRepositoryToken)(entities_1.AuditActionSummaryEntity),
89
+ useFactory: (dataSource) => {
90
+ return dataSource.getRepository(entities_1.AuditActionSummaryEntity);
91
+ },
92
+ inject: [(0, typeorm_1.getDataSourceToken)(auditConnectionName)],
93
+ },
61
94
  {
62
95
  provide: 'AUDIT_ENTITY_MANAGER',
63
96
  useFactory: (dataSource) => {
@@ -69,7 +102,14 @@ let AuditModule = AuditModule_1 = class AuditModule {
69
102
  return {
70
103
  module: AuditModule_1,
71
104
  imports: [
72
- typeorm_1.TypeOrmModule.forFeature([entities_1.EntityAuditLogEntity, entities_1.EntityTransactionEntity], auditConnectionName),
105
+ // ��计日志存储到指定的数据库连接
106
+ typeorm_1.TypeOrmModule.forFeature([
107
+ entities_1.EntityAuditLogEntity,
108
+ entities_1.EntityTransactionEntity,
109
+ entities_1.OperationTemplateEntity,
110
+ entities_1.ManualOperationLogEntity,
111
+ entities_1.AuditActionSummaryEntity,
112
+ ], auditConnectionName),
73
113
  nestjs_cls_1.ClsModule.forRoot({
74
114
  global: true,
75
115
  middleware: { mount: true },
@@ -95,7 +135,11 @@ let AuditModule = AuditModule_1 = class AuditModule {
95
135
  ...repositoryProviders,
96
136
  services_1.EntityAuditService,
97
137
  services_1.TransactionAuditService,
138
+ services_1.OperationDescriptionService,
139
+ services_1.AuditActionService,
140
+ services_1.ManualAuditLogService,
98
141
  interceptors_1.AuditInterceptor,
142
+ interceptors_1.AuditActionInterceptor,
99
143
  ...subscriberProviders,
100
144
  ],
101
145
  exports: [
@@ -104,11 +148,20 @@ let AuditModule = AuditModule_1 = class AuditModule {
104
148
  services_1.MultiDatabaseService,
105
149
  services_1.EntityAuditService,
106
150
  services_1.TransactionAuditService,
151
+ services_1.OperationDescriptionService,
152
+ services_1.AuditActionService,
153
+ services_1.ManualAuditLogService,
107
154
  interceptors_1.AuditInterceptor,
155
+ interceptors_1.AuditActionInterceptor,
156
+ (0, typeorm_1.getRepositoryToken)(entities_1.AuditActionSummaryEntity),
108
157
  ],
109
158
  };
110
159
  }
160
+ /**
161
+ * 注册审计模块(异步)
162
+ */
111
163
  static forRootAsync(options) {
164
+ // 创建repository别名提供者,使service能够注入正确连接的repository
112
165
  const repositoryProviders = [
113
166
  {
114
167
  provide: (0, typeorm_1.getRepositoryToken)(entities_1.EntityAuditLogEntity),
@@ -195,6 +248,7 @@ let AuditModule = AuditModule_1 = class AuditModule {
195
248
  const config = yield options.useFactory(...args);
196
249
  const monitoredConnections = ((_a = config === null || config === void 0 ? void 0 : config.connections) === null || _a === void 0 ? void 0 : _a.monitored) || ['default'];
197
250
  const auditConnectionName = ((_b = config === null || config === void 0 ? void 0 : config.connections) === null || _b === void 0 ? void 0 : _b.audit) || 'default';
251
+ // 动态注册 TypeORM 实体
198
252
  const typeOrmModule = typeorm_1.TypeOrmModule.forFeature([entities_1.EntityAuditLogEntity, entities_1.EntityTransactionEntity], auditConnectionName);
199
253
  return monitoredConnections;
200
254
  }),
@@ -211,7 +265,11 @@ let AuditModule = AuditModule_1 = class AuditModule {
211
265
  ...repositoryProviders,
212
266
  services_1.EntityAuditService,
213
267
  services_1.TransactionAuditService,
268
+ services_1.OperationDescriptionService,
269
+ services_1.AuditActionService,
270
+ services_1.ManualAuditLogService,
214
271
  interceptors_1.AuditInterceptor,
272
+ interceptors_1.AuditActionInterceptor,
215
273
  ],
216
274
  exports: [
217
275
  services_1.AuditContextService,
@@ -219,7 +277,11 @@ let AuditModule = AuditModule_1 = class AuditModule {
219
277
  services_1.MultiDatabaseService,
220
278
  services_1.EntityAuditService,
221
279
  services_1.TransactionAuditService,
280
+ services_1.OperationDescriptionService,
281
+ services_1.AuditActionService,
282
+ services_1.ManualAuditLogService,
222
283
  interceptors_1.AuditInterceptor,
284
+ interceptors_1.AuditActionInterceptor,
223
285
  ],
224
286
  };
225
287
  }
@@ -4,17 +4,105 @@ import { AuditLogQueryDto, CompareEntitiesDto, RestoreEntityDto, PreCheckRestore
4
4
  import { EntityAuditLogEntity } from '../entities';
5
5
  import { EntityDifference, PreCheckResult, RestoreResult } from '../interfaces';
6
6
  import { PageDto } from '../../common/dto';
7
+ /**
8
+ * 审计控制器
9
+ */
7
10
  export declare class AuditController {
8
11
  private readonly entityAuditService;
9
12
  private readonly transactionAuditService;
10
13
  constructor(entityAuditService: EntityAuditService, transactionAuditService: TransactionAuditService);
14
+ /**
15
+ * 查询实体审计日志
16
+ */
11
17
  getAuditLogs(query: AuditLogQueryDto): Promise<PageDto<EntityAuditLogEntity>>;
18
+ /**
19
+ * 比较实体版本
20
+ */
12
21
  compareEntities(query: CompareEntitiesDto): Promise<EntityDifference>;
22
+ /**
23
+ * 预检查恢复操作
24
+ */
13
25
  preCheckRestore(preCheckDto: PreCheckRestoreDto): Promise<PreCheckResult>;
26
+ /**
27
+ * 恢复实体到指定版本
28
+ */
14
29
  restoreEntity(restoreDto: RestoreEntityDto): Promise<RestoreResult>;
30
+ /**
31
+ * 开始审计事务
32
+ */
15
33
  beginTransaction(beginTransactionDto: BeginTransactionDto): Promise<{
16
34
  transactionId: string;
17
35
  }>;
36
+ /**
37
+ * 提交审计事务
38
+ */
18
39
  commitTransaction(transactionId: string): Promise<void>;
40
+ /**
41
+ * 回滚审计事务
42
+ */
19
43
  rollbackTransaction(transactionId: string): Promise<void>;
44
+ /**
45
+ * 查询审计动作汇总记录
46
+ */
47
+ getAuditActions(userId?: string, username?: string, actionName?: string, success?: string, startTime?: string, endTime?: string, page?: number, limit?: number): Promise<PageDto<import("../entities").AuditActionSummaryEntity>>;
48
+ /**
49
+ * 查询单个审计动作的详细信息
50
+ */
51
+ getAuditActionDetail(actionId: string): Promise<{
52
+ summary: {
53
+ id: string;
54
+ actionName: string;
55
+ operationTemplateKey: string;
56
+ description: string;
57
+ descriptionParams: Record<string, any>;
58
+ success: boolean;
59
+ errorMessage: string;
60
+ duration: number;
61
+ userId: string;
62
+ username: string;
63
+ requestId: string;
64
+ requestIp: string;
65
+ userAgent: string;
66
+ entityChangesCount: number;
67
+ entityTypes: string[];
68
+ operationStats: Record<string, number>;
69
+ createdAt: Date;
70
+ metadata: Record<string, any>;
71
+ };
72
+ entityChanges: EntityAuditLogEntity[];
73
+ detailedChanges: {
74
+ id: string;
75
+ entityType: string;
76
+ entityId: string;
77
+ operation: import("..").AuditOperation;
78
+ operationLabel: string;
79
+ description: string;
80
+ sequenceInAction: number;
81
+ createdAt: Date;
82
+ oldValue: Record<string, any>;
83
+ newValue: Record<string, any>;
84
+ fieldChanges: {
85
+ field: string;
86
+ fieldLabel: string;
87
+ oldValue: any;
88
+ newValue: any;
89
+ changeType: "added" | "removed" | "modified" | "unchanged";
90
+ displayOldValue?: string;
91
+ displayNewValue?: string;
92
+ }[];
93
+ changedFieldsCount: number;
94
+ changedFields: string[];
95
+ }[];
96
+ statistics: {
97
+ totalChanges: number;
98
+ totalFieldChanges: number;
99
+ byEntityType: Record<string, number>;
100
+ byOperation: Record<string, number>;
101
+ operationSequence: {
102
+ sequence: number;
103
+ entityType: string;
104
+ operation: import("..").AuditOperation;
105
+ }[];
106
+ };
107
+ }>;
20
108
  }
@@ -27,48 +27,97 @@ const swagger_1 = require("@nestjs/swagger");
27
27
  const entity_audit_service_1 = require("../services/entity-audit.service");
28
28
  const transaction_audit_service_1 = require("../services/transaction-audit.service");
29
29
  const dto_1 = require("../dto");
30
+ /**
31
+ * 审计控制器
32
+ */
30
33
  let AuditController = class AuditController {
31
34
  constructor(entityAuditService, transactionAuditService) {
32
35
  this.entityAuditService = entityAuditService;
33
36
  this.transactionAuditService = transactionAuditService;
34
37
  }
38
+ /**
39
+ * 查询实体审计日志
40
+ */
35
41
  getAuditLogs(query) {
36
42
  return __awaiter(this, void 0, void 0, function* () {
37
43
  return this.entityAuditService.getAuditLogs(query);
38
44
  });
39
45
  }
46
+ /**
47
+ * 比较实体版本
48
+ */
40
49
  compareEntities(query) {
41
50
  return __awaiter(this, void 0, void 0, function* () {
42
51
  var _a, _b;
43
52
  return this.entityAuditService.compareEntities(query.entityType, query.entityId, (_a = query.fromVersion) === null || _a === void 0 ? void 0 : _a.toString(), (_b = query.toVersion) === null || _b === void 0 ? void 0 : _b.toString());
44
53
  });
45
54
  }
55
+ /**
56
+ * 预检查恢复操作
57
+ */
46
58
  preCheckRestore(preCheckDto) {
47
59
  return __awaiter(this, void 0, void 0, function* () {
48
60
  return this.entityAuditService.preCheckRestore(preCheckDto.entityType, preCheckDto.entityId, preCheckDto.auditLogId);
49
61
  });
50
62
  }
63
+ /**
64
+ * 恢复实体到指定版本
65
+ */
51
66
  restoreEntity(restoreDto) {
52
67
  return __awaiter(this, void 0, void 0, function* () {
53
68
  return this.entityAuditService.restoreEntity(restoreDto.entityType, restoreDto.entityId, restoreDto.auditLogId, restoreDto.options);
54
69
  });
55
70
  }
71
+ /**
72
+ * 开始审计事务
73
+ */
56
74
  beginTransaction(beginTransactionDto) {
57
75
  return __awaiter(this, void 0, void 0, function* () {
58
76
  const transactionId = yield this.transactionAuditService.beginTransaction(beginTransactionDto.description);
59
77
  return { transactionId };
60
78
  });
61
79
  }
80
+ /**
81
+ * 提交审计事务
82
+ */
62
83
  commitTransaction(transactionId) {
63
84
  return __awaiter(this, void 0, void 0, function* () {
64
85
  return this.transactionAuditService.commitTransaction(transactionId);
65
86
  });
66
87
  }
88
+ /**
89
+ * 回滚审计事务
90
+ */
67
91
  rollbackTransaction(transactionId) {
68
92
  return __awaiter(this, void 0, void 0, function* () {
69
93
  return this.transactionAuditService.rollbackTransaction(transactionId);
70
94
  });
71
95
  }
96
+ /**
97
+ * 查询审计动作汇总记录
98
+ */
99
+ getAuditActions(userId_1, username_1, actionName_1, success_1, startTime_1, endTime_1) {
100
+ return __awaiter(this, arguments, void 0, function* (userId, username, actionName, success, startTime, endTime, page = 1, limit = 20) {
101
+ return this.entityAuditService.getAuditActions({
102
+ userId,
103
+ username,
104
+ actionName,
105
+ success: success ? success === 'true' : undefined,
106
+ startTime: startTime ? new Date(startTime) : undefined,
107
+ endTime: endTime ? new Date(endTime) : undefined,
108
+ page,
109
+ limit,
110
+ });
111
+ });
112
+ }
113
+ /**
114
+ * 查询单个审计动作的详细信息
115
+ */
116
+ getAuditActionDetail(actionId) {
117
+ return __awaiter(this, void 0, void 0, function* () {
118
+ return this.entityAuditService.getAuditActionDetail(actionId);
119
+ });
120
+ }
72
121
  };
73
122
  exports.AuditController = AuditController;
74
123
  __decorate([
@@ -134,6 +183,31 @@ __decorate([
134
183
  __metadata("design:paramtypes", [String]),
135
184
  __metadata("design:returntype", Promise)
136
185
  ], AuditController.prototype, "rollbackTransaction", null);
186
+ __decorate([
187
+ (0, common_1.Get)('actions'),
188
+ (0, swagger_1.ApiOperation)({ summary: '查询审计动作汇总记录' }),
189
+ (0, swagger_1.ApiResponse)({ status: 200, description: '返回审计动作汇总列表' }),
190
+ __param(0, (0, common_1.Query)('userId')),
191
+ __param(1, (0, common_1.Query)('username')),
192
+ __param(2, (0, common_1.Query)('actionName')),
193
+ __param(3, (0, common_1.Query)('success')),
194
+ __param(4, (0, common_1.Query)('startTime')),
195
+ __param(5, (0, common_1.Query)('endTime')),
196
+ __param(6, (0, common_1.Query)('page')),
197
+ __param(7, (0, common_1.Query)('limit')),
198
+ __metadata("design:type", Function),
199
+ __metadata("design:paramtypes", [String, String, String, String, String, String, Number, Number]),
200
+ __metadata("design:returntype", Promise)
201
+ ], AuditController.prototype, "getAuditActions", null);
202
+ __decorate([
203
+ (0, common_1.Get)('actions/:actionId'),
204
+ (0, swagger_1.ApiOperation)({ summary: '查询审计动作详细信息' }),
205
+ (0, swagger_1.ApiResponse)({ status: 200, description: '返回审计动作详细信息' }),
206
+ __param(0, (0, common_1.Param)('actionId')),
207
+ __metadata("design:type", Function),
208
+ __metadata("design:paramtypes", [String]),
209
+ __metadata("design:returntype", Promise)
210
+ ], AuditController.prototype, "getAuditActionDetail", null);
137
211
  exports.AuditController = AuditController = __decorate([
138
212
  (0, common_1.Controller)('audit'),
139
213
  (0, swagger_1.ApiTags)('audit'),
@@ -0,0 +1,74 @@
1
+ import { AuditParamsContext } from '../services/audit-context.service';
2
+ export declare const AUDIT_ACTION_METADATA = "AUDIT_ACTION_METADATA";
3
+ /**
4
+ * 审计动作选项
5
+ */
6
+ export interface AuditActionOptions {
7
+ /**
8
+ * 操作模板键(可选)
9
+ * @example 'order.create'
10
+ */
11
+ templateKey?: string;
12
+ /**
13
+ * 参数构建器,用于从请求和实体变更中提取描述参数
14
+ * @param context - 包含 req, result, error, entityChanges 的上下文
15
+ * @returns 描述参数对象
16
+ *
17
+ * @example
18
+ * paramsBuilder: (context) => {
19
+ * const order = context.findEntity('Order', 'CREATE');
20
+ * const items = context.findEntities('OrderItem', 'CREATE');
21
+ * return {
22
+ * 'order.sn': order?.newValue.orderSn,
23
+ * 'product.count': items.length,
24
+ * 'receiver': order?.newValue.receiverName,
25
+ * };
26
+ * }
27
+ */
28
+ paramsBuilder?: (context: AuditParamsContext) => Record<string, any>;
29
+ /**
30
+ * 是否启用审计(默认 true)
31
+ */
32
+ enabled?: boolean;
33
+ /**
34
+ * 扩展元数据
35
+ */
36
+ metadata?: Record<string, any>;
37
+ }
38
+ /**
39
+ * 审计动作装饰器元数据
40
+ */
41
+ export interface AuditActionMetadata {
42
+ actionName: string;
43
+ options: AuditActionOptions;
44
+ }
45
+ /**
46
+ * 审计动作装饰器
47
+ * 用于在控制器方法上标记审计动作,自动收集该请求中的所有实体变更
48
+ *
49
+ * @param actionName - 操作名称,如 'createOrder', 'cancelOrder'
50
+ * @param options - 审计动作选项
51
+ *
52
+ * @example
53
+ * ```typescript
54
+ * @Post()
55
+ * @AuditAction('createOrder', {
56
+ * templateKey: 'order.create',
57
+ * paramsBuilder: (context) => {
58
+ * const order = context.findEntity('Order', 'CREATE');
59
+ * const items = context.findEntities('OrderItem', 'CREATE');
60
+ * return {
61
+ * 'order.sn': order?.newValue.orderSn,
62
+ * 'product.count': items.length,
63
+ * 'product.names': items.map(i => i.metadata?.productName).join('、'),
64
+ * 'receiver': order?.newValue.receiverName,
65
+ * 'totalAmount': order?.newValue.totalAmount,
66
+ * };
67
+ * }
68
+ * })
69
+ * async createOrder(@Body() dto: CreateOrderDto) {
70
+ * return await this.orderService.create(dto);
71
+ * }
72
+ * ```
73
+ */
74
+ export declare function AuditAction(actionName: string, options?: AuditActionOptions): MethodDecorator;
@@ -0,0 +1,42 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AUDIT_ACTION_METADATA = void 0;
4
+ exports.AuditAction = AuditAction;
5
+ const common_1 = require("@nestjs/common");
6
+ exports.AUDIT_ACTION_METADATA = 'AUDIT_ACTION_METADATA';
7
+ /**
8
+ * 审计动作装饰器
9
+ * 用于在控制器方法上标记审计动作,自动收集该请求中的所有实体变更
10
+ *
11
+ * @param actionName - 操作名称,如 'createOrder', 'cancelOrder'
12
+ * @param options - 审计动作选项
13
+ *
14
+ * @example
15
+ * ```typescript
16
+ * @Post()
17
+ * @AuditAction('createOrder', {
18
+ * templateKey: 'order.create',
19
+ * paramsBuilder: (context) => {
20
+ * const order = context.findEntity('Order', 'CREATE');
21
+ * const items = context.findEntities('OrderItem', 'CREATE');
22
+ * return {
23
+ * 'order.sn': order?.newValue.orderSn,
24
+ * 'product.count': items.length,
25
+ * 'product.names': items.map(i => i.metadata?.productName).join('、'),
26
+ * 'receiver': order?.newValue.receiverName,
27
+ * 'totalAmount': order?.newValue.totalAmount,
28
+ * };
29
+ * }
30
+ * })
31
+ * async createOrder(@Body() dto: CreateOrderDto) {
32
+ * return await this.orderService.create(dto);
33
+ * }
34
+ * ```
35
+ */
36
+ function AuditAction(actionName, options = {}) {
37
+ const metadata = {
38
+ actionName,
39
+ options: Object.assign({ enabled: true }, options),
40
+ };
41
+ return (0, common_1.SetMetadata)(exports.AUDIT_ACTION_METADATA, metadata);
42
+ }
@@ -1,5 +1,13 @@
1
1
  import { ControllerAuditOptions, MethodAuditOptions } from '../interfaces';
2
2
  export declare const CONTROLLER_AUDIT_OPTIONS: unique symbol;
3
3
  export declare const METHOD_AUDIT_OPTIONS: unique symbol;
4
- export declare function EntityAuditController(options?: ControllerAuditOptions): ClassDecorator;
4
+ /**
5
+ * 控制器审计装饰器
6
+ * @param options 控制器审计选项
7
+ */
8
+ export declare function AuditController(options?: ControllerAuditOptions): ClassDecorator;
9
+ /**
10
+ * 方法审计装饰器
11
+ * @param options 方法审计选项
12
+ */
5
13
  export declare function AuditMethod(options?: MethodAuditOptions): MethodDecorator;
@@ -1,15 +1,24 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.METHOD_AUDIT_OPTIONS = exports.CONTROLLER_AUDIT_OPTIONS = void 0;
4
- exports.EntityAuditController = EntityAuditController;
4
+ exports.AuditController = AuditController;
5
5
  exports.AuditMethod = AuditMethod;
6
+ // 元数据键
6
7
  exports.CONTROLLER_AUDIT_OPTIONS = Symbol('CONTROLLER_AUDIT_OPTIONS');
7
8
  exports.METHOD_AUDIT_OPTIONS = Symbol('METHOD_AUDIT_OPTIONS');
8
- function EntityAuditController(options) {
9
+ /**
10
+ * 控制器审计装饰器
11
+ * @param options 控制器审计选项
12
+ */
13
+ function AuditController(options) {
9
14
  return (target) => {
10
15
  Reflect.defineMetadata(exports.CONTROLLER_AUDIT_OPTIONS, options || {}, target);
11
16
  };
12
17
  }
18
+ /**
19
+ * 方法审计装饰器
20
+ * @param options 方法审计选项
21
+ */
13
22
  function AuditMethod(options) {
14
23
  return (target, propertyKey, descriptor) => {
15
24
  Reflect.defineMetadata(exports.METHOD_AUDIT_OPTIONS, options || {}, descriptor.value);
@@ -1,5 +1,50 @@
1
1
  import { AuditOperationOptions } from '../interfaces';
2
2
  export declare const AUDIT_OPERATION_OPTIONS: unique symbol;
3
+ /**
4
+ * 方法审计装饰器
5
+ *
6
+ * @description
7
+ * 用于手动记录业务操作的审计日志,支持:
8
+ * - 自定义操作模板
9
+ * - 动态描述参数
10
+ * - 回滚操作定义
11
+ * - 自动事务管理
12
+ *
13
+ * @param options 审计操作选项
14
+ *
15
+ * @example
16
+ * ```typescript
17
+ * @AuditLog({
18
+ * templateKey: 'user.approve',
19
+ * descriptionParams: (args, result) => ({
20
+ * username: args[0].username,
21
+ * approver: result.approver
22
+ * }),
23
+ * rollbackActions: (args, result) => [{
24
+ * type: RollbackActionType.UPDATE,
25
+ * action: 'reject',
26
+ * params: { userId: args[0].id },
27
+ * order: 1
28
+ * }],
29
+ * autoTransaction: true
30
+ * })
31
+ * async approveUser(user: User): Promise<ApprovalResult> {
32
+ * // 业务逻辑
33
+ * }
34
+ * ```
35
+ */
3
36
  export declare function AuditLog(options: AuditOperationOptions): MethodDecorator;
37
+ /**
38
+ * 获取方法的审计配置
39
+ * @param target 目标类或实例
40
+ * @param propertyKey 方法名
41
+ * @returns 审计操作选项
42
+ */
4
43
  export declare function getAuditOperationConfig(target: any, propertyKey: string | symbol): AuditOperationOptions | undefined;
44
+ /**
45
+ * 检查方法是否配置了审计
46
+ * @param target 目标类或实例
47
+ * @param propertyKey 方法名
48
+ * @returns 是否配置了审计
49
+ */
5
50
  export declare function hasAuditOperation(target: any, propertyKey: string | symbol): boolean;
@@ -4,20 +4,69 @@ exports.AUDIT_OPERATION_OPTIONS = void 0;
4
4
  exports.AuditLog = AuditLog;
5
5
  exports.getAuditOperationConfig = getAuditOperationConfig;
6
6
  exports.hasAuditOperation = hasAuditOperation;
7
+ // 元数据键
7
8
  exports.AUDIT_OPERATION_OPTIONS = Symbol('AUDIT_OPERATION_OPTIONS');
9
+ /**
10
+ * 方法审计装饰器
11
+ *
12
+ * @description
13
+ * 用于手动记录业务操作的审计日志,支持:
14
+ * - 自定义操作模板
15
+ * - 动态描述参数
16
+ * - 回滚操作定义
17
+ * - 自动事务管理
18
+ *
19
+ * @param options 审计操作选项
20
+ *
21
+ * @example
22
+ * ```typescript
23
+ * @AuditLog({
24
+ * templateKey: 'user.approve',
25
+ * descriptionParams: (args, result) => ({
26
+ * username: args[0].username,
27
+ * approver: result.approver
28
+ * }),
29
+ * rollbackActions: (args, result) => [{
30
+ * type: RollbackActionType.UPDATE,
31
+ * action: 'reject',
32
+ * params: { userId: args[0].id },
33
+ * order: 1
34
+ * }],
35
+ * autoTransaction: true
36
+ * })
37
+ * async approveUser(user: User): Promise<ApprovalResult> {
38
+ * // 业务逻辑
39
+ * }
40
+ * ```
41
+ */
8
42
  function AuditLog(options) {
9
43
  return (target, propertyKey, descriptor) => {
44
+ // 验证必需参数
10
45
  if (!options.templateKey) {
11
46
  throw new Error(`@AuditLog requires templateKey for method ${String(propertyKey)}`);
12
47
  }
48
+ // 存储元数据
13
49
  const methodMetadata = Object.assign(Object.assign({}, options), { methodName: String(propertyKey) });
14
50
  Reflect.defineMetadata(exports.AUDIT_OPERATION_OPTIONS, methodMetadata, target, propertyKey);
51
+ // 返回原始描述符,实际的拦截逻辑由 AuditInterceptor 处理
15
52
  return descriptor;
16
53
  };
17
54
  }
55
+ /**
56
+ * 获取方法的审计配置
57
+ * @param target 目标类或实例
58
+ * @param propertyKey 方法名
59
+ * @returns 审计操作选项
60
+ */
18
61
  function getAuditOperationConfig(target, propertyKey) {
19
62
  return Reflect.getMetadata(exports.AUDIT_OPERATION_OPTIONS, target, propertyKey);
20
63
  }
64
+ /**
65
+ * 检查方法是否配置了审计
66
+ * @param target 目标类或实例
67
+ * @param propertyKey 方法名
68
+ * @returns 是否配置了审计
69
+ */
21
70
  function hasAuditOperation(target, propertyKey) {
22
71
  return Reflect.hasMetadata(exports.AUDIT_OPERATION_OPTIONS, target, propertyKey);
23
72
  }