@ductape/sdk 0.0.4 → 0.0.6

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 (952) hide show
  1. package/README.md +87 -53
  2. package/dist/agents/agent-context.d.ts +100 -0
  3. package/dist/agents/agent-context.js +604 -0
  4. package/dist/agents/agent-context.js.map +1 -0
  5. package/dist/agents/agent-executor.d.ts +180 -0
  6. package/dist/agents/agent-executor.js +715 -0
  7. package/dist/agents/agent-executor.js.map +1 -0
  8. package/dist/agents/agents.service.d.ts +310 -0
  9. package/dist/agents/agents.service.js +1253 -0
  10. package/dist/agents/agents.service.js.map +1 -0
  11. package/dist/agents/index.d.ts +55 -0
  12. package/dist/agents/index.js +110 -0
  13. package/dist/agents/index.js.map +1 -0
  14. package/dist/agents/memory-manager.d.ts +182 -0
  15. package/dist/agents/memory-manager.js +383 -0
  16. package/dist/agents/memory-manager.js.map +1 -0
  17. package/dist/agents/tool-registry.d.ts +141 -0
  18. package/dist/agents/tool-registry.js +355 -0
  19. package/dist/agents/tool-registry.js.map +1 -0
  20. package/dist/agents/types/agents.types.d.ts +1240 -0
  21. package/dist/agents/types/agents.types.js +12 -0
  22. package/dist/agents/types/agents.types.js.map +1 -0
  23. package/dist/agents/types/index.d.ts +6 -0
  24. package/dist/agents/types/index.js +23 -0
  25. package/dist/agents/types/index.js.map +1 -0
  26. package/dist/agents/vector-store-adapter.d.ts +108 -0
  27. package/dist/agents/vector-store-adapter.js +213 -0
  28. package/dist/agents/vector-store-adapter.js.map +1 -0
  29. package/dist/api/services/appApi.service.d.ts +51 -5
  30. package/dist/api/services/appApi.service.js +116 -9
  31. package/dist/api/services/appApi.service.js.map +1 -1
  32. package/dist/api/services/logsApi.service.d.ts +51 -0
  33. package/dist/api/services/logsApi.service.js +19 -2
  34. package/dist/api/services/logsApi.service.js.map +1 -1
  35. package/dist/api/services/pricingApi.service.d.ts +10 -0
  36. package/dist/api/services/pricingApi.service.js +34 -0
  37. package/dist/api/services/pricingApi.service.js.map +1 -0
  38. package/dist/api/services/processorApi.service.d.ts +900 -2
  39. package/dist/api/services/processorApi.service.js +665 -12
  40. package/dist/api/services/processorApi.service.js.map +1 -1
  41. package/dist/api/services/productsApi.service.d.ts +130 -1
  42. package/dist/api/services/productsApi.service.js +198 -11
  43. package/dist/api/services/productsApi.service.js.map +1 -1
  44. package/dist/api/services/resilienceApi.service.d.ts +106 -0
  45. package/dist/api/services/resilienceApi.service.js +224 -0
  46. package/dist/api/services/resilienceApi.service.js.map +1 -0
  47. package/dist/api/services/secretsApi.service.d.ts +50 -0
  48. package/dist/api/services/secretsApi.service.js +113 -0
  49. package/dist/api/services/secretsApi.service.js.map +1 -0
  50. package/dist/api/services/webhooksApi.service.js +13 -6
  51. package/dist/api/services/webhooksApi.service.js.map +1 -1
  52. package/dist/api/services/workflowApi.service.d.ts +199 -0
  53. package/dist/api/services/workflowApi.service.js +201 -0
  54. package/dist/api/services/workflowApi.service.js.map +1 -0
  55. package/dist/api/services/workspaceApi.service.d.ts +8 -0
  56. package/dist/api/services/workspaceApi.service.js +20 -0
  57. package/dist/api/services/workspaceApi.service.js.map +1 -1
  58. package/dist/api/urls.d.ts +92 -1
  59. package/dist/api/urls.js +118 -18
  60. package/dist/api/urls.js.map +1 -1
  61. package/dist/api/utils/auth.utils.d.ts +1 -3
  62. package/dist/api/utils/auth.utils.js.map +1 -1
  63. package/dist/api/utils/cache.utils.d.ts +1 -1
  64. package/dist/api/utils/cache.utils.js +2 -2
  65. package/dist/api/utils/cache.utils.js.map +1 -1
  66. package/dist/api/utils/strings.utils.d.ts +2 -0
  67. package/dist/api/utils/strings.utils.js +14 -0
  68. package/dist/api/utils/strings.utils.js.map +1 -1
  69. package/dist/apps/services/app.service.d.ts +42 -33
  70. package/dist/apps/services/app.service.js +574 -223
  71. package/dist/apps/services/app.service.js.map +1 -1
  72. package/dist/apps/utils/auth-context-manager.d.ts +137 -0
  73. package/dist/apps/utils/auth-context-manager.js +248 -0
  74. package/dist/apps/utils/auth-context-manager.js.map +1 -0
  75. package/dist/apps/utils/credential-manager.d.ts +128 -0
  76. package/dist/apps/utils/credential-manager.js +199 -0
  77. package/dist/apps/utils/credential-manager.js.map +1 -0
  78. package/dist/apps/utils/index.d.ts +10 -0
  79. package/dist/apps/utils/index.js +54 -0
  80. package/dist/apps/utils/index.js.map +1 -0
  81. package/dist/apps/utils/input-helpers.d.ts +67 -0
  82. package/dist/apps/utils/input-helpers.js +185 -0
  83. package/dist/apps/utils/input-helpers.js.map +1 -0
  84. package/dist/apps/utils/input-resolver.d.ts +165 -0
  85. package/dist/apps/utils/input-resolver.js +477 -0
  86. package/dist/apps/utils/input-resolver.js.map +1 -0
  87. package/dist/apps/utils/oauth-manager.d.ts +196 -0
  88. package/dist/apps/utils/oauth-manager.js +429 -0
  89. package/dist/apps/utils/oauth-manager.js.map +1 -0
  90. package/dist/apps/validators/joi-validators/create.appAction.validator.d.ts +1 -2
  91. package/dist/apps/validators/joi-validators/create.appAction.validator.js +22 -2
  92. package/dist/apps/validators/joi-validators/create.appAction.validator.js.map +1 -1
  93. package/dist/apps/validators/joi-validators/update.app.validator.js +2 -0
  94. package/dist/apps/validators/joi-validators/update.app.validator.js.map +1 -1
  95. package/dist/apps/validators/joi-validators/update.appAction.validator.js +23 -2
  96. package/dist/apps/validators/joi-validators/update.appAction.validator.js.map +1 -1
  97. package/dist/apps/validators/joi-validators/update.appActionResponse.validator.d.ts +1 -1
  98. package/dist/apps/validators/joi-validators/update.appActionResponse.validator.js +34 -1
  99. package/dist/apps/validators/joi-validators/update.appActionResponse.validator.js.map +1 -1
  100. package/dist/bin.d.ts +26 -0
  101. package/dist/bin.js +28 -0
  102. package/dist/bin.js.map +1 -0
  103. package/dist/brokers/brokers.service.d.ts +435 -0
  104. package/dist/brokers/brokers.service.js +1205 -0
  105. package/dist/brokers/brokers.service.js.map +1 -0
  106. package/dist/brokers/index.d.ts +46 -0
  107. package/dist/brokers/index.js +83 -0
  108. package/dist/brokers/index.js.map +1 -0
  109. package/dist/brokers/types/index.d.ts +567 -0
  110. package/dist/brokers/types/index.js +8 -0
  111. package/dist/brokers/types/index.js.map +1 -0
  112. package/dist/brokers/utils/broker.util.d.ts +33 -0
  113. package/dist/brokers/utils/broker.util.js +125 -0
  114. package/dist/brokers/utils/broker.util.js.map +1 -0
  115. package/dist/{processor/services/messagebrokers → brokers/utils/providers}/aws-sqs.service.d.ts +3 -2
  116. package/dist/brokers/utils/providers/aws-sqs.service.js +71 -0
  117. package/dist/brokers/utils/providers/aws-sqs.service.js.map +1 -0
  118. package/dist/{processor/services/messagebrokers → brokers/utils/providers}/google-pubsub.service.d.ts +2 -2
  119. package/dist/{processor/services/messagebrokers → brokers/utils/providers}/google-pubsub.service.js +16 -7
  120. package/dist/brokers/utils/providers/google-pubsub.service.js.map +1 -0
  121. package/dist/brokers/utils/providers/index.d.ts +6 -0
  122. package/dist/brokers/utils/providers/index.js +16 -0
  123. package/dist/brokers/utils/providers/index.js.map +1 -0
  124. package/dist/brokers/utils/providers/kafka.service.d.ts +23 -0
  125. package/dist/brokers/utils/providers/kafka.service.js +131 -0
  126. package/dist/brokers/utils/providers/kafka.service.js.map +1 -0
  127. package/dist/brokers/utils/providers/nats.service.d.ts +18 -0
  128. package/dist/brokers/utils/providers/nats.service.js +63 -0
  129. package/dist/brokers/utils/providers/nats.service.js.map +1 -0
  130. package/dist/brokers/utils/providers/rabbitmq.service.d.ts +25 -0
  131. package/dist/brokers/utils/providers/rabbitmq.service.js +138 -0
  132. package/dist/brokers/utils/providers/rabbitmq.service.js.map +1 -0
  133. package/dist/{processor/services/messagebrokers → brokers/utils/providers}/redis.service.d.ts +3 -3
  134. package/dist/{processor/services/messagebrokers → brokers/utils/providers}/redis.service.js +25 -14
  135. package/dist/brokers/utils/providers/redis.service.js.map +1 -0
  136. package/dist/cache/cache.manager.d.ts +308 -0
  137. package/dist/cache/cache.manager.js +900 -0
  138. package/dist/cache/cache.manager.js.map +1 -0
  139. package/dist/cache/cache.service.d.ts +191 -0
  140. package/dist/cache/cache.service.js +594 -0
  141. package/dist/cache/cache.service.js.map +1 -0
  142. package/dist/cache/index.d.ts +52 -0
  143. package/dist/cache/index.js +81 -0
  144. package/dist/cache/index.js.map +1 -0
  145. package/dist/cache/types/index.d.ts +110 -0
  146. package/dist/cache/types/index.js +6 -0
  147. package/dist/cache/types/index.js.map +1 -0
  148. package/dist/clients/apps.client.js +1 -1
  149. package/dist/clients/apps.client.js.map +1 -1
  150. package/dist/clients/pricing.client.d.ts +3 -0
  151. package/dist/clients/pricing.client.js +33 -0
  152. package/dist/clients/pricing.client.js.map +1 -0
  153. package/dist/database/actions/action-manager.d.ts +170 -0
  154. package/dist/database/actions/action-manager.js +465 -0
  155. package/dist/database/actions/action-manager.js.map +1 -0
  156. package/dist/database/actions/index.d.ts +6 -0
  157. package/dist/database/actions/index.js +13 -0
  158. package/dist/database/actions/index.js.map +1 -0
  159. package/dist/database/adapters/adapter.factory.d.ts +62 -0
  160. package/dist/database/adapters/adapter.factory.js +97 -0
  161. package/dist/database/adapters/adapter.factory.js.map +1 -0
  162. package/dist/database/adapters/base.adapter.d.ts +423 -0
  163. package/dist/database/adapters/base.adapter.js +260 -0
  164. package/dist/database/adapters/base.adapter.js.map +1 -0
  165. package/dist/database/adapters/cassandra.adapter.d.ts +92 -0
  166. package/dist/database/adapters/cassandra.adapter.js +1091 -0
  167. package/dist/database/adapters/cassandra.adapter.js.map +1 -0
  168. package/dist/database/adapters/dynamodb.adapter.d.ts +110 -0
  169. package/dist/database/adapters/dynamodb.adapter.js +1564 -0
  170. package/dist/database/adapters/dynamodb.adapter.js.map +1 -0
  171. package/dist/database/adapters/index.d.ts +11 -0
  172. package/dist/database/adapters/index.js +27 -0
  173. package/dist/database/adapters/index.js.map +1 -0
  174. package/dist/database/adapters/mariadb.adapter.d.ts +100 -0
  175. package/dist/database/adapters/mariadb.adapter.js +247 -0
  176. package/dist/database/adapters/mariadb.adapter.js.map +1 -0
  177. package/dist/database/adapters/mongodb.adapter.d.ts +121 -0
  178. package/dist/database/adapters/mongodb.adapter.js +1284 -0
  179. package/dist/database/adapters/mongodb.adapter.js.map +1 -0
  180. package/dist/database/adapters/mysql.adapter.d.ts +86 -0
  181. package/dist/database/adapters/mysql.adapter.js +1371 -0
  182. package/dist/database/adapters/mysql.adapter.js.map +1 -0
  183. package/dist/database/adapters/postgresql.adapter.d.ts +90 -0
  184. package/dist/database/adapters/postgresql.adapter.js +1487 -0
  185. package/dist/database/adapters/postgresql.adapter.js.map +1 -0
  186. package/dist/database/databases.service.d.ts +1476 -0
  187. package/dist/database/databases.service.js +3068 -0
  188. package/dist/database/databases.service.js.map +1 -0
  189. package/dist/database/index.d.ts +46 -0
  190. package/dist/database/index.js +109 -0
  191. package/dist/database/index.js.map +1 -0
  192. package/dist/database/migrations/index.d.ts +6 -0
  193. package/dist/database/migrations/index.js +12 -0
  194. package/dist/database/migrations/index.js.map +1 -0
  195. package/dist/database/migrations/migration-engine.d.ts +136 -0
  196. package/dist/database/migrations/migration-engine.js +1421 -0
  197. package/dist/database/migrations/migration-engine.js.map +1 -0
  198. package/dist/database/operators/aggregation-builder.d.ts +67 -0
  199. package/dist/database/operators/aggregation-builder.js +841 -0
  200. package/dist/database/operators/aggregation-builder.js.map +1 -0
  201. package/dist/database/operators/index.d.ts +7 -0
  202. package/dist/database/operators/index.js +15 -0
  203. package/dist/database/operators/index.js.map +1 -0
  204. package/dist/database/operators/query-builder.d.ts +69 -0
  205. package/dist/database/operators/query-builder.js +447 -0
  206. package/dist/database/operators/query-builder.js.map +1 -0
  207. package/dist/database/presave/decrypt.d.ts +25 -0
  208. package/dist/database/presave/decrypt.js +146 -0
  209. package/dist/database/presave/decrypt.js.map +1 -0
  210. package/dist/database/presave/index.d.ts +9 -0
  211. package/dist/database/presave/index.js +18 -0
  212. package/dist/database/presave/index.js.map +1 -0
  213. package/dist/database/presave/presave-processor.d.ts +148 -0
  214. package/dist/database/presave/presave-processor.js +702 -0
  215. package/dist/database/presave/presave-processor.js.map +1 -0
  216. package/dist/database/schema/index.d.ts +7 -0
  217. package/dist/database/schema/index.js +13 -0
  218. package/dist/database/schema/index.js.map +1 -0
  219. package/dist/database/schema/schema-manager.d.ts +258 -0
  220. package/dist/database/schema/schema-manager.js +638 -0
  221. package/dist/database/schema/schema-manager.js.map +1 -0
  222. package/dist/database/transactions/index.d.ts +6 -0
  223. package/dist/database/transactions/index.js +13 -0
  224. package/dist/database/transactions/index.js.map +1 -0
  225. package/dist/database/transactions/transaction-manager.d.ts +113 -0
  226. package/dist/database/transactions/transaction-manager.js +344 -0
  227. package/dist/database/transactions/transaction-manager.js.map +1 -0
  228. package/dist/database/triggers/index.d.ts +7 -0
  229. package/dist/database/triggers/index.js +14 -0
  230. package/dist/database/triggers/index.js.map +1 -0
  231. package/dist/database/triggers/trigger-processor.d.ts +239 -0
  232. package/dist/database/triggers/trigger-processor.js +1034 -0
  233. package/dist/database/triggers/trigger-processor.js.map +1 -0
  234. package/dist/database/types/action.interface.d.ts +148 -0
  235. package/dist/database/types/action.interface.js +6 -0
  236. package/dist/database/types/action.interface.js.map +1 -0
  237. package/dist/database/types/aggregation.interface.d.ts +185 -0
  238. package/dist/database/types/aggregation.interface.js +6 -0
  239. package/dist/database/types/aggregation.interface.js.map +1 -0
  240. package/dist/database/types/connection.interface.d.ts +137 -0
  241. package/dist/database/types/connection.interface.js +6 -0
  242. package/dist/database/types/connection.interface.js.map +1 -0
  243. package/dist/database/types/dashboard.interface.d.ts +74 -0
  244. package/dist/database/types/dashboard.interface.js +7 -0
  245. package/dist/database/types/dashboard.interface.js.map +1 -0
  246. package/dist/database/types/enums.d.ts +195 -0
  247. package/dist/database/types/enums.js +244 -0
  248. package/dist/database/types/enums.js.map +1 -0
  249. package/dist/database/types/index.d.ts +15 -0
  250. package/dist/database/types/index.js +31 -0
  251. package/dist/database/types/index.js.map +1 -0
  252. package/dist/database/types/migration.interface.d.ts +686 -0
  253. package/dist/database/types/migration.interface.js +9 -0
  254. package/dist/database/types/migration.interface.js.map +1 -0
  255. package/dist/database/types/presave.interface.d.ts +292 -0
  256. package/dist/database/types/presave.interface.js +60 -0
  257. package/dist/database/types/presave.interface.js.map +1 -0
  258. package/dist/database/types/query.interface.d.ts +205 -0
  259. package/dist/database/types/query.interface.js +6 -0
  260. package/dist/database/types/query.interface.js.map +1 -0
  261. package/dist/database/types/schema.interface.d.ts +412 -0
  262. package/dist/database/types/schema.interface.js +6 -0
  263. package/dist/database/types/schema.interface.js.map +1 -0
  264. package/dist/database/types/transaction.interface.d.ts +84 -0
  265. package/dist/database/types/transaction.interface.js +6 -0
  266. package/dist/database/types/transaction.interface.js.map +1 -0
  267. package/dist/database/types/trigger.interface.d.ts +612 -0
  268. package/dist/database/types/trigger.interface.js +121 -0
  269. package/dist/database/types/trigger.interface.js.map +1 -0
  270. package/dist/database/types/write.interface.d.ts +216 -0
  271. package/dist/database/types/write.interface.js +6 -0
  272. package/dist/database/types/write.interface.js.map +1 -0
  273. package/dist/database/utils/database-error.d.ts +96 -0
  274. package/dist/database/utils/database-error.js +221 -0
  275. package/dist/database/utils/database-error.js.map +1 -0
  276. package/dist/database/utils/index.d.ts +6 -0
  277. package/dist/database/utils/index.js +11 -0
  278. package/dist/database/utils/index.js.map +1 -0
  279. package/dist/graph/adapters/adapter.factory.d.ts +47 -0
  280. package/dist/graph/adapters/adapter.factory.js +77 -0
  281. package/dist/graph/adapters/adapter.factory.js.map +1 -0
  282. package/dist/graph/adapters/arangodb.adapter.d.ts +86 -0
  283. package/dist/graph/adapters/arangodb.adapter.js +1588 -0
  284. package/dist/graph/adapters/arangodb.adapter.js.map +1 -0
  285. package/dist/graph/adapters/base.adapter.d.ts +264 -0
  286. package/dist/graph/adapters/base.adapter.js +156 -0
  287. package/dist/graph/adapters/base.adapter.js.map +1 -0
  288. package/dist/graph/adapters/index.d.ts +11 -0
  289. package/dist/graph/adapters/index.js +21 -0
  290. package/dist/graph/adapters/index.js.map +1 -0
  291. package/dist/graph/adapters/memgraph.adapter.d.ts +110 -0
  292. package/dist/graph/adapters/memgraph.adapter.js +1452 -0
  293. package/dist/graph/adapters/memgraph.adapter.js.map +1 -0
  294. package/dist/graph/adapters/neo4j.adapter.d.ts +81 -0
  295. package/dist/graph/adapters/neo4j.adapter.js +1317 -0
  296. package/dist/graph/adapters/neo4j.adapter.js.map +1 -0
  297. package/dist/graph/adapters/neptune.adapter.d.ts +82 -0
  298. package/dist/graph/adapters/neptune.adapter.js +1369 -0
  299. package/dist/graph/adapters/neptune.adapter.js.map +1 -0
  300. package/dist/graph/graphs.service.d.ts +606 -0
  301. package/dist/graph/graphs.service.js +2434 -0
  302. package/dist/graph/graphs.service.js.map +1 -0
  303. package/dist/graph/index.d.ts +57 -0
  304. package/dist/graph/index.js +77 -0
  305. package/dist/graph/index.js.map +1 -0
  306. package/dist/graph/transactions/index.d.ts +4 -0
  307. package/dist/graph/transactions/index.js +9 -0
  308. package/dist/graph/transactions/index.js.map +1 -0
  309. package/dist/graph/transactions/transaction-manager.d.ts +61 -0
  310. package/dist/graph/transactions/transaction-manager.js +126 -0
  311. package/dist/graph/transactions/transaction-manager.js.map +1 -0
  312. package/dist/graph/types/connection.interface.d.ts +149 -0
  313. package/dist/graph/types/connection.interface.js +9 -0
  314. package/dist/graph/types/connection.interface.js.map +1 -0
  315. package/dist/graph/types/enums.d.ts +101 -0
  316. package/dist/graph/types/enums.js +114 -0
  317. package/dist/graph/types/enums.js.map +1 -0
  318. package/dist/graph/types/index.d.ts +13 -0
  319. package/dist/graph/types/index.js +20 -0
  320. package/dist/graph/types/index.js.map +1 -0
  321. package/dist/graph/types/node.interface.d.ts +248 -0
  322. package/dist/graph/types/node.interface.js +9 -0
  323. package/dist/graph/types/node.interface.js.map +1 -0
  324. package/dist/graph/types/query.interface.d.ts +175 -0
  325. package/dist/graph/types/query.interface.js +9 -0
  326. package/dist/graph/types/query.interface.js.map +1 -0
  327. package/dist/graph/types/relationship.interface.d.ts +207 -0
  328. package/dist/graph/types/relationship.interface.js +9 -0
  329. package/dist/graph/types/relationship.interface.js.map +1 -0
  330. package/dist/graph/types/schema.interface.d.ts +295 -0
  331. package/dist/graph/types/schema.interface.js +9 -0
  332. package/dist/graph/types/schema.interface.js.map +1 -0
  333. package/dist/graph/types/transaction.interface.d.ts +55 -0
  334. package/dist/graph/types/transaction.interface.js +9 -0
  335. package/dist/graph/types/transaction.interface.js.map +1 -0
  336. package/dist/graph/types/traversal.interface.d.ts +181 -0
  337. package/dist/graph/types/traversal.interface.js +9 -0
  338. package/dist/graph/types/traversal.interface.js.map +1 -0
  339. package/dist/graph/utils/graph-error.d.ts +71 -0
  340. package/dist/graph/utils/graph-error.js +142 -0
  341. package/dist/graph/utils/graph-error.js.map +1 -0
  342. package/dist/graph/utils/index.d.ts +4 -0
  343. package/dist/graph/utils/index.js +9 -0
  344. package/dist/graph/utils/index.js.map +1 -0
  345. package/dist/imports/imports.service.d.ts +3 -3
  346. package/dist/imports/imports.service.js +8 -7
  347. package/dist/imports/imports.service.js.map +1 -1
  348. package/dist/imports/imports.types.d.ts +8 -0
  349. package/dist/imports/repos/openApi.repo.d.ts +1 -2
  350. package/dist/imports/repos/openApi.repo.js +409 -70
  351. package/dist/imports/repos/openApi.repo.js.map +1 -1
  352. package/dist/imports/repos/postmanV21.repo.d.ts +1 -1
  353. package/dist/imports/repos/postmanV21.repo.js +126 -83
  354. package/dist/imports/repos/postmanV21.repo.js.map +1 -1
  355. package/dist/index.d.ts +3926 -269
  356. package/dist/index.js +5475 -682
  357. package/dist/index.js.map +1 -1
  358. package/dist/init.interface.d.ts +407 -0
  359. package/dist/{processor/services/messagebrokers/messagebrokers.type.js → init.interface.js} +1 -1
  360. package/dist/init.interface.js.map +1 -0
  361. package/dist/inputs/inputs.service.d.ts +1 -1
  362. package/dist/inputs/inputs.service.js +2 -2
  363. package/dist/inputs/inputs.service.js.map +1 -1
  364. package/dist/inputs/utils/inputs.utils.create.js +1 -1
  365. package/dist/inputs/utils/inputs.utils.create.js.map +1 -1
  366. package/dist/jobs/index.d.ts +38 -0
  367. package/dist/jobs/index.js +50 -0
  368. package/dist/jobs/index.js.map +1 -0
  369. package/dist/jobs/jobs.service.d.ts +154 -0
  370. package/dist/jobs/jobs.service.js +491 -0
  371. package/dist/jobs/jobs.service.js.map +1 -0
  372. package/dist/jobs/jobs.state.d.ts +113 -0
  373. package/dist/jobs/jobs.state.js +447 -0
  374. package/dist/jobs/jobs.state.js.map +1 -0
  375. package/dist/jobs/types.d.ts +449 -0
  376. package/dist/jobs/types.js +74 -0
  377. package/dist/jobs/types.js.map +1 -0
  378. package/dist/logs/logs.service.js +6 -1
  379. package/dist/logs/logs.service.js.map +1 -1
  380. package/dist/logs/logs.types.d.ts +33 -1
  381. package/dist/logs/logs.types.js +17 -0
  382. package/dist/logs/logs.types.js.map +1 -1
  383. package/dist/models/index.d.ts +6 -0
  384. package/dist/models/index.js +11 -0
  385. package/dist/models/index.js.map +1 -0
  386. package/dist/models/models.service.d.ts +137 -0
  387. package/dist/models/models.service.js +195 -0
  388. package/dist/models/models.service.js.map +1 -0
  389. package/dist/notifications/index.d.ts +13 -0
  390. package/dist/notifications/index.js +26 -0
  391. package/dist/notifications/index.js.map +1 -0
  392. package/dist/notifications/notifications.service.d.ts +268 -0
  393. package/dist/notifications/notifications.service.js +905 -0
  394. package/dist/notifications/notifications.service.js.map +1 -0
  395. package/dist/notifications/types/index.d.ts +4 -0
  396. package/dist/notifications/types/index.js +21 -0
  397. package/dist/notifications/types/index.js.map +1 -0
  398. package/dist/notifications/types/notifications.types.d.ts +452 -0
  399. package/dist/notifications/types/notifications.types.js +49 -0
  400. package/dist/notifications/types/notifications.types.js.map +1 -0
  401. package/dist/parsers/index.d.ts +3 -0
  402. package/dist/parsers/index.js +27 -0
  403. package/dist/parsers/index.js.map +1 -0
  404. package/dist/parsers/pipelines/postman.pipelines.d.ts +15 -0
  405. package/dist/parsers/pipelines/postman.pipelines.js +103 -0
  406. package/dist/parsers/pipelines/postman.pipelines.js.map +1 -0
  407. package/dist/parsers/types/postman.types.d.ts +200 -0
  408. package/dist/parsers/types/postman.types.js +3 -0
  409. package/dist/parsers/types/postman.types.js.map +1 -0
  410. package/dist/parsers/utils/postman.utils.d.ts +12 -0
  411. package/dist/parsers/utils/postman.utils.js +116 -0
  412. package/dist/parsers/utils/postman.utils.js.map +1 -0
  413. package/dist/parsers/validators/postman-auth.validators.d.ts +10 -0
  414. package/dist/parsers/validators/postman-auth.validators.js +127 -0
  415. package/dist/parsers/validators/postman-auth.validators.js.map +1 -0
  416. package/dist/parsers/validators/postman-request.validators.d.ts +13 -0
  417. package/dist/parsers/validators/postman-request.validators.js +139 -0
  418. package/dist/parsers/validators/postman-request.validators.js.map +1 -0
  419. package/dist/parsers/validators/postman-response.validators.d.ts +13 -0
  420. package/dist/parsers/validators/postman-response.validators.js +150 -0
  421. package/dist/parsers/validators/postman-response.validators.js.map +1 -0
  422. package/dist/parsers/validators/postman-variable.validators.d.ts +14 -0
  423. package/dist/parsers/validators/postman-variable.validators.js +163 -0
  424. package/dist/parsers/validators/postman-variable.validators.js.map +1 -0
  425. package/dist/pricing/pricing.repo.js +1 -0
  426. package/dist/pricing/pricing.repo.js.map +1 -0
  427. package/dist/pricing/pricing.service.d.ts +24 -0
  428. package/dist/pricing/pricing.service.js +51 -0
  429. package/dist/pricing/pricing.service.js.map +1 -0
  430. package/dist/pricing/pricing.types.d.ts +76 -0
  431. package/dist/pricing/pricing.types.js +21 -0
  432. package/dist/pricing/pricing.types.js.map +1 -0
  433. package/dist/pricing/utils/string.utils.d.ts +1 -0
  434. package/dist/pricing/utils/string.utils.js +9 -0
  435. package/dist/pricing/utils/string.utils.js.map +1 -0
  436. package/dist/processor/repos/sms.repo.d.ts +4 -4
  437. package/dist/processor/repos/sms.repo.js +23 -10
  438. package/dist/processor/repos/sms.repo.js.map +1 -1
  439. package/dist/processor/services/processor.service.d.ts +251 -78
  440. package/dist/processor/services/processor.service.js +2803 -1495
  441. package/dist/processor/services/processor.service.js.map +1 -1
  442. package/dist/processor/services/request.service.d.ts +36 -0
  443. package/dist/processor/services/request.service.js +304 -0
  444. package/dist/processor/services/request.service.js.map +1 -0
  445. package/dist/processor/types/request.types.d.ts +14 -0
  446. package/dist/processor/types/request.types.js +3 -0
  447. package/dist/processor/types/request.types.js.map +1 -0
  448. package/dist/processor/utils/processor.utils.d.ts +8 -0
  449. package/dist/processor/utils/processor.utils.js +152 -12
  450. package/dist/processor/utils/processor.utils.js.map +1 -1
  451. package/dist/processor/utils/request.utils.d.ts +20 -0
  452. package/dist/processor/utils/request.utils.js +113 -0
  453. package/dist/processor/utils/request.utils.js.map +1 -0
  454. package/dist/processor/utils/storage.util.js +63 -40
  455. package/dist/processor/utils/storage.util.js.map +1 -1
  456. package/dist/products/services/products.service.d.ts +386 -76
  457. package/dist/products/services/products.service.js +3221 -419
  458. package/dist/products/services/products.service.js.map +1 -1
  459. package/dist/products/utils/string.utils.d.ts +1 -1
  460. package/dist/products/utils/string.utils.js +14 -2
  461. package/dist/products/utils/string.utils.js.map +1 -1
  462. package/dist/products/validators/index.d.ts +7 -1
  463. package/dist/products/validators/index.js +16 -1
  464. package/dist/products/validators/index.js.map +1 -1
  465. package/dist/products/validators/joi-validators/create.productAgent.validator.d.ts +3 -0
  466. package/dist/products/validators/joi-validators/create.productAgent.validator.js +266 -0
  467. package/dist/products/validators/joi-validators/create.productAgent.validator.js.map +1 -0
  468. package/dist/products/validators/joi-validators/create.productApp.validator.js +2 -2
  469. package/dist/products/validators/joi-validators/create.productApp.validator.js.map +1 -1
  470. package/dist/products/validators/joi-validators/create.productDatabase.validator.js +5 -0
  471. package/dist/products/validators/joi-validators/create.productDatabase.validator.js.map +1 -1
  472. package/dist/products/validators/joi-validators/create.productEnv.validator.js +1 -0
  473. package/dist/products/validators/joi-validators/create.productEnv.validator.js.map +1 -1
  474. package/dist/products/validators/joi-validators/create.productFeature.validator.js +1 -1
  475. package/dist/products/validators/joi-validators/create.productGraph.validator.js +89 -0
  476. package/dist/products/validators/joi-validators/create.productGraph.validator.js.map +1 -0
  477. package/dist/products/validators/joi-validators/create.productHealthcheck.validator.d.ts +4 -0
  478. package/dist/{processor/services/messagebrokers/rabbitmq.service.js → products/validators/joi-validators/create.productHealthcheck.validator.js} +23 -32
  479. package/dist/products/validators/joi-validators/create.productHealthcheck.validator.js.map +1 -0
  480. package/dist/products/validators/joi-validators/create.productJob.validator.js +2 -2
  481. package/dist/products/validators/joi-validators/create.productJob.validator.js.map +1 -1
  482. package/dist/products/validators/joi-validators/create.productMessageBrokerTopic.validator.js +1 -0
  483. package/dist/products/validators/joi-validators/create.productMessageBrokerTopic.validator.js.map +1 -1
  484. package/dist/products/validators/joi-validators/create.productMessageBrokers.validator.js +81 -25
  485. package/dist/products/validators/joi-validators/create.productMessageBrokers.validator.js.map +1 -1
  486. package/dist/products/validators/joi-validators/create.productModel.validator.d.ts +3 -0
  487. package/dist/products/validators/joi-validators/create.productModel.validator.js +132 -0
  488. package/dist/products/validators/joi-validators/create.productModel.validator.js.map +1 -0
  489. package/dist/products/validators/joi-validators/create.productNotification.validator.js +150 -51
  490. package/dist/products/validators/joi-validators/create.productNotification.validator.js.map +1 -1
  491. package/dist/products/validators/joi-validators/create.productStorage.validator.js +77 -18
  492. package/dist/products/validators/joi-validators/create.productStorage.validator.js.map +1 -1
  493. package/dist/products/validators/joi-validators/create.productVector.validator.d.ts +3 -0
  494. package/dist/products/validators/joi-validators/create.productVector.validator.js +136 -0
  495. package/dist/products/validators/joi-validators/create.productVector.validator.js.map +1 -0
  496. package/dist/products/validators/joi-validators/create.userAuth.validator.js +1 -0
  497. package/dist/products/validators/joi-validators/create.userAuth.validator.js.map +1 -1
  498. package/dist/products/validators/joi-validators/update.dataValue.validator.js +1 -0
  499. package/dist/products/validators/joi-validators/update.dataValue.validator.js.map +1 -1
  500. package/dist/products/validators/joi-validators/update.productDatabase.validator.js +5 -0
  501. package/dist/products/validators/joi-validators/update.productDatabase.validator.js.map +1 -1
  502. package/dist/products/validators/joi-validators/update.productEnv.validator.js +3 -0
  503. package/dist/products/validators/joi-validators/update.productEnv.validator.js.map +1 -1
  504. package/dist/products/validators/joi-validators/update.productGraph.validator.js +88 -0
  505. package/dist/products/validators/joi-validators/update.productGraph.validator.js.map +1 -0
  506. package/dist/products/validators/joi-validators/update.userAuth.validator.js +1 -0
  507. package/dist/products/validators/joi-validators/update.userAuth.validator.js.map +1 -1
  508. package/dist/resilience/fallback.service.d.ts +141 -0
  509. package/dist/resilience/fallback.service.js +766 -0
  510. package/dist/resilience/fallback.service.js.map +1 -0
  511. package/dist/resilience/healthcheck.service.d.ts +159 -0
  512. package/dist/resilience/healthcheck.service.js +943 -0
  513. package/dist/resilience/healthcheck.service.js.map +1 -0
  514. package/dist/resilience/index.d.ts +104 -0
  515. package/dist/resilience/index.js +140 -0
  516. package/dist/resilience/index.js.map +1 -0
  517. package/dist/resilience/quota.service.d.ts +83 -0
  518. package/dist/resilience/quota.service.js +518 -0
  519. package/dist/resilience/quota.service.js.map +1 -0
  520. package/dist/resilience/resilience.service.d.ts +98 -0
  521. package/dist/resilience/resilience.service.js +560 -0
  522. package/dist/resilience/resilience.service.js.map +1 -0
  523. package/dist/resilience/types/index.d.ts +513 -0
  524. package/dist/resilience/types/index.js +29 -0
  525. package/dist/resilience/types/index.js.map +1 -0
  526. package/dist/secrets/index.d.ts +10 -0
  527. package/dist/secrets/index.js +33 -0
  528. package/dist/secrets/index.js.map +1 -0
  529. package/dist/secrets/secrets.resolver.d.ts +52 -0
  530. package/dist/secrets/secrets.resolver.js +236 -0
  531. package/dist/secrets/secrets.resolver.js.map +1 -0
  532. package/dist/secrets/secrets.service.d.ts +93 -0
  533. package/dist/secrets/secrets.service.js +246 -0
  534. package/dist/secrets/secrets.service.js.map +1 -0
  535. package/dist/secrets/secrets.types.d.ts +188 -0
  536. package/dist/secrets/secrets.types.js +87 -0
  537. package/dist/secrets/secrets.types.js.map +1 -0
  538. package/dist/sessions/index.d.ts +50 -0
  539. package/dist/sessions/index.js +96 -0
  540. package/dist/sessions/index.js.map +1 -0
  541. package/dist/sessions/sessions.helper.d.ts +88 -0
  542. package/dist/sessions/sessions.helper.js +133 -0
  543. package/dist/sessions/sessions.helper.js.map +1 -0
  544. package/dist/sessions/sessions.resolver.d.ts +188 -0
  545. package/dist/sessions/sessions.resolver.js +603 -0
  546. package/dist/sessions/sessions.resolver.js.map +1 -0
  547. package/dist/sessions/sessions.service.d.ts +194 -0
  548. package/dist/sessions/sessions.service.js +987 -0
  549. package/dist/sessions/sessions.service.js.map +1 -0
  550. package/dist/sessions/types/index.d.ts +342 -0
  551. package/dist/sessions/types/index.js +6 -0
  552. package/dist/sessions/types/index.js.map +1 -0
  553. package/dist/storage/index.d.ts +66 -0
  554. package/dist/storage/index.js +99 -0
  555. package/dist/storage/index.js.map +1 -0
  556. package/dist/storage/storage.service.d.ts +177 -0
  557. package/dist/storage/storage.service.js +897 -0
  558. package/dist/storage/storage.service.js.map +1 -0
  559. package/dist/storage/types/index.d.ts +267 -0
  560. package/dist/storage/types/index.js +6 -0
  561. package/dist/storage/types/index.js.map +1 -0
  562. package/dist/storage/utils/storage.util.d.ts +62 -0
  563. package/dist/storage/utils/storage.util.js +593 -0
  564. package/dist/storage/utils/storage.util.js.map +1 -0
  565. package/dist/types/appBuilder.types.d.ts +13 -14
  566. package/dist/types/enums.d.ts +11 -1
  567. package/dist/types/enums.js +10 -0
  568. package/dist/types/enums.js.map +1 -1
  569. package/dist/types/index.types.d.ts +9 -4
  570. package/dist/types/index.types.js +0 -1
  571. package/dist/types/index.types.js.map +1 -1
  572. package/dist/types/inputs.types.d.ts +1 -0
  573. package/dist/types/inputs.types.js +4 -3
  574. package/dist/types/inputs.types.js.map +1 -1
  575. package/dist/types/pricing.types.d.ts +4 -0
  576. package/dist/types/pricing.types.js +3 -0
  577. package/dist/types/pricing.types.js.map +1 -0
  578. package/dist/types/processor.types.d.ts +324 -18
  579. package/dist/types/processor.types.js +9 -1
  580. package/dist/types/processor.types.js.map +1 -1
  581. package/dist/types/productsBuilder.types.d.ts +1007 -23
  582. package/dist/types/productsBuilder.types.js +216 -2
  583. package/dist/types/productsBuilder.types.js.map +1 -1
  584. package/dist/types/request-tracker.interface.js +1 -0
  585. package/dist/types/request-tracker.interface.js.map +1 -0
  586. package/dist/types/requests.types.d.ts +2 -0
  587. package/dist/utils/constants.d.ts +1 -0
  588. package/dist/utils/constants.js +5 -0
  589. package/dist/utils/constants.js.map +1 -0
  590. package/dist/utils/index.d.ts +0 -2
  591. package/dist/utils/index.js +24 -52
  592. package/dist/utils/index.js.map +1 -1
  593. package/dist/vector/actions/action-manager.d.ts +140 -0
  594. package/dist/vector/actions/action-manager.js +356 -0
  595. package/dist/vector/actions/action-manager.js.map +1 -0
  596. package/dist/vector/adapters/base.adapter.d.ts +169 -0
  597. package/dist/vector/adapters/base.adapter.js +218 -0
  598. package/dist/vector/adapters/base.adapter.js.map +1 -0
  599. package/dist/vector/adapters/index.d.ts +10 -0
  600. package/dist/vector/adapters/index.js +19 -0
  601. package/dist/vector/adapters/index.js.map +1 -0
  602. package/dist/vector/adapters/memory.adapter.d.ts +85 -0
  603. package/dist/vector/adapters/memory.adapter.js +505 -0
  604. package/dist/vector/adapters/memory.adapter.js.map +1 -0
  605. package/dist/vector/adapters/pinecone.adapter.d.ts +52 -0
  606. package/dist/vector/adapters/pinecone.adapter.js +433 -0
  607. package/dist/vector/adapters/pinecone.adapter.js.map +1 -0
  608. package/dist/vector/adapters/qdrant.adapter.d.ts +56 -0
  609. package/dist/vector/adapters/qdrant.adapter.js +442 -0
  610. package/dist/vector/adapters/qdrant.adapter.js.map +1 -0
  611. package/dist/vector/adapters/weaviate.adapter.d.ts +68 -0
  612. package/dist/vector/adapters/weaviate.adapter.js +661 -0
  613. package/dist/vector/adapters/weaviate.adapter.js.map +1 -0
  614. package/dist/vector/index.d.ts +36 -0
  615. package/dist/vector/index.js +70 -0
  616. package/dist/vector/index.js.map +1 -0
  617. package/dist/vector/types/action.interface.d.ts +195 -0
  618. package/dist/vector/types/action.interface.js +100 -0
  619. package/dist/vector/types/action.interface.js.map +1 -0
  620. package/dist/vector/types/connection.interface.d.ts +151 -0
  621. package/dist/vector/types/connection.interface.js +8 -0
  622. package/dist/vector/types/connection.interface.js.map +1 -0
  623. package/dist/vector/types/embedding.interface.d.ts +144 -0
  624. package/dist/vector/types/embedding.interface.js +8 -0
  625. package/dist/vector/types/embedding.interface.js.map +1 -0
  626. package/dist/vector/types/enums.d.ts +104 -0
  627. package/dist/vector/types/enums.js +113 -0
  628. package/dist/vector/types/enums.js.map +1 -0
  629. package/dist/vector/types/index.d.ts +11 -0
  630. package/dist/vector/types/index.js +23 -0
  631. package/dist/vector/types/index.js.map +1 -0
  632. package/dist/vector/types/vector.interface.d.ts +315 -0
  633. package/dist/vector/types/vector.interface.js +8 -0
  634. package/dist/vector/types/vector.interface.js.map +1 -0
  635. package/dist/vector/utils/index.d.ts +6 -0
  636. package/dist/vector/utils/index.js +11 -0
  637. package/dist/vector/utils/index.js.map +1 -0
  638. package/dist/vector/utils/vector-error.d.ts +69 -0
  639. package/dist/vector/utils/vector-error.js +116 -0
  640. package/dist/vector/utils/vector-error.js.map +1 -0
  641. package/dist/vector/vector-database.service.d.ts +476 -0
  642. package/dist/vector/vector-database.service.js +892 -0
  643. package/dist/vector/vector-database.service.js.map +1 -0
  644. package/dist/vector/vector.service.d.ts +283 -0
  645. package/dist/vector/vector.service.js +544 -0
  646. package/dist/vector/vector.service.js.map +1 -0
  647. package/dist/warehouse/executor/index.d.ts +5 -0
  648. package/dist/warehouse/executor/index.js +12 -0
  649. package/dist/warehouse/executor/index.js.map +1 -0
  650. package/dist/warehouse/executor/joins/index.d.ts +5 -0
  651. package/dist/warehouse/executor/joins/index.js +11 -0
  652. package/dist/warehouse/executor/joins/index.js.map +1 -0
  653. package/dist/warehouse/executor/joins/join-executor.d.ts +101 -0
  654. package/dist/warehouse/executor/joins/join-executor.js +493 -0
  655. package/dist/warehouse/executor/joins/join-executor.js.map +1 -0
  656. package/dist/warehouse/executor/joins/semantic-join.d.ts +64 -0
  657. package/dist/warehouse/executor/joins/semantic-join.js +241 -0
  658. package/dist/warehouse/executor/joins/semantic-join.js.map +1 -0
  659. package/dist/warehouse/executor/single-source-executor.d.ts +155 -0
  660. package/dist/warehouse/executor/single-source-executor.js +573 -0
  661. package/dist/warehouse/executor/single-source-executor.js.map +1 -0
  662. package/dist/warehouse/index.d.ts +79 -0
  663. package/dist/warehouse/index.js +111 -0
  664. package/dist/warehouse/index.js.map +1 -0
  665. package/dist/warehouse/parser/index.d.ts +4 -0
  666. package/dist/warehouse/parser/index.js +10 -0
  667. package/dist/warehouse/parser/index.js.map +1 -0
  668. package/dist/warehouse/parser/query-parser.d.ts +181 -0
  669. package/dist/warehouse/parser/query-parser.js +415 -0
  670. package/dist/warehouse/parser/query-parser.js.map +1 -0
  671. package/dist/warehouse/registry/data-source-registry.d.ts +207 -0
  672. package/dist/warehouse/registry/data-source-registry.js +396 -0
  673. package/dist/warehouse/registry/data-source-registry.js.map +1 -0
  674. package/dist/warehouse/registry/index.d.ts +4 -0
  675. package/dist/warehouse/registry/index.js +9 -0
  676. package/dist/warehouse/registry/index.js.map +1 -0
  677. package/dist/warehouse/transactions/index.d.ts +4 -0
  678. package/dist/warehouse/transactions/index.js +9 -0
  679. package/dist/warehouse/transactions/index.js.map +1 -0
  680. package/dist/warehouse/transactions/saga-orchestrator.d.ts +92 -0
  681. package/dist/warehouse/transactions/saga-orchestrator.js +383 -0
  682. package/dist/warehouse/transactions/saga-orchestrator.js.map +1 -0
  683. package/dist/warehouse/types/index.d.ts +9 -0
  684. package/dist/warehouse/types/index.js +33 -0
  685. package/dist/warehouse/types/index.js.map +1 -0
  686. package/dist/warehouse/types/join.interface.d.ts +225 -0
  687. package/dist/warehouse/types/join.interface.js +87 -0
  688. package/dist/warehouse/types/join.interface.js.map +1 -0
  689. package/dist/warehouse/types/query.interface.d.ts +232 -0
  690. package/dist/warehouse/types/query.interface.js +9 -0
  691. package/dist/warehouse/types/query.interface.js.map +1 -0
  692. package/dist/warehouse/types/transaction.interface.d.ts +236 -0
  693. package/dist/warehouse/types/transaction.interface.js +74 -0
  694. package/dist/warehouse/types/transaction.interface.js.map +1 -0
  695. package/dist/warehouse/types/where.interface.d.ts +208 -0
  696. package/dist/warehouse/types/where.interface.js +89 -0
  697. package/dist/warehouse/types/where.interface.js.map +1 -0
  698. package/dist/warehouse/warehouse.service.d.ts +200 -0
  699. package/dist/warehouse/warehouse.service.js +470 -0
  700. package/dist/warehouse/warehouse.service.js.map +1 -0
  701. package/dist/workflows/index.d.ts +30 -0
  702. package/dist/workflows/index.js +64 -0
  703. package/dist/workflows/index.js.map +1 -0
  704. package/dist/workflows/types/index.d.ts +6 -0
  705. package/dist/workflows/types/index.js +23 -0
  706. package/dist/workflows/types/index.js.map +1 -0
  707. package/dist/workflows/types/workflows.types.d.ts +1095 -0
  708. package/dist/workflows/types/workflows.types.js +13 -0
  709. package/dist/workflows/types/workflows.types.js.map +1 -0
  710. package/dist/workflows/workflow-builder.d.ts +70 -0
  711. package/dist/workflows/workflow-builder.js +353 -0
  712. package/dist/workflows/workflow-builder.js.map +1 -0
  713. package/dist/workflows/workflow-executor.d.ts +287 -0
  714. package/dist/workflows/workflow-executor.js +2399 -0
  715. package/dist/workflows/workflow-executor.js.map +1 -0
  716. package/dist/workflows/workflows.service.d.ts +412 -0
  717. package/dist/workflows/workflows.service.js +2188 -0
  718. package/dist/workflows/workflows.service.js.map +1 -0
  719. package/package.json +83 -11
  720. package/dist/actions/actions.repo.js +0 -13
  721. package/dist/actions/actions.repo.js.map +0 -1
  722. package/dist/actions/actions.service.js +0 -24
  723. package/dist/actions/actions.service.js.map +0 -1
  724. package/dist/actions/utils/actions.util.read.d.ts +0 -0
  725. package/dist/actions/utils/actions.util.read.js +0 -427
  726. package/dist/actions/utils/actions.util.read.js.map +0 -1
  727. package/dist/api/services/integrationsApi.service.d.ts +0 -18
  728. package/dist/api/services/integrationsApi.service.js +0 -80
  729. package/dist/api/services/integrationsApi.service.js.map +0 -1
  730. package/dist/appBuilder/services/app.service.d.ts +0 -111
  731. package/dist/appBuilder/services/app.service.js +0 -737
  732. package/dist/appBuilder/services/app.service.js.map +0 -1
  733. package/dist/appBuilder/services/appBuilder.service.d.ts +0 -111
  734. package/dist/appBuilder/services/appBuilder.service.js +0 -662
  735. package/dist/appBuilder/services/appBuilder.service.js.map +0 -1
  736. package/dist/appBuilder/utils/objects.utils.d.ts +0 -3
  737. package/dist/appBuilder/utils/objects.utils.js +0 -9
  738. package/dist/appBuilder/utils/objects.utils.js.map +0 -1
  739. package/dist/appBuilder/utils/string.utils.d.ts +0 -2
  740. package/dist/appBuilder/utils/string.utils.js +0 -57
  741. package/dist/appBuilder/utils/string.utils.js.map +0 -1
  742. package/dist/appBuilder/validators/index.d.ts +0 -19
  743. package/dist/appBuilder/validators/index.js +0 -40
  744. package/dist/appBuilder/validators/index.js.map +0 -1
  745. package/dist/appBuilder/validators/joi-validators/create.app.validator.js +0 -10
  746. package/dist/appBuilder/validators/joi-validators/create.app.validator.js.map +0 -1
  747. package/dist/appBuilder/validators/joi-validators/create.appAction.validator.d.ts +0 -4
  748. package/dist/appBuilder/validators/joi-validators/create.appAction.validator.js +0 -20
  749. package/dist/appBuilder/validators/joi-validators/create.appAction.validator.js.map +0 -1
  750. package/dist/appBuilder/validators/joi-validators/create.appActionResponse.validator.d.ts +0 -7
  751. package/dist/appBuilder/validators/joi-validators/create.appActionResponse.validator.js +0 -44
  752. package/dist/appBuilder/validators/joi-validators/create.appActionResponse.validator.js.map +0 -1
  753. package/dist/appBuilder/validators/joi-validators/create.appAuth.validator.d.ts +0 -3
  754. package/dist/appBuilder/validators/joi-validators/create.appAuth.validator.js +0 -31
  755. package/dist/appBuilder/validators/joi-validators/create.appAuth.validator.js.map +0 -1
  756. package/dist/appBuilder/validators/joi-validators/create.appBody.validators.d.ts +0 -4
  757. package/dist/appBuilder/validators/joi-validators/create.appBody.validators.js +0 -11
  758. package/dist/appBuilder/validators/joi-validators/create.appBody.validators.js.map +0 -1
  759. package/dist/appBuilder/validators/joi-validators/create.appConstants.validator.d.ts +0 -4
  760. package/dist/appBuilder/validators/joi-validators/create.appConstants.validator.js +0 -12
  761. package/dist/appBuilder/validators/joi-validators/create.appConstants.validator.js.map +0 -1
  762. package/dist/appBuilder/validators/joi-validators/create.appEnv.validator.d.ts +0 -4
  763. package/dist/appBuilder/validators/joi-validators/create.appEnv.validator.js +0 -17
  764. package/dist/appBuilder/validators/joi-validators/create.appEnv.validator.js.map +0 -1
  765. package/dist/appBuilder/validators/joi-validators/create.appEvent.validator.d.ts +0 -5
  766. package/dist/appBuilder/validators/joi-validators/create.appEvent.validator.js +0 -30
  767. package/dist/appBuilder/validators/joi-validators/create.appEvent.validator.js.map +0 -1
  768. package/dist/appBuilder/validators/joi-validators/create.appVariable.validator.d.ts +0 -4
  769. package/dist/appBuilder/validators/joi-validators/create.appVariable.validator.js +0 -14
  770. package/dist/appBuilder/validators/joi-validators/create.appVariable.validator.js.map +0 -1
  771. package/dist/appBuilder/validators/joi-validators/sample.validator.d.ts +0 -5
  772. package/dist/appBuilder/validators/joi-validators/sample.validator.js +0 -26
  773. package/dist/appBuilder/validators/joi-validators/sample.validator.js.map +0 -1
  774. package/dist/appBuilder/validators/joi-validators/update.app.validator.d.ts +0 -4
  775. package/dist/appBuilder/validators/joi-validators/update.app.validator.js +0 -34
  776. package/dist/appBuilder/validators/joi-validators/update.app.validator.js.map +0 -1
  777. package/dist/appBuilder/validators/joi-validators/update.appAction.validator.d.ts +0 -4
  778. package/dist/appBuilder/validators/joi-validators/update.appAction.validator.js +0 -23
  779. package/dist/appBuilder/validators/joi-validators/update.appAction.validator.js.map +0 -1
  780. package/dist/appBuilder/validators/joi-validators/update.appActionResponse.validator.d.ts +0 -3
  781. package/dist/appBuilder/validators/joi-validators/update.appActionResponse.validator.js +0 -21
  782. package/dist/appBuilder/validators/joi-validators/update.appActionResponse.validator.js.map +0 -1
  783. package/dist/appBuilder/validators/joi-validators/update.appAuth.validator.d.ts +0 -4
  784. package/dist/appBuilder/validators/joi-validators/update.appAuth.validator.js +0 -19
  785. package/dist/appBuilder/validators/joi-validators/update.appAuth.validator.js.map +0 -1
  786. package/dist/appBuilder/validators/joi-validators/update.appConstants.validator.d.ts +0 -4
  787. package/dist/appBuilder/validators/joi-validators/update.appConstants.validator.js +0 -12
  788. package/dist/appBuilder/validators/joi-validators/update.appConstants.validator.js.map +0 -1
  789. package/dist/appBuilder/validators/joi-validators/update.appEnv.validator.d.ts +0 -4
  790. package/dist/appBuilder/validators/joi-validators/update.appEnv.validator.js +0 -17
  791. package/dist/appBuilder/validators/joi-validators/update.appEnv.validator.js.map +0 -1
  792. package/dist/appBuilder/validators/joi-validators/update.appEvent.validator.d.ts +0 -4
  793. package/dist/appBuilder/validators/joi-validators/update.appEvent.validator.js +0 -16
  794. package/dist/appBuilder/validators/joi-validators/update.appEvent.validator.js.map +0 -1
  795. package/dist/appBuilder/validators/joi-validators/update.appVariables.validator.d.ts +0 -4
  796. package/dist/appBuilder/validators/joi-validators/update.appVariables.validator.js +0 -14
  797. package/dist/appBuilder/validators/joi-validators/update.appVariables.validator.js.map +0 -1
  798. package/dist/appBuilder/validators/joi-validators/update.validation.entityData.validator.js +0 -27
  799. package/dist/appBuilder/validators/joi-validators/update.validation.entityData.validator.js.map +0 -1
  800. package/dist/apps/validators/joi-validators/create.appEvent.validator.d.ts +0 -5
  801. package/dist/apps/validators/joi-validators/create.appEvent.validator.js +0 -30
  802. package/dist/apps/validators/joi-validators/create.appEvent.validator.js.map +0 -1
  803. package/dist/apps/validators/joi-validators/update.appEvent.validator.d.ts +0 -4
  804. package/dist/apps/validators/joi-validators/update.appEvent.validator.js +0 -16
  805. package/dist/apps/validators/joi-validators/update.appEvent.validator.js.map +0 -1
  806. package/dist/clients/integrations.client.d.ts +0 -2
  807. package/dist/clients/integrations.client.js +0 -26
  808. package/dist/clients/integrations.client.js.map +0 -1
  809. package/dist/integrationsBuilder/services/integration.service.d.ts +0 -138
  810. package/dist/integrationsBuilder/services/integration.service.js +0 -1148
  811. package/dist/integrationsBuilder/services/integration.service.js.map +0 -1
  812. package/dist/integrationsBuilder/services/integrationBuilder.service.d.ts +0 -130
  813. package/dist/integrationsBuilder/services/integrationBuilder.service.js +0 -1017
  814. package/dist/integrationsBuilder/services/integrationBuilder.service.js.map +0 -1
  815. package/dist/integrationsBuilder/utils/objects.utils.d.ts +0 -2
  816. package/dist/integrationsBuilder/utils/objects.utils.js +0 -48
  817. package/dist/integrationsBuilder/utils/objects.utils.js.map +0 -1
  818. package/dist/integrationsBuilder/utils/string.utils.d.ts +0 -1
  819. package/dist/integrationsBuilder/utils/string.utils.js +0 -9
  820. package/dist/integrationsBuilder/utils/string.utils.js.map +0 -1
  821. package/dist/integrationsBuilder/validators/index.d.ts +0 -18
  822. package/dist/integrationsBuilder/validators/index.js +0 -38
  823. package/dist/integrationsBuilder/validators/index.js.map +0 -1
  824. package/dist/integrationsBuilder/validators/joi-validators/create.integration.validator.d.ts +0 -3
  825. package/dist/integrationsBuilder/validators/joi-validators/create.integration.validator.js +0 -10
  826. package/dist/integrationsBuilder/validators/joi-validators/create.integration.validator.js.map +0 -1
  827. package/dist/integrationsBuilder/validators/joi-validators/create.integrationApp.validator.d.ts +0 -4
  828. package/dist/integrationsBuilder/validators/joi-validators/create.integrationApp.validator.js +0 -26
  829. package/dist/integrationsBuilder/validators/joi-validators/create.integrationApp.validator.js.map +0 -1
  830. package/dist/integrationsBuilder/validators/joi-validators/create.integrationCache.validator.d.ts +0 -3
  831. package/dist/integrationsBuilder/validators/joi-validators/create.integrationCache.validator.js +0 -8
  832. package/dist/integrationsBuilder/validators/joi-validators/create.integrationCache.validator.js.map +0 -1
  833. package/dist/integrationsBuilder/validators/joi-validators/create.integrationDatabase.validator.d.ts +0 -3
  834. package/dist/integrationsBuilder/validators/joi-validators/create.integrationDatabase.validator.js +0 -8
  835. package/dist/integrationsBuilder/validators/joi-validators/create.integrationDatabase.validator.js.map +0 -1
  836. package/dist/integrationsBuilder/validators/joi-validators/create.integrationEnv.validator.d.ts +0 -3
  837. package/dist/integrationsBuilder/validators/joi-validators/create.integrationEnv.validator.js +0 -10
  838. package/dist/integrationsBuilder/validators/joi-validators/create.integrationEnv.validator.js.map +0 -1
  839. package/dist/integrationsBuilder/validators/joi-validators/create.integrationFeature.validator.d.ts +0 -3
  840. package/dist/integrationsBuilder/validators/joi-validators/create.integrationFeature.validator.js +0 -60
  841. package/dist/integrationsBuilder/validators/joi-validators/create.integrationFeature.validator.js.map +0 -1
  842. package/dist/integrationsBuilder/validators/joi-validators/create.integrationFunction.validator.d.ts +0 -3
  843. package/dist/integrationsBuilder/validators/joi-validators/create.integrationFunction.validator.js +0 -8
  844. package/dist/integrationsBuilder/validators/joi-validators/create.integrationFunction.validator.js.map +0 -1
  845. package/dist/integrationsBuilder/validators/joi-validators/create.integrationJob.validator.d.ts +0 -3
  846. package/dist/integrationsBuilder/validators/joi-validators/create.integrationJob.validator.js +0 -8
  847. package/dist/integrationsBuilder/validators/joi-validators/create.integrationJob.validator.js.map +0 -1
  848. package/dist/integrationsBuilder/validators/joi-validators/create.integrationNotification.validator.d.ts +0 -3
  849. package/dist/integrationsBuilder/validators/joi-validators/create.integrationNotification.validator.js +0 -8
  850. package/dist/integrationsBuilder/validators/joi-validators/create.integrationNotification.validator.js.map +0 -1
  851. package/dist/integrationsBuilder/validators/joi-validators/update.integrationApp.validator.d.ts +0 -3
  852. package/dist/integrationsBuilder/validators/joi-validators/update.integrationApp.validator.js +0 -9
  853. package/dist/integrationsBuilder/validators/joi-validators/update.integrationApp.validator.js.map +0 -1
  854. package/dist/integrationsBuilder/validators/joi-validators/update.integrationCache.validator.d.ts +0 -3
  855. package/dist/integrationsBuilder/validators/joi-validators/update.integrationCache.validator.js +0 -8
  856. package/dist/integrationsBuilder/validators/joi-validators/update.integrationCache.validator.js.map +0 -1
  857. package/dist/integrationsBuilder/validators/joi-validators/update.integrationDatabase.validator.d.ts +0 -3
  858. package/dist/integrationsBuilder/validators/joi-validators/update.integrationDatabase.validator.js +0 -8
  859. package/dist/integrationsBuilder/validators/joi-validators/update.integrationDatabase.validator.js.map +0 -1
  860. package/dist/integrationsBuilder/validators/joi-validators/update.integrationEnv.validator.d.ts +0 -3
  861. package/dist/integrationsBuilder/validators/joi-validators/update.integrationEnv.validator.js +0 -8
  862. package/dist/integrationsBuilder/validators/joi-validators/update.integrationEnv.validator.js.map +0 -1
  863. package/dist/integrationsBuilder/validators/joi-validators/update.integrationFeature.validator.d.ts +0 -3
  864. package/dist/integrationsBuilder/validators/joi-validators/update.integrationFeature.validator.js +0 -8
  865. package/dist/integrationsBuilder/validators/joi-validators/update.integrationFeature.validator.js.map +0 -1
  866. package/dist/integrationsBuilder/validators/joi-validators/update.integrationFunction.validator copy.d.ts +0 -3
  867. package/dist/integrationsBuilder/validators/joi-validators/update.integrationFunction.validator copy.js +0 -8
  868. package/dist/integrationsBuilder/validators/joi-validators/update.integrationFunction.validator copy.js.map +0 -1
  869. package/dist/integrationsBuilder/validators/joi-validators/update.integrationJob.validator.d.ts +0 -3
  870. package/dist/integrationsBuilder/validators/joi-validators/update.integrationJob.validator.js +0 -8
  871. package/dist/integrationsBuilder/validators/joi-validators/update.integrationJob.validator.js.map +0 -1
  872. package/dist/integrationsBuilder/validators/joi-validators/update.integrationNotification.validator.d.ts +0 -3
  873. package/dist/integrationsBuilder/validators/joi-validators/update.integrationNotification.validator.js +0 -8
  874. package/dist/integrationsBuilder/validators/joi-validators/update.integrationNotification.validator.js.map +0 -1
  875. package/dist/postman.d.ts +0 -1
  876. package/dist/postman.js +0 -21674
  877. package/dist/postman.js.map +0 -1
  878. package/dist/processor/services/fallback.service.d.ts +0 -5
  879. package/dist/processor/services/fallback.service.js +0 -43
  880. package/dist/processor/services/fallback.service.js.map +0 -1
  881. package/dist/processor/services/messagebrokers/aws-sqs.service.js +0 -77
  882. package/dist/processor/services/messagebrokers/aws-sqs.service.js.map +0 -1
  883. package/dist/processor/services/messagebrokers/google-pubsub.service.js.map +0 -1
  884. package/dist/processor/services/messagebrokers/index.d.ts +0 -3
  885. package/dist/processor/services/messagebrokers/index.js +0 -26
  886. package/dist/processor/services/messagebrokers/index.js.map +0 -1
  887. package/dist/processor/services/messagebrokers/kafka.service.d.ts +0 -14
  888. package/dist/processor/services/messagebrokers/kafka.service.js +0 -45
  889. package/dist/processor/services/messagebrokers/kafka.service.js.map +0 -1
  890. package/dist/processor/services/messagebrokers/messagebrokers.type.d.ts +0 -6
  891. package/dist/processor/services/messagebrokers/messagebrokers.type.js.map +0 -1
  892. package/dist/processor/services/messagebrokers/rabbitmq.service.d.ts +0 -14
  893. package/dist/processor/services/messagebrokers/rabbitmq.service.js.map +0 -1
  894. package/dist/processor/services/messagebrokers/redis.service.js.map +0 -1
  895. package/dist/processor/services/quota.service.d.ts +0 -15
  896. package/dist/processor/services/quota.service.js +0 -63
  897. package/dist/processor/services/quota.service.js.map +0 -1
  898. package/dist/processor/utils/mongo.util.d.ts +0 -0
  899. package/dist/processor/utils/mongo.util.js +0 -152
  900. package/dist/processor/utils/mongo.util.js.map +0 -1
  901. package/dist/processor/utils/postgres.util.d.ts +0 -14
  902. package/dist/processor/utils/postgres.util.js +0 -83
  903. package/dist/processor/utils/postgres.util.js.map +0 -1
  904. package/dist/products/validators/joi-validators/create.product.validator.d.ts +0 -3
  905. package/dist/products/validators/joi-validators/create.product.validator.js +0 -10
  906. package/dist/products/validators/joi-validators/create.product.validator.js.map +0 -1
  907. package/dist/test/test.appBuilder.d.ts +0 -1
  908. package/dist/test/test.appBuilder.js +0 -16
  909. package/dist/test/test.appBuilder.js.map +0 -1
  910. package/dist/test/test.import.d.ts +0 -1
  911. package/dist/test/test.import.js +0 -1460
  912. package/dist/test/test.import.js.map +0 -1
  913. package/dist/test/test.import.openapi.d.ts +0 -1
  914. package/dist/test/test.import.openapi.js +0 -76
  915. package/dist/test/test.import.openapi.js.map +0 -1
  916. package/dist/test/test.imports.d.ts +0 -1
  917. package/dist/test/test.imports.js +0 -62
  918. package/dist/test/test.imports.js.map +0 -1
  919. package/dist/test/test.logs.d.ts +0 -1
  920. package/dist/test/test.logs.js +0 -18
  921. package/dist/test/test.logs.js.map +0 -1
  922. package/dist/test/test.processor.d.ts +0 -1
  923. package/dist/test/test.processor.js +0 -123
  924. package/dist/test/test.processor.js.map +0 -1
  925. package/dist/test/test.productBuilder.d.ts +0 -1
  926. package/dist/test/test.productBuilder.js +0 -661
  927. package/dist/test/test.productBuilder.js.map +0 -1
  928. package/dist/test.appBuilder.d.ts +0 -1
  929. package/dist/test.appBuilder.js +0 -14
  930. package/dist/test.appBuilder.js.map +0 -1
  931. package/dist/test.import.d.ts +0 -0
  932. package/dist/test.import.js +0 -24
  933. package/dist/test.import.js.map +0 -1
  934. package/dist/test.imports.d.ts +0 -1
  935. package/dist/test.imports.js +0 -28
  936. package/dist/test.imports.js.map +0 -1
  937. package/dist/test.integrationBuilder.d.ts +0 -1
  938. package/dist/test.integrationBuilder.js +0 -276
  939. package/dist/test.integrationBuilder.js.map +0 -1
  940. package/dist/test.processor.d.ts +0 -1
  941. package/dist/test.processor.js +0 -23
  942. package/dist/test.processor.js.map +0 -1
  943. package/dist/test.utils.d.ts +0 -1
  944. package/dist/test.utils.js +0 -25
  945. package/dist/test.utils.js.map +0 -1
  946. package/dist/types/integrationsBuilder.types.d.ts +0 -276
  947. package/dist/types/integrationsBuilder.types.js +0 -51
  948. package/dist/types/integrationsBuilder.types.js.map +0 -1
  949. /package/dist/{actions/actions.repo.d.ts → pricing/pricing.repo.d.ts} +0 -0
  950. /package/dist/{appBuilder/validators/joi-validators/create.app.validator.d.ts → products/validators/joi-validators/create.productGraph.validator.d.ts} +0 -0
  951. /package/dist/{appBuilder/validators/joi-validators/update.validation.entityData.validator.d.ts → products/validators/joi-validators/update.productGraph.validator.d.ts} +0 -0
  952. /package/dist/{actions/actions.service.d.ts → types/request-tracker.interface.d.ts} +0 -0
@@ -0,0 +1,905 @@
1
+ "use strict";
2
+ /**
3
+ * NotificationsService - Main Notifications Service Class
4
+ *
5
+ * Provides a unified interface for sending notifications through multiple channels:
6
+ * - Push notifications (Firebase, Expo)
7
+ * - Email (SMTP)
8
+ * - SMS (Twilio, Nexmo, Plivo)
9
+ * - Callbacks (HTTP webhooks)
10
+ */
11
+ var __importDefault = (this && this.__importDefault) || function (mod) {
12
+ return (mod && mod.__esModule) ? mod : { "default": mod };
13
+ };
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.NotificationsService = void 0;
16
+ exports.notificationsService = notificationsService;
17
+ const products_service_1 = __importDefault(require("../products/services/products.service"));
18
+ const processor_service_1 = __importDefault(require("../processor/services/processor.service"));
19
+ const logs_service_1 = __importDefault(require("../logs/logs.service"));
20
+ const logs_types_1 = require("../logs/logs.types");
21
+ const processor_utils_1 = require("../processor/utils/processor.utils");
22
+ const cache_manager_1 = require("../cache/cache.manager");
23
+ const sessions_1 = require("../sessions");
24
+ const types_1 = require("./types");
25
+ /**
26
+ * NotificationsService - Send notifications through push, email, SMS, and callbacks
27
+ *
28
+ * @example
29
+ * ```typescript
30
+ * const notifications = new NotificationsService({
31
+ * workspace_id: 'ws-123',
32
+ * public_key: 'pk-123',
33
+ * user_id: 'user-123',
34
+ * token: 'token-123',
35
+ * env_type: 'production',
36
+ * });
37
+ *
38
+ * // Send push notification
39
+ * await notifications.push({
40
+ * product: 'my-product',
41
+ * env: 'production',
42
+ * notification: 'alerts:welcome-message',
43
+ * input: {
44
+ * device_tokens: ['token1', 'token2'],
45
+ * title: { name: 'John' },
46
+ * body: { message: 'Welcome!' },
47
+ * },
48
+ * });
49
+ *
50
+ * // Send email
51
+ * await notifications.email({
52
+ * product: 'my-product',
53
+ * env: 'production',
54
+ * notification: 'emails:order-confirmation',
55
+ * input: {
56
+ * recipients: ['user@example.com'],
57
+ * subject: { orderId: '12345' },
58
+ * template: { orderDetails: '...' },
59
+ * },
60
+ * });
61
+ * ```
62
+ */
63
+ class NotificationsService {
64
+ /**
65
+ * Create a new NotificationsService instance
66
+ * @param config - Configuration for authentication and workspace context
67
+ */
68
+ constructor(config) {
69
+ /** ProductBuilder instances cache (keyed by product tag) */
70
+ this.productBuilders = new Map();
71
+ /** LogService instance for logging operations */
72
+ this.logService = null;
73
+ /** Current product ID for logging */
74
+ this.productId = '';
75
+ /** Cache manager for 3-tier caching */
76
+ this.cacheManager = null;
77
+ /** Private keys per product for cache encryption */
78
+ this.privateKeys = new Map();
79
+ /** Local cache for cache configurations to avoid repeated API calls */
80
+ this.cacheConfigCache = new Map();
81
+ this.config = config;
82
+ this._privateKey = config.private_key;
83
+ // Initialize CacheManager if Redis client is provided
84
+ if (config.redis_client) {
85
+ this.cacheManager = new cache_manager_1.CacheManager({
86
+ workspace_id: config.workspace_id,
87
+ public_key: config.public_key,
88
+ user_id: config.user_id,
89
+ token: config.token,
90
+ env_type: config.env_type,
91
+ redis_client: config.redis_client,
92
+ });
93
+ }
94
+ }
95
+ // ==================== INTERNAL HELPERS ====================
96
+ /**
97
+ * Create a new ProductBuilder instance
98
+ */
99
+ createNewProductBuilder() {
100
+ return new products_service_1.default({
101
+ workspace_id: this.config.workspace_id,
102
+ public_key: this.config.public_key,
103
+ user_id: this.config.user_id,
104
+ token: this.config.token,
105
+ env_type: this.config.env_type,
106
+ });
107
+ }
108
+ /**
109
+ * Get or create a ProductBuilder instance for the given product tag
110
+ */
111
+ async getProductBuilder(productTag) {
112
+ let builder = this.productBuilders.get(productTag);
113
+ if (!builder) {
114
+ builder = this.createNewProductBuilder();
115
+ await builder.initializeProductByTag(productTag);
116
+ this.productBuilders.set(productTag, builder);
117
+ this.productId = builder.fetchProductId() || '';
118
+ }
119
+ return builder;
120
+ }
121
+ /**
122
+ * Initialize logging service
123
+ */
124
+ initializeLogService() {
125
+ if (!this.logService) {
126
+ this.logService = new logs_service_1.default({
127
+ product_id: this.productId,
128
+ workspace_id: this.config.workspace_id,
129
+ public_key: this.config.public_key,
130
+ user_id: this.config.user_id,
131
+ token: this.config.token,
132
+ env_type: this.config.env_type,
133
+ });
134
+ }
135
+ }
136
+ /**
137
+ * Validate cache tag exists in product and return cache configuration
138
+ * Uses local in-memory cache to avoid repeated API calls (5 minute TTL)
139
+ */
140
+ async validateCache(productTag, cacheTag) {
141
+ const cacheKey = `${productTag}:${cacheTag}`;
142
+ const cached = this.cacheConfigCache.get(cacheKey);
143
+ const now = Date.now();
144
+ const CACHE_TTL = 5 * 60 * 1000; // 5 minutes
145
+ // Return cached config if still valid
146
+ if (cached && (now - cached.fetchedAt) < CACHE_TTL) {
147
+ return { expiry: cached.expiry };
148
+ }
149
+ // Fetch from API and cache the result
150
+ const builder = await this.getProductBuilder(productTag);
151
+ const cache = await builder.fetchCache(cacheTag);
152
+ if (!cache) {
153
+ throw new Error(`Cache configuration '${cacheTag}' does not exist`);
154
+ }
155
+ this.cacheConfigCache.set(cacheKey, { expiry: cache.expiry, fetchedAt: now });
156
+ return { expiry: cache.expiry };
157
+ }
158
+ /**
159
+ * Create a new ProcessorService instance
160
+ */
161
+ createNewProcessor() {
162
+ return new processor_service_1.default({
163
+ workspace_id: this.config.workspace_id,
164
+ public_key: this.config.public_key,
165
+ user_id: this.config.user_id,
166
+ token: this.config.token,
167
+ env_type: this.config.env_type,
168
+ private_key: this._privateKey,
169
+ });
170
+ }
171
+ /**
172
+ * Parse notification tag to extract notification and message tags
173
+ * Format: notification_tag:message_tag
174
+ */
175
+ parseNotificationTag(tag) {
176
+ const parts = tag.split(':');
177
+ if (parts.length !== 2) {
178
+ throw new Error(`Invalid notification tag format: "${tag}". Expected format: "notification_tag:message_tag"`);
179
+ }
180
+ return {
181
+ notificationTag: parts[0],
182
+ messageTag: parts[1],
183
+ };
184
+ }
185
+ /**
186
+ * Build INotificationRequest from channel-specific input
187
+ */
188
+ buildNotificationRequest(options) {
189
+ const request = {};
190
+ if (options.push_notification) {
191
+ request.push_notification = {
192
+ device_tokens: options.push_notification.device_tokens,
193
+ title: options.push_notification.title,
194
+ body: options.push_notification.body,
195
+ data: options.push_notification.data,
196
+ };
197
+ }
198
+ if (options.email) {
199
+ request.email = {
200
+ recipients: options.email.recipients,
201
+ subject: options.email.subject,
202
+ template: options.email.template,
203
+ };
204
+ }
205
+ if (options.sms) {
206
+ request.sms = {
207
+ recipients: options.sms.recipients,
208
+ body: options.sms.body,
209
+ };
210
+ }
211
+ if (options.callback) {
212
+ request.callback = {
213
+ query: options.callback.query,
214
+ headers: options.callback.headers,
215
+ params: options.callback.params,
216
+ body: options.callback.body,
217
+ };
218
+ }
219
+ return request;
220
+ }
221
+ // ==================== PUSH NOTIFICATIONS ====================
222
+ /**
223
+ * Send a push notification
224
+ *
225
+ * @param options - Push notification options
226
+ * @returns Notification result
227
+ *
228
+ * @example
229
+ * ```typescript
230
+ * const result = await notifications.push({
231
+ * product: 'my-product',
232
+ * env: 'production',
233
+ * notification: 'alerts:welcome',
234
+ * input: {
235
+ * device_tokens: ['device-token-1', 'device-token-2'],
236
+ * title: { name: 'John' },
237
+ * body: { message: 'Welcome to our app!' },
238
+ * data: { action: 'open_home' },
239
+ * },
240
+ * });
241
+ * ```
242
+ */
243
+ async push(options) {
244
+ var _a, _b, _c;
245
+ const { product, env, notification, input, session, cache } = options;
246
+ const start = Date.now();
247
+ const { notificationTag, messageTag } = this.parseNotificationTag(notification);
248
+ let sessionLogFields = {};
249
+ let resolvedInput = input;
250
+ try {
251
+ await this.getProductBuilder(product);
252
+ this.initializeLogService();
253
+ // Store private key for cache operations
254
+ this.privateKeys.set(product, this._privateKey);
255
+ // Process session if provided - verify and resolve $Session{} references
256
+ if (session && this._privateKey) {
257
+ const productBuilder = await this.getProductBuilder(product);
258
+ const sessionResult = await (0, sessions_1.processSessionForExecution)(session, this._privateKey, input, env, {
259
+ fetchSessionSelector: async (sessionTag) => {
260
+ const sessionConfig = await productBuilder.fetchSession(sessionTag);
261
+ return sessionConfig === null || sessionConfig === void 0 ? void 0 : sessionConfig.selector;
262
+ },
263
+ });
264
+ if (sessionResult.error) {
265
+ throw new Error(`Session validation failed: ${sessionResult.error}`);
266
+ }
267
+ sessionLogFields = sessionResult.logFields;
268
+ resolvedInput = sessionResult.input;
269
+ }
270
+ const processId = (0, processor_utils_1.generateObjectId)();
271
+ // Check cache for idempotency (prevent duplicate sends with same data)
272
+ if (cache && this.cacheManager && this._privateKey) {
273
+ const cacheConfig = await this.validateCache(product, cache);
274
+ const cacheOptions = {
275
+ cache_tag: cache,
276
+ product_tag: product,
277
+ component_tag: `${notificationTag}:${messageTag}`,
278
+ component_type: 'notification',
279
+ operation: 'push',
280
+ input: { notification, device_tokens: input.device_tokens, title: input.title, body: input.body },
281
+ privateKey: this._privateKey,
282
+ expiry: cacheConfig.expiry,
283
+ };
284
+ const cached = await this.cacheManager.fetch(cacheOptions);
285
+ if (cached.hit && cached.data) {
286
+ const end = Date.now();
287
+ (_a = this.logService) === null || _a === void 0 ? void 0 : _a.add({
288
+ process_id: processId,
289
+ product_tag: product,
290
+ env,
291
+ start,
292
+ end,
293
+ type: logs_types_1.LogEventTypes.NOTIFICATIONS,
294
+ name: 'Push notification - cache hit',
295
+ message: `Push notification cache hit (${cached.source})`,
296
+ data: { notification, cache_source: cached.source },
297
+ status: logs_types_1.LogEventStatus.SUCCESS,
298
+ cache_tag: cache,
299
+ cache_key: cached.key,
300
+ cache_status: true,
301
+ });
302
+ return cached.data;
303
+ }
304
+ }
305
+ const processor = this.createNewProcessor();
306
+ const notificationInput = {
307
+ product,
308
+ env,
309
+ event: notification,
310
+ input: {
311
+ push_notification: {
312
+ device_tokens: resolvedInput.device_tokens,
313
+ title: resolvedInput.title,
314
+ body: resolvedInput.body,
315
+ data: resolvedInput.data,
316
+ },
317
+ },
318
+ session,
319
+ cache,
320
+ };
321
+ await processor.processNotification(notificationInput);
322
+ const result = {
323
+ success: true,
324
+ channel: types_1.NotificationChannelType.PUSH,
325
+ messageId: processId,
326
+ };
327
+ // Store in cache for idempotency (fire-and-forget)
328
+ if (cache && this.cacheManager && this._privateKey) {
329
+ const cacheConfig = await this.validateCache(product, cache);
330
+ this.cacheManager.store({
331
+ cache_tag: cache,
332
+ product_tag: product,
333
+ component_tag: `${notificationTag}:${messageTag}`,
334
+ component_type: 'notification',
335
+ operation: 'push',
336
+ input: { notification, device_tokens: resolvedInput.device_tokens, title: resolvedInput.title, body: resolvedInput.body },
337
+ privateKey: this._privateKey,
338
+ expiry: cacheConfig.expiry,
339
+ }, result);
340
+ }
341
+ const end = Date.now();
342
+ (_b = this.logService) === null || _b === void 0 ? void 0 : _b.add(Object.assign({ process_id: processId, product_tag: product, env,
343
+ start,
344
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'Push notification sent', message: 'Push notification sent successfully', data: { notification, recipients: resolvedInput.device_tokens.length }, status: logs_types_1.LogEventStatus.SUCCESS }, sessionLogFields));
345
+ return result;
346
+ }
347
+ catch (error) {
348
+ const end = Date.now();
349
+ const errorMessage = error instanceof Error ? error.message : String(error);
350
+ (_c = this.logService) === null || _c === void 0 ? void 0 : _c.add(Object.assign({ process_id: (0, processor_utils_1.generateObjectId)(), product_tag: product, env,
351
+ start,
352
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'Push notification failed', message: errorMessage, data: { notification }, status: logs_types_1.LogEventStatus.FAIL }, sessionLogFields));
353
+ return {
354
+ success: false,
355
+ channel: types_1.NotificationChannelType.PUSH,
356
+ error: errorMessage,
357
+ };
358
+ }
359
+ }
360
+ // ==================== EMAIL ====================
361
+ /**
362
+ * Send an email
363
+ *
364
+ * @param options - Email options
365
+ * @returns Notification result
366
+ *
367
+ * @example
368
+ * ```typescript
369
+ * const result = await notifications.email({
370
+ * product: 'my-product',
371
+ * env: 'production',
372
+ * notification: 'emails:order-confirmation',
373
+ * input: {
374
+ * recipients: ['user@example.com', 'admin@example.com'],
375
+ * subject: { orderId: '12345' },
376
+ * template: {
377
+ * customerName: 'John Doe',
378
+ * orderTotal: '$99.99',
379
+ * },
380
+ * },
381
+ * });
382
+ * ```
383
+ */
384
+ async email(options) {
385
+ var _a, _b, _c;
386
+ const { product, env, notification, input, session, cache } = options;
387
+ const start = Date.now();
388
+ const { notificationTag, messageTag } = this.parseNotificationTag(notification);
389
+ let sessionLogFields = {};
390
+ let resolvedInput = input;
391
+ try {
392
+ await this.getProductBuilder(product);
393
+ this.initializeLogService();
394
+ // Store private key for cache operations
395
+ this.privateKeys.set(product, this._privateKey);
396
+ // Process session if provided - verify and resolve $Session{} references
397
+ if (session && this._privateKey) {
398
+ const productBuilder = await this.getProductBuilder(product);
399
+ const sessionResult = await (0, sessions_1.processSessionForExecution)(session, this._privateKey, input, env, {
400
+ fetchSessionSelector: async (sessionTag) => {
401
+ const sessionConfig = await productBuilder.fetchSession(sessionTag);
402
+ return sessionConfig === null || sessionConfig === void 0 ? void 0 : sessionConfig.selector;
403
+ },
404
+ });
405
+ if (sessionResult.error) {
406
+ throw new Error(`Session validation failed: ${sessionResult.error}`);
407
+ }
408
+ sessionLogFields = sessionResult.logFields;
409
+ resolvedInput = sessionResult.input;
410
+ }
411
+ const processId = (0, processor_utils_1.generateObjectId)();
412
+ // Check cache for idempotency (prevent duplicate sends with same data)
413
+ if (cache && this.cacheManager && this._privateKey) {
414
+ const cacheConfig = await this.validateCache(product, cache);
415
+ const cacheOptions = {
416
+ cache_tag: cache,
417
+ product_tag: product,
418
+ component_tag: `${notificationTag}:${messageTag}`,
419
+ component_type: 'notification',
420
+ operation: 'email',
421
+ input: { notification, recipients: input.recipients, subject: input.subject },
422
+ privateKey: this._privateKey,
423
+ expiry: cacheConfig.expiry,
424
+ };
425
+ const cached = await this.cacheManager.fetch(cacheOptions);
426
+ if (cached.hit && cached.data) {
427
+ const end = Date.now();
428
+ (_a = this.logService) === null || _a === void 0 ? void 0 : _a.add({
429
+ process_id: processId,
430
+ product_tag: product,
431
+ env,
432
+ start,
433
+ end,
434
+ type: logs_types_1.LogEventTypes.NOTIFICATIONS,
435
+ name: 'Email - cache hit',
436
+ message: `Email cache hit (${cached.source})`,
437
+ data: { notification, cache_source: cached.source },
438
+ status: logs_types_1.LogEventStatus.SUCCESS,
439
+ cache_tag: cache,
440
+ cache_key: cached.key,
441
+ cache_status: true,
442
+ });
443
+ return cached.data;
444
+ }
445
+ }
446
+ const processor = this.createNewProcessor();
447
+ const notificationInput = {
448
+ product,
449
+ env,
450
+ event: notification,
451
+ input: {
452
+ email: {
453
+ recipients: resolvedInput.recipients,
454
+ subject: resolvedInput.subject,
455
+ template: resolvedInput.template,
456
+ },
457
+ },
458
+ session,
459
+ cache,
460
+ };
461
+ await processor.processNotification(notificationInput);
462
+ const result = {
463
+ success: true,
464
+ channel: types_1.NotificationChannelType.EMAIL,
465
+ messageId: processId,
466
+ };
467
+ // Store in cache for idempotency (fire-and-forget)
468
+ if (cache && this.cacheManager && this._privateKey) {
469
+ const cacheConfig = await this.validateCache(product, cache);
470
+ this.cacheManager.store({
471
+ cache_tag: cache,
472
+ product_tag: product,
473
+ component_tag: `${notificationTag}:${messageTag}`,
474
+ component_type: 'notification',
475
+ operation: 'email',
476
+ input: { notification, recipients: resolvedInput.recipients, subject: resolvedInput.subject },
477
+ privateKey: this._privateKey,
478
+ expiry: cacheConfig.expiry,
479
+ }, result);
480
+ }
481
+ const end = Date.now();
482
+ (_b = this.logService) === null || _b === void 0 ? void 0 : _b.add(Object.assign({ process_id: processId, product_tag: product, env,
483
+ start,
484
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'Email sent', message: 'Email sent successfully', data: { notification, recipients: resolvedInput.recipients.length }, status: logs_types_1.LogEventStatus.SUCCESS }, sessionLogFields));
485
+ return result;
486
+ }
487
+ catch (error) {
488
+ const end = Date.now();
489
+ const errorMessage = error instanceof Error ? error.message : String(error);
490
+ (_c = this.logService) === null || _c === void 0 ? void 0 : _c.add(Object.assign({ process_id: (0, processor_utils_1.generateObjectId)(), product_tag: product, env,
491
+ start,
492
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'Email failed', message: errorMessage, data: { notification }, status: logs_types_1.LogEventStatus.FAIL }, sessionLogFields));
493
+ return {
494
+ success: false,
495
+ channel: types_1.NotificationChannelType.EMAIL,
496
+ error: errorMessage,
497
+ };
498
+ }
499
+ }
500
+ // ==================== SMS ====================
501
+ /**
502
+ * Send an SMS
503
+ *
504
+ * @param options - SMS options
505
+ * @returns Notification result
506
+ *
507
+ * @example
508
+ * ```typescript
509
+ * const result = await notifications.sms({
510
+ * product: 'my-product',
511
+ * env: 'production',
512
+ * notification: 'sms:verification',
513
+ * input: {
514
+ * recipients: ['+1234567890', '+0987654321'],
515
+ * body: { code: '123456' },
516
+ * },
517
+ * });
518
+ * ```
519
+ */
520
+ async sms(options) {
521
+ var _a, _b, _c;
522
+ const { product, env, notification, input, session, cache } = options;
523
+ const start = Date.now();
524
+ const { notificationTag, messageTag } = this.parseNotificationTag(notification);
525
+ let sessionLogFields = {};
526
+ let resolvedInput = input;
527
+ try {
528
+ await this.getProductBuilder(product);
529
+ this.initializeLogService();
530
+ // Store private key for cache operations
531
+ this.privateKeys.set(product, this._privateKey);
532
+ // Process session if provided - verify and resolve $Session{} references
533
+ if (session && this._privateKey) {
534
+ const productBuilder = await this.getProductBuilder(product);
535
+ const sessionResult = await (0, sessions_1.processSessionForExecution)(session, this._privateKey, input, env, {
536
+ fetchSessionSelector: async (sessionTag) => {
537
+ const sessionConfig = await productBuilder.fetchSession(sessionTag);
538
+ return sessionConfig === null || sessionConfig === void 0 ? void 0 : sessionConfig.selector;
539
+ },
540
+ });
541
+ if (sessionResult.error) {
542
+ throw new Error(`Session validation failed: ${sessionResult.error}`);
543
+ }
544
+ sessionLogFields = sessionResult.logFields;
545
+ resolvedInput = sessionResult.input;
546
+ }
547
+ const processId = (0, processor_utils_1.generateObjectId)();
548
+ // Check cache for idempotency (prevent duplicate sends with same data)
549
+ if (cache && this.cacheManager && this._privateKey) {
550
+ const cacheConfig = await this.validateCache(product, cache);
551
+ const cacheOptions = {
552
+ cache_tag: cache,
553
+ product_tag: product,
554
+ component_tag: `${notificationTag}:${messageTag}`,
555
+ component_type: 'notification',
556
+ operation: 'sms',
557
+ input: { notification, recipients: resolvedInput.recipients, body: resolvedInput.body },
558
+ privateKey: this._privateKey,
559
+ expiry: cacheConfig.expiry,
560
+ };
561
+ const cached = await this.cacheManager.fetch(cacheOptions);
562
+ if (cached.hit && cached.data) {
563
+ const end = Date.now();
564
+ (_a = this.logService) === null || _a === void 0 ? void 0 : _a.add(Object.assign({ process_id: processId, product_tag: product, env,
565
+ start,
566
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'SMS - cache hit', message: `SMS cache hit (${cached.source})`, data: { notification, cache_source: cached.source }, status: logs_types_1.LogEventStatus.SUCCESS, cache_tag: cache, cache_key: cached.key, cache_status: true }, sessionLogFields));
567
+ return cached.data;
568
+ }
569
+ }
570
+ const processor = this.createNewProcessor();
571
+ const notificationInput = {
572
+ product,
573
+ env,
574
+ event: notification,
575
+ input: {
576
+ sms: {
577
+ recipients: resolvedInput.recipients,
578
+ body: resolvedInput.body,
579
+ },
580
+ },
581
+ session,
582
+ cache,
583
+ };
584
+ await processor.processNotification(notificationInput);
585
+ const result = {
586
+ success: true,
587
+ channel: types_1.NotificationChannelType.SMS,
588
+ messageId: processId,
589
+ };
590
+ // Store in cache for idempotency (fire-and-forget)
591
+ if (cache && this.cacheManager && this._privateKey) {
592
+ const cacheConfig = await this.validateCache(product, cache);
593
+ this.cacheManager.store({
594
+ cache_tag: cache,
595
+ product_tag: product,
596
+ component_tag: `${notificationTag}:${messageTag}`,
597
+ component_type: 'notification',
598
+ operation: 'sms',
599
+ input: { notification, recipients: resolvedInput.recipients, body: resolvedInput.body },
600
+ privateKey: this._privateKey,
601
+ expiry: cacheConfig.expiry,
602
+ }, result);
603
+ }
604
+ const end = Date.now();
605
+ (_b = this.logService) === null || _b === void 0 ? void 0 : _b.add(Object.assign({ process_id: processId, product_tag: product, env,
606
+ start,
607
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'SMS sent', message: 'SMS sent successfully', data: { notification, recipients: resolvedInput.recipients.length }, status: logs_types_1.LogEventStatus.SUCCESS }, sessionLogFields));
608
+ return result;
609
+ }
610
+ catch (error) {
611
+ const end = Date.now();
612
+ const errorMessage = error instanceof Error ? error.message : String(error);
613
+ (_c = this.logService) === null || _c === void 0 ? void 0 : _c.add(Object.assign({ process_id: (0, processor_utils_1.generateObjectId)(), product_tag: product, env,
614
+ start,
615
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'SMS failed', message: errorMessage, data: { notification }, status: logs_types_1.LogEventStatus.FAIL }, sessionLogFields));
616
+ return {
617
+ success: false,
618
+ channel: types_1.NotificationChannelType.SMS,
619
+ error: errorMessage,
620
+ };
621
+ }
622
+ }
623
+ // ==================== CALLBACK ====================
624
+ /**
625
+ * Send a callback (HTTP webhook)
626
+ *
627
+ * @param options - Callback options
628
+ * @returns Notification result
629
+ *
630
+ * @example
631
+ * ```typescript
632
+ * const result = await notifications.callback({
633
+ * product: 'my-product',
634
+ * env: 'production',
635
+ * notification: 'webhooks:order-created',
636
+ * input: {
637
+ * body: {
638
+ * orderId: '12345',
639
+ * status: 'created',
640
+ * timestamp: Date.now(),
641
+ * },
642
+ * headers: {
643
+ * 'X-Custom-Header': 'value',
644
+ * },
645
+ * },
646
+ * });
647
+ * ```
648
+ */
649
+ async callback(options) {
650
+ var _a, _b, _c;
651
+ const { product, env, notification, input, session, cache } = options;
652
+ const start = Date.now();
653
+ const { notificationTag, messageTag } = this.parseNotificationTag(notification);
654
+ let sessionLogFields = {};
655
+ let resolvedInput = input;
656
+ try {
657
+ await this.getProductBuilder(product);
658
+ this.initializeLogService();
659
+ // Store private key for cache operations
660
+ this.privateKeys.set(product, this._privateKey);
661
+ // Process session if provided - verify and resolve $Session{} references
662
+ if (session && this._privateKey) {
663
+ const productBuilder = await this.getProductBuilder(product);
664
+ const sessionResult = await (0, sessions_1.processSessionForExecution)(session, this._privateKey, input, env, {
665
+ fetchSessionSelector: async (sessionTag) => {
666
+ const sessionConfig = await productBuilder.fetchSession(sessionTag);
667
+ return sessionConfig === null || sessionConfig === void 0 ? void 0 : sessionConfig.selector;
668
+ },
669
+ });
670
+ if (sessionResult.error) {
671
+ throw new Error(`Session validation failed: ${sessionResult.error}`);
672
+ }
673
+ sessionLogFields = sessionResult.logFields;
674
+ resolvedInput = sessionResult.input;
675
+ }
676
+ const processId = (0, processor_utils_1.generateObjectId)();
677
+ // Check cache for idempotency (prevent duplicate sends with same data)
678
+ if (cache && this.cacheManager && this._privateKey) {
679
+ const cacheConfig = await this.validateCache(product, cache);
680
+ const cacheOptions = {
681
+ cache_tag: cache,
682
+ product_tag: product,
683
+ component_tag: `${notificationTag}:${messageTag}`,
684
+ component_type: 'notification',
685
+ operation: 'callback',
686
+ input: { notification, body: resolvedInput.body, query: resolvedInput.query },
687
+ privateKey: this._privateKey,
688
+ expiry: cacheConfig.expiry,
689
+ };
690
+ const cached = await this.cacheManager.fetch(cacheOptions);
691
+ if (cached.hit && cached.data) {
692
+ const end = Date.now();
693
+ (_a = this.logService) === null || _a === void 0 ? void 0 : _a.add(Object.assign({ process_id: processId, product_tag: product, env,
694
+ start,
695
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'Callback - cache hit', message: `Callback cache hit (${cached.source})`, data: { notification, cache_source: cached.source }, status: logs_types_1.LogEventStatus.SUCCESS, cache_tag: cache, cache_key: cached.key, cache_status: true }, sessionLogFields));
696
+ return cached.data;
697
+ }
698
+ }
699
+ const processor = this.createNewProcessor();
700
+ const notificationInput = {
701
+ product,
702
+ env,
703
+ event: notification,
704
+ input: {
705
+ callback: {
706
+ query: resolvedInput.query,
707
+ headers: resolvedInput.headers,
708
+ params: resolvedInput.params,
709
+ body: resolvedInput.body,
710
+ },
711
+ },
712
+ session,
713
+ cache,
714
+ };
715
+ await processor.processNotification(notificationInput);
716
+ const result = {
717
+ success: true,
718
+ channel: types_1.NotificationChannelType.CALLBACK,
719
+ messageId: processId,
720
+ };
721
+ // Store in cache for idempotency (fire-and-forget)
722
+ if (cache && this.cacheManager && this._privateKey) {
723
+ const cacheConfig = await this.validateCache(product, cache);
724
+ this.cacheManager.store({
725
+ cache_tag: cache,
726
+ product_tag: product,
727
+ component_tag: `${notificationTag}:${messageTag}`,
728
+ component_type: 'notification',
729
+ operation: 'callback',
730
+ input: { notification, body: resolvedInput.body, query: resolvedInput.query },
731
+ privateKey: this._privateKey,
732
+ expiry: cacheConfig.expiry,
733
+ }, result);
734
+ }
735
+ const end = Date.now();
736
+ (_b = this.logService) === null || _b === void 0 ? void 0 : _b.add(Object.assign({ process_id: processId, product_tag: product, env,
737
+ start,
738
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'Callback sent', message: 'Callback sent successfully', data: { notification }, status: logs_types_1.LogEventStatus.SUCCESS }, sessionLogFields));
739
+ return result;
740
+ }
741
+ catch (error) {
742
+ const end = Date.now();
743
+ const errorMessage = error instanceof Error ? error.message : String(error);
744
+ (_c = this.logService) === null || _c === void 0 ? void 0 : _c.add(Object.assign({ process_id: (0, processor_utils_1.generateObjectId)(), product_tag: product, env,
745
+ start,
746
+ end, type: logs_types_1.LogEventTypes.NOTIFICATIONS, name: 'Callback failed', message: errorMessage, data: { notification }, status: logs_types_1.LogEventStatus.FAIL }, sessionLogFields));
747
+ return {
748
+ success: false,
749
+ channel: types_1.NotificationChannelType.CALLBACK,
750
+ error: errorMessage,
751
+ };
752
+ }
753
+ }
754
+ // ==================== MULTI-CHANNEL SEND ====================
755
+ /**
756
+ * Send notifications to multiple channels at once
757
+ *
758
+ * @param options - Multi-channel notification options
759
+ * @returns Results for each channel
760
+ *
761
+ * @example
762
+ * ```typescript
763
+ * const result = await notifications.send({
764
+ * product: 'my-product',
765
+ * env: 'production',
766
+ * notification: 'alerts:order-placed',
767
+ * push_notification: {
768
+ * device_tokens: ['token1'],
769
+ * title: { order: 'New Order' },
770
+ * body: { message: 'Order #12345 placed' },
771
+ * },
772
+ * email: {
773
+ * recipients: ['user@example.com'],
774
+ * subject: { orderId: '12345' },
775
+ * template: { orderDetails: '...' },
776
+ * },
777
+ * sms: {
778
+ * recipients: ['+1234567890'],
779
+ * body: { message: 'Order #12345 placed' },
780
+ * },
781
+ * });
782
+ * ```
783
+ */
784
+ async send(options) {
785
+ const results = {
786
+ success: false,
787
+ channels: {},
788
+ };
789
+ const promises = [];
790
+ if (options.push_notification) {
791
+ promises.push(this.push({
792
+ product: options.product,
793
+ env: options.env,
794
+ notification: options.notification,
795
+ input: options.push_notification,
796
+ session: options.session,
797
+ cache: options.cache,
798
+ }).then((result) => {
799
+ results.channels.push = result;
800
+ }));
801
+ }
802
+ if (options.email) {
803
+ promises.push(this.email({
804
+ product: options.product,
805
+ env: options.env,
806
+ notification: options.notification,
807
+ input: options.email,
808
+ session: options.session,
809
+ cache: options.cache,
810
+ }).then((result) => {
811
+ results.channels.email = result;
812
+ }));
813
+ }
814
+ if (options.sms) {
815
+ promises.push(this.sms({
816
+ product: options.product,
817
+ env: options.env,
818
+ notification: options.notification,
819
+ input: options.sms,
820
+ session: options.session,
821
+ cache: options.cache,
822
+ }).then((result) => {
823
+ results.channels.sms = result;
824
+ }));
825
+ }
826
+ if (options.callback) {
827
+ promises.push(this.callback({
828
+ product: options.product,
829
+ env: options.env,
830
+ notification: options.notification,
831
+ input: options.callback,
832
+ session: options.session,
833
+ cache: options.cache,
834
+ }).then((result) => {
835
+ results.channels.callback = result;
836
+ }));
837
+ }
838
+ await Promise.all(promises);
839
+ // Overall success if at least one channel succeeded
840
+ results.success = Object.values(results.channels).some((channel) => channel === null || channel === void 0 ? void 0 : channel.success);
841
+ return results;
842
+ }
843
+ // ==================== SCHEDULING ====================
844
+ /**
845
+ * Schedule a notification to be sent at a later time
846
+ *
847
+ * @param options - Notification options with scheduling
848
+ * @returns Dispatch result with job ID
849
+ *
850
+ * @example
851
+ * ```typescript
852
+ * const result = await notifications.dispatch({
853
+ * product: 'my-product',
854
+ * env: 'production',
855
+ * notification: 'reminders:payment-due',
856
+ * input: {
857
+ * push_notification: {
858
+ * device_tokens: ['token1'],
859
+ * title: { name: 'Payment' },
860
+ * body: { message: 'Your payment is due' },
861
+ * },
862
+ * },
863
+ * schedule: {
864
+ * start_at: Date.now() + 86400000, // 24 hours from now
865
+ * },
866
+ * });
867
+ * ```
868
+ */
869
+ async dispatch(options) {
870
+ const { product, env, notification, schedule, retries = 3 } = options;
871
+ await this.getProductBuilder(product);
872
+ this.initializeLogService();
873
+ const processor = this.createNewProcessor();
874
+ const notificationRequest = this.buildNotificationRequest(options);
875
+ // TODO: dispatchNotification is not yet implemented in ProcessorService
876
+ // For now, fall back to immediate processing
877
+ const notificationInput = {
878
+ product,
879
+ env,
880
+ event: notification,
881
+ input: notificationRequest,
882
+ session: options.session,
883
+ cache: options.cache,
884
+ retries,
885
+ };
886
+ await processor.processNotification(notificationInput);
887
+ const scheduledAt = (schedule === null || schedule === void 0 ? void 0 : schedule.start_at) ? Number(schedule.start_at) : Date.now();
888
+ return {
889
+ job_id: (0, processor_utils_1.generateObjectId)(),
890
+ status: 'queued',
891
+ scheduled_at: scheduledAt,
892
+ recurring: !!(schedule === null || schedule === void 0 ? void 0 : schedule.cron) || !!(schedule === null || schedule === void 0 ? void 0 : schedule.every),
893
+ next_run_at: (schedule === null || schedule === void 0 ? void 0 : schedule.cron) || (schedule === null || schedule === void 0 ? void 0 : schedule.every) ? scheduledAt : undefined,
894
+ };
895
+ }
896
+ }
897
+ exports.NotificationsService = NotificationsService;
898
+ /**
899
+ * Factory function for creating NotificationsService instances
900
+ */
901
+ function notificationsService(config) {
902
+ return new NotificationsService(config);
903
+ }
904
+ exports.default = NotificationsService;
905
+ //# sourceMappingURL=notifications.service.js.map