@morojs/moro 1.6.8 → 1.7.0

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 (300) hide show
  1. package/README.md +3 -1
  2. package/dist/core/auth/morojs-adapter.js +16 -6
  3. package/dist/core/auth/morojs-adapter.js.map +1 -1
  4. package/dist/core/config/config-sources.js +27 -15
  5. package/dist/core/config/config-sources.js.map +1 -1
  6. package/dist/core/config/config-validator.js +201 -6
  7. package/dist/core/config/config-validator.js.map +1 -1
  8. package/dist/core/docs/openapi-generator.js +8 -9
  9. package/dist/core/docs/openapi-generator.js.map +1 -1
  10. package/dist/core/events/event-bus.js +1 -1
  11. package/dist/core/events/event-bus.js.map +1 -1
  12. package/dist/core/framework.d.ts +4 -2
  13. package/dist/core/framework.js +25 -24
  14. package/dist/core/framework.js.map +1 -1
  15. package/dist/core/graphql/core.js +34 -8
  16. package/dist/core/graphql/core.js.map +1 -1
  17. package/dist/core/grpc/adapters/grpc-js-adapter.d.ts +28 -0
  18. package/dist/core/grpc/adapters/grpc-js-adapter.js +449 -0
  19. package/dist/core/grpc/adapters/grpc-js-adapter.js.map +1 -0
  20. package/dist/core/grpc/adapters/index.d.ts +1 -0
  21. package/dist/core/grpc/adapters/index.js +6 -0
  22. package/dist/core/grpc/adapters/index.js.map +1 -0
  23. package/dist/core/grpc/grpc-adapter.d.ts +47 -0
  24. package/dist/core/grpc/grpc-adapter.js +4 -0
  25. package/dist/core/grpc/grpc-adapter.js.map +1 -0
  26. package/dist/core/grpc/grpc-manager.d.ts +59 -0
  27. package/dist/core/grpc/grpc-manager.js +218 -0
  28. package/dist/core/grpc/grpc-manager.js.map +1 -0
  29. package/dist/core/grpc/index.d.ts +7 -0
  30. package/dist/core/grpc/index.js +10 -0
  31. package/dist/core/grpc/index.js.map +1 -0
  32. package/dist/core/grpc/middleware/auth.d.ts +22 -0
  33. package/dist/core/grpc/middleware/auth.js +126 -0
  34. package/dist/core/grpc/middleware/auth.js.map +1 -0
  35. package/dist/core/grpc/middleware/logging.d.ts +19 -0
  36. package/dist/core/grpc/middleware/logging.js +57 -0
  37. package/dist/core/grpc/middleware/logging.js.map +1 -0
  38. package/dist/core/grpc/middleware/validation.d.ts +18 -0
  39. package/dist/core/grpc/middleware/validation.js +126 -0
  40. package/dist/core/grpc/middleware/validation.js.map +1 -0
  41. package/dist/core/grpc/types.d.ts +233 -0
  42. package/dist/core/grpc/types.js +36 -0
  43. package/dist/core/grpc/types.js.map +1 -0
  44. package/dist/core/http/http-server.d.ts +13 -84
  45. package/dist/core/http/http-server.js +205 -792
  46. package/dist/core/http/http-server.js.map +1 -1
  47. package/dist/core/http/http2-server.d.ts +131 -0
  48. package/dist/core/http/http2-server.js +803 -0
  49. package/dist/core/http/http2-server.js.map +1 -0
  50. package/dist/core/http/index.d.ts +3 -1
  51. package/dist/core/http/index.js +2 -1
  52. package/dist/core/http/index.js.map +1 -1
  53. package/dist/core/http/uws-http-server.js +21 -26
  54. package/dist/core/http/uws-http-server.js.map +1 -1
  55. package/dist/core/jobs/job-executor.js +6 -1
  56. package/dist/core/jobs/job-executor.js.map +1 -1
  57. package/dist/core/jobs/job-scheduler.js +4 -1
  58. package/dist/core/jobs/job-scheduler.js.map +1 -1
  59. package/dist/core/jobs/leader-election.js +2 -1
  60. package/dist/core/jobs/leader-election.js.map +1 -1
  61. package/dist/core/logger/logger.js +41 -18
  62. package/dist/core/logger/logger.js.map +1 -1
  63. package/dist/core/logger/outputs.js +9 -3
  64. package/dist/core/logger/outputs.js.map +1 -1
  65. package/dist/core/mail/adapters/console-adapter.d.ts +14 -0
  66. package/dist/core/mail/adapters/console-adapter.js +89 -0
  67. package/dist/core/mail/adapters/console-adapter.js.map +1 -0
  68. package/dist/core/mail/adapters/index.d.ts +5 -0
  69. package/dist/core/mail/adapters/index.js +8 -0
  70. package/dist/core/mail/adapters/index.js.map +1 -0
  71. package/dist/core/mail/adapters/nodemailer-adapter.d.ts +18 -0
  72. package/dist/core/mail/adapters/nodemailer-adapter.js +188 -0
  73. package/dist/core/mail/adapters/nodemailer-adapter.js.map +1 -0
  74. package/dist/core/mail/adapters/resend-adapter.d.ts +18 -0
  75. package/dist/core/mail/adapters/resend-adapter.js +169 -0
  76. package/dist/core/mail/adapters/resend-adapter.js.map +1 -0
  77. package/dist/core/mail/adapters/sendgrid-adapter.d.ts +19 -0
  78. package/dist/core/mail/adapters/sendgrid-adapter.js +186 -0
  79. package/dist/core/mail/adapters/sendgrid-adapter.js.map +1 -0
  80. package/dist/core/mail/adapters/ses-adapter.d.ts +18 -0
  81. package/dist/core/mail/adapters/ses-adapter.js +167 -0
  82. package/dist/core/mail/adapters/ses-adapter.js.map +1 -0
  83. package/dist/core/mail/index.d.ts +5 -0
  84. package/dist/core/mail/index.js +8 -0
  85. package/dist/core/mail/index.js.map +1 -0
  86. package/dist/core/mail/mail-adapter.d.ts +62 -0
  87. package/dist/core/mail/mail-adapter.js +83 -0
  88. package/dist/core/mail/mail-adapter.js.map +1 -0
  89. package/dist/core/mail/mail-manager.d.ts +63 -0
  90. package/dist/core/mail/mail-manager.js +302 -0
  91. package/dist/core/mail/mail-manager.js.map +1 -0
  92. package/dist/core/mail/template-engine.d.ts +43 -0
  93. package/dist/core/mail/template-engine.js +239 -0
  94. package/dist/core/mail/template-engine.js.map +1 -0
  95. package/dist/core/mail/types.d.ts +237 -0
  96. package/dist/core/mail/types.js +4 -0
  97. package/dist/core/mail/types.js.map +1 -0
  98. package/dist/core/middleware/built-in/body-size/core.d.ts +12 -0
  99. package/dist/core/middleware/built-in/body-size/core.js +52 -0
  100. package/dist/core/middleware/built-in/body-size/core.js.map +1 -0
  101. package/dist/core/middleware/built-in/body-size/hook.d.ts +2 -0
  102. package/dist/core/middleware/built-in/body-size/hook.js +12 -0
  103. package/dist/core/middleware/built-in/body-size/hook.js.map +1 -0
  104. package/dist/core/middleware/built-in/body-size/index.d.ts +6 -0
  105. package/dist/core/middleware/built-in/body-size/index.js +7 -0
  106. package/dist/core/middleware/built-in/body-size/index.js.map +1 -0
  107. package/dist/core/middleware/built-in/body-size/middleware.d.ts +14 -0
  108. package/dist/core/middleware/built-in/body-size/middleware.js +22 -0
  109. package/dist/core/middleware/built-in/body-size/middleware.js.map +1 -0
  110. package/dist/core/middleware/built-in/cache/core.d.ts +20 -1
  111. package/dist/core/middleware/built-in/cache/core.js.map +1 -1
  112. package/dist/core/middleware/built-in/cache/hook.d.ts +38 -1
  113. package/dist/core/middleware/built-in/cache/hook.js +202 -16
  114. package/dist/core/middleware/built-in/cache/hook.js.map +1 -1
  115. package/dist/core/middleware/built-in/cache/index.js +1 -1
  116. package/dist/core/middleware/built-in/cache/index.js.map +1 -1
  117. package/dist/core/middleware/built-in/compression/core.d.ts +16 -0
  118. package/dist/core/middleware/built-in/compression/core.js +75 -0
  119. package/dist/core/middleware/built-in/compression/core.js.map +1 -0
  120. package/dist/core/middleware/built-in/compression/hook.d.ts +2 -0
  121. package/dist/core/middleware/built-in/compression/hook.js +14 -0
  122. package/dist/core/middleware/built-in/compression/hook.js.map +1 -0
  123. package/dist/core/middleware/built-in/compression/index.d.ts +6 -0
  124. package/dist/core/middleware/built-in/compression/index.js +7 -0
  125. package/dist/core/middleware/built-in/compression/index.js.map +1 -0
  126. package/dist/core/middleware/built-in/compression/middleware.d.ts +20 -0
  127. package/dist/core/middleware/built-in/compression/middleware.js +28 -0
  128. package/dist/core/middleware/built-in/compression/middleware.js.map +1 -0
  129. package/dist/core/middleware/built-in/cookie/core.js +37 -9
  130. package/dist/core/middleware/built-in/cookie/core.js.map +1 -1
  131. package/dist/core/middleware/built-in/helmet/core.d.ts +19 -0
  132. package/dist/core/middleware/built-in/helmet/core.js +70 -0
  133. package/dist/core/middleware/built-in/helmet/core.js.map +1 -0
  134. package/dist/core/middleware/built-in/helmet/hook.d.ts +2 -0
  135. package/dist/core/middleware/built-in/helmet/hook.js +12 -0
  136. package/dist/core/middleware/built-in/helmet/hook.js.map +1 -0
  137. package/dist/core/middleware/built-in/helmet/index.d.ts +6 -0
  138. package/dist/core/middleware/built-in/helmet/index.js +7 -0
  139. package/dist/core/middleware/built-in/helmet/index.js.map +1 -0
  140. package/dist/core/middleware/built-in/helmet/middleware.d.ts +22 -0
  141. package/dist/core/middleware/built-in/helmet/middleware.js +28 -0
  142. package/dist/core/middleware/built-in/helmet/middleware.js.map +1 -0
  143. package/dist/core/middleware/built-in/http2/core.d.ts +35 -0
  144. package/dist/core/middleware/built-in/http2/core.js +128 -0
  145. package/dist/core/middleware/built-in/http2/core.js.map +1 -0
  146. package/dist/core/middleware/built-in/http2/hook.d.ts +5 -0
  147. package/dist/core/middleware/built-in/http2/hook.js +34 -0
  148. package/dist/core/middleware/built-in/http2/hook.js.map +1 -0
  149. package/dist/core/middleware/built-in/http2/index.d.ts +8 -0
  150. package/dist/core/middleware/built-in/http2/index.js +10 -0
  151. package/dist/core/middleware/built-in/http2/index.js.map +1 -0
  152. package/dist/core/middleware/built-in/http2/middleware.d.ts +20 -0
  153. package/dist/core/middleware/built-in/http2/middleware.js +31 -0
  154. package/dist/core/middleware/built-in/http2/middleware.js.map +1 -0
  155. package/dist/core/middleware/built-in/index.d.ts +18 -0
  156. package/dist/core/middleware/built-in/index.js +28 -0
  157. package/dist/core/middleware/built-in/index.js.map +1 -1
  158. package/dist/core/middleware/built-in/range/core.d.ts +16 -0
  159. package/dist/core/middleware/built-in/range/core.js +112 -0
  160. package/dist/core/middleware/built-in/range/core.js.map +1 -0
  161. package/dist/core/middleware/built-in/range/hook.d.ts +2 -0
  162. package/dist/core/middleware/built-in/range/hook.js +12 -0
  163. package/dist/core/middleware/built-in/range/hook.js.map +1 -0
  164. package/dist/core/middleware/built-in/range/index.d.ts +6 -0
  165. package/dist/core/middleware/built-in/range/index.js +7 -0
  166. package/dist/core/middleware/built-in/range/index.js.map +1 -0
  167. package/dist/core/middleware/built-in/range/middleware.d.ts +21 -0
  168. package/dist/core/middleware/built-in/range/middleware.js +27 -0
  169. package/dist/core/middleware/built-in/range/middleware.js.map +1 -0
  170. package/dist/core/middleware/built-in/session/core.js +14 -1
  171. package/dist/core/middleware/built-in/session/core.js.map +1 -1
  172. package/dist/core/middleware/built-in/static/core.d.ts +20 -0
  173. package/dist/core/middleware/built-in/static/core.js +143 -0
  174. package/dist/core/middleware/built-in/static/core.js.map +1 -0
  175. package/dist/core/middleware/built-in/static/hook.d.ts +2 -0
  176. package/dist/core/middleware/built-in/static/hook.js +12 -0
  177. package/dist/core/middleware/built-in/static/hook.js.map +1 -0
  178. package/dist/core/middleware/built-in/static/index.d.ts +6 -0
  179. package/dist/core/middleware/built-in/static/index.js +7 -0
  180. package/dist/core/middleware/built-in/static/index.js.map +1 -0
  181. package/dist/core/middleware/built-in/static/middleware.d.ts +18 -0
  182. package/dist/core/middleware/built-in/static/middleware.js +26 -0
  183. package/dist/core/middleware/built-in/static/middleware.js.map +1 -0
  184. package/dist/core/middleware/built-in/template/core.d.ts +19 -0
  185. package/dist/core/middleware/built-in/template/core.js +108 -0
  186. package/dist/core/middleware/built-in/template/core.js.map +1 -0
  187. package/dist/core/middleware/built-in/template/hook.d.ts +2 -0
  188. package/dist/core/middleware/built-in/template/hook.js +12 -0
  189. package/dist/core/middleware/built-in/template/hook.js.map +1 -0
  190. package/dist/core/middleware/built-in/template/index.d.ts +6 -0
  191. package/dist/core/middleware/built-in/template/index.js +7 -0
  192. package/dist/core/middleware/built-in/template/index.js.map +1 -0
  193. package/dist/core/middleware/built-in/template/middleware.d.ts +21 -0
  194. package/dist/core/middleware/built-in/template/middleware.js +27 -0
  195. package/dist/core/middleware/built-in/template/middleware.js.map +1 -0
  196. package/dist/core/middleware/built-in/upload/core.d.ts +29 -0
  197. package/dist/core/middleware/built-in/upload/core.js +66 -0
  198. package/dist/core/middleware/built-in/upload/core.js.map +1 -0
  199. package/dist/core/middleware/built-in/upload/hook.d.ts +2 -0
  200. package/dist/core/middleware/built-in/upload/hook.js +25 -0
  201. package/dist/core/middleware/built-in/upload/hook.js.map +1 -0
  202. package/dist/core/middleware/built-in/upload/index.d.ts +6 -0
  203. package/dist/core/middleware/built-in/upload/index.js +7 -0
  204. package/dist/core/middleware/built-in/upload/index.js.map +1 -0
  205. package/dist/core/middleware/built-in/upload/middleware.d.ts +18 -0
  206. package/dist/core/middleware/built-in/upload/middleware.js +41 -0
  207. package/dist/core/middleware/built-in/upload/middleware.js.map +1 -0
  208. package/dist/core/middleware/built-in/validation/middleware.js +2 -1
  209. package/dist/core/middleware/built-in/validation/middleware.js.map +1 -1
  210. package/dist/core/networking/adapters/uws-adapter.js +54 -6
  211. package/dist/core/networking/adapters/uws-adapter.js.map +1 -1
  212. package/dist/core/networking/adapters/ws-adapter.js +56 -17
  213. package/dist/core/networking/adapters/ws-adapter.js.map +1 -1
  214. package/dist/core/pooling/object-pool-manager.js +9 -1
  215. package/dist/core/pooling/object-pool-manager.js.map +1 -1
  216. package/dist/core/queue/adapters/bull-adapter.d.ts +86 -0
  217. package/dist/core/queue/adapters/bull-adapter.js +330 -0
  218. package/dist/core/queue/adapters/bull-adapter.js.map +1 -0
  219. package/dist/core/queue/adapters/index.d.ts +9 -0
  220. package/dist/core/queue/adapters/index.js +10 -0
  221. package/dist/core/queue/adapters/index.js.map +1 -0
  222. package/dist/core/queue/adapters/kafka-adapter.d.ts +86 -0
  223. package/dist/core/queue/adapters/kafka-adapter.js +462 -0
  224. package/dist/core/queue/adapters/kafka-adapter.js.map +1 -0
  225. package/dist/core/queue/adapters/memory-adapter.d.ts +87 -0
  226. package/dist/core/queue/adapters/memory-adapter.js +415 -0
  227. package/dist/core/queue/adapters/memory-adapter.js.map +1 -0
  228. package/dist/core/queue/adapters/rabbitmq-adapter.d.ts +86 -0
  229. package/dist/core/queue/adapters/rabbitmq-adapter.js +436 -0
  230. package/dist/core/queue/adapters/rabbitmq-adapter.js.map +1 -0
  231. package/dist/core/queue/adapters/sqs-adapter.d.ts +102 -0
  232. package/dist/core/queue/adapters/sqs-adapter.js +522 -0
  233. package/dist/core/queue/adapters/sqs-adapter.js.map +1 -0
  234. package/dist/core/queue/index.d.ts +11 -0
  235. package/dist/core/queue/index.js +14 -0
  236. package/dist/core/queue/index.js.map +1 -0
  237. package/dist/core/queue/middleware/index.d.ts +7 -0
  238. package/dist/core/queue/middleware/index.js +8 -0
  239. package/dist/core/queue/middleware/index.js.map +1 -0
  240. package/dist/core/queue/middleware/monitoring.d.ts +84 -0
  241. package/dist/core/queue/middleware/monitoring.js +145 -0
  242. package/dist/core/queue/middleware/monitoring.js.map +1 -0
  243. package/dist/core/queue/middleware/priority.d.ts +61 -0
  244. package/dist/core/queue/middleware/priority.js +90 -0
  245. package/dist/core/queue/middleware/priority.js.map +1 -0
  246. package/dist/core/queue/middleware/rate-limit.d.ts +34 -0
  247. package/dist/core/queue/middleware/rate-limit.js +109 -0
  248. package/dist/core/queue/middleware/rate-limit.js.map +1 -0
  249. package/dist/core/queue/queue-adapter.d.ts +73 -0
  250. package/dist/core/queue/queue-adapter.js +20 -0
  251. package/dist/core/queue/queue-adapter.js.map +1 -0
  252. package/dist/core/queue/queue-manager.d.ts +92 -0
  253. package/dist/core/queue/queue-manager.js +327 -0
  254. package/dist/core/queue/queue-manager.js.map +1 -0
  255. package/dist/core/queue/types.d.ts +205 -0
  256. package/dist/core/queue/types.js +6 -0
  257. package/dist/core/queue/types.js.map +1 -0
  258. package/dist/core/routing/index.js +41 -10
  259. package/dist/core/routing/index.js.map +1 -1
  260. package/dist/core/routing/radix-tree.d.ts +48 -0
  261. package/dist/core/routing/radix-tree.js +211 -0
  262. package/dist/core/routing/radix-tree.js.map +1 -0
  263. package/dist/core/routing/router.d.ts +10 -9
  264. package/dist/core/routing/router.js +3 -1
  265. package/dist/core/routing/router.js.map +1 -1
  266. package/dist/core/routing/unified-router.d.ts +18 -12
  267. package/dist/core/routing/unified-router.js +220 -163
  268. package/dist/core/routing/unified-router.js.map +1 -1
  269. package/dist/core/runtime/aws-lambda-adapter.js +21 -10
  270. package/dist/core/runtime/aws-lambda-adapter.js.map +1 -1
  271. package/dist/core/runtime/base-adapter.js +15 -5
  272. package/dist/core/runtime/base-adapter.js.map +1 -1
  273. package/dist/core/runtime/cloudflare-workers-adapter.js +35 -12
  274. package/dist/core/runtime/cloudflare-workers-adapter.js.map +1 -1
  275. package/dist/core/runtime/vercel-edge-adapter.js +16 -6
  276. package/dist/core/runtime/vercel-edge-adapter.js.map +1 -1
  277. package/dist/core/utilities/container.js +3 -1
  278. package/dist/core/utilities/container.js.map +1 -1
  279. package/dist/core/workers/facade.d.ts +74 -0
  280. package/dist/core/workers/facade.js +98 -0
  281. package/dist/core/workers/facade.js.map +1 -0
  282. package/dist/core/workers/index.d.ts +2 -0
  283. package/dist/core/workers/index.js +6 -0
  284. package/dist/core/workers/index.js.map +1 -0
  285. package/dist/core/workers/worker-manager.d.ts +124 -0
  286. package/dist/core/workers/worker-manager.js +299 -0
  287. package/dist/core/workers/worker-manager.js.map +1 -0
  288. package/dist/core/workers/worker.d.ts +1 -0
  289. package/dist/core/workers/worker.js +225 -0
  290. package/dist/core/workers/worker.js.map +1 -0
  291. package/dist/index.d.ts +8 -1
  292. package/dist/index.js +6 -1
  293. package/dist/index.js.map +1 -1
  294. package/dist/moro.d.ts +345 -13
  295. package/dist/moro.js +803 -214
  296. package/dist/moro.js.map +1 -1
  297. package/dist/types/cache.d.ts +4 -0
  298. package/dist/types/config.d.ts +42 -0
  299. package/dist/types/core.d.ts +18 -1
  300. package/package.json +94 -20
@@ -0,0 +1,436 @@
1
+ /**
2
+ * RabbitMQ Queue Adapter
3
+ * Adapter for RabbitMQ/AMQP message broker
4
+ * Uses lazy loading for optional dependencies
5
+ */
6
+ import { QueueAdapter } from '../queue-adapter.js';
7
+ import { isPackageAvailable, resolveUserPackage } from '../../utilities/package-utils.js';
8
+ import { randomUUID } from 'crypto';
9
+ import { createFrameworkLogger } from '../../logger/index.js';
10
+ const logger = createFrameworkLogger('RabbitMQQueue');
11
+ /**
12
+ * RabbitMQ adapter for AMQP-based queues
13
+ * Suitable for complex routing and pub/sub patterns
14
+ */
15
+ export class RabbitMQAdapter extends QueueAdapter {
16
+ name = 'rabbitmq';
17
+ amqp = null;
18
+ connection = null;
19
+ channel = null;
20
+ connectionConfig;
21
+ processors = new Map();
22
+ jobStore = new Map();
23
+ consumerTags = new Map();
24
+ constructor(connectionConfig = {}) {
25
+ super();
26
+ this.connectionConfig = connectionConfig;
27
+ }
28
+ /**
29
+ * Initialize the RabbitMQ adapter
30
+ */
31
+ async initialize() {
32
+ if (this.isReady) {
33
+ return;
34
+ }
35
+ if (!isPackageAvailable('amqplib')) {
36
+ throw new Error('amqplib is not installed. Install it with: npm install amqplib');
37
+ }
38
+ try {
39
+ // Load amqplib
40
+ const amqpPath = resolveUserPackage('amqplib');
41
+ this.amqp = await import(amqpPath);
42
+ // Build connection URL
43
+ const host = this.connectionConfig.host || 'localhost';
44
+ const port = this.connectionConfig.port || 5672;
45
+ const username = this.connectionConfig.username || 'guest';
46
+ const password = this.connectionConfig.password || 'guest';
47
+ const url = `amqp://${username}:${password}@${host}:${port}`;
48
+ // Create connection and channel
49
+ this.connection = await this.amqp.connect(url);
50
+ this.channel = await this.connection.createChannel();
51
+ this.isReady = true;
52
+ }
53
+ catch (error) {
54
+ throw new Error(`Failed to initialize RabbitMQ adapter: ${error instanceof Error ? error.message : String(error)}`);
55
+ }
56
+ }
57
+ /**
58
+ * Ensure queue exists in RabbitMQ
59
+ */
60
+ async ensureQueueExists(queueName) {
61
+ if (!this.channel) {
62
+ throw new Error('Channel not initialized');
63
+ }
64
+ await this.channel.assertQueue(queueName, {
65
+ durable: true,
66
+ arguments: {},
67
+ });
68
+ if (!this.jobStore.has(queueName)) {
69
+ this.jobStore.set(queueName, new Map());
70
+ }
71
+ }
72
+ /**
73
+ * Add a job to the queue
74
+ */
75
+ async addJob(queueName, data, options = {}) {
76
+ this.ensureReady();
77
+ await this.ensureQueueExists(queueName);
78
+ const jobId = options.jobId || randomUUID();
79
+ const job = {
80
+ id: jobId,
81
+ name: queueName,
82
+ data,
83
+ options,
84
+ attemptsMade: 0,
85
+ timestamp: Date.now(),
86
+ progress: 0,
87
+ };
88
+ // Store job metadata
89
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
90
+ this.jobStore.get(queueName).set(jobId, job);
91
+ // Prepare message
92
+ const message = {
93
+ jobId,
94
+ data,
95
+ options,
96
+ timestamp: job.timestamp,
97
+ };
98
+ const messageBuffer = Buffer.from(JSON.stringify(message));
99
+ // Send to RabbitMQ with options
100
+ const sendOptions = {
101
+ persistent: true,
102
+ priority: options.priority || 0,
103
+ messageId: jobId,
104
+ };
105
+ if (options.delay && options.delay > 0) {
106
+ // Use dead letter exchange for delayed messages
107
+ const delayQueue = `${queueName}.delay`;
108
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
109
+ await this.channel.assertQueue(delayQueue, {
110
+ durable: true,
111
+ arguments: {
112
+ 'x-dead-letter-exchange': '',
113
+ 'x-dead-letter-routing-key': queueName,
114
+ 'x-message-ttl': options.delay,
115
+ },
116
+ });
117
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
118
+ this.channel.sendToQueue(delayQueue, messageBuffer, sendOptions);
119
+ }
120
+ else {
121
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
122
+ this.channel.sendToQueue(queueName, messageBuffer, sendOptions);
123
+ }
124
+ return {
125
+ id: job.id,
126
+ name: job.name,
127
+ data: job.data,
128
+ progress: job.progress,
129
+ attemptsMade: job.attemptsMade,
130
+ timestamp: job.timestamp,
131
+ opts: job.options,
132
+ };
133
+ }
134
+ /**
135
+ * Add multiple jobs in bulk
136
+ */
137
+ async addBulkJobs(queueName, jobs) {
138
+ this.ensureReady();
139
+ const addedJobs = [];
140
+ for (const jobData of jobs) {
141
+ const job = await this.addJob(queueName, jobData.data, jobData.options);
142
+ addedJobs.push(job);
143
+ }
144
+ return addedJobs;
145
+ }
146
+ /**
147
+ * Register a job processor
148
+ */
149
+ async process(queueName, concurrency, handler) {
150
+ this.ensureReady();
151
+ await this.ensureQueueExists(queueName);
152
+ this.processors.set(queueName, handler);
153
+ // Set prefetch count (concurrency)
154
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
155
+ await this.channel.prefetch(concurrency);
156
+ // Start consuming messages
157
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
158
+ const consumer = await this.channel.consume(queueName, async (msg) => {
159
+ if (!msg) {
160
+ return;
161
+ }
162
+ try {
163
+ const message = JSON.parse(msg.content.toString());
164
+ const { jobId, data, options } = message;
165
+ const storedJob = this.jobStore.get(queueName)?.get(jobId);
166
+ if (!storedJob) {
167
+ // Job not found, acknowledge and skip
168
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
169
+ this.channel.ack(msg);
170
+ return;
171
+ }
172
+ storedJob.processedOn = Date.now();
173
+ // Create job context
174
+ const jobContext = {
175
+ id: jobId,
176
+ name: queueName,
177
+ data,
178
+ progress: storedJob.progress,
179
+ attemptsMade: storedJob.attemptsMade,
180
+ timestamp: storedJob.timestamp,
181
+ processedOn: storedJob.processedOn,
182
+ finishedOn: storedJob.finishedOn,
183
+ failedReason: storedJob.failedReason,
184
+ opts: options,
185
+ updateProgress: async (progress) => {
186
+ storedJob.progress = progress;
187
+ },
188
+ log: (message) => {
189
+ logger.debug(`[Job ${jobId}] ${message}`);
190
+ },
191
+ };
192
+ // Execute handler
193
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
194
+ const result = await handler(jobContext);
195
+ // Mark as completed
196
+ storedJob.finishedOn = Date.now();
197
+ storedJob.progress = 100;
198
+ // Acknowledge message
199
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
200
+ this.channel.ack(msg);
201
+ // Auto-remove if configured
202
+ if (options.removeOnComplete) {
203
+ setTimeout(() => {
204
+ this.jobStore.get(queueName)?.delete(jobId);
205
+ }, typeof options.removeOnComplete === 'number' ? options.removeOnComplete : 0);
206
+ }
207
+ }
208
+ catch (error) {
209
+ const message = JSON.parse(msg.content.toString());
210
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
211
+ const { jobId, data, options } = message;
212
+ const storedJob = this.jobStore.get(queueName)?.get(jobId);
213
+ if (storedJob) {
214
+ storedJob.attemptsMade++;
215
+ storedJob.failedReason = error instanceof Error ? error.message : String(error);
216
+ storedJob.finishedOn = Date.now();
217
+ // Check if we should retry
218
+ const maxAttempts = options.attempts || 1;
219
+ if (storedJob.attemptsMade < maxAttempts) {
220
+ // Reject and requeue
221
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
222
+ this.channel.nack(msg, false, true);
223
+ }
224
+ else {
225
+ // Max attempts reached, move to DLQ or acknowledge
226
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
227
+ this.channel.ack(msg);
228
+ // Auto-remove if configured
229
+ if (options.removeOnFail) {
230
+ setTimeout(() => {
231
+ this.jobStore.get(queueName)?.delete(jobId);
232
+ }, typeof options.removeOnFail === 'number' ? options.removeOnFail : 0);
233
+ }
234
+ }
235
+ }
236
+ else {
237
+ // Job not found, acknowledge
238
+ // eslint-disable-next-line @typescript-eslint/no-non-null-assertion
239
+ this.channel.ack(msg);
240
+ }
241
+ }
242
+ }, { noAck: false });
243
+ this.consumerTags.set(queueName, consumer.consumerTag);
244
+ }
245
+ /**
246
+ * Get a job by ID
247
+ */
248
+ async getJob(queueName, jobId) {
249
+ this.ensureReady();
250
+ const storedJob = this.jobStore.get(queueName)?.get(jobId);
251
+ if (!storedJob) {
252
+ return null;
253
+ }
254
+ return {
255
+ id: storedJob.id,
256
+ name: storedJob.name,
257
+ data: storedJob.data,
258
+ progress: storedJob.progress,
259
+ attemptsMade: storedJob.attemptsMade,
260
+ timestamp: storedJob.timestamp,
261
+ processedOn: storedJob.processedOn,
262
+ finishedOn: storedJob.finishedOn,
263
+ failedReason: storedJob.failedReason,
264
+ opts: storedJob.options,
265
+ };
266
+ }
267
+ /**
268
+ * Get jobs by status
269
+ */
270
+ async getJobs(queueName, status, start = 0, end = -1) {
271
+ this.ensureReady();
272
+ const jobs = Array.from(this.jobStore.get(queueName)?.values() || []);
273
+ // Filter by status if provided
274
+ const filteredJobs = status ? jobs.filter(job => this.getJobStatus(job) === status) : jobs;
275
+ // Apply pagination
276
+ const endIndex = end === -1 ? filteredJobs.length : end + 1;
277
+ return filteredJobs.slice(start, endIndex).map(job => ({
278
+ id: job.id,
279
+ name: job.name,
280
+ data: job.data,
281
+ progress: job.progress,
282
+ attemptsMade: job.attemptsMade,
283
+ timestamp: job.timestamp,
284
+ processedOn: job.processedOn,
285
+ finishedOn: job.finishedOn,
286
+ failedReason: job.failedReason,
287
+ opts: job.options,
288
+ }));
289
+ }
290
+ /**
291
+ * Remove a job
292
+ */
293
+ async removeJob(queueName, jobId) {
294
+ this.ensureReady();
295
+ this.jobStore.get(queueName)?.delete(jobId);
296
+ }
297
+ /**
298
+ * Retry a failed job
299
+ */
300
+ async retryJob(queueName, jobId) {
301
+ this.ensureReady();
302
+ const storedJob = this.jobStore.get(queueName)?.get(jobId);
303
+ if (!storedJob) {
304
+ return;
305
+ }
306
+ // Reset job state
307
+ storedJob.failedReason = undefined;
308
+ storedJob.processedOn = undefined;
309
+ storedJob.finishedOn = undefined;
310
+ storedJob.progress = 0;
311
+ // Re-add to queue
312
+ await this.addJob(queueName, storedJob.data, storedJob.options);
313
+ }
314
+ /**
315
+ * Pause the queue
316
+ */
317
+ async pauseQueue(queueName) {
318
+ this.ensureReady();
319
+ const consumerTag = this.consumerTags.get(queueName);
320
+ if (consumerTag && this.channel) {
321
+ await this.channel.cancel(consumerTag);
322
+ this.consumerTags.delete(queueName);
323
+ }
324
+ }
325
+ /**
326
+ * Resume the queue
327
+ */
328
+ async resumeQueue(queueName) {
329
+ this.ensureReady();
330
+ // Restart consuming
331
+ const handler = this.processors.get(queueName);
332
+ if (handler) {
333
+ await this.process(queueName, 1, handler);
334
+ }
335
+ }
336
+ /**
337
+ * Get queue metrics
338
+ */
339
+ async getMetrics(queueName) {
340
+ this.ensureReady();
341
+ const jobs = Array.from(this.jobStore.get(queueName)?.values() || []);
342
+ const metrics = {
343
+ waiting: 0,
344
+ active: 0,
345
+ completed: 0,
346
+ failed: 0,
347
+ delayed: 0,
348
+ paused: 0,
349
+ };
350
+ for (const job of jobs) {
351
+ const status = this.getJobStatus(job);
352
+ if (status in metrics) {
353
+ metrics[status]++;
354
+ }
355
+ }
356
+ return metrics;
357
+ }
358
+ /**
359
+ * Clean old jobs
360
+ */
361
+ async clean(queueName, gracePeriod, status) {
362
+ this.ensureReady();
363
+ const jobs = this.jobStore.get(queueName);
364
+ if (!jobs) {
365
+ return;
366
+ }
367
+ const cutoff = Date.now() - gracePeriod;
368
+ const jobsToRemove = [];
369
+ for (const [jobId, job] of jobs.entries()) {
370
+ const jobStatus = this.getJobStatus(job);
371
+ const shouldClean = !status || jobStatus === status;
372
+ if (shouldClean && job.finishedOn && job.finishedOn < cutoff) {
373
+ jobsToRemove.push(jobId);
374
+ }
375
+ }
376
+ for (const jobId of jobsToRemove) {
377
+ jobs.delete(jobId);
378
+ }
379
+ }
380
+ /**
381
+ * Obliterate a queue
382
+ */
383
+ async obliterate(queueName) {
384
+ this.ensureReady();
385
+ // Cancel consumer
386
+ await this.pauseQueue(queueName);
387
+ // Delete queue from RabbitMQ
388
+ if (this.channel) {
389
+ await this.channel.deleteQueue(queueName);
390
+ }
391
+ // Clear job store
392
+ this.jobStore.delete(queueName);
393
+ this.processors.delete(queueName);
394
+ }
395
+ /**
396
+ * Close the adapter
397
+ */
398
+ async close() {
399
+ // Cancel all consumers
400
+ for (const queueName of this.consumerTags.keys()) {
401
+ await this.pauseQueue(queueName);
402
+ }
403
+ // Close channel
404
+ if (this.channel) {
405
+ await this.channel.close();
406
+ this.channel = null;
407
+ }
408
+ // Close connection
409
+ if (this.connection) {
410
+ await this.connection.close();
411
+ this.connection = null;
412
+ }
413
+ this.jobStore.clear();
414
+ this.processors.clear();
415
+ this.isReady = false;
416
+ }
417
+ /**
418
+ * Get job status
419
+ */
420
+ getJobStatus(job) {
421
+ if (job.failedReason) {
422
+ return 'failed';
423
+ }
424
+ if (job.finishedOn) {
425
+ return 'completed';
426
+ }
427
+ if (job.processedOn) {
428
+ return 'active';
429
+ }
430
+ if (job.options.delay && job.options.delay > 0) {
431
+ return 'delayed';
432
+ }
433
+ return 'waiting';
434
+ }
435
+ }
436
+ //# sourceMappingURL=rabbitmq-adapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"rabbitmq-adapter.js","sourceRoot":"","sources":["../../../../src/core/queue/adapters/rabbitmq-adapter.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AAWnD,OAAO,EAAE,kBAAkB,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;AAC1F,OAAO,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AACpC,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAE9D,MAAM,MAAM,GAAG,qBAAqB,CAAC,eAAe,CAAC,CAAC;AAwBtD;;;GAGG;AACH,MAAM,OAAO,eAAgB,SAAQ,YAAY;IACxC,IAAI,GAAG,UAAU,CAAC;IAEjB,IAAI,GAAQ,IAAI,CAAC;IACjB,UAAU,GAA0B,IAAI,CAAC;IACzC,OAAO,GAAuB,IAAI,CAAC;IACnC,gBAAgB,CAAwB;IACxC,UAAU,GAAsC,IAAI,GAAG,EAAE,CAAC;IAC1D,QAAQ,GAAwC,IAAI,GAAG,EAAE,CAAC;IAC1D,YAAY,GAAwB,IAAI,GAAG,EAAE,CAAC;IAEtD,YAAY,mBAA0C,EAAE;QACtD,KAAK,EAAE,CAAC;QACR,IAAI,CAAC,gBAAgB,GAAG,gBAAgB,CAAC;IAC3C,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU;QACd,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,OAAO;QACT,CAAC;QAED,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,EAAE,CAAC;YACnC,MAAM,IAAI,KAAK,CAAC,gEAAgE,CAAC,CAAC;QACpF,CAAC;QAED,IAAI,CAAC;YACH,eAAe;YACf,MAAM,QAAQ,GAAG,kBAAkB,CAAC,SAAS,CAAC,CAAC;YAC/C,IAAI,CAAC,IAAI,GAAG,MAAM,MAAM,CAAC,QAAQ,CAAC,CAAC;YAEnC,uBAAuB;YACvB,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,IAAI,WAAW,CAAC;YACvD,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,IAAI,IAAI,CAAC;YAChD,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,IAAI,OAAO,CAAC;YAC3D,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,IAAI,OAAO,CAAC;YAC3D,MAAM,GAAG,GAAG,UAAU,QAAQ,IAAI,QAAQ,IAAI,IAAI,IAAI,IAAI,EAAE,CAAC;YAE7D,gCAAgC;YAChC,IAAI,CAAC,UAAU,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;YAC/C,IAAI,CAAC,OAAO,GAAG,MAAM,IAAI,CAAC,UAAU,CAAC,aAAa,EAAE,CAAC;YAErD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CACb,0CAA0C,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CACnG,CAAC;QACJ,CAAC;IACH,CAAC;IAED;;OAEG;IACK,KAAK,CAAC,iBAAiB,CAAC,SAAiB;QAC/C,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAClB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;QAC7C,CAAC;QAED,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,EAAE;YACxC,OAAO,EAAE,IAAI;YACb,SAAS,EAAE,EAAE;SACd,CAAC,CAAC;QAEH,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YAClC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,GAAG,EAAE,CAAC,CAAC;QAC1C,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,MAAM,CAAU,SAAiB,EAAE,IAAO,EAAE,UAAsB,EAAE;QACxE,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;QAExC,MAAM,KAAK,GAAG,OAAO,CAAC,KAAK,IAAI,UAAU,EAAE,CAAC;QAC5C,MAAM,GAAG,GAAc;YACrB,EAAE,EAAE,KAAK;YACT,IAAI,EAAE,SAAS;YACf,IAAI;YACJ,OAAO;YACP,YAAY,EAAE,CAAC;YACf,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE;YACrB,QAAQ,EAAE,CAAC;SACZ,CAAC;QAEF,qBAAqB;QACrB,oEAAoE;QACpE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAE,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QAE9C,kBAAkB;QAClB,MAAM,OAAO,GAAG;YACd,KAAK;YACL,IAAI;YACJ,OAAO;YACP,SAAS,EAAE,GAAG,CAAC,SAAS;SACzB,CAAC;QAEF,MAAM,aAAa,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,CAAC;QAE3D,gCAAgC;QAChC,MAAM,WAAW,GAAQ;YACvB,UAAU,EAAE,IAAI;YAChB,QAAQ,EAAE,OAAO,CAAC,QAAQ,IAAI,CAAC;YAC/B,SAAS,EAAE,KAAK;SACjB,CAAC;QAEF,IAAI,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;YACvC,gDAAgD;YAChD,MAAM,UAAU,GAAG,GAAG,SAAS,QAAQ,CAAC;YACxC,oEAAoE;YACpE,MAAM,IAAI,CAAC,OAAQ,CAAC,WAAW,CAAC,UAAU,EAAE;gBAC1C,OAAO,EAAE,IAAI;gBACb,SAAS,EAAE;oBACT,wBAAwB,EAAE,EAAE;oBAC5B,2BAA2B,EAAE,SAAS;oBACtC,eAAe,EAAE,OAAO,CAAC,KAAK;iBAC/B;aACF,CAAC,CAAC;YACH,oEAAoE;YACpE,IAAI,CAAC,OAAQ,CAAC,WAAW,CAAC,UAAU,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;QACpE,CAAC;aAAM,CAAC;YACN,oEAAoE;YACpE,IAAI,CAAC,OAAQ,CAAC,WAAW,CAAC,SAAS,EAAE,aAAa,EAAE,WAAW,CAAC,CAAC;QACnE,CAAC;QAED,OAAO;YACL,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,YAAY,EAAE,GAAG,CAAC,YAAY;YAC9B,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,IAAI,EAAE,GAAG,CAAC,OAAO;SAClB,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,WAAW,CAAU,SAAiB,EAAE,IAAsB;QAClE,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,SAAS,GAAa,EAAE,CAAC;QAC/B,KAAK,MAAM,OAAO,IAAI,IAAI,EAAE,CAAC;YAC3B,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC;YACxE,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtB,CAAC;QAED,OAAO,SAAS,CAAC;IACnB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO,CACX,SAAiB,EACjB,WAAmB,EACnB,OAAyB;QAEzB,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,MAAM,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;QAExC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QAExC,mCAAmC;QACnC,oEAAoE;QACpE,MAAM,IAAI,CAAC,OAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QAE1C,2BAA2B;QAC3B,oEAAoE;QACpE,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,OAAQ,CAAC,OAAO,CAC1C,SAAS,EACT,KAAK,EAAE,GAAQ,EAAE,EAAE;YACjB,IAAI,CAAC,GAAG,EAAE,CAAC;gBACT,OAAO;YACT,CAAC;YAED,IAAI,CAAC;gBACH,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;gBACnD,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;gBAEzC,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;gBAC3D,IAAI,CAAC,SAAS,EAAE,CAAC;oBACf,sCAAsC;oBACtC,oEAAoE;oBACpE,IAAI,CAAC,OAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;oBACvB,OAAO;gBACT,CAAC;gBAED,SAAS,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBAEnC,qBAAqB;gBACrB,MAAM,UAAU,GAAkB;oBAChC,EAAE,EAAE,KAAK;oBACT,IAAI,EAAE,SAAS;oBACf,IAAI;oBACJ,QAAQ,EAAE,SAAS,CAAC,QAAQ;oBAC5B,YAAY,EAAE,SAAS,CAAC,YAAY;oBACpC,SAAS,EAAE,SAAS,CAAC,SAAS;oBAC9B,WAAW,EAAE,SAAS,CAAC,WAAW;oBAClC,UAAU,EAAE,SAAS,CAAC,UAAU;oBAChC,YAAY,EAAE,SAAS,CAAC,YAAY;oBACpC,IAAI,EAAE,OAAO;oBACb,cAAc,EAAE,KAAK,EAAE,QAAgB,EAAE,EAAE;wBACzC,SAAS,CAAC,QAAQ,GAAG,QAAQ,CAAC;oBAChC,CAAC;oBACD,GAAG,EAAE,CAAC,OAAe,EAAE,EAAE;wBACvB,MAAM,CAAC,KAAK,CAAC,QAAQ,KAAK,KAAK,OAAO,EAAE,CAAC,CAAC;oBAC5C,CAAC;iBACF,CAAC;gBAEF,kBAAkB;gBAClB,6DAA6D;gBAC7D,MAAM,MAAM,GAAG,MAAM,OAAO,CAAC,UAAU,CAAC,CAAC;gBAEzC,oBAAoB;gBACpB,SAAS,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;gBAClC,SAAS,CAAC,QAAQ,GAAG,GAAG,CAAC;gBAEzB,sBAAsB;gBACtB,oEAAoE;gBACpE,IAAI,CAAC,OAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBAEvB,4BAA4B;gBAC5B,IAAI,OAAO,CAAC,gBAAgB,EAAE,CAAC;oBAC7B,UAAU,CACR,GAAG,EAAE;wBACH,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;oBAC9C,CAAC,EACD,OAAO,OAAO,CAAC,gBAAgB,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAC5E,CAAC;gBACJ,CAAC;YACH,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,OAAO,CAAC,QAAQ,EAAE,CAAC,CAAC;gBACnD,6DAA6D;gBAC7D,MAAM,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,OAAO,CAAC;gBAEzC,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;gBAC3D,IAAI,SAAS,EAAE,CAAC;oBACd,SAAS,CAAC,YAAY,EAAE,CAAC;oBACzB,SAAS,CAAC,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;oBAChF,SAAS,CAAC,UAAU,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;oBAElC,2BAA2B;oBAC3B,MAAM,WAAW,GAAG,OAAO,CAAC,QAAQ,IAAI,CAAC,CAAC;oBAC1C,IAAI,SAAS,CAAC,YAAY,GAAG,WAAW,EAAE,CAAC;wBACzC,qBAAqB;wBACrB,oEAAoE;wBACpE,IAAI,CAAC,OAAQ,CAAC,IAAI,CAAC,GAAG,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;oBACvC,CAAC;yBAAM,CAAC;wBACN,mDAAmD;wBACnD,oEAAoE;wBACpE,IAAI,CAAC,OAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;wBAEvB,4BAA4B;wBAC5B,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;4BACzB,UAAU,CACR,GAAG,EAAE;gCACH,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;4BAC9C,CAAC,EACD,OAAO,OAAO,CAAC,YAAY,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CACpE,CAAC;wBACJ,CAAC;oBACH,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,6BAA6B;oBAC7B,oEAAoE;oBACpE,IAAI,CAAC,OAAQ,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;gBACzB,CAAC;YACH,CAAC;QACH,CAAC,EACD,EAAE,KAAK,EAAE,KAAK,EAAE,CACjB,CAAC;QAEF,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,EAAE,QAAQ,CAAC,WAAW,CAAC,CAAC;IACzD,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,MAAM,CAAC,SAAiB,EAAE,KAAa;QAC3C,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;QAC3D,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO;YACL,EAAE,EAAE,SAAS,CAAC,EAAE;YAChB,IAAI,EAAE,SAAS,CAAC,IAAI;YACpB,IAAI,EAAE,SAAS,CAAC,IAAI;YACpB,QAAQ,EAAE,SAAS,CAAC,QAAQ;YAC5B,YAAY,EAAE,SAAS,CAAC,YAAY;YACpC,SAAS,EAAE,SAAS,CAAC,SAAS;YAC9B,WAAW,EAAE,SAAS,CAAC,WAAW;YAClC,UAAU,EAAE,SAAS,CAAC,UAAU;YAChC,YAAY,EAAE,SAAS,CAAC,YAAY;YACpC,IAAI,EAAE,SAAS,CAAC,OAAO;SACxB,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO,CACX,SAAiB,EACjB,MAAkB,EAClB,QAAgB,CAAC,EACjB,MAAc,CAAC,CAAC;QAEhB,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QAEtE,+BAA+B;QAC/B,MAAM,YAAY,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAE3F,mBAAmB;QACnB,MAAM,QAAQ,GAAG,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;QAC5D,OAAO,YAAY,CAAC,KAAK,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACrD,EAAE,EAAE,GAAG,CAAC,EAAE;YACV,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,IAAI,EAAE,GAAG,CAAC,IAAI;YACd,QAAQ,EAAE,GAAG,CAAC,QAAQ;YACtB,YAAY,EAAE,GAAG,CAAC,YAAY;YAC9B,SAAS,EAAE,GAAG,CAAC,SAAS;YACxB,WAAW,EAAE,GAAG,CAAC,WAAW;YAC5B,UAAU,EAAE,GAAG,CAAC,UAAU;YAC1B,YAAY,EAAE,GAAG,CAAC,YAAY;YAC9B,IAAI,EAAE,GAAG,CAAC,OAAO;SAClB,CAAC,CAAC,CAAC;IACN,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,SAAS,CAAC,SAAiB,EAAE,KAAa;QAC9C,IAAI,CAAC,WAAW,EAAE,CAAC;QACnB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,QAAQ,CAAC,SAAiB,EAAE,KAAa;QAC7C,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,GAAG,CAAC,KAAK,CAAC,CAAC;QAC3D,IAAI,CAAC,SAAS,EAAE,CAAC;YACf,OAAO;QACT,CAAC;QAED,kBAAkB;QAClB,SAAS,CAAC,YAAY,GAAG,SAAS,CAAC;QACnC,SAAS,CAAC,WAAW,GAAG,SAAS,CAAC;QAClC,SAAS,CAAC,UAAU,GAAG,SAAS,CAAC;QACjC,SAAS,CAAC,QAAQ,GAAG,CAAC,CAAC;QAEvB,kBAAkB;QAClB,MAAM,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC;IAClE,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,SAAiB;QAChC,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,WAAW,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QACrD,IAAI,WAAW,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YAChC,MAAM,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC,CAAC;YACvC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACtC,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,WAAW,CAAC,SAAiB;QACjC,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,oBAAoB;QACpB,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/C,IAAI,OAAO,EAAE,CAAC;YACZ,MAAM,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,EAAE,OAAO,CAAC,CAAC;QAC5C,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,SAAiB;QAChC,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QAEtE,MAAM,OAAO,GAAiB;YAC5B,OAAO,EAAE,CAAC;YACV,MAAM,EAAE,CAAC;YACT,SAAS,EAAE,CAAC;YACZ,MAAM,EAAE,CAAC;YACT,OAAO,EAAE,CAAC;YACV,MAAM,EAAE,CAAC;SACV,CAAC;QAEF,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;YACtC,IAAI,MAAM,IAAI,OAAO,EAAE,CAAC;gBACtB,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YACpB,CAAC;QACH,CAAC;QAED,OAAO,OAAO,CAAC;IACjB,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK,CAAC,SAAiB,EAAE,WAAmB,EAAE,MAAkB;QACpE,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC1C,IAAI,CAAC,IAAI,EAAE,CAAC;YACV,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,WAAW,CAAC;QACxC,MAAM,YAAY,GAAa,EAAE,CAAC;QAElC,KAAK,MAAM,CAAC,KAAK,EAAE,GAAG,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YAC1C,MAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC;YACzC,MAAM,WAAW,GAAG,CAAC,MAAM,IAAI,SAAS,KAAK,MAAM,CAAC;YAEpD,IAAI,WAAW,IAAI,GAAG,CAAC,UAAU,IAAI,GAAG,CAAC,UAAU,GAAG,MAAM,EAAE,CAAC;gBAC7D,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC3B,CAAC;QACH,CAAC;QAED,KAAK,MAAM,KAAK,IAAI,YAAY,EAAE,CAAC;YACjC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,UAAU,CAAC,SAAiB;QAChC,IAAI,CAAC,WAAW,EAAE,CAAC;QAEnB,kBAAkB;QAClB,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QAEjC,6BAA6B;QAC7B,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC;QAC5C,CAAC;QAED,kBAAkB;QAClB,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QAChC,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;IACpC,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,KAAK;QACT,uBAAuB;QACvB,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,EAAE,CAAC;YACjD,MAAM,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QACnC,CAAC;QAED,gBAAgB;QAChB,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;YACjB,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAC3B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACtB,CAAC;QAED,mBAAmB;QACnB,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;YAC9B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACzB,CAAC;QAED,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,CAAC;QACxB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;IAED;;OAEG;IACK,YAAY,CAAC,GAAc;QACjC,IAAI,GAAG,CAAC,YAAY,EAAE,CAAC;YACrB,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,IAAI,GAAG,CAAC,UAAU,EAAE,CAAC;YACnB,OAAO,WAAW,CAAC;QACrB,CAAC;QACD,IAAI,GAAG,CAAC,WAAW,EAAE,CAAC;YACpB,OAAO,QAAQ,CAAC;QAClB,CAAC;QACD,IAAI,GAAG,CAAC,OAAO,CAAC,KAAK,IAAI,GAAG,CAAC,OAAO,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;YAC/C,OAAO,SAAS,CAAC;QACnB,CAAC;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;CACF"}
@@ -0,0 +1,102 @@
1
+ /**
2
+ * AWS SQS Queue Adapter
3
+ * Adapter for AWS Simple Queue Service
4
+ * Uses lazy loading for optional dependencies
5
+ */
6
+ import { QueueAdapter } from '../queue-adapter.js';
7
+ import type { Job, JobOptions, JobHandler, JobStatus, QueueMetrics, BulkJobData, QueueConnectionConfig } from '../types.js';
8
+ /**
9
+ * AWS SQS adapter for cloud-native queues
10
+ * Suitable for AWS-based applications
11
+ */
12
+ export declare class SQSAdapter extends QueueAdapter {
13
+ name: string;
14
+ private SQSClient;
15
+ private SendMessageCommand;
16
+ private SendMessageBatchCommand;
17
+ private ReceiveMessageCommand;
18
+ private DeleteMessageCommand;
19
+ private client;
20
+ private connectionConfig;
21
+ private processors;
22
+ private jobStore;
23
+ private pollingIntervals;
24
+ private queueUrls;
25
+ constructor(connectionConfig?: QueueConnectionConfig);
26
+ /**
27
+ * Initialize the SQS adapter
28
+ */
29
+ initialize(): Promise<void>;
30
+ /**
31
+ * Get or set queue URL
32
+ */
33
+ private getQueueUrl;
34
+ /**
35
+ * Ensure job store exists
36
+ */
37
+ private ensureJobStore;
38
+ /**
39
+ * Add a job to the queue
40
+ */
41
+ addJob<T = any>(queueName: string, data: T, options?: JobOptions): Promise<Job<T>>;
42
+ /**
43
+ * Add multiple jobs in bulk
44
+ */
45
+ addBulkJobs<T = any>(queueName: string, jobs: BulkJobData<T>[]): Promise<Job<T>[]>;
46
+ /**
47
+ * Register a job processor
48
+ */
49
+ process<T = any, R = any>(queueName: string, concurrency: number, handler: JobHandler<T, R>): Promise<void>;
50
+ /**
51
+ * Get a job by ID
52
+ */
53
+ getJob(queueName: string, jobId: string): Promise<Job | null>;
54
+ /**
55
+ * Get jobs by status
56
+ */
57
+ getJobs(queueName: string, status?: JobStatus, start?: number, end?: number): Promise<Job[]>;
58
+ /**
59
+ * Remove a job
60
+ */
61
+ removeJob(queueName: string, jobId: string): Promise<void>;
62
+ /**
63
+ * Retry a failed job
64
+ */
65
+ retryJob(queueName: string, jobId: string): Promise<void>;
66
+ /**
67
+ * Pause the queue
68
+ */
69
+ pauseQueue(queueName: string): Promise<void>;
70
+ /**
71
+ * Resume the queue
72
+ */
73
+ resumeQueue(queueName: string): Promise<void>;
74
+ /**
75
+ * Get queue metrics
76
+ */
77
+ getMetrics(queueName: string): Promise<QueueMetrics>;
78
+ /**
79
+ * Clean old jobs
80
+ */
81
+ clean(queueName: string, gracePeriod: number, status?: JobStatus): Promise<void>;
82
+ /**
83
+ * Obliterate a queue
84
+ */
85
+ obliterate(queueName: string): Promise<void>;
86
+ /**
87
+ * Close the adapter
88
+ */
89
+ close(): Promise<void>;
90
+ /**
91
+ * Start polling for messages
92
+ */
93
+ private startPolling;
94
+ /**
95
+ * Process a single message
96
+ */
97
+ private processMessage;
98
+ /**
99
+ * Get job status
100
+ */
101
+ private getJobStatus;
102
+ }