stratal 0.0.14 → 0.0.15

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 (136) hide show
  1. package/dist/application-Du0d8O_e.d.mts +116 -0
  2. package/dist/application-Du0d8O_e.d.mts.map +1 -0
  3. package/dist/{base-email.provider-bzdAYp8Z.mjs → base-email.provider-CNwsPbwm.mjs} +1 -1
  4. package/dist/{base-email.provider-bzdAYp8Z.mjs.map → base-email.provider-CNwsPbwm.mjs.map} +1 -1
  5. package/dist/bin/cloudflare-workers-loader.mjs +34 -0
  6. package/dist/bin/cloudflare-workers-loader.mjs.map +1 -0
  7. package/dist/bin/quarry.mjs +164 -0
  8. package/dist/bin/quarry.mjs.map +1 -0
  9. package/dist/cache/index.d.mts +2 -2
  10. package/dist/cache/index.mjs +10 -6
  11. package/dist/cache/index.mjs.map +1 -1
  12. package/dist/command-DG_u5ob2.mjs +192 -0
  13. package/dist/command-DG_u5ob2.mjs.map +1 -0
  14. package/dist/command-DcebcSrL.d.mts +120 -0
  15. package/dist/command-DcebcSrL.d.mts.map +1 -0
  16. package/dist/config/index.d.mts +2 -2
  17. package/dist/config/index.mjs +10 -6
  18. package/dist/config/index.mjs.map +1 -1
  19. package/dist/cron/index.d.mts +1 -1
  20. package/dist/cron/index.mjs +4 -3
  21. package/dist/{cron-manager-CpS_hrDD.mjs → cron-manager-BRh86QCS.mjs} +3 -3
  22. package/dist/{cron-manager-CpS_hrDD.mjs.map → cron-manager-BRh86QCS.mjs.map} +1 -1
  23. package/dist/decorate-D5j-d9_z.mjs +171 -0
  24. package/dist/decorate-D5j-d9_z.mjs.map +1 -0
  25. package/dist/di/index.d.mts +1 -1
  26. package/dist/di/index.mjs +3 -2
  27. package/dist/email/index.d.mts +3 -3
  28. package/dist/email/index.mjs +15 -11
  29. package/dist/email/index.mjs.map +1 -1
  30. package/dist/{en-C9U5-ETs.mjs → en-uVIaxFXR.mjs} +3 -1
  31. package/dist/en-uVIaxFXR.mjs.map +1 -0
  32. package/dist/errors/index.d.mts +1 -1
  33. package/dist/errors/index.mjs +3 -2
  34. package/dist/{errors-BRJgVd5-.mjs → errors-CtCi1wn6.mjs} +6 -3
  35. package/dist/errors-CtCi1wn6.mjs.map +1 -0
  36. package/dist/events/index.d.mts +2 -2
  37. package/dist/events/index.mjs +3 -2
  38. package/dist/{events-CQyvSyrQ.mjs → events-CXl-o1Ad.mjs} +3 -2
  39. package/dist/{events-CQyvSyrQ.mjs.map → events-CXl-o1Ad.mjs.map} +1 -1
  40. package/dist/{gateway-context-D7TFPLi5.mjs → gateway-context-90CQEQDR.mjs} +4 -4
  41. package/dist/{gateway-context-D7TFPLi5.mjs.map → gateway-context-90CQEQDR.mjs.map} +1 -1
  42. package/dist/guards/index.d.mts +3 -3
  43. package/dist/guards/index.mjs +1 -1
  44. package/dist/{guards-B5o618bL.mjs → guards-DMbsAxSX.mjs} +1 -1
  45. package/dist/{guards-B5o618bL.mjs.map → guards-DMbsAxSX.mjs.map} +1 -1
  46. package/dist/i18n/index.d.mts +2 -2
  47. package/dist/i18n/index.mjs +14 -10
  48. package/dist/i18n/messages/en/index.d.mts +1 -1
  49. package/dist/i18n/messages/en/index.mjs +1 -1
  50. package/dist/i18n/validation/index.d.mts +1 -1
  51. package/dist/i18n/validation/index.mjs +1 -1
  52. package/dist/{i18n.module-C9wQr_2k.mjs → i18n.module-qNrpIVts.mjs} +10 -11
  53. package/dist/i18n.module-qNrpIVts.mjs.map +1 -0
  54. package/dist/{index-BWEwA_XK.d.mts → index-CSuHOJc3.d.mts} +3 -1
  55. package/dist/{index-BWEwA_XK.d.mts.map → index-CSuHOJc3.d.mts.map} +1 -1
  56. package/dist/{index-3TtGtYlJ.d.mts → index-Cfkie8JM.d.mts} +1 -1
  57. package/dist/{index-3TtGtYlJ.d.mts.map → index-Cfkie8JM.d.mts.map} +1 -1
  58. package/dist/{index-Dl4RvzNp.d.mts → index-CpAN9ENH.d.mts} +2 -2
  59. package/dist/{index-Dl4RvzNp.d.mts.map → index-CpAN9ENH.d.mts.map} +1 -1
  60. package/dist/{index-C9bIk5tt.d.mts → index-D69rxo8H.d.mts} +9 -6
  61. package/dist/index-D69rxo8H.d.mts.map +1 -0
  62. package/dist/{index-zKURVFOC.d.mts → index-H-Su81aK.d.mts} +3 -3
  63. package/dist/{index-zKURVFOC.d.mts.map → index-H-Su81aK.d.mts.map} +1 -1
  64. package/dist/index.d.mts +3 -106
  65. package/dist/index.d.mts.map +1 -1
  66. package/dist/index.mjs +19 -13
  67. package/dist/is-command-MZDCH-0T.mjs +14 -0
  68. package/dist/is-command-MZDCH-0T.mjs.map +1 -0
  69. package/dist/is-seeder-BN9Ej1r7.mjs +28 -0
  70. package/dist/is-seeder-BN9Ej1r7.mjs.map +1 -0
  71. package/dist/logger/index.d.mts +1 -1
  72. package/dist/logger/index.mjs +2 -1
  73. package/dist/{logger-Bg-CuidS.mjs → logger-BR1-s1Um.mjs} +4 -169
  74. package/dist/logger-BR1-s1Um.mjs.map +1 -0
  75. package/dist/middleware/index.d.mts +1 -1
  76. package/dist/middleware/index.mjs +5 -4
  77. package/dist/{middleware-B3tx1u1K.mjs → middleware-iRhNjsPH.mjs} +3 -3
  78. package/dist/{middleware-B3tx1u1K.mjs.map → middleware-iRhNjsPH.mjs.map} +1 -1
  79. package/dist/module/index.d.mts +21 -3
  80. package/dist/module/index.d.mts.map +1 -1
  81. package/dist/module/index.mjs +10 -6
  82. package/dist/{module-Dvzm4dhS.mjs → module-BH7t7BGG.mjs} +44 -5
  83. package/dist/module-BH7t7BGG.mjs.map +1 -0
  84. package/dist/openapi/index.d.mts +3 -3
  85. package/dist/openapi/index.mjs +14 -10
  86. package/dist/quarry/index.d.mts +112 -0
  87. package/dist/quarry/index.d.mts.map +1 -0
  88. package/dist/quarry/index.mjs +6 -0
  89. package/dist/quarry-registry-BPmKVjhG.mjs +302 -0
  90. package/dist/quarry-registry-BPmKVjhG.mjs.map +1 -0
  91. package/dist/queue/index.d.mts +1 -1
  92. package/dist/queue/index.mjs +11 -7
  93. package/dist/queue/index.mjs.map +1 -1
  94. package/dist/{queue.module-ZqaZ2iY0.mjs → queue.module-BdXWUvIM.mjs} +4 -4
  95. package/dist/{queue.module-ZqaZ2iY0.mjs.map → queue.module-BdXWUvIM.mjs.map} +1 -1
  96. package/dist/{resend.provider-BFGt6fS4.mjs → resend.provider-CQT5be5E.mjs} +5 -4
  97. package/dist/{resend.provider-BFGt6fS4.mjs.map → resend.provider-CQT5be5E.mjs.map} +1 -1
  98. package/dist/router/index.d.mts +1 -1
  99. package/dist/router/index.mjs +14 -10
  100. package/dist/{router-context-DlTxpJUG.mjs → router-context-BLn4PrRG.mjs} +2 -2
  101. package/dist/{router-context-DlTxpJUG.mjs.map → router-context-BLn4PrRG.mjs.map} +1 -1
  102. package/dist/seeder/index.d.mts +77 -0
  103. package/dist/seeder/index.d.mts.map +1 -0
  104. package/dist/seeder/index.mjs +7 -0
  105. package/dist/seeder-DatfjJvU.mjs +132 -0
  106. package/dist/seeder-DatfjJvU.mjs.map +1 -0
  107. package/dist/{smtp.provider-BYY-AdmU.mjs → smtp.provider-Cj7BUFbJ.mjs} +5 -4
  108. package/dist/{smtp.provider-BYY-AdmU.mjs.map → smtp.provider-Cj7BUFbJ.mjs.map} +1 -1
  109. package/dist/storage/index.d.mts +2 -2
  110. package/dist/storage/index.mjs +12 -8
  111. package/dist/{storage-dgi7MG6z.mjs → storage-BtcfgibD.mjs} +5 -5
  112. package/dist/{storage-dgi7MG6z.mjs.map → storage-BtcfgibD.mjs.map} +1 -1
  113. package/dist/{stratal-D4MS_7pI.mjs → stratal-Cm0Yy8v4.mjs} +44 -9
  114. package/dist/stratal-Cm0Yy8v4.mjs.map +1 -0
  115. package/dist/{types-JUIHSW_a.d.mts → types-Cu4jkeiH.d.mts} +1 -1
  116. package/dist/types-Cu4jkeiH.d.mts.map +1 -0
  117. package/dist/types-N84Ak6YT.d.mts +64 -0
  118. package/dist/types-N84Ak6YT.d.mts.map +1 -0
  119. package/dist/usage-generator-BTZDk5zx.mjs +75 -0
  120. package/dist/usage-generator-BTZDk5zx.mjs.map +1 -0
  121. package/dist/{validation-DA5nptIp.mjs → validation-Dbt-snjx.mjs} +1 -1
  122. package/dist/{validation-DA5nptIp.mjs.map → validation-Dbt-snjx.mjs.map} +1 -1
  123. package/dist/websocket/index.d.mts +2 -2
  124. package/dist/websocket/index.mjs +5 -4
  125. package/dist/workers/index.d.mts +1 -1
  126. package/dist/workers/index.mjs +19 -13
  127. package/dist/workers/index.mjs.map +1 -1
  128. package/package.json +15 -1
  129. package/dist/en-C9U5-ETs.mjs.map +0 -1
  130. package/dist/errors-BRJgVd5-.mjs.map +0 -1
  131. package/dist/i18n.module-C9wQr_2k.mjs.map +0 -1
  132. package/dist/index-C9bIk5tt.d.mts.map +0 -1
  133. package/dist/logger-Bg-CuidS.mjs.map +0 -1
  134. package/dist/module-Dvzm4dhS.mjs.map +0 -1
  135. package/dist/stratal-D4MS_7pI.mjs.map +0 -1
  136. package/dist/types-JUIHSW_a.d.mts.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.mts","names":[],"sources":["../src/execution-context.ts","../src/application.ts","../src/stratal.ts"],"mappings":";;;;UAAiB,uBAAA;EACf,SAAA,CAAU,OAAA,EAAS,OAAA;AAAA;;;UCwBJ,iBAAA;;EAEf,MAAA,EAAQ,WAAA,GAAc,aAAA;ED1BtB;EC4BA,OAAA;IACE,KAAA,GAAQ,QAAA;IACR,SAAA;EAAA;;;;AANJ;EAYE,UAAA,GAAa,iBAAA;AAAA;AAAA,UAGE,kBAAA,SAA2B,iBAAA;EAC1C,GAAA,EAAK,UAAA;EACL,GAAA,EAAK,uBAAA;AAAA;;;;;;;;;;;;;;AAFP;;;;;;;cAyBa,WAAA;EAzB+B;;;EAAA,QA6BlC,UAAA;EAAA,QAEA,OAAA;EAAA,QACA,cAAA;EAAA,QACA,gBAAA;EAAA,QACA,WAAA;EAAA,QACA,WAAA;EAAA,SAEC,GAAA,EAAK,UAAA;EAAA,iBACG,SAAA;;IAEH,GAAA;IAAK,GAAA;IAAA,GAAQ;EAAA,GAAU,kBAAA;EAAlB;;;EAAA,IA+Bf,SAAA,CAAA,GAAa,SAAA;EAWG;;;EAAA,IAJhB,IAAA,CAAA,GAAQ,OAAA;EAIN,UAAA,CAAA,GAAc,OAAA;EA0EoC;;;EAjCxD,OAAA,GAAA,CAAW,KAAA,WAAgB,CAAA;EA0DF;;;EA7CnB,WAAA,CAAY,KAAA,EAAO,YAAA,EAAc,SAAA,WAAoB,OAAA;EAvGnD;;;EA2HF,eAAA,CAAgB,UAAA,EAAY,mBAAA,GAAsB,OAAA;EAvH1C;;;EAwId,uBAAA,CAAwB,MAAA,YAAgB,aAAA;EAQlC,QAAA,CAAA,GAAY,OAAA;EAAA,QAYV,sBAAA;EAAA,QAOA,gBAAA;EAhKmB;;;EAAA,QA0KnB,sBAAA;EApIJ;;;EAAA,QAyJI,qBAAA;EA5GR;;;EAAA,QAgIQ,oBAAA;AAAA;;;;;;ADnSV;;;;;;;;;;;cEqBa,OAAA,aAAoB,UAAA,GAAa,UAAA;EAAA,QACpC,GAAA;EAAA,QACA,WAAA;EAAA,eAEO,YAAA;cAEH,MAAA,EAAQ,iBAAA;EASd,KAAA,CAAM,OAAA,EAAS,OAAA,EAAS,GAAA,EAAK,GAAA,EAAK,GAAA,EAAK,gBAAA,GAAmB,OAAA,CAAQ,QAAA;EAKlE,KAAA,CAAM,KAAA,EAAO,YAAA,GAAe,OAAA;EAK5B,SAAA,CAAU,UAAA,EAAY,mBAAA,GAAsB,OAAA;EAAA,IAK9C,IAAA,CAAA,GAAQ,OAAA,CAAQ,OAAA;EAId,QAAA,CAAA,GAAY,OAAA;ED5BlB;;;;;;EAAA,OC0CO,kBAAA,CAAA,GAAsB,OAAA,CAAQ,WAAA;EAAA,QAOvB,WAAA;EAAA,QAKA,UAAA;AAAA"}
1
+ {"version":3,"file":"index.d.mts","names":[],"sources":["../src/stratal.ts"],"mappings":";;;;;;;AAqBA;;;;;;;;;;;cAAa,OAAA,aAAoB,UAAA,GAAa,UAAA;EAAA,QACpC,GAAA;EAAA,QACA,WAAA;EAAA,eAEO,YAAA;cAEH,MAAA,EAAQ,iBAAA;EASd,KAAA,CAAM,OAAA,EAAS,OAAA,EAAS,GAAA,EAAK,GAAA,EAAK,GAAA,EAAK,gBAAA,GAAmB,OAAA,CAAQ,QAAA;EAKlE,KAAA,CAAM,KAAA,EAAO,YAAA,GAAe,OAAA;EAK5B,SAAA,CAAU,UAAA,EAAY,mBAAA,GAAsB,OAAA;EAAA,IAK9C,IAAA,CAAA,GAAQ,OAAA,CAAQ,OAAA;EAId,QAAA,CAAA,GAAY,OAAA;EAckB;;;;;;EAAA,OAA7B,kBAAA,CAAA,GAAsB,OAAA,CAAQ,WAAA;EAAA,QAOvB,WAAA;EAAA,QAKA,UAAA;AAAA"}
package/dist/index.mjs CHANGED
@@ -1,14 +1,20 @@
1
- import "./errors-BRJgVd5-.mjs";
2
- import "./logger-Bg-CuidS.mjs";
3
- import "./module-Dvzm4dhS.mjs";
4
- import "./events-CQyvSyrQ.mjs";
5
- import "./middleware-B3tx1u1K.mjs";
6
- import "./router-context-DlTxpJUG.mjs";
7
- import "./cron-manager-CpS_hrDD.mjs";
8
- import "./validation-DA5nptIp.mjs";
9
- import "./i18n.module-C9wQr_2k.mjs";
10
- import "./guards-B5o618bL.mjs";
11
- import "./gateway-context-D7TFPLi5.mjs";
12
- import "./queue.module-ZqaZ2iY0.mjs";
13
- import { n as Application, t as Stratal } from "./stratal-D4MS_7pI.mjs";
1
+ import "./errors-CtCi1wn6.mjs";
2
+ import "./decorate-D5j-d9_z.mjs";
3
+ import "./logger-BR1-s1Um.mjs";
4
+ import "./module-BH7t7BGG.mjs";
5
+ import "./events-CXl-o1Ad.mjs";
6
+ import "./command-DG_u5ob2.mjs";
7
+ import "./is-command-MZDCH-0T.mjs";
8
+ import "./is-seeder-BN9Ej1r7.mjs";
9
+ import "./middleware-iRhNjsPH.mjs";
10
+ import "./router-context-BLn4PrRG.mjs";
11
+ import "./cron-manager-BRh86QCS.mjs";
12
+ import "./validation-Dbt-snjx.mjs";
13
+ import "./i18n.module-qNrpIVts.mjs";
14
+ import "./guards-DMbsAxSX.mjs";
15
+ import "./gateway-context-90CQEQDR.mjs";
16
+ import "./quarry-registry-BPmKVjhG.mjs";
17
+ import "./queue.module-BdXWUvIM.mjs";
18
+ import "./seeder-DatfjJvU.mjs";
19
+ import { n as Application, t as Stratal } from "./stratal-Cm0Yy8v4.mjs";
14
20
  export { Application, Stratal };
@@ -0,0 +1,14 @@
1
+ import { t as Command } from "./command-DG_u5ob2.mjs";
2
+ //#region src/quarry/is-command.ts
3
+ /**
4
+ * Check if a class is a Command (extends Command base class).
5
+ *
6
+ * Used by ModuleRegistry for auto-discovery from providers.
7
+ */
8
+ function isCommand(target) {
9
+ return target.prototype instanceof Command;
10
+ }
11
+ //#endregion
12
+ export { isCommand as t };
13
+
14
+ //# sourceMappingURL=is-command-MZDCH-0T.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"is-command-MZDCH-0T.mjs","names":[],"sources":["../src/quarry/is-command.ts"],"sourcesContent":["import { Command } from './command'\nimport type { Constructor } from '../types'\n\n/**\n * Check if a class is a Command (extends Command base class).\n *\n * Used by ModuleRegistry for auto-discovery from providers.\n */\nexport function isCommand(target: Constructor): boolean {\n return target.prototype instanceof Command\n}\n"],"mappings":";;;;;;;AAQA,SAAgB,UAAU,QAA8B;AACtD,QAAO,OAAO,qBAAqB"}
@@ -0,0 +1,28 @@
1
+ //#region src/seeder/seeder.ts
2
+ const SEEDER_INTERNALS = Symbol("seeder:internals");
3
+ var Seeder = class {
4
+ [SEEDER_INTERNALS] = {
5
+ run: () => {
6
+ throw new Error("SeederRegistry not available");
7
+ },
8
+ container: null
9
+ };
10
+ /** Call another seeder (like Laravel's $this->call()) */
11
+ async call(SeederClass) {
12
+ await this[SEEDER_INTERNALS].run(SeederClass);
13
+ }
14
+ };
15
+ //#endregion
16
+ //#region src/seeder/is-seeder.ts
17
+ /**
18
+ * Check if a class is a Seeder (extends Seeder base class).
19
+ *
20
+ * Used by ModuleRegistry for auto-discovery from providers.
21
+ */
22
+ function isSeeder(target) {
23
+ return target.prototype instanceof Seeder;
24
+ }
25
+ //#endregion
26
+ export { SEEDER_INTERNALS as n, Seeder as r, isSeeder as t };
27
+
28
+ //# sourceMappingURL=is-seeder-BN9Ej1r7.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"is-seeder-BN9Ej1r7.mjs","names":[],"sources":["../src/seeder/seeder.ts","../src/seeder/is-seeder.ts"],"sourcesContent":["import type { Container } from '../di/container'\nimport type { Constructor } from '../types'\n\nexport const SEEDER_INTERNALS = Symbol('seeder:internals')\n\nexport interface SeederContext {\n run(SeederClass: Constructor<Seeder>): Promise<void>\n container: Container | null\n}\n\nexport abstract class Seeder {\n [SEEDER_INTERNALS]: SeederContext = {\n run: () => { throw new Error('SeederRegistry not available') },\n container: null,\n }\n\n abstract run(): Promise<void>\n\n /** Call another seeder (like Laravel's $this->call()) */\n protected async call(SeederClass: Constructor<Seeder>): Promise<void> {\n await this[SEEDER_INTERNALS].run(SeederClass)\n }\n}\n","import type { Constructor } from '../types'\nimport { Seeder } from './seeder'\n\n/**\n * Check if a class is a Seeder (extends Seeder base class).\n *\n * Used by ModuleRegistry for auto-discovery from providers.\n */\nexport function isSeeder(target: Constructor): boolean {\n return target.prototype instanceof Seeder\n}\n"],"mappings":";AAGA,MAAa,mBAAmB,OAAO,mBAAmB;AAO1D,IAAsB,SAAtB,MAA6B;CAC3B,CAAC,oBAAmC;EAClC,WAAW;AAAE,SAAM,IAAI,MAAM,+BAA+B;;EAC5D,WAAW;EACZ;;CAKD,MAAgB,KAAK,aAAiD;AACpE,QAAM,KAAK,kBAAkB,IAAI,YAAY;;;;;;;;;;ACZjD,SAAgB,SAAS,QAA8B;AACrD,QAAO,OAAO,qBAAqB"}
@@ -1,2 +1,2 @@
1
- import { a as LogEntry, c as LOG_LEVEL_PRIORITY, i as LoggerService, l as LogLevel, n as PrettyFormatter, o as InternalLogContext, r as JsonFormatter, s as LogContext, t as ConsoleTransport, u as LOGGER_TOKENS } from "../index-3TtGtYlJ.mjs";
1
+ import { a as LogEntry, c as LOG_LEVEL_PRIORITY, i as LoggerService, l as LogLevel, n as PrettyFormatter, o as InternalLogContext, r as JsonFormatter, s as LogContext, t as ConsoleTransport, u as LOGGER_TOKENS } from "../index-Cfkie8JM.mjs";
2
2
  export { ConsoleTransport, InternalLogContext, JsonFormatter, LOGGER_TOKENS, LOG_LEVEL_PRIORITY, LogContext, LogEntry, LogLevel, LoggerService, PrettyFormatter };
@@ -1,2 +1,3 @@
1
- import { c as LOG_LEVEL_PRIORITY, i as LoggerService, l as LogLevel, n as PrettyFormatter, r as JsonFormatter, t as ConsoleTransport, u as LOGGER_TOKENS } from "../logger-Bg-CuidS.mjs";
1
+ import "../decorate-D5j-d9_z.mjs";
2
+ import { a as LOG_LEVEL_PRIORITY, i as LoggerService, n as PrettyFormatter, o as LogLevel, r as JsonFormatter, s as LOGGER_TOKENS, t as ConsoleTransport } from "../logger-BR1-s1Um.mjs";
2
3
  export { ConsoleTransport, JsonFormatter, LOGGER_TOKENS, LOG_LEVEL_PRIORITY, LogLevel, LoggerService, PrettyFormatter };
@@ -1,150 +1,5 @@
1
- import { inject, injectable } from "tsyringe";
2
- //#region src/di/tokens.ts
3
- /**
4
- * Token for the Container instance
5
- * Used for injecting the Container into services that need dynamic resolution
6
- */
7
- const CONTAINER_TOKEN = Symbol.for("stratal:di:container");
8
- const DI_TOKENS = {
9
- CloudflareEnv: Symbol.for("stratal:cloudflare:env"),
10
- ExecutionContext: Symbol.for("stratal:execution:context"),
11
- Container: CONTAINER_TOKEN,
12
- Application: Symbol.for("stratal:application"),
13
- ModuleRegistry: Symbol.for("stratal:module:registry"),
14
- ErrorHandler: Symbol.for("stratal:error:handler"),
15
- Database: Symbol.for("stratal:database:service"),
16
- Queue: Symbol.for("stratal:queue:manager"),
17
- ConsumerRegistry: Symbol.for("stratal:consumer:registry"),
18
- Cron: Symbol.for("stratal:cron:manager"),
19
- EventRegistry: Symbol.for("stratal:event:registry"),
20
- AuthContext: Symbol.for("stratal:auth:context"),
21
- DurableObjectState: Symbol.for("stratal:durable:object:state"),
22
- DurableObjectId: Symbol.for("stratal:durable:object:id")
23
- };
24
- //#endregion
25
- //#region src/di/decorators/inject-param.decorator.ts
26
- /**
27
- * Metadata key for storing parameter injection information
28
- */
29
- const INJECT_PARAM_METADATA_KEY = Symbol.for("stratal:inject:param");
30
- /**
31
- * Mark a method parameter for DI injection
32
- *
33
- * The parameter will be resolved from the request-scoped container
34
- * when the controller method is invoked.
35
- *
36
- * @param token - DI token to resolve (class or symbol)
37
- *
38
- * @example With class token
39
- * ```typescript
40
- * async show(
41
- * ctx: RouterContext,
42
- * @InjectParam(UserService) userService: UserService
43
- * ) { }
44
- * ```
45
- *
46
- * @example With symbol token
47
- * ```typescript
48
- * async show(
49
- * ctx: RouterContext,
50
- * @InjectParam(DI_TOKENS.Cache) cache: ICacheService
51
- * ) { }
52
- * ```
53
- */
54
- function InjectParam(token) {
55
- return (target, propertyKey, parameterIndex) => {
56
- if (propertyKey === void 0) throw new Error("@InjectParam can only be used on method parameters, not constructor parameters");
57
- const existingInjections = Reflect.getMetadata(INJECT_PARAM_METADATA_KEY, target, propertyKey) ?? [];
58
- existingInjections.push({
59
- index: parameterIndex,
60
- token
61
- });
62
- Reflect.defineMetadata(INJECT_PARAM_METADATA_KEY, existingInjections, target, propertyKey);
63
- };
64
- }
65
- /**
66
- * Get method parameter injections
67
- *
68
- * @param target - Controller prototype
69
- * @param propertyKey - Method name
70
- * @returns Array of parameter injections sorted by index
71
- */
72
- function getMethodInjections(target, propertyKey) {
73
- return (Reflect.getMetadata(INJECT_PARAM_METADATA_KEY, target, propertyKey) ?? []).sort((a, b) => a.index - b.index);
74
- }
75
- //#endregion
76
- //#region src/di/decorators.ts
77
- /**
78
- * DI Decorators
79
- *
80
- * Provides decorators for dependency injection:
81
- * - @Transient: Mark classes as injectable (lifecycle controlled at registration)
82
- * - @InjectParam: Inject dependencies into method parameters
83
- *
84
- * Lifecycle (Singleton, Request, Transient) is controlled at registration time
85
- * via the `scope` property in module providers or Container.register().
86
- */
87
- /**
88
- * Mark a class as injectable
89
- *
90
- * This decorator wraps tsyringe's `@injectable` decorator and optionally
91
- * associates a token with the class. The actual lifecycle (Singleton, Request,
92
- * Transient) is determined at registration time, not decoration time.
93
- *
94
- * **Lifecycle Control:**
95
- * - Use `scope: Scope.Singleton` in module providers for singleton
96
- * - Use `scope: Scope.Request` in module providers for request-scoped
97
- * - Default is Transient (new instance per resolution)
98
- *
99
- * @param token - Optional DI token for service resolution
100
- *
101
- * @example Basic usage (no token)
102
- * ```typescript
103
- * @Transient()
104
- * export class UserService {
105
- * constructor(@inject(DI_TOKENS.Database) private db: DatabaseService) {}
106
- * }
107
- *
108
- * // In module:
109
- * @Module({
110
- * providers: [UserService] // Transient by default
111
- * })
112
- * ```
113
- *
114
- * @example With token
115
- * ```typescript
116
- * @Transient(DI_TOKENS.ConnectionManager)
117
- * export class ConnectionManager implements Disposable {
118
- * // ...
119
- * }
120
- *
121
- * // In Application.ts:
122
- * container.register(DI_TOKENS.ConnectionManager, ConnectionManager, Scope.Request)
123
- * ```
124
- *
125
- * @example Singleton via provider scope
126
- * ```typescript
127
- * @Transient()
128
- * export class ConsumerRegistry {
129
- * // ...
130
- * }
131
- *
132
- * // In module:
133
- * @Module({
134
- * providers: [
135
- * { provide: DI_TOKENS.ConsumerRegistry, useClass: ConsumerRegistry, scope: Scope.Singleton }
136
- * ]
137
- * })
138
- * ```
139
- */
140
- function Transient(token) {
141
- return function(target) {
142
- const targetConstructor = target;
143
- injectable({ token })(targetConstructor);
144
- return target;
145
- };
146
- }
147
- //#endregion
1
+ import { i as Transient, l as DI_TOKENS, n as __decorateParam, r as __decorateMetadata, t as __decorate } from "./decorate-D5j-d9_z.mjs";
2
+ import { inject } from "tsyringe";
148
3
  //#region src/logger/logger.tokens.ts
149
4
  /**
150
5
  * Dependency Injection Tokens for Logger Module
@@ -183,26 +38,6 @@ const LOG_LEVEL_PRIORITY = {
183
38
  [LogLevel.ERROR]: 3
184
39
  };
185
40
  //#endregion
186
- //#region \0@oxc-project+runtime@0.115.0/helpers/decorateMetadata.js
187
- function __decorateMetadata(k, v) {
188
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
189
- }
190
- //#endregion
191
- //#region \0@oxc-project+runtime@0.115.0/helpers/decorateParam.js
192
- function __decorateParam(paramIndex, decorator) {
193
- return function(target, key) {
194
- decorator(target, key, paramIndex);
195
- };
196
- }
197
- //#endregion
198
- //#region \0@oxc-project+runtime@0.115.0/helpers/decorate.js
199
- function __decorate(decorators, target, key, desc) {
200
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
201
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
202
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
203
- return c > 3 && r && Object.defineProperty(target, key, r), r;
204
- }
205
- //#endregion
206
41
  //#region src/logger/services/logger.service.ts
207
42
  var _ref, _ref2;
208
43
  let LoggerService = class LoggerService {
@@ -412,6 +247,6 @@ let ConsoleTransport = class ConsoleTransport extends BaseTransport {
412
247
  };
413
248
  ConsoleTransport = __decorate([Transient(LOGGER_TOKENS.ConsoleTransport)], ConsoleTransport);
414
249
  //#endregion
415
- export { __decorate as a, LOG_LEVEL_PRIORITY as c, Transient as d, INJECT_PARAM_METADATA_KEY as f, DI_TOKENS as g, CONTAINER_TOKEN as h, LoggerService as i, LogLevel as l, getMethodInjections as m, PrettyFormatter as n, __decorateParam as o, InjectParam as p, JsonFormatter as r, __decorateMetadata as s, ConsoleTransport as t, LOGGER_TOKENS as u };
250
+ export { LOG_LEVEL_PRIORITY as a, LoggerService as i, PrettyFormatter as n, LogLevel as o, JsonFormatter as r, LOGGER_TOKENS as s, ConsoleTransport as t };
416
251
 
417
- //# sourceMappingURL=logger-Bg-CuidS.mjs.map
252
+ //# sourceMappingURL=logger-BR1-s1Um.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger-BR1-s1Um.mjs","names":[],"sources":["../src/logger/logger.tokens.ts","../src/logger/contracts/log-level.ts","../src/logger/services/logger.service.ts","../src/logger/formatters/json-formatter.ts","../src/logger/formatters/pretty-formatter.ts","../src/logger/transports/base-transport.ts","../src/logger/transports/console-transport.ts"],"sourcesContent":["/**\n * Dependency Injection Tokens for Logger Module\n *\n * Symbol-based tokens ensure type-safe dependency injection\n * and prevent naming collisions.\n */\nexport const LOGGER_TOKENS = {\n /**\n * Main logger service facade\n */\n LoggerService: Symbol.for('stratal:logger:service'),\n\n /**\n * Log formatter (JSON or Pretty)\n */\n Formatter: Symbol.for('stratal:logger:formatter'),\n\n /**\n * Array of active transports\n */\n Transports: Symbol.for('stratal:logger:transports'),\n\n /**\n * Individual transport tokens (for factory registration)\n */\n ConsoleTransport: Symbol.for('stratal:logger:console:transport'),\n\n /**\n * Configured log level for filtering\n */\n LogLevelOptions: Symbol.for('stratal:logger:log:level:options'),\n} as const\n","/**\n * Log severity levels\n * Ordered from least to most severe\n */\nexport enum LogLevel {\n DEBUG = 'debug',\n INFO = 'info',\n WARN = 'warn',\n ERROR = 'error',\n}\n\n/**\n * Map log levels to numeric priorities (for filtering)\n * Higher numbers = more severe = higher priority\n */\nexport const LOG_LEVEL_PRIORITY: Record<LogLevel, number> = {\n [LogLevel.DEBUG]: 0,\n [LogLevel.INFO]: 1,\n [LogLevel.WARN]: 2,\n [LogLevel.ERROR]: 3,\n}\n","import { inject } from 'tsyringe'\nimport { Transient } from '../../di/decorators'\nimport { DI_TOKENS } from '../../di/tokens'\nimport type { InternalLogContext, LogContext, LogEntry } from '../contracts'\nimport { LOG_LEVEL_PRIORITY, LogLevel } from '../contracts/log-level'\nimport type { ILogFormatter } from '../formatters/formatter.interface'\nimport { LOGGER_TOKENS } from '../logger.tokens'\nimport type { ILogTransport } from '../transports/transport.interface'\n\n/**\n * Logger Service\n *\n * Main logging facade.\n *\n * **Features:**\n * - Async logging via ctx.waitUntil() for non-blocking performance\n * - Multi-transport support (console, future Sentry/Cloudflare Analytics)\n * - Configurable formatters (JSON production, Pretty development)\n * - Log level filtering based on environment\n *\n * **Architecture:**\n * - Transports and formatters injected via DI\n *\n * @example Basic usage\n * ```typescript\n * @Transient()\n * export class UserService {\n * constructor(\n * @inject(LOGGER_TOKENS.LoggerService)\n * private readonly logger: LoggerService\n * ) {}\n *\n * async createUser(input: CreateUserInput) {\n * this.logger.info('Creating user', { email: input.email })\n * }\n * }\n * ```\n */\n@Transient()\nexport class LoggerService {\n constructor(\n @inject(LOGGER_TOKENS.LogLevelOptions)\n private readonly logLevel: LogLevel,\n\n @inject(DI_TOKENS.ExecutionContext)\n private readonly executionContext: globalThis.ExecutionContext,\n\n @inject(LOGGER_TOKENS.Formatter)\n private readonly formatter: ILogFormatter,\n\n @inject(LOGGER_TOKENS.Transports)\n private readonly transports: ILogTransport[],\n ) { }\n\n /**\n * Log debug message (development only)\n */\n debug(message: string, context?: LogContext): void {\n this.log(LogLevel.DEBUG, message, context)\n }\n\n /**\n * Log info message\n */\n info(message: string, context?: LogContext): void {\n this.log(LogLevel.INFO, message, context)\n }\n\n /**\n * Log warning message\n */\n warn(message: string, context?: LogContext): void {\n this.log(LogLevel.WARN, message, context)\n }\n\n /**\n * Log error message\n * Accepts Error object or custom context\n */\n error(message: string, contextOrError?: LogContext | Error): void {\n let context: LogContext | undefined\n let error: Error | undefined\n\n if (contextOrError instanceof Error) {\n error = contextOrError\n } else {\n context = contextOrError\n }\n\n this.log(LogLevel.ERROR, message, context, error)\n }\n\n /**\n * Core logging implementation\n * Enriches context, formats message, dispatches to transports\n * Uses ctx.waitUntil() for async non-blocking processing\n */\n private log(\n level: LogLevel,\n message: string,\n userContext?: LogContext,\n error?: Error\n ): void {\n // Filter by configured log level\n if (LOG_LEVEL_PRIORITY[level] < LOG_LEVEL_PRIORITY[this.logLevel]) {\n return\n }\n\n // Build complete log entry with enriched context\n const entry: LogEntry = {\n level,\n message,\n context: this.enrichContext(userContext ?? {}),\n error: error ? this.serializeError(error) : undefined,\n }\n\n // Format once for all transports\n const formatted = this.formatter.format(entry)\n\n // Dispatch to all transports asynchronously\n const writePromises = this.transports.map(transport =>\n transport.write(entry, formatted).catch((err: unknown) => {\n // Swallow transport errors to prevent log failure from crashing app\n console.error(`Transport ${transport.name} failed:`, err)\n })\n )\n\n // Use waitUntil to ensure logs complete even after response sent\n const allWrites = Promise.all(writePromises)\n try {\n this.executionContext.waitUntil(allWrites)\n } catch (error) {\n if (!(error instanceof Error) || !error.message.includes('global scope')) {\n throw error\n }\n }\n }\n\n /**\n * Enrich log context with request info and timestamp\n * Context enrichment can be extended by application modules\n */\n private enrichContext(userContext: LogContext): InternalLogContext {\n return {\n ...userContext,\n timestamp: Date.now(),\n }\n }\n\n /**\n * Serialize Error object for transport\n */\n private serializeError(error: Error): { message: string; stack?: string; name?: string } {\n return {\n message: error.message,\n stack: error.stack,\n name: error.name,\n }\n }\n}\n","import type { LogEntry } from '../contracts'\nimport type { ILogFormatter } from './formatter.interface'\n\n/**\n * JSON Formatter\n *\n * Produces structured JSON logs for production environments.\n * Optimized for log aggregation systems (Cloudflare Analytics, Datadog, etc.)\n *\n * Output format:\n * {\n * \"level\": \"info\",\n * \"message\": \"User logged in\",\n * \"timestamp\": 1234567890,\n * \"userId\": \"user_456\",\n * \"error\": { \"message\": \"...\", \"stack\": \"...\" }\n * }\n */\nexport class JsonFormatter implements ILogFormatter {\n format(entry: LogEntry): string {\n const output = {\n level: entry.level,\n message: entry.message,\n ...entry.context,\n ...(entry.error && { error: entry.error }),\n }\n\n return JSON.stringify(output)\n }\n}\n","import type { LogEntry } from '../contracts'\nimport { LogLevel } from '../contracts'\nimport type { ILogFormatter } from './formatter.interface'\n\n/**\n * Pretty Formatter\n *\n * Human-readable colored output for development environments.\n * Uses ANSI color codes for terminal output.\n *\n * Output format:\n * [2024-01-15 10:30:45] INFO: User logged in\n * userId: user_456\n */\nexport class PrettyFormatter implements ILogFormatter {\n private readonly colors: Record<LogLevel, string> = {\n [LogLevel.DEBUG]: '\\x1b[36m', // Cyan\n [LogLevel.INFO]: '\\x1b[32m', // Green\n [LogLevel.WARN]: '\\x1b[33m', // Yellow\n [LogLevel.ERROR]: '\\x1b[31m', // Red\n }\n\n private readonly reset = '\\x1b[0m'\n\n format(entry: LogEntry): string {\n const color = this.colors[entry.level]\n const timestamp = new Date(entry.context.timestamp).toISOString()\n const levelStr = entry.level.toUpperCase().padEnd(5)\n\n let output = `${color}[${timestamp}] ${levelStr}${this.reset}: ${entry.message}`\n\n // Add context (exclude timestamp)\n const { timestamp: _, ...contextWithoutTimestamp } = entry.context\n const contextEntries = Object.entries(contextWithoutTimestamp)\n\n if (contextEntries.length > 0) {\n output += '\\n'\n contextEntries.forEach(([key, value]) => {\n output += ` ${key}: ${JSON.stringify(value)}\\n`\n })\n }\n\n // Add error stack if present\n if (entry.error?.stack) {\n output += `\\n${entry.error.stack}\\n`\n }\n\n return output.trimEnd()\n }\n}\n","import type { ILogTransport } from './transport.interface'\nimport type { LogEntry } from '../contracts'\n\n/**\n * Base Transport\n *\n * Abstract base class providing shared transport logic.\n * Reduces code duplication across transport implementations.\n */\nexport abstract class BaseTransport implements ILogTransport {\n abstract readonly name: string\n\n /**\n * Write log entry - must be implemented by concrete transports\n */\n abstract write(entry: LogEntry, formatted: string): Promise<void>\n\n /**\n * Handle transport errors gracefully\n * Logs to console.error as fallback to prevent log loss\n *\n * @param error - Error that occurred during write\n * @param entry - Log entry that failed\n */\n protected handleError(error: unknown, entry: LogEntry): void {\n console.error(`[${this.name}] Failed to write log:`, {\n error: error instanceof Error ? error.message : String(error),\n logMessage: entry.message,\n level: entry.level,\n })\n }\n}\n","import { Transient } from '../../di/decorators'\nimport { LOGGER_TOKENS } from '../logger.tokens'\nimport { BaseTransport } from './base-transport'\nimport type { LogEntry } from '../contracts'\nimport { LogLevel } from '../contracts'\n\n/**\n * Console Transport\n *\n * Writes logs to console using appropriate console methods.\n * Maps log levels to console.debug, console.info, console.warn, console.error.\n *\n * Thread-safe for Cloudflare Workers environment.\n */\n@Transient(LOGGER_TOKENS.ConsoleTransport)\nexport class ConsoleTransport extends BaseTransport {\n readonly name = 'console'\n\n write(entry: LogEntry, formatted: string): Promise<void> {\n try {\n const consoleMethod = this.getConsoleMethod(entry.level)\n consoleMethod(formatted)\n } catch (error) {\n this.handleError(error, entry)\n }\n\n return Promise.resolve()\n }\n\n /**\n * Map log level to console method\n */\n private getConsoleMethod(level: LogLevel): typeof console.log {\n switch (level) {\n case LogLevel.DEBUG:\n return console.debug\n case LogLevel.INFO:\n return console.info\n case LogLevel.WARN:\n return console.warn\n case LogLevel.ERROR:\n return console.error\n default:\n return console.log\n }\n }\n}\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import { G as MiddlewareConsumerImpl, K as createMiddlewareConsumer, W as MiddlewareConfigurationService, _t as MiddlewareConfigEntry, bt as MiddlewareRouteTarget, gt as MiddlewareBuilder, vt as MiddlewareConfigurable, xt as RouteInfo, yt as MiddlewareConsumer } from "../index-C9bIk5tt.mjs";
1
+ import { G as MiddlewareConsumerImpl, K as createMiddlewareConsumer, W as MiddlewareConfigurationService, _t as MiddlewareConfigEntry, bt as MiddlewareRouteTarget, gt as MiddlewareBuilder, vt as MiddlewareConfigurable, xt as RouteInfo, yt as MiddlewareConsumer } from "../index-D69rxo8H.mjs";
2
2
  export { MiddlewareBuilder, MiddlewareConfigEntry, MiddlewareConfigurable, MiddlewareConfigurationService, MiddlewareConsumer, MiddlewareConsumerImpl, MiddlewareRouteTarget, RouteInfo, createMiddlewareConsumer };
@@ -1,5 +1,6 @@
1
- import "../errors-BRJgVd5-.mjs";
2
- import "../logger-Bg-CuidS.mjs";
3
- import { o as MiddlewareConsumerImpl, s as createMiddlewareConsumer, t as MiddlewareConfigurationService } from "../middleware-B3tx1u1K.mjs";
4
- import "../router-context-DlTxpJUG.mjs";
1
+ import "../errors-CtCi1wn6.mjs";
2
+ import "../decorate-D5j-d9_z.mjs";
3
+ import "../logger-BR1-s1Um.mjs";
4
+ import { o as MiddlewareConsumerImpl, s as createMiddlewareConsumer, t as MiddlewareConfigurationService } from "../middleware-iRhNjsPH.mjs";
5
+ import "../router-context-BLn4PrRG.mjs";
5
6
  export { MiddlewareConfigurationService, MiddlewareConsumerImpl, createMiddlewareConsumer };
@@ -1,5 +1,5 @@
1
- import { d as Transient } from "./logger-Bg-CuidS.mjs";
2
- import { o as ROUTE_METADATA_KEYS, t as RouterContext } from "./router-context-DlTxpJUG.mjs";
1
+ import { i as Transient } from "./decorate-D5j-d9_z.mjs";
2
+ import { o as ROUTE_METADATA_KEYS, t as RouterContext } from "./router-context-BLn4PrRG.mjs";
3
3
  //#region src/middleware/middleware-consumer.ts
4
4
  /**
5
5
  * Builder for configuring middleware routes and exclusions
@@ -359,4 +359,4 @@ var MiddlewareConfigurationService = class {
359
359
  //#endregion
360
360
  export { getControllerVersion as a, getControllerRoute as i, Controller as n, MiddlewareConsumerImpl as o, getControllerOptions as r, createMiddlewareConsumer as s, MiddlewareConfigurationService as t };
361
361
 
362
- //# sourceMappingURL=middleware-B3tx1u1K.mjs.map
362
+ //# sourceMappingURL=middleware-iRhNjsPH.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"middleware-B3tx1u1K.mjs","names":[],"sources":["../src/middleware/middleware-consumer.ts","../src/router/decorators/controller.decorator.ts","../src/middleware/middleware-configuration.service.ts"],"sourcesContent":["import type { Middleware } from '../router/middleware.interface'\nimport type { Constructor } from '../types'\nimport type {\n MiddlewareConfigEntry,\n MiddlewareConsumer as IMiddlewareConsumer,\n MiddlewareBuilder as IMiddlewareBuilder,\n MiddlewareRouteTarget,\n RouteInfo,\n} from './types'\n\n/**\n * Builder for configuring middleware routes and exclusions\n *\n * Provides fluent API for specifying where middleware should apply.\n */\nclass MiddlewareBuilderImpl implements IMiddlewareBuilder {\n private middlewares: Constructor<Middleware>[]\n private excludedRoutes: RouteInfo[] = []\n private consumer: MiddlewareConsumerImpl\n\n constructor(\n middlewares: Constructor<Middleware>[],\n consumer: MiddlewareConsumerImpl\n ) {\n this.middlewares = middlewares\n this.consumer = consumer\n }\n\n /**\n * Exclude specific routes from middleware\n *\n * @param routes - Routes to exclude (path strings or RouteInfo objects)\n * @returns this for method chaining\n *\n * @example\n * ```typescript\n * consumer\n * .apply(AuthMiddleware)\n * .exclude('/health', { path: '/api/public', method: 'get' })\n * .forRoutes('*')\n * ```\n */\n exclude(...routes: (string | RouteInfo)[]): this {\n for (const route of routes) {\n if (typeof route === 'string') {\n this.excludedRoutes.push({ path: route })\n } else {\n this.excludedRoutes.push(route)\n }\n }\n return this\n }\n\n /**\n * Apply middleware to specified routes\n *\n * This method finalizes the configuration and registers it with the consumer.\n *\n * @param targets - Controller classes, RouteInfo objects, or '*' for global\n *\n * @example\n * ```typescript\n * // Apply to all routes\n * consumer.apply(LoggingMiddleware).forRoutes('*')\n *\n * // Apply to specific controllers\n * consumer.apply(CorsMiddleware).forRoutes(ApiController, WebhooksController)\n *\n * // Apply to specific paths\n * consumer.apply(RateLimitMiddleware).forRoutes(\n * { path: '/api/v1/auth', method: 'post' }\n * )\n * ```\n */\n forRoutes(...targets: MiddlewareRouteTarget[]): void {\n const entry: MiddlewareConfigEntry = {\n middlewares: this.middlewares,\n excludes: this.excludedRoutes,\n routes: targets,\n }\n this.consumer.addEntry(entry)\n }\n}\n\n/**\n * Consumer for configuring middleware in modules\n *\n * Provides fluent API for registering middleware with route targeting.\n * Used by modules implementing MiddlewareConfigurable interface.\n *\n * @example\n * ```typescript\n * @Module({ providers: [...] })\n * export class AppModule implements MiddlewareConfigurable {\n * configure(consumer: MiddlewareConsumer): void {\n * // Global logging middleware (excludes health check)\n * consumer\n * .apply(LoggingMiddleware)\n * .exclude('/health')\n * .forRoutes('*')\n *\n * // CORS middleware for specific controllers\n * consumer\n * .apply(CorsMiddleware)\n * .forRoutes(ApiController, WebhooksController)\n *\n * // Rate limiting for auth endpoints\n * consumer\n * .apply(RateLimitMiddleware)\n * .forRoutes({ path: '/api/v1/auth/*', method: 'post' })\n * }\n * }\n * ```\n */\nexport class MiddlewareConsumerImpl implements IMiddlewareConsumer {\n private entries: MiddlewareConfigEntry[] = []\n\n /**\n * Start configuring middleware\n *\n * @param middlewares - Middleware classes to apply\n * @returns Builder for configuring routes and exclusions\n */\n apply(...middlewares: Constructor<Middleware>[]): IMiddlewareBuilder {\n return new MiddlewareBuilderImpl(middlewares, this)\n }\n\n /**\n * Add a configuration entry (called by builder)\n * @internal\n */\n addEntry(entry: MiddlewareConfigEntry): void {\n this.entries.push(entry)\n }\n\n /**\n * Get all configured middleware entries\n */\n getEntries(): MiddlewareConfigEntry[] {\n return this.entries\n }\n}\n\n/**\n * Create a new middleware consumer instance\n */\nexport function createMiddlewareConsumer(): IMiddlewareConsumer {\n return new MiddlewareConsumerImpl()\n}\n","import { Transient } from '../../di/decorators'\nimport { type Constructor } from '../../types'\nimport { ROUTE_METADATA_KEYS } from '../constants'\nimport { type ControllerOptions } from '../types'\n\nconst CONTROLLER_ROUTE_KEY = ROUTE_METADATA_KEYS.CONTROLLER_ROUTE\n\n/**\n * Base controller decorator for route registration\n *\n * This is the core controller decorator that handles:\n * - Transient scope registration (request-scoped)\n * - Route metadata storage\n * - Controller options (tags, security schemes, hideFromDocs)\n *\n * @param route - Base route for this controller (e.g., '/api/v1/users')\n * @param options - Optional configuration (tags, security schemes, hideFromDocs)\n *\n * @example\n * ```typescript\n * import { Controller } from 'stratal/router'\n *\n * @Controller('/api/v1/users', { tags: ['Users'] })\n * export class UsersController implements IController {\n * // All routes accessible\n * }\n * ```\n */\nexport function Controller(route: string, options?: ControllerOptions) {\n return function <T extends Constructor>(target: T) {\n // Wrap @Transient (handles @injectable and scope metadata)\n Transient()(target)\n\n // Store route metadata on the class\n Reflect.defineMetadata(CONTROLLER_ROUTE_KEY, route, target)\n\n // Store options metadata if provided\n if (options) {\n Reflect.defineMetadata(ROUTE_METADATA_KEYS.CONTROLLER_OPTIONS, options, target)\n }\n\n return target\n }\n}\n\n/**\n * Get the route from controller class metadata\n *\n * @param target - Controller class or instance\n * @returns Route string or undefined if not set\n */\nexport function getControllerRoute(target: object): string | undefined {\n // Check if target is a class constructor (function) or an instance\n // If class, get metadata from it directly; if instance, get from constructor\n const metadataTarget = typeof target === 'function' ? target : (target as { constructor: object }).constructor\n return Reflect.getMetadata(CONTROLLER_ROUTE_KEY, metadataTarget) as string | undefined\n}\n\n/**\n * Get the options from controller class metadata\n *\n * @param target - Controller class or instance\n * @returns Controller options or undefined if not set\n */\nexport function getControllerOptions(target: object): ControllerOptions | undefined {\n const metadataTarget = typeof target === 'function' ? target : (target as { constructor: object }).constructor\n return Reflect.getMetadata(ROUTE_METADATA_KEYS.CONTROLLER_OPTIONS, metadataTarget) as ControllerOptions | undefined\n}\n\n/**\n * Get the version from controller class metadata\n *\n * @param target - Controller class or instance\n * @returns Version string, array, VERSION_NEUTRAL symbol, or undefined if not set\n */\nexport function getControllerVersion(target: object): ControllerOptions['version'] {\n const options = getControllerOptions(target)\n return options?.version\n}\n","import type { Context } from 'hono'\nimport type { OpenAPIHono } from '../i18n/validation'\nimport type { Container } from '../di'\nimport type { LoggerService } from '../logger'\nimport type { IController } from '../router/controller'\nimport { getControllerRoute } from '../router/decorators/controller.decorator'\nimport type { Middleware } from '../router/middleware.interface'\nimport { RouterContext } from '../router/router-context'\nimport type { HttpMethod, RouterEnv, VersioningOptions } from '../router/types'\nimport type { Constructor } from '../types'\nimport type { MiddlewareConfigEntry, RouteInfo } from './types'\n\n/**\n * Service for applying middleware configurations to Hono app\n *\n * Processes MiddlewareConfigEntry[] from modules and registers\n * appropriate middleware handlers with route matching.\n */\nexport class MiddlewareConfigurationService {\n constructor(\n private readonly logger: LoggerService,\n private readonly versioningOptions: VersioningOptions | null = null,\n ) { }\n\n /**\n * Apply middleware configurations to the Hono app\n *\n * @param app - Hono application instance\n * @param configs - Middleware configuration entries from modules\n * @param controllers - All registered controller classes (for route resolution)\n * @param container - DI container for resolving middleware instances\n */\n applyMiddlewares(\n app: OpenAPIHono<RouterEnv>,\n configs: MiddlewareConfigEntry[],\n controllers: Constructor<IController>[],\n container: Container\n ): void {\n for (const config of configs) {\n this.applyMiddlewareConfig(app, config, controllers, container)\n }\n }\n\n /**\n * Apply a single middleware configuration entry\n */\n private applyMiddlewareConfig(\n app: OpenAPIHono<RouterEnv>,\n config: MiddlewareConfigEntry,\n controllers: Constructor<IController>[],\n container: Container\n ): void {\n const { middlewares, excludes, routes } = config\n\n // Resolve route patterns from targets\n const routePatterns = this.resolveRoutePatterns(routes, controllers)\n\n // Log the configuration for debugging\n this.logger.debug('Applying middleware configuration', {\n middlewares: middlewares.map(m => m.name),\n routes: routePatterns,\n excludes: excludes,\n })\n\n // Apply middleware to each route pattern\n for (const pattern of routePatterns) {\n this.registerMiddlewareForPattern(app, middlewares, pattern, excludes, container)\n }\n }\n\n /**\n * Resolve route targets into concrete route patterns\n */\n private resolveRoutePatterns(\n targets: (Constructor<IController> | RouteInfo | '*')[],\n _controllers: Constructor<IController>[]\n ): RouteInfo[] {\n const patterns: RouteInfo[] = []\n\n for (const target of targets) {\n if (target === '*') {\n // Global middleware - apply to all routes\n patterns.push({ path: '*' })\n } else if (typeof target === 'function') {\n // Controller class - get its route from metadata\n const route = getControllerRoute(target)\n if (route) {\n // Add wildcard for all paths under this controller\n patterns.push({ path: `${route}/*` })\n // Also match the exact path\n patterns.push({ path: route })\n } else {\n this.logger.warn('Controller has no route metadata', { controller: target.name })\n }\n } else {\n // RouteInfo object - resolve version if present\n if (!this.versioningOptions || !target.version) {\n // Fast path: no versioning or no version on target — push directly\n patterns.push(target)\n } else {\n const resolved = this.resolveVersionedRouteInfo(target)\n patterns.push(...resolved)\n }\n }\n }\n\n return patterns\n }\n\n /**\n * Resolve a RouteInfo with version into versioned path(s).\n * If versioning is disabled or no version is specified, returns the RouteInfo as-is.\n */\n private resolveVersionedRouteInfo(routeInfo: RouteInfo): RouteInfo[] {\n if (!this.versioningOptions || !routeInfo.version) {\n return [routeInfo]\n }\n\n const prefix = this.versioningOptions.prefix ?? 'v'\n const versions = Array.isArray(routeInfo.version) ? routeInfo.version : [routeInfo.version]\n const results: RouteInfo[] = []\n\n for (const v of versions) {\n const versionedPath = `/${prefix}${v}${routeInfo.path}`\n // Add exact path match\n results.push({ path: versionedPath, method: routeInfo.method })\n // Add wildcard match for sub-paths\n results.push({ path: `${versionedPath}/*`, method: routeInfo.method })\n }\n\n return results\n }\n\n /**\n * Register middleware handlers for a specific route pattern\n */\n private registerMiddlewareForPattern(\n app: OpenAPIHono<RouterEnv>,\n middlewares: Constructor<Middleware>[],\n pattern: RouteInfo,\n excludes: RouteInfo[],\n container: Container\n ): void {\n const path = pattern.path\n const methods = pattern.method\n ? (Array.isArray(pattern.method) ? pattern.method : [pattern.method])\n : undefined\n\n // Create the middleware handler\n const handler = this.createMiddlewareHandler(middlewares, excludes, container)\n\n // Register with Hono\n if (methods && methods.length > 0) {\n // Method-specific registration\n for (const method of methods) {\n this.registerForMethod(app, method, path, handler)\n }\n } else {\n // All methods\n app.use(path, handler)\n }\n }\n\n /**\n * Register handler for a specific HTTP method\n */\n private registerForMethod(\n app: OpenAPIHono<RouterEnv>,\n method: HttpMethod,\n path: string,\n handler: (c: Context<RouterEnv>, next: () => Promise<void>) => Promise<void>\n ): void {\n switch (method) {\n case 'get':\n app.get(path, handler)\n break\n case 'post':\n app.post(path, handler)\n break\n case 'put':\n app.put(path, handler)\n break\n case 'delete':\n app.delete(path, handler)\n break\n case 'patch':\n app.patch(path, handler)\n break\n default:\n app.use(path, handler)\n }\n }\n\n /**\n * Create a middleware handler function that executes the middleware chain\n */\n private createMiddlewareHandler(\n middlewares: Constructor<Middleware>[],\n excludes: RouteInfo[],\n container: Container\n ): (c: Context<RouterEnv>, next: () => Promise<void>) => Promise<void> {\n return async (c, next) => {\n const requestPath = c.req.path\n const requestMethod = c.req.method.toLowerCase() as HttpMethod\n\n // Check if this request should be excluded\n if (this.isExcluded(requestPath, requestMethod, excludes)) {\n await next()\n return\n }\n\n // Create RouterContext for middleware\n const ctx = new RouterContext(c)\n\n // Execute middleware chain\n await this.executeMiddlewareChain(middlewares, ctx, container, next)\n }\n }\n\n /**\n * Check if a request matches any exclusion pattern\n */\n private isExcluded(\n requestPath: string,\n requestMethod: HttpMethod,\n excludes: RouteInfo[]\n ): boolean {\n for (const exclude of excludes) {\n if (this.matchesRoute(requestPath, requestMethod, exclude)) {\n return true\n }\n }\n return false\n }\n\n /**\n * Check if request matches a route pattern\n */\n private matchesRoute(\n requestPath: string,\n requestMethod: HttpMethod,\n route: RouteInfo\n ): boolean {\n // Check method match (if specified)\n if (route.method) {\n const methods = Array.isArray(route.method) ? route.method : [route.method]\n if (!methods.includes(requestMethod)) {\n return false\n }\n }\n\n // Check path match\n return this.matchesPath(requestPath, route.path)\n }\n\n /**\n * Match request path against pattern\n * Supports wildcards: /api/* matches /api/users, /api/v1/users\n */\n private matchesPath(requestPath: string, pattern: string): boolean {\n // Exact match\n if (pattern === requestPath) {\n return true\n }\n\n // Global wildcard\n if (pattern === '*') {\n return true\n }\n\n // Wildcard pattern (e.g., /api/*)\n if (pattern.endsWith('/*')) {\n const prefix = pattern.slice(0, -2)\n return requestPath === prefix || requestPath.startsWith(prefix + '/')\n }\n\n // Path parameter pattern (e.g., /api/users/:id)\n // Convert to regex for matching\n const regexPattern = pattern\n .replace(/:[^/]+/g, '[^/]+') // Replace :param with regex\n .replace(/\\*/g, '.*') // Replace * with regex\n const regex = new RegExp(`^${regexPattern}$`)\n return regex.test(requestPath)\n }\n\n /**\n * Execute middleware chain in order\n */\n private async executeMiddlewareChain(\n middlewares: Constructor<Middleware>[],\n ctx: RouterContext,\n container: Container,\n finalNext: () => Promise<void>\n ): Promise<void> {\n // Build middleware chain from end to start\n let chain = finalNext\n\n for (let i = middlewares.length - 1; i >= 0; i--) {\n const MiddlewareClass = middlewares[i]\n const currentNext = chain\n\n chain = async () => {\n // Resolve middleware from request-scoped container\n const requestContainer = ctx.getContainer()\n const middleware = requestContainer.resolve<Middleware>(MiddlewareClass)\n await middleware.handle(ctx, currentNext)\n }\n }\n\n // Execute the chain\n await chain()\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"middleware-iRhNjsPH.mjs","names":[],"sources":["../src/middleware/middleware-consumer.ts","../src/router/decorators/controller.decorator.ts","../src/middleware/middleware-configuration.service.ts"],"sourcesContent":["import type { Middleware } from '../router/middleware.interface'\nimport type { Constructor } from '../types'\nimport type {\n MiddlewareConfigEntry,\n MiddlewareConsumer as IMiddlewareConsumer,\n MiddlewareBuilder as IMiddlewareBuilder,\n MiddlewareRouteTarget,\n RouteInfo,\n} from './types'\n\n/**\n * Builder for configuring middleware routes and exclusions\n *\n * Provides fluent API for specifying where middleware should apply.\n */\nclass MiddlewareBuilderImpl implements IMiddlewareBuilder {\n private middlewares: Constructor<Middleware>[]\n private excludedRoutes: RouteInfo[] = []\n private consumer: MiddlewareConsumerImpl\n\n constructor(\n middlewares: Constructor<Middleware>[],\n consumer: MiddlewareConsumerImpl\n ) {\n this.middlewares = middlewares\n this.consumer = consumer\n }\n\n /**\n * Exclude specific routes from middleware\n *\n * @param routes - Routes to exclude (path strings or RouteInfo objects)\n * @returns this for method chaining\n *\n * @example\n * ```typescript\n * consumer\n * .apply(AuthMiddleware)\n * .exclude('/health', { path: '/api/public', method: 'get' })\n * .forRoutes('*')\n * ```\n */\n exclude(...routes: (string | RouteInfo)[]): this {\n for (const route of routes) {\n if (typeof route === 'string') {\n this.excludedRoutes.push({ path: route })\n } else {\n this.excludedRoutes.push(route)\n }\n }\n return this\n }\n\n /**\n * Apply middleware to specified routes\n *\n * This method finalizes the configuration and registers it with the consumer.\n *\n * @param targets - Controller classes, RouteInfo objects, or '*' for global\n *\n * @example\n * ```typescript\n * // Apply to all routes\n * consumer.apply(LoggingMiddleware).forRoutes('*')\n *\n * // Apply to specific controllers\n * consumer.apply(CorsMiddleware).forRoutes(ApiController, WebhooksController)\n *\n * // Apply to specific paths\n * consumer.apply(RateLimitMiddleware).forRoutes(\n * { path: '/api/v1/auth', method: 'post' }\n * )\n * ```\n */\n forRoutes(...targets: MiddlewareRouteTarget[]): void {\n const entry: MiddlewareConfigEntry = {\n middlewares: this.middlewares,\n excludes: this.excludedRoutes,\n routes: targets,\n }\n this.consumer.addEntry(entry)\n }\n}\n\n/**\n * Consumer for configuring middleware in modules\n *\n * Provides fluent API for registering middleware with route targeting.\n * Used by modules implementing MiddlewareConfigurable interface.\n *\n * @example\n * ```typescript\n * @Module({ providers: [...] })\n * export class AppModule implements MiddlewareConfigurable {\n * configure(consumer: MiddlewareConsumer): void {\n * // Global logging middleware (excludes health check)\n * consumer\n * .apply(LoggingMiddleware)\n * .exclude('/health')\n * .forRoutes('*')\n *\n * // CORS middleware for specific controllers\n * consumer\n * .apply(CorsMiddleware)\n * .forRoutes(ApiController, WebhooksController)\n *\n * // Rate limiting for auth endpoints\n * consumer\n * .apply(RateLimitMiddleware)\n * .forRoutes({ path: '/api/v1/auth/*', method: 'post' })\n * }\n * }\n * ```\n */\nexport class MiddlewareConsumerImpl implements IMiddlewareConsumer {\n private entries: MiddlewareConfigEntry[] = []\n\n /**\n * Start configuring middleware\n *\n * @param middlewares - Middleware classes to apply\n * @returns Builder for configuring routes and exclusions\n */\n apply(...middlewares: Constructor<Middleware>[]): IMiddlewareBuilder {\n return new MiddlewareBuilderImpl(middlewares, this)\n }\n\n /**\n * Add a configuration entry (called by builder)\n * @internal\n */\n addEntry(entry: MiddlewareConfigEntry): void {\n this.entries.push(entry)\n }\n\n /**\n * Get all configured middleware entries\n */\n getEntries(): MiddlewareConfigEntry[] {\n return this.entries\n }\n}\n\n/**\n * Create a new middleware consumer instance\n */\nexport function createMiddlewareConsumer(): IMiddlewareConsumer {\n return new MiddlewareConsumerImpl()\n}\n","import { Transient } from '../../di/decorators'\nimport { type Constructor } from '../../types'\nimport { ROUTE_METADATA_KEYS } from '../constants'\nimport { type ControllerOptions } from '../types'\n\nconst CONTROLLER_ROUTE_KEY = ROUTE_METADATA_KEYS.CONTROLLER_ROUTE\n\n/**\n * Base controller decorator for route registration\n *\n * This is the core controller decorator that handles:\n * - Transient scope registration (request-scoped)\n * - Route metadata storage\n * - Controller options (tags, security schemes, hideFromDocs)\n *\n * @param route - Base route for this controller (e.g., '/api/v1/users')\n * @param options - Optional configuration (tags, security schemes, hideFromDocs)\n *\n * @example\n * ```typescript\n * import { Controller } from 'stratal/router'\n *\n * @Controller('/api/v1/users', { tags: ['Users'] })\n * export class UsersController implements IController {\n * // All routes accessible\n * }\n * ```\n */\nexport function Controller(route: string, options?: ControllerOptions) {\n return function <T extends Constructor>(target: T) {\n // Wrap @Transient (handles @injectable and scope metadata)\n Transient()(target)\n\n // Store route metadata on the class\n Reflect.defineMetadata(CONTROLLER_ROUTE_KEY, route, target)\n\n // Store options metadata if provided\n if (options) {\n Reflect.defineMetadata(ROUTE_METADATA_KEYS.CONTROLLER_OPTIONS, options, target)\n }\n\n return target\n }\n}\n\n/**\n * Get the route from controller class metadata\n *\n * @param target - Controller class or instance\n * @returns Route string or undefined if not set\n */\nexport function getControllerRoute(target: object): string | undefined {\n // Check if target is a class constructor (function) or an instance\n // If class, get metadata from it directly; if instance, get from constructor\n const metadataTarget = typeof target === 'function' ? target : (target as { constructor: object }).constructor\n return Reflect.getMetadata(CONTROLLER_ROUTE_KEY, metadataTarget) as string | undefined\n}\n\n/**\n * Get the options from controller class metadata\n *\n * @param target - Controller class or instance\n * @returns Controller options or undefined if not set\n */\nexport function getControllerOptions(target: object): ControllerOptions | undefined {\n const metadataTarget = typeof target === 'function' ? target : (target as { constructor: object }).constructor\n return Reflect.getMetadata(ROUTE_METADATA_KEYS.CONTROLLER_OPTIONS, metadataTarget) as ControllerOptions | undefined\n}\n\n/**\n * Get the version from controller class metadata\n *\n * @param target - Controller class or instance\n * @returns Version string, array, VERSION_NEUTRAL symbol, or undefined if not set\n */\nexport function getControllerVersion(target: object): ControllerOptions['version'] {\n const options = getControllerOptions(target)\n return options?.version\n}\n","import type { Context } from 'hono'\nimport type { OpenAPIHono } from '../i18n/validation'\nimport type { Container } from '../di'\nimport type { LoggerService } from '../logger'\nimport type { IController } from '../router/controller'\nimport { getControllerRoute } from '../router/decorators/controller.decorator'\nimport type { Middleware } from '../router/middleware.interface'\nimport { RouterContext } from '../router/router-context'\nimport type { HttpMethod, RouterEnv, VersioningOptions } from '../router/types'\nimport type { Constructor } from '../types'\nimport type { MiddlewareConfigEntry, RouteInfo } from './types'\n\n/**\n * Service for applying middleware configurations to Hono app\n *\n * Processes MiddlewareConfigEntry[] from modules and registers\n * appropriate middleware handlers with route matching.\n */\nexport class MiddlewareConfigurationService {\n constructor(\n private readonly logger: LoggerService,\n private readonly versioningOptions: VersioningOptions | null = null,\n ) { }\n\n /**\n * Apply middleware configurations to the Hono app\n *\n * @param app - Hono application instance\n * @param configs - Middleware configuration entries from modules\n * @param controllers - All registered controller classes (for route resolution)\n * @param container - DI container for resolving middleware instances\n */\n applyMiddlewares(\n app: OpenAPIHono<RouterEnv>,\n configs: MiddlewareConfigEntry[],\n controllers: Constructor<IController>[],\n container: Container\n ): void {\n for (const config of configs) {\n this.applyMiddlewareConfig(app, config, controllers, container)\n }\n }\n\n /**\n * Apply a single middleware configuration entry\n */\n private applyMiddlewareConfig(\n app: OpenAPIHono<RouterEnv>,\n config: MiddlewareConfigEntry,\n controllers: Constructor<IController>[],\n container: Container\n ): void {\n const { middlewares, excludes, routes } = config\n\n // Resolve route patterns from targets\n const routePatterns = this.resolveRoutePatterns(routes, controllers)\n\n // Log the configuration for debugging\n this.logger.debug('Applying middleware configuration', {\n middlewares: middlewares.map(m => m.name),\n routes: routePatterns,\n excludes: excludes,\n })\n\n // Apply middleware to each route pattern\n for (const pattern of routePatterns) {\n this.registerMiddlewareForPattern(app, middlewares, pattern, excludes, container)\n }\n }\n\n /**\n * Resolve route targets into concrete route patterns\n */\n private resolveRoutePatterns(\n targets: (Constructor<IController> | RouteInfo | '*')[],\n _controllers: Constructor<IController>[]\n ): RouteInfo[] {\n const patterns: RouteInfo[] = []\n\n for (const target of targets) {\n if (target === '*') {\n // Global middleware - apply to all routes\n patterns.push({ path: '*' })\n } else if (typeof target === 'function') {\n // Controller class - get its route from metadata\n const route = getControllerRoute(target)\n if (route) {\n // Add wildcard for all paths under this controller\n patterns.push({ path: `${route}/*` })\n // Also match the exact path\n patterns.push({ path: route })\n } else {\n this.logger.warn('Controller has no route metadata', { controller: target.name })\n }\n } else {\n // RouteInfo object - resolve version if present\n if (!this.versioningOptions || !target.version) {\n // Fast path: no versioning or no version on target — push directly\n patterns.push(target)\n } else {\n const resolved = this.resolveVersionedRouteInfo(target)\n patterns.push(...resolved)\n }\n }\n }\n\n return patterns\n }\n\n /**\n * Resolve a RouteInfo with version into versioned path(s).\n * If versioning is disabled or no version is specified, returns the RouteInfo as-is.\n */\n private resolveVersionedRouteInfo(routeInfo: RouteInfo): RouteInfo[] {\n if (!this.versioningOptions || !routeInfo.version) {\n return [routeInfo]\n }\n\n const prefix = this.versioningOptions.prefix ?? 'v'\n const versions = Array.isArray(routeInfo.version) ? routeInfo.version : [routeInfo.version]\n const results: RouteInfo[] = []\n\n for (const v of versions) {\n const versionedPath = `/${prefix}${v}${routeInfo.path}`\n // Add exact path match\n results.push({ path: versionedPath, method: routeInfo.method })\n // Add wildcard match for sub-paths\n results.push({ path: `${versionedPath}/*`, method: routeInfo.method })\n }\n\n return results\n }\n\n /**\n * Register middleware handlers for a specific route pattern\n */\n private registerMiddlewareForPattern(\n app: OpenAPIHono<RouterEnv>,\n middlewares: Constructor<Middleware>[],\n pattern: RouteInfo,\n excludes: RouteInfo[],\n container: Container\n ): void {\n const path = pattern.path\n const methods = pattern.method\n ? (Array.isArray(pattern.method) ? pattern.method : [pattern.method])\n : undefined\n\n // Create the middleware handler\n const handler = this.createMiddlewareHandler(middlewares, excludes, container)\n\n // Register with Hono\n if (methods && methods.length > 0) {\n // Method-specific registration\n for (const method of methods) {\n this.registerForMethod(app, method, path, handler)\n }\n } else {\n // All methods\n app.use(path, handler)\n }\n }\n\n /**\n * Register handler for a specific HTTP method\n */\n private registerForMethod(\n app: OpenAPIHono<RouterEnv>,\n method: HttpMethod,\n path: string,\n handler: (c: Context<RouterEnv>, next: () => Promise<void>) => Promise<void>\n ): void {\n switch (method) {\n case 'get':\n app.get(path, handler)\n break\n case 'post':\n app.post(path, handler)\n break\n case 'put':\n app.put(path, handler)\n break\n case 'delete':\n app.delete(path, handler)\n break\n case 'patch':\n app.patch(path, handler)\n break\n default:\n app.use(path, handler)\n }\n }\n\n /**\n * Create a middleware handler function that executes the middleware chain\n */\n private createMiddlewareHandler(\n middlewares: Constructor<Middleware>[],\n excludes: RouteInfo[],\n container: Container\n ): (c: Context<RouterEnv>, next: () => Promise<void>) => Promise<void> {\n return async (c, next) => {\n const requestPath = c.req.path\n const requestMethod = c.req.method.toLowerCase() as HttpMethod\n\n // Check if this request should be excluded\n if (this.isExcluded(requestPath, requestMethod, excludes)) {\n await next()\n return\n }\n\n // Create RouterContext for middleware\n const ctx = new RouterContext(c)\n\n // Execute middleware chain\n await this.executeMiddlewareChain(middlewares, ctx, container, next)\n }\n }\n\n /**\n * Check if a request matches any exclusion pattern\n */\n private isExcluded(\n requestPath: string,\n requestMethod: HttpMethod,\n excludes: RouteInfo[]\n ): boolean {\n for (const exclude of excludes) {\n if (this.matchesRoute(requestPath, requestMethod, exclude)) {\n return true\n }\n }\n return false\n }\n\n /**\n * Check if request matches a route pattern\n */\n private matchesRoute(\n requestPath: string,\n requestMethod: HttpMethod,\n route: RouteInfo\n ): boolean {\n // Check method match (if specified)\n if (route.method) {\n const methods = Array.isArray(route.method) ? route.method : [route.method]\n if (!methods.includes(requestMethod)) {\n return false\n }\n }\n\n // Check path match\n return this.matchesPath(requestPath, route.path)\n }\n\n /**\n * Match request path against pattern\n * Supports wildcards: /api/* matches /api/users, /api/v1/users\n */\n private matchesPath(requestPath: string, pattern: string): boolean {\n // Exact match\n if (pattern === requestPath) {\n return true\n }\n\n // Global wildcard\n if (pattern === '*') {\n return true\n }\n\n // Wildcard pattern (e.g., /api/*)\n if (pattern.endsWith('/*')) {\n const prefix = pattern.slice(0, -2)\n return requestPath === prefix || requestPath.startsWith(prefix + '/')\n }\n\n // Path parameter pattern (e.g., /api/users/:id)\n // Convert to regex for matching\n const regexPattern = pattern\n .replace(/:[^/]+/g, '[^/]+') // Replace :param with regex\n .replace(/\\*/g, '.*') // Replace * with regex\n const regex = new RegExp(`^${regexPattern}$`)\n return regex.test(requestPath)\n }\n\n /**\n * Execute middleware chain in order\n */\n private async executeMiddlewareChain(\n middlewares: Constructor<Middleware>[],\n ctx: RouterContext,\n container: Container,\n finalNext: () => Promise<void>\n ): Promise<void> {\n // Build middleware chain from end to start\n let chain = finalNext\n\n for (let i = middlewares.length - 1; i >= 0; i--) {\n const MiddlewareClass = middlewares[i]\n const currentNext = chain\n\n chain = async () => {\n // Resolve middleware from request-scoped container\n const requestContainer = ctx.getContainer()\n const middleware = requestContainer.resolve<Middleware>(MiddlewareClass)\n await middleware.handle(ctx, currentNext)\n }\n }\n\n // Execute the chain\n await chain()\n }\n}\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import { $t as Container, _t as MiddlewareConfigEntry, at as ExistingProvider, ct as ModuleClass, dt as OnInitialize, ft as OnShutdown, ht as ValueProvider, it as DynamicModule, lt as ModuleContext, mt as RegistryEntry, nt as AsyncModuleOptions, ot as FactoryProvider, pt as Provider, rt as ClassProvider, st as InjectionToken, ut as ModuleOptions } from "../index-C9bIk5tt.mjs";
2
- import { t as Constructor } from "../types-JUIHSW_a.mjs";
3
- import { i as LoggerService } from "../index-3TtGtYlJ.mjs";
1
+ import { $t as Container, _t as MiddlewareConfigEntry, at as ExistingProvider, ct as ModuleClass, dt as OnInitialize, ft as OnShutdown, ht as ValueProvider, it as DynamicModule, lt as ModuleContext, mt as RegistryEntry, nt as AsyncModuleOptions, ot as FactoryProvider, pt as Provider, rt as ClassProvider, st as InjectionToken, ut as ModuleOptions } from "../index-D69rxo8H.mjs";
2
+ import { t as Constructor } from "../types-Cu4jkeiH.mjs";
3
+ import { i as LoggerService } from "../index-Cfkie8JM.mjs";
4
4
 
5
5
  //#region src/module/module.decorator.d.ts
6
6
  declare const MODULE_OPTIONS_KEY: unique symbol;
@@ -52,6 +52,8 @@ declare class ModuleRegistry {
52
52
  private allConsumers;
53
53
  private allJobs;
54
54
  private allListeners;
55
+ private allCommands;
56
+ private allSeeders;
55
57
  private allMiddlewareConfigs;
56
58
  constructor(container: Container, logger: LoggerService);
57
59
  /**
@@ -84,6 +86,14 @@ declare class ModuleRegistry {
84
86
  * Get all listeners registered from all modules
85
87
  */
86
88
  getAllListeners(): Constructor[];
89
+ /**
90
+ * Get all commands registered from all modules
91
+ */
92
+ getAllCommands(): Constructor[];
93
+ /**
94
+ * Get all seeders registered from all modules
95
+ */
96
+ getAllSeeders(): Constructor[];
87
97
  /**
88
98
  * Get all middleware configurations from all modules
89
99
  */
@@ -120,6 +130,14 @@ declare class ModuleRegistry {
120
130
  * Register a single provider in the container
121
131
  */
122
132
  private registerProvider;
133
+ /**
134
+ * Check if a class is a `Command` and collect it for auto-wiring
135
+ */
136
+ private collectIfCommand;
137
+ /**
138
+ * Check if a class is a `Seeder` and collect it for auto-wiring
139
+ */
140
+ private collectIfSeeder;
123
141
  /**
124
142
  * Check if a class is a `@Listener()` and collect it for auto-wiring
125
143
  */
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.mts","names":[],"sources":["../../src/module/module.decorator.ts","../../src/module/module-registry.ts"],"mappings":";;;;;cAea,kBAAA;;;AAyBb;;;;;;;;;;;;;iBAAgB,MAAA,CAAO,OAAA,EAAS,aAAA,uCACa,IAAA,uBAA2B,MAAA,EAAQ,SAAA,KAAY,SAAA;;;;iBAmB5E,gBAAA,CAAiB,MAAA,EAAQ,WAAA,GAAc,aAAA;;;;iBAOvC,aAAA,CAAc,MAAA,YAAkB,MAAA,IAAU,WAAA;;;;;;;;;;;;;;;cChB7C,cAAA;EAAA,iBAaQ,SAAA;EAAA,iBACA,MAAA;EAAA,QAbX,OAAA;EAAA,QACA,iBAAA;EAAA,QACA,WAAA;EAAA,QAGA,cAAA;EAAA,QACA,YAAA;EAAA,QACA,OAAA;EAAA,QACA,YAAA;EAAA,QACA,oBAAA;cAGW,SAAA,EAAW,SAAA,EACX,MAAA,EAAQ,aAAA;EDEA;;;;;ECM3B,QAAA,CAAS,eAAA,EAAiB,WAAA,GAAc,aAAA;EDN2B;;;EC+DnE,WAAA,CAAY,OAAA,GAAU,WAAA,GAAc,aAAA;;AA/EtC;;EAwFQ,UAAA,CAAA,GAAc,OAAA;EA3EU;;;EAkH9B,iBAAA,CAAA,GAAqB,WAAA;EAhDC;;;EAuDtB,eAAA,CAAA,GAAmB,WAAA;EAAA;;;EAOnB,UAAA,CAAA,GAAc,WAAA;EAqBI;;;EAdlB,eAAA,CAAA,GAAmB,WAAA;EAtIA;;;EA6InB,uBAAA,CAAA,GAA2B,qBAAA;EArJnB;;;EA4JF,QAAA,CAAA,GAAY,OAAA;EAxJV;;;EAAA,QAmLA,yBAAA;EA/KmB;;;EAAA,QA2LnB,eAAA;EAnLgC;;;EAAA,QA+LhC,aAAA;EAtI4B;;;;;;;EAAA,QAsJ5B,aAAA;EAxFR;;;EAAA,QAuHQ,eAAA;EAzGR;;;EAAA,QAqHQ,gBAAA;EAnFA;;;EAAA,QAmHA,iBAAA;AAAA"}
1
+ {"version":3,"file":"index.d.mts","names":[],"sources":["../../src/module/module.decorator.ts","../../src/module/module-registry.ts"],"mappings":";;;;;cAea,kBAAA;;;AAyBb;;;;;;;;;;;;;iBAAgB,MAAA,CAAO,OAAA,EAAS,aAAA,uCACa,IAAA,uBAA2B,MAAA,EAAQ,SAAA,KAAY,SAAA;;;;iBAmB5E,gBAAA,CAAiB,MAAA,EAAQ,WAAA,GAAc,aAAA;;;;iBAOvC,aAAA,CAAc,MAAA,YAAkB,MAAA,IAAU,WAAA;;;;;;;;;;;;;;;cCd7C,cAAA;EAAA,iBAeQ,SAAA;EAAA,iBACA,MAAA;EAAA,QAfX,OAAA;EAAA,QACA,iBAAA;EAAA,QACA,WAAA;EAAA,QAGA,cAAA;EAAA,QACA,YAAA;EAAA,QACA,OAAA;EAAA,QACA,YAAA;EAAA,QACA,WAAA;EAAA,QACA,UAAA;EAAA,QACA,oBAAA;cAGW,SAAA,EAAW,SAAA,EACX,MAAA,EAAQ,aAAA;EDFwC;;;;;ECUnE,QAAA,CAAS,eAAA,EAAiB,WAAA,GAAc,aAAA;;;;EAyDxC,WAAA,CAAY,OAAA,GAAU,WAAA,GAAc,aAAA;EAjFX;;;EA0FnB,UAAA,CAAA,GAAc,OAAA;EAlEM;;;EAyG1B,iBAAA,CAAA,GAAqB,WAAA;EAvCD;;;EA8CpB,eAAA,CAAA,GAAmB,WAAA;EAcA;;;EAPnB,UAAA,CAAA,GAAc,WAAA;EAmCI;;;EA5BlB,eAAA,CAAA,GAAmB,WAAA;EAtIA;;;EA6InB,cAAA,CAAA,GAAkB,WAAA;EAvJV;;;EA8JR,aAAA,CAAA,GAAiB,WAAA;EA1JT;;;EAiKR,uBAAA,CAAA,GAA2B,qBAAA;EA5JG;;;EAmKxB,QAAA,CAAA,GAAY,OAAA;EA1JlB;;;EAAA,QAqLQ,yBAAA;EA5HR;;;EAAA,QAwIQ,eAAA;EA/HF;;;EAAA,QA2IE,aAAA;EA7FR;;;;;;;EAAA,QA6GQ,aAAA;EAjFR;;;EAAA,QAgHQ,eAAA;EAlGF;;;EAAA,QA8GE,gBAAA;EA3DA;;;EAAA,QA+FA,gBAAA;EAAA;;;EAAA,QAWA,eAAA;EAUiB;;;EAAA,QAAjB,iBAAA;AAAA"}
@@ -1,7 +1,11 @@
1
- import "../errors-BRJgVd5-.mjs";
2
- import "../logger-Bg-CuidS.mjs";
3
- import { a as isModuleClass, i as getModuleOptions, n as MODULE_OPTIONS_KEY, r as Module, t as ModuleRegistry } from "../module-Dvzm4dhS.mjs";
4
- import "../events-CQyvSyrQ.mjs";
5
- import "../middleware-B3tx1u1K.mjs";
6
- import "../router-context-DlTxpJUG.mjs";
1
+ import "../errors-CtCi1wn6.mjs";
2
+ import "../decorate-D5j-d9_z.mjs";
3
+ import "../logger-BR1-s1Um.mjs";
4
+ import { a as isModuleClass, i as getModuleOptions, n as MODULE_OPTIONS_KEY, r as Module, t as ModuleRegistry } from "../module-BH7t7BGG.mjs";
5
+ import "../events-CXl-o1Ad.mjs";
6
+ import "../command-DG_u5ob2.mjs";
7
+ import "../is-command-MZDCH-0T.mjs";
8
+ import "../is-seeder-BN9Ej1r7.mjs";
9
+ import "../middleware-iRhNjsPH.mjs";
10
+ import "../router-context-BLn4PrRG.mjs";
7
11
  export { MODULE_OPTIONS_KEY, Module, ModuleRegistry, getModuleOptions, isModuleClass };