@zintrust/core 0.4.26 → 0.4.28

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 (486) hide show
  1. package/app/Controllers/AuthController.d.ts +10 -0
  2. package/app/Controllers/AuthController.d.ts.map +1 -0
  3. package/app/Controllers/AuthController.js +233 -0
  4. package/app/Controllers/TestController.d.ts +22 -0
  5. package/app/Controllers/TestController.d.ts.map +1 -0
  6. package/app/Controllers/TestController.js +188 -0
  7. package/app/Controllers/UserController.d.ts +9 -0
  8. package/app/Controllers/UserController.d.ts.map +1 -0
  9. package/app/Controllers/UserController.js +8 -0
  10. package/app/Controllers/UserQueryBuilderController.d.ts +16 -0
  11. package/app/Controllers/UserQueryBuilderController.d.ts.map +1 -0
  12. package/app/Controllers/UserQueryBuilderController.js +404 -0
  13. package/app/Jobs/AdvancedEmailJobService.d.ts +57 -0
  14. package/app/Jobs/AdvancedEmailJobService.d.ts.map +1 -0
  15. package/app/Jobs/AdvancedEmailJobService.js +185 -0
  16. package/app/Jobs/EmailJobService.d.ts +33 -0
  17. package/app/Jobs/EmailJobService.d.ts.map +1 -0
  18. package/app/Jobs/EmailJobService.js +113 -0
  19. package/app/Middleware/AuthFailureResponder.d.ts +3 -0
  20. package/app/Middleware/AuthFailureResponder.d.ts.map +1 -0
  21. package/app/Middleware/AuthFailureResponder.js +8 -0
  22. package/app/Middleware/ProfilerMiddleware.d.ts +12 -0
  23. package/app/Middleware/ProfilerMiddleware.d.ts.map +1 -0
  24. package/app/Middleware/ProfilerMiddleware.js +47 -0
  25. package/app/Middleware/index.d.ts +59 -0
  26. package/app/Middleware/index.d.ts.map +1 -0
  27. package/app/Middleware/index.js +216 -0
  28. package/app/Models/Post.d.ts +14 -0
  29. package/app/Models/Post.d.ts.map +1 -0
  30. package/app/Models/Post.js +27 -0
  31. package/app/Models/User.d.ts +14 -0
  32. package/app/Models/User.d.ts.map +1 -0
  33. package/app/Models/User.js +44 -0
  34. package/app/Schedules/JobTracking.d.ts +3 -0
  35. package/app/Schedules/JobTracking.d.ts.map +1 -0
  36. package/app/Schedules/JobTracking.js +13 -0
  37. package/app/Schedules/index.d.ts +2 -0
  38. package/app/Schedules/index.d.ts.map +1 -0
  39. package/app/Schedules/index.js +1 -0
  40. package/app/Toolkit/Broadcast/sendBroadcast.d.ts +6 -0
  41. package/app/Toolkit/Broadcast/sendBroadcast.d.ts.map +1 -0
  42. package/app/Toolkit/Broadcast/sendBroadcast.js +5 -0
  43. package/app/Toolkit/Mail/sendWelcomeEmail.d.ts +6 -0
  44. package/app/Toolkit/Mail/sendWelcomeEmail.d.ts.map +1 -0
  45. package/app/Toolkit/Mail/sendWelcomeEmail.js +20 -0
  46. package/app/Toolkit/Notification/sendSlackNotification.d.ts +8 -0
  47. package/app/Toolkit/Notification/sendSlackNotification.d.ts.map +1 -0
  48. package/app/Toolkit/Notification/sendSlackNotification.js +5 -0
  49. package/app/Toolkit/Notification/sendSms.d.ts +6 -0
  50. package/app/Toolkit/Notification/sendSms.d.ts.map +1 -0
  51. package/app/Toolkit/Notification/sendSms.js +5 -0
  52. package/app/Types/controller.d.ts +44 -0
  53. package/app/Types/controller.d.ts.map +1 -0
  54. package/app/Types/controller.js +1 -0
  55. package/app/Workers/AdvancEmailWorker.d.ts +44 -0
  56. package/app/Workers/AdvancEmailWorker.d.ts.map +1 -0
  57. package/app/Workers/AdvancEmailWorker.js +192 -0
  58. package/app/Workers/EmailWorker.d.ts +39 -0
  59. package/app/Workers/EmailWorker.d.ts.map +1 -0
  60. package/app/Workers/EmailWorker.js +199 -0
  61. package/app/Workers/TestWorker.d.ts +16 -0
  62. package/app/Workers/TestWorker.d.ts.map +1 -0
  63. package/app/Workers/TestWorker.js +153 -0
  64. package/bin/z.js +0 -0
  65. package/bin/zin.js +0 -0
  66. package/bin/zintrust.js +0 -0
  67. package/bin/zt.js +0 -0
  68. package/build-manifest.json +6410 -0
  69. package/config/broadcast.d.ts +38 -0
  70. package/config/broadcast.d.ts.map +1 -0
  71. package/config/broadcast.js +37 -0
  72. package/config/cache.d.ts +40 -0
  73. package/config/cache.d.ts.map +1 -0
  74. package/config/cache.js +39 -0
  75. package/config/database.d.ts +58 -0
  76. package/config/database.d.ts.map +1 -0
  77. package/config/database.js +65 -0
  78. package/config/mail.d.ts +51 -0
  79. package/config/mail.d.ts.map +1 -0
  80. package/config/mail.js +69 -0
  81. package/config/middleware.d.ts +21 -0
  82. package/config/middleware.d.ts.map +1 -0
  83. package/config/middleware.js +61 -0
  84. package/config/notification.d.ts +33 -0
  85. package/config/notification.d.ts.map +1 -0
  86. package/config/notification.js +33 -0
  87. package/config/queue.d.ts +55 -0
  88. package/config/queue.d.ts.map +1 -0
  89. package/config/queue.js +87 -0
  90. package/config/storage.d.ts +59 -0
  91. package/config/storage.d.ts.map +1 -0
  92. package/config/storage.js +59 -0
  93. package/config/workers.d.ts +54 -0
  94. package/config/workers.d.ts.map +1 -0
  95. package/config/workers.js +83 -0
  96. package/database/factories/UserFactory.d.ts +40 -0
  97. package/database/factories/UserFactory.d.ts.map +1 -0
  98. package/database/factories/UserFactory.js +99 -0
  99. package/database/migrations/20260109074544_create_users_table.d.ts +7 -0
  100. package/database/migrations/20260109074544_create_users_table.d.ts.map +1 -0
  101. package/database/migrations/20260109074544_create_users_table.js +21 -0
  102. package/database/migrations/20260109144731_create_tasks_table.d.ts +7 -0
  103. package/database/migrations/20260109144731_create_tasks_table.d.ts.map +1 -0
  104. package/database/migrations/20260109144731_create_tasks_table.js +19 -0
  105. package/database/migrations/20260109144735_add_done_tasks_table.d.ts +11 -0
  106. package/database/migrations/20260109144735_add_done_tasks_table.d.ts.map +1 -0
  107. package/database/migrations/20260109144735_add_done_tasks_table.js +25 -0
  108. package/database/migrations/20260109150837_add_start_tasks_table.d.ts +11 -0
  109. package/database/migrations/20260109150837_add_start_tasks_table.d.ts.map +1 -0
  110. package/database/migrations/20260109150837_add_start_tasks_table.js +22 -0
  111. package/database/migrations/20260109152114_add_way_tasks_table.d.ts +11 -0
  112. package/database/migrations/20260109152114_add_way_tasks_table.d.ts.map +1 -0
  113. package/database/migrations/20260109152114_add_way_tasks_table.js +22 -0
  114. package/database/migrations/20260218121500_create_jwt_revocations_table.d.ts +7 -0
  115. package/database/migrations/20260218121500_create_jwt_revocations_table.d.ts.map +1 -0
  116. package/database/migrations/20260218121500_create_jwt_revocations_table.js +22 -0
  117. package/database/migrations/20260222120000_add_kind_to_jwt_revocations_table.d.ts +11 -0
  118. package/database/migrations/20260222120000_add_kind_to_jwt_revocations_table.d.ts.map +1 -0
  119. package/database/migrations/20260222120000_add_kind_to_jwt_revocations_table.js +20 -0
  120. package/database/migrations/20260222123000_add_user_id_to_jwt_revocations_table.d.ts +11 -0
  121. package/database/migrations/20260222123000_add_user_id_to_jwt_revocations_table.d.ts.map +1 -0
  122. package/database/migrations/20260222123000_add_user_id_to_jwt_revocations_table.js +20 -0
  123. package/database/migrations/20260327112651_create_posts_table.d.ts +11 -0
  124. package/database/migrations/20260327112651_create_posts_table.d.ts.map +1 -0
  125. package/database/migrations/20260327112651_create_posts_table.js +24 -0
  126. package/database/seeders/DatabaseSeeder.d.ts +5 -0
  127. package/database/seeders/DatabaseSeeder.d.ts.map +1 -0
  128. package/database/seeders/DatabaseSeeder.js +15 -0
  129. package/database/seeders/UserSeeder.d.ts +30 -0
  130. package/database/seeders/UserSeeder.d.ts.map +1 -0
  131. package/database/seeders/UserSeeder.js +97 -0
  132. package/index.d.ts +1 -0
  133. package/index.js +1 -0
  134. package/package.json +27 -78
  135. package/packages/cache-redis/src/RedisProxyAdapter.d.ts +6 -0
  136. package/packages/cache-redis/src/RedisProxyAdapter.d.ts.map +1 -0
  137. package/packages/cache-redis/src/RedisProxyAdapter.js +144 -0
  138. package/packages/cache-redis/src/index.d.ts +27 -0
  139. package/packages/cache-redis/src/index.d.ts.map +1 -0
  140. package/packages/cache-redis/src/index.js +153 -0
  141. package/packages/db-d1/src/index.d.ts +55 -0
  142. package/packages/db-d1/src/index.d.ts.map +1 -0
  143. package/packages/db-d1/src/index.js +118 -0
  144. package/packages/db-d1/src/register.d.ts +6 -0
  145. package/packages/db-d1/src/register.d.ts.map +1 -0
  146. package/packages/db-d1/src/register.js +8 -0
  147. package/packages/db-mysql/src/common.d.ts +7 -0
  148. package/packages/db-mysql/src/common.d.ts.map +1 -0
  149. package/packages/db-mysql/src/common.js +17 -0
  150. package/packages/db-mysql/src/index.d.ts +43 -0
  151. package/packages/db-mysql/src/index.d.ts.map +1 -0
  152. package/packages/db-mysql/src/index.js +265 -0
  153. package/packages/db-mysql/src/register.d.ts +6 -0
  154. package/packages/db-mysql/src/register.d.ts.map +1 -0
  155. package/packages/db-mysql/src/register.js +32 -0
  156. package/packages/db-postgres/src/index.d.ts +39 -0
  157. package/packages/db-postgres/src/index.d.ts.map +1 -0
  158. package/packages/db-postgres/src/index.js +179 -0
  159. package/packages/db-postgres/src/register.d.ts +6 -0
  160. package/packages/db-postgres/src/register.d.ts.map +1 -0
  161. package/packages/db-postgres/src/register.js +8 -0
  162. package/packages/db-sqlite/src/index.d.ts +9 -0
  163. package/packages/db-sqlite/src/index.d.ts.map +1 -0
  164. package/packages/db-sqlite/src/index.js +7 -0
  165. package/packages/db-sqlite/src/register.d.ts +6 -0
  166. package/packages/db-sqlite/src/register.d.ts.map +1 -0
  167. package/packages/db-sqlite/src/register.js +8 -0
  168. package/packages/db-sqlserver/src/index.d.ts +38 -0
  169. package/packages/db-sqlserver/src/index.d.ts.map +1 -0
  170. package/packages/db-sqlserver/src/index.js +73 -0
  171. package/packages/db-sqlserver/src/register.d.ts +6 -0
  172. package/packages/db-sqlserver/src/register.d.ts.map +1 -0
  173. package/packages/db-sqlserver/src/register.js +21 -0
  174. package/packages/mail-sendgrid/src/register.d.ts +6 -0
  175. package/packages/mail-sendgrid/src/register.d.ts.map +1 -0
  176. package/packages/mail-sendgrid/src/register.js +24 -0
  177. package/packages/mail-smtp/src/register.d.ts +6 -0
  178. package/packages/mail-smtp/src/register.d.ts.map +1 -0
  179. package/packages/mail-smtp/src/register.js +29 -0
  180. package/packages/queue-monitor/src/QueueMonitoringService.d.ts +35 -0
  181. package/packages/queue-monitor/src/QueueMonitoringService.d.ts.map +1 -0
  182. package/packages/queue-monitor/src/QueueMonitoringService.js +194 -0
  183. package/packages/queue-monitor/src/connection.d.ts +3 -0
  184. package/packages/queue-monitor/src/connection.d.ts.map +1 -0
  185. package/packages/queue-monitor/src/connection.js +1 -0
  186. package/packages/queue-monitor/src/dashboard-ui.d.ts +7 -0
  187. package/packages/queue-monitor/src/dashboard-ui.d.ts.map +1 -0
  188. package/packages/queue-monitor/src/dashboard-ui.js +997 -0
  189. package/packages/queue-monitor/src/driver.d.ts +15 -0
  190. package/packages/queue-monitor/src/driver.d.ts.map +1 -0
  191. package/packages/queue-monitor/src/driver.js +115 -0
  192. package/packages/queue-monitor/src/index.d.ts +71 -0
  193. package/packages/queue-monitor/src/index.d.ts.map +1 -0
  194. package/packages/queue-monitor/src/index.js +296 -0
  195. package/packages/queue-monitor/src/metrics.d.ts +27 -0
  196. package/packages/queue-monitor/src/metrics.d.ts.map +1 -0
  197. package/packages/queue-monitor/src/metrics.js +92 -0
  198. package/packages/queue-monitor/src/worker.d.ts +8 -0
  199. package/packages/queue-monitor/src/worker.d.ts.map +1 -0
  200. package/packages/queue-monitor/src/worker.js +35 -0
  201. package/packages/queue-redis/src/BullMQRedisQueue.d.ts +26 -0
  202. package/packages/queue-redis/src/BullMQRedisQueue.d.ts.map +1 -0
  203. package/packages/queue-redis/src/BullMQRedisQueue.js +465 -0
  204. package/packages/queue-redis/src/HttpQueueDriver.d.ts +18 -0
  205. package/packages/queue-redis/src/HttpQueueDriver.d.ts.map +1 -0
  206. package/packages/queue-redis/src/HttpQueueDriver.js +249 -0
  207. package/packages/queue-redis/src/QueueHttpGateway.d.ts +16 -0
  208. package/packages/queue-redis/src/QueueHttpGateway.d.ts.map +1 -0
  209. package/packages/queue-redis/src/QueueHttpGateway.js +217 -0
  210. package/packages/queue-redis/src/RedisPublishClient.d.ts +14 -0
  211. package/packages/queue-redis/src/RedisPublishClient.d.ts.map +1 -0
  212. package/packages/queue-redis/src/RedisPublishClient.js +251 -0
  213. package/packages/queue-redis/src/index.d.ts +12 -0
  214. package/packages/queue-redis/src/index.d.ts.map +1 -0
  215. package/packages/queue-redis/src/index.js +10 -0
  216. package/packages/queue-redis/src/register.d.ts +6 -0
  217. package/packages/queue-redis/src/register.d.ts.map +1 -0
  218. package/packages/queue-redis/src/register.js +21 -0
  219. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts +11 -0
  220. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.d.ts.map +1 -0
  221. package/packages/workers/migrations/20260119100000_create_zintrust_workers_table.js +32 -0
  222. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts +11 -0
  223. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.d.ts.map +1 -0
  224. package/packages/workers/migrations/20260123180000_create_queue_jobs_table.js +46 -0
  225. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts +7 -0
  226. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.d.ts.map +1 -0
  227. package/packages/workers/migrations/20260213142000_create_zintrust_job_tracking_tables.js +44 -0
  228. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts +7 -0
  229. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.d.ts.map +1 -0
  230. package/packages/workers/migrations/20260213183000_expand_zintrust_job_tracking_reliability_tables.js +104 -0
  231. package/packages/workers/src/AnomalyDetection.d.ts +107 -0
  232. package/packages/workers/src/AnomalyDetection.d.ts.map +1 -0
  233. package/packages/workers/src/AnomalyDetection.js +329 -0
  234. package/packages/workers/src/AutoScaler.d.ts +128 -0
  235. package/packages/workers/src/AutoScaler.d.ts.map +1 -0
  236. package/packages/workers/src/AutoScaler.js +425 -0
  237. package/packages/workers/src/BroadcastWorker.d.ts +29 -0
  238. package/packages/workers/src/BroadcastWorker.d.ts.map +1 -0
  239. package/packages/workers/src/BroadcastWorker.js +24 -0
  240. package/packages/workers/src/CanaryController.d.ts +104 -0
  241. package/packages/workers/src/CanaryController.d.ts.map +1 -0
  242. package/packages/workers/src/CanaryController.js +424 -0
  243. package/packages/workers/src/ChaosEngineering.d.ts +80 -0
  244. package/packages/workers/src/ChaosEngineering.d.ts.map +1 -0
  245. package/packages/workers/src/ChaosEngineering.js +229 -0
  246. package/packages/workers/src/CircuitBreaker.d.ts +107 -0
  247. package/packages/workers/src/CircuitBreaker.d.ts.map +1 -0
  248. package/packages/workers/src/CircuitBreaker.js +374 -0
  249. package/packages/workers/src/ClusterLock.d.ts +91 -0
  250. package/packages/workers/src/ClusterLock.d.ts.map +1 -0
  251. package/packages/workers/src/ClusterLock.js +397 -0
  252. package/packages/workers/src/ComplianceManager.d.ts +178 -0
  253. package/packages/workers/src/ComplianceManager.d.ts.map +1 -0
  254. package/packages/workers/src/ComplianceManager.js +556 -0
  255. package/packages/workers/src/DatacenterOrchestrator.d.ts +134 -0
  256. package/packages/workers/src/DatacenterOrchestrator.d.ts.map +1 -0
  257. package/packages/workers/src/DatacenterOrchestrator.js +404 -0
  258. package/packages/workers/src/DeadLetterQueue.d.ts +123 -0
  259. package/packages/workers/src/DeadLetterQueue.d.ts.map +1 -0
  260. package/packages/workers/src/DeadLetterQueue.js +544 -0
  261. package/packages/workers/src/HealthMonitor.d.ts +43 -0
  262. package/packages/workers/src/HealthMonitor.d.ts.map +1 -0
  263. package/packages/workers/src/HealthMonitor.js +312 -0
  264. package/packages/workers/src/MultiQueueWorker.d.ts +90 -0
  265. package/packages/workers/src/MultiQueueWorker.d.ts.map +1 -0
  266. package/packages/workers/src/MultiQueueWorker.js +282 -0
  267. package/packages/workers/src/NotificationWorker.d.ts +29 -0
  268. package/packages/workers/src/NotificationWorker.d.ts.map +1 -0
  269. package/packages/workers/src/NotificationWorker.js +23 -0
  270. package/packages/workers/src/Observability.d.ts +154 -0
  271. package/packages/workers/src/Observability.d.ts.map +1 -0
  272. package/packages/workers/src/Observability.js +538 -0
  273. package/packages/workers/src/PluginManager.d.ts +124 -0
  274. package/packages/workers/src/PluginManager.d.ts.map +1 -0
  275. package/packages/workers/src/PluginManager.js +392 -0
  276. package/packages/workers/src/PriorityQueue.d.ts +118 -0
  277. package/packages/workers/src/PriorityQueue.d.ts.map +1 -0
  278. package/packages/workers/src/PriorityQueue.js +276 -0
  279. package/packages/workers/src/ResourceMonitor.d.ts +165 -0
  280. package/packages/workers/src/ResourceMonitor.d.ts.map +1 -0
  281. package/packages/workers/src/ResourceMonitor.js +632 -0
  282. package/packages/workers/src/SLAMonitor.d.ts +111 -0
  283. package/packages/workers/src/SLAMonitor.d.ts.map +1 -0
  284. package/packages/workers/src/SLAMonitor.js +274 -0
  285. package/packages/workers/src/WorkerFactory.d.ts +226 -0
  286. package/packages/workers/src/WorkerFactory.d.ts.map +1 -0
  287. package/packages/workers/src/WorkerFactory.js +2551 -0
  288. package/packages/workers/src/WorkerInit.d.ts +103 -0
  289. package/packages/workers/src/WorkerInit.d.ts.map +1 -0
  290. package/packages/workers/src/WorkerInit.js +359 -0
  291. package/packages/workers/src/WorkerMetrics.d.ts +116 -0
  292. package/packages/workers/src/WorkerMetrics.d.ts.map +1 -0
  293. package/packages/workers/src/WorkerMetrics.js +570 -0
  294. package/packages/workers/src/WorkerRegistry.d.ts +152 -0
  295. package/packages/workers/src/WorkerRegistry.d.ts.map +1 -0
  296. package/packages/workers/src/WorkerRegistry.js +396 -0
  297. package/packages/workers/src/WorkerShutdown.d.ts +70 -0
  298. package/packages/workers/src/WorkerShutdown.d.ts.map +1 -0
  299. package/packages/workers/src/WorkerShutdown.js +185 -0
  300. package/packages/workers/src/WorkerVersioning.d.ts +108 -0
  301. package/packages/workers/src/WorkerVersioning.d.ts.map +1 -0
  302. package/packages/workers/src/WorkerVersioning.js +300 -0
  303. package/packages/workers/src/config/workerConfig.d.ts +5 -0
  304. package/packages/workers/src/config/workerConfig.d.ts.map +1 -0
  305. package/packages/workers/src/config/workerConfig.js +25 -0
  306. package/packages/workers/src/createQueueWorker.d.ts +31 -0
  307. package/packages/workers/src/createQueueWorker.d.ts.map +1 -0
  308. package/packages/workers/src/createQueueWorker.js +382 -0
  309. package/packages/workers/src/dashboard/index.d.ts +2 -0
  310. package/packages/workers/src/dashboard/index.d.ts.map +1 -0
  311. package/packages/workers/src/dashboard/index.js +1 -0
  312. package/packages/workers/src/dashboard/types.d.ts +123 -0
  313. package/packages/workers/src/dashboard/types.d.ts.map +1 -0
  314. package/packages/workers/src/dashboard/types.js +1 -0
  315. package/packages/workers/src/dashboard/workers-api.d.ts +5 -0
  316. package/packages/workers/src/dashboard/workers-api.d.ts.map +1 -0
  317. package/packages/workers/src/dashboard/workers-api.js +776 -0
  318. package/packages/workers/src/helper/index.d.ts +6 -0
  319. package/packages/workers/src/helper/index.d.ts.map +1 -0
  320. package/packages/workers/src/helper/index.js +10 -0
  321. package/packages/workers/src/http/WorkerApiController.d.ts +39 -0
  322. package/packages/workers/src/http/WorkerApiController.d.ts.map +1 -0
  323. package/packages/workers/src/http/WorkerApiController.js +313 -0
  324. package/packages/workers/src/http/WorkerController.d.ts +375 -0
  325. package/packages/workers/src/http/WorkerController.d.ts.map +1 -0
  326. package/packages/workers/src/http/WorkerController.js +1454 -0
  327. package/packages/workers/src/http/WorkerMonitoringService.d.ts +12 -0
  328. package/packages/workers/src/http/WorkerMonitoringService.d.ts.map +1 -0
  329. package/packages/workers/src/http/WorkerMonitoringService.js +89 -0
  330. package/packages/workers/src/http/middleware/CustomValidation.d.ts +93 -0
  331. package/packages/workers/src/http/middleware/CustomValidation.d.ts.map +1 -0
  332. package/packages/workers/src/http/middleware/CustomValidation.js +270 -0
  333. package/packages/workers/src/http/middleware/DatacenterValidator.d.ts +4 -0
  334. package/packages/workers/src/http/middleware/DatacenterValidator.d.ts.map +1 -0
  335. package/packages/workers/src/http/middleware/DatacenterValidator.js +94 -0
  336. package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts +8 -0
  337. package/packages/workers/src/http/middleware/EditWorkerValidation.d.ts.map +1 -0
  338. package/packages/workers/src/http/middleware/EditWorkerValidation.js +56 -0
  339. package/packages/workers/src/http/middleware/FeaturesValidator.d.ts +4 -0
  340. package/packages/workers/src/http/middleware/FeaturesValidator.d.ts.map +1 -0
  341. package/packages/workers/src/http/middleware/FeaturesValidator.js +61 -0
  342. package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts +32 -0
  343. package/packages/workers/src/http/middleware/InfrastructureValidator.d.ts.map +1 -0
  344. package/packages/workers/src/http/middleware/InfrastructureValidator.js +226 -0
  345. package/packages/workers/src/http/middleware/OptionsValidator.d.ts +4 -0
  346. package/packages/workers/src/http/middleware/OptionsValidator.d.ts.map +1 -0
  347. package/packages/workers/src/http/middleware/OptionsValidator.js +112 -0
  348. package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts +8 -0
  349. package/packages/workers/src/http/middleware/PayloadSanitizer.d.ts.map +1 -0
  350. package/packages/workers/src/http/middleware/PayloadSanitizer.js +42 -0
  351. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts +4 -0
  352. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.d.ts.map +1 -0
  353. package/packages/workers/src/http/middleware/ProcessorPathSanitizer.js +140 -0
  354. package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts +4 -0
  355. package/packages/workers/src/http/middleware/QueueNameSanitizer.d.ts.map +1 -0
  356. package/packages/workers/src/http/middleware/QueueNameSanitizer.js +45 -0
  357. package/packages/workers/src/http/middleware/ValidateDriver.d.ts +8 -0
  358. package/packages/workers/src/http/middleware/ValidateDriver.d.ts.map +1 -0
  359. package/packages/workers/src/http/middleware/ValidateDriver.js +20 -0
  360. package/packages/workers/src/http/middleware/VersionSanitizer.d.ts +4 -0
  361. package/packages/workers/src/http/middleware/VersionSanitizer.d.ts.map +1 -0
  362. package/packages/workers/src/http/middleware/VersionSanitizer.js +25 -0
  363. package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts +4 -0
  364. package/packages/workers/src/http/middleware/WorkerNameSanitizer.d.ts.map +1 -0
  365. package/packages/workers/src/http/middleware/WorkerNameSanitizer.js +46 -0
  366. package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts +28 -0
  367. package/packages/workers/src/http/middleware/WorkerValidationChain.d.ts.map +1 -0
  368. package/packages/workers/src/http/middleware/WorkerValidationChain.js +186 -0
  369. package/packages/workers/src/index.d.ts +47 -0
  370. package/packages/workers/src/index.d.ts.map +1 -0
  371. package/packages/workers/src/index.js +48 -0
  372. package/packages/workers/src/register.d.ts +10 -0
  373. package/packages/workers/src/register.d.ts.map +1 -0
  374. package/packages/workers/src/register.js +43 -0
  375. package/packages/workers/src/routes/workers.d.ts +13 -0
  376. package/packages/workers/src/routes/workers.d.ts.map +1 -0
  377. package/packages/workers/src/routes/workers.js +126 -0
  378. package/packages/workers/src/storage/WorkerStore.d.ts +52 -0
  379. package/packages/workers/src/storage/WorkerStore.d.ts.map +1 -0
  380. package/packages/workers/src/storage/WorkerStore.js +259 -0
  381. package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts +47 -0
  382. package/packages/workers/src/telemetry/api/TelemetryAPI.d.ts.map +1 -0
  383. package/packages/workers/src/telemetry/api/TelemetryAPI.js +219 -0
  384. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts +18 -0
  385. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.d.ts.map +1 -0
  386. package/packages/workers/src/telemetry/api/TelemetryMonitoringService.js +140 -0
  387. package/packages/workers/src/telemetry/components/AlertPanel.d.ts +2 -0
  388. package/packages/workers/src/telemetry/components/AlertPanel.d.ts.map +1 -0
  389. package/packages/workers/src/telemetry/components/AlertPanel.js +13 -0
  390. package/packages/workers/src/telemetry/components/CostTracking.d.ts +2 -0
  391. package/packages/workers/src/telemetry/components/CostTracking.d.ts.map +1 -0
  392. package/packages/workers/src/telemetry/components/CostTracking.js +14 -0
  393. package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts +2 -0
  394. package/packages/workers/src/telemetry/components/ResourceUsageChart.d.ts.map +1 -0
  395. package/packages/workers/src/telemetry/components/ResourceUsageChart.js +11 -0
  396. package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts +2 -0
  397. package/packages/workers/src/telemetry/components/WorkerHealthChart.d.ts.map +1 -0
  398. package/packages/workers/src/telemetry/components/WorkerHealthChart.js +11 -0
  399. package/packages/workers/src/telemetry/index.d.ts +16 -0
  400. package/packages/workers/src/telemetry/index.d.ts.map +1 -0
  401. package/packages/workers/src/telemetry/index.js +60 -0
  402. package/packages/workers/src/telemetry/routes/dashboard.d.ts +7 -0
  403. package/packages/workers/src/telemetry/routes/dashboard.d.ts.map +1 -0
  404. package/packages/workers/src/telemetry/routes/dashboard.js +608 -0
  405. package/packages/workers/src/type.d.ts +77 -0
  406. package/packages/workers/src/type.d.ts.map +1 -0
  407. package/packages/workers/src/type.js +1 -0
  408. package/packages/workers/src/ui/router/EmbeddedAssets.d.ts +5 -0
  409. package/packages/workers/src/ui/router/EmbeddedAssets.d.ts.map +1 -0
  410. package/packages/workers/src/ui/router/EmbeddedAssets.js +13 -0
  411. package/packages/workers/src/ui/router/ui.d.ts +4 -0
  412. package/packages/workers/src/ui/router/ui.d.ts.map +1 -0
  413. package/packages/workers/src/ui/router/ui.js +208 -0
  414. package/packages/workers/src/ui/types/worker-ui.d.ts +230 -0
  415. package/packages/workers/src/ui/types/worker-ui.d.ts.map +1 -0
  416. package/packages/workers/src/ui/types/worker-ui.js +5 -0
  417. package/routes/DirectTestRoutes.d.ts +25 -0
  418. package/routes/DirectTestRoutes.d.ts.map +1 -0
  419. package/routes/DirectTestRoutes.js +480 -0
  420. package/routes/TestRoutes.d.ts +11 -0
  421. package/routes/TestRoutes.d.ts.map +1 -0
  422. package/routes/TestRoutes.js +25 -0
  423. package/routes/api.d.ts +7 -0
  424. package/routes/api.d.ts.map +1 -0
  425. package/routes/api.js +136 -0
  426. package/routes/apiDev.d.ts +7 -0
  427. package/routes/apiDev.d.ts.map +1 -0
  428. package/routes/apiDev.js +92 -0
  429. package/routes/broadcast.d.ts +9 -0
  430. package/routes/broadcast.d.ts.map +1 -0
  431. package/routes/broadcast.js +27 -0
  432. package/routes/mail.d.ts +12 -0
  433. package/routes/mail.d.ts.map +1 -0
  434. package/routes/mail.js +138 -0
  435. package/routes/storage.d.ts +4 -0
  436. package/routes/storage.d.ts.map +1 -0
  437. package/routes/storage.js +35 -0
  438. package/src/boot/bootstrap.js +5 -0
  439. package/src/cli/CLI.d.ts.map +1 -1
  440. package/src/cli/CLI.js +4 -0
  441. package/src/cli/commands/D1ProxyCommand.d.ts +6 -0
  442. package/src/cli/commands/D1ProxyCommand.d.ts.map +1 -0
  443. package/src/cli/commands/D1ProxyCommand.js +170 -0
  444. package/src/cli/commands/InitContainerCommand.d.ts.map +1 -1
  445. package/src/cli/commands/InitContainerCommand.js +61 -23
  446. package/src/cli/commands/KvProxyCommand.d.ts +6 -0
  447. package/src/cli/commands/KvProxyCommand.d.ts.map +1 -0
  448. package/src/cli/commands/KvProxyCommand.js +158 -0
  449. package/src/cli/commands/MigrateCommand.js +1 -1
  450. package/src/cli/commands/MigrateWorkerCommand.d.ts.map +1 -1
  451. package/src/cli/commands/MigrateWorkerCommand.js +8 -2
  452. package/src/cli/commands/ProxyCommand.d.ts.map +1 -1
  453. package/src/cli/commands/ProxyCommand.js +2 -0
  454. package/src/cli/commands/WorkerCommands.d.ts.map +1 -1
  455. package/src/cli/commands/WorkerCommands.js +47 -7
  456. package/src/cli/commands/index.d.ts +2 -0
  457. package/src/cli/commands/index.d.ts.map +1 -1
  458. package/src/cli/commands/index.js +2 -0
  459. package/src/cli/index.d.ts +2 -0
  460. package/src/cli/index.d.ts.map +1 -1
  461. package/src/cli/index.js +2 -0
  462. package/src/cli/scaffolding/GovernanceScaffolder.d.ts.map +1 -1
  463. package/src/cli/scaffolding/GovernanceScaffolder.js +20 -3
  464. package/src/cli/scaffolding/ProjectScaffolder.d.ts.map +1 -1
  465. package/src/cli/scaffolding/ProjectScaffolder.js +13 -4
  466. package/src/cli/utils/DistPackager.d.ts +2 -2
  467. package/src/cli/utils/DistPackager.d.ts.map +1 -1
  468. package/src/cli/utils/DistPackager.js +9 -3
  469. package/src/index.js +3 -3
  470. package/src/proxy.d.ts +2 -0
  471. package/src/proxy.d.ts.map +1 -1
  472. package/src/proxy.js +2 -0
  473. package/src/runtime/WorkerProjectAutoImports.d.ts +14 -0
  474. package/src/runtime/WorkerProjectAutoImports.d.ts.map +1 -0
  475. package/src/runtime/WorkerProjectAutoImports.js +63 -0
  476. package/src/templates/project/basic/app/Workers/ExampleWorker.ts.tpl +17 -0
  477. package/src/templates/project/basic/package.json.tpl +1 -1
  478. package/src/templates/project/basic/src/zintrust.workers.ts.tpl +11 -0
  479. package/src/zintrust.comon.d.ts +9 -0
  480. package/src/zintrust.comon.d.ts.map +1 -0
  481. package/src/zintrust.comon.js +15 -0
  482. package/src/zintrust.plugins.d.ts +6 -3
  483. package/src/zintrust.plugins.d.ts.map +1 -1
  484. package/src/zintrust.plugins.js +27 -3
  485. package/start.d.ts +1 -0
  486. package/start.js +1 -0
@@ -0,0 +1,480 @@
1
+ /**
2
+ * Redis Test Routes
3
+ * Tests Redis connectivity via proxy from Cloudflare Workers
4
+ */
5
+ import { Cache } from '../src/cache/Cache.js';
6
+ import { Cloudflare } from '../src/config/cloudflare.js';
7
+ import { ErrorFactory } from '../src/exceptions/ZintrustError.js';
8
+ import { isInt, isNonEmptyString } from '../src/helper/index.js';
9
+ import { Mail } from '../src/tools/mail/index.js';
10
+ import { WorkerFactory } from '../packages/workers/src/index.js';
11
+ import { RedisProxyAdapter } from '../packages/cache-redis/src/index.js';
12
+ const ADVANCED_WORKER_SPEC = 'https://wk.zintrust.com/AdvancEmailWorker.js';
13
+ const runRedisTest = async (driver, label) => {
14
+ const key = `zt:redis-test:${label}:${Date.now()}`;
15
+ const value = { ok: true, ts: new Date().toISOString() };
16
+ await driver.set(key, value, 30);
17
+ const read = await driver.get(key);
18
+ const exists = await driver.has(key);
19
+ await driver.delete(key);
20
+ const existsAfterDelete = await driver.has(key);
21
+ return {
22
+ key,
23
+ wrote: value,
24
+ read,
25
+ exists,
26
+ existsAfterDelete,
27
+ };
28
+ };
29
+ const getCacheRouteContext = (req) => {
30
+ const isFlare = Cloudflare?.getWorkersEnv() !== null;
31
+ const storeNameRaw = req.getQueryParam?.('store');
32
+ const storeName = isNonEmptyString(storeNameRaw) ? storeNameRaw.trim() : undefined;
33
+ return {
34
+ storeName,
35
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
36
+ };
37
+ };
38
+ const getCacheStore = (storeName) => storeName === undefined ? Cache : Cache.store(storeName);
39
+ const getCacheKeyOrDefault = (req, fallbackPrefix) => {
40
+ const raw = req.getQueryParam?.('key');
41
+ const key = Array.isArray(raw) ? raw[0] : raw;
42
+ if (isNonEmptyString(key))
43
+ return key.trim();
44
+ return `${fallbackPrefix}:${Date.now()}`;
45
+ };
46
+ const getTtlSeconds = (req) => {
47
+ const raw = req.getQueryParam?.('ttl');
48
+ const value = Array.isArray(raw) ? raw[0] : raw;
49
+ if (!isInt(value, true, { min: 1, max: 60 * 60 }))
50
+ return undefined;
51
+ return Number(value);
52
+ };
53
+ const getValueForSet = (req) => {
54
+ const raw = req.getQueryParam?.('value');
55
+ const value = Array.isArray(raw) ? raw[0] : raw;
56
+ if (!isNonEmptyString(value)) {
57
+ return { ok: true, ts: new Date().toISOString() };
58
+ }
59
+ const v = value.trim();
60
+ if (v.startsWith('{') || v.startsWith('[')) {
61
+ try {
62
+ return JSON.parse(v);
63
+ }
64
+ catch {
65
+ return v;
66
+ }
67
+ }
68
+ return v;
69
+ };
70
+ export const testCacheSmoke = async (req, res) => {
71
+ const ctx = getCacheRouteContext(req);
72
+ const key = getCacheKeyOrDefault(req, 'cache-smoke');
73
+ const ttlSeconds = getTtlSeconds(req) ?? 30;
74
+ const value = { ok: true, ts: new Date().toISOString(), key };
75
+ try {
76
+ const store = getCacheStore(ctx.storeName);
77
+ await store.set(key, value, ttlSeconds);
78
+ const read = await store.get(key);
79
+ const exists = await store.has(key);
80
+ await store.delete(key);
81
+ const existsAfterDelete = await store.has(key);
82
+ res.json({
83
+ success: true,
84
+ message: 'Cache smoke test successful',
85
+ runtime: ctx.runtime,
86
+ store: ctx.storeName ?? 'default',
87
+ key,
88
+ ttlSeconds,
89
+ wrote: value,
90
+ read,
91
+ exists,
92
+ existsAfterDelete,
93
+ timestamp: new Date().toISOString(),
94
+ });
95
+ }
96
+ catch (error) {
97
+ res.status(500).json({
98
+ success: false,
99
+ error: 'Cache smoke test failed',
100
+ runtime: ctx.runtime,
101
+ store: ctx.storeName ?? 'default',
102
+ key,
103
+ details: String(error),
104
+ timestamp: new Date().toISOString(),
105
+ });
106
+ }
107
+ };
108
+ export const testCacheSet = async (req, res) => {
109
+ const ctx = getCacheRouteContext(req);
110
+ const key = getCacheKeyOrDefault(req, 'cache-set');
111
+ const ttlSeconds = getTtlSeconds(req);
112
+ const value = getValueForSet(req);
113
+ try {
114
+ const store = getCacheStore(ctx.storeName);
115
+ await store.set(key, value, ttlSeconds);
116
+ res.json({
117
+ success: true,
118
+ message: 'Cache set successful',
119
+ runtime: ctx.runtime,
120
+ store: ctx.storeName ?? 'default',
121
+ key,
122
+ ttlSeconds: ttlSeconds ?? null,
123
+ timestamp: new Date().toISOString(),
124
+ });
125
+ }
126
+ catch (error) {
127
+ res.status(500).json({
128
+ success: false,
129
+ error: 'Cache set failed',
130
+ runtime: ctx.runtime,
131
+ store: ctx.storeName ?? 'default',
132
+ key,
133
+ details: String(error),
134
+ timestamp: new Date().toISOString(),
135
+ });
136
+ }
137
+ };
138
+ export const testCacheGet = async (req, res) => {
139
+ const ctx = getCacheRouteContext(req);
140
+ const rawKey = req.getQueryParam?.('key');
141
+ const key = Array.isArray(rawKey) ? rawKey[0] : rawKey;
142
+ if (!isNonEmptyString(key)) {
143
+ res.status(400).json({
144
+ success: false,
145
+ error: 'Missing key',
146
+ message: 'Provide ?key=...',
147
+ runtime: ctx.runtime,
148
+ store: ctx.storeName ?? 'default',
149
+ timestamp: new Date().toISOString(),
150
+ });
151
+ return;
152
+ }
153
+ const trimmedKey = key.trim();
154
+ try {
155
+ const store = getCacheStore(ctx.storeName);
156
+ const value = await store.get(trimmedKey);
157
+ res.json({
158
+ success: true,
159
+ message: 'Cache get successful',
160
+ runtime: ctx.runtime,
161
+ store: ctx.storeName ?? 'default',
162
+ key: trimmedKey,
163
+ value,
164
+ timestamp: new Date().toISOString(),
165
+ });
166
+ }
167
+ catch (error) {
168
+ res.status(500).json({
169
+ success: false,
170
+ error: 'Cache get failed',
171
+ runtime: ctx.runtime,
172
+ store: ctx.storeName ?? 'default',
173
+ key: trimmedKey,
174
+ details: String(error),
175
+ timestamp: new Date().toISOString(),
176
+ });
177
+ }
178
+ };
179
+ export const testCacheHas = async (req, res) => {
180
+ const ctx = getCacheRouteContext(req);
181
+ const rawKey = req.getQueryParam?.('key');
182
+ const key = Array.isArray(rawKey) ? rawKey[0] : rawKey;
183
+ if (!isNonEmptyString(key)) {
184
+ res.status(400).json({
185
+ success: false,
186
+ error: 'Missing key',
187
+ message: 'Provide ?key=...',
188
+ runtime: ctx.runtime,
189
+ store: ctx.storeName ?? 'default',
190
+ timestamp: new Date().toISOString(),
191
+ });
192
+ return;
193
+ }
194
+ const trimmedKey = key.trim();
195
+ try {
196
+ const store = getCacheStore(ctx.storeName);
197
+ const exists = await store.has(trimmedKey);
198
+ res.json({
199
+ success: true,
200
+ message: 'Cache has successful',
201
+ runtime: ctx.runtime,
202
+ store: ctx.storeName ?? 'default',
203
+ key: trimmedKey,
204
+ exists,
205
+ timestamp: new Date().toISOString(),
206
+ });
207
+ }
208
+ catch (error) {
209
+ res.status(500).json({
210
+ success: false,
211
+ error: 'Cache has failed',
212
+ runtime: ctx.runtime,
213
+ store: ctx.storeName ?? 'default',
214
+ key: trimmedKey,
215
+ details: String(error),
216
+ timestamp: new Date().toISOString(),
217
+ });
218
+ }
219
+ };
220
+ export const testCacheDelete = async (req, res) => {
221
+ const ctx = getCacheRouteContext(req);
222
+ const rawKey = req.getQueryParam?.('key');
223
+ const key = Array.isArray(rawKey) ? rawKey[0] : rawKey;
224
+ if (!isNonEmptyString(key)) {
225
+ res.status(400).json({
226
+ success: false,
227
+ error: 'Missing key',
228
+ message: 'Provide ?key=...',
229
+ runtime: ctx.runtime,
230
+ store: ctx.storeName ?? 'default',
231
+ timestamp: new Date().toISOString(),
232
+ });
233
+ return;
234
+ }
235
+ const trimmedKey = key.trim();
236
+ try {
237
+ const store = getCacheStore(ctx.storeName);
238
+ await store.delete(trimmedKey);
239
+ const existsAfterDelete = await store.has(trimmedKey);
240
+ res.json({
241
+ success: true,
242
+ message: 'Cache delete successful',
243
+ runtime: ctx.runtime,
244
+ store: ctx.storeName ?? 'default',
245
+ key: trimmedKey,
246
+ existsAfterDelete,
247
+ timestamp: new Date().toISOString(),
248
+ });
249
+ }
250
+ catch (error) {
251
+ res.status(500).json({
252
+ success: false,
253
+ error: 'Cache delete failed',
254
+ runtime: ctx.runtime,
255
+ store: ctx.storeName ?? 'default',
256
+ key: trimmedKey,
257
+ details: String(error),
258
+ timestamp: new Date().toISOString(),
259
+ });
260
+ }
261
+ };
262
+ export const testCacheClear = async (req, res) => {
263
+ const ctx = getCacheRouteContext(req);
264
+ try {
265
+ const store = getCacheStore(ctx.storeName);
266
+ await store.clear();
267
+ res.json({
268
+ success: true,
269
+ message: 'Cache clear executed',
270
+ note: 'Some drivers (e.g., kv-remote) may not implement clear() and will no-op.',
271
+ runtime: ctx.runtime,
272
+ store: ctx.storeName ?? 'default',
273
+ timestamp: new Date().toISOString(),
274
+ });
275
+ }
276
+ catch (error) {
277
+ res.status(500).json({
278
+ success: false,
279
+ error: 'Cache clear failed',
280
+ runtime: ctx.runtime,
281
+ store: ctx.storeName ?? 'default',
282
+ details: String(error),
283
+ timestamp: new Date().toISOString(),
284
+ });
285
+ }
286
+ };
287
+ /**
288
+ * Test Redis via HTTP proxy
289
+ */
290
+ export const testRedisProxy = async (_req, res) => {
291
+ const isFlare = Cloudflare?.getWorkersEnv() !== null;
292
+ try {
293
+ const driver = RedisProxyAdapter.create();
294
+ const result = await runRedisTest(driver, 'proxy');
295
+ res.json({
296
+ success: true,
297
+ message: 'Redis proxy test successful',
298
+ adapter: 'packages/cache-redis (proxy)',
299
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
300
+ data: result,
301
+ timestamp: new Date().toISOString(),
302
+ });
303
+ }
304
+ catch (error) {
305
+ res.status(500).json({
306
+ success: false,
307
+ error: 'Redis proxy test failed',
308
+ details: String(error),
309
+ adapter: 'packages/cache-redis (proxy)',
310
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
311
+ timestamp: new Date().toISOString(),
312
+ });
313
+ }
314
+ };
315
+ /**
316
+ * Test URL-based worker processor resolution (Cloudflare Workers)
317
+ */
318
+ export const testWorkerProcessorUrl = async (_req, res) => {
319
+ const isFlare = Cloudflare?.getWorkersEnv() !== null;
320
+ try {
321
+ let resolveProcessorSpec = null;
322
+ try {
323
+ const candidate = WorkerFactory['resolveProcessorSpec'];
324
+ if (typeof candidate === 'function') {
325
+ resolveProcessorSpec = candidate;
326
+ }
327
+ }
328
+ catch {
329
+ resolveProcessorSpec = null;
330
+ }
331
+ if (resolveProcessorSpec === null) {
332
+ throw ErrorFactory.createConfigError('PROCESSOR_SPEC_RESOLVER_UNAVAILABLE');
333
+ }
334
+ const resolved = await resolveProcessorSpec(ADVANCED_WORKER_SPEC);
335
+ if (resolved === undefined || resolved === null) {
336
+ throw ErrorFactory.createConfigError('PROCESSOR_SPEC_NOT_RESOLVED');
337
+ }
338
+ res.json({
339
+ success: true,
340
+ message: 'Processor spec resolved successfully',
341
+ spec: ADVANCED_WORKER_SPEC,
342
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
343
+ timestamp: new Date().toISOString(),
344
+ });
345
+ }
346
+ catch (error) {
347
+ res.status(500).json({
348
+ success: false,
349
+ error: 'Processor spec resolution failed',
350
+ spec: ADVANCED_WORKER_SPEC,
351
+ details: String(error),
352
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
353
+ timestamp: new Date().toISOString(),
354
+ });
355
+ }
356
+ };
357
+ const getMailConfig = () => {
358
+ const mailHost = process.env['MAIL_HOST'] ?? '';
359
+ const mailUsername = process.env['MAIL_USERNAME'] ?? '';
360
+ const mailPassword = process.env['MAIL_PASSWORD'] ?? '';
361
+ const mailDriver = process.env['MAIL_DRIVER'] ?? process.env['MAIL_CONNECTION'] ?? 'smtp';
362
+ return {
363
+ mailHost,
364
+ mailUsername,
365
+ mailPassword,
366
+ mailDriver,
367
+ isConfigured: Boolean(mailHost) && Boolean(mailUsername) && Boolean(mailPassword),
368
+ configStatus: {
369
+ driver: mailDriver,
370
+ host: mailHost ? 'configured' : 'missing',
371
+ username: mailUsername ? 'configured' : 'missing',
372
+ password: mailPassword ? 'configured' : 'missing',
373
+ },
374
+ };
375
+ };
376
+ const getMailErrorDetails = (errorMessage) => {
377
+ const isProxyAuthError = errorMessage.includes('SMTP proxy forbidden') ||
378
+ errorMessage.includes('SMTP proxy unauthorized') ||
379
+ errorMessage.includes('ForbiddenError');
380
+ const isConnectionError = errorMessage.includes('ConnectionError') ||
381
+ errorMessage.includes('ECONNREFUSED') ||
382
+ errorMessage.includes('ETIMEDOUT');
383
+ const isAuthError = errorMessage.includes('auth') || errorMessage.includes('535') || errorMessage.includes('530');
384
+ const isConfigError = errorMessage.includes('Configuration') || errorMessage.includes('config');
385
+ if (isProxyAuthError) {
386
+ return {
387
+ errorType: 'proxy-auth',
388
+ suggestion: 'Ensure SMTP proxy signing credentials match between worker and proxy (SMTP_PROXY_KEY_ID/SMTP_PROXY_SECRET or APP_KEY).',
389
+ };
390
+ }
391
+ if (isConnectionError) {
392
+ return {
393
+ errorType: 'connection',
394
+ suggestion: 'Check MAIL_HOST, MAIL_PORT, and network connectivity',
395
+ };
396
+ }
397
+ if (isAuthError) {
398
+ return {
399
+ errorType: 'authentication',
400
+ suggestion: 'Verify MAIL_USERNAME and MAIL_PASSWORD are correct',
401
+ };
402
+ }
403
+ if (isConfigError) {
404
+ return {
405
+ errorType: 'configuration',
406
+ suggestion: 'Check mail driver configuration',
407
+ };
408
+ }
409
+ return {
410
+ errorType: 'unknown',
411
+ suggestion: 'Check mail service logs for more details',
412
+ };
413
+ };
414
+ const handleMailConfiguration = (mailConfig, isFlare, res) => {
415
+ if (mailConfig.mailDriver === 'smtp' && !mailConfig.isConfigured) {
416
+ res.status(400).json({
417
+ success: false,
418
+ error: 'Mail configuration incomplete',
419
+ message: 'SMTP mail driver requires MAIL_HOST, MAIL_USERNAME, and MAIL_PASSWORD environment variables',
420
+ config: mailConfig.configStatus,
421
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
422
+ timestamp: new Date().toISOString(),
423
+ });
424
+ return false;
425
+ }
426
+ return true;
427
+ };
428
+ /**
429
+ * Test sending email using configured mail driver
430
+ */
431
+ export const testMailSend = async (req, res) => {
432
+ const isFlare = Cloudflare?.getWorkersEnv() !== null;
433
+ const mailConfig = getMailConfig();
434
+ if (!handleMailConfiguration(mailConfig, isFlare, res))
435
+ return;
436
+ try {
437
+ const to = req.getQueryParam?.('to') ?? 'test@zintrust.com';
438
+ const subject = 'SMTP test from ZinTrust';
439
+ const htmlContent = await Mail.render({
440
+ template: 'welcome',
441
+ variables: { alertType: 'critical' },
442
+ });
443
+ const result = await Mail.send({
444
+ to: to ?? 'test@zintrust.com',
445
+ subject: subject ?? 'Worker Notification from ZinTrust',
446
+ text: `Worker job completed successfully.`,
447
+ html: htmlContent,
448
+ from: {
449
+ address: 'no-reply@engage.vizo.app',
450
+ name: 'ZinTrust Advanced Worker',
451
+ },
452
+ });
453
+ res.json({
454
+ success: true,
455
+ message: 'Mail send test completed successfully',
456
+ to,
457
+ result,
458
+ config: mailConfig.configStatus,
459
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
460
+ timestamp: new Date().toISOString(),
461
+ });
462
+ }
463
+ catch (error) {
464
+ const errorMessage = String(error);
465
+ const errorDetails = typeof error === 'object' && error !== null && 'details' in error
466
+ ? error.details
467
+ : undefined;
468
+ const { errorType, suggestion } = getMailErrorDetails(errorMessage);
469
+ res.status(500).json({
470
+ success: false,
471
+ error: 'Mail send test failed',
472
+ errorType,
473
+ details: errorDetails ?? errorMessage,
474
+ suggestion,
475
+ config: mailConfig.configStatus,
476
+ runtime: isFlare ? 'Cloudflare Workers' : 'Node',
477
+ timestamp: new Date().toISOString(),
478
+ });
479
+ }
480
+ };
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Register Direct MySQL Test Routes
3
+ * These routes test packages/db-mysql adapter directly with Cloudflare Workers
4
+ */
5
+ import type { IRouter } from '../src/routes/Router';
6
+ /**
7
+ * Register direct MySQL test routes
8
+ */
9
+ export declare const registerDirectMysqlTestRoutes: (router: IRouter) => void;
10
+ export default registerDirectMysqlTestRoutes;
11
+ //# sourceMappingURL=TestRoutes.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TestRoutes.d.ts","sourceRoot":"","sources":["../../routes/TestRoutes.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAC;AAcnD;;GAEG;AACH,eAAO,MAAM,6BAA6B,GAAI,QAAQ,OAAO,KAAG,IAiB/D,CAAC;AAEF,eAAe,6BAA6B,CAAC"}
@@ -0,0 +1,25 @@
1
+ /**
2
+ * Register Direct MySQL Test Routes
3
+ * These routes test packages/db-mysql adapter directly with Cloudflare Workers
4
+ */
5
+ import { Router } from '../src/routes/Router.js';
6
+ import { testCacheClear, testCacheDelete, testCacheGet, testCacheHas, testCacheSet, testCacheSmoke, testMailSend, testRedisProxy, testWorkerProcessorUrl, } from './DirectTestRoutes.js';
7
+ /**
8
+ * Register direct MySQL test routes
9
+ */
10
+ export const registerDirectMysqlTestRoutes = (router) => {
11
+ // CRUD operations test
12
+ Router.get(router, '/test/wg-pr', testRedisProxy);
13
+ // Processor spec resolution test
14
+ Router.get(router, '/test/wg-ts', testWorkerProcessorUrl);
15
+ // Mail send test
16
+ Router.get(router, '/test/wg-ma', testMailSend);
17
+ // Cache system (src/cache/Cache.ts) tests
18
+ Router.get(router, '/test/cache/smoke', testCacheSmoke);
19
+ Router.get(router, '/test/cache/set', testCacheSet);
20
+ Router.get(router, '/test/cache/get', testCacheGet);
21
+ Router.get(router, '/test/cache/has', testCacheHas);
22
+ Router.get(router, '/test/cache/delete', testCacheDelete);
23
+ Router.get(router, '/test/cache/clear', testCacheClear);
24
+ };
25
+ export default registerDirectMysqlTestRoutes;
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Example Routes
3
+ * Demonstrates routing patterns
4
+ */
5
+ import { type IRouter } from '../src/routes/Router';
6
+ export declare function registerRoutes(router: IRouter): void;
7
+ //# sourceMappingURL=api.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"api.d.ts","sourceRoot":"","sources":["../../routes/api.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAMH,OAAO,EAAE,KAAK,OAAO,EAAU,MAAM,qBAAqB,CAAC;AAQ3D,wBAAgB,cAAc,CAAC,MAAM,EAAE,OAAO,GAAG,IAAI,CAapD"}
package/routes/api.js ADDED
@@ -0,0 +1,136 @@
1
+ /**
2
+ * Example Routes
3
+ * Demonstrates routing patterns
4
+ */
5
+ import { AuthController } from '../app/Controllers/AuthController.js';
6
+ import { UserQueryBuilderController } from '../app/Controllers/UserQueryBuilderController.js';
7
+ import { Env } from '../src/config/env.js';
8
+ import { Router } from '../src/routes/Router.js';
9
+ import { registerBroadcastRoutes } from './broadcast.js';
10
+ import { registerStorageRoutes } from './storage.js';
11
+ import { getRuntimeMode } from '../src/runtime/detectRuntime.js';
12
+ import { ErrorFactory } from '../src/index.js';
13
+ export function registerRoutes(router) {
14
+ try {
15
+ const authController = AuthController.create();
16
+ const userController = UserQueryBuilderController.create();
17
+ registerPublicRoutes(router);
18
+ registerApiV1Routes(router, authController, userController);
19
+ registerAdminRoutes(router);
20
+ }
21
+ catch (error) {
22
+ throw ErrorFactory.createConfigError(`Failed to register routes: ${error.message}`, error);
23
+ }
24
+ }
25
+ /**
26
+ * Register public routes
27
+ */
28
+ function registerPublicRoutes(router) {
29
+ registerRootRoute(router);
30
+ registerHealthRoute(router);
31
+ registerBroadcastRoutes(router);
32
+ registerStorageRoutes(router);
33
+ }
34
+ function registerHealthRoute(router) {
35
+ Router.get(router, '/health', async (_req, res) => {
36
+ const modeFromEnv = Env.get('RUNTIME_MODE', '').trim();
37
+ const mode = modeFromEnv === '' ? getRuntimeMode() : modeFromEnv;
38
+ res.json({
39
+ status: 'ok',
40
+ mode,
41
+ worker: Env.get('WORKER_ENABLED', 'false') === 'true',
42
+ timestamp: new Date().toISOString(),
43
+ });
44
+ });
45
+ }
46
+ function registerRootRoute(router) {
47
+ Router.get(router, '/', async (_req, res) => {
48
+ res.json({
49
+ framework: 'ZinTrust Framework',
50
+ app_name: Env.APP_NAME,
51
+ version: '0.1.41',
52
+ env: Env.NODE_ENV ?? 'development',
53
+ database: Env.DB_CONNECTION ?? 'sqlite',
54
+ });
55
+ });
56
+ }
57
+ /**
58
+ * Register API V1 routes
59
+ */
60
+ function registerApiV1Routes(router, authController, userController) {
61
+ Router.group(router, '/api/v1', (r) => {
62
+ // Auth routes
63
+ Router.post(r, '/auth/login', authController.login, {
64
+ middleware: ['authRateLimit', 'validateLogin'],
65
+ });
66
+ Router.post(r, '/auth/register', authController.register, {
67
+ middleware: ['authRateLimit', 'validateRegister'],
68
+ });
69
+ Router.post(r, '/auth/logout', authController.logout, {
70
+ middleware: ['auth', 'jwt'],
71
+ });
72
+ Router.post(r, '/auth/logout-all', authController.logoutAll, {
73
+ middleware: ['auth', 'jwt'],
74
+ });
75
+ Router.post(r, '/auth/refresh', authController.refresh, {
76
+ middleware: ['auth', 'jwt'],
77
+ });
78
+ // Protected routes (Router supports per-route middleware metadata)
79
+ const pr = r;
80
+ // User resource (REST-ish)
81
+ Router.resource(pr, '/users', {
82
+ index: userController.index,
83
+ store: userController.store,
84
+ show: userController.show,
85
+ update: userController.update,
86
+ destroy: userController.destroy,
87
+ }, {
88
+ middleware: ['auth', 'bulletproof'],
89
+ store: {
90
+ middleware: ['auth', 'bulletproof', 'userMutationRateLimit', 'validateUserStore'],
91
+ },
92
+ update: {
93
+ middleware: ['auth', 'bulletproof', 'userMutationRateLimit', 'validateUserUpdate'],
94
+ },
95
+ destroy: { middleware: ['auth', 'bulletproof', 'userMutationRateLimit'] },
96
+ });
97
+ Router.post(pr, '/users/fill', userController.fill, {
98
+ middleware: ['auth', 'jwt', 'fillRateLimit', 'validateUserFill'],
99
+ });
100
+ // If the controller exposes create/edit, wire them explicitly.
101
+ Router.get(pr, '/users/create', userController.create, {
102
+ middleware: ['auth', 'jwt'],
103
+ });
104
+ Router.get(pr, '/users/:id/edit', userController.edit, {
105
+ middleware: ['auth', 'jwt'],
106
+ });
107
+ // Custom user routes
108
+ Router.get(pr, '/profile', async (__req, res) => {
109
+ res.json({ message: 'Get user profile' });
110
+ }, { middleware: ['auth', 'bulletproof'] });
111
+ Router.put(pr, '/profile', async (__req, res) => {
112
+ res.json({ message: 'Update user profile' });
113
+ }, { middleware: ['auth', 'bulletproof'] });
114
+ // Posts resource
115
+ Router.get(r, '/posts', async (_req, res) => {
116
+ res.json({ data: [] });
117
+ });
118
+ Router.get(r, '/posts/:id', async (req, res) => {
119
+ const id = req.getParam('id');
120
+ res.json({ data: { id } });
121
+ });
122
+ });
123
+ }
124
+ /**
125
+ * Register admin routes
126
+ */
127
+ function registerAdminRoutes(router) {
128
+ Router.group(router, '/admin', (r) => {
129
+ Router.get(r, '/dashboard', async (__req, res) => {
130
+ res.json({ message: 'Admin dashboard' });
131
+ });
132
+ Router.get(r, '/users', async (__req, res) => {
133
+ res.json({ data: [] });
134
+ });
135
+ });
136
+ }
@@ -0,0 +1,7 @@
1
+ /**
2
+ * Example Routes
3
+ * Demonstrates routing patterns
4
+ */
5
+ import { type IRouter } from '../src/routes/Router';
6
+ export declare function registerDevRoutes(_router: IRouter): void;
7
+ //# sourceMappingURL=apiDev.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"apiDev.d.ts","sourceRoot":"","sources":["../../routes/apiDev.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,KAAK,OAAO,EAAU,MAAM,qBAAqB,CAAC;AAqG3D,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAKxD"}