@bgord/bun 1.10.23 → 1.11.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (792) hide show
  1. package/dist/ab-assignment-composite.strategy.d.ts +10 -0
  2. package/dist/ab-assignment-composite.strategy.d.ts.map +1 -0
  3. package/dist/ab-assignment-composite.strategy.js +15 -0
  4. package/dist/ab-assignment-composite.strategy.js.map +1 -0
  5. package/dist/ab-assignment-fixed.strategy.d.ts +10 -0
  6. package/dist/ab-assignment-fixed.strategy.d.ts.map +1 -0
  7. package/dist/ab-assignment-fixed.strategy.js +10 -0
  8. package/dist/ab-assignment-fixed.strategy.js.map +1 -0
  9. package/dist/ab-assignment-hash.strategy.d.ts +12 -0
  10. package/dist/ab-assignment-hash.strategy.d.ts.map +1 -0
  11. package/dist/ab-assignment-hash.strategy.js +14 -0
  12. package/dist/ab-assignment-hash.strategy.js.map +1 -0
  13. package/dist/ab-assignment-query.strategy.d.ts +10 -0
  14. package/dist/ab-assignment-query.strategy.d.ts.map +1 -0
  15. package/dist/ab-assignment-query.strategy.js +11 -0
  16. package/dist/ab-assignment-query.strategy.js.map +1 -0
  17. package/dist/ab-assignment.strategy.d.ts +7 -0
  18. package/dist/ab-assignment.strategy.d.ts.map +1 -0
  19. package/dist/ab-assignment.strategy.js +2 -0
  20. package/dist/ab-assignment.strategy.js.map +1 -0
  21. package/dist/ab-hono-noop.middleware.d.ts +10 -0
  22. package/dist/ab-hono-noop.middleware.d.ts.map +1 -0
  23. package/dist/ab-hono-noop.middleware.js +18 -0
  24. package/dist/ab-hono-noop.middleware.js.map +1 -0
  25. package/dist/ab-hono.middleware.d.ts +14 -0
  26. package/dist/ab-hono.middleware.d.ts.map +1 -0
  27. package/dist/ab-hono.middleware.js +17 -0
  28. package/dist/ab-hono.middleware.js.map +1 -0
  29. package/dist/ab-variant-selector.service.d.ts +12 -0
  30. package/dist/ab-variant-selector.service.d.ts.map +1 -0
  31. package/dist/ab-variant-selector.service.js +22 -0
  32. package/dist/ab-variant-selector.service.js.map +1 -0
  33. package/dist/ab-variant-weight.vo.d.ts +7 -0
  34. package/dist/ab-variant-weight.vo.d.ts.map +1 -0
  35. package/dist/ab-variant-weight.vo.js +10 -0
  36. package/dist/ab-variant-weight.vo.js.map +1 -0
  37. package/dist/ab-variant.vo.d.ts +11 -0
  38. package/dist/ab-variant.vo.d.ts.map +1 -0
  39. package/dist/ab-variant.vo.js +7 -0
  40. package/dist/ab-variant.vo.js.map +1 -0
  41. package/dist/ab-variants.vo.d.ts +12 -0
  42. package/dist/ab-variants.vo.d.ts.map +1 -0
  43. package/dist/ab-variants.vo.js +24 -0
  44. package/dist/ab-variants.vo.js.map +1 -0
  45. package/dist/ab.middleware.d.ts +11 -0
  46. package/dist/ab.middleware.d.ts.map +1 -0
  47. package/dist/ab.middleware.js +12 -0
  48. package/dist/ab.middleware.js.map +1 -0
  49. package/dist/api-version-hono.middleware.d.ts +17 -0
  50. package/dist/api-version-hono.middleware.d.ts.map +1 -0
  51. package/dist/api-version-hono.middleware.js +15 -0
  52. package/dist/api-version-hono.middleware.js.map +1 -0
  53. package/dist/api-version.middleware.d.ts +5 -2
  54. package/dist/api-version.middleware.d.ts.map +1 -1
  55. package/dist/api-version.middleware.js +12 -10
  56. package/dist/api-version.middleware.js.map +1 -1
  57. package/dist/auth-session-reader.port.d.ts +8 -7
  58. package/dist/auth-session-reader.port.d.ts.map +1 -1
  59. package/dist/basic-auth.service.d.ts +3 -3
  60. package/dist/basic-auth.service.d.ts.map +1 -1
  61. package/dist/basic-auth.service.js.map +1 -1
  62. package/dist/cache-response-hono.middleware.d.ts +14 -0
  63. package/dist/cache-response-hono.middleware.d.ts.map +1 -0
  64. package/dist/cache-response-hono.middleware.js +34 -0
  65. package/dist/cache-response-hono.middleware.js.map +1 -0
  66. package/dist/cache-response.middleware.d.ts +18 -8
  67. package/dist/cache-response.middleware.d.ts.map +1 -1
  68. package/dist/cache-response.middleware.js +8 -21
  69. package/dist/cache-response.middleware.js.map +1 -1
  70. package/dist/correlation-hono.middleware.d.ts +16 -0
  71. package/dist/correlation-hono.middleware.d.ts.map +1 -0
  72. package/dist/correlation-hono.middleware.js +20 -0
  73. package/dist/correlation-hono.middleware.js.map +1 -0
  74. package/dist/correlation-id.middleware.d.ts +14 -0
  75. package/dist/correlation-id.middleware.d.ts.map +1 -0
  76. package/dist/correlation-id.middleware.js +16 -0
  77. package/dist/correlation-id.middleware.js.map +1 -0
  78. package/dist/correlation-storage.service.d.ts +0 -1
  79. package/dist/correlation-storage.service.d.ts.map +1 -1
  80. package/dist/correlation-storage.service.js +0 -2
  81. package/dist/correlation-storage.service.js.map +1 -1
  82. package/dist/crypto-key-provider-with-cache.adapter.d.ts +5 -4
  83. package/dist/crypto-key-provider-with-cache.adapter.d.ts.map +1 -1
  84. package/dist/crypto-key-provider-with-cache.adapter.js +5 -5
  85. package/dist/crypto-key-provider-with-cache.adapter.js.map +1 -1
  86. package/dist/environment-loader-process-safe.adapter.d.ts.map +1 -1
  87. package/dist/environment-loader-process-safe.adapter.js +3 -3
  88. package/dist/environment-loader-process-safe.adapter.js.map +1 -1
  89. package/dist/etag-extractor-hono.middleware.d.ts +13 -0
  90. package/dist/etag-extractor-hono.middleware.d.ts.map +1 -0
  91. package/dist/etag-extractor-hono.middleware.js +17 -0
  92. package/dist/etag-extractor-hono.middleware.js.map +1 -0
  93. package/dist/etag-extractor.middleware.d.ts +3 -8
  94. package/dist/etag-extractor.middleware.d.ts.map +1 -1
  95. package/dist/etag-extractor.middleware.js +5 -9
  96. package/dist/etag-extractor.middleware.js.map +1 -1
  97. package/dist/event-store.d.ts +2 -2
  98. package/dist/event-store.d.ts.map +1 -1
  99. package/dist/event-store.js.map +1 -1
  100. package/dist/file-inspection-noop.adapter.d.ts +2 -2
  101. package/dist/file-inspection-noop.adapter.d.ts.map +1 -1
  102. package/dist/file-inspection-noop.adapter.js.map +1 -1
  103. package/dist/file-reader-json-with-cache.adapter.d.ts +5 -4
  104. package/dist/file-reader-json-with-cache.adapter.d.ts.map +1 -1
  105. package/dist/file-reader-json-with-cache.adapter.js +6 -6
  106. package/dist/file-reader-json-with-cache.adapter.js.map +1 -1
  107. package/dist/file-reader-raw-with-cache.adapter.d.ts +5 -4
  108. package/dist/file-reader-raw-with-cache.adapter.d.ts.map +1 -1
  109. package/dist/file-reader-raw-with-cache.adapter.js +6 -6
  110. package/dist/file-reader-raw-with-cache.adapter.js.map +1 -1
  111. package/dist/file-reader-text-with-cache.adapter.d.ts +5 -4
  112. package/dist/file-reader-text-with-cache.adapter.d.ts.map +1 -1
  113. package/dist/file-reader-text-with-cache.adapter.js +6 -6
  114. package/dist/file-reader-text-with-cache.adapter.js.map +1 -1
  115. package/dist/file-uploader-hono.middleware.d.ts +13 -0
  116. package/dist/file-uploader-hono.middleware.d.ts.map +1 -0
  117. package/dist/file-uploader-hono.middleware.js +37 -0
  118. package/dist/file-uploader-hono.middleware.js.map +1 -0
  119. package/dist/file-uploader.middleware.d.ts +19 -8
  120. package/dist/file-uploader.middleware.d.ts.map +1 -1
  121. package/dist/file-uploader.middleware.js +24 -26
  122. package/dist/file-uploader.middleware.js.map +1 -1
  123. package/dist/handler-hono.port.d.ts +5 -0
  124. package/dist/handler-hono.port.d.ts.map +1 -0
  125. package/dist/handler-hono.port.js +2 -0
  126. package/dist/handler-hono.port.js.map +1 -0
  127. package/dist/hash-bucket.vo.d.ts +9 -0
  128. package/dist/hash-bucket.vo.d.ts.map +1 -0
  129. package/dist/hash-bucket.vo.js +17 -0
  130. package/dist/hash-bucket.vo.js.map +1 -0
  131. package/dist/healthcheck-hono.handler.d.ts +87 -0
  132. package/dist/healthcheck-hono.handler.d.ts.map +1 -0
  133. package/dist/healthcheck-hono.handler.js +17 -0
  134. package/dist/healthcheck-hono.handler.js.map +1 -0
  135. package/dist/healthcheck.handler.d.ts +83 -0
  136. package/dist/healthcheck.handler.d.ts.map +1 -0
  137. package/dist/{healthcheck.service.js → healthcheck.handler.js} +21 -19
  138. package/dist/healthcheck.handler.js.map +1 -0
  139. package/dist/http-logger-hono.middleware.d.ts +17 -0
  140. package/dist/http-logger-hono.middleware.d.ts.map +1 -0
  141. package/dist/http-logger-hono.middleware.js +37 -0
  142. package/dist/http-logger-hono.middleware.js.map +1 -0
  143. package/dist/http-logger.middleware.d.ts +19 -4
  144. package/dist/http-logger.middleware.d.ts.map +1 -1
  145. package/dist/http-logger.middleware.js +31 -41
  146. package/dist/http-logger.middleware.js.map +1 -1
  147. package/dist/i18n.service.d.ts +1 -1
  148. package/dist/i18n.service.d.ts.map +1 -1
  149. package/dist/image-info-noop.adapter.d.ts +1 -1
  150. package/dist/image-info-noop.adapter.d.ts.map +1 -1
  151. package/dist/image-info-noop.adapter.js +1 -1
  152. package/dist/image-info-noop.adapter.js.map +1 -1
  153. package/dist/image-info-sharp.adapter.d.ts +1 -1
  154. package/dist/image-info-sharp.adapter.d.ts.map +1 -1
  155. package/dist/image-info-sharp.adapter.js +3 -3
  156. package/dist/image-info-sharp.adapter.js.map +1 -1
  157. package/dist/image-info.port.d.ts +1 -1
  158. package/dist/image-info.port.d.ts.map +1 -1
  159. package/dist/in-flight-requests-hono.middleware.d.ts +7 -0
  160. package/dist/in-flight-requests-hono.middleware.d.ts.map +1 -0
  161. package/dist/in-flight-requests-hono.middleware.js +16 -0
  162. package/dist/in-flight-requests-hono.middleware.js.map +1 -0
  163. package/dist/in-flight-requests-tracker.service.d.ts.map +1 -1
  164. package/dist/in-flight-requests-tracker.service.js +0 -1
  165. package/dist/in-flight-requests-tracker.service.js.map +1 -1
  166. package/dist/in-flight-requests.middleware.d.ts +3 -2
  167. package/dist/in-flight-requests.middleware.d.ts.map +1 -1
  168. package/dist/in-flight-requests.middleware.js +6 -10
  169. package/dist/in-flight-requests.middleware.js.map +1 -1
  170. package/dist/index.d.ts +70 -25
  171. package/dist/index.d.ts.map +1 -1
  172. package/dist/index.js +70 -25
  173. package/dist/index.js.map +1 -1
  174. package/dist/invariant-error-handler.service.d.ts +1 -2
  175. package/dist/invariant-error-handler.service.d.ts.map +1 -1
  176. package/dist/invariant-error-handler.service.js.map +1 -1
  177. package/dist/invariant.service.d.ts +2 -2
  178. package/dist/invariant.service.d.ts.map +1 -1
  179. package/dist/mailer-resend.adapter.d.ts +2 -2
  180. package/dist/mailer-resend.adapter.d.ts.map +1 -1
  181. package/dist/mailer-resend.adapter.js.map +1 -1
  182. package/dist/mailer-smtp.adapter.d.ts +2 -2
  183. package/dist/mailer-smtp.adapter.d.ts.map +1 -1
  184. package/dist/mailer-smtp.adapter.js.map +1 -1
  185. package/dist/middleware-hono-noop.adapter.d.ts +6 -0
  186. package/dist/middleware-hono-noop.adapter.d.ts.map +1 -0
  187. package/dist/middleware-hono-noop.adapter.js +6 -0
  188. package/dist/middleware-hono-noop.adapter.js.map +1 -0
  189. package/dist/middleware-hono.port.d.ts +5 -0
  190. package/dist/middleware-hono.port.d.ts.map +1 -0
  191. package/dist/middleware-hono.port.js +2 -0
  192. package/dist/middleware-hono.port.js.map +1 -0
  193. package/dist/modules/preferences/invariants/user-language-has-changed.d.ts +6 -6
  194. package/dist/modules/preferences/invariants/user-language-has-changed.d.ts.map +1 -1
  195. package/dist/modules/preferences/invariants/user-language-has-changed.js.map +1 -1
  196. package/dist/ping-hono.handler.d.ts +6 -0
  197. package/dist/ping-hono.handler.d.ts.map +1 -0
  198. package/dist/ping-hono.handler.js +13 -0
  199. package/dist/ping-hono.handler.js.map +1 -0
  200. package/dist/ping.handler.d.ts +4 -0
  201. package/dist/ping.handler.d.ts.map +1 -0
  202. package/dist/ping.handler.js +6 -0
  203. package/dist/ping.handler.js.map +1 -0
  204. package/dist/prerequisite-verifier-binary.adapter.d.ts +5 -3
  205. package/dist/prerequisite-verifier-binary.adapter.d.ts.map +1 -1
  206. package/dist/prerequisite-verifier-binary.adapter.js.map +1 -1
  207. package/dist/prerequisite-verifier-bun.adapter.d.ts +6 -4
  208. package/dist/prerequisite-verifier-bun.adapter.d.ts.map +1 -1
  209. package/dist/prerequisite-verifier-bun.adapter.js.map +1 -1
  210. package/dist/prerequisite-verifier-clock-drift.adapter.d.ts +4 -3
  211. package/dist/prerequisite-verifier-clock-drift.adapter.d.ts.map +1 -1
  212. package/dist/prerequisite-verifier-clock-drift.adapter.js.map +1 -1
  213. package/dist/prerequisite-verifier-directory.adapter.d.ts +5 -4
  214. package/dist/prerequisite-verifier-directory.adapter.d.ts.map +1 -1
  215. package/dist/prerequisite-verifier-directory.adapter.js.map +1 -1
  216. package/dist/prerequisite-verifier-dns.adapter.d.ts +5 -3
  217. package/dist/prerequisite-verifier-dns.adapter.d.ts.map +1 -1
  218. package/dist/prerequisite-verifier-dns.adapter.js.map +1 -1
  219. package/dist/prerequisite-verifier-external-api.adapter.d.ts +5 -3
  220. package/dist/prerequisite-verifier-external-api.adapter.d.ts.map +1 -1
  221. package/dist/prerequisite-verifier-external-api.adapter.js.map +1 -1
  222. package/dist/prerequisite-verifier-file.adapter.d.ts +5 -4
  223. package/dist/prerequisite-verifier-file.adapter.d.ts.map +1 -1
  224. package/dist/prerequisite-verifier-file.adapter.js.map +1 -1
  225. package/dist/prerequisite-verifier-jobs.adapter.d.ts +5 -3
  226. package/dist/prerequisite-verifier-jobs.adapter.d.ts.map +1 -1
  227. package/dist/prerequisite-verifier-jobs.adapter.js.map +1 -1
  228. package/dist/prerequisite-verifier-memory.adapter.d.ts +5 -3
  229. package/dist/prerequisite-verifier-memory.adapter.d.ts.map +1 -1
  230. package/dist/prerequisite-verifier-memory.adapter.js.map +1 -1
  231. package/dist/prerequisite-verifier-node.adapter.d.ts +6 -4
  232. package/dist/prerequisite-verifier-node.adapter.d.ts.map +1 -1
  233. package/dist/prerequisite-verifier-node.adapter.js.map +1 -1
  234. package/dist/prerequisite-verifier-os.adapter.d.ts +5 -3
  235. package/dist/prerequisite-verifier-os.adapter.d.ts.map +1 -1
  236. package/dist/prerequisite-verifier-os.adapter.js.map +1 -1
  237. package/dist/prerequisite-verifier-port.adapter.d.ts +5 -3
  238. package/dist/prerequisite-verifier-port.adapter.d.ts.map +1 -1
  239. package/dist/prerequisite-verifier-port.adapter.js.map +1 -1
  240. package/dist/prerequisite-verifier-ram.adapter.d.ts +5 -3
  241. package/dist/prerequisite-verifier-ram.adapter.d.ts.map +1 -1
  242. package/dist/prerequisite-verifier-ram.adapter.js.map +1 -1
  243. package/dist/prerequisite-verifier-running-user.adapter.d.ts +5 -3
  244. package/dist/prerequisite-verifier-running-user.adapter.d.ts.map +1 -1
  245. package/dist/prerequisite-verifier-running-user.adapter.js.map +1 -1
  246. package/dist/prerequisite-verifier-space.adapter.d.ts +4 -3
  247. package/dist/prerequisite-verifier-space.adapter.d.ts.map +1 -1
  248. package/dist/prerequisite-verifier-space.adapter.js.map +1 -1
  249. package/dist/prerequisite-verifier-sqlite.adapter.d.ts +5 -3
  250. package/dist/prerequisite-verifier-sqlite.adapter.d.ts.map +1 -1
  251. package/dist/prerequisite-verifier-sqlite.adapter.js.map +1 -1
  252. package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts +5 -4
  253. package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.d.ts.map +1 -1
  254. package/dist/prerequisite-verifier-ssl-certificate-expiry.adapter.js.map +1 -1
  255. package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts +5 -3
  256. package/dist/prerequisite-verifier-timezone-utc.adapter.d.ts.map +1 -1
  257. package/dist/prerequisite-verifier-timezone-utc.adapter.js.map +1 -1
  258. package/dist/prerequisite-verifier-translations.adapter.d.ts +1 -1
  259. package/dist/prerequisite-verifier-translations.adapter.d.ts.map +1 -1
  260. package/dist/prerequisite-verifier-translations.adapter.js.map +1 -1
  261. package/dist/prerequisite-verifier-with-cache.adapter.d.ts +5 -4
  262. package/dist/prerequisite-verifier-with-cache.adapter.d.ts.map +1 -1
  263. package/dist/prerequisite-verifier-with-cache.adapter.js +6 -6
  264. package/dist/prerequisite-verifier-with-cache.adapter.js.map +1 -1
  265. package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts +2 -2
  266. package/dist/prerequisite-verifier-with-fail-safe.adapter.d.ts.map +1 -1
  267. package/dist/prerequisite-verifier-with-fail-safe.adapter.js.map +1 -1
  268. package/dist/prerequisite-verifier-with-logger.adapter.d.ts +4 -3
  269. package/dist/prerequisite-verifier-with-logger.adapter.d.ts.map +1 -1
  270. package/dist/prerequisite-verifier-with-logger.adapter.js.map +1 -1
  271. package/dist/prerequisite-verifier-with-retry.adapter.d.ts +6 -5
  272. package/dist/prerequisite-verifier-with-retry.adapter.d.ts.map +1 -1
  273. package/dist/prerequisite-verifier-with-retry.adapter.js.map +1 -1
  274. package/dist/prerequisite-verifier-with-timeout.adapter.d.ts +5 -4
  275. package/dist/prerequisite-verifier-with-timeout.adapter.d.ts.map +1 -1
  276. package/dist/prerequisite-verifier-with-timeout.adapter.js.map +1 -1
  277. package/dist/prerequisite-verifier.decorator.d.ts +4 -4
  278. package/dist/prerequisite-verifier.decorator.d.ts.map +1 -1
  279. package/dist/prerequisite-verifier.decorator.js.map +1 -1
  280. package/dist/prerequisite.vo.d.ts +2 -2
  281. package/dist/prerequisite.vo.d.ts.map +1 -1
  282. package/dist/prerequisite.vo.js.map +1 -1
  283. package/dist/remote-file-storage-disk.adapter.d.ts +4 -4
  284. package/dist/remote-file-storage-disk.adapter.d.ts.map +1 -1
  285. package/dist/remote-file-storage-disk.adapter.js.map +1 -1
  286. package/dist/request-context-hono.adapter.d.ts +1 -1
  287. package/dist/request-context-hono.adapter.d.ts.map +1 -1
  288. package/dist/request-context-hono.adapter.js +10 -1
  289. package/dist/request-context-hono.adapter.js.map +1 -1
  290. package/dist/request-context.port.d.ts +18 -0
  291. package/dist/request-context.port.d.ts.map +1 -1
  292. package/dist/retry.service.d.ts +5 -5
  293. package/dist/retry.service.d.ts.map +1 -1
  294. package/dist/retry.service.js.map +1 -1
  295. package/dist/security-countermeasure-ban.strategy.d.ts +8 -7
  296. package/dist/security-countermeasure-ban.strategy.d.ts.map +1 -1
  297. package/dist/security-countermeasure-ban.strategy.js.map +1 -1
  298. package/dist/security-countermeasure-mirage.strategy.d.ts +6 -5
  299. package/dist/security-countermeasure-mirage.strategy.d.ts.map +1 -1
  300. package/dist/security-countermeasure-mirage.strategy.js.map +1 -1
  301. package/dist/security-countermeasure-tarpit.strategy.d.ts +5 -4
  302. package/dist/security-countermeasure-tarpit.strategy.d.ts.map +1 -1
  303. package/dist/security-countermeasure-tarpit.strategy.js.map +1 -1
  304. package/dist/security-rule-violation-threshold.strategy.d.ts +4 -3
  305. package/dist/security-rule-violation-threshold.strategy.d.ts.map +1 -1
  306. package/dist/security-rule-violation-threshold.strategy.js +4 -4
  307. package/dist/security-rule-violation-threshold.strategy.js.map +1 -1
  308. package/dist/setup-hono.service.d.ts +31 -0
  309. package/dist/setup-hono.service.d.ts.map +1 -0
  310. package/dist/{setup.service.js → setup-hono.service.js} +25 -33
  311. package/dist/setup-hono.service.js.map +1 -0
  312. package/dist/shield-api-key-hono.strategy.d.ts +11 -0
  313. package/dist/shield-api-key-hono.strategy.d.ts.map +1 -0
  314. package/dist/shield-api-key-hono.strategy.js +19 -0
  315. package/dist/shield-api-key-hono.strategy.js.map +1 -0
  316. package/dist/shield-api-key.strategy.d.ts +9 -9
  317. package/dist/shield-api-key.strategy.d.ts.map +1 -1
  318. package/dist/shield-api-key.strategy.js +5 -11
  319. package/dist/shield-api-key.strategy.js.map +1 -1
  320. package/dist/shield-auth-hono.strategy.d.ts +16 -0
  321. package/dist/shield-auth-hono.strategy.d.ts.map +1 -0
  322. package/dist/shield-auth-hono.strategy.js +31 -0
  323. package/dist/shield-auth-hono.strategy.js.map +1 -0
  324. package/dist/shield-auth.strategy.d.ts +8 -7
  325. package/dist/shield-auth.strategy.d.ts.map +1 -1
  326. package/dist/shield-auth.strategy.js +10 -23
  327. package/dist/shield-auth.strategy.js.map +1 -1
  328. package/dist/shield-basic-auth-hono.strategy.d.ts +11 -0
  329. package/dist/shield-basic-auth-hono.strategy.d.ts.map +1 -0
  330. package/dist/shield-basic-auth-hono.strategy.js +21 -0
  331. package/dist/shield-basic-auth-hono.strategy.js.map +1 -0
  332. package/dist/shield-basic-auth.strategy.d.ts +9 -7
  333. package/dist/shield-basic-auth.strategy.d.ts.map +1 -1
  334. package/dist/shield-basic-auth.strategy.js +18 -5
  335. package/dist/shield-basic-auth.strategy.js.map +1 -1
  336. package/dist/shield-body-limit-hono.strategy.d.ts +10 -0
  337. package/dist/shield-body-limit-hono.strategy.d.ts.map +1 -0
  338. package/dist/shield-body-limit-hono.strategy.js +21 -0
  339. package/dist/shield-body-limit-hono.strategy.js.map +1 -0
  340. package/dist/shield-body-limit.strategy.d.ts +14 -0
  341. package/dist/shield-body-limit.strategy.d.ts.map +1 -0
  342. package/dist/shield-body-limit.strategy.js +19 -0
  343. package/dist/shield-body-limit.strategy.js.map +1 -0
  344. package/dist/shield-csrf-hono.strategy.d.ts +11 -0
  345. package/dist/shield-csrf-hono.strategy.d.ts.map +1 -0
  346. package/dist/shield-csrf-hono.strategy.js +19 -0
  347. package/dist/shield-csrf-hono.strategy.js.map +1 -0
  348. package/dist/shield-csrf.strategy.d.ts +8 -7
  349. package/dist/shield-csrf.strategy.d.ts.map +1 -1
  350. package/dist/shield-csrf.strategy.js +7 -11
  351. package/dist/shield-csrf.strategy.js.map +1 -1
  352. package/dist/shield-hcaptcha-hono-local.strategy.d.ts +14 -0
  353. package/dist/shield-hcaptcha-hono-local.strategy.d.ts.map +1 -0
  354. package/dist/shield-hcaptcha-hono-local.strategy.js +20 -0
  355. package/dist/shield-hcaptcha-hono-local.strategy.js.map +1 -0
  356. package/dist/shield-hcaptcha-hono.strategy.d.ts +11 -0
  357. package/dist/shield-hcaptcha-hono.strategy.d.ts.map +1 -0
  358. package/dist/shield-hcaptcha-hono.strategy.js +19 -0
  359. package/dist/shield-hcaptcha-hono.strategy.js.map +1 -0
  360. package/dist/shield-hcaptcha.strategy.d.ts +5 -5
  361. package/dist/shield-hcaptcha.strategy.d.ts.map +1 -1
  362. package/dist/shield-hcaptcha.strategy.js +6 -12
  363. package/dist/shield-hcaptcha.strategy.js.map +1 -1
  364. package/dist/shield-maintenance-hono.strategy.d.ts +9 -0
  365. package/dist/shield-maintenance-hono.strategy.d.ts.map +1 -0
  366. package/dist/shield-maintenance-hono.strategy.js +18 -0
  367. package/dist/shield-maintenance-hono.strategy.js.map +1 -0
  368. package/dist/shield-maintenance.strategy.d.ts +15 -0
  369. package/dist/shield-maintenance.strategy.d.ts.map +1 -0
  370. package/dist/shield-maintenance.strategy.js +13 -0
  371. package/dist/shield-maintenance.strategy.js.map +1 -0
  372. package/dist/shield-rate-limit-hono.strategy.d.ts +18 -0
  373. package/dist/shield-rate-limit-hono.strategy.d.ts.map +1 -0
  374. package/dist/shield-rate-limit-hono.strategy.js +21 -0
  375. package/dist/shield-rate-limit-hono.strategy.js.map +1 -0
  376. package/dist/shield-rate-limit.strategy.d.ts +11 -10
  377. package/dist/shield-rate-limit.strategy.d.ts.map +1 -1
  378. package/dist/shield-rate-limit.strategy.js +9 -16
  379. package/dist/shield-rate-limit.strategy.js.map +1 -1
  380. package/dist/shield-recaptcha-hono.strategy.d.ts +11 -0
  381. package/dist/shield-recaptcha-hono.strategy.d.ts.map +1 -0
  382. package/dist/shield-recaptcha-hono.strategy.js +22 -0
  383. package/dist/shield-recaptcha-hono.strategy.js.map +1 -0
  384. package/dist/shield-recaptcha.strategy.d.ts +9 -8
  385. package/dist/shield-recaptcha.strategy.d.ts.map +1 -1
  386. package/dist/shield-recaptcha.strategy.js +8 -13
  387. package/dist/shield-recaptcha.strategy.js.map +1 -1
  388. package/dist/shield-security-hono.strategy.d.ts +18 -0
  389. package/dist/shield-security-hono.strategy.d.ts.map +1 -0
  390. package/dist/shield-security-hono.strategy.js +43 -0
  391. package/dist/shield-security-hono.strategy.js.map +1 -0
  392. package/dist/shield-security.strategy.d.ts +6 -12
  393. package/dist/shield-security.strategy.d.ts.map +1 -1
  394. package/dist/shield-security.strategy.js +12 -43
  395. package/dist/shield-security.strategy.js.map +1 -1
  396. package/dist/shield-timeout-hono.strategy.d.ts +11 -0
  397. package/dist/shield-timeout-hono.strategy.d.ts.map +1 -0
  398. package/dist/shield-timeout-hono.strategy.js +15 -0
  399. package/dist/shield-timeout-hono.strategy.js.map +1 -0
  400. package/dist/shield-timeout.strategy.d.ts +7 -9
  401. package/dist/shield-timeout.strategy.d.ts.map +1 -1
  402. package/dist/shield-timeout.strategy.js +3 -7
  403. package/dist/shield-timeout.strategy.js.map +1 -1
  404. package/dist/simulated-error-hono.middleware.d.ts +8 -0
  405. package/dist/simulated-error-hono.middleware.d.ts.map +1 -0
  406. package/dist/simulated-error-hono.middleware.js +13 -0
  407. package/dist/simulated-error-hono.middleware.js.map +1 -0
  408. package/dist/simulated-error.middleware.d.ts +2 -2
  409. package/dist/simulated-error.middleware.d.ts.map +1 -1
  410. package/dist/simulated-error.middleware.js +3 -4
  411. package/dist/simulated-error.middleware.js.map +1 -1
  412. package/dist/slower-hono.middleware.d.ts +14 -0
  413. package/dist/slower-hono.middleware.d.ts.map +1 -0
  414. package/dist/slower-hono.middleware.js +14 -0
  415. package/dist/slower-hono.middleware.js.map +1 -0
  416. package/dist/slower.middleware.d.ts +5 -2
  417. package/dist/slower.middleware.d.ts.map +1 -1
  418. package/dist/slower.middleware.js +10 -6
  419. package/dist/slower.middleware.js.map +1 -1
  420. package/dist/{ssr.d.ts → ssr-bun.service.d.ts} +2 -2
  421. package/dist/ssr-bun.service.d.ts.map +1 -0
  422. package/dist/ssr-bun.service.js +14 -0
  423. package/dist/ssr-bun.service.js.map +1 -0
  424. package/dist/ssr.service.d.ts +26 -0
  425. package/dist/ssr.service.d.ts.map +1 -0
  426. package/dist/ssr.service.js +49 -0
  427. package/dist/ssr.service.js.map +1 -0
  428. package/dist/{static-files.service.d.ts → static-files-hono.service.d.ts} +2 -2
  429. package/dist/static-files-hono.service.d.ts.map +1 -0
  430. package/dist/{static-files.service.js → static-files-hono.service.js} +2 -2
  431. package/dist/static-files-hono.service.js.map +1 -0
  432. package/dist/subject-application-resolver.vo.d.ts +23 -0
  433. package/dist/subject-application-resolver.vo.d.ts.map +1 -0
  434. package/dist/{cache-subject-application-resolver.vo.js → subject-application-resolver.vo.js} +7 -7
  435. package/dist/subject-application-resolver.vo.js.map +1 -0
  436. package/dist/{cache-subject-request-resolver.vo.d.ts → subject-request-resolver.vo.d.ts} +6 -6
  437. package/dist/subject-request-resolver.vo.d.ts.map +1 -0
  438. package/dist/{cache-subject-request-resolver.vo.js → subject-request-resolver.vo.js} +7 -7
  439. package/dist/subject-request-resolver.vo.js.map +1 -0
  440. package/dist/subject-segment-application.strategy.d.ts +6 -0
  441. package/dist/subject-segment-application.strategy.d.ts.map +1 -0
  442. package/dist/subject-segment-application.strategy.js +2 -0
  443. package/dist/subject-segment-application.strategy.js.map +1 -0
  444. package/dist/subject-segment-build.strategy.d.ts +9 -0
  445. package/dist/subject-segment-build.strategy.d.ts.map +1 -0
  446. package/dist/subject-segment-build.strategy.js +13 -0
  447. package/dist/subject-segment-build.strategy.js.map +1 -0
  448. package/dist/subject-segment-cookie.strategy.d.ts +9 -0
  449. package/dist/subject-segment-cookie.strategy.d.ts.map +1 -0
  450. package/dist/subject-segment-cookie.strategy.js +11 -0
  451. package/dist/subject-segment-cookie.strategy.js.map +1 -0
  452. package/dist/subject-segment-env.strategy.d.ts +9 -0
  453. package/dist/subject-segment-env.strategy.d.ts.map +1 -0
  454. package/dist/{cache-subject-segment-env.strategy.js → subject-segment-env.strategy.js} +2 -2
  455. package/dist/subject-segment-env.strategy.js.map +1 -0
  456. package/dist/subject-segment-fixed.strategy.d.ts +8 -0
  457. package/dist/subject-segment-fixed.strategy.d.ts.map +1 -0
  458. package/dist/{cache-subject-segment-fixed.strategy.js → subject-segment-fixed.strategy.js} +2 -2
  459. package/dist/subject-segment-fixed.strategy.js.map +1 -0
  460. package/dist/subject-segment-header.strategy.d.ts +9 -0
  461. package/dist/subject-segment-header.strategy.d.ts.map +1 -0
  462. package/dist/subject-segment-header.strategy.js +11 -0
  463. package/dist/subject-segment-header.strategy.js.map +1 -0
  464. package/dist/subject-segment-ip.strategy.d.ts +6 -0
  465. package/dist/subject-segment-ip.strategy.d.ts.map +1 -0
  466. package/dist/subject-segment-ip.strategy.js +7 -0
  467. package/dist/subject-segment-ip.strategy.js.map +1 -0
  468. package/dist/subject-segment-path.strategy.d.ts +6 -0
  469. package/dist/subject-segment-path.strategy.d.ts.map +1 -0
  470. package/dist/subject-segment-path.strategy.js +6 -0
  471. package/dist/subject-segment-path.strategy.js.map +1 -0
  472. package/dist/subject-segment-query.strategy.d.ts +7 -0
  473. package/dist/subject-segment-query.strategy.d.ts.map +1 -0
  474. package/dist/subject-segment-query.strategy.js +12 -0
  475. package/dist/subject-segment-query.strategy.js.map +1 -0
  476. package/dist/subject-segment-request.strategy.d.ts +9 -0
  477. package/dist/subject-segment-request.strategy.d.ts.map +1 -0
  478. package/dist/subject-segment-request.strategy.js +2 -0
  479. package/dist/subject-segment-request.strategy.js.map +1 -0
  480. package/dist/subject-segment-user.strategy.d.ts +6 -0
  481. package/dist/subject-segment-user.strategy.d.ts.map +1 -0
  482. package/dist/subject-segment-user.strategy.js +7 -0
  483. package/dist/subject-segment-user.strategy.js.map +1 -0
  484. package/dist/time-zone-offset-hono.middleware.d.ts +12 -0
  485. package/dist/time-zone-offset-hono.middleware.d.ts.map +1 -0
  486. package/dist/time-zone-offset-hono.middleware.js +17 -0
  487. package/dist/time-zone-offset-hono.middleware.js.map +1 -0
  488. package/dist/time-zone-offset.middleware.d.ts +3 -6
  489. package/dist/time-zone-offset.middleware.d.ts.map +1 -1
  490. package/dist/time-zone-offset.middleware.js +5 -13
  491. package/dist/time-zone-offset.middleware.js.map +1 -1
  492. package/dist/timing-hono.middleware.d.ts +12 -0
  493. package/dist/timing-hono.middleware.d.ts.map +1 -0
  494. package/dist/timing-hono.middleware.js +15 -0
  495. package/dist/timing-hono.middleware.js.map +1 -0
  496. package/dist/timing.middleware.d.ts +12 -0
  497. package/dist/timing.middleware.d.ts.map +1 -0
  498. package/dist/timing.middleware.js +14 -0
  499. package/dist/timing.middleware.js.map +1 -0
  500. package/dist/trailing-slash-hono.middleware.d.ts +7 -0
  501. package/dist/trailing-slash-hono.middleware.d.ts.map +1 -0
  502. package/dist/trailing-slash-hono.middleware.js +21 -0
  503. package/dist/trailing-slash-hono.middleware.js.map +1 -0
  504. package/dist/trailing-slash.middleware.d.ts +11 -0
  505. package/dist/trailing-slash.middleware.d.ts.map +1 -0
  506. package/dist/trailing-slash.middleware.js +10 -0
  507. package/dist/trailing-slash.middleware.js.map +1 -0
  508. package/dist/translations-hono.handler.d.ts +23 -0
  509. package/dist/translations-hono.handler.d.ts.map +1 -0
  510. package/dist/translations-hono.handler.js +17 -0
  511. package/dist/translations-hono.handler.js.map +1 -0
  512. package/dist/translations.handler.d.ts +22 -0
  513. package/dist/translations.handler.d.ts.map +1 -0
  514. package/dist/translations.handler.js +18 -0
  515. package/dist/translations.handler.js.map +1 -0
  516. package/dist/tsconfig.tsbuildinfo +1 -1
  517. package/dist/weak-etag-extractor-hono.middleware.d.ts +12 -0
  518. package/dist/weak-etag-extractor-hono.middleware.d.ts.map +1 -0
  519. package/dist/weak-etag-extractor-hono.middleware.js +17 -0
  520. package/dist/weak-etag-extractor-hono.middleware.js.map +1 -0
  521. package/dist/weak-etag-extractor.middleware.d.ts +4 -5
  522. package/dist/weak-etag-extractor.middleware.d.ts.map +1 -1
  523. package/dist/weak-etag-extractor.middleware.js +5 -9
  524. package/dist/weak-etag-extractor.middleware.js.map +1 -1
  525. package/dist/woodchopper-dispatcher-async.strategy.d.ts.map +1 -1
  526. package/dist/woodchopper-dispatcher-async.strategy.js +2 -0
  527. package/dist/woodchopper-dispatcher-async.strategy.js.map +1 -1
  528. package/dist/woodchopper-sampling-correlation-id.strategy.d.ts +2 -2
  529. package/dist/woodchopper-sampling-correlation-id.strategy.d.ts.map +1 -1
  530. package/dist/woodchopper-sampling-correlation-id.strategy.js.map +1 -1
  531. package/dist/woodchopper-sampling-every-nth.strategy.d.ts +3 -2
  532. package/dist/woodchopper-sampling-every-nth.strategy.d.ts.map +1 -1
  533. package/dist/woodchopper-sampling-every-nth.strategy.js.map +1 -1
  534. package/dist/woodchopper.d.ts +2 -2
  535. package/dist/woodchopper.d.ts.map +1 -1
  536. package/dist/woodchopper.js.map +1 -1
  537. package/package.json +9 -9
  538. package/readme.md +69 -24
  539. package/src/ab-assignment-composite.strategy.ts +17 -0
  540. package/src/ab-assignment-fixed.strategy.ts +12 -0
  541. package/src/ab-assignment-hash.strategy.ts +23 -0
  542. package/src/ab-assignment-query.strategy.ts +14 -0
  543. package/src/ab-assignment.strategy.ts +7 -0
  544. package/src/ab-hono-noop.middleware.ts +26 -0
  545. package/src/ab-hono.middleware.ts +28 -0
  546. package/src/ab-variant-selector.service.ts +27 -0
  547. package/src/ab-variant-weight.vo.ts +13 -0
  548. package/src/ab-variant.vo.ts +7 -0
  549. package/src/ab-variants.vo.ts +24 -0
  550. package/src/ab.middleware.ts +15 -0
  551. package/src/api-version-hono.middleware.ts +30 -0
  552. package/src/api-version.middleware.ts +18 -17
  553. package/src/auth-session-reader.port.ts +3 -3
  554. package/src/basic-auth.service.ts +3 -3
  555. package/src/cache-response-hono.middleware.ts +53 -0
  556. package/src/cache-response.middleware.ts +27 -33
  557. package/src/correlation-hono.middleware.ts +32 -0
  558. package/src/correlation-id.middleware.ts +20 -0
  559. package/src/correlation-storage.service.ts +0 -3
  560. package/src/crypto-key-provider-with-cache.adapter.ts +8 -6
  561. package/src/environment-loader-process-safe.adapter.ts +3 -6
  562. package/src/etag-extractor-hono.middleware.ts +27 -0
  563. package/src/etag-extractor.middleware.ts +6 -12
  564. package/src/event-store.ts +2 -2
  565. package/src/file-inspection-noop.adapter.ts +2 -2
  566. package/src/file-reader-json-with-cache.adapter.ts +8 -7
  567. package/src/file-reader-raw-with-cache.adapter.ts +8 -7
  568. package/src/file-reader-text-with-cache.adapter.ts +8 -7
  569. package/src/file-uploader-hono.middleware.ts +47 -0
  570. package/src/file-uploader.middleware.ts +21 -25
  571. package/src/handler-hono.port.ts +5 -0
  572. package/src/hash-bucket.vo.ts +19 -0
  573. package/src/healthcheck-hono.handler.ts +31 -0
  574. package/src/healthcheck.handler.ts +150 -0
  575. package/src/http-logger-hono.middleware.ts +50 -0
  576. package/src/http-logger.middleware.ts +56 -63
  577. package/src/i18n.service.ts +1 -1
  578. package/src/image-info-noop.adapter.ts +1 -1
  579. package/src/image-info-sharp.adapter.ts +3 -3
  580. package/src/image-info.port.ts +1 -1
  581. package/src/in-flight-requests-hono.middleware.ts +19 -0
  582. package/src/in-flight-requests-tracker.service.ts +0 -2
  583. package/src/in-flight-requests.middleware.ts +7 -11
  584. package/src/index.ts +70 -25
  585. package/src/invariant-error-handler.service.ts +2 -3
  586. package/src/invariant.service.ts +2 -2
  587. package/src/mailer-resend.adapter.ts +2 -2
  588. package/src/mailer-smtp.adapter.ts +2 -2
  589. package/src/middleware-hono-noop.adapter.ts +8 -0
  590. package/src/middleware-hono.port.ts +5 -0
  591. package/src/modules/preferences/invariants/user-language-has-changed.ts +4 -7
  592. package/src/ping-hono.handler.ts +17 -0
  593. package/src/ping.handler.ts +5 -0
  594. package/src/prerequisite-verifier-binary.adapter.ts +3 -1
  595. package/src/prerequisite-verifier-bun.adapter.ts +3 -1
  596. package/src/prerequisite-verifier-clock-drift.adapter.ts +2 -1
  597. package/src/prerequisite-verifier-directory.adapter.ts +6 -4
  598. package/src/prerequisite-verifier-dns.adapter.ts +3 -1
  599. package/src/prerequisite-verifier-external-api.adapter.ts +3 -1
  600. package/src/prerequisite-verifier-file.adapter.ts +6 -4
  601. package/src/prerequisite-verifier-jobs.adapter.ts +3 -1
  602. package/src/prerequisite-verifier-memory.adapter.ts +3 -1
  603. package/src/prerequisite-verifier-node.adapter.ts +3 -1
  604. package/src/prerequisite-verifier-os.adapter.ts +3 -1
  605. package/src/prerequisite-verifier-port.adapter.ts +3 -1
  606. package/src/prerequisite-verifier-ram.adapter.ts +3 -1
  607. package/src/prerequisite-verifier-running-user.adapter.ts +3 -1
  608. package/src/prerequisite-verifier-space.adapter.ts +2 -1
  609. package/src/prerequisite-verifier-sqlite.adapter.ts +3 -1
  610. package/src/prerequisite-verifier-ssl-certificate-expiry.adapter.ts +3 -1
  611. package/src/prerequisite-verifier-timezone-utc.adapter.ts +3 -1
  612. package/src/prerequisite-verifier-translations.adapter.ts +1 -2
  613. package/src/prerequisite-verifier-with-cache.adapter.ts +8 -7
  614. package/src/prerequisite-verifier-with-fail-safe.adapter.ts +4 -4
  615. package/src/prerequisite-verifier-with-logger.adapter.ts +3 -1
  616. package/src/prerequisite-verifier-with-retry.adapter.ts +3 -2
  617. package/src/prerequisite-verifier-with-timeout.adapter.ts +2 -1
  618. package/src/prerequisite-verifier.decorator.ts +4 -4
  619. package/src/prerequisite.vo.ts +2 -5
  620. package/src/remote-file-storage-disk.adapter.ts +3 -3
  621. package/src/request-context-hono.adapter.ts +12 -1
  622. package/src/request-context.port.ts +15 -0
  623. package/src/retry.service.ts +4 -4
  624. package/src/security-countermeasure-ban.strategy.ts +6 -4
  625. package/src/security-countermeasure-mirage.strategy.ts +2 -1
  626. package/src/security-countermeasure-tarpit.strategy.ts +2 -1
  627. package/src/security-rule-violation-threshold.strategy.ts +7 -6
  628. package/src/{setup.service.ts → setup-hono.service.ts} +36 -43
  629. package/src/shield-api-key-hono.strategy.ts +28 -0
  630. package/src/shield-api-key.strategy.ts +9 -15
  631. package/src/shield-auth-hono.strategy.ts +41 -0
  632. package/src/shield-auth.strategy.ts +12 -26
  633. package/src/shield-basic-auth-hono.strategy.ts +30 -0
  634. package/src/shield-basic-auth.strategy.ts +21 -10
  635. package/src/shield-body-limit-hono.strategy.ts +30 -0
  636. package/src/shield-body-limit.strategy.ts +23 -0
  637. package/src/shield-csrf-hono.strategy.ts +24 -0
  638. package/src/shield-csrf.strategy.ts +11 -16
  639. package/src/shield-hcaptcha-hono-local.strategy.ts +26 -0
  640. package/src/shield-hcaptcha-hono.strategy.ts +25 -0
  641. package/src/shield-hcaptcha.strategy.ts +7 -13
  642. package/src/shield-maintenance-hono.strategy.ts +23 -0
  643. package/src/shield-maintenance.strategy.ts +17 -0
  644. package/src/shield-rate-limit-hono.strategy.ts +34 -0
  645. package/src/shield-rate-limit.strategy.ts +11 -19
  646. package/src/shield-recaptcha-hono.strategy.ts +31 -0
  647. package/src/shield-recaptcha.strategy.ts +14 -20
  648. package/src/shield-security-hono.strategy.ts +62 -0
  649. package/src/shield-security.strategy.ts +19 -62
  650. package/src/shield-timeout-hono.strategy.ts +25 -0
  651. package/src/shield-timeout.strategy.ts +4 -14
  652. package/src/simulated-error-hono.middleware.ts +17 -0
  653. package/src/simulated-error.middleware.ts +4 -7
  654. package/src/slower-hono.middleware.ts +23 -0
  655. package/src/slower.middleware.ts +8 -7
  656. package/src/ssr-bun.service.ts +25 -0
  657. package/src/ssr.service.ts +66 -0
  658. package/src/{static-files.service.ts → static-files-hono.service.ts} +1 -1
  659. package/src/subject-application-resolver.vo.ts +34 -0
  660. package/src/subject-request-resolver.vo.ts +34 -0
  661. package/src/subject-segment-application.strategy.ts +7 -0
  662. package/src/subject-segment-build.strategy.ts +15 -0
  663. package/src/subject-segment-cookie.strategy.ts +14 -0
  664. package/src/subject-segment-env.strategy.ts +11 -0
  665. package/src/subject-segment-fixed.strategy.ts +12 -0
  666. package/src/subject-segment-header.strategy.ts +14 -0
  667. package/src/subject-segment-ip.strategy.ts +12 -0
  668. package/src/subject-segment-path.strategy.ts +8 -0
  669. package/src/subject-segment-query.strategy.ts +19 -0
  670. package/src/{cache-subject-segment-request.strategy.ts → subject-segment-request.strategy.ts} +4 -4
  671. package/src/subject-segment-user.strategy.ts +12 -0
  672. package/src/time-zone-offset-hono.middleware.ts +26 -0
  673. package/src/time-zone-offset.middleware.ts +6 -18
  674. package/src/timing-hono.middleware.ts +22 -0
  675. package/src/timing.middleware.ts +18 -0
  676. package/src/trailing-slash-hono.middleware.ts +27 -0
  677. package/src/trailing-slash.middleware.ts +11 -0
  678. package/src/translations-hono.handler.ts +26 -0
  679. package/src/translations.handler.ts +31 -0
  680. package/src/weak-etag-extractor-hono.middleware.ts +26 -0
  681. package/src/weak-etag-extractor.middleware.ts +6 -11
  682. package/src/woodchopper-dispatcher-async.strategy.ts +2 -0
  683. package/src/woodchopper-sampling-correlation-id.strategy.ts +2 -2
  684. package/src/woodchopper-sampling-every-nth.strategy.ts +2 -2
  685. package/src/woodchopper.ts +2 -2
  686. package/dist/cache-subject-application-resolver.vo.d.ts +0 -23
  687. package/dist/cache-subject-application-resolver.vo.d.ts.map +0 -1
  688. package/dist/cache-subject-application-resolver.vo.js.map +0 -1
  689. package/dist/cache-subject-request-resolver.vo.d.ts.map +0 -1
  690. package/dist/cache-subject-request-resolver.vo.js.map +0 -1
  691. package/dist/cache-subject-segment-application.strategy.d.ts +0 -6
  692. package/dist/cache-subject-segment-application.strategy.d.ts.map +0 -1
  693. package/dist/cache-subject-segment-application.strategy.js +0 -2
  694. package/dist/cache-subject-segment-application.strategy.js.map +0 -1
  695. package/dist/cache-subject-segment-build.strategy.d.ts +0 -9
  696. package/dist/cache-subject-segment-build.strategy.d.ts.map +0 -1
  697. package/dist/cache-subject-segment-build.strategy.js +0 -13
  698. package/dist/cache-subject-segment-build.strategy.js.map +0 -1
  699. package/dist/cache-subject-segment-cookie.strategy.d.ts +0 -9
  700. package/dist/cache-subject-segment-cookie.strategy.d.ts.map +0 -1
  701. package/dist/cache-subject-segment-cookie.strategy.js +0 -11
  702. package/dist/cache-subject-segment-cookie.strategy.js.map +0 -1
  703. package/dist/cache-subject-segment-env.strategy.d.ts +0 -9
  704. package/dist/cache-subject-segment-env.strategy.d.ts.map +0 -1
  705. package/dist/cache-subject-segment-env.strategy.js.map +0 -1
  706. package/dist/cache-subject-segment-fixed.strategy.d.ts +0 -8
  707. package/dist/cache-subject-segment-fixed.strategy.d.ts.map +0 -1
  708. package/dist/cache-subject-segment-fixed.strategy.js.map +0 -1
  709. package/dist/cache-subject-segment-header.strategy.d.ts +0 -9
  710. package/dist/cache-subject-segment-header.strategy.d.ts.map +0 -1
  711. package/dist/cache-subject-segment-header.strategy.js +0 -11
  712. package/dist/cache-subject-segment-header.strategy.js.map +0 -1
  713. package/dist/cache-subject-segment-ip.strategy.d.ts +0 -6
  714. package/dist/cache-subject-segment-ip.strategy.d.ts.map +0 -1
  715. package/dist/cache-subject-segment-ip.strategy.js +0 -7
  716. package/dist/cache-subject-segment-ip.strategy.js.map +0 -1
  717. package/dist/cache-subject-segment-path.strategy.d.ts +0 -6
  718. package/dist/cache-subject-segment-path.strategy.d.ts.map +0 -1
  719. package/dist/cache-subject-segment-path.strategy.js +0 -6
  720. package/dist/cache-subject-segment-path.strategy.js.map +0 -1
  721. package/dist/cache-subject-segment-query.strategy.d.ts +0 -7
  722. package/dist/cache-subject-segment-query.strategy.d.ts.map +0 -1
  723. package/dist/cache-subject-segment-query.strategy.js +0 -12
  724. package/dist/cache-subject-segment-query.strategy.js.map +0 -1
  725. package/dist/cache-subject-segment-request.strategy.d.ts +0 -9
  726. package/dist/cache-subject-segment-request.strategy.d.ts.map +0 -1
  727. package/dist/cache-subject-segment-request.strategy.js +0 -2
  728. package/dist/cache-subject-segment-request.strategy.js.map +0 -1
  729. package/dist/cache-subject-segment-user.strategy.d.ts +0 -6
  730. package/dist/cache-subject-segment-user.strategy.d.ts.map +0 -1
  731. package/dist/cache-subject-segment-user.strategy.js +0 -7
  732. package/dist/cache-subject-segment-user.strategy.js.map +0 -1
  733. package/dist/context.middleware.d.ts +0 -14
  734. package/dist/context.middleware.d.ts.map +0 -1
  735. package/dist/context.middleware.js +0 -11
  736. package/dist/context.middleware.js.map +0 -1
  737. package/dist/healthcheck.service.d.ts +0 -96
  738. package/dist/healthcheck.service.d.ts.map +0 -1
  739. package/dist/healthcheck.service.js.map +0 -1
  740. package/dist/maintenance-mode.middleware.d.ts +0 -11
  741. package/dist/maintenance-mode.middleware.d.ts.map +0 -1
  742. package/dist/maintenance-mode.middleware.js +0 -12
  743. package/dist/maintenance-mode.middleware.js.map +0 -1
  744. package/dist/ping.service.d.ts +0 -4
  745. package/dist/ping.service.d.ts.map +0 -1
  746. package/dist/ping.service.js +0 -6
  747. package/dist/ping.service.js.map +0 -1
  748. package/dist/setup.service.d.ts +0 -35
  749. package/dist/setup.service.d.ts.map +0 -1
  750. package/dist/setup.service.js.map +0 -1
  751. package/dist/shield-hcaptcha-local.strategy.d.ts +0 -11
  752. package/dist/shield-hcaptcha-local.strategy.d.ts.map +0 -1
  753. package/dist/shield-hcaptcha-local.strategy.js +0 -23
  754. package/dist/shield-hcaptcha-local.strategy.js.map +0 -1
  755. package/dist/shield-noop.strategy.d.ts +0 -5
  756. package/dist/shield-noop.strategy.d.ts.map +0 -1
  757. package/dist/shield-noop.strategy.js +0 -5
  758. package/dist/shield-noop.strategy.js.map +0 -1
  759. package/dist/shield.strategy.d.ts +0 -5
  760. package/dist/shield.strategy.d.ts.map +0 -1
  761. package/dist/shield.strategy.js +0 -2
  762. package/dist/shield.strategy.js.map +0 -1
  763. package/dist/ssr.d.ts.map +0 -1
  764. package/dist/ssr.js +0 -43
  765. package/dist/ssr.js.map +0 -1
  766. package/dist/static-files.service.d.ts.map +0 -1
  767. package/dist/static-files.service.js.map +0 -1
  768. package/dist/translations.service.d.ts +0 -21
  769. package/dist/translations.service.d.ts.map +0 -1
  770. package/dist/translations.service.js +0 -11
  771. package/dist/translations.service.js.map +0 -1
  772. package/src/cache-subject-application-resolver.vo.ts +0 -34
  773. package/src/cache-subject-request-resolver.vo.ts +0 -39
  774. package/src/cache-subject-segment-application.strategy.ts +0 -7
  775. package/src/cache-subject-segment-build.strategy.ts +0 -15
  776. package/src/cache-subject-segment-cookie.strategy.ts +0 -14
  777. package/src/cache-subject-segment-env.strategy.ts +0 -11
  778. package/src/cache-subject-segment-fixed.strategy.ts +0 -15
  779. package/src/cache-subject-segment-header.strategy.ts +0 -14
  780. package/src/cache-subject-segment-ip.strategy.ts +0 -12
  781. package/src/cache-subject-segment-path.strategy.ts +0 -11
  782. package/src/cache-subject-segment-query.strategy.ts +0 -19
  783. package/src/cache-subject-segment-user.strategy.ts +0 -12
  784. package/src/context.middleware.ts +0 -24
  785. package/src/healthcheck.service.ts +0 -154
  786. package/src/maintenance-mode.middleware.ts +0 -15
  787. package/src/ping.service.ts +0 -7
  788. package/src/shield-hcaptcha-local.strategy.ts +0 -24
  789. package/src/shield-noop.strategy.ts +0 -6
  790. package/src/shield.strategy.ts +0 -5
  791. package/src/ssr.ts +0 -57
  792. package/src/translations.service.ts +0 -20
@@ -0,0 +1,11 @@
1
+ import type { MiddlewareHandler } from "hono";
2
+ import { HTTPException } from "hono/http-exception";
3
+ import type { MiddlewareHonoPort } from "./middleware-hono.port";
4
+ import { type ShieldBasicAuthConfig } from "./shield-basic-auth.strategy";
5
+ export declare const ShieldBasicAuthError: HTTPException;
6
+ export declare class ShieldBasicAuthHonoStrategy implements MiddlewareHonoPort {
7
+ private readonly strategy;
8
+ constructor(config: ShieldBasicAuthConfig);
9
+ handle(): MiddlewareHandler;
10
+ }
11
+ //# sourceMappingURL=shield-basic-auth-hono.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-basic-auth-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-basic-auth-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EACL,KAAK,qBAAqB,EAG3B,MAAM,8BAA8B,CAAC;AAEtC,eAAO,MAAM,oBAAoB,eAE/B,CAAC;AAEH,qBAAa,2BAA4B,YAAW,kBAAkB;IACpE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;gBAEvC,MAAM,EAAE,qBAAqB;IAIzC,MAAM,IAAI,iBAAiB;CAQ5B"}
@@ -0,0 +1,21 @@
1
+ import { HTTPException } from "hono/http-exception";
2
+ import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
3
+ import { ShieldBasicAuthStrategy, ShieldBasicAuthStrategyError, } from "./shield-basic-auth.strategy";
4
+ export const ShieldBasicAuthError = new HTTPException(401, {
5
+ message: ShieldBasicAuthStrategyError.Rejected,
6
+ });
7
+ export class ShieldBasicAuthHonoStrategy {
8
+ strategy;
9
+ constructor(config) {
10
+ this.strategy = new ShieldBasicAuthStrategy(config);
11
+ }
12
+ handle() {
13
+ return async (c, next) => {
14
+ const context = new RequestContextHonoAdapter(c);
15
+ if (this.strategy.evaluate(context))
16
+ return next();
17
+ throw ShieldBasicAuthError;
18
+ };
19
+ }
20
+ }
21
+ //# sourceMappingURL=shield-basic-auth-hono.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-basic-auth-hono.strategy.js","sourceRoot":"","sources":["../src/shield-basic-auth-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAEL,uBAAuB,EACvB,4BAA4B,GAC7B,MAAM,8BAA8B,CAAC;AAEtC,MAAM,CAAC,MAAM,oBAAoB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE;IACzD,OAAO,EAAE,4BAA4B,CAAC,QAAQ;CAC/C,CAAC,CAAC;AAEH,MAAM,OAAO,2BAA2B;IACrB,QAAQ,CAA0B;IAEnD,YAAY,MAA6B;QACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAAC;IACtD,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAAE,OAAO,IAAI,EAAE,CAAC;YACnD,MAAM,oBAAoB,CAAC;QAC7B,CAAC,CAAC;IACJ,CAAC;CACF"}
@@ -1,14 +1,16 @@
1
1
  import type { BasicAuthPasswordType } from "./basic-auth-password.vo";
2
2
  import type { BasicAuthUsernameType } from "./basic-auth-username.vo";
3
- import type { ShieldStrategy } from "./shield.strategy";
4
- type ShieldBasicAuthConfigType = {
3
+ import type { HasRequestHeader } from "./request-context.port";
4
+ export type ShieldBasicAuthConfig = {
5
5
  username: BasicAuthUsernameType;
6
6
  password: BasicAuthPasswordType;
7
7
  };
8
- export declare class ShieldBasicAuthStrategy implements ShieldStrategy {
9
- private readonly basicAuth;
10
- constructor(config: ShieldBasicAuthConfigType);
11
- verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
8
+ export declare const ShieldBasicAuthStrategyError: {
9
+ Rejected: string;
10
+ };
11
+ export declare class ShieldBasicAuthStrategy {
12
+ private readonly config;
13
+ constructor(config: ShieldBasicAuthConfig);
14
+ evaluate(context: HasRequestHeader): boolean;
12
15
  }
13
- export {};
14
16
  //# sourceMappingURL=shield-basic-auth.strategy.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"shield-basic-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,KAAK,yBAAyB,GAAG;IAAE,QAAQ,EAAE,qBAAqB,CAAC;IAAC,QAAQ,EAAE,qBAAqB,CAAA;CAAE,CAAC;AAEtG,qBAAa,uBAAwB,YAAW,cAAc;IAC5D,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAC;gBAEf,MAAM,EAAE,yBAAyB;IAI7C,MAAM,8DAA4E;CACnF"}
1
+ {"version":3,"file":"shield-basic-auth.strategy.d.ts","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,MAAM,MAAM,qBAAqB,GAAG;IAAE,QAAQ,EAAE,qBAAqB,CAAC;IAAC,QAAQ,EAAE,qBAAqB,CAAA;CAAE,CAAC;AAEzG,eAAO,MAAM,4BAA4B;;CAA6C,CAAC;AAEvF,qBAAa,uBAAuB;IACtB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,qBAAqB;IAE1D,QAAQ,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO;CAgB7C"}
@@ -1,10 +1,23 @@
1
- import { basicAuth } from "hono/basic-auth";
2
- import { createMiddleware } from "hono/factory";
1
+ export const ShieldBasicAuthStrategyError = { Rejected: "shield.basic.auth.rejected" };
3
2
  export class ShieldBasicAuthStrategy {
4
- basicAuth;
3
+ config;
5
4
  constructor(config) {
6
- this.basicAuth = basicAuth(config);
5
+ this.config = config;
6
+ }
7
+ evaluate(context) {
8
+ const header = context.request.header("authorization");
9
+ try {
10
+ const credentials = atob(String(header).replace("Basic ", ""));
11
+ const [username, password] = credentials.split(":");
12
+ if (username !== this.config.username)
13
+ return false;
14
+ if (password !== this.config.password)
15
+ return false;
16
+ return true;
17
+ }
18
+ catch {
19
+ return false;
20
+ }
7
21
  }
8
- verify = createMiddleware(async (context, next) => this.basicAuth(context, next));
9
22
  }
10
23
  //# sourceMappingURL=shield-basic-auth.strategy.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shield-basic-auth.strategy.js","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAOhD,MAAM,OAAO,uBAAuB;IACjB,SAAS,CAAC;IAE3B,YAAY,MAAiC;QAC3C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC;IACrC,CAAC;IAED,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,IAAI,CAAC,CAAC,CAAC;CACnF"}
1
+ {"version":3,"file":"shield-basic-auth.strategy.js","sourceRoot":"","sources":["../src/shield-basic-auth.strategy.ts"],"names":[],"mappings":"AAMA,MAAM,CAAC,MAAM,4BAA4B,GAAG,EAAE,QAAQ,EAAE,4BAA4B,EAAE,CAAC;AAEvF,MAAM,OAAO,uBAAuB;IACL;IAA7B,YAA6B,MAA6B;QAA7B,WAAM,GAAN,MAAM,CAAuB;IAAG,CAAC;IAE9D,QAAQ,CAAC,OAAyB;QAChC,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;QAEvD,IAAI,CAAC;YACH,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,QAAQ,EAAE,EAAE,CAAC,CAAC,CAAC;YAE/D,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,WAAW,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAEpD,IAAI,QAAQ,KAAK,IAAI,CAAC,MAAM,CAAC,QAAQ;gBAAE,OAAO,KAAK,CAAC;YACpD,IAAI,QAAQ,KAAK,IAAI,CAAC,MAAM,CAAC,QAAQ;gBAAE,OAAO,KAAK,CAAC;YAEpD,OAAO,IAAI,CAAC;QACd,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;CACF"}
@@ -0,0 +1,10 @@
1
+ import { HTTPException } from "hono/http-exception";
2
+ import type { MiddlewareHonoPort } from "./middleware-hono.port";
3
+ import { type ShieldBodyLimitConfig } from "./shield-body-limit.strategy";
4
+ export declare const ShieldBodyLimitTooBigError: HTTPException;
5
+ export declare class ShieldBodyLimitHonoStrategy implements MiddlewareHonoPort {
6
+ private readonly strategy;
7
+ constructor(config: ShieldBodyLimitConfig);
8
+ handle(): import("hono").MiddlewareHandler<any, string, {}, Response>;
9
+ }
10
+ //# sourceMappingURL=shield-body-limit-hono.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-body-limit-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-body-limit-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EACL,KAAK,qBAAqB,EAG3B,MAAM,8BAA8B,CAAC;AAEtC,eAAO,MAAM,0BAA0B,eAAmE,CAAC;AAE3G,qBAAa,2BAA4B,YAAW,kBAAkB;IACpE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;gBAEvC,MAAM,EAAE,qBAAqB;IAIzC,MAAM;CAUP"}
@@ -0,0 +1,21 @@
1
+ import { createMiddleware } from "hono/factory";
2
+ import { HTTPException } from "hono/http-exception";
3
+ import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
4
+ import { ShieldBodyLimitError, ShieldBodyLimitStrategy, } from "./shield-body-limit.strategy";
5
+ export const ShieldBodyLimitTooBigError = new HTTPException(413, { message: ShieldBodyLimitError.TooBig });
6
+ export class ShieldBodyLimitHonoStrategy {
7
+ strategy;
8
+ constructor(config) {
9
+ this.strategy = new ShieldBodyLimitStrategy(config);
10
+ }
11
+ handle() {
12
+ return createMiddleware(async (c, next) => {
13
+ const context = new RequestContextHonoAdapter(c);
14
+ const result = this.strategy.evaluate(context);
15
+ if (!result)
16
+ throw ShieldBodyLimitTooBigError;
17
+ return next();
18
+ });
19
+ }
20
+ }
21
+ //# sourceMappingURL=shield-body-limit-hono.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-body-limit-hono.strategy.js","sourceRoot":"","sources":["../src/shield-body-limit-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAEL,oBAAoB,EACpB,uBAAuB,GACxB,MAAM,8BAA8B,CAAC;AAEtC,MAAM,CAAC,MAAM,0BAA0B,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,oBAAoB,CAAC,MAAM,EAAE,CAAC,CAAC;AAE3G,MAAM,OAAO,2BAA2B;IACrB,QAAQ,CAA0B;IAEnD,YAAY,MAA6B;QACvC,IAAI,CAAC,QAAQ,GAAG,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAAC;IACtD,CAAC;IAED,MAAM;QACJ,OAAO,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACxC,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC;YAE/C,IAAI,CAAC,MAAM;gBAAE,MAAM,0BAA0B,CAAC;YAC9C,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC,CAAC,CAAC;IACL,CAAC;CACF"}
@@ -0,0 +1,14 @@
1
+ import * as tools from "@bgord/tools";
2
+ import type { HasRequestHeader } from "./request-context.port";
3
+ export type ShieldBodyLimitConfig = {
4
+ maxSize: tools.Size;
5
+ };
6
+ export declare const ShieldBodyLimitError: {
7
+ TooBig: string;
8
+ };
9
+ export declare class ShieldBodyLimitStrategy {
10
+ private readonly config;
11
+ constructor(config: ShieldBodyLimitConfig);
12
+ evaluate(context: HasRequestHeader): boolean;
13
+ }
14
+ //# sourceMappingURL=shield-body-limit.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-body-limit.strategy.d.ts","sourceRoot":"","sources":["../src/shield-body-limit.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AACtC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAE/D,MAAM,MAAM,qBAAqB,GAAG;IAAE,OAAO,EAAE,KAAK,CAAC,IAAI,CAAA;CAAE,CAAC;AAE5D,eAAO,MAAM,oBAAoB;;CAA2C,CAAC;AAE7E,qBAAa,uBAAuB;IACtB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,qBAAqB;IAE1D,QAAQ,CAAC,OAAO,EAAE,gBAAgB,GAAG,OAAO;CAY7C"}
@@ -0,0 +1,19 @@
1
+ import * as tools from "@bgord/tools";
2
+ export const ShieldBodyLimitError = { TooBig: "shield.body.limit.rejected" };
3
+ export class ShieldBodyLimitStrategy {
4
+ config;
5
+ constructor(config) {
6
+ this.config = config;
7
+ }
8
+ evaluate(context) {
9
+ const header = context.request.header("content-length");
10
+ const contentLength = tools.SizeBytes.safeParse(Number(header));
11
+ if (!contentLength.success)
12
+ return true;
13
+ const size = tools.Size.fromBytes(contentLength.data);
14
+ if (size.isGreaterThan(this.config.maxSize))
15
+ return false;
16
+ return true;
17
+ }
18
+ }
19
+ //# sourceMappingURL=shield-body-limit.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-body-limit.strategy.js","sourceRoot":"","sources":["../src/shield-body-limit.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAKtC,MAAM,CAAC,MAAM,oBAAoB,GAAG,EAAE,MAAM,EAAE,4BAA4B,EAAE,CAAC;AAE7E,MAAM,OAAO,uBAAuB;IACL;IAA7B,YAA6B,MAA6B;QAA7B,WAAM,GAAN,MAAM,CAAuB;IAAG,CAAC;IAE9D,QAAQ,CAAC,OAAyB;QAChC,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;QAExD,MAAM,aAAa,GAAG,KAAK,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC;QAEhE,IAAI,CAAC,aAAa,CAAC,OAAO;YAAE,OAAO,IAAI,CAAC;QAExC,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;QAEtD,IAAI,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;YAAE,OAAO,KAAK,CAAC;QAC1D,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ import type { MiddlewareHandler } from "hono";
2
+ import { HTTPException } from "hono/http-exception";
3
+ import type { MiddlewareHonoPort } from "./middleware-hono.port";
4
+ import { type ShieldCsrfConfig } from "./shield-csrf.strategy";
5
+ export declare const ShieldCsrfError: HTTPException;
6
+ export declare class ShieldCsrfHonoStrategy implements MiddlewareHonoPort {
7
+ private readonly strategy;
8
+ constructor(config: ShieldCsrfConfig);
9
+ handle(): MiddlewareHandler;
10
+ }
11
+ //# sourceMappingURL=shield-csrf-hono.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-csrf-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-csrf-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EAAE,KAAK,gBAAgB,EAA+C,MAAM,wBAAwB,CAAC;AAE5G,eAAO,MAAM,eAAe,eAAwE,CAAC;AAErG,qBAAa,sBAAuB,YAAW,kBAAkB;IAC/D,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAqB;gBAElC,MAAM,EAAE,gBAAgB;IAIpC,MAAM,IAAI,iBAAiB;CAQ5B"}
@@ -0,0 +1,19 @@
1
+ import { HTTPException } from "hono/http-exception";
2
+ import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
3
+ import { ShieldCsrfStrategy, ShieldCsrfStrategyError } from "./shield-csrf.strategy";
4
+ export const ShieldCsrfError = new HTTPException(403, { message: ShieldCsrfStrategyError.Rejected });
5
+ export class ShieldCsrfHonoStrategy {
6
+ strategy;
7
+ constructor(config) {
8
+ this.strategy = new ShieldCsrfStrategy(config);
9
+ }
10
+ handle() {
11
+ return async (c, next) => {
12
+ const context = new RequestContextHonoAdapter(c);
13
+ if (this.strategy.evaluate(context))
14
+ return next();
15
+ throw ShieldCsrfError;
16
+ };
17
+ }
18
+ }
19
+ //# sourceMappingURL=shield-csrf-hono.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-csrf-hono.strategy.js","sourceRoot":"","sources":["../src/shield-csrf-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAAyB,kBAAkB,EAAE,uBAAuB,EAAE,MAAM,wBAAwB,CAAC;AAE5G,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,uBAAuB,CAAC,QAAQ,EAAE,CAAC,CAAC;AAErG,MAAM,OAAO,sBAAsB;IAChB,QAAQ,CAAqB;IAE9C,YAAY,MAAwB;QAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,kBAAkB,CAAC,MAAM,CAAC,CAAC;IACjD,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAAE,OAAO,IAAI,EAAE,CAAC;YACnD,MAAM,eAAe,CAAC;QACxB,CAAC,CAAC;IACJ,CAAC;CACF"}
@@ -1,12 +1,13 @@
1
- import { HTTPException } from "hono/http-exception";
2
- import type { ShieldStrategy } from "./shield.strategy";
3
- export type ShieldCsrfConfigType = {
1
+ import type { HasRequestHeader, HasRequestMethod } from "./request-context.port";
2
+ export type ShieldCsrfConfig = {
4
3
  origin: ReadonlyArray<string>;
5
4
  };
6
- export declare const ShieldCsrfError: HTTPException;
7
- export declare class ShieldCsrfStrategy implements ShieldStrategy {
5
+ export declare const ShieldCsrfStrategyError: {
6
+ Rejected: string;
7
+ };
8
+ export declare class ShieldCsrfStrategy {
8
9
  private readonly config;
9
- constructor(config: ShieldCsrfConfigType);
10
- verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
10
+ constructor(config: ShieldCsrfConfig);
11
+ evaluate(context: HasRequestMethod & HasRequestHeader): boolean;
11
12
  }
12
13
  //# sourceMappingURL=shield-csrf.strategy.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"shield-csrf.strategy.d.ts","sourceRoot":"","sources":["../src/shield-csrf.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAIxD,MAAM,MAAM,oBAAoB,GAAG;IAAE,MAAM,EAAE,aAAa,CAAC,MAAM,CAAC,CAAA;CAAE,CAAC;AAErE,eAAO,MAAM,eAAe,eAAqD,CAAC;AAElF,qBAAa,kBAAmB,YAAW,cAAc;IAC3C,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,oBAAoB;IAEzD,MAAM,8DAUH;CACJ"}
1
+ {"version":3,"file":"shield-csrf.strategy.d.ts","sourceRoot":"","sources":["../src/shield-csrf.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAIjF,MAAM,MAAM,gBAAgB,GAAG;IAAE,MAAM,EAAE,aAAa,CAAC,MAAM,CAAC,CAAA;CAAE,CAAC;AAEjE,eAAO,MAAM,uBAAuB;;CAAuC,CAAC;AAE5E,qBAAa,kBAAkB;IACjB,OAAO,CAAC,QAAQ,CAAC,MAAM;gBAAN,MAAM,EAAE,gBAAgB;IAErD,QAAQ,CAAC,OAAO,EAAE,gBAAgB,GAAG,gBAAgB,GAAG,OAAO;CAShE"}
@@ -1,23 +1,19 @@
1
- import { createMiddleware } from "hono/factory";
2
- import { HTTPException } from "hono/http-exception";
3
- import { RequestContextAdapterHono } from "./request-context-hono.adapter";
4
1
  const STATE_CHANGING_METHODS = ["POST", "PUT", "PATCH", "DELETE"];
5
- export const ShieldCsrfError = new HTTPException(403, { message: "shield.csrf" });
2
+ export const ShieldCsrfStrategyError = { Rejected: "shield.csrf.rejected" };
6
3
  export class ShieldCsrfStrategy {
7
4
  config;
8
5
  constructor(config) {
9
6
  this.config = config;
10
7
  }
11
- verify = createMiddleware(async (c, next) => {
12
- const context = new RequestContextAdapterHono(c);
8
+ evaluate(context) {
13
9
  if (!STATE_CHANGING_METHODS.includes(context.request.method))
14
- return next();
10
+ return true;
15
11
  const origin = context.request.header("origin");
16
12
  if (!origin)
17
- return next();
13
+ return true;
18
14
  if (!this.config.origin.includes(origin))
19
- throw ShieldCsrfError;
20
- return next();
21
- });
15
+ return false;
16
+ return true;
17
+ }
22
18
  }
23
19
  //# sourceMappingURL=shield-csrf.strategy.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shield-csrf.strategy.js","sourceRoot":"","sources":["../src/shield-csrf.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAG3E,MAAM,sBAAsB,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;AAIlE,MAAM,CAAC,MAAM,eAAe,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,aAAa,EAAE,CAAC,CAAC;AAElF,MAAM,OAAO,kBAAkB;IACA;IAA7B,YAA6B,MAA4B;QAA5B,WAAM,GAAN,MAAM,CAAsB;IAAG,CAAC;IAE7D,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;QAC1C,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;QAEjD,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC;YAAE,OAAO,IAAI,EAAE,CAAC;QAE5E,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEhD,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,EAAE,CAAC;QAC3B,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,MAAM,eAAe,CAAC;QAChE,OAAO,IAAI,EAAE,CAAC;IAChB,CAAC,CAAC,CAAC;CACJ"}
1
+ {"version":3,"file":"shield-csrf.strategy.js","sourceRoot":"","sources":["../src/shield-csrf.strategy.ts"],"names":[],"mappings":"AAEA,MAAM,sBAAsB,GAAG,CAAC,MAAM,EAAE,KAAK,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;AAIlE,MAAM,CAAC,MAAM,uBAAuB,GAAG,EAAE,QAAQ,EAAE,sBAAsB,EAAE,CAAC;AAE5E,MAAM,OAAO,kBAAkB;IACA;IAA7B,YAA6B,MAAwB;QAAxB,WAAM,GAAN,MAAM,CAAkB;IAAG,CAAC;IAEzD,QAAQ,CAAC,OAA4C;QACnD,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC;YAAE,OAAO,IAAI,CAAC;QAE1E,MAAM,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;QAEhD,IAAI,CAAC,MAAM;YAAE,OAAO,IAAI,CAAC;QACzB,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC;YAAE,OAAO,KAAK,CAAC;QACvD,OAAO,IAAI,CAAC;IACd,CAAC;CACF"}
@@ -0,0 +1,14 @@
1
+ import type { MiddlewareHandler } from "hono";
2
+ import { HTTPException } from "hono/http-exception";
3
+ import type { HCaptchaSecretKeyType } from "./hcaptcha-secret-key.vo";
4
+ import type { MiddlewareHonoPort } from "./middleware-hono.port";
5
+ export declare const ShieldHcaptchaLocalStrategyError: {
6
+ Rejected: string;
7
+ };
8
+ export declare const ShieldHcaptchaLocalError: HTTPException;
9
+ export declare class ShieldHcaptchaLocalHonoStrategy implements MiddlewareHonoPort {
10
+ private readonly strategy;
11
+ constructor(secretKey: HCaptchaSecretKeyType);
12
+ handle(): MiddlewareHandler;
13
+ }
14
+ //# sourceMappingURL=shield-hcaptcha-hono-local.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-hcaptcha-hono-local.strategy.d.ts","sourceRoot":"","sources":["../src/shield-hcaptcha-hono-local.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAGjE,eAAO,MAAM,gCAAgC;;CAAiD,CAAC;AAE/F,eAAO,MAAM,wBAAwB,eAEnC,CAAC;AAEH,qBAAa,+BAAgC,YAAW,kBAAkB;IACxE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAyB;gBAEtC,SAAS,EAAE,qBAAqB;IAI5C,MAAM,IAAI,iBAAiB;CAM5B"}
@@ -0,0 +1,20 @@
1
+ import { HTTPException } from "hono/http-exception";
2
+ import { ShieldHcaptchaStrategy } from "./shield-hcaptcha.strategy";
3
+ export const ShieldHcaptchaLocalStrategyError = { Rejected: "shield.hcaptcha.local.rejected" };
4
+ export const ShieldHcaptchaLocalError = new HTTPException(403, {
5
+ message: ShieldHcaptchaLocalStrategyError.Rejected,
6
+ });
7
+ export class ShieldHcaptchaLocalHonoStrategy {
8
+ strategy;
9
+ constructor(secretKey) {
10
+ this.strategy = new ShieldHcaptchaStrategy(secretKey);
11
+ }
12
+ handle() {
13
+ return async (_c, next) => {
14
+ if (await this.strategy.evaluate("10000000-aaaa-bbbb-cccc-000000000001"))
15
+ return next();
16
+ throw ShieldHcaptchaLocalError;
17
+ };
18
+ }
19
+ }
20
+ //# sourceMappingURL=shield-hcaptcha-hono-local.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-hcaptcha-hono-local.strategy.js","sourceRoot":"","sources":["../src/shield-hcaptcha-hono-local.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAAE,sBAAsB,EAAE,MAAM,4BAA4B,CAAC;AAEpE,MAAM,CAAC,MAAM,gCAAgC,GAAG,EAAE,QAAQ,EAAE,gCAAgC,EAAE,CAAC;AAE/F,MAAM,CAAC,MAAM,wBAAwB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE;IAC7D,OAAO,EAAE,gCAAgC,CAAC,QAAQ;CACnD,CAAC,CAAC;AAEH,MAAM,OAAO,+BAA+B;IACzB,QAAQ,CAAyB;IAElD,YAAY,SAAgC;QAC1C,IAAI,CAAC,QAAQ,GAAG,IAAI,sBAAsB,CAAC,SAAS,CAAC,CAAC;IACxD,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE;YACxB,IAAI,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,sCAAsC,CAAC;gBAAE,OAAO,IAAI,EAAE,CAAC;YACxF,MAAM,wBAAwB,CAAC;QACjC,CAAC,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,11 @@
1
+ import type { MiddlewareHandler } from "hono";
2
+ import { HTTPException } from "hono/http-exception";
3
+ import type { HCaptchaSecretKeyType } from "./hcaptcha-secret-key.vo";
4
+ import type { MiddlewareHonoPort } from "./middleware-hono.port";
5
+ export declare const ShieldHcaptchaError: HTTPException;
6
+ export declare class ShieldHcaptchaHonoStrategy implements MiddlewareHonoPort {
7
+ private readonly strategy;
8
+ constructor(secretKey: HCaptchaSecretKeyType);
9
+ handle(): MiddlewareHandler;
10
+ }
11
+ //# sourceMappingURL=shield-hcaptcha-hono.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-hcaptcha-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-hcaptcha-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAGjE,eAAO,MAAM,mBAAmB,eAA4E,CAAC;AAE7G,qBAAa,0BAA2B,YAAW,kBAAkB;IACnE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAyB;gBAEtC,SAAS,EAAE,qBAAqB;IAI5C,MAAM,IAAI,iBAAiB;CAS5B"}
@@ -0,0 +1,19 @@
1
+ import { HTTPException } from "hono/http-exception";
2
+ import { ShieldHcaptchaStrategy, ShieldHcaptchaStrategyError } from "./shield-hcaptcha.strategy";
3
+ export const ShieldHcaptchaError = new HTTPException(403, { message: ShieldHcaptchaStrategyError.Rejected });
4
+ export class ShieldHcaptchaHonoStrategy {
5
+ strategy;
6
+ constructor(secretKey) {
7
+ this.strategy = new ShieldHcaptchaStrategy(secretKey);
8
+ }
9
+ handle() {
10
+ return async (c, next) => {
11
+ const form = await c.req.formData();
12
+ const token = form.get("h-captcha-response")?.toString();
13
+ if (await this.strategy.evaluate(token))
14
+ return next();
15
+ throw ShieldHcaptchaError;
16
+ };
17
+ }
18
+ }
19
+ //# sourceMappingURL=shield-hcaptcha-hono.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-hcaptcha-hono.strategy.js","sourceRoot":"","sources":["../src/shield-hcaptcha-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAGpD,OAAO,EAAE,sBAAsB,EAAE,2BAA2B,EAAE,MAAM,4BAA4B,CAAC;AAEjG,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,2BAA2B,CAAC,QAAQ,EAAE,CAAC,CAAC;AAE7G,MAAM,OAAO,0BAA0B;IACpB,QAAQ,CAAyB;IAElD,YAAY,SAAgC;QAC1C,IAAI,CAAC,QAAQ,GAAG,IAAI,sBAAsB,CAAC,SAAS,CAAC,CAAC;IACxD,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,IAAI,GAAG,MAAM,CAAC,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;YACpC,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,QAAQ,EAAE,CAAC;YAEzD,IAAI,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,KAAK,CAAC;gBAAE,OAAO,IAAI,EAAE,CAAC;YACvD,MAAM,mBAAmB,CAAC;QAC5B,CAAC,CAAC;IACJ,CAAC;CACF"}
@@ -1,11 +1,11 @@
1
- import { HTTPException } from "hono/http-exception";
2
1
  import type { HCaptchaSecretKeyType } from "./hcaptcha-secret-key.vo";
3
- import type { ShieldStrategy } from "./shield.strategy";
4
- export declare const ShieldHcaptchaError: HTTPException;
5
- export declare class ShieldHcaptchaStrategy implements ShieldStrategy {
2
+ export declare const ShieldHcaptchaStrategyError: {
3
+ Rejected: string;
4
+ };
5
+ export declare class ShieldHcaptchaStrategy {
6
6
  private readonly secretKey;
7
7
  private readonly hcaptcha;
8
8
  constructor(secretKey: HCaptchaSecretKeyType);
9
- verify: import("hono").MiddlewareHandler<any, string, {}, Response>;
9
+ evaluate(token: string | undefined): Promise<boolean>;
10
10
  }
11
11
  //# sourceMappingURL=shield-hcaptcha.strategy.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"shield-hcaptcha.strategy.d.ts","sourceRoot":"","sources":["../src/shield-hcaptcha.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAEpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AACtE,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAExD,eAAO,MAAM,mBAAmB,eAAyD,CAAC;AAE1F,qBAAa,sBAAuB,YAAW,cAAc;IAG/C,OAAO,CAAC,QAAQ,CAAC,SAAS;IAFtC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAyB;gBAErB,SAAS,EAAE,qBAAqB;IAE7D,MAAM,8DAWH;CACJ"}
1
+ {"version":3,"file":"shield-hcaptcha.strategy.d.ts","sourceRoot":"","sources":["../src/shield-hcaptcha.strategy.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,0BAA0B,CAAC;AAEtE,eAAO,MAAM,2BAA2B;;CAA2C,CAAC;AAEpF,qBAAa,sBAAsB;IAGrB,OAAO,CAAC,QAAQ,CAAC,SAAS;IAFtC,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAyB;gBAErB,SAAS,EAAE,qBAAqB;IAEvD,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,GAAG,OAAO,CAAC,OAAO,CAAC;CAS5D"}
@@ -1,25 +1,19 @@
1
- import { createMiddleware } from "hono/factory";
2
- import { HTTPException } from "hono/http-exception";
3
1
  import { HCaptchaService } from "./hcaptcha.service";
4
- export const ShieldHcaptchaError = new HTTPException(403, { message: "shield.hcaptcha" });
2
+ export const ShieldHcaptchaStrategyError = { Rejected: "shield.hcaptcha.rejected" };
5
3
  export class ShieldHcaptchaStrategy {
6
4
  secretKey;
7
5
  hcaptcha = new HCaptchaService();
8
6
  constructor(secretKey) {
9
7
  this.secretKey = secretKey;
10
8
  }
11
- verify = createMiddleware(async (context, next) => {
9
+ async evaluate(token) {
12
10
  try {
13
- const form = await context.req.formData();
14
- const hcaptchaTokenFormData = form.get("h-captcha-response")?.toString();
15
- const result = await this.hcaptcha.verify(this.secretKey, hcaptchaTokenFormData);
16
- if (!result.success)
17
- throw ShieldHcaptchaError;
18
- return next();
11
+ const result = await this.hcaptcha.verify(this.secretKey, token);
12
+ return result.success;
19
13
  }
20
14
  catch {
21
- throw ShieldHcaptchaError;
15
+ return false;
22
16
  }
23
- });
17
+ }
24
18
  }
25
19
  //# sourceMappingURL=shield-hcaptcha.strategy.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shield-hcaptcha.strategy.js","sourceRoot":"","sources":["../src/shield-hcaptcha.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAChD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAIrD,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE,EAAE,OAAO,EAAE,iBAAiB,EAAE,CAAC,CAAC;AAE1F,MAAM,OAAO,sBAAsB;IAGJ;IAFZ,QAAQ,GAAG,IAAI,eAAe,EAAE,CAAC;IAElD,YAA6B,SAAgC;QAAhC,cAAS,GAAT,SAAS,CAAuB;IAAG,CAAC;IAEjE,MAAM,GAAG,gBAAgB,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE;QAChD,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC;YAC1C,MAAM,qBAAqB,GAAG,IAAI,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,QAAQ,EAAE,CAAC;YACzE,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,qBAAqB,CAAC,CAAC;YAEjF,IAAI,CAAC,MAAM,CAAC,OAAO;gBAAE,MAAM,mBAAmB,CAAC;YAC/C,OAAO,IAAI,EAAE,CAAC;QAChB,CAAC;QAAC,MAAM,CAAC;YACP,MAAM,mBAAmB,CAAC;QAC5B,CAAC;IACH,CAAC,CAAC,CAAC;CACJ"}
1
+ {"version":3,"file":"shield-hcaptcha.strategy.js","sourceRoot":"","sources":["../src/shield-hcaptcha.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGrD,MAAM,CAAC,MAAM,2BAA2B,GAAG,EAAE,QAAQ,EAAE,0BAA0B,EAAE,CAAC;AAEpF,MAAM,OAAO,sBAAsB;IAGJ;IAFZ,QAAQ,GAAG,IAAI,eAAe,EAAE,CAAC;IAElD,YAA6B,SAAgC;QAAhC,cAAS,GAAT,SAAS,CAAuB;IAAG,CAAC;IAEjE,KAAK,CAAC,QAAQ,CAAC,KAAyB;QACtC,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;YAEjE,OAAO,MAAM,CAAC,OAAO,CAAC;QACxB,CAAC;QAAC,MAAM,CAAC;YACP,OAAO,KAAK,CAAC;QACf,CAAC;IACH,CAAC;CACF"}
@@ -0,0 +1,9 @@
1
+ import type { MiddlewareHandler } from "hono";
2
+ import type { MiddlewareHonoPort } from "./middleware-hono.port";
3
+ import { type ShieldMaintenanceConfig } from "./shield-maintenance.strategy";
4
+ export declare class ShieldMaintenanceHonoStrategy implements MiddlewareHonoPort {
5
+ private readonly strategy;
6
+ constructor(config?: ShieldMaintenanceConfig);
7
+ handle(): MiddlewareHandler;
8
+ }
9
+ //# sourceMappingURL=shield-maintenance-hono.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-maintenance-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-maintenance-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AACjE,OAAO,EAAE,KAAK,uBAAuB,EAA6B,MAAM,+BAA+B,CAAC;AAExG,qBAAa,6BAA8B,YAAW,kBAAkB;IACtE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA4B;gBAEzC,MAAM,CAAC,EAAE,uBAAuB;IAI5C,MAAM,IAAI,iBAAiB;CAW5B"}
@@ -0,0 +1,18 @@
1
+ import { ShieldMaintenanceStrategy } from "./shield-maintenance.strategy";
2
+ export class ShieldMaintenanceHonoStrategy {
3
+ strategy;
4
+ constructor(config) {
5
+ this.strategy = new ShieldMaintenanceStrategy(config);
6
+ }
7
+ handle() {
8
+ return async (c, next) => {
9
+ const maintenance = this.strategy.evaluate();
10
+ if (!maintenance.enabled)
11
+ return next();
12
+ return c.json({ reason: "maintenance" }, 503, {
13
+ "Retry-After": maintenance.RetryAfter.seconds.toString(),
14
+ });
15
+ };
16
+ }
17
+ }
18
+ //# sourceMappingURL=shield-maintenance-hono.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-maintenance-hono.strategy.js","sourceRoot":"","sources":["../src/shield-maintenance-hono.strategy.ts"],"names":[],"mappings":"AAEA,OAAO,EAAgC,yBAAyB,EAAE,MAAM,+BAA+B,CAAC;AAExG,MAAM,OAAO,6BAA6B;IACvB,QAAQ,CAA4B;IAErD,YAAY,MAAgC;QAC1C,IAAI,CAAC,QAAQ,GAAG,IAAI,yBAAyB,CAAC,MAAM,CAAC,CAAC;IACxD,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;YAE7C,IAAI,CAAC,WAAW,CAAC,OAAO;gBAAE,OAAO,IAAI,EAAE,CAAC;YAExC,OAAO,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE,GAAG,EAAE;gBAC5C,aAAa,EAAE,WAAW,CAAC,UAAU,CAAC,OAAO,CAAC,QAAQ,EAAE;aACzD,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;CACF"}
@@ -0,0 +1,15 @@
1
+ import * as tools from "@bgord/tools";
2
+ export type ShieldMaintenanceConfig = {
3
+ enabled: boolean;
4
+ RetryAfter?: tools.Duration;
5
+ };
6
+ export declare class ShieldMaintenanceStrategy {
7
+ private readonly enabled;
8
+ private readonly RetryAfter;
9
+ constructor(config?: ShieldMaintenanceConfig);
10
+ evaluate(): {
11
+ enabled: boolean;
12
+ RetryAfter: tools.Duration;
13
+ };
14
+ }
15
+ //# sourceMappingURL=shield-maintenance.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-maintenance.strategy.d.ts","sourceRoot":"","sources":["../src/shield-maintenance.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAEtC,MAAM,MAAM,uBAAuB,GAAG;IAAE,OAAO,EAAE,OAAO,CAAC;IAAC,UAAU,CAAC,EAAE,KAAK,CAAC,QAAQ,CAAA;CAAE,CAAC;AAExF,qBAAa,yBAAyB;IACpC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAU;IAClC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAiB;gBAEhC,MAAM,CAAC,EAAE,uBAAuB;IAK5C,QAAQ,IAAI;QAAE,OAAO,EAAE,OAAO,CAAC;QAAC,UAAU,EAAE,KAAK,CAAC,QAAQ,CAAA;KAAE;CAG7D"}
@@ -0,0 +1,13 @@
1
+ import * as tools from "@bgord/tools";
2
+ export class ShieldMaintenanceStrategy {
3
+ enabled;
4
+ RetryAfter;
5
+ constructor(config) {
6
+ this.enabled = config?.enabled ?? false;
7
+ this.RetryAfter = config?.RetryAfter ?? tools.Duration.Hours(1);
8
+ }
9
+ evaluate() {
10
+ return { enabled: this.enabled, RetryAfter: this.RetryAfter };
11
+ }
12
+ }
13
+ //# sourceMappingURL=shield-maintenance.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-maintenance.strategy.js","sourceRoot":"","sources":["../src/shield-maintenance.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,cAAc,CAAC;AAItC,MAAM,OAAO,yBAAyB;IACnB,OAAO,CAAU;IACjB,UAAU,CAAiB;IAE5C,YAAY,MAAgC;QAC1C,IAAI,CAAC,OAAO,GAAG,MAAM,EAAE,OAAO,IAAI,KAAK,CAAC;QACxC,IAAI,CAAC,UAAU,GAAG,MAAM,EAAE,UAAU,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAClE,CAAC;IAED,QAAQ;QACN,OAAO,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC;IAChE,CAAC;CACF"}
@@ -0,0 +1,18 @@
1
+ import type { MiddlewareHandler } from "hono";
2
+ import { HTTPException } from "hono/http-exception";
3
+ import type { CacheResolverStrategy } from "./cache-resolver.strategy";
4
+ import type { ClockPort } from "./clock.port";
5
+ import type { MiddlewareHonoPort } from "./middleware-hono.port";
6
+ import { type ShieldRateLimitConfig } from "./shield-rate-limit.strategy";
7
+ type Dependencies = {
8
+ Clock: ClockPort;
9
+ CacheResolver: CacheResolverStrategy;
10
+ };
11
+ export declare const ShieldRateLimitError: HTTPException;
12
+ export declare class ShieldRateLimitHonoStrategy implements MiddlewareHonoPort {
13
+ private readonly strategy;
14
+ constructor(config: ShieldRateLimitConfig, deps: Dependencies);
15
+ handle(): MiddlewareHandler;
16
+ }
17
+ export {};
18
+ //# sourceMappingURL=shield-rate-limit-hono.strategy.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-rate-limit-hono.strategy.d.ts","sourceRoot":"","sources":["../src/shield-rate-limit-hono.strategy.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AACvE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAC9C,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,wBAAwB,CAAC;AAEjE,OAAO,EACL,KAAK,qBAAqB,EAG3B,MAAM,8BAA8B,CAAC;AAEtC,KAAK,YAAY,GAAG;IAAE,KAAK,EAAE,SAAS,CAAC;IAAC,aAAa,EAAE,qBAAqB,CAAA;CAAE,CAAC;AAE/E,eAAO,MAAM,oBAAoB,eAE/B,CAAC;AAEH,qBAAa,2BAA4B,YAAW,kBAAkB;IACpE,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAA0B;gBAEvC,MAAM,EAAE,qBAAqB,EAAE,IAAI,EAAE,YAAY;IAI7D,MAAM,IAAI,iBAAiB;CAQ5B"}
@@ -0,0 +1,21 @@
1
+ import { HTTPException } from "hono/http-exception";
2
+ import { RequestContextHonoAdapter } from "./request-context-hono.adapter";
3
+ import { ShieldRateLimitStrategy, ShieldRateLimitStrategyError, } from "./shield-rate-limit.strategy";
4
+ export const ShieldRateLimitError = new HTTPException(429, {
5
+ message: ShieldRateLimitStrategyError.Rejected,
6
+ });
7
+ export class ShieldRateLimitHonoStrategy {
8
+ strategy;
9
+ constructor(config, deps) {
10
+ this.strategy = new ShieldRateLimitStrategy(config, deps);
11
+ }
12
+ handle() {
13
+ return async (c, next) => {
14
+ const context = new RequestContextHonoAdapter(c);
15
+ if (await this.strategy.evaluate(context))
16
+ return next();
17
+ throw ShieldRateLimitError;
18
+ };
19
+ }
20
+ }
21
+ //# sourceMappingURL=shield-rate-limit-hono.strategy.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shield-rate-limit-hono.strategy.js","sourceRoot":"","sources":["../src/shield-rate-limit-hono.strategy.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAIpD,OAAO,EAAE,yBAAyB,EAAE,MAAM,gCAAgC,CAAC;AAC3E,OAAO,EAEL,uBAAuB,EACvB,4BAA4B,GAC7B,MAAM,8BAA8B,CAAC;AAItC,MAAM,CAAC,MAAM,oBAAoB,GAAG,IAAI,aAAa,CAAC,GAAG,EAAE;IACzD,OAAO,EAAE,4BAA4B,CAAC,QAAQ;CAC/C,CAAC,CAAC;AAEH,MAAM,OAAO,2BAA2B;IACrB,QAAQ,CAA0B;IAEnD,YAAY,MAA6B,EAAE,IAAkB;QAC3D,IAAI,CAAC,QAAQ,GAAG,IAAI,uBAAuB,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;IAC5D,CAAC;IAED,MAAM;QACJ,OAAO,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE;YACvB,MAAM,OAAO,GAAG,IAAI,yBAAyB,CAAC,CAAC,CAAC,CAAC;YAEjD,IAAI,MAAM,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC;gBAAE,OAAO,IAAI,EAAE,CAAC;YACzD,MAAM,oBAAoB,CAAC;QAC7B,CAAC,CAAC;IACJ,CAAC;CACF"}