@zintrust/core 0.1.42 → 0.1.44

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 (381) hide show
  1. package/README.md +1 -0
  2. package/app/Controllers/AuthController.d.ts +10 -0
  3. package/app/Controllers/AuthController.d.ts.map +1 -0
  4. package/app/Controllers/AuthController.js +201 -0
  5. package/app/Controllers/UserController.d.ts +9 -0
  6. package/app/Controllers/UserController.d.ts.map +1 -0
  7. package/app/Controllers/UserController.js +8 -0
  8. package/app/Controllers/UserQueryBuilderController.d.ts +16 -0
  9. package/app/Controllers/UserQueryBuilderController.d.ts.map +1 -0
  10. package/app/Controllers/UserQueryBuilderController.js +404 -0
  11. package/app/Middleware/ProfilerMiddleware.d.ts +12 -0
  12. package/app/Middleware/ProfilerMiddleware.d.ts.map +1 -0
  13. package/app/Middleware/ProfilerMiddleware.js +47 -0
  14. package/app/Middleware/index.d.ts +59 -0
  15. package/app/Middleware/index.d.ts.map +1 -0
  16. package/app/Middleware/index.js +215 -0
  17. package/app/Models/Post.d.ts +14 -0
  18. package/app/Models/Post.d.ts.map +1 -0
  19. package/app/Models/Post.js +27 -0
  20. package/app/Models/User.d.ts +14 -0
  21. package/app/Models/User.d.ts.map +1 -0
  22. package/app/Models/User.js +44 -0
  23. package/app/Schedules/JobTracking.d.ts +3 -0
  24. package/app/Schedules/JobTracking.d.ts.map +1 -0
  25. package/app/Schedules/JobTracking.js +13 -0
  26. package/app/Schedules/index.d.ts +2 -0
  27. package/app/Schedules/index.d.ts.map +1 -0
  28. package/app/Schedules/index.js +1 -0
  29. package/app/Toolkit/Broadcast/sendBroadcast.d.ts +6 -0
  30. package/app/Toolkit/Broadcast/sendBroadcast.d.ts.map +1 -0
  31. package/app/Toolkit/Broadcast/sendBroadcast.js +5 -0
  32. package/app/Toolkit/Mail/sendWelcomeEmail.d.ts +6 -0
  33. package/app/Toolkit/Mail/sendWelcomeEmail.d.ts.map +1 -0
  34. package/app/Toolkit/Mail/sendWelcomeEmail.js +20 -0
  35. package/app/Toolkit/Notification/sendSlackNotification.d.ts +8 -0
  36. package/app/Toolkit/Notification/sendSlackNotification.d.ts.map +1 -0
  37. package/app/Toolkit/Notification/sendSlackNotification.js +5 -0
  38. package/app/Toolkit/Notification/sendSms.d.ts +6 -0
  39. package/app/Toolkit/Notification/sendSms.d.ts.map +1 -0
  40. package/app/Toolkit/Notification/sendSms.js +5 -0
  41. package/app/Types/controller.d.ts +42 -0
  42. package/app/Types/controller.d.ts.map +1 -0
  43. package/app/Types/controller.js +1 -0
  44. package/config/broadcast.d.ts +38 -0
  45. package/config/broadcast.d.ts.map +1 -0
  46. package/config/broadcast.js +37 -0
  47. package/config/cache.d.ts +40 -0
  48. package/config/cache.d.ts.map +1 -0
  49. package/config/cache.js +39 -0
  50. package/config/database.d.ts +58 -0
  51. package/config/database.d.ts.map +1 -0
  52. package/config/database.js +65 -0
  53. package/config/mail.d.ts +51 -0
  54. package/config/mail.d.ts.map +1 -0
  55. package/config/mail.js +69 -0
  56. package/config/middleware.d.ts +11 -0
  57. package/config/middleware.d.ts.map +1 -0
  58. package/config/middleware.js +30 -0
  59. package/config/notification.d.ts +33 -0
  60. package/config/notification.d.ts.map +1 -0
  61. package/config/notification.js +33 -0
  62. package/config/queue.d.ts +55 -0
  63. package/config/queue.d.ts.map +1 -0
  64. package/config/queue.js +87 -0
  65. package/config/storage.d.ts +59 -0
  66. package/config/storage.d.ts.map +1 -0
  67. package/config/storage.js +59 -0
  68. package/config/workers.d.ts +54 -0
  69. package/config/workers.d.ts.map +1 -0
  70. package/config/workers.js +83 -0
  71. package/package.json +12 -5
  72. package/packages/cloudflare-d1-proxy/src/index.d.ts +48 -0
  73. package/packages/cloudflare-d1-proxy/src/index.d.ts.map +1 -0
  74. package/packages/cloudflare-d1-proxy/src/index.js +387 -0
  75. package/packages/cloudflare-kv-proxy/src/index.d.ts +44 -0
  76. package/packages/cloudflare-kv-proxy/src/index.d.ts.map +1 -0
  77. package/packages/cloudflare-kv-proxy/src/index.js +325 -0
  78. package/packages/queue-monitor/src/QueueMonitoringService.d.ts +35 -0
  79. package/packages/queue-monitor/src/QueueMonitoringService.d.ts.map +1 -0
  80. package/packages/queue-monitor/src/QueueMonitoringService.js +194 -0
  81. package/packages/queue-monitor/src/connection.d.ts +3 -0
  82. package/packages/queue-monitor/src/connection.d.ts.map +1 -0
  83. package/packages/queue-monitor/src/connection.js +1 -0
  84. package/packages/queue-monitor/src/dashboard-ui.d.ts +7 -0
  85. package/packages/queue-monitor/src/dashboard-ui.d.ts.map +1 -0
  86. package/packages/queue-monitor/src/dashboard-ui.js +997 -0
  87. package/packages/queue-monitor/src/driver.d.ts +15 -0
  88. package/packages/queue-monitor/src/driver.d.ts.map +1 -0
  89. package/packages/queue-monitor/src/driver.js +115 -0
  90. package/packages/queue-monitor/src/index.d.ts +71 -0
  91. package/packages/queue-monitor/src/index.d.ts.map +1 -0
  92. package/packages/queue-monitor/src/index.js +296 -0
  93. package/packages/queue-monitor/src/metrics.d.ts +27 -0
  94. package/packages/queue-monitor/src/metrics.d.ts.map +1 -0
  95. package/packages/queue-monitor/src/metrics.js +92 -0
  96. package/packages/queue-monitor/src/worker.d.ts +8 -0
  97. package/packages/queue-monitor/src/worker.d.ts.map +1 -0
  98. package/packages/queue-monitor/src/worker.js +35 -0
  99. package/packages/queue-redis/src/BullMQRedisQueue.d.ts +26 -0
  100. package/packages/queue-redis/src/BullMQRedisQueue.d.ts.map +1 -0
  101. package/packages/queue-redis/src/BullMQRedisQueue.js +463 -0
  102. package/packages/queue-redis/src/HttpQueueDriver.d.ts +18 -0
  103. package/packages/queue-redis/src/HttpQueueDriver.d.ts.map +1 -0
  104. package/packages/queue-redis/src/HttpQueueDriver.js +249 -0
  105. package/packages/queue-redis/src/QueueHttpGateway.d.ts +16 -0
  106. package/packages/queue-redis/src/QueueHttpGateway.d.ts.map +1 -0
  107. package/packages/queue-redis/src/QueueHttpGateway.js +217 -0
  108. package/packages/queue-redis/src/RedisPublishClient.d.ts +14 -0
  109. package/packages/queue-redis/src/RedisPublishClient.d.ts.map +1 -0
  110. package/packages/queue-redis/src/RedisPublishClient.js +251 -0
  111. package/packages/queue-redis/src/index.d.ts +12 -0
  112. package/packages/queue-redis/src/index.d.ts.map +1 -0
  113. package/packages/queue-redis/src/index.js +10 -0
  114. package/packages/queue-redis/src/register.d.ts +6 -0
  115. package/packages/queue-redis/src/register.d.ts.map +1 -0
  116. package/packages/queue-redis/src/register.js +21 -0
  117. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts +11 -0
  118. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts.map +1 -0
  119. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.js +32 -0
  120. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts +11 -0
  121. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts.map +1 -0
  122. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.js +46 -0
  123. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts +7 -0
  124. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts.map +1 -0
  125. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.js +44 -0
  126. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts +7 -0
  127. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts.map +1 -0
  128. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.js +104 -0
  129. package/packages/workers/src/AnomalyDetection.d.ts +107 -0
  130. package/packages/workers/src/AnomalyDetection.d.ts.map +1 -0
  131. package/packages/workers/src/AnomalyDetection.js +329 -0
  132. package/packages/workers/src/AutoScaler.d.ts +128 -0
  133. package/packages/workers/src/AutoScaler.d.ts.map +1 -0
  134. package/packages/workers/src/AutoScaler.js +425 -0
  135. package/packages/workers/src/BroadcastWorker.d.ts +24 -0
  136. package/packages/workers/src/BroadcastWorker.d.ts.map +1 -0
  137. package/packages/workers/src/BroadcastWorker.js +24 -0
  138. package/packages/workers/src/CanaryController.d.ts +104 -0
  139. package/packages/workers/src/CanaryController.d.ts.map +1 -0
  140. package/packages/workers/src/CanaryController.js +424 -0
  141. package/packages/workers/src/ChaosEngineering.d.ts +80 -0
  142. package/packages/workers/src/ChaosEngineering.d.ts.map +1 -0
  143. package/packages/workers/src/ChaosEngineering.js +229 -0
  144. package/packages/workers/src/CircuitBreaker.d.ts +107 -0
  145. package/packages/workers/src/CircuitBreaker.d.ts.map +1 -0
  146. package/packages/workers/src/CircuitBreaker.js +374 -0
  147. package/packages/workers/src/ClusterLock.d.ts +91 -0
  148. package/packages/workers/src/ClusterLock.d.ts.map +1 -0
  149. package/packages/workers/src/ClusterLock.js +397 -0
  150. package/packages/workers/src/ComplianceManager.d.ts +178 -0
  151. package/packages/workers/src/ComplianceManager.d.ts.map +1 -0
  152. package/packages/workers/src/ComplianceManager.js +556 -0
  153. package/packages/workers/src/DatacenterOrchestrator.d.ts +134 -0
  154. package/packages/workers/src/DatacenterOrchestrator.d.ts.map +1 -0
  155. package/packages/workers/src/DatacenterOrchestrator.js +404 -0
  156. package/packages/workers/src/DeadLetterQueue.d.ts +123 -0
  157. package/packages/workers/src/DeadLetterQueue.d.ts.map +1 -0
  158. package/packages/workers/src/DeadLetterQueue.js +544 -0
  159. package/packages/workers/src/HealthMonitor.d.ts +43 -0
  160. package/packages/workers/src/HealthMonitor.d.ts.map +1 -0
  161. package/packages/workers/src/HealthMonitor.js +312 -0
  162. package/packages/workers/src/MultiQueueWorker.d.ts +90 -0
  163. package/packages/workers/src/MultiQueueWorker.d.ts.map +1 -0
  164. package/packages/workers/src/MultiQueueWorker.js +282 -0
  165. package/packages/workers/src/NotificationWorker.d.ts +24 -0
  166. package/packages/workers/src/NotificationWorker.d.ts.map +1 -0
  167. package/packages/workers/src/NotificationWorker.js +23 -0
  168. package/packages/workers/src/Observability.d.ts +154 -0
  169. package/packages/workers/src/Observability.d.ts.map +1 -0
  170. package/packages/workers/src/Observability.js +538 -0
  171. package/packages/workers/src/PluginManager.d.ts +124 -0
  172. package/packages/workers/src/PluginManager.d.ts.map +1 -0
  173. package/packages/workers/src/PluginManager.js +392 -0
  174. package/packages/workers/src/PriorityQueue.d.ts +118 -0
  175. package/packages/workers/src/PriorityQueue.d.ts.map +1 -0
  176. package/packages/workers/src/PriorityQueue.js +276 -0
  177. package/packages/workers/src/ResourceMonitor.d.ts +165 -0
  178. package/packages/workers/src/ResourceMonitor.d.ts.map +1 -0
  179. package/packages/workers/src/ResourceMonitor.js +632 -0
  180. package/packages/workers/src/SLAMonitor.d.ts +111 -0
  181. package/packages/workers/src/SLAMonitor.d.ts.map +1 -0
  182. package/packages/workers/src/SLAMonitor.js +274 -0
  183. package/packages/workers/src/WorkerFactory.d.ts +218 -0
  184. package/packages/workers/src/WorkerFactory.d.ts.map +1 -0
  185. package/packages/workers/src/WorkerFactory.js +2253 -0
  186. package/packages/workers/src/WorkerInit.d.ts +86 -0
  187. package/packages/workers/src/WorkerInit.d.ts.map +1 -0
  188. package/packages/workers/src/WorkerInit.js +307 -0
  189. package/packages/workers/src/WorkerMetrics.d.ts +116 -0
  190. package/packages/workers/src/WorkerMetrics.d.ts.map +1 -0
  191. package/packages/workers/src/WorkerMetrics.js +570 -0
  192. package/packages/workers/src/WorkerRegistry.d.ts +152 -0
  193. package/packages/workers/src/WorkerRegistry.d.ts.map +1 -0
  194. package/packages/workers/src/WorkerRegistry.js +396 -0
  195. package/packages/workers/src/WorkerShutdown.d.ts +70 -0
  196. package/packages/workers/src/WorkerShutdown.d.ts.map +1 -0
  197. package/packages/workers/src/WorkerShutdown.js +185 -0
  198. package/packages/workers/src/WorkerVersioning.d.ts +108 -0
  199. package/packages/workers/src/WorkerVersioning.d.ts.map +1 -0
  200. package/packages/workers/src/WorkerVersioning.js +300 -0
  201. package/packages/workers/src/config/workerConfig.d.ts +5 -0
  202. package/packages/workers/src/config/workerConfig.d.ts.map +1 -0
  203. package/packages/workers/src/config/workerConfig.js +25 -0
  204. package/packages/workers/src/createQueueWorker.d.ts +26 -0
  205. package/packages/workers/src/createQueueWorker.d.ts.map +1 -0
  206. package/packages/workers/src/createQueueWorker.js +367 -0
  207. package/packages/workers/src/dashboard/index.d.ts +2 -0
  208. package/packages/workers/src/dashboard/index.d.ts.map +1 -0
  209. package/packages/workers/src/dashboard/index.js +1 -0
  210. package/packages/workers/src/dashboard/types.d.ts +123 -0
  211. package/packages/workers/src/dashboard/types.d.ts.map +1 -0
  212. package/packages/workers/src/dashboard/types.js +1 -0
  213. package/packages/workers/src/dashboard/workers-api.d.ts +5 -0
  214. package/packages/workers/src/dashboard/workers-api.d.ts.map +1 -0
  215. package/packages/workers/src/dashboard/workers-api.js +738 -0
  216. package/packages/workers/src/helper/index.d.ts +6 -0
  217. package/packages/workers/src/helper/index.d.ts.map +1 -0
  218. package/packages/workers/src/helper/index.js +10 -0
  219. package/packages/workers/src/http/WorkerApiController.d.ts +39 -0
  220. package/packages/workers/src/http/WorkerApiController.d.ts.map +1 -0
  221. package/packages/workers/src/http/WorkerApiController.js +313 -0
  222. package/packages/workers/src/http/WorkerController.d.ts +375 -0
  223. package/packages/workers/src/http/WorkerController.d.ts.map +1 -0
  224. package/packages/workers/src/http/WorkerController.js +1454 -0
  225. package/packages/workers/src/http/WorkerMonitoringService.d.ts +12 -0
  226. package/packages/workers/src/http/WorkerMonitoringService.d.ts.map +1 -0
  227. package/packages/workers/src/http/WorkerMonitoringService.js +89 -0
  228. package/packages/workers/src/http/middleware/CustomValidation.d.ts +93 -0
  229. package/packages/workers/src/http/middleware/CustomValidation.d.ts.map +1 -0
  230. package/packages/workers/src/http/middleware/CustomValidation.js +270 -0
  231. package/packages/workers/src/http/middleware/DatacenterValidator.d.ts +4 -0
  232. package/packages/workers/src/http/middleware/DatacenterValidator.d.ts.map +1 -0
  233. package/packages/workers/src/http/middleware/DatacenterValidator.js +94 -0
  234. package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts +8 -0
  235. package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts.map +1 -0
  236. package/packages/workers/src/http/middleware/EditWorkerValidation.js +56 -0
  237. package/packages/workers/src/http/middleware/FeaturesValidator.d.ts +4 -0
  238. package/packages/workers/src/http/middleware/FeaturesValidator.d.ts.map +1 -0
  239. package/packages/workers/src/http/middleware/FeaturesValidator.js +60 -0
  240. package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts +32 -0
  241. package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts.map +1 -0
  242. package/packages/workers/src/http/middleware/InfrastructureValidator.js +226 -0
  243. package/packages/workers/src/http/middleware/OptionsValidator.d.ts +4 -0
  244. package/packages/workers/src/http/middleware/OptionsValidator.d.ts.map +1 -0
  245. package/packages/workers/src/http/middleware/OptionsValidator.js +112 -0
  246. package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts +8 -0
  247. package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts.map +1 -0
  248. package/packages/workers/src/http/middleware/PayloadSanitizer.js +42 -0
  249. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts +4 -0
  250. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts.map +1 -0
  251. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.js +140 -0
  252. package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts +4 -0
  253. package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts.map +1 -0
  254. package/packages/workers/src/http/middleware/QueueNameSanitizer.js +45 -0
  255. package/packages/workers/src/http/middleware/ValidateDriver.d.ts +8 -0
  256. package/packages/workers/src/http/middleware/ValidateDriver.d.ts.map +1 -0
  257. package/packages/workers/src/http/middleware/ValidateDriver.js +20 -0
  258. package/packages/workers/src/http/middleware/VersionSanitizer.d.ts +4 -0
  259. package/packages/workers/src/http/middleware/VersionSanitizer.d.ts.map +1 -0
  260. package/packages/workers/src/http/middleware/VersionSanitizer.js +25 -0
  261. package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts +4 -0
  262. package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts.map +1 -0
  263. package/packages/workers/src/http/middleware/WorkerNameSanitizer.js +46 -0
  264. package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts +28 -0
  265. package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts.map +1 -0
  266. package/packages/workers/src/http/middleware/WorkerValidationChain.js +186 -0
  267. package/packages/workers/src/index.d.ts +47 -0
  268. package/packages/workers/src/index.d.ts.map +1 -0
  269. package/packages/workers/src/index.js +48 -0
  270. package/packages/workers/src/routes/workers.d.ts +13 -0
  271. package/packages/workers/src/routes/workers.d.ts.map +1 -0
  272. package/packages/workers/src/routes/workers.js +126 -0
  273. package/packages/workers/src/storage/WorkerStore.d.ts +52 -0
  274. package/packages/workers/src/storage/WorkerStore.d.ts.map +1 -0
  275. package/packages/workers/src/storage/WorkerStore.js +259 -0
  276. package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts +47 -0
  277. package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts.map +1 -0
  278. package/packages/workers/src/telemetry/api/TelemetryAPI.js +219 -0
  279. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts +18 -0
  280. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts.map +1 -0
  281. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.js +140 -0
  282. package/packages/workers/src/telemetry/components/AlertPanel.d.ts +2 -0
  283. package/packages/workers/src/telemetry/components/AlertPanel.d.ts.map +1 -0
  284. package/packages/workers/src/telemetry/components/AlertPanel.js +13 -0
  285. package/packages/workers/src/telemetry/components/CostTracking.d.ts +2 -0
  286. package/packages/workers/src/telemetry/components/CostTracking.d.ts.map +1 -0
  287. package/packages/workers/src/telemetry/components/CostTracking.js +14 -0
  288. package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts +2 -0
  289. package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts.map +1 -0
  290. package/packages/workers/src/telemetry/components/ResourceUsageChart.js +11 -0
  291. package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts +2 -0
  292. package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts.map +1 -0
  293. package/packages/workers/src/telemetry/components/WorkerHealthChart.js +11 -0
  294. package/packages/workers/src/telemetry/index.d.ts +16 -0
  295. package/packages/workers/src/telemetry/index.d.ts.map +1 -0
  296. package/packages/workers/src/telemetry/index.js +60 -0
  297. package/packages/workers/src/telemetry/routes/dashboard.d.ts +7 -0
  298. package/packages/workers/src/telemetry/routes/dashboard.d.ts.map +1 -0
  299. package/packages/workers/src/telemetry/routes/dashboard.js +608 -0
  300. package/packages/workers/src/type.d.ts +77 -0
  301. package/packages/workers/src/type.d.ts.map +1 -0
  302. package/packages/workers/src/type.js +1 -0
  303. package/packages/workers/src/ui/router/EmbeddedAssets.d.ts +5 -0
  304. package/packages/workers/src/ui/router/EmbeddedAssets.d.ts.map +1 -0
  305. package/packages/workers/src/ui/router/EmbeddedAssets.js +13 -0
  306. package/packages/workers/src/ui/router/ui.d.ts +4 -0
  307. package/packages/workers/src/ui/router/ui.d.ts.map +1 -0
  308. package/packages/workers/src/ui/router/ui.js +208 -0
  309. package/packages/workers/src/ui/types/worker-ui.d.ts +230 -0
  310. package/packages/workers/src/ui/types/worker-ui.d.ts.map +1 -0
  311. package/packages/workers/src/ui/types/worker-ui.js +5 -0
  312. package/routes/api.d.ts +7 -0
  313. package/routes/api.d.ts.map +1 -0
  314. package/routes/api.js +129 -0
  315. package/routes/broadcast.d.ts +9 -0
  316. package/routes/broadcast.d.ts.map +1 -0
  317. package/routes/broadcast.js +27 -0
  318. package/routes/storage.d.ts +4 -0
  319. package/routes/storage.d.ts.map +1 -0
  320. package/routes/storage.js +35 -0
  321. package/src/cache/Cache.d.ts.map +1 -1
  322. package/src/cache/Cache.js +40 -8
  323. package/src/cache/drivers/KVRemoteDriver.d.ts +1 -1
  324. package/src/cache/drivers/KVRemoteDriver.d.ts.map +1 -1
  325. package/src/cache/drivers/KVRemoteDriver.js +259 -44
  326. package/src/cache/drivers/MemoryDriver.d.ts.map +1 -1
  327. package/src/cache/drivers/MemoryDriver.js +10 -2
  328. package/src/cache/drivers/RedisDriver.d.ts.map +1 -1
  329. package/src/cache/drivers/RedisDriver.js +256 -33
  330. package/src/cli/CLI.d.ts.map +1 -1
  331. package/src/cli/CLI.js +6 -0
  332. package/src/cli/commands/DeployCommand.d.ts.map +1 -1
  333. package/src/cli/commands/DeployCommand.js +12 -1
  334. package/src/cli/commands/DeployContainersProxyCommand.d.ts +5 -0
  335. package/src/cli/commands/DeployContainersProxyCommand.d.ts.map +1 -0
  336. package/src/cli/commands/DeployContainersProxyCommand.js +45 -0
  337. package/src/cli/commands/DockerCommand.d.ts +5 -0
  338. package/src/cli/commands/DockerCommand.d.ts.map +1 -0
  339. package/src/cli/commands/DockerCommand.js +74 -0
  340. package/src/cli/commands/InitContainerCommand.js +10 -10
  341. package/src/cli/commands/InitContainersProxyCommand.d.ts +5 -0
  342. package/src/cli/commands/InitContainersProxyCommand.d.ts.map +1 -0
  343. package/src/cli/commands/InitContainersProxyCommand.js +159 -0
  344. package/src/cli/commands/NewCommand.d.ts.map +1 -1
  345. package/src/cli/commands/NewCommand.js +33 -0
  346. package/src/cli/commands/PutCommand.d.ts.map +1 -1
  347. package/src/cli/commands/PutCommand.js +15 -5
  348. package/src/cli/commands/StartCommand.d.ts.map +1 -1
  349. package/src/cli/commands/StartCommand.js +43 -4
  350. package/src/cli/scaffolding/ProjectScaffolder.d.ts.map +1 -1
  351. package/src/cli/scaffolding/ProjectScaffolder.js +65 -73
  352. package/src/cli/utils/DistPackager.d.ts.map +1 -1
  353. package/src/cli/utils/DistPackager.js +25 -0
  354. package/src/cli/utils/EnvFileLoader.d.ts +1 -0
  355. package/src/cli/utils/EnvFileLoader.d.ts.map +1 -1
  356. package/src/cli/utils/EnvFileLoader.js +14 -0
  357. package/src/common/RemoteSignedJson.d.ts.map +1 -1
  358. package/src/common/RemoteSignedJson.js +9 -2
  359. package/src/config/cache.js +1 -1
  360. package/src/config/env.d.ts +7 -0
  361. package/src/config/env.d.ts.map +1 -1
  362. package/src/config/env.js +8 -0
  363. package/src/config/queue.js +1 -1
  364. package/src/functions/cloudflare.d.ts.map +1 -1
  365. package/src/functions/cloudflare.js +4 -2
  366. package/src/index.js +3 -3
  367. package/src/middleware/JwtAuthMiddleware.d.ts.map +1 -1
  368. package/src/middleware/JwtAuthMiddleware.js +11 -5
  369. package/src/runtime/RuntimeAdapter.d.ts.map +1 -1
  370. package/src/runtime/RuntimeAdapter.js +30 -12
  371. package/src/runtime/adapters/CloudflareAdapter.d.ts.map +1 -1
  372. package/src/runtime/adapters/CloudflareAdapter.js +15 -4
  373. package/src/scheduler/Schedule.js +1 -1
  374. package/src/scheduler/leader/SchedulerLeader.js +1 -1
  375. package/src/schedules/job-tracking-cleanup.js +1 -1
  376. package/src/security/TokenRevocation.d.ts +19 -2
  377. package/src/security/TokenRevocation.d.ts.map +1 -1
  378. package/src/security/TokenRevocation.js +558 -30
  379. package/src/templates/project/basic/app/Controllers/AuthController.ts.tpl +11 -3
  380. package/src/templates/project/basic/config/middleware.ts.tpl +23 -22
  381. package/src/templates/project/basic/wrangler.jsonc.tpl +28 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProfilerMiddleware.d.ts","sourceRoot":"","sources":["../../../app/Middleware/ProfilerMiddleware.ts"],"names":[],"mappings":"AACA;;;GAGG;AAGH,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,6BAA6B,CAAC;AAG9D;;;;GAIG;AACH,eAAO,MAAM,kBAAkB,EAAE,UAwChC,CAAC"}
@@ -0,0 +1,47 @@
1
+ // @ts-nocheck - Example middleware - WIP
2
+ /**
3
+ * Profiler Middleware
4
+ * Enables request profiling when ENABLE_PROFILER environment variable is set
5
+ */
6
+ import { Logger } from '../../src/config/logger.js';
7
+ import { RequestProfiler } from '../../src/profiling/RequestProfiler.js';
8
+ /**
9
+ * ProfilerMiddleware wraps request execution with performance profiling
10
+ * Enabled via ENABLE_PROFILER=true environment variable
11
+ * Attaches profiling report to response headers
12
+ */
13
+ export const ProfilerMiddleware = async (req, res, next) => {
14
+ const isEnabled = process.env.ENABLE_PROFILER === 'true';
15
+ if (!isEnabled) {
16
+ // Pass through without profiling
17
+ await next();
18
+ return;
19
+ }
20
+ const profiler = RequestProfiler.create();
21
+ const queryLogger = profiler.getQueryLogger();
22
+ // Set up query logging if database is available
23
+ const db = req.context.db;
24
+ if (db !== undefined && db !== null && typeof db.onAfterQuery === 'function') {
25
+ db.onAfterQuery((sql, params, duration) => {
26
+ queryLogger.logQuery(sql, params, duration, 'middleware-profiling');
27
+ });
28
+ }
29
+ // Capture request execution
30
+ const profile = await profiler.captureRequest(async () => next());
31
+ // Attach profile to response
32
+ res.locals.profile = profile;
33
+ // Add profiling report to response header
34
+ try {
35
+ const report = profiler.generateReport(profile);
36
+ res.setHeader('X-Profiler-Report', Buffer.from(report).toString('base64'));
37
+ res.setHeader('X-Profiler-Queries', profile.queriesExecuted.toString());
38
+ res.setHeader('X-Profiler-Duration', profile.duration.toString());
39
+ if (profile.n1Patterns.length > 0) {
40
+ res.setHeader('X-Profiler-N1-Patterns', profile.n1Patterns.length.toString());
41
+ }
42
+ }
43
+ catch (error) {
44
+ // Silently fail if header encoding fails
45
+ Logger.error('Failed to encode profiler report header:', error);
46
+ }
47
+ };
@@ -0,0 +1,59 @@
1
+ /**
2
+ * Example Middleware
3
+ * Common middleware patterns for ZinTrust
4
+ */
5
+ import type { IRequest } from '../../src/http/Request';
6
+ import type { IResponse } from '../../src/http/Response';
7
+ import type { CsrfTokenManagerType, ICsrfTokenManager } from '../../src/security/CsrfTokenManager';
8
+ import type { IJwtManager, JwtAlgorithm, JwtManagerType } from '../../src/security/JwtManager';
9
+ import type { SchemaType } from '../../src/validation/Validator';
10
+ type JwtManagerInput = IJwtManager | JwtManagerType;
11
+ type CsrfManagerInput = ICsrfTokenManager | CsrfTokenManagerType;
12
+ /**
13
+ * Authentication Middleware
14
+ * Verify user is authenticated
15
+ */
16
+ export declare const authMiddleware: (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
17
+ /**
18
+ * CORS Middleware
19
+ * Handle CORS headers
20
+ */
21
+ export declare const corsMiddleware: (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
22
+ /**
23
+ * JSON Request Middleware
24
+ * Parse JSON request bodies
25
+ */
26
+ export declare const jsonMiddleware: (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
27
+ /**
28
+ * Logging Middleware
29
+ * Log all requests
30
+ */
31
+ export declare const loggingMiddleware: (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
32
+ export declare const rateLimitMiddleware: (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
33
+ /**
34
+ * Trailing Slash Middleware
35
+ * Redirect URLs with trailing slashes
36
+ */
37
+ export declare const trailingSlashMiddleware: (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
38
+ /**
39
+ * JWT Authentication Middleware
40
+ * Verify JWT token and extract claims
41
+ */
42
+ export declare const jwtMiddleware: (jwtManager: JwtManagerInput, algorithm?: JwtAlgorithm) => (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
43
+ /**
44
+ * CSRF Protection Middleware
45
+ * Validate CSRF tokens for state-changing requests
46
+ */
47
+ export declare const csrfMiddleware: (csrfManager: CsrfManagerInput) => (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
48
+ /**
49
+ * Input Validation Middleware
50
+ * Validate request body against schema
51
+ */
52
+ export declare const validationMiddleware: (schema: SchemaType) => (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
53
+ /**
54
+ * XSS Protection Middleware
55
+ * Sanitize and escape user input
56
+ */
57
+ export declare const xssProtectionMiddleware: (req: IRequest, res: IResponse, next: () => Promise<void>) => Promise<void>;
58
+ export {};
59
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../app/Middleware/index.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,KAAK,EAAE,oBAAoB,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAC1F,OAAO,KAAK,EAAE,WAAW,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAGtF,OAAO,KAAK,EAAW,UAAU,EAAE,MAAM,uBAAuB,CAAC;AAGjE,KAAK,eAAe,GAAG,WAAW,GAAG,cAAc,CAAC;AACpD,KAAK,gBAAgB,GAAG,iBAAiB,GAAG,oBAAoB,CAAC;AAajE;;;GAGG;AACH,eAAO,MAAM,cAAc,GACzB,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KACxB,OAAO,CAAC,IAAI,CASd,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,cAAc,GACzB,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KACxB,OAAO,CAAC,IAAI,CAWd,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,cAAc,GACzB,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KACxB,OAAO,CAAC,IAAI,CAYd,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,iBAAiB,GAC5B,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KACxB,OAAO,CAAC,IAAI,CAYd,CAAC;AAQF,eAAO,MAAM,mBAAmB,GAC9B,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KACxB,OAAO,CAAC,IAAI,CAsBd,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,uBAAuB,GAClC,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KACxB,OAAO,CAAC,IAAI,CAUd,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,aAAa,GAAI,YAAY,eAAe,EAAE,YAAW,YAAsB,MAC5E,KAAK,QAAQ,EAAE,KAAK,SAAS,EAAE,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KAAG,OAAO,CAAC,IAAI,CAgCtF,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,cAAc,GAAI,aAAa,gBAAgB,MAC5C,KAAK,QAAQ,EAAE,KAAK,SAAS,EAAE,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KAAG,OAAO,CAAC,IAAI,CAmCtF,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,oBAAoB,GAAI,QAAQ,UAAU,MACvC,KAAK,QAAQ,EAAE,KAAK,SAAS,EAAE,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KAAG,OAAO,CAAC,IAAI,CAwBtF,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,uBAAuB,GAClC,KAAK,QAAQ,EACb,KAAK,SAAS,EACd,MAAM,MAAM,OAAO,CAAC,IAAI,CAAC,KACxB,OAAO,CAAC,IAAI,CAiBd,CAAC"}
@@ -0,0 +1,215 @@
1
+ /**
2
+ * Example Middleware
3
+ * Common middleware patterns for ZinTrust
4
+ */
5
+ import { Logger } from '../../src/config/logger.js';
6
+ import { TokenRevocation } from '../../src/security/TokenRevocation.js';
7
+ import { XssProtection } from '../../src/security/XssProtection.js';
8
+ import { Validator } from '../../src/validation/Validator.js';
9
+ const resolveJwtManager = (jwtManager) => 'verify' in jwtManager ? jwtManager : jwtManager.create();
10
+ const resolveCsrfManager = (csrfManager) => 'validateToken' in csrfManager ? csrfManager : csrfManager.create();
11
+ const resolveSchema = (schema) => 'getRules' in schema ? schema : schema.create();
12
+ /**
13
+ * Authentication Middleware
14
+ * Verify user is authenticated
15
+ */
16
+ export const authMiddleware = async (req, res, next) => {
17
+ const token = req.getHeader('authorization');
18
+ if (token === undefined || token === '') {
19
+ res.setStatus(401).json({ error: 'Unauthorized' });
20
+ return;
21
+ }
22
+ await next();
23
+ };
24
+ /**
25
+ * CORS Middleware
26
+ * Handle CORS headers
27
+ */
28
+ export const corsMiddleware = async (req, res, next) => {
29
+ res.setHeader('Access-Control-Allow-Origin', '*');
30
+ res.setHeader('Access-Control-Allow-Methods', 'GET, POST, PUT, PATCH, DELETE, OPTIONS');
31
+ res.setHeader('Access-Control-Allow-Headers', 'Content-Type, Authorization');
32
+ if (req.getMethod() === 'OPTIONS') {
33
+ res.setStatus(200).send('');
34
+ return;
35
+ }
36
+ await next();
37
+ };
38
+ /**
39
+ * JSON Request Middleware
40
+ * Parse JSON request bodies
41
+ */
42
+ export const jsonMiddleware = async (req, res, next) => {
43
+ if (req.getMethod() === 'GET' || req.getMethod() === 'DELETE') {
44
+ await next();
45
+ return;
46
+ }
47
+ if (req.isJson() === false) {
48
+ res.setStatus(415).json({ error: 'Content-Type must be application/json' });
49
+ return;
50
+ }
51
+ await next();
52
+ };
53
+ /**
54
+ * Logging Middleware
55
+ * Log all requests
56
+ */
57
+ export const loggingMiddleware = async (req, res, next) => {
58
+ const startTime = Date.now();
59
+ const method = req.getMethod();
60
+ const path = req.getPath();
61
+ Logger.info(`→ ${method} ${path}`);
62
+ await next();
63
+ const duration = Date.now() - startTime;
64
+ const status = res.getStatus();
65
+ Logger.info(`← ${status} ${method} ${path} (${duration}ms)`);
66
+ };
67
+ /**
68
+ * Rate Limiting Middleware
69
+ * Simple in-memory rate limiting
70
+ */
71
+ const requestCounts = new Map();
72
+ export const rateLimitMiddleware = async (req, res, next) => {
73
+ const ip = req.getRaw().socket.remoteAddress ?? 'unknown';
74
+ const now = Date.now();
75
+ const windowMs = 60 * 1000; // 1 minute
76
+ const maxRequests = 100;
77
+ if (requestCounts.has(ip) === false) {
78
+ requestCounts.set(ip, []);
79
+ }
80
+ const requests = requestCounts.get(ip) ?? [];
81
+ const recentRequests = requests.filter((time) => now - time < windowMs);
82
+ if (recentRequests.length >= maxRequests) {
83
+ res.setStatus(429).json({ error: 'Too many requests' });
84
+ return;
85
+ }
86
+ recentRequests.push(now);
87
+ requestCounts.set(ip, recentRequests);
88
+ await next();
89
+ };
90
+ /**
91
+ * Trailing Slash Middleware
92
+ * Redirect URLs with trailing slashes
93
+ */
94
+ export const trailingSlashMiddleware = async (req, res, next) => {
95
+ const path = req.getPath();
96
+ if (path.length > 1 && path.endsWith('/') === true) {
97
+ const withoutSlash = path.slice(0, -1);
98
+ res.redirect(withoutSlash, 301);
99
+ return;
100
+ }
101
+ await next();
102
+ };
103
+ /**
104
+ * JWT Authentication Middleware
105
+ * Verify JWT token and extract claims
106
+ */
107
+ export const jwtMiddleware = (jwtManager, algorithm = 'HS256') => {
108
+ return async (req, res, next) => {
109
+ const authHeader = req.getHeader('authorization');
110
+ if (authHeader === undefined || authHeader === '') {
111
+ res.setStatus(401).json({ error: 'Missing authorization header' });
112
+ return;
113
+ }
114
+ const authHeaderStr = (Array.isArray(authHeader) ? authHeader[0] : authHeader).trim();
115
+ const [scheme, ...rest] = authHeaderStr.split(/\s+/);
116
+ const token = rest.join(' ').trim();
117
+ if (scheme.toLowerCase() !== 'bearer' || token === '') {
118
+ res.setStatus(401).json({ error: 'Invalid authorization header format' });
119
+ return;
120
+ }
121
+ if (await TokenRevocation.isRevoked(token)) {
122
+ res.setStatus(401).json({ error: 'Invalid or expired token' });
123
+ return;
124
+ }
125
+ try {
126
+ const payload = resolveJwtManager(jwtManager).verify(token, algorithm);
127
+ // Store in request context (TypeScript allows dynamic properties)
128
+ req.user = payload;
129
+ await next();
130
+ }
131
+ catch (error) {
132
+ Logger.error('JWT verification failed:', error);
133
+ res.setStatus(401).json({ error: 'Invalid or expired token' });
134
+ }
135
+ };
136
+ };
137
+ /**
138
+ * CSRF Protection Middleware
139
+ * Validate CSRF tokens for state-changing requests
140
+ */
141
+ export const csrfMiddleware = (csrfManager) => {
142
+ return async (req, res, next) => {
143
+ const method = req.getMethod();
144
+ // Only validate on state-changing requests
145
+ if (['POST', 'PUT', 'PATCH', 'DELETE'].includes(method) === false) {
146
+ await next();
147
+ return;
148
+ }
149
+ const sessionId = req.sessionId ?? req.getHeader('x-session-id');
150
+ if (sessionId === undefined || sessionId === '') {
151
+ res.setStatus(400).json({ error: 'Missing session ID' });
152
+ return;
153
+ }
154
+ const csrfToken = req.getHeader('x-csrf-token');
155
+ if (csrfToken === undefined || csrfToken === '') {
156
+ res.setStatus(403).json({ error: 'Missing CSRF token' });
157
+ return;
158
+ }
159
+ const isValid = await resolveCsrfManager(csrfManager).validateToken(String(sessionId), String(csrfToken));
160
+ if (isValid === false) {
161
+ res.setStatus(403).json({ error: 'Invalid or expired CSRF token' });
162
+ return;
163
+ }
164
+ await next();
165
+ };
166
+ };
167
+ /**
168
+ * Input Validation Middleware
169
+ * Validate request body against schema
170
+ */
171
+ export const validationMiddleware = (schema) => {
172
+ return async (req, res, next) => {
173
+ if (req.getMethod() === 'GET' || req.getMethod() === 'DELETE') {
174
+ await next();
175
+ return;
176
+ }
177
+ try {
178
+ const body = req.body ?? {};
179
+ Validator.validate(body, resolveSchema(schema));
180
+ await next();
181
+ }
182
+ catch (error) {
183
+ Logger.error('Validation error:', error);
184
+ const newError = error;
185
+ if (error !== undefined &&
186
+ 'toObject' in newError &&
187
+ typeof newError.toObject === 'function') {
188
+ res.setStatus(422).json({ errors: newError.toObject() });
189
+ }
190
+ else {
191
+ res.setStatus(400).json({ error: 'Invalid request body' });
192
+ }
193
+ }
194
+ };
195
+ };
196
+ /**
197
+ * XSS Protection Middleware
198
+ * Sanitize and escape user input
199
+ */
200
+ export const xssProtectionMiddleware = async (req, res, next) => {
201
+ // Add XSS protection headers
202
+ res.setHeader('X-Content-Type-Options', 'nosniff');
203
+ res.setHeader('X-Frame-Options', 'DENY');
204
+ res.setHeader('X-XSS-Protection', '1; mode=block');
205
+ // Sanitize request body if present
206
+ const body = req.body;
207
+ if (body !== undefined && body !== null && typeof body === 'object') {
208
+ for (const [key, value] of Object.entries(body)) {
209
+ if (typeof value === 'string') {
210
+ body[key] = XssProtection.escape(value);
211
+ }
212
+ }
213
+ }
214
+ await next();
215
+ };
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Example Post Model
3
+ */
4
+ import type { IRelationship } from '../../src/orm/Relationships';
5
+ import type { ModelConfig } from '../../src/orm/Model';
6
+ export declare const PostConfig: ModelConfig;
7
+ /**
8
+ * Post Model
9
+ * Refactored to Functional Object pattern
10
+ */
11
+ export declare const Post: import("../../src/orm/Model").DefinedModel<{
12
+ readonly author: () => IRelationship;
13
+ }>;
14
+ //# sourceMappingURL=Post.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Post.d.ts","sourceRoot":"","sources":["../../../app/Models/Post.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEzD,OAAO,KAAK,EAAU,WAAW,EAAE,MAAM,YAAY,CAAC;AAGtD,eAAO,MAAM,UAAU,EAAE,WASxB,CAAC;AAEF;;;GAGG;AACH,eAAO,MAAM,IAAI;;EAOf,CAAC"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Example Post Model
3
+ */
4
+ import { User } from '../Models/User.js';
5
+ import { Model } from '../../src/orm/Model.js';
6
+ export const PostConfig = {
7
+ table: 'posts',
8
+ fillable: ['title', 'content', 'user_id'],
9
+ hidden: [],
10
+ timestamps: true,
11
+ casts: {
12
+ published_at: 'datetime',
13
+ is_published: 'boolean',
14
+ },
15
+ };
16
+ /**
17
+ * Post Model
18
+ * Refactored to Functional Object pattern
19
+ */
20
+ export const Post = Model.define(PostConfig, {
21
+ /**
22
+ * Get post's author
23
+ */
24
+ author(model) {
25
+ return model.belongsTo(User);
26
+ },
27
+ });
@@ -0,0 +1,14 @@
1
+ /**
2
+ * User Model
3
+ */
4
+ /**
5
+ * User Model Definition
6
+ */
7
+ export declare const User: import("../../src/orm/Model").DefinedModel<{
8
+ readonly profile: () => undefined;
9
+ readonly posts: () => import("../../src").IRelationship;
10
+ readonly isAdmin: () => boolean;
11
+ readonly getFullName: () => string;
12
+ }>;
13
+ export default User;
14
+ //# sourceMappingURL=User.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"User.d.ts","sourceRoot":"","sources":["../../../app/Models/User.ts"],"names":[],"mappings":"AAAA;;GAEG;AAMH;;GAEG;AACH,eAAO,MAAM,IAAI;;;;;EAwChB,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,44 @@
1
+ /**
2
+ * User Model
3
+ */
4
+ import { Post } from '../Models/Post.js';
5
+ import { Model } from '../../src/orm/Model.js';
6
+ /**
7
+ * User Model Definition
8
+ */
9
+ export const User = Model.define({
10
+ table: 'users',
11
+ fillable: ['name', 'email', 'password'],
12
+ hidden: ['password'],
13
+ timestamps: true,
14
+ casts: {
15
+ email_verified_at: 'datetime',
16
+ },
17
+ }, {
18
+ /**
19
+ * Get user's profile
20
+ */
21
+ profile(_model) {
22
+ return undefined; // Placeholder
23
+ },
24
+ /**
25
+ * Get user's posts
26
+ */
27
+ posts(model) {
28
+ return model.hasMany(Post);
29
+ },
30
+ /**
31
+ * Check if user is admin
32
+ */
33
+ isAdmin(model) {
34
+ return model.getAttribute('is_admin') === 1;
35
+ },
36
+ /**
37
+ * Get user's full name
38
+ */
39
+ getFullName(model) {
40
+ const name = model.getAttribute('name');
41
+ return typeof name === 'string' ? name : '';
42
+ },
43
+ });
44
+ export default User;
@@ -0,0 +1,3 @@
1
+ declare const JobTrackingCleanupSchedule: import("../../src/scheduler").ISchedule;
2
+ export default JobTrackingCleanupSchedule;
3
+ //# sourceMappingURL=JobTracking.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JobTracking.d.ts","sourceRoot":"","sources":["../../../app/Schedules/JobTracking.ts"],"names":[],"mappings":"AAMA,QAAA,MAAM,0BAA0B,yCAMtB,CAAC;AAEX,eAAe,0BAA0B,CAAC"}
@@ -0,0 +1,13 @@
1
+ import { Env } from '../../src/config/env.js';
2
+ import Schedule from '../../src/scheduler/Schedule.js';
3
+ import { cleanupJobTrackingOnce } from '../../src/schedules/job-tracking-cleanup.js';
4
+ const enabled = Env.getBool('JOB_TRACKING_CLEANUP_ENABLED', false);
5
+ const intervalMs = Env.getInt('JOB_TRACKING_CLEANUP_INTERVAL_MS', 6 * 60 * 60 * 1000);
6
+ const JobTrackingCleanupSchedule = Schedule.define('jobTracking.cleanup', async () => {
7
+ await cleanupJobTrackingOnce();
8
+ })
9
+ .intervalMs(intervalMs)
10
+ .withoutOverlapping({ provider: Env.get('JOB_TRACKING_CLEANUP_LOCK_PROVIDER', 'redis') })
11
+ .enabledWhen(enabled)
12
+ .build();
13
+ export default JobTrackingCleanupSchedule;
@@ -0,0 +1,2 @@
1
+ export { default as jobTrackingCleanup } from '../Schedules/JobTracking';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../app/Schedules/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,kBAAkB,EAAE,MAAM,4BAA4B,CAAC"}
@@ -0,0 +1 @@
1
+ export { default as jobTrackingCleanup } from '../Schedules/JobTracking.js';
@@ -0,0 +1,6 @@
1
+ export declare function sendBroadcast(channel: string, event: string, data: unknown): Promise<void>;
2
+ declare const _default: Readonly<{
3
+ sendBroadcast: typeof sendBroadcast;
4
+ }>;
5
+ export default _default;
6
+ //# sourceMappingURL=sendBroadcast.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sendBroadcast.d.ts","sourceRoot":"","sources":["../../../../app/Toolkit/Broadcast/sendBroadcast.ts"],"names":[],"mappings":"AAEA,wBAAsB,aAAa,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAEhG;;;;AAED,wBAAgD"}
@@ -0,0 +1,5 @@
1
+ import { Broadcast } from '../../../src/tools/broadcast/Broadcast.js';
2
+ export async function sendBroadcast(channel, event, data) {
3
+ await Broadcast.send(channel, event, data);
4
+ }
5
+ export default Object.freeze({ sendBroadcast });
@@ -0,0 +1,6 @@
1
+ export declare function sendWelcomeEmail(to: string, name: string, attachmentDisk?: string, attachmentPath?: string): Promise<void>;
2
+ declare const _default: Readonly<{
3
+ sendWelcomeEmail: typeof sendWelcomeEmail;
4
+ }>;
5
+ export default _default;
6
+ //# sourceMappingURL=sendWelcomeEmail.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sendWelcomeEmail.d.ts","sourceRoot":"","sources":["../../../../app/Toolkit/Mail/sendWelcomeEmail.ts"],"names":[],"mappings":"AAEA,wBAAsB,gBAAgB,CACpC,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,MAAM,EACZ,cAAc,CAAC,EAAE,MAAM,EACvB,cAAc,CAAC,EAAE,MAAM,GACtB,OAAO,CAAC,IAAI,CAAC,CAoBf;;;;AAED,wBAAmD"}
@@ -0,0 +1,20 @@
1
+ import { Mail } from '../../../src/tools/mail/index.js';
2
+ export async function sendWelcomeEmail(to, name, attachmentDisk, attachmentPath) {
3
+ const subject = `Welcome, ${name}`;
4
+ const text = `Hello ${name}, welcome.`;
5
+ const attachments = attachmentDisk !== null &&
6
+ attachmentDisk !== undefined &&
7
+ attachmentDisk.trim() !== '' &&
8
+ attachmentPath !== null &&
9
+ attachmentPath !== undefined &&
10
+ attachmentPath.trim() !== ''
11
+ ? [{ disk: attachmentDisk, path: attachmentPath }]
12
+ : undefined;
13
+ await Mail.send({
14
+ to,
15
+ subject,
16
+ text,
17
+ attachments,
18
+ });
19
+ }
20
+ export default Object.freeze({ sendWelcomeEmail });
@@ -0,0 +1,8 @@
1
+ export declare function sendSlackNotification(webhookUrl: string, message: {
2
+ text: string;
3
+ }): Promise<void>;
4
+ declare const _default: Readonly<{
5
+ sendSlackNotification: typeof sendSlackNotification;
6
+ }>;
7
+ export default _default;
8
+ //# sourceMappingURL=sendSlackNotification.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sendSlackNotification.d.ts","sourceRoot":"","sources":["../../../../app/Toolkit/Notification/sendSlackNotification.ts"],"names":[],"mappings":"AAEA,wBAAsB,qBAAqB,CACzC,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE;IAAE,IAAI,EAAE,MAAM,CAAA;CAAE,GACxB,OAAO,CAAC,IAAI,CAAC,CAEf;;;;AAED,wBAAwD"}
@@ -0,0 +1,5 @@
1
+ import { sendSlackWebhook } from '../../../src/tools/notification/drivers/Slack.js';
2
+ export async function sendSlackNotification(webhookUrl, message) {
3
+ await sendSlackWebhook({ webhookUrl }, message);
4
+ }
5
+ export default Object.freeze({ sendSlackNotification });
@@ -0,0 +1,6 @@
1
+ export declare function sendSmsNotification(accountSid: string, authToken: string, from: string, to: string, body: string): Promise<void>;
2
+ declare const _default: Readonly<{
3
+ sendSmsNotification: typeof sendSmsNotification;
4
+ }>;
5
+ export default _default;
6
+ //# sourceMappingURL=sendSms.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sendSms.d.ts","sourceRoot":"","sources":["../../../../app/Toolkit/Notification/sendSms.ts"],"names":[],"mappings":"AAEA,wBAAsB,mBAAmB,CACvC,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,IAAI,EAAE,MAAM,EACZ,EAAE,EAAE,MAAM,EACV,IAAI,EAAE,MAAM,GACX,OAAO,CAAC,IAAI,CAAC,CAEf;;;;AAED,wBAAsD"}
@@ -0,0 +1,5 @@
1
+ import { sendSms } from '../../../src/tools/notification/drivers/Twilio.js';
2
+ export async function sendSmsNotification(accountSid, authToken, from, to, body) {
3
+ await sendSms({ accountSid, authToken, from }, { to, body });
4
+ }
5
+ export default Object.freeze({ sendSmsNotification });
@@ -0,0 +1,42 @@
1
+ import type { IRequest } from '../../src/http/Request';
2
+ import type { IResponse } from '../../src/http/Response';
3
+ export type JsonRecord = Record<string, unknown>;
4
+ export type LoginBody = {
5
+ email: string;
6
+ password: string;
7
+ };
8
+ export type RegisterBody = {
9
+ name: string;
10
+ email: string;
11
+ password: string;
12
+ };
13
+ export type UserRow = {
14
+ id?: unknown;
15
+ name?: unknown;
16
+ email?: unknown;
17
+ password?: unknown;
18
+ };
19
+ export type AuthControllerApi = {
20
+ login(req: IRequest, res: IResponse): Promise<void>;
21
+ register(req: IRequest, res: IResponse): Promise<void>;
22
+ logout(req: IRequest, res: IResponse): Promise<void>;
23
+ refresh(req: IRequest, res: IResponse): Promise<void>;
24
+ };
25
+ export type ValidationErrorLike = {
26
+ name?: unknown;
27
+ toObject?: () => Record<string, string[]>;
28
+ };
29
+ /**
30
+ * User Controller Interface
31
+ */
32
+ export interface IUserController {
33
+ index(req: IRequest, res: IResponse): Promise<void>;
34
+ show(req: IRequest, res: IResponse): Promise<void>;
35
+ create(req: IRequest, res: IResponse): Promise<void>;
36
+ store(req: IRequest, res: IResponse): Promise<void>;
37
+ fill(req: IRequest, res: IResponse): Promise<void>;
38
+ edit(req: IRequest, res: IResponse): Promise<void>;
39
+ update(req: IRequest, res: IResponse): Promise<void>;
40
+ destroy(req: IRequest, res: IResponse): Promise<void>;
41
+ }
42
+ //# sourceMappingURL=controller.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"controller.d.ts","sourceRoot":"","sources":["../../../app/Types/controller.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;AAEjD,MAAM,MAAM,SAAS,GAAG;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,MAAM,MAAM,OAAO,GAAG;IACpB,EAAE,CAAC,EAAE,OAAO,CAAC;IACb,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AACF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,KAAK,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpD,QAAQ,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACvD,MAAM,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,OAAO,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACvD,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;CAC3C,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,eAAe;IAC9B,KAAK,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpD,IAAI,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACnD,MAAM,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,KAAK,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACpD,IAAI,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACnD,IAAI,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACnD,MAAM,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACrD,OAAO,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CACvD"}
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,38 @@
1
+ /**
2
+ * Broadcast Configuration (default override)
3
+ *
4
+ * Keep this file declarative:
5
+ * - Core owns env parsing/default logic.
6
+ * - Projects can override config by editing values below.
7
+ */
8
+ declare const _default: {
9
+ default: string;
10
+ drivers: {
11
+ inmemory: {
12
+ driver: "inmemory";
13
+ };
14
+ pusher: {
15
+ driver: "pusher";
16
+ appId: string;
17
+ key: string;
18
+ secret: string;
19
+ cluster: string;
20
+ useTLS: boolean;
21
+ };
22
+ redis: {
23
+ driver: "redis";
24
+ host: string;
25
+ port: number;
26
+ password: string;
27
+ channelPrefix: string;
28
+ };
29
+ redishttps: {
30
+ driver: "redishttps";
31
+ endpoint: string;
32
+ token: string;
33
+ channelPrefix: string;
34
+ };
35
+ };
36
+ };
37
+ export default _default;
38
+ //# sourceMappingURL=broadcast.d.ts.map