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

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 (441) hide show
  1. package/audit/audit.module.d.ts +11 -0
  2. package/audit/audit.module.js +65 -1
  3. package/audit/controllers/audit.controller.d.ts +81 -1
  4. package/audit/controllers/audit.controller.js +67 -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 +38 -0
  10. package/audit/decorators/audit-operation.decorator.js +42 -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-action-query.dto.d.ts +13 -0
  16. package/audit/dto/audit-action-query.dto.js +77 -0
  17. package/audit/dto/audit-log-query.dto.d.ts +3 -0
  18. package/audit/dto/audit-log-query.dto.js +3 -0
  19. package/audit/dto/begin-transaction.dto.d.ts +3 -0
  20. package/audit/dto/begin-transaction.dto.js +3 -0
  21. package/audit/dto/compare-entities.dto.d.ts +3 -0
  22. package/audit/dto/compare-entities.dto.js +3 -0
  23. package/audit/dto/index.d.ts +1 -0
  24. package/audit/dto/index.js +1 -0
  25. package/audit/dto/pre-check-restore.dto.d.ts +3 -0
  26. package/audit/dto/pre-check-restore.dto.js +3 -0
  27. package/audit/dto/restore-entity.dto.d.ts +3 -0
  28. package/audit/dto/restore-entity.dto.js +3 -0
  29. package/audit/entities/audit-action-summary.entity.d.ts +23 -0
  30. package/audit/entities/audit-action-summary.entity.js +101 -0
  31. package/audit/entities/entity-audit-log.entity.d.ts +10 -2
  32. package/audit/entities/entity-audit-log.entity.js +48 -9
  33. package/audit/entities/entity-transaction.entity.d.ts +11 -2
  34. package/audit/entities/entity-transaction.entity.js +42 -3
  35. package/audit/entities/index.d.ts +3 -0
  36. package/audit/entities/index.js +3 -0
  37. package/audit/entities/manual-operation-log.entity.d.ts +4 -2
  38. package/audit/entities/manual-operation-log.entity.js +12 -9
  39. package/audit/entities/operation-template.entity.d.ts +4 -0
  40. package/audit/entities/operation-template.entity.js +4 -0
  41. package/audit/enums/audit.enums.d.ts +29 -6
  42. package/audit/enums/audit.enums.js +31 -7
  43. package/audit/examples/decorator-value-mapping.example.d.ts +70 -0
  44. package/audit/examples/decorator-value-mapping.example.js +414 -0
  45. package/audit/index.d.ts +5 -1
  46. package/audit/index.js +38 -1
  47. package/audit/interceptors/audit-action.interceptor.d.ts +38 -0
  48. package/audit/interceptors/audit-action.interceptor.js +215 -0
  49. package/audit/interceptors/audit.interceptor.d.ts +16 -0
  50. package/audit/interceptors/audit.interceptor.js +41 -11
  51. package/audit/interceptors/index.d.ts +1 -0
  52. package/audit/interceptors/index.js +1 -0
  53. package/audit/interfaces/audit.interfaces.d.ts +174 -4
  54. package/audit/services/audit-action.service.d.ts +141 -0
  55. package/audit/services/audit-action.service.js +244 -0
  56. package/audit/services/audit-context.service.d.ts +106 -0
  57. package/audit/services/audit-context.service.js +185 -0
  58. package/audit/services/audit-strategy.service.d.ts +6 -0
  59. package/audit/services/audit-strategy.service.js +13 -0
  60. package/audit/services/entity-audit.service.d.ts +273 -5
  61. package/audit/services/entity-audit.service.js +840 -60
  62. package/audit/services/index.d.ts +3 -0
  63. package/audit/services/index.js +3 -0
  64. package/audit/services/manual-audit-log.service.d.ts +133 -9
  65. package/audit/services/manual-audit-log.service.js +157 -42
  66. package/audit/services/multi-database.service.d.ts +9 -2
  67. package/audit/services/multi-database.service.js +9 -21
  68. package/audit/services/operation-description.service.d.ts +71 -2
  69. package/audit/services/operation-description.service.js +231 -20
  70. package/audit/services/transaction-audit.service.d.ts +30 -0
  71. package/audit/services/transaction-audit.service.js +53 -5
  72. package/audit/subscribers/entity-audit.subscriber.d.ts +20 -0
  73. package/audit/subscribers/entity-audit.subscriber.js +98 -6
  74. package/cache/cache-metrics.service.d.ts +67 -0
  75. package/cache/cache-metrics.service.js +68 -4
  76. package/cache/cache-serialization.service.d.ts +31 -0
  77. package/cache/cache-serialization.service.js +25 -0
  78. package/cache/cache.constants.d.ts +9 -0
  79. package/cache/cache.constants.js +9 -0
  80. package/cache/cache.health.d.ts +26 -0
  81. package/cache/cache.health.js +30 -0
  82. package/cache/cache.module.d.ts +87 -2
  83. package/cache/cache.module.js +84 -11
  84. package/cache/cache.service.d.ts +143 -3
  85. package/cache/cache.service.js +173 -4
  86. package/cache/cache.warmup.service.d.ts +39 -0
  87. package/cache/cache.warmup.service.js +32 -0
  88. package/cache/decorators/cache-evict.decorator.d.ts +47 -0
  89. package/cache/decorators/cache-evict.decorator.js +56 -0
  90. package/cache/decorators/cache-put.decorator.d.ts +34 -0
  91. package/cache/decorators/cache-put.decorator.js +39 -0
  92. package/cache/decorators/cacheable.decorator.d.ts +40 -0
  93. package/cache/decorators/cacheable.decorator.js +55 -0
  94. package/cache/dependencies/callback.dependency.d.ts +33 -0
  95. package/cache/dependencies/callback.dependency.js +39 -1
  96. package/cache/dependencies/chain.dependency.d.ts +28 -0
  97. package/cache/dependencies/chain.dependency.js +34 -0
  98. package/cache/dependencies/db.dependency.d.ts +83 -7
  99. package/cache/dependencies/db.dependency.js +89 -14
  100. package/cache/dependencies/file.dependency.d.ts +32 -0
  101. package/cache/dependencies/file.dependency.js +34 -0
  102. package/cache/dependencies/tag.dependency.d.ts +75 -4
  103. package/cache/dependencies/tag.dependency.js +145 -11
  104. package/cache/dependencies/time.dependency.d.ts +43 -0
  105. package/cache/dependencies/time.dependency.js +43 -0
  106. package/cache/entities/index.d.ts +1 -0
  107. package/cache/entities/index.js +17 -0
  108. package/cache/entities/typeorm-cache.entity.d.ts +71 -0
  109. package/cache/entities/typeorm-cache.entity.js +110 -0
  110. package/cache/examples/basic-usage.d.ts +15 -0
  111. package/cache/examples/basic-usage.js +62 -8
  112. package/cache/index.d.ts +2 -1
  113. package/cache/index.js +28 -2
  114. package/cache/interfaces/cache-dependency.interface.d.ts +53 -0
  115. package/cache/interfaces/cache-options.interface.d.ts +89 -0
  116. package/cache/interfaces/cache-options.interface.js +6 -0
  117. package/cache/interfaces/cache-provider.interface.d.ts +78 -0
  118. package/cache/providers/base-cache.provider.d.ts +14 -0
  119. package/cache/providers/base-cache.provider.js +16 -0
  120. package/cache/providers/cls-cache.provider.d.ts +20 -0
  121. package/cache/providers/cls-cache.provider.js +28 -0
  122. package/cache/providers/index.d.ts +2 -1
  123. package/cache/providers/index.js +2 -1
  124. package/cache/providers/lrucache.provider.d.ts +76 -0
  125. package/cache/providers/lrucache.provider.js +226 -0
  126. package/cache/providers/redis-cache.provider.d.ts +26 -0
  127. package/cache/providers/redis-cache.provider.js +29 -0
  128. package/cache/providers/typeorm-cache.provider.d.ts +211 -0
  129. package/cache/providers/typeorm-cache.provider.js +483 -0
  130. package/cache/utils/dependency-manager.util.d.ts +52 -0
  131. package/cache/utils/dependency-manager.util.js +59 -0
  132. package/cache/utils/key-generator.util.d.ts +42 -0
  133. package/cache/utils/key-generator.util.js +53 -1
  134. package/common/abstract.entity.d.ts +14 -0
  135. package/common/abstract.entity.js +14 -0
  136. package/common/boilerplate.polyfill.d.ts +143 -0
  137. package/common/boilerplate.polyfill.js +35 -1
  138. package/common/dto/dto-container.d.ts +16 -0
  139. package/common/dto/dto-container.js +20 -0
  140. package/common/dto/dto-decorators.d.ts +18 -0
  141. package/common/dto/dto-decorators.js +14 -0
  142. package/common/dto/dto-extensions.d.ts +11 -0
  143. package/common/dto/dto-extensions.js +9 -0
  144. package/common/dto/dto-service-accessor.d.ts +17 -0
  145. package/common/dto/dto-service-accessor.js +18 -0
  146. package/common/dto/dto-transformer.d.ts +12 -0
  147. package/common/dto/dto-transformer.js +9 -0
  148. package/common/dto/index.js +2 -0
  149. package/common/examples/paginate-and-map.example.d.ts +6 -0
  150. package/common/examples/paginate-and-map.example.js +26 -0
  151. package/common/helpers/validation-metadata-helper.d.ts +55 -0
  152. package/common/helpers/validation-metadata-helper.js +60 -0
  153. package/common/index.d.ts +1 -0
  154. package/common/index.js +4 -0
  155. package/common/utils.d.ts +15 -0
  156. package/common/utils.js +15 -0
  157. package/constants/language-code.js +1 -0
  158. package/decorators/field.decorators.d.ts +72 -3
  159. package/decorators/field.decorators.js +155 -19
  160. package/decorators/property.decorators.js +1 -0
  161. package/decorators/public-route.decorator.js +1 -0
  162. package/decorators/transform.decorators.d.ts +27 -2
  163. package/decorators/transform.decorators.js +29 -23
  164. package/decorators/translate.decorator.js +1 -0
  165. package/decorators/user.decorator.js +1 -0
  166. package/decorators/validator.decorators.d.ts +8 -18
  167. package/decorators/validator.decorators.js +22 -190
  168. package/file-upload/controllers/file-access.controller.d.ts +23 -0
  169. package/file-upload/controllers/file-access.controller.js +128 -0
  170. package/file-upload/decorators/column.decorator.d.ts +151 -0
  171. package/file-upload/decorators/column.decorator.js +273 -0
  172. package/file-upload/decorators/csv-data.decorator.d.ts +30 -0
  173. package/file-upload/decorators/csv-data.decorator.js +85 -0
  174. package/file-upload/decorators/csv-import.decorator.d.ts +34 -0
  175. package/file-upload/decorators/csv-import.decorator.js +24 -0
  176. package/file-upload/decorators/examples/column-mapping.example.d.ts +76 -0
  177. package/file-upload/decorators/examples/column-mapping.example.js +122 -0
  178. package/file-upload/decorators/excel-data.decorator.d.ts +30 -0
  179. package/file-upload/decorators/excel-data.decorator.js +85 -0
  180. package/file-upload/decorators/file-upload.decorator.d.ts +83 -0
  181. package/file-upload/decorators/file-upload.decorator.js +172 -0
  182. package/file-upload/decorators/index.d.ts +5 -0
  183. package/file-upload/decorators/index.js +38 -0
  184. package/file-upload/decorators/process.decorator.d.ts +40 -0
  185. package/file-upload/decorators/process.decorator.js +52 -0
  186. package/file-upload/decorators/validate-data.decorator.d.ts +91 -0
  187. package/file-upload/decorators/validate-data.decorator.js +39 -0
  188. package/file-upload/dto/create-file.dto.d.ts +24 -0
  189. package/file-upload/dto/create-file.dto.js +112 -0
  190. package/file-upload/dto/find-files.dto.d.ts +15 -0
  191. package/file-upload/dto/find-files.dto.js +76 -0
  192. package/file-upload/dto/index.d.ts +4 -0
  193. package/file-upload/dto/index.js +20 -0
  194. package/file-upload/dto/pagination.dto.d.ts +7 -0
  195. package/file-upload/dto/pagination.dto.js +39 -0
  196. package/file-upload/dto/update-file.dto.d.ts +15 -0
  197. package/file-upload/dto/update-file.dto.js +67 -0
  198. package/file-upload/entities/file-metadata.entity.d.ts +25 -0
  199. package/file-upload/entities/file-metadata.entity.js +76 -0
  200. package/file-upload/entities/file.entity.d.ts +114 -0
  201. package/file-upload/entities/file.entity.js +350 -0
  202. package/file-upload/entities/index.d.ts +2 -0
  203. package/file-upload/entities/index.js +18 -0
  204. package/file-upload/enums/file-type.enum.d.ts +72 -0
  205. package/file-upload/enums/file-type.enum.js +212 -0
  206. package/file-upload/exceptions/file-upload.exception.d.ts +57 -0
  207. package/file-upload/exceptions/file-upload.exception.js +120 -0
  208. package/file-upload/exceptions/index.d.ts +1 -0
  209. package/file-upload/exceptions/index.js +17 -0
  210. package/file-upload/file-upload.module.d.ts +89 -0
  211. package/file-upload/file-upload.module.js +292 -0
  212. package/file-upload/index.d.ts +37 -0
  213. package/file-upload/index.js +77 -0
  214. package/file-upload/interceptors/file-upload.interceptor.d.ts +101 -0
  215. package/file-upload/interceptors/file-upload.interceptor.js +594 -0
  216. package/file-upload/interceptors/index.d.ts +1 -0
  217. package/file-upload/interceptors/index.js +17 -0
  218. package/file-upload/interfaces/custom-file-type.interface.d.ts +72 -0
  219. package/file-upload/interfaces/custom-file-type.interface.js +2 -0
  220. package/file-upload/interfaces/file-buffer.interface.d.ts +72 -0
  221. package/file-upload/interfaces/file-buffer.interface.js +2 -0
  222. package/file-upload/interfaces/file-entity.interface.d.ts +142 -0
  223. package/file-upload/interfaces/file-entity.interface.js +28 -0
  224. package/file-upload/interfaces/file-metadata.interface.d.ts +21 -0
  225. package/file-upload/interfaces/file-metadata.interface.js +2 -0
  226. package/file-upload/interfaces/file-processor.interface.d.ts +93 -0
  227. package/file-upload/interfaces/file-processor.interface.js +2 -0
  228. package/file-upload/interfaces/file-upload-options.interface.d.ts +74 -0
  229. package/file-upload/interfaces/file-upload-options.interface.js +5 -0
  230. package/file-upload/interfaces/index.d.ts +7 -0
  231. package/file-upload/interfaces/index.js +24 -0
  232. package/file-upload/interfaces/processor-options.interface.d.ts +102 -0
  233. package/file-upload/interfaces/processor-options.interface.js +2 -0
  234. package/file-upload/interfaces/storage-provider.interface.d.ts +239 -0
  235. package/file-upload/interfaces/storage-provider.interface.js +2 -0
  236. package/file-upload/interfaces/upload-options.interface.d.ts +19 -0
  237. package/file-upload/interfaces/upload-options.interface.js +2 -0
  238. package/file-upload/processors/csv.processor.d.ts +98 -0
  239. package/file-upload/processors/csv.processor.js +391 -0
  240. package/file-upload/processors/excel.processor.d.ts +130 -0
  241. package/file-upload/processors/excel.processor.js +547 -0
  242. package/file-upload/processors/image.processor.d.ts +199 -0
  243. package/file-upload/processors/image.processor.js +377 -0
  244. package/file-upload/providers/index.d.ts +2 -0
  245. package/file-upload/providers/index.js +18 -0
  246. package/file-upload/providers/local-storage.provider.d.ts +98 -0
  247. package/file-upload/providers/local-storage.provider.js +484 -0
  248. package/file-upload/providers/s3-storage.provider.d.ts +87 -0
  249. package/file-upload/providers/s3-storage.provider.js +455 -0
  250. package/file-upload/services/file-signature-validator.service.d.ts +118 -0
  251. package/file-upload/services/file-signature-validator.service.js +376 -0
  252. package/file-upload/services/file.service.d.ts +193 -0
  253. package/file-upload/services/file.service.js +638 -0
  254. package/file-upload/services/index.d.ts +4 -0
  255. package/file-upload/services/index.js +20 -0
  256. package/file-upload/services/malicious-file-detector.service.d.ts +300 -0
  257. package/file-upload/services/malicious-file-detector.service.js +1234 -0
  258. package/file-upload/services/mime-registry.service.d.ts +47 -0
  259. package/file-upload/services/mime-registry.service.js +167 -0
  260. package/file-upload/utils/checksum.util.d.ts +28 -0
  261. package/file-upload/utils/checksum.util.js +65 -0
  262. package/file-upload/utils/dynamic-import.util.d.ts +54 -0
  263. package/file-upload/utils/dynamic-import.util.js +156 -0
  264. package/file-upload/utils/filename.util.d.ts +59 -0
  265. package/file-upload/utils/filename.util.js +184 -0
  266. package/file-upload/utils/filepath.util.d.ts +70 -0
  267. package/file-upload/utils/filepath.util.js +152 -0
  268. package/file-upload/utils/index.d.ts +4 -0
  269. package/file-upload/utils/index.js +20 -0
  270. package/filters/bad-request.filter.js +19 -4
  271. package/filters/constraint-errors.js +1 -0
  272. package/helpers/common.helper.d.ts +13 -0
  273. package/helpers/common.helper.js +13 -0
  274. package/http-client/config/http-client.config.d.ts +20 -0
  275. package/http-client/config/http-client.config.js +48 -21
  276. package/http-client/decorators/http-client.decorators.d.ts +55 -14
  277. package/http-client/decorators/http-client.decorators.js +154 -78
  278. package/http-client/entities/http-log.entity.d.ts +217 -8
  279. package/http-client/entities/http-log.entity.js +7 -22
  280. package/http-client/errors/http-client.errors.d.ts +57 -0
  281. package/http-client/errors/http-client.errors.js +58 -0
  282. package/http-client/examples/advanced-usage.example.d.ts +40 -0
  283. package/http-client/examples/advanced-usage.example.js +53 -61
  284. package/http-client/examples/auth-with-waiting-lock.example.d.ts +31 -0
  285. package/http-client/examples/auth-with-waiting-lock.example.js +52 -5
  286. package/http-client/examples/basic-usage.example.d.ts +60 -0
  287. package/http-client/examples/basic-usage.example.js +60 -0
  288. package/http-client/examples/multi-api-configuration.example.d.ts +60 -0
  289. package/http-client/examples/multi-api-configuration.example.js +76 -5
  290. package/http-client/examples/proxy-from-environment.example.d.ts +133 -0
  291. package/http-client/examples/proxy-from-environment.example.js +409 -0
  292. package/http-client/http-client.module.d.ts +48 -2
  293. package/http-client/http-client.module.js +147 -68
  294. package/http-client/index.d.ts +1 -1
  295. package/http-client/index.js +8 -0
  296. package/http-client/interfaces/api-client-config.interface.d.ts +80 -45
  297. package/http-client/interfaces/api-client-config.interface.js +3 -0
  298. package/http-client/interfaces/http-client-config.interface.d.ts +109 -52
  299. package/http-client/services/api-client-registry.service.d.ts +50 -11
  300. package/http-client/services/api-client-registry.service.js +90 -250
  301. package/http-client/services/circuit-breaker.service.d.ts +115 -2
  302. package/http-client/services/circuit-breaker.service.js +237 -7
  303. package/http-client/services/http-client.service.d.ts +124 -14
  304. package/http-client/services/http-client.service.js +437 -148
  305. package/http-client/services/http-log-query.service.d.ts +83 -0
  306. package/http-client/services/http-log-query.service.js +121 -13
  307. package/http-client/services/http-replay.service.d.ts +101 -0
  308. package/http-client/services/http-replay.service.js +86 -0
  309. package/http-client/services/index.d.ts +0 -1
  310. package/http-client/services/index.js +0 -1
  311. package/http-client/services/log-cleanup.service.d.ts +63 -0
  312. package/http-client/services/log-cleanup.service.js +54 -2
  313. package/http-client/services/logging.service.d.ts +116 -7
  314. package/http-client/services/logging.service.js +349 -86
  315. package/http-client/utils/call-stack-extractor.util.d.ts +63 -0
  316. package/http-client/utils/call-stack-extractor.util.js +83 -0
  317. package/http-client/utils/context-extractor.util.d.ts +49 -0
  318. package/http-client/utils/context-extractor.util.js +54 -0
  319. package/http-client/utils/curl-generator.util.d.ts +21 -0
  320. package/http-client/utils/curl-generator.util.js +44 -3
  321. package/http-client/utils/index.d.ts +1 -0
  322. package/http-client/utils/index.js +1 -0
  323. package/http-client/utils/proxy-environment.util.d.ts +42 -0
  324. package/http-client/utils/proxy-environment.util.js +148 -0
  325. package/http-client/utils/request-id.util.d.ts +18 -0
  326. package/http-client/utils/request-id.util.js +20 -0
  327. package/http-client/utils/retry-recorder.util.d.ts +42 -0
  328. package/http-client/utils/retry-recorder.util.js +44 -0
  329. package/http-client/utils/security-validator.util.d.ts +118 -0
  330. package/http-client/utils/security-validator.util.js +352 -0
  331. package/index.d.ts +3 -1
  332. package/index.js +12 -1
  333. package/interceptors/translation-interceptor.service.js +5 -0
  334. package/ip-filter/constants.d.ts +21 -0
  335. package/ip-filter/constants.js +24 -0
  336. package/ip-filter/decorators/index.d.ts +1 -0
  337. package/ip-filter/decorators/index.js +17 -0
  338. package/ip-filter/decorators/ip-filter.decorator.d.ts +58 -0
  339. package/ip-filter/decorators/ip-filter.decorator.js +79 -0
  340. package/ip-filter/guards/index.d.ts +1 -0
  341. package/ip-filter/guards/index.js +17 -0
  342. package/ip-filter/guards/ip-filter.guard.d.ts +62 -0
  343. package/ip-filter/guards/ip-filter.guard.js +174 -0
  344. package/ip-filter/index.d.ts +7 -0
  345. package/ip-filter/index.js +23 -0
  346. package/ip-filter/interfaces/index.d.ts +4 -0
  347. package/ip-filter/interfaces/index.js +20 -0
  348. package/ip-filter/interfaces/ip-filter-async-options.interface.d.ts +15 -0
  349. package/ip-filter/interfaces/ip-filter-async-options.interface.js +2 -0
  350. package/ip-filter/interfaces/ip-filter-metadata.interface.d.ts +26 -0
  351. package/ip-filter/interfaces/ip-filter-metadata.interface.js +2 -0
  352. package/ip-filter/interfaces/ip-filter-options.interface.d.ts +34 -0
  353. package/ip-filter/interfaces/ip-filter-options.interface.js +2 -0
  354. package/ip-filter/interfaces/ip-rule.interface.d.ts +36 -0
  355. package/ip-filter/interfaces/ip-rule.interface.js +2 -0
  356. package/ip-filter/ip-filter.module.d.ts +55 -0
  357. package/ip-filter/ip-filter.module.js +105 -0
  358. package/ip-filter/services/index.d.ts +1 -0
  359. package/ip-filter/services/index.js +17 -0
  360. package/ip-filter/services/ip-filter.service.d.ts +92 -0
  361. package/ip-filter/services/ip-filter.service.js +238 -0
  362. package/ip-filter/utils/index.d.ts +1 -0
  363. package/ip-filter/utils/index.js +17 -0
  364. package/ip-filter/utils/ip-utils.d.ts +61 -0
  365. package/ip-filter/utils/ip-utils.js +162 -0
  366. package/package.json +32 -29
  367. package/providers/context.provider.d.ts +9 -0
  368. package/providers/context.provider.js +15 -0
  369. package/providers/generator.provider.d.ts +4 -0
  370. package/providers/generator.provider.js +4 -0
  371. package/redis-lock/comprehensive-lock-cleanup.service.d.ts +94 -0
  372. package/redis-lock/comprehensive-lock-cleanup.service.js +253 -0
  373. package/redis-lock/examples/lock-strategy.examples.d.ts +89 -0
  374. package/redis-lock/examples/lock-strategy.examples.js +130 -15
  375. package/redis-lock/index.d.ts +2 -0
  376. package/redis-lock/index.js +8 -1
  377. package/redis-lock/lock-heartbeat.service.d.ts +80 -0
  378. package/redis-lock/lock-heartbeat.service.js +232 -0
  379. package/redis-lock/redis-lock.decorator.d.ts +101 -0
  380. package/redis-lock/redis-lock.decorator.js +120 -0
  381. package/redis-lock/redis-lock.module.d.ts +66 -0
  382. package/redis-lock/redis-lock.module.js +175 -70
  383. package/redis-lock/redis-lock.service.d.ts +282 -0
  384. package/redis-lock/redis-lock.service.js +343 -20
  385. package/setup/bootstrap.setup.d.ts +2 -1
  386. package/setup/bootstrap.setup.js +22 -1
  387. package/setup/index.d.ts +1 -0
  388. package/setup/index.js +1 -0
  389. package/setup/mode.setup.d.ts +44 -0
  390. package/setup/mode.setup.js +44 -0
  391. package/setup/run-in-mode.decorator.d.ts +56 -0
  392. package/setup/run-in-mode.decorator.js +92 -0
  393. package/setup/schedule.decorator.d.ts +227 -0
  394. package/setup/schedule.decorator.js +240 -12
  395. package/setup/worker.decorator.d.ts +86 -0
  396. package/setup/worker.decorator.js +97 -0
  397. package/shared/index.d.ts +1 -1
  398. package/shared/index.js +1 -1
  399. package/shared/{serviceRegistryModule.js → service-registry.module.js} +19 -18
  400. package/shared/services/api-config.service.d.ts +3 -0
  401. package/shared/services/api-config.service.js +21 -9
  402. package/shared/services/index.d.ts +0 -1
  403. package/shared/services/index.js +0 -1
  404. package/validator-json/decorators.d.ts +17 -0
  405. package/validator-json/decorators.js +17 -2
  406. package/validator-json/default.d.ts +6 -0
  407. package/validator-json/default.js +30 -2
  408. package/validator-json/defaultConverters.js +1 -0
  409. package/validator-json/options.d.ts +23 -0
  410. package/validators/common-validators.d.ts +143 -0
  411. package/validators/common-validators.js +249 -0
  412. package/validators/custom-validate.examples.d.ts +23 -0
  413. package/validators/custom-validate.examples.js +78 -6
  414. package/validators/custom-validate.validator.d.ts +108 -0
  415. package/validators/custom-validate.validator.js +85 -0
  416. package/validators/file-mimetype.validator.d.ts +0 -2
  417. package/validators/file-mimetype.validator.js +4 -6
  418. package/validators/index.d.ts +1 -0
  419. package/validators/index.js +1 -0
  420. package/validators/is-exists.validator.d.ts +26 -6
  421. package/validators/is-exists.validator.js +30 -7
  422. package/validators/is-unique.validator.d.ts +33 -7
  423. package/validators/is-unique.validator.js +59 -17
  424. package/validators/skip-empty.validator.d.ts +5 -0
  425. package/validators/skip-empty.validator.js +5 -0
  426. package/vault/interfaces/vault-options.interface.d.ts +9 -0
  427. package/vault/vault-config.loader.d.ts +30 -0
  428. package/vault/vault-config.loader.js +48 -1
  429. package/vault/vault-config.service.d.ts +53 -0
  430. package/vault/vault-config.service.js +57 -0
  431. package/vault/vault.module.d.ts +4 -0
  432. package/vault/vault.module.js +4 -0
  433. package/cache/providers/memory-cache.provider.d.ts +0 -26
  434. package/cache/providers/memory-cache.provider.js +0 -171
  435. package/decorators/examples/validation-decorators.example.d.ts +0 -69
  436. package/decorators/examples/validation-decorators.example.js +0 -331
  437. package/http-client/services/cache.service.d.ts +0 -24
  438. package/http-client/services/cache.service.js +0 -264
  439. package/shared/services/validator.service.d.ts +0 -3
  440. package/shared/services/validator.service.js +0 -20
  441. /package/shared/{serviceRegistryModule.d.ts → service-registry.module.d.ts} +0 -0
@@ -0,0 +1,376 @@
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 __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
15
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
16
+ return new (P || (P = Promise))(function (resolve, reject) {
17
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
18
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
19
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
20
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
21
+ });
22
+ };
23
+ var FileSignatureValidator_1;
24
+ Object.defineProperty(exports, "__esModule", { value: true });
25
+ exports.FileSignatureValidator = void 0;
26
+ const common_1 = require("@nestjs/common");
27
+ const mime_registry_service_1 = require("./mime-registry.service");
28
+ const fs = require("fs-extra");
29
+ /**
30
+ * 文件签名验证服务
31
+ */
32
+ let FileSignatureValidator = FileSignatureValidator_1 = class FileSignatureValidator {
33
+ constructor(mimeRegistry, customTypes) {
34
+ this.mimeRegistry = mimeRegistry;
35
+ this.logger = new common_1.Logger(FileSignatureValidator_1.name);
36
+ this.defaultSignatures = new Map();
37
+ this.initializeDefaultSignatures();
38
+ if (customTypes) {
39
+ this.registerCustomSignatures(customTypes);
40
+ }
41
+ }
42
+ /**
43
+ * 验证文件签名
44
+ */
45
+ validateFileSignature(filePath, expectedTypes, options) {
46
+ return __awaiter(this, void 0, void 0, function* () {
47
+ const maxBytes = (options === null || options === void 0 ? void 0 : options.maxReadBytes) || 2048;
48
+ // 读取文件头
49
+ const buffer = yield this.readFileBuffer(filePath, maxBytes);
50
+ // 检测实际文件类型
51
+ const detectedTypes = yield this.detectFileTypes(buffer);
52
+ // 验证期望的类型
53
+ const isValid = expectedTypes.some((type) => this.matchesType(buffer, type));
54
+ // 检查文件完整性
55
+ const integrity = yield this.checkFileIntegrity(filePath, buffer);
56
+ // 获取文件大小
57
+ const stats = yield fs.stat(filePath);
58
+ return {
59
+ valid: isValid && integrity.valid,
60
+ detectedTypes,
61
+ expectedTypes,
62
+ errors: [
63
+ ...(!isValid
64
+ ? this.getValidationError(detectedTypes, expectedTypes)
65
+ : []),
66
+ ...(!integrity.valid ? integrity.errors : []),
67
+ ],
68
+ metadata: {
69
+ fileSize: stats.size,
70
+ confidence: this.calculateConfidence(buffer, detectedTypes),
71
+ signatures: detectedTypes.map((t) => ({
72
+ type: t.type,
73
+ signature: t.signature,
74
+ })),
75
+ },
76
+ };
77
+ });
78
+ }
79
+ /**
80
+ * 检测文件类型
81
+ */
82
+ detectFileTypes(buffer) {
83
+ return __awaiter(this, void 0, void 0, function* () {
84
+ const detected = [];
85
+ // 检查内置签名
86
+ for (const [mimeType, signatures] of this.defaultSignatures.entries()) {
87
+ for (const signature of signatures) {
88
+ if (this.matchesSignature(buffer, signature)) {
89
+ detected.push({
90
+ type: mimeType,
91
+ signature,
92
+ confidence: this.calculateSignatureConfidence(signature),
93
+ });
94
+ break;
95
+ }
96
+ }
97
+ }
98
+ // 检查自定义签名
99
+ const registeredTypes = this.mimeRegistry.getAllRegisteredTypes();
100
+ for (const typeName of registeredTypes) {
101
+ const config = this.mimeRegistry.getMimeConfig(typeName);
102
+ if (config === null || config === void 0 ? void 0 : config.signatures) {
103
+ const signatures = Array.isArray(config.signatures)
104
+ ? config.signatures
105
+ : [config.signatures];
106
+ for (const signature of signatures) {
107
+ if (this.matchesSignature(buffer, signature)) {
108
+ detected.push({
109
+ type: typeName,
110
+ signature,
111
+ confidence: this.calculateSignatureConfidence(signature),
112
+ isCustom: true,
113
+ });
114
+ break;
115
+ }
116
+ }
117
+ }
118
+ }
119
+ // 按置信度排序
120
+ return detected.sort((a, b) => b.confidence - a.confidence);
121
+ });
122
+ }
123
+ /**
124
+ * 注册自定义签名
125
+ */
126
+ registerCustomSignatures(customTypes) {
127
+ if (!customTypes || typeof customTypes !== 'object') {
128
+ this.logger.warn('Invalid custom types provided to registerCustomSignatures');
129
+ return;
130
+ }
131
+ Object.entries(customTypes).forEach(([typeName, config]) => {
132
+ if (config === null || config === void 0 ? void 0 : config.signature) {
133
+ const signatures = Array.isArray(config.signature)
134
+ ? config.signature
135
+ : [config.signature];
136
+ this.defaultSignatures.set(typeName, signatures);
137
+ this.logger.debug(`Registered custom signatures for: ${typeName}`);
138
+ }
139
+ });
140
+ }
141
+ /**
142
+ * 检查签名是否匹配
143
+ */
144
+ matchesSignature(buffer, signature) {
145
+ const offset = signature.offset || 0;
146
+ const bytes = this.normalizeSignatureBytes(signature.bytes);
147
+ const length = signature.length || bytes.length;
148
+ // 检查边界
149
+ if (offset + length > buffer.length) {
150
+ return false;
151
+ }
152
+ const bufferSlice = buffer.slice(offset, offset + length);
153
+ // 应用掩码
154
+ if (signature.mask) {
155
+ const mask = this.normalizeSignatureBytes(signature.mask);
156
+ for (let i = 0; i < length; i++) {
157
+ if ((bufferSlice[i] & mask[i]) !== (bytes[i] & mask[i])) {
158
+ return false;
159
+ }
160
+ }
161
+ return true;
162
+ }
163
+ // 字符串比较
164
+ if (typeof signature.bytes === 'string') {
165
+ const bufferStr = bufferSlice.toString('ascii');
166
+ if (signature.exact === false) {
167
+ return bufferStr.startsWith(signature.bytes);
168
+ }
169
+ return bufferStr === signature.bytes;
170
+ }
171
+ // 字节数组比较
172
+ return bufferSlice.equals(bytes);
173
+ }
174
+ /**
175
+ * 检查类型是否匹配
176
+ */
177
+ matchesType(buffer, type) {
178
+ const config = this.mimeRegistry.getMimeConfig(type);
179
+ if (!(config === null || config === void 0 ? void 0 : config.signatures)) {
180
+ return true; // 无签名配置,默认通过
181
+ }
182
+ const signatures = Array.isArray(config.signatures)
183
+ ? config.signatures
184
+ : [config.signatures];
185
+ return signatures.some((sig) => this.matchesSignature(buffer, sig));
186
+ }
187
+ /**
188
+ * 规范化签名字节
189
+ */
190
+ normalizeSignatureBytes(bytes) {
191
+ if (Buffer.isBuffer(bytes)) {
192
+ return bytes;
193
+ }
194
+ if (typeof bytes === 'string') {
195
+ return Buffer.from(bytes, 'ascii');
196
+ }
197
+ return Buffer.from(bytes);
198
+ }
199
+ /**
200
+ * 读取文件缓冲区
201
+ */
202
+ readFileBuffer(filePath, size) {
203
+ return __awaiter(this, void 0, void 0, function* () {
204
+ let fileHandle;
205
+ try {
206
+ fileHandle = yield fs.open(filePath, 'r');
207
+ // 使用Buffer.alloc代替allocUnsafe以避免安全风险
208
+ const buffer = Buffer.alloc(size);
209
+ const { bytesRead } = yield fileHandle.read(buffer, 0, size, 0);
210
+ return buffer.slice(0, bytesRead);
211
+ }
212
+ finally {
213
+ if (fileHandle) {
214
+ try {
215
+ yield fileHandle.close();
216
+ }
217
+ catch (closeError) {
218
+ this.logger.error(`Failed to close file handle: ${closeError.message}`);
219
+ }
220
+ }
221
+ }
222
+ });
223
+ }
224
+ /**
225
+ * 检查文件完整性
226
+ */
227
+ checkFileIntegrity(filePath, header) {
228
+ return __awaiter(this, void 0, void 0, function* () {
229
+ const errors = [];
230
+ const stats = yield fs.stat(filePath);
231
+ // 检查文件是否为空
232
+ if (stats.size === 0) {
233
+ errors.push('File is empty');
234
+ }
235
+ // 检查常见损坏标记(大量null字节)
236
+ const nullBytes = header.filter((byte) => byte === 0x00).length;
237
+ if (nullBytes > header.length * 0.8) {
238
+ errors.push('File may be corrupted (excessive null bytes found)');
239
+ }
240
+ // 特定格式完整性检查
241
+ const detectedTypes = yield this.detectFileTypes(header);
242
+ for (const detection of detectedTypes) {
243
+ if (detection.type.includes('pdf')) {
244
+ // 检查 PDF 结尾标记
245
+ const tail = yield this.readFileTail(filePath, 1024);
246
+ if (!tail.includes(Buffer.from('%%EOF'))) {
247
+ errors.push('PDF file missing EOF marker');
248
+ }
249
+ }
250
+ }
251
+ return {
252
+ valid: errors.length === 0,
253
+ errors,
254
+ };
255
+ });
256
+ }
257
+ /**
258
+ * 读取文件尾部
259
+ */
260
+ readFileTail(filePath, size) {
261
+ return __awaiter(this, void 0, void 0, function* () {
262
+ const stats = yield fs.stat(filePath);
263
+ const start = Math.max(0, stats.size - size);
264
+ const actualSize = Math.min(size, stats.size);
265
+ const buffer = Buffer.alloc(actualSize);
266
+ const fileHandle = yield fs.open(filePath, 'r');
267
+ try {
268
+ yield fileHandle.read(buffer, 0, actualSize, start);
269
+ return buffer;
270
+ }
271
+ finally {
272
+ yield fileHandle.close();
273
+ }
274
+ });
275
+ }
276
+ /**
277
+ * 计算签名置信度
278
+ */
279
+ calculateSignatureConfidence(signature) {
280
+ const bytes = typeof signature.bytes === 'string'
281
+ ? signature.bytes.length
282
+ : signature.bytes.length;
283
+ // 签名越长,置信度越高
284
+ let confidence = Math.min(bytes / 8, 1);
285
+ // 精确匹配提高置信度
286
+ if (signature.exact !== false) {
287
+ confidence *= 1.2;
288
+ }
289
+ // 有掩码降低置信度
290
+ if (signature.mask) {
291
+ confidence *= 0.9;
292
+ }
293
+ return Math.min(confidence, 1);
294
+ }
295
+ /**
296
+ * 计算总体置信度
297
+ */
298
+ calculateConfidence(buffer, detected) {
299
+ if (detected.length === 0) {
300
+ return 0;
301
+ }
302
+ // 取最高置信度
303
+ return detected[0].confidence;
304
+ }
305
+ /**
306
+ * 获取验证错误信息
307
+ */
308
+ getValidationError(detected, expected) {
309
+ if (detected.length === 0) {
310
+ return ['Unable to detect file type'];
311
+ }
312
+ const detectedTypes = detected.map((d) => d.type).join(', ');
313
+ return [
314
+ `File signature mismatch. Expected: ${expected.join(', ')}, Detected: ${detectedTypes}`,
315
+ ];
316
+ }
317
+ /**
318
+ * 初始化默认签名
319
+ */
320
+ initializeDefaultSignatures() {
321
+ // 图片格式
322
+ this.defaultSignatures.set('image/jpeg', [
323
+ { bytes: [0xff, 0xd8, 0xff], offset: 0 },
324
+ ]);
325
+ this.defaultSignatures.set('image/png', [
326
+ { bytes: [0x89, 0x50, 0x4e, 0x47, 0x0d, 0x0a, 0x1a, 0x0a], offset: 0 },
327
+ ]);
328
+ this.defaultSignatures.set('image/gif', [
329
+ { bytes: 'GIF87a', offset: 0 },
330
+ { bytes: 'GIF89a', offset: 0 },
331
+ ]);
332
+ this.defaultSignatures.set('image/webp', [{ bytes: 'RIFF', offset: 0 }]);
333
+ this.defaultSignatures.set('image/bmp', [
334
+ { bytes: [0x42, 0x4d], offset: 0 },
335
+ ]);
336
+ // PDF
337
+ this.defaultSignatures.set('application/pdf', [
338
+ { bytes: '%PDF-', exact: false, offset: 0 },
339
+ ]);
340
+ // ZIP 容器(DOCX, XLSX 等)
341
+ this.defaultSignatures.set('application/zip', [
342
+ { bytes: [0x50, 0x4b, 0x03, 0x04], offset: 0 },
343
+ { bytes: [0x50, 0x4b, 0x05, 0x06], offset: 0 },
344
+ { bytes: [0x50, 0x4b, 0x07, 0x08], offset: 0 },
345
+ ]);
346
+ // Office 文档 (旧格式)
347
+ this.defaultSignatures.set('application/msword', [
348
+ { bytes: [0xd0, 0xcf, 0x11, 0xe0, 0xa1, 0xb1, 0x1a, 0xe1], offset: 0 },
349
+ ]);
350
+ // 可执行文件 (用于检测)
351
+ this.defaultSignatures.set('application/x-executable', [
352
+ { bytes: [0x4d, 0x5a], offset: 0 }, // PE (Windows)
353
+ { bytes: [0x7f, 0x45, 0x4c, 0x46], offset: 0 }, // ELF (Linux)
354
+ { bytes: [0xfe, 0xed, 0xfa, 0xce], offset: 0 }, // Mach-O (macOS)
355
+ { bytes: [0xfe, 0xed, 0xfa, 0xcf], offset: 0 }, // Mach-O 64-bit
356
+ ]);
357
+ // 压缩格式
358
+ this.defaultSignatures.set('application/x-rar', [
359
+ { bytes: 'Rar!', offset: 0 },
360
+ ]);
361
+ this.defaultSignatures.set('application/x-7z-compressed', [
362
+ { bytes: [0x37, 0x7a, 0xbc, 0xaf, 0x27, 0x1c], offset: 0 },
363
+ ]);
364
+ this.defaultSignatures.set('application/gzip', [
365
+ { bytes: [0x1f, 0x8b], offset: 0 },
366
+ ]);
367
+ this.logger.log(`Initialized ${this.defaultSignatures.size} default file signatures`);
368
+ }
369
+ };
370
+ exports.FileSignatureValidator = FileSignatureValidator;
371
+ exports.FileSignatureValidator = FileSignatureValidator = FileSignatureValidator_1 = __decorate([
372
+ (0, common_1.Injectable)(),
373
+ __param(1, (0, common_1.Optional)()),
374
+ __param(1, (0, common_1.Inject)('CUSTOM_FILE_TYPES')),
375
+ __metadata("design:paramtypes", [mime_registry_service_1.MimeRegistryService, Object])
376
+ ], FileSignatureValidator);
@@ -0,0 +1,193 @@
1
+ import { Repository } from 'typeorm';
2
+ import { FileEntity } from '../entities/file.entity';
3
+ import { FileMetadataEntity } from '../entities/file-metadata.entity';
4
+ import { CreateFileDto } from '../dto/create-file.dto';
5
+ import { UpdateFileDto } from '../dto/update-file.dto';
6
+ import { FindFilesDto } from '../dto/find-files.dto';
7
+ import { PaginationDto } from '../dto/pagination.dto';
8
+ import { IStorageProvider } from '../interfaces/storage-provider.interface';
9
+ import { FileBuffer } from '../interfaces/file-buffer.interface';
10
+ import { Readable } from 'stream';
11
+ /**
12
+ * 存储统计信息
13
+ */
14
+ export interface StorageStats {
15
+ totalFiles: number;
16
+ totalSize: number;
17
+ providers: Record<string, {
18
+ count: number;
19
+ size: number;
20
+ }>;
21
+ }
22
+ /**
23
+ * 文件查询结果
24
+ */
25
+ export interface FileQueryResult {
26
+ files: FileEntity[];
27
+ total: number;
28
+ page: number;
29
+ limit: number;
30
+ totalPages: number;
31
+ }
32
+ /**
33
+ * 文件管理服务
34
+ */
35
+ export declare class FileService {
36
+ private readonly fileRepository;
37
+ private readonly metadataRepository;
38
+ private readonly storageProvider?;
39
+ private readonly localStorageProvider?;
40
+ private readonly s3StorageProvider?;
41
+ private readonly logger;
42
+ private readonly ALLOWED_ORDER_FIELDS;
43
+ private readonly ALLOWED_ORDER_DIRECTIONS;
44
+ constructor(fileRepository: Repository<FileEntity>, metadataRepository: Repository<FileMetadataEntity>, storageProvider?: IStorageProvider, localStorageProvider?: IStorageProvider, s3StorageProvider?: IStorageProvider);
45
+ /**
46
+ * 创建文件记录
47
+ */
48
+ create(createFileDto: CreateFileDto): Promise<FileEntity>;
49
+ /**
50
+ * 根据ID查找文件
51
+ */
52
+ findById(id: string, includeDeleted?: boolean): Promise<FileEntity | null>;
53
+ /**
54
+ * 根据uploadId查找文件
55
+ */
56
+ findByUploadId(uploadId: string): Promise<FileEntity[]>;
57
+ /**
58
+ * 查找文件列表
59
+ */
60
+ findFiles(query: FindFilesDto, pagination: PaginationDto): Promise<FileQueryResult>;
61
+ /**
62
+ * 更新文件记录
63
+ */
64
+ update(id: string, updateFileDto: UpdateFileDto): Promise<FileEntity>;
65
+ /**
66
+ * 软删除文件
67
+ * @param id 文件ID
68
+ * @param deletePhysicalFile 是否同时删除物理文件,默认 false
69
+ */
70
+ softDelete(id: string, deletePhysicalFile?: boolean): Promise<void>;
71
+ /**
72
+ * 硬删除文件
73
+ * @param id 文件ID
74
+ * @param deletePhysicalFile 是否同时删除物理文件,默认 true
75
+ */
76
+ hardDelete(id: string, deletePhysicalFile?: boolean): Promise<void>;
77
+ /**
78
+ * 添加元数据
79
+ */
80
+ addMetadata(fileId: string, key: string, value: any, isPublic?: boolean): Promise<FileMetadataEntity>;
81
+ /**
82
+ * 获取元数据
83
+ */
84
+ getMetadata(fileId: string, keys?: string[]): Promise<Map<string, any>>;
85
+ /**
86
+ * 获取存储统计
87
+ */
88
+ getStorageStats(userId?: string): Promise<StorageStats>;
89
+ /**
90
+ * 更新处理状态
91
+ * 处理状态信息保存到 file_metadata 表
92
+ */
93
+ updateProcessingStatus(fileId: string, processor: string, status: 'pending' | 'completed' | 'failed', result?: any, error?: string): Promise<void>;
94
+ /**
95
+ * 清理临时文件(定时任务)
96
+ */
97
+ cleanupTempFiles(olderThanHours?: number): Promise<{
98
+ deleted: number;
99
+ }>;
100
+ /**
101
+ * 获取文件内容(二进制)
102
+ * 适用于服务间调用,获取完整文件内容
103
+ *
104
+ * @param fileId 文件ID
105
+ * @returns 文件缓冲区对象
106
+ * @throws NotFoundException 文件不存在
107
+ * @throws BadRequestException 文件未完成上传
108
+ */
109
+ getFileContent(fileId: string): Promise<FileBuffer>;
110
+ /**
111
+ * 获取文件流(用于大文件)
112
+ * 适用于流式处理,避免一次性加载到内存
113
+ * 注意:仅支持本地存储,对象存储请使用 getSignedUrl
114
+ *
115
+ * @param fileId 文件ID
116
+ * @returns 可读流
117
+ * @throws NotFoundException 文件不存在或物理文件缺失
118
+ * @throws BadRequestException 文件未完成或存储类型不支持
119
+ */
120
+ getFileStream(fileId: string): Promise<Readable>;
121
+ /**
122
+ * 获取预签名 URL(对象存储)
123
+ * 适用于客户端直接下载,或临时授权访问
124
+ *
125
+ * @param fileId 文件ID
126
+ * @param expiresIn 过期时间(秒),默认 3600 秒(1小时)
127
+ * @returns 预签名 URL
128
+ * @throws NotFoundException 文件不存在
129
+ */
130
+ getSignedUrl(fileId: string, expiresIn?: number): Promise<string>;
131
+ /**
132
+ * 批量获取文件内容
133
+ * 适用于需要同时处理多个文件的场景
134
+ * 失败的文件会被跳过,不会中断整个流程
135
+ *
136
+ * @param fileIds 文件ID列表
137
+ * @returns Map<文件ID, 文件内容>
138
+ */
139
+ getFilesContent(fileIds: string[]): Promise<Map<string, FileBuffer>>;
140
+ /**
141
+ * 获取文件访问 URL
142
+ * 根据存储类型返回不同的 URL
143
+ *
144
+ * @param fileId 文件ID
145
+ * @param baseUrl 基础 URL(可选,用于本地存储)
146
+ * @returns 文件访问 URL
147
+ */
148
+ getFileUrl(fileId: string, baseUrl?: string): Promise<string>;
149
+ /**
150
+ * 批量删除文件
151
+ * @param fileIds 文件ID列表
152
+ * @param deletePhysicalFile 是否同时删除物理文件,默认 true
153
+ * @returns 删除结果统计
154
+ */
155
+ batchDelete(fileIds: string[], deletePhysicalFile?: boolean): Promise<{
156
+ success: string[];
157
+ failed: Array<{
158
+ id: string;
159
+ error: string;
160
+ }>;
161
+ }>;
162
+ /**
163
+ * 复制文件(创建新记录)
164
+ * @param sourceFileId 源文件ID
165
+ * @param userId 新文件的用户ID(可选)
166
+ * @returns 新的文件实体
167
+ */
168
+ copyFile(sourceFileId: string, userId?: string): Promise<FileEntity>;
169
+ /**
170
+ * 移动文件到新路径
171
+ * @param fileId 文件ID
172
+ * @param newPath 新路径
173
+ * @returns 更新后的文件实体
174
+ */
175
+ moveFile(fileId: string, newPath: string): Promise<FileEntity>;
176
+ /**
177
+ * 删除物理文件
178
+ * @private
179
+ */
180
+ private deletePhysicalFile;
181
+ /**
182
+ * 根据存储类型获取存储提供者
183
+ *
184
+ * @param storageType 存储类型
185
+ * @returns 存储提供者实例
186
+ * @throws Error 存储提供者未配置或不支持
187
+ */
188
+ private getStorageProvider;
189
+ /**
190
+ * 转义 LIKE 操作符中的特殊字符
191
+ */
192
+ private escapeLikeString;
193
+ }