@daiso-tech/core 0.41.1 → 0.43.2

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 (1425) hide show
  1. package/README.md +18 -8
  2. package/dist/backoff-policies/_module-exports.d.ts +5 -4
  3. package/dist/backoff-policies/_module-exports.js +5 -4
  4. package/dist/backoff-policies/_module-exports.js.map +1 -1
  5. package/dist/backoff-policies/_module.d.ts +7 -0
  6. package/dist/backoff-policies/_module.js +8 -0
  7. package/dist/backoff-policies/_module.js.map +1 -0
  8. package/dist/backoff-policies/_shared.d.ts +8 -3
  9. package/dist/backoff-policies/_shared.js +57 -2
  10. package/dist/backoff-policies/_shared.js.map +1 -1
  11. package/dist/backoff-policies/backoffs-lua.d.ts +7 -0
  12. package/dist/backoff-policies/backoffs-lua.js +78 -0
  13. package/dist/backoff-policies/backoffs-lua.js.map +1 -0
  14. package/dist/backoff-policies/constant-backoff/_module.d.ts +1 -0
  15. package/dist/backoff-policies/constant-backoff/_module.js +2 -0
  16. package/dist/backoff-policies/constant-backoff/_module.js.map +1 -0
  17. package/dist/backoff-policies/constant-backoff/constant-backoff.d.ts +53 -0
  18. package/dist/backoff-policies/constant-backoff/constant-backoff.js +54 -0
  19. package/dist/backoff-policies/constant-backoff/constant-backoff.js.map +1 -0
  20. package/dist/backoff-policies/exponential-backoff/_module.d.ts +1 -0
  21. package/dist/backoff-policies/exponential-backoff/_module.js +2 -0
  22. package/dist/backoff-policies/exponential-backoff/_module.js.map +1 -0
  23. package/dist/backoff-policies/exponential-backoff/exponential-backoff.d.ts +68 -0
  24. package/dist/backoff-policies/exponential-backoff/exponential-backoff.js +59 -0
  25. package/dist/backoff-policies/exponential-backoff/exponential-backoff.js.map +1 -0
  26. package/dist/backoff-policies/linear-backoff/_module.d.ts +1 -0
  27. package/dist/backoff-policies/linear-backoff/_module.js +2 -0
  28. package/dist/backoff-policies/linear-backoff/_module.js.map +1 -0
  29. package/dist/backoff-policies/linear-backoff/linear-backoff.d.ts +63 -0
  30. package/dist/backoff-policies/linear-backoff/linear-backoff.js +57 -0
  31. package/dist/backoff-policies/linear-backoff/linear-backoff.js.map +1 -0
  32. package/dist/backoff-policies/polynomial-backoff/_module.d.ts +1 -0
  33. package/dist/backoff-policies/polynomial-backoff/_module.js +2 -0
  34. package/dist/backoff-policies/polynomial-backoff/_module.js.map +1 -0
  35. package/dist/backoff-policies/polynomial-backoff/polynomial-backoff.d.ts +68 -0
  36. package/dist/backoff-policies/polynomial-backoff/polynomial-backoff.js +59 -0
  37. package/dist/backoff-policies/polynomial-backoff/polynomial-backoff.js.map +1 -0
  38. package/dist/backoff-policies/types.d.ts +83 -0
  39. package/dist/backoff-policies/types.js +18 -0
  40. package/dist/backoff-policies/types.js.map +1 -0
  41. package/dist/cache/contracts/_module-exports.d.ts +5 -4
  42. package/dist/cache/contracts/_module-exports.js +0 -4
  43. package/dist/cache/contracts/_module-exports.js.map +1 -1
  44. package/dist/cache/contracts/_module.d.ts +7 -0
  45. package/dist/cache/contracts/_module.js +3 -0
  46. package/dist/cache/contracts/_module.js.map +1 -0
  47. package/dist/cache/contracts/cache-adapter.contract.d.ts +1 -1
  48. package/dist/cache/contracts/cache-adapter.contract.js +4 -1
  49. package/dist/cache/contracts/cache-adapter.contract.js.map +1 -1
  50. package/dist/cache/contracts/cache-factory.contract.d.ts +1 -1
  51. package/dist/cache/contracts/cache-factory.contract.js +2 -1
  52. package/dist/cache/contracts/cache-factory.contract.js.map +1 -1
  53. package/dist/cache/contracts/cache.contract.d.ts +79 -76
  54. package/dist/cache/contracts/cache.contract.js +10 -1
  55. package/dist/cache/contracts/cache.contract.js.map +1 -1
  56. package/dist/cache/contracts/cache.errors.d.ts +22 -0
  57. package/dist/cache/contracts/cache.errors.js +29 -0
  58. package/dist/cache/contracts/cache.errors.js.map +1 -1
  59. package/dist/cache/contracts/cache.events.d.ts +19 -22
  60. package/dist/cache/contracts/cache.events.js +8 -1
  61. package/dist/cache/contracts/cache.events.js.map +1 -1
  62. package/dist/cache/contracts/types.d.ts +18 -0
  63. package/dist/cache/contracts/types.js +7 -0
  64. package/dist/cache/contracts/types.js.map +1 -0
  65. package/dist/cache/implementations/adapters/{_module-exports.js → _module.js} +1 -1
  66. package/dist/cache/implementations/adapters/_module.js.map +1 -0
  67. package/dist/cache/implementations/adapters/kysely-cache-adapter/_module-exports.d.ts +1 -0
  68. package/dist/cache/implementations/adapters/kysely-cache-adapter/_module-exports.js +2 -0
  69. package/dist/cache/implementations/adapters/kysely-cache-adapter/_module-exports.js.map +1 -0
  70. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.d.ts +20 -13
  71. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js +16 -8
  72. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js.map +1 -1
  73. package/dist/cache/implementations/adapters/memory-cache-adapter/_module-exports.d.ts +1 -0
  74. package/dist/cache/implementations/adapters/memory-cache-adapter/_module-exports.js +2 -0
  75. package/dist/cache/implementations/adapters/memory-cache-adapter/_module-exports.js.map +1 -0
  76. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.d.ts +4 -4
  77. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js +4 -3
  78. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js.map +1 -1
  79. package/dist/cache/implementations/adapters/mongodb-cache-adapter/_module-exports.d.ts +1 -0
  80. package/dist/cache/implementations/adapters/mongodb-cache-adapter/_module-exports.js +2 -0
  81. package/dist/cache/implementations/adapters/mongodb-cache-adapter/_module-exports.js.map +1 -0
  82. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter-serde.d.ts +1 -1
  83. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter-serde.js +1 -1
  84. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter-serde.js.map +1 -1
  85. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.d.ts +10 -11
  86. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js +11 -8
  87. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js.map +1 -1
  88. package/dist/cache/implementations/adapters/no-op-cache-adapter/_module-exports.d.ts +1 -0
  89. package/dist/cache/implementations/adapters/no-op-cache-adapter/_module-exports.js +2 -0
  90. package/dist/cache/implementations/adapters/no-op-cache-adapter/_module-exports.js.map +1 -0
  91. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.d.ts +3 -3
  92. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js +3 -2
  93. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js.map +1 -1
  94. package/dist/cache/implementations/adapters/redis-cache-adapter/_module-exports.d.ts +1 -0
  95. package/dist/cache/implementations/adapters/redis-cache-adapter/_module-exports.js +2 -0
  96. package/dist/cache/implementations/adapters/redis-cache-adapter/_module-exports.js.map +1 -0
  97. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter-serde.d.ts +1 -1
  98. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter-serde.js +1 -1
  99. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter-serde.js.map +1 -1
  100. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.d.ts +7 -7
  101. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js +9 -5
  102. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js.map +1 -1
  103. package/dist/cache/implementations/adapters/redis-cache-adapter/utilities.js +1 -1
  104. package/dist/cache/implementations/adapters/redis-cache-adapter/utilities.js.map +1 -1
  105. package/dist/cache/implementations/derivables/_module.d.ts +2 -0
  106. package/dist/cache/implementations/derivables/_module.js +3 -0
  107. package/dist/cache/implementations/derivables/_module.js.map +1 -0
  108. package/dist/cache/implementations/derivables/cache/_module.d.ts +1 -0
  109. package/dist/cache/implementations/derivables/cache/_module.js +1 -0
  110. package/dist/cache/implementations/derivables/cache/_module.js.map +1 -1
  111. package/dist/cache/implementations/derivables/cache/cache.d.ts +53 -43
  112. package/dist/cache/implementations/derivables/cache/cache.js +148 -82
  113. package/dist/cache/implementations/derivables/cache/cache.js.map +1 -1
  114. package/dist/cache/implementations/derivables/cache/database-cache-adapter.d.ts +2 -2
  115. package/dist/cache/implementations/derivables/cache/database-cache-adapter.js +2 -1
  116. package/dist/cache/implementations/derivables/cache/database-cache-adapter.js.map +1 -1
  117. package/dist/cache/implementations/derivables/cache/is-database-cache-adapter.d.ts +2 -3
  118. package/dist/cache/implementations/derivables/cache/is-database-cache-adapter.js +9 -2
  119. package/dist/cache/implementations/derivables/cache/is-database-cache-adapter.js.map +1 -1
  120. package/dist/cache/implementations/derivables/cache/resolve-cache-adapter.d.ts +8 -0
  121. package/dist/cache/implementations/derivables/cache/resolve-cache-adapter.js +16 -0
  122. package/dist/cache/implementations/derivables/cache/resolve-cache-adapter.js.map +1 -0
  123. package/dist/cache/implementations/derivables/cache-factory/cache-factory.d.ts +14 -11
  124. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js +19 -6
  125. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js.map +1 -1
  126. package/dist/cache/implementations/test-utilities/_module.d.ts +3 -0
  127. package/dist/cache/implementations/test-utilities/_module.js +4 -0
  128. package/dist/cache/implementations/test-utilities/_module.js.map +1 -0
  129. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.d.ts +4 -4
  130. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js +6 -6
  131. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js.map +1 -1
  132. package/dist/cache/implementations/test-utilities/cache.test-suite.d.ts +7 -3
  133. package/dist/cache/implementations/test-utilities/cache.test-suite.js +1480 -608
  134. package/dist/cache/implementations/test-utilities/cache.test-suite.js.map +1 -1
  135. package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.d.ts +16 -9
  136. package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js +17 -10
  137. package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js.map +1 -1
  138. package/dist/circuit-breaker/contracts/_module-exports.d.ts +9 -0
  139. package/dist/circuit-breaker/contracts/_module-exports.js +6 -0
  140. package/dist/circuit-breaker/contracts/_module-exports.js.map +1 -0
  141. package/dist/circuit-breaker/contracts/_module.d.ts +9 -0
  142. package/dist/circuit-breaker/contracts/_module.js +6 -0
  143. package/dist/circuit-breaker/contracts/_module.js.map +1 -0
  144. package/dist/circuit-breaker/contracts/circuit-breaker-adapter.contract.d.ts +45 -0
  145. package/dist/circuit-breaker/contracts/circuit-breaker-adapter.contract.js +7 -0
  146. package/dist/circuit-breaker/contracts/circuit-breaker-adapter.contract.js.map +1 -0
  147. package/dist/circuit-breaker/contracts/circuit-breaker-policy.contract.d.ts +114 -0
  148. package/dist/circuit-breaker/contracts/circuit-breaker-policy.contract.js +41 -0
  149. package/dist/circuit-breaker/contracts/circuit-breaker-policy.contract.js.map +1 -0
  150. package/dist/circuit-breaker/contracts/circuit-breaker-provider-factory.contract.d.ts +19 -0
  151. package/dist/circuit-breaker/contracts/circuit-breaker-provider-factory.contract.js +10 -0
  152. package/dist/circuit-breaker/contracts/circuit-breaker-provider-factory.contract.js.map +1 -0
  153. package/dist/circuit-breaker/contracts/circuit-breaker-provider.contract.d.ts +63 -0
  154. package/dist/circuit-breaker/contracts/circuit-breaker-provider.contract.js +19 -0
  155. package/dist/circuit-breaker/contracts/circuit-breaker-provider.contract.js.map +1 -0
  156. package/dist/circuit-breaker/contracts/circuit-breaker-state.contract.d.ts +20 -0
  157. package/dist/circuit-breaker/contracts/circuit-breaker-state.contract.js +15 -0
  158. package/dist/circuit-breaker/contracts/circuit-breaker-state.contract.js.map +1 -0
  159. package/dist/circuit-breaker/contracts/circuit-breaker-storage-adapter.contract.d.ts +52 -0
  160. package/dist/circuit-breaker/contracts/circuit-breaker-storage-adapter.contract.js +5 -0
  161. package/dist/circuit-breaker/contracts/circuit-breaker-storage-adapter.contract.js.map +1 -0
  162. package/dist/circuit-breaker/contracts/circuit-breaker.contract.d.ts +40 -0
  163. package/dist/circuit-breaker/contracts/circuit-breaker.contract.js +9 -0
  164. package/dist/circuit-breaker/contracts/circuit-breaker.contract.js.map +1 -0
  165. package/dist/circuit-breaker/contracts/circuit-breaker.errors.d.ts +49 -0
  166. package/dist/circuit-breaker/contracts/circuit-breaker.errors.js +61 -0
  167. package/dist/circuit-breaker/contracts/circuit-breaker.errors.js.map +1 -0
  168. package/dist/circuit-breaker/contracts/circuit-breaker.events.d.ts +96 -0
  169. package/dist/circuit-breaker/contracts/circuit-breaker.events.js +20 -0
  170. package/dist/circuit-breaker/contracts/circuit-breaker.events.js.map +1 -0
  171. package/dist/circuit-breaker/implementations/adapters/_module.d.ts +7 -0
  172. package/dist/circuit-breaker/implementations/adapters/_module.js +8 -0
  173. package/dist/circuit-breaker/implementations/adapters/_module.js.map +1 -0
  174. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/_module-exports.d.ts +1 -0
  175. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/_module-exports.js +2 -0
  176. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/_module-exports.js.map +1 -0
  177. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/_module.d.ts +1 -0
  178. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/_module.js +2 -0
  179. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/_module.js.map +1 -0
  180. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-policy.d.ts +65 -0
  181. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-policy.js +128 -0
  182. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-policy.js.map +1 -0
  183. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-state-manager.d.ts +18 -0
  184. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-state-manager.js +57 -0
  185. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-state-manager.js.map +1 -0
  186. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-storage.d.ts +17 -0
  187. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-storage.js +40 -0
  188. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/circuit-breaker-storage.js.map +1 -0
  189. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/database-circuit-breaker-adapter.d.ts +59 -0
  190. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/database-circuit-breaker-adapter.js +57 -0
  191. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/database-circuit-breaker-adapter.js.map +1 -0
  192. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/types.d.ts +12 -0
  193. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/types.js +6 -0
  194. package/dist/circuit-breaker/implementations/adapters/database-circuit-breaker-adapter/types.js.map +1 -0
  195. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/_module-exports.d.ts +1 -0
  196. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/_module-exports.js +2 -0
  197. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/_module-exports.js.map +1 -0
  198. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/_module.d.ts +1 -0
  199. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/_module.js +2 -0
  200. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/_module.js.map +1 -0
  201. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/kysely-circuit-breaker-storage-adapter.d.ts +81 -0
  202. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/kysely-circuit-breaker-storage-adapter.js +149 -0
  203. package/dist/circuit-breaker/implementations/adapters/kysely-circuit-breaker-storage-adapter/kysely-circuit-breaker-storage-adapter.js.map +1 -0
  204. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/_module-exports.d.ts +1 -0
  205. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/_module-exports.js +2 -0
  206. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/_module-exports.js.map +1 -0
  207. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/_module.d.ts +1 -0
  208. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/_module.js +2 -0
  209. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/_module.js.map +1 -0
  210. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/memory-circuit-breaker-storage-adapter.d.ts +42 -0
  211. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/memory-circuit-breaker-storage-adapter.js +60 -0
  212. package/dist/circuit-breaker/implementations/adapters/memory-circuit-breaker-storage-adapter/memory-circuit-breaker-storage-adapter.js.map +1 -0
  213. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/_module-exports.d.ts +1 -0
  214. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/_module-exports.js +2 -0
  215. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/_module-exports.js.map +1 -0
  216. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/_module.d.ts +1 -0
  217. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/_module.js +2 -0
  218. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/_module.js.map +1 -0
  219. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/mongodb-circuit-breaker-storage-adapter.d.ts +80 -0
  220. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/mongodb-circuit-breaker-storage-adapter.js +115 -0
  221. package/dist/circuit-breaker/implementations/adapters/mongodb-circuit-breaker-storage-adapter/mongodb-circuit-breaker-storage-adapter.js.map +1 -0
  222. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/_module-exports.d.ts +1 -0
  223. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/_module-exports.js +2 -0
  224. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/_module-exports.js.map +1 -0
  225. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/_module.d.ts +1 -0
  226. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/_module.js +2 -0
  227. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/_module.js.map +1 -0
  228. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/no-op-circuit-breaker-adapter.d.ts +16 -0
  229. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/no-op-circuit-breaker-adapter.js +32 -0
  230. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-adapter/no-op-circuit-breaker-adapter.js.map +1 -0
  231. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/_module-exports.d.ts +1 -0
  232. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/_module-exports.js +2 -0
  233. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/_module-exports.js.map +1 -0
  234. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/_module.d.ts +1 -0
  235. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/_module.js +2 -0
  236. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/_module.js.map +1 -0
  237. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/no-op-circuit-breaker-storage-adapter.d.ts +16 -0
  238. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/no-op-circuit-breaker-storage-adapter.js +24 -0
  239. package/dist/circuit-breaker/implementations/adapters/no-op-circuit-breaker-storage-adapter/no-op-circuit-breaker-storage-adapter.js.map +1 -0
  240. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/_module-exports.d.ts +1 -0
  241. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/_module-exports.js +2 -0
  242. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/_module-exports.js.map +1 -0
  243. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/_module.d.ts +1 -0
  244. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/_module.js +2 -0
  245. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/_module.js.map +1 -0
  246. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/_module.d.ts +1 -0
  247. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/_module.js +2 -0
  248. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/_module.js.map +1 -0
  249. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-factory-lua.d.ts +4 -0
  250. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-factory-lua.js +76 -0
  251. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-factory-lua.js.map +1 -0
  252. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-lua.d.ts +7 -0
  253. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-lua.js +34 -0
  254. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-lua.js.map +1 -0
  255. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-policy-lua.d.ts +7 -0
  256. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-policy-lua.js +144 -0
  257. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-policy-lua.js.map +1 -0
  258. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-state-manager-lua.d.ts +7 -0
  259. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-state-manager-lua.js +64 -0
  260. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-state-manager-lua.js.map +1 -0
  261. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-storage-lua.d.ts +7 -0
  262. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-storage-lua.js +39 -0
  263. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/circuit-breaker-storage-lua.js.map +1 -0
  264. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/consecutive-breaker-lua.d.ts +7 -0
  265. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/consecutive-breaker-lua.js +75 -0
  266. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/consecutive-breaker-lua.js.map +1 -0
  267. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/count-breaker-lua.d.ts +7 -0
  268. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/count-breaker-lua.js +136 -0
  269. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/count-breaker-lua.js.map +1 -0
  270. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/sampling-breaker-lua.d.ts +7 -0
  271. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/sampling-breaker-lua.js +153 -0
  272. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/lua/sampling-breaker-lua.js.map +1 -0
  273. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/redis-circuit-breaker-adapter.d.ts +68 -0
  274. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/redis-circuit-breaker-adapter.js +131 -0
  275. package/dist/circuit-breaker/implementations/adapters/redis-circuit-breaker-adapter/redis-circuit-breaker-adapter.js.map +1 -0
  276. package/dist/circuit-breaker/implementations/derivables/_module-exports.d.ts +2 -0
  277. package/dist/circuit-breaker/implementations/derivables/_module-exports.js +3 -0
  278. package/dist/circuit-breaker/implementations/derivables/_module-exports.js.map +1 -0
  279. package/dist/circuit-breaker/implementations/derivables/_module.d.ts +2 -0
  280. package/dist/circuit-breaker/implementations/derivables/_module.js +3 -0
  281. package/dist/circuit-breaker/implementations/derivables/_module.js.map +1 -0
  282. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/_module.d.ts +1 -0
  283. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/_module.js +2 -0
  284. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/_module.js.map +1 -0
  285. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-provider.d.ts +154 -0
  286. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-provider.js +138 -0
  287. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-provider.js.map +1 -0
  288. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-serde-transformer.d.ts +41 -0
  289. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-serde-transformer.js +77 -0
  290. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-serde-transformer.js.map +1 -0
  291. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker.d.ts +62 -0
  292. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker.js +201 -0
  293. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker.js.map +1 -0
  294. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/_module.d.ts +2 -0
  295. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/_module.js +3 -0
  296. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/_module.js.map +1 -0
  297. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/circuit-breaker-provider-factory.d.ts +108 -0
  298. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/circuit-breaker-provider-factory.js +140 -0
  299. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/circuit-breaker-provider-factory.js.map +1 -0
  300. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/database-circuit-breaker-provider-factory.d.ts +137 -0
  301. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/database-circuit-breaker-provider-factory.js +164 -0
  302. package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/database-circuit-breaker-provider-factory.js.map +1 -0
  303. package/dist/circuit-breaker/implementations/policies/_module-exports.d.ts +5 -0
  304. package/dist/circuit-breaker/implementations/policies/_module-exports.js +6 -0
  305. package/dist/circuit-breaker/implementations/policies/_module-exports.js.map +1 -0
  306. package/dist/circuit-breaker/implementations/policies/_module.d.ts +5 -0
  307. package/dist/circuit-breaker/implementations/policies/_module.js +6 -0
  308. package/dist/circuit-breaker/implementations/policies/_module.js.map +1 -0
  309. package/dist/circuit-breaker/implementations/policies/_shared.d.ts +12 -0
  310. package/dist/circuit-breaker/implementations/policies/_shared.js +50 -0
  311. package/dist/circuit-breaker/implementations/policies/_shared.js.map +1 -0
  312. package/dist/circuit-breaker/implementations/policies/consecutive-breaker/_module.d.ts +1 -0
  313. package/dist/circuit-breaker/implementations/policies/consecutive-breaker/_module.js +2 -0
  314. package/dist/circuit-breaker/implementations/policies/consecutive-breaker/_module.js.map +1 -0
  315. package/dist/circuit-breaker/implementations/policies/consecutive-breaker/consecutive-breaker.d.ts +51 -0
  316. package/dist/circuit-breaker/implementations/policies/consecutive-breaker/consecutive-breaker.js +85 -0
  317. package/dist/circuit-breaker/implementations/policies/consecutive-breaker/consecutive-breaker.js.map +1 -0
  318. package/dist/circuit-breaker/implementations/policies/count-breaker/_module.d.ts +1 -0
  319. package/dist/circuit-breaker/implementations/policies/count-breaker/_module.js +2 -0
  320. package/dist/circuit-breaker/implementations/policies/count-breaker/_module.js.map +1 -0
  321. package/dist/circuit-breaker/implementations/policies/count-breaker/count-breaker.d.ts +74 -0
  322. package/dist/circuit-breaker/implementations/policies/count-breaker/count-breaker.js +130 -0
  323. package/dist/circuit-breaker/implementations/policies/count-breaker/count-breaker.js.map +1 -0
  324. package/dist/circuit-breaker/implementations/policies/sampling-breaker/_module.d.ts +1 -0
  325. package/dist/circuit-breaker/implementations/policies/sampling-breaker/_module.js +2 -0
  326. package/dist/circuit-breaker/implementations/policies/sampling-breaker/_module.js.map +1 -0
  327. package/dist/circuit-breaker/implementations/policies/sampling-breaker/sampling-breaker.d.ts +112 -0
  328. package/dist/circuit-breaker/implementations/policies/sampling-breaker/sampling-breaker.js +159 -0
  329. package/dist/circuit-breaker/implementations/policies/sampling-breaker/sampling-breaker.js.map +1 -0
  330. package/dist/circuit-breaker/implementations/policies/types.d.ts +51 -0
  331. package/dist/circuit-breaker/implementations/policies/types.js +16 -0
  332. package/dist/circuit-breaker/implementations/policies/types.js.map +1 -0
  333. package/dist/circuit-breaker/implementations/test-utilities/_module-exports.d.ts +4 -0
  334. package/dist/circuit-breaker/implementations/test-utilities/_module-exports.js +5 -0
  335. package/dist/circuit-breaker/implementations/test-utilities/_module-exports.js.map +1 -0
  336. package/dist/circuit-breaker/implementations/test-utilities/_module.d.ts +4 -0
  337. package/dist/circuit-breaker/implementations/test-utilities/_module.js +5 -0
  338. package/dist/circuit-breaker/implementations/test-utilities/_module.js.map +1 -0
  339. package/dist/circuit-breaker/implementations/test-utilities/circuit-breaker-storage-adapter.test-suite.d.ts +45 -0
  340. package/dist/circuit-breaker/implementations/test-utilities/circuit-breaker-storage-adapter.test-suite.js +110 -0
  341. package/dist/circuit-breaker/implementations/test-utilities/circuit-breaker-storage-adapter.test-suite.js.map +1 -0
  342. package/dist/circuit-breaker/implementations/test-utilities/consecutive-breaker.test-suite.d.ts +60 -0
  343. package/dist/circuit-breaker/implementations/test-utilities/consecutive-breaker.test-suite.js +453 -0
  344. package/dist/circuit-breaker/implementations/test-utilities/consecutive-breaker.test-suite.js.map +1 -0
  345. package/dist/circuit-breaker/implementations/test-utilities/count-breaker.test-suite.d.ts +60 -0
  346. package/dist/circuit-breaker/implementations/test-utilities/count-breaker.test-suite.js +703 -0
  347. package/dist/circuit-breaker/implementations/test-utilities/count-breaker.test-suite.js.map +1 -0
  348. package/dist/circuit-breaker/implementations/test-utilities/sampling-breaker.test-suite.d.ts +60 -0
  349. package/dist/circuit-breaker/implementations/test-utilities/sampling-breaker.test-suite.js +94 -0
  350. package/dist/circuit-breaker/implementations/test-utilities/sampling-breaker.test-suite.js.map +1 -0
  351. package/dist/collection/contracts/_module-exports.d.ts +3 -3
  352. package/dist/collection/contracts/_module-exports.js +0 -3
  353. package/dist/collection/contracts/_module-exports.js.map +1 -1
  354. package/dist/collection/contracts/_module.d.ts +4 -0
  355. package/dist/collection/contracts/_module.js +2 -0
  356. package/dist/collection/contracts/_module.js.map +1 -0
  357. package/dist/collection/contracts/_shared/_module.d.ts +11 -11
  358. package/dist/collection/contracts/_shared/_module.js +1 -11
  359. package/dist/collection/contracts/_shared/_module.js.map +1 -1
  360. package/dist/collection/contracts/_shared/compartor.type.d.ts +1 -1
  361. package/dist/collection/contracts/_shared/compartor.type.js +1 -1
  362. package/dist/collection/contracts/_shared/compartor.type.js.map +1 -1
  363. package/dist/collection/contracts/_shared/foreach.type.d.ts +1 -1
  364. package/dist/collection/contracts/_shared/foreach.type.js +1 -1
  365. package/dist/collection/contracts/_shared/foreach.type.js.map +1 -1
  366. package/dist/collection/contracts/_shared/map.type.d.ts +1 -1
  367. package/dist/collection/contracts/_shared/map.type.js +1 -1
  368. package/dist/collection/contracts/_shared/map.type.js.map +1 -1
  369. package/dist/collection/contracts/_shared/modifier.type.d.ts +1 -1
  370. package/dist/collection/contracts/_shared/modifier.type.js +1 -1
  371. package/dist/collection/contracts/_shared/modifier.type.js.map +1 -1
  372. package/dist/collection/contracts/_shared/predicate.type.d.ts +1 -1
  373. package/dist/collection/contracts/_shared/predicate.type.js +1 -1
  374. package/dist/collection/contracts/_shared/predicate.type.js.map +1 -1
  375. package/dist/collection/contracts/_shared/reduce.type.d.ts +1 -1
  376. package/dist/collection/contracts/_shared/reduce.type.js +1 -1
  377. package/dist/collection/contracts/_shared/reduce.type.js.map +1 -1
  378. package/dist/collection/contracts/_shared/tap.type.d.ts +1 -1
  379. package/dist/collection/contracts/_shared/tap.type.js +1 -1
  380. package/dist/collection/contracts/_shared/tap.type.js.map +1 -1
  381. package/dist/collection/contracts/_shared/transform.type.d.ts +1 -1
  382. package/dist/collection/contracts/_shared/transform.type.js +1 -1
  383. package/dist/collection/contracts/_shared/transform.type.js.map +1 -1
  384. package/dist/collection/contracts/async-collection.contract.d.ts +54 -54
  385. package/dist/collection/contracts/async-collection.contract.js +5 -1
  386. package/dist/collection/contracts/async-collection.contract.js.map +1 -1
  387. package/dist/collection/contracts/collection.contract.d.ts +12 -12
  388. package/dist/collection/contracts/collection.contract.js +5 -1
  389. package/dist/collection/contracts/collection.contract.js.map +1 -1
  390. package/dist/collection/contracts/collection.errors.d.ts +18 -10
  391. package/dist/collection/contracts/collection.errors.js +24 -13
  392. package/dist/collection/contracts/collection.errors.js.map +1 -1
  393. package/dist/collection/implementations/_module.d.ts +4 -0
  394. package/dist/collection/implementations/_module.js +5 -0
  395. package/dist/collection/implementations/_module.js.map +1 -0
  396. package/dist/collection/implementations/_shared.d.ts +0 -23
  397. package/dist/collection/implementations/_shared.js +0 -41
  398. package/dist/collection/implementations/_shared.js.map +1 -1
  399. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.d.ts +2 -2
  400. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js +2 -2
  401. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-iterable.js.map +1 -1
  402. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.d.ts +2 -2
  403. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js +2 -2
  404. package/dist/collection/implementations/async-iterable-collection/_shared/async-chunk-while-iterable.js.map +1 -1
  405. package/dist/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.d.ts +1 -1
  406. package/dist/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js +2 -2
  407. package/dist/collection/implementations/async-iterable-collection/_shared/async-collapse-iterable.js.map +1 -1
  408. package/dist/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.d.ts +1 -1
  409. package/dist/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js +2 -2
  410. package/dist/collection/implementations/async-iterable-collection/_shared/async-count-by-iterable.js.map +1 -1
  411. package/dist/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.d.ts +2 -3
  412. package/dist/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js +3 -4
  413. package/dist/collection/implementations/async-iterable-collection/_shared/async-cross-join-iterable.js.map +1 -1
  414. package/dist/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.d.ts +1 -1
  415. package/dist/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js +2 -2
  416. package/dist/collection/implementations/async-iterable-collection/_shared/async-entries-iterable.js.map +1 -1
  417. package/dist/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.d.ts +1 -1
  418. package/dist/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js +2 -2
  419. package/dist/collection/implementations/async-iterable-collection/_shared/async-filter-iterable.js.map +1 -1
  420. package/dist/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.d.ts +1 -1
  421. package/dist/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js +2 -2
  422. package/dist/collection/implementations/async-iterable-collection/_shared/async-flat-map-iterable.js.map +1 -1
  423. package/dist/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.d.ts +2 -2
  424. package/dist/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js +2 -2
  425. package/dist/collection/implementations/async-iterable-collection/_shared/async-group-by-iterable.js.map +1 -1
  426. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.d.ts +2 -2
  427. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js +3 -3
  428. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-after-iterable.js.map +1 -1
  429. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.d.ts +2 -2
  430. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js +3 -3
  431. package/dist/collection/implementations/async-iterable-collection/_shared/async-insert-before-iterable.js.map +1 -1
  432. package/dist/collection/implementations/async-iterable-collection/_shared/async-map-iterable.d.ts +1 -1
  433. package/dist/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js +2 -2
  434. package/dist/collection/implementations/async-iterable-collection/_shared/async-map-iterable.js.map +1 -1
  435. package/dist/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.d.ts +1 -1
  436. package/dist/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js +4 -5
  437. package/dist/collection/implementations/async-iterable-collection/_shared/async-merge-iterable.js.map +1 -1
  438. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.d.ts +2 -2
  439. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js +2 -2
  440. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-end-iterable.js.map +1 -1
  441. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.d.ts +2 -2
  442. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js +2 -2
  443. package/dist/collection/implementations/async-iterable-collection/_shared/async-pad-start-iterable.js.map +1 -1
  444. package/dist/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.d.ts +2 -2
  445. package/dist/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js +2 -2
  446. package/dist/collection/implementations/async-iterable-collection/_shared/async-partion-iterable.js.map +1 -1
  447. package/dist/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.d.ts +2 -2
  448. package/dist/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js +2 -2
  449. package/dist/collection/implementations/async-iterable-collection/_shared/async-repeat-iterable.js.map +1 -1
  450. package/dist/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.d.ts +2 -2
  451. package/dist/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js +2 -2
  452. package/dist/collection/implementations/async-iterable-collection/_shared/async-reverse-iterable.js.map +1 -1
  453. package/dist/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.d.ts +1 -1
  454. package/dist/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js +1 -1
  455. package/dist/collection/implementations/async-iterable-collection/_shared/async-shuffle-iterable.js.map +1 -1
  456. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.d.ts +1 -1
  457. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js +1 -1
  458. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-iterable.js.map +1 -1
  459. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.d.ts +1 -1
  460. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js +2 -2
  461. package/dist/collection/implementations/async-iterable-collection/_shared/async-skip-until-iterable.js.map +1 -1
  462. package/dist/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.d.ts +1 -1
  463. package/dist/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js +1 -1
  464. package/dist/collection/implementations/async-iterable-collection/_shared/async-slice-iterable.js.map +1 -1
  465. package/dist/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.d.ts +1 -1
  466. package/dist/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js +1 -1
  467. package/dist/collection/implementations/async-iterable-collection/_shared/async-sliding-iterable.js.map +1 -1
  468. package/dist/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.d.ts +1 -1
  469. package/dist/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js +2 -2
  470. package/dist/collection/implementations/async-iterable-collection/_shared/async-sort-iterable.js.map +1 -1
  471. package/dist/collection/implementations/async-iterable-collection/_shared/async-split-iterable.d.ts +2 -2
  472. package/dist/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js +2 -2
  473. package/dist/collection/implementations/async-iterable-collection/_shared/async-split-iterable.js.map +1 -1
  474. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-iterable.d.ts +1 -1
  475. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js +1 -1
  476. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-iterable.js.map +1 -1
  477. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.d.ts +1 -1
  478. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js +2 -2
  479. package/dist/collection/implementations/async-iterable-collection/_shared/async-take-until-iterable.js.map +1 -1
  480. package/dist/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.d.ts +1 -1
  481. package/dist/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js +2 -2
  482. package/dist/collection/implementations/async-iterable-collection/_shared/async-tap-iterable.js.map +1 -1
  483. package/dist/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.d.ts +1 -1
  484. package/dist/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js +2 -2
  485. package/dist/collection/implementations/async-iterable-collection/_shared/async-unique-iterable.js.map +1 -1
  486. package/dist/collection/implementations/async-iterable-collection/_shared/async-update-iterable.d.ts +1 -1
  487. package/dist/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js +2 -2
  488. package/dist/collection/implementations/async-iterable-collection/_shared/async-update-iterable.js.map +1 -1
  489. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.d.ts +1 -1
  490. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.js +4 -0
  491. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.js.map +1 -1
  492. package/dist/collection/implementations/async-iterable-collection/_shared/async-when-iterable.d.ts +1 -1
  493. package/dist/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js +2 -2
  494. package/dist/collection/implementations/async-iterable-collection/_shared/async-when-iterable.js.map +1 -1
  495. package/dist/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.d.ts +1 -1
  496. package/dist/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js +3 -16
  497. package/dist/collection/implementations/async-iterable-collection/_shared/async-zip-iterable.js.map +1 -1
  498. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.d.ts +43 -44
  499. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js +32 -32
  500. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js.map +1 -1
  501. package/dist/collection/implementations/iterable-collection/_shared/chunk-iterable.d.ts +1 -1
  502. package/dist/collection/implementations/iterable-collection/_shared/chunk-iterable.js +1 -1
  503. package/dist/collection/implementations/iterable-collection/_shared/chunk-iterable.js.map +1 -1
  504. package/dist/collection/implementations/iterable-collection/_shared/chunk-while-iterable.d.ts +1 -1
  505. package/dist/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js +2 -2
  506. package/dist/collection/implementations/iterable-collection/_shared/chunk-while-iterable.js.map +1 -1
  507. package/dist/collection/implementations/iterable-collection/_shared/collapse-iterable.d.ts +1 -1
  508. package/dist/collection/implementations/iterable-collection/_shared/collapse-iterable.js +2 -2
  509. package/dist/collection/implementations/iterable-collection/_shared/collapse-iterable.js.map +1 -1
  510. package/dist/collection/implementations/iterable-collection/_shared/count-by-iterable.d.ts +1 -1
  511. package/dist/collection/implementations/iterable-collection/_shared/count-by-iterable.js +2 -2
  512. package/dist/collection/implementations/iterable-collection/_shared/count-by-iterable.js.map +1 -1
  513. package/dist/collection/implementations/iterable-collection/_shared/cross-join-iterable.d.ts +1 -1
  514. package/dist/collection/implementations/iterable-collection/_shared/cross-join-iterable.js +2 -1
  515. package/dist/collection/implementations/iterable-collection/_shared/cross-join-iterable.js.map +1 -1
  516. package/dist/collection/implementations/iterable-collection/_shared/filter-iterable.d.ts +1 -1
  517. package/dist/collection/implementations/iterable-collection/_shared/filter-iterable.js +2 -2
  518. package/dist/collection/implementations/iterable-collection/_shared/filter-iterable.js.map +1 -1
  519. package/dist/collection/implementations/iterable-collection/_shared/flat-map-iterable.d.ts +1 -1
  520. package/dist/collection/implementations/iterable-collection/_shared/flat-map-iterable.js +2 -2
  521. package/dist/collection/implementations/iterable-collection/_shared/flat-map-iterable.js.map +1 -1
  522. package/dist/collection/implementations/iterable-collection/_shared/group-by-iterable.d.ts +1 -1
  523. package/dist/collection/implementations/iterable-collection/_shared/group-by-iterable.js +2 -2
  524. package/dist/collection/implementations/iterable-collection/_shared/group-by-iterable.js.map +1 -1
  525. package/dist/collection/implementations/iterable-collection/_shared/insert-after-iterable.d.ts +1 -1
  526. package/dist/collection/implementations/iterable-collection/_shared/insert-after-iterable.js +2 -2
  527. package/dist/collection/implementations/iterable-collection/_shared/insert-after-iterable.js.map +1 -1
  528. package/dist/collection/implementations/iterable-collection/_shared/insert-before-iterable.d.ts +1 -1
  529. package/dist/collection/implementations/iterable-collection/_shared/insert-before-iterable.js +2 -2
  530. package/dist/collection/implementations/iterable-collection/_shared/insert-before-iterable.js.map +1 -1
  531. package/dist/collection/implementations/iterable-collection/_shared/map-iterable.d.ts +1 -1
  532. package/dist/collection/implementations/iterable-collection/_shared/map-iterable.js +2 -2
  533. package/dist/collection/implementations/iterable-collection/_shared/map-iterable.js.map +1 -1
  534. package/dist/collection/implementations/iterable-collection/_shared/merge-iterable.d.ts +2 -1
  535. package/dist/collection/implementations/iterable-collection/_shared/merge-iterable.js +3 -2
  536. package/dist/collection/implementations/iterable-collection/_shared/merge-iterable.js.map +1 -1
  537. package/dist/collection/implementations/iterable-collection/_shared/pad-end-iterable.d.ts +1 -1
  538. package/dist/collection/implementations/iterable-collection/_shared/pad-end-iterable.js +1 -1
  539. package/dist/collection/implementations/iterable-collection/_shared/pad-end-iterable.js.map +1 -1
  540. package/dist/collection/implementations/iterable-collection/_shared/pad-start-iterable.d.ts +1 -1
  541. package/dist/collection/implementations/iterable-collection/_shared/pad-start-iterable.js +1 -1
  542. package/dist/collection/implementations/iterable-collection/_shared/pad-start-iterable.js.map +1 -1
  543. package/dist/collection/implementations/iterable-collection/_shared/partion-iterable.d.ts +1 -1
  544. package/dist/collection/implementations/iterable-collection/_shared/partion-iterable.js +2 -2
  545. package/dist/collection/implementations/iterable-collection/_shared/partion-iterable.js.map +1 -1
  546. package/dist/collection/implementations/iterable-collection/_shared/repeat-iterable.d.ts +1 -1
  547. package/dist/collection/implementations/iterable-collection/_shared/repeat-iterable.js +1 -1
  548. package/dist/collection/implementations/iterable-collection/_shared/repeat-iterable.js.map +1 -1
  549. package/dist/collection/implementations/iterable-collection/_shared/reverse-iterable.d.ts +1 -1
  550. package/dist/collection/implementations/iterable-collection/_shared/reverse-iterable.js +1 -1
  551. package/dist/collection/implementations/iterable-collection/_shared/reverse-iterable.js.map +1 -1
  552. package/dist/collection/implementations/iterable-collection/_shared/skip-iterable.d.ts +1 -1
  553. package/dist/collection/implementations/iterable-collection/_shared/skip-iterable.js +1 -1
  554. package/dist/collection/implementations/iterable-collection/_shared/skip-iterable.js.map +1 -1
  555. package/dist/collection/implementations/iterable-collection/_shared/skip-until-iterable.d.ts +1 -1
  556. package/dist/collection/implementations/iterable-collection/_shared/skip-until-iterable.js +2 -2
  557. package/dist/collection/implementations/iterable-collection/_shared/skip-until-iterable.js.map +1 -1
  558. package/dist/collection/implementations/iterable-collection/_shared/slice-iterable.d.ts +1 -1
  559. package/dist/collection/implementations/iterable-collection/_shared/slice-iterable.js +1 -1
  560. package/dist/collection/implementations/iterable-collection/_shared/slice-iterable.js.map +1 -1
  561. package/dist/collection/implementations/iterable-collection/_shared/sliding-iterable.d.ts +1 -1
  562. package/dist/collection/implementations/iterable-collection/_shared/sliding-iterable.js +1 -1
  563. package/dist/collection/implementations/iterable-collection/_shared/sliding-iterable.js.map +1 -1
  564. package/dist/collection/implementations/iterable-collection/_shared/sort-iterable.d.ts +1 -1
  565. package/dist/collection/implementations/iterable-collection/_shared/sort-iterable.js +2 -2
  566. package/dist/collection/implementations/iterable-collection/_shared/sort-iterable.js.map +1 -1
  567. package/dist/collection/implementations/iterable-collection/_shared/split-iterable.d.ts +1 -1
  568. package/dist/collection/implementations/iterable-collection/_shared/split-iterable.js +1 -1
  569. package/dist/collection/implementations/iterable-collection/_shared/split-iterable.js.map +1 -1
  570. package/dist/collection/implementations/iterable-collection/_shared/take-iterable.d.ts +1 -1
  571. package/dist/collection/implementations/iterable-collection/_shared/take-iterable.js +1 -1
  572. package/dist/collection/implementations/iterable-collection/_shared/take-iterable.js.map +1 -1
  573. package/dist/collection/implementations/iterable-collection/_shared/take-until-iterable.d.ts +1 -1
  574. package/dist/collection/implementations/iterable-collection/_shared/take-until-iterable.js +2 -2
  575. package/dist/collection/implementations/iterable-collection/_shared/take-until-iterable.js.map +1 -1
  576. package/dist/collection/implementations/iterable-collection/_shared/tap-iterable.d.ts +1 -1
  577. package/dist/collection/implementations/iterable-collection/_shared/tap-iterable.js +2 -2
  578. package/dist/collection/implementations/iterable-collection/_shared/tap-iterable.js.map +1 -1
  579. package/dist/collection/implementations/iterable-collection/_shared/unique-iterable.d.ts +1 -1
  580. package/dist/collection/implementations/iterable-collection/_shared/unique-iterable.js +2 -2
  581. package/dist/collection/implementations/iterable-collection/_shared/unique-iterable.js.map +1 -1
  582. package/dist/collection/implementations/iterable-collection/_shared/update-iterable.d.ts +1 -1
  583. package/dist/collection/implementations/iterable-collection/_shared/update-iterable.js +2 -2
  584. package/dist/collection/implementations/iterable-collection/_shared/update-iterable.js.map +1 -1
  585. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.d.ts +4 -1
  586. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.js +2 -1
  587. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.js.map +1 -1
  588. package/dist/collection/implementations/iterable-collection/_shared/when-iterable.d.ts +1 -1
  589. package/dist/collection/implementations/iterable-collection/_shared/when-iterable.js +2 -2
  590. package/dist/collection/implementations/iterable-collection/_shared/when-iterable.js.map +1 -1
  591. package/dist/collection/implementations/iterable-collection/iterable-collection.d.ts +17 -18
  592. package/dist/collection/implementations/iterable-collection/iterable-collection.js +39 -40
  593. package/dist/collection/implementations/iterable-collection/iterable-collection.js.map +1 -1
  594. package/dist/collection/implementations/list-collection/list-collection.d.ts +16 -17
  595. package/dist/collection/implementations/list-collection/list-collection.js +45 -41
  596. package/dist/collection/implementations/list-collection/list-collection.js.map +1 -1
  597. package/dist/event-bus/contracts/_module-exports.d.ts +3 -3
  598. package/dist/event-bus/contracts/_module-exports.js +1 -3
  599. package/dist/event-bus/contracts/_module-exports.js.map +1 -1
  600. package/dist/event-bus/contracts/_module.d.ts +3 -0
  601. package/dist/event-bus/contracts/_module.js +2 -0
  602. package/dist/event-bus/contracts/_module.js.map +1 -0
  603. package/dist/event-bus/contracts/event-bus-adapter.contract.d.ts +21 -8
  604. package/dist/event-bus/contracts/event-bus-adapter.contract.js +1 -1
  605. package/dist/event-bus/contracts/event-bus-adapter.contract.js.map +1 -1
  606. package/dist/event-bus/contracts/event-bus-factory.contract.d.ts +1 -1
  607. package/dist/event-bus/contracts/event-bus-factory.contract.js +2 -1
  608. package/dist/event-bus/contracts/event-bus-factory.contract.js.map +1 -1
  609. package/dist/event-bus/contracts/event-bus.contract.d.ts +12 -12
  610. package/dist/event-bus/contracts/event-bus.contract.js +3 -1
  611. package/dist/event-bus/contracts/event-bus.contract.js.map +1 -1
  612. package/dist/event-bus/implementations/adapters/{_module-exports.js → _module.js} +1 -1
  613. package/dist/event-bus/implementations/adapters/_module.js.map +1 -0
  614. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/_module-exports.d.ts +1 -0
  615. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/_module-exports.js +2 -0
  616. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/_module-exports.js.map +1 -0
  617. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.d.ts +4 -4
  618. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js +4 -3
  619. package/dist/event-bus/implementations/adapters/memory-event-bus-adapter/memory-event-bus-adapter.js.map +1 -1
  620. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/_module-exports.d.ts +1 -0
  621. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/_module-exports.js +2 -0
  622. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/_module-exports.js.map +1 -0
  623. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.d.ts +2 -3
  624. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js +2 -1
  625. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.js.map +1 -1
  626. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module-exports.d.ts +1 -0
  627. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module-exports.js +2 -0
  628. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/_module-exports.js.map +1 -0
  629. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.d.ts +7 -7
  630. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js +8 -6
  631. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js.map +1 -1
  632. package/dist/event-bus/implementations/derivables/_module.d.ts +2 -0
  633. package/dist/event-bus/implementations/derivables/_module.js +3 -0
  634. package/dist/event-bus/implementations/derivables/_module.js.map +1 -0
  635. package/dist/event-bus/implementations/derivables/event-bus/event-bus.d.ts +12 -14
  636. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js +8 -7
  637. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js.map +1 -1
  638. package/dist/event-bus/implementations/derivables/event-bus/listener-store.d.ts +1 -1
  639. package/dist/event-bus/implementations/derivables/event-bus/listener-store.js +2 -1
  640. package/dist/event-bus/implementations/derivables/event-bus/listener-store.js.map +1 -1
  641. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.d.ts +9 -7
  642. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js +10 -7
  643. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js.map +1 -1
  644. package/dist/event-bus/implementations/test-utilities/_module.d.ts +2 -0
  645. package/dist/event-bus/implementations/test-utilities/_module.js +3 -0
  646. package/dist/event-bus/implementations/test-utilities/_module.js.map +1 -0
  647. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.d.ts +2 -2
  648. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js +4 -3
  649. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js.map +1 -1
  650. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.d.ts +2 -2
  651. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js +6 -6
  652. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js.map +1 -1
  653. package/dist/hooks/_module-exports.d.ts +1 -1
  654. package/dist/hooks/_module-exports.js +0 -1
  655. package/dist/hooks/_module-exports.js.map +1 -1
  656. package/dist/hooks/_module.d.ts +3 -0
  657. package/dist/hooks/_module.js +3 -0
  658. package/dist/hooks/_module.js.map +1 -0
  659. package/dist/hooks/async-hooks.d.ts +3 -3
  660. package/dist/hooks/async-hooks.js +8 -5
  661. package/dist/hooks/async-hooks.js.map +1 -1
  662. package/dist/hooks/hooks.d.ts +2 -2
  663. package/dist/hooks/hooks.js +2 -1
  664. package/dist/hooks/hooks.js.map +1 -1
  665. package/dist/lock/contracts/_module-exports.d.ts +6 -6
  666. package/dist/lock/contracts/_module-exports.js +0 -6
  667. package/dist/lock/contracts/_module-exports.js.map +1 -1
  668. package/dist/lock/contracts/_module.d.ts +9 -0
  669. package/dist/lock/contracts/_module.js +4 -0
  670. package/dist/lock/contracts/_module.js.map +1 -0
  671. package/dist/lock/contracts/database-lock-adapter.contract.d.ts +8 -3
  672. package/dist/lock/contracts/database-lock-adapter.contract.js +1 -1
  673. package/dist/lock/contracts/database-lock-adapter.contract.js.map +1 -1
  674. package/dist/lock/contracts/lock-adapter.contract.d.ts +1 -1
  675. package/dist/lock/contracts/lock-adapter.contract.js +3 -1
  676. package/dist/lock/contracts/lock-adapter.contract.js.map +1 -1
  677. package/dist/lock/contracts/lock-provider-factory.contract.d.ts +1 -1
  678. package/dist/lock/contracts/lock-provider-factory.contract.js +2 -1
  679. package/dist/lock/contracts/lock-provider-factory.contract.js.map +1 -1
  680. package/dist/lock/contracts/lock-provider.contract.d.ts +4 -8
  681. package/dist/lock/contracts/lock-provider.contract.js +4 -1
  682. package/dist/lock/contracts/lock-provider.contract.js.map +1 -1
  683. package/dist/lock/contracts/lock-state.contract.d.ts +2 -2
  684. package/dist/lock/contracts/lock-state.contract.js +1 -0
  685. package/dist/lock/contracts/lock-state.contract.js.map +1 -1
  686. package/dist/lock/contracts/lock.contract.d.ts +18 -27
  687. package/dist/lock/contracts/lock.contract.js +5 -1
  688. package/dist/lock/contracts/lock.contract.js.map +1 -1
  689. package/dist/lock/contracts/lock.errors.d.ts +19 -0
  690. package/dist/lock/contracts/lock.errors.js +25 -0
  691. package/dist/lock/contracts/lock.errors.js.map +1 -1
  692. package/dist/lock/contracts/lock.events.d.ts +1 -1
  693. package/dist/lock/contracts/lock.events.js +2 -0
  694. package/dist/lock/contracts/lock.events.js.map +1 -1
  695. package/dist/lock/contracts/types.d.ts +2 -2
  696. package/dist/lock/contracts/types.js +2 -1
  697. package/dist/lock/contracts/types.js.map +1 -1
  698. package/dist/lock/implementations/adapters/{_module-exports.js → _module.js} +1 -1
  699. package/dist/lock/implementations/adapters/_module.js.map +1 -0
  700. package/dist/lock/implementations/adapters/kysely-lock-adapter/_module-exports.d.ts +1 -0
  701. package/dist/lock/implementations/adapters/kysely-lock-adapter/_module-exports.js +2 -0
  702. package/dist/lock/implementations/adapters/kysely-lock-adapter/_module-exports.js.map +1 -0
  703. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.d.ts +13 -18
  704. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js +11 -10
  705. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js.map +1 -1
  706. package/dist/lock/implementations/adapters/memory-lock-adapter/_module-exports.d.ts +1 -0
  707. package/dist/lock/implementations/adapters/memory-lock-adapter/_module-exports.js +2 -0
  708. package/dist/lock/implementations/adapters/memory-lock-adapter/_module-exports.js.map +1 -0
  709. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.d.ts +11 -8
  710. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js +10 -4
  711. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js.map +1 -1
  712. package/dist/lock/implementations/adapters/mongodb-lock-adapter/_module-exports.d.ts +1 -0
  713. package/dist/lock/implementations/adapters/mongodb-lock-adapter/_module-exports.js +2 -0
  714. package/dist/lock/implementations/adapters/mongodb-lock-adapter/_module-exports.js.map +1 -0
  715. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.d.ts +8 -9
  716. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js +6 -3
  717. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js.map +1 -1
  718. package/dist/lock/implementations/adapters/no-op-lock-adapter/_module-exports.d.ts +1 -0
  719. package/dist/lock/implementations/adapters/no-op-lock-adapter/_module-exports.js +2 -0
  720. package/dist/lock/implementations/adapters/no-op-lock-adapter/_module-exports.js.map +1 -0
  721. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.d.ts +3 -3
  722. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.js +3 -1
  723. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.js.map +1 -1
  724. package/dist/lock/implementations/adapters/redis-lock-adapter/_module-exports.d.ts +1 -0
  725. package/dist/lock/implementations/adapters/redis-lock-adapter/_module-exports.js +2 -0
  726. package/dist/lock/implementations/adapters/redis-lock-adapter/_module-exports.js.map +1 -0
  727. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.d.ts +5 -6
  728. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js +5 -2
  729. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js.map +1 -1
  730. package/dist/lock/implementations/derivables/_module.d.ts +2 -0
  731. package/dist/lock/implementations/derivables/_module.js +3 -0
  732. package/dist/lock/implementations/derivables/_module.js.map +1 -0
  733. package/dist/lock/implementations/derivables/lock-provider/_module.d.ts +1 -0
  734. package/dist/lock/implementations/derivables/lock-provider/_module.js +1 -0
  735. package/dist/lock/implementations/derivables/lock-provider/_module.js.map +1 -1
  736. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.d.ts +2 -2
  737. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js +5 -3
  738. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js.map +1 -1
  739. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.d.ts +1 -2
  740. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.js +4 -0
  741. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.js.map +1 -1
  742. package/dist/lock/implementations/derivables/lock-provider/lock-provider.d.ts +40 -25
  743. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js +30 -21
  744. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js.map +1 -1
  745. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.d.ts +6 -6
  746. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js +6 -2
  747. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js.map +1 -1
  748. package/dist/lock/implementations/derivables/lock-provider/lock.d.ts +19 -23
  749. package/dist/lock/implementations/derivables/lock-provider/lock.js +13 -37
  750. package/dist/lock/implementations/derivables/lock-provider/lock.js.map +1 -1
  751. package/dist/lock/implementations/derivables/lock-provider/resolve-lock-adapter.d.ts +8 -0
  752. package/dist/lock/implementations/derivables/lock-provider/{resolve-database-lock-adapter.js → resolve-lock-adapter.js} +7 -3
  753. package/dist/lock/implementations/derivables/lock-provider/resolve-lock-adapter.js.map +1 -0
  754. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.d.ts +12 -12
  755. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js +15 -8
  756. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js.map +1 -1
  757. package/dist/lock/implementations/test-utilities/_module.d.ts +3 -0
  758. package/dist/lock/implementations/test-utilities/_module.js +4 -0
  759. package/dist/lock/implementations/test-utilities/_module.js.map +1 -0
  760. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.d.ts +17 -12
  761. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js +19 -14
  762. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js.map +1 -1
  763. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.d.ts +3 -3
  764. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js +5 -5
  765. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js.map +1 -1
  766. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.d.ts +6 -6
  767. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js +9 -544
  768. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js.map +1 -1
  769. package/dist/namespace/_module.d.ts +1 -0
  770. package/dist/namespace/_module.js +2 -0
  771. package/dist/namespace/_module.js.map +1 -0
  772. package/dist/namespace/namespace.d.ts +1 -1
  773. package/dist/namespace/namespace.js +1 -1
  774. package/dist/namespace/namespace.js.map +1 -1
  775. package/dist/rate-limiter/contracts/_module-exports.d.ts +9 -0
  776. package/dist/rate-limiter/contracts/_module-exports.js +4 -0
  777. package/dist/rate-limiter/contracts/_module-exports.js.map +1 -0
  778. package/dist/rate-limiter/contracts/_module.d.ts +9 -0
  779. package/dist/rate-limiter/contracts/_module.js +4 -0
  780. package/dist/rate-limiter/contracts/_module.js.map +1 -0
  781. package/dist/rate-limiter/contracts/rate-limiter-adapter.contract.d.ts +36 -0
  782. package/dist/rate-limiter/contracts/rate-limiter-adapter.contract.js +7 -0
  783. package/dist/rate-limiter/contracts/rate-limiter-adapter.contract.js.map +1 -0
  784. package/dist/rate-limiter/contracts/rate-limiter-policy.contract.d.ts +28 -0
  785. package/dist/rate-limiter/contracts/rate-limiter-policy.contract.js +5 -0
  786. package/dist/rate-limiter/contracts/rate-limiter-policy.contract.js.map +1 -0
  787. package/dist/rate-limiter/contracts/rate-limiter-provider-factory.contract.d.ts +19 -0
  788. package/dist/rate-limiter/contracts/rate-limiter-provider-factory.contract.js +10 -0
  789. package/dist/rate-limiter/contracts/rate-limiter-provider-factory.contract.js.map +1 -0
  790. package/dist/rate-limiter/contracts/rate-limiter-provider.contract.d.ts +39 -0
  791. package/dist/rate-limiter/contracts/rate-limiter-provider.contract.js +8 -0
  792. package/dist/rate-limiter/contracts/rate-limiter-provider.contract.js.map +1 -0
  793. package/dist/rate-limiter/contracts/rate-limiter-state.contract.d.ts +48 -0
  794. package/dist/rate-limiter/contracts/rate-limiter-state.contract.js +14 -0
  795. package/dist/rate-limiter/contracts/rate-limiter-state.contract.js.map +1 -0
  796. package/dist/rate-limiter/contracts/rate-limiter-storage-adapter.contract.d.ts +65 -0
  797. package/dist/rate-limiter/contracts/rate-limiter-storage-adapter.contract.js +5 -0
  798. package/dist/rate-limiter/contracts/rate-limiter-storage-adapter.contract.js.map +1 -0
  799. package/dist/rate-limiter/contracts/rate-limiter.contract.d.ts +46 -0
  800. package/dist/rate-limiter/contracts/rate-limiter.contract.js +10 -0
  801. package/dist/rate-limiter/contracts/rate-limiter.contract.js.map +1 -0
  802. package/dist/rate-limiter/contracts/rate-limiter.errors.d.ts +34 -0
  803. package/dist/rate-limiter/contracts/rate-limiter.errors.js +40 -0
  804. package/dist/rate-limiter/contracts/rate-limiter.errors.js.map +1 -0
  805. package/dist/rate-limiter/contracts/rate-limiter.events.d.ts +74 -0
  806. package/dist/rate-limiter/contracts/rate-limiter.events.js +17 -0
  807. package/dist/rate-limiter/contracts/rate-limiter.events.js.map +1 -0
  808. package/dist/rate-limiter/implementations/adapters/_module.d.ts +7 -0
  809. package/dist/rate-limiter/implementations/adapters/_module.js +8 -0
  810. package/dist/rate-limiter/implementations/adapters/_module.js.map +1 -0
  811. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/_module-exports.d.ts +1 -0
  812. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/_module-exports.js +2 -0
  813. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/_module-exports.js.map +1 -0
  814. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/_module.d.ts +1 -0
  815. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/_module.js +2 -0
  816. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/_module.js.map +1 -0
  817. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/database-rate-limiter-adapter.d.ts +56 -0
  818. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/database-rate-limiter-adapter.js +75 -0
  819. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/database-rate-limiter-adapter.js.map +1 -0
  820. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-policy.d.ts +48 -0
  821. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-policy.js +69 -0
  822. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-policy.js.map +1 -0
  823. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-state-manager.d.ts +15 -0
  824. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-state-manager.js +33 -0
  825. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-state-manager.js.map +1 -0
  826. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-storage.d.ts +45 -0
  827. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-storage.js +59 -0
  828. package/dist/rate-limiter/implementations/adapters/database-rate-limiter-adapter/rate-limiter-storage.js.map +1 -0
  829. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/_module-exports.d.ts +1 -0
  830. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/_module-exports.js +2 -0
  831. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/_module-exports.js.map +1 -0
  832. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/_module.d.ts +1 -0
  833. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/_module.js +2 -0
  834. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/_module.js.map +1 -0
  835. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/kysely-rate-limiter-storage-adapter.d.ts +95 -0
  836. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/kysely-rate-limiter-storage-adapter.js +186 -0
  837. package/dist/rate-limiter/implementations/adapters/kysely-rate-limiter-storage-adapter/kysely-rate-limiter-storage-adapter.js.map +1 -0
  838. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/_module-exports.d.ts +1 -0
  839. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/_module-exports.js +2 -0
  840. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/_module-exports.js.map +1 -0
  841. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/_module.d.ts +1 -0
  842. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/_module.js +2 -0
  843. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/_module.js.map +1 -0
  844. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/memory-rate-limiter-storage-adapter.d.ts +37 -0
  845. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/memory-rate-limiter-storage-adapter.js +71 -0
  846. package/dist/rate-limiter/implementations/adapters/memory-rate-limiter-storage-adapter/memory-rate-limiter-storage-adapter.js.map +1 -0
  847. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/_module-exports.d.ts +1 -0
  848. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/_module-exports.js +2 -0
  849. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/_module-exports.js.map +1 -0
  850. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/_module.d.ts +1 -0
  851. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/_module.js +2 -0
  852. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/_module.js.map +1 -0
  853. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/mongodb-rate-limiter-storage-adapter.d.ts +77 -0
  854. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/mongodb-rate-limiter-storage-adapter.js +126 -0
  855. package/dist/rate-limiter/implementations/adapters/mongodb-rate-limiter-storage-adapter/mongodb-rate-limiter-storage-adapter.js.map +1 -0
  856. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/_module-exports.d.ts +1 -0
  857. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/_module-exports.js +2 -0
  858. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/_module-exports.js.map +1 -0
  859. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/_module.d.ts +1 -0
  860. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/_module.js +2 -0
  861. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/_module.js.map +1 -0
  862. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/no-op-rate-limiter-adapter.d.ts +13 -0
  863. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/no-op-rate-limiter-adapter.js +29 -0
  864. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-adapter/no-op-rate-limiter-adapter.js.map +1 -0
  865. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/_module-exports.d.ts +1 -0
  866. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/_module-exports.js +2 -0
  867. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/_module-exports.js.map +1 -0
  868. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/_module.d.ts +1 -0
  869. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/_module.js +2 -0
  870. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/_module.js.map +1 -0
  871. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/no-op-rate-limiter-storage-adapter.d.ts +16 -0
  872. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/no-op-rate-limiter-storage-adapter.js +33 -0
  873. package/dist/rate-limiter/implementations/adapters/no-op-rate-limiter-storage-adapter/no-op-rate-limiter-storage-adapter.js.map +1 -0
  874. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/_module-exports.d.ts +1 -0
  875. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/_module-exports.js +2 -0
  876. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/_module-exports.js.map +1 -0
  877. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/_module.d.ts +1 -0
  878. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/_module.js +2 -0
  879. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/_module.js.map +1 -0
  880. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/_module.d.ts +1 -0
  881. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/_module.js +2 -0
  882. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/_module.js.map +1 -0
  883. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/fixed-window-limiter-lua.d.ts +7 -0
  884. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/fixed-window-limiter-lua.js +55 -0
  885. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/fixed-window-limiter-lua.js.map +1 -0
  886. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-factory-lua.d.ts +4 -0
  887. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-factory-lua.js +71 -0
  888. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-factory-lua.js.map +1 -0
  889. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-lua.d.ts +4 -0
  890. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-lua.js +29 -0
  891. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-lua.js.map +1 -0
  892. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-policy-lua.d.ts +7 -0
  893. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-policy-lua.js +82 -0
  894. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-policy-lua.js.map +1 -0
  895. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-state-manager-lua.d.ts +7 -0
  896. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-state-manager-lua.js +51 -0
  897. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-state-manager-lua.js.map +1 -0
  898. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-storage-lua.d.ts +7 -0
  899. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-storage-lua.js +59 -0
  900. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/rate-limiter-storage-lua.js.map +1 -0
  901. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/sliding-window-limiter-lua.d.ts +7 -0
  902. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/sliding-window-limiter-lua.js +113 -0
  903. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/lua/sliding-window-limiter-lua.js.map +1 -0
  904. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/redis-rate-limiter-adapter.d.ts +64 -0
  905. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/redis-rate-limiter-adapter.js +95 -0
  906. package/dist/rate-limiter/implementations/adapters/redis-rate-limiter-adapter/redis-rate-limiter-adapter.js.map +1 -0
  907. package/dist/rate-limiter/implementations/derivables/_module-exports.d.ts +2 -0
  908. package/dist/rate-limiter/implementations/derivables/_module-exports.js +3 -0
  909. package/dist/rate-limiter/implementations/derivables/_module-exports.js.map +1 -0
  910. package/dist/rate-limiter/implementations/derivables/_module.d.ts +2 -0
  911. package/dist/rate-limiter/implementations/derivables/_module.js +3 -0
  912. package/dist/rate-limiter/implementations/derivables/_module.js.map +1 -0
  913. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/_module.d.ts +1 -0
  914. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/_module.js +2 -0
  915. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/_module.js.map +1 -0
  916. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-provider.d.ts +114 -0
  917. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-provider.js +104 -0
  918. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-provider.js.map +1 -0
  919. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter.d.ts +41 -0
  920. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter.js +160 -0
  921. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter.js.map +1 -0
  922. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/_module.d.ts +2 -0
  923. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/_module.js +3 -0
  924. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/_module.js.map +1 -0
  925. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/database-rate-limiter-provider-factory.d.ts +135 -0
  926. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/database-rate-limiter-provider-factory.js +156 -0
  927. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/database-rate-limiter-provider-factory.js.map +1 -0
  928. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/rate-limiter-provider-factory.d.ts +106 -0
  929. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/rate-limiter-provider-factory.js +132 -0
  930. package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/rate-limiter-provider-factory.js.map +1 -0
  931. package/dist/rate-limiter/implementations/policies/_module-exports.d.ts +4 -0
  932. package/dist/rate-limiter/implementations/policies/_module-exports.js +5 -0
  933. package/dist/rate-limiter/implementations/policies/_module-exports.js.map +1 -0
  934. package/dist/rate-limiter/implementations/policies/_module.d.ts +4 -0
  935. package/dist/rate-limiter/implementations/policies/_module.js +5 -0
  936. package/dist/rate-limiter/implementations/policies/_module.js.map +1 -0
  937. package/dist/rate-limiter/implementations/policies/_shared.d.ts +12 -0
  938. package/dist/rate-limiter/implementations/policies/_shared.js +37 -0
  939. package/dist/rate-limiter/implementations/policies/_shared.js.map +1 -0
  940. package/dist/rate-limiter/implementations/policies/fixed-window-limiter/_module.d.ts +1 -0
  941. package/dist/rate-limiter/implementations/policies/fixed-window-limiter/_module.js +2 -0
  942. package/dist/rate-limiter/implementations/policies/fixed-window-limiter/_module.js.map +1 -0
  943. package/dist/rate-limiter/implementations/policies/fixed-window-limiter/fixed-window-limiter.d.ts +74 -0
  944. package/dist/rate-limiter/implementations/policies/fixed-window-limiter/fixed-window-limiter.js +73 -0
  945. package/dist/rate-limiter/implementations/policies/fixed-window-limiter/fixed-window-limiter.js.map +1 -0
  946. package/dist/rate-limiter/implementations/policies/sliding-window-limiter/_module.d.ts +1 -0
  947. package/dist/rate-limiter/implementations/policies/sliding-window-limiter/_module.js +2 -0
  948. package/dist/rate-limiter/implementations/policies/sliding-window-limiter/_module.js.map +1 -0
  949. package/dist/rate-limiter/implementations/policies/sliding-window-limiter/sliding-window-limiter.d.ts +86 -0
  950. package/dist/rate-limiter/implementations/policies/sliding-window-limiter/sliding-window-limiter.js +106 -0
  951. package/dist/rate-limiter/implementations/policies/sliding-window-limiter/sliding-window-limiter.js.map +1 -0
  952. package/dist/rate-limiter/implementations/policies/types.d.ts +47 -0
  953. package/dist/rate-limiter/implementations/policies/types.js +14 -0
  954. package/dist/rate-limiter/implementations/policies/types.js.map +1 -0
  955. package/dist/rate-limiter/implementations/test-utilities/_module-exports.d.ts +3 -0
  956. package/dist/rate-limiter/implementations/test-utilities/_module-exports.js +4 -0
  957. package/dist/rate-limiter/implementations/test-utilities/_module-exports.js.map +1 -0
  958. package/dist/rate-limiter/implementations/test-utilities/_module.d.ts +3 -0
  959. package/dist/rate-limiter/implementations/test-utilities/_module.js +4 -0
  960. package/dist/rate-limiter/implementations/test-utilities/_module.js.map +1 -0
  961. package/dist/rate-limiter/implementations/test-utilities/fixed-window-limiter.test-suite.d.ts +60 -0
  962. package/dist/rate-limiter/implementations/test-utilities/fixed-window-limiter.test-suite.js +90 -0
  963. package/dist/rate-limiter/implementations/test-utilities/fixed-window-limiter.test-suite.js.map +1 -0
  964. package/dist/rate-limiter/implementations/test-utilities/rate-limiter-storage-adapter.test-suite.d.ts +45 -0
  965. package/dist/rate-limiter/implementations/test-utilities/rate-limiter-storage-adapter.test-suite.js +102 -0
  966. package/dist/rate-limiter/implementations/test-utilities/rate-limiter-storage-adapter.test-suite.js.map +1 -0
  967. package/dist/rate-limiter/implementations/test-utilities/sliding-window-limiter.test-suite.d.ts +60 -0
  968. package/dist/rate-limiter/implementations/test-utilities/sliding-window-limiter.test-suite.js +91 -0
  969. package/dist/rate-limiter/implementations/test-utilities/sliding-window-limiter.test-suite.js.map +1 -0
  970. package/dist/resilience/_module.d.ts +2 -0
  971. package/dist/resilience/_module.js +3 -0
  972. package/dist/resilience/_module.js.map +1 -0
  973. package/dist/resilience/middlewares/dynamic/dynamic.middleware.d.ts +2 -2
  974. package/dist/resilience/middlewares/dynamic/dynamic.middleware.js +2 -1
  975. package/dist/resilience/middlewares/dynamic/dynamic.middleware.js.map +1 -1
  976. package/dist/resilience/middlewares/fallback/_module.d.ts +1 -1
  977. package/dist/resilience/middlewares/fallback/_module.js +0 -1
  978. package/dist/resilience/middlewares/fallback/_module.js.map +1 -1
  979. package/dist/resilience/middlewares/fallback/fallback.middleware.d.ts +3 -25
  980. package/dist/resilience/middlewares/fallback/fallback.middleware.js +6 -32
  981. package/dist/resilience/middlewares/fallback/fallback.middleware.js.map +1 -1
  982. package/dist/resilience/middlewares/fallback/fallback.types.d.ts +4 -6
  983. package/dist/resilience/middlewares/fallback/fallback.types.js +2 -2
  984. package/dist/resilience/middlewares/fallback/fallback.types.js.map +1 -1
  985. package/dist/resilience/middlewares/observe/_module.d.ts +1 -1
  986. package/dist/resilience/middlewares/observe/_module.js +0 -1
  987. package/dist/resilience/middlewares/observe/_module.js.map +1 -1
  988. package/dist/resilience/middlewares/observe/observe.middleware.d.ts +3 -39
  989. package/dist/resilience/middlewares/observe/observe.middleware.js +5 -57
  990. package/dist/resilience/middlewares/observe/observe.middleware.js.map +1 -1
  991. package/dist/resilience/middlewares/observe/observe.types.d.ts +4 -5
  992. package/dist/resilience/middlewares/observe/observe.types.js +3 -1
  993. package/dist/resilience/middlewares/observe/observe.types.js.map +1 -1
  994. package/dist/resilience/middlewares/retry/_module.d.ts +1 -1
  995. package/dist/resilience/middlewares/retry/_module.js +0 -1
  996. package/dist/resilience/middlewares/retry/_module.js.map +1 -1
  997. package/dist/resilience/middlewares/retry/retry.middleware.d.ts +3 -33
  998. package/dist/resilience/middlewares/retry/retry.middleware.js +9 -40
  999. package/dist/resilience/middlewares/retry/retry.middleware.js.map +1 -1
  1000. package/dist/resilience/middlewares/retry/retry.types.d.ts +7 -9
  1001. package/dist/resilience/middlewares/retry/retry.types.js +4 -3
  1002. package/dist/resilience/middlewares/retry/retry.types.js.map +1 -1
  1003. package/dist/resilience/middlewares/timeout/_module.d.ts +1 -1
  1004. package/dist/resilience/middlewares/timeout/_module.js +0 -1
  1005. package/dist/resilience/middlewares/timeout/_module.js.map +1 -1
  1006. package/dist/resilience/middlewares/timeout/timeout.middleware.d.ts +2 -2
  1007. package/dist/resilience/middlewares/timeout/timeout.middleware.js +4 -2
  1008. package/dist/resilience/middlewares/timeout/timeout.middleware.js.map +1 -1
  1009. package/dist/resilience/middlewares/timeout/timeout.type.d.ts +4 -4
  1010. package/dist/resilience/middlewares/timeout/timeout.type.js +4 -1
  1011. package/dist/resilience/middlewares/timeout/timeout.type.js.map +1 -1
  1012. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.d.ts +1 -1
  1013. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.js +1 -1
  1014. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.js.map +1 -1
  1015. package/dist/semaphore/contracts/_module-exports.d.ts +6 -6
  1016. package/dist/semaphore/contracts/_module-exports.js +0 -6
  1017. package/dist/semaphore/contracts/_module-exports.js.map +1 -1
  1018. package/dist/semaphore/contracts/_module.d.ts +9 -0
  1019. package/dist/semaphore/contracts/_module.js +4 -0
  1020. package/dist/semaphore/contracts/_module.js.map +1 -0
  1021. package/dist/semaphore/contracts/database-semaphore-adapter.contract.d.ts +1 -1
  1022. package/dist/semaphore/contracts/database-semaphore-adapter.contract.js +1 -1
  1023. package/dist/semaphore/contracts/database-semaphore-adapter.contract.js.map +1 -1
  1024. package/dist/semaphore/contracts/semaphore-adapter.contract.d.ts +1 -1
  1025. package/dist/semaphore/contracts/semaphore-adapter.contract.js +3 -1
  1026. package/dist/semaphore/contracts/semaphore-adapter.contract.js.map +1 -1
  1027. package/dist/semaphore/contracts/semaphore-provider-factory.contract.d.ts +1 -1
  1028. package/dist/semaphore/contracts/semaphore-provider-factory.contract.js +2 -1
  1029. package/dist/semaphore/contracts/semaphore-provider-factory.contract.js.map +1 -1
  1030. package/dist/semaphore/contracts/semaphore-provider.contract.d.ts +4 -8
  1031. package/dist/semaphore/contracts/semaphore-provider.contract.js +4 -1
  1032. package/dist/semaphore/contracts/semaphore-provider.contract.js.map +1 -1
  1033. package/dist/semaphore/contracts/semaphore-state.contract.d.ts +2 -2
  1034. package/dist/semaphore/contracts/semaphore-state.contract.js +1 -0
  1035. package/dist/semaphore/contracts/semaphore-state.contract.js.map +1 -1
  1036. package/dist/semaphore/contracts/semaphore.contract.d.ts +18 -28
  1037. package/dist/semaphore/contracts/semaphore.contract.js +5 -1
  1038. package/dist/semaphore/contracts/semaphore.contract.js.map +1 -1
  1039. package/dist/semaphore/contracts/semaphore.errors.d.ts +19 -0
  1040. package/dist/semaphore/contracts/semaphore.errors.js +25 -0
  1041. package/dist/semaphore/contracts/semaphore.errors.js.map +1 -1
  1042. package/dist/semaphore/contracts/semaphore.events.d.ts +1 -1
  1043. package/dist/semaphore/contracts/semaphore.events.js +1 -0
  1044. package/dist/semaphore/contracts/semaphore.events.js.map +1 -1
  1045. package/dist/semaphore/contracts/types.d.ts +2 -2
  1046. package/dist/semaphore/contracts/types.js +2 -1
  1047. package/dist/semaphore/contracts/types.js.map +1 -1
  1048. package/dist/semaphore/implementations/adapters/{_module-exports.js → _module.js} +1 -1
  1049. package/dist/semaphore/implementations/adapters/_module.js.map +1 -0
  1050. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module-exports.d.ts +1 -0
  1051. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module-exports.js +2 -0
  1052. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module-exports.js.map +1 -0
  1053. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.d.ts +18 -11
  1054. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.js +13 -6
  1055. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.js.map +1 -1
  1056. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module-exports.d.ts +1 -0
  1057. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module-exports.js +2 -0
  1058. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module-exports.js.map +1 -0
  1059. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.d.ts +13 -8
  1060. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.js +22 -4
  1061. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.js.map +1 -1
  1062. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module-exports.d.ts +1 -0
  1063. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module-exports.js +2 -0
  1064. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module-exports.js.map +1 -0
  1065. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.d.ts +13 -10
  1066. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.js +9 -5
  1067. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.js.map +1 -1
  1068. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module-exports.d.ts +1 -0
  1069. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module-exports.js +2 -0
  1070. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module-exports.js.map +1 -0
  1071. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.d.ts +3 -3
  1072. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.js +3 -1
  1073. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.js.map +1 -1
  1074. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module-exports.d.ts +1 -0
  1075. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module-exports.js +2 -0
  1076. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module-exports.js.map +1 -0
  1077. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.d.ts +4 -4
  1078. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.js +4 -1
  1079. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.js.map +1 -1
  1080. package/dist/semaphore/implementations/derivables/_module-exports.d.ts +1 -1
  1081. package/dist/semaphore/implementations/derivables/_module-exports.js +0 -1
  1082. package/dist/semaphore/implementations/derivables/_module-exports.js.map +1 -1
  1083. package/dist/semaphore/implementations/derivables/_module.d.ts +2 -0
  1084. package/dist/semaphore/implementations/derivables/_module.js +2 -0
  1085. package/dist/semaphore/implementations/derivables/_module.js.map +1 -0
  1086. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.d.ts +2 -2
  1087. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.js +3 -1
  1088. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.js.map +1 -1
  1089. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.d.ts +1 -1
  1090. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.js +4 -0
  1091. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.js.map +1 -1
  1092. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-semaphore-adapter.d.ts +8 -0
  1093. package/dist/semaphore/implementations/derivables/semaphore-provider/{resolve-database-semaphore-adapter.js → resolve-semaphore-adapter.js} +4 -3
  1094. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-semaphore-adapter.js.map +1 -0
  1095. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.d.ts +57 -18
  1096. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js +46 -12
  1097. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js.map +1 -1
  1098. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.d.ts +6 -6
  1099. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js +6 -3
  1100. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js.map +1 -1
  1101. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.d.ts +19 -23
  1102. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js +13 -36
  1103. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js.map +1 -1
  1104. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.d.ts +1 -1
  1105. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.js +1 -1
  1106. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.js.map +1 -1
  1107. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.d.ts +59 -4
  1108. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js +63 -1
  1109. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js.map +1 -1
  1110. package/dist/semaphore/implementations/test-utilities/_module.d.ts +3 -0
  1111. package/dist/semaphore/implementations/test-utilities/_module.js +4 -0
  1112. package/dist/semaphore/implementations/test-utilities/_module.js.map +1 -0
  1113. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.d.ts +17 -12
  1114. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.js +18 -12
  1115. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.js.map +1 -1
  1116. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.d.ts +4 -4
  1117. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.js +6 -6
  1118. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.js.map +1 -1
  1119. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.d.ts +6 -6
  1120. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.js +81 -810
  1121. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.js.map +1 -1
  1122. package/dist/serde/contracts/_module-exports.d.ts +5 -5
  1123. package/dist/serde/contracts/_module-exports.js +0 -5
  1124. package/dist/serde/contracts/_module-exports.js.map +1 -1
  1125. package/dist/serde/contracts/_module.d.ts +6 -0
  1126. package/dist/serde/contracts/_module.js +2 -0
  1127. package/dist/serde/contracts/_module.js.map +1 -0
  1128. package/dist/serde/contracts/flexible-serde-adapter.contract.d.ts +1 -1
  1129. package/dist/serde/contracts/flexible-serde-adapter.contract.js +1 -1
  1130. package/dist/serde/contracts/flexible-serde-adapter.contract.js.map +1 -1
  1131. package/dist/serde/contracts/flexible-serde.contract.d.ts +2 -2
  1132. package/dist/serde/contracts/flexible-serde.contract.js +2 -1
  1133. package/dist/serde/contracts/flexible-serde.contract.js.map +1 -1
  1134. package/dist/serde/contracts/serde.contract.d.ts +2 -2
  1135. package/dist/serde/contracts/serde.contract.js +2 -1
  1136. package/dist/serde/contracts/serde.contract.js.map +1 -1
  1137. package/dist/serde/contracts/serde.errors.d.ts +12 -0
  1138. package/dist/serde/contracts/serde.errors.js +16 -0
  1139. package/dist/serde/contracts/serde.errors.js.map +1 -1
  1140. package/dist/serde/implementations/adapters/{_module-exports.js → _module.js} +1 -1
  1141. package/dist/serde/implementations/adapters/_module.js.map +1 -0
  1142. package/dist/serde/implementations/adapters/no-op-serde-adapter/_module-exports.d.ts +1 -0
  1143. package/dist/serde/implementations/adapters/no-op-serde-adapter/_module-exports.js +2 -0
  1144. package/dist/serde/implementations/adapters/no-op-serde-adapter/_module-exports.js.map +1 -0
  1145. package/dist/serde/implementations/adapters/no-op-serde-adapter/no-op-serde-adapter.d.ts +2 -2
  1146. package/dist/serde/implementations/adapters/no-op-serde-adapter/no-op-serde-adapter.js +5 -1
  1147. package/dist/serde/implementations/adapters/no-op-serde-adapter/no-op-serde-adapter.js.map +1 -1
  1148. package/dist/serde/implementations/adapters/super-json-serde-adapter/_module-exports.d.ts +1 -0
  1149. package/dist/serde/implementations/adapters/super-json-serde-adapter/_module-exports.js +2 -0
  1150. package/dist/serde/implementations/adapters/super-json-serde-adapter/_module-exports.js.map +1 -0
  1151. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.d.ts +2 -2
  1152. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js +4 -4
  1153. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js.map +1 -1
  1154. package/dist/serde/implementations/derivables/_module.d.ts +1 -0
  1155. package/dist/serde/implementations/derivables/_module.js +2 -0
  1156. package/dist/serde/implementations/derivables/_module.js.map +1 -0
  1157. package/dist/serde/implementations/derivables/serde-transformers.d.ts +2 -2
  1158. package/dist/serde/implementations/derivables/serde-transformers.js +5 -1
  1159. package/dist/serde/implementations/derivables/serde-transformers.js.map +1 -1
  1160. package/dist/serde/implementations/derivables/serde.d.ts +7 -7
  1161. package/dist/serde/implementations/derivables/serde.js +7 -6
  1162. package/dist/serde/implementations/derivables/serde.js.map +1 -1
  1163. package/dist/serde/implementations/test-utilities/_module.d.ts +2 -0
  1164. package/dist/serde/implementations/test-utilities/_module.js +3 -0
  1165. package/dist/serde/implementations/test-utilities/_module.js.map +1 -0
  1166. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.d.ts +2 -2
  1167. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js +2 -1
  1168. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js.map +1 -1
  1169. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.d.ts +2 -2
  1170. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js +2 -1
  1171. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js.map +1 -1
  1172. package/dist/shared-lock/contracts/_module-exports.d.ts +7 -7
  1173. package/dist/shared-lock/contracts/_module-exports.js +0 -7
  1174. package/dist/shared-lock/contracts/_module-exports.js.map +1 -1
  1175. package/dist/shared-lock/contracts/_module.d.ts +10 -0
  1176. package/dist/shared-lock/contracts/_module.js +4 -0
  1177. package/dist/shared-lock/contracts/_module.js.map +1 -0
  1178. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.d.ts +1 -1
  1179. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.js +1 -1
  1180. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.js.map +1 -1
  1181. package/dist/shared-lock/contracts/shared-lock-adapter.contract.d.ts +1 -1
  1182. package/dist/shared-lock/contracts/shared-lock-adapter.contract.js +3 -1
  1183. package/dist/shared-lock/contracts/shared-lock-adapter.contract.js.map +1 -1
  1184. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.d.ts +1 -1
  1185. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.js +2 -1
  1186. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.js.map +1 -1
  1187. package/dist/shared-lock/contracts/shared-lock-provider.contract.d.ts +4 -8
  1188. package/dist/shared-lock/contracts/shared-lock-provider.contract.js +4 -1
  1189. package/dist/shared-lock/contracts/shared-lock-provider.contract.js.map +1 -1
  1190. package/dist/shared-lock/contracts/shared-lock-state.contract.d.ts +3 -3
  1191. package/dist/shared-lock/contracts/shared-lock-state.contract.js +1 -0
  1192. package/dist/shared-lock/contracts/shared-lock-state.contract.js.map +1 -1
  1193. package/dist/shared-lock/contracts/shared-lock.contract.d.ts +33 -51
  1194. package/dist/shared-lock/contracts/shared-lock.contract.js +5 -0
  1195. package/dist/shared-lock/contracts/shared-lock.contract.js.map +1 -1
  1196. package/dist/shared-lock/contracts/shared-lock.errors.d.ts +37 -0
  1197. package/dist/shared-lock/contracts/shared-lock.errors.js +52 -0
  1198. package/dist/shared-lock/contracts/shared-lock.errors.js.map +1 -1
  1199. package/dist/shared-lock/contracts/shared-lock.events.d.ts +1 -1
  1200. package/dist/shared-lock/contracts/shared-lock.events.js +1 -0
  1201. package/dist/shared-lock/contracts/shared-lock.events.js.map +1 -1
  1202. package/dist/shared-lock/contracts/types.d.ts +2 -2
  1203. package/dist/shared-lock/contracts/types.js +2 -1
  1204. package/dist/shared-lock/contracts/types.js.map +1 -1
  1205. package/dist/shared-lock/implementations/adapters/{_module-exports.js → _module.js} +1 -1
  1206. package/dist/shared-lock/implementations/adapters/_module.js.map +1 -0
  1207. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module-exports.d.ts +1 -0
  1208. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module-exports.js +2 -0
  1209. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module-exports.js.map +1 -0
  1210. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.d.ts +21 -14
  1211. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.js +15 -8
  1212. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.js.map +1 -1
  1213. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module-exports.d.ts +1 -0
  1214. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module-exports.js +2 -0
  1215. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module-exports.js.map +1 -0
  1216. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.d.ts +15 -12
  1217. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.js +12 -7
  1218. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.js.map +1 -1
  1219. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module-exports.d.ts +1 -0
  1220. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module-exports.js +2 -0
  1221. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module-exports.js.map +1 -0
  1222. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.d.ts +15 -15
  1223. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.js +10 -8
  1224. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.js.map +1 -1
  1225. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module-exports.d.ts +1 -0
  1226. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module-exports.js +2 -0
  1227. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module-exports.js.map +1 -0
  1228. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.d.ts +3 -3
  1229. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.js +3 -1
  1230. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.js.map +1 -1
  1231. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module-exports.d.ts +1 -0
  1232. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module-exports.js +2 -0
  1233. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module-exports.js.map +1 -0
  1234. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.d.ts +6 -6
  1235. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.js +6 -3
  1236. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.js.map +1 -1
  1237. package/dist/shared-lock/implementations/derivables/_module.d.ts +2 -0
  1238. package/dist/shared-lock/implementations/derivables/_module.js +3 -0
  1239. package/dist/shared-lock/implementations/derivables/_module.js.map +1 -0
  1240. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.d.ts +2 -3
  1241. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.js +6 -3
  1242. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.js.map +1 -1
  1243. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.d.ts +1 -1
  1244. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.js +1 -0
  1245. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.js.map +1 -1
  1246. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-shared-lock-adapter.d.ts +8 -0
  1247. package/dist/shared-lock/implementations/derivables/shared-lock-provider/{resolve-database-shared-lock-adapter.js → resolve-shared-lock-adapter.js} +4 -3
  1248. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-shared-lock-adapter.js.map +1 -0
  1249. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.d.ts +43 -27
  1250. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js +32 -22
  1251. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js.map +1 -1
  1252. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.d.ts +6 -6
  1253. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js +6 -3
  1254. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js.map +1 -1
  1255. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.d.ts +31 -35
  1256. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js +17 -68
  1257. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js.map +1 -1
  1258. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.d.ts +19 -19
  1259. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js +22 -15
  1260. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js.map +1 -1
  1261. package/dist/shared-lock/implementations/test-utilities/_module.d.ts +3 -0
  1262. package/dist/shared-lock/implementations/test-utilities/_module.js +4 -0
  1263. package/dist/shared-lock/implementations/test-utilities/_module.js.map +1 -0
  1264. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.d.ts +20 -15
  1265. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.js +24 -13
  1266. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.js.map +1 -1
  1267. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.d.ts +3 -3
  1268. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.js +5 -5
  1269. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.js.map +1 -1
  1270. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.d.ts +6 -6
  1271. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.js +1008 -2498
  1272. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.js.map +1 -1
  1273. package/dist/task/contracts/_module-exports.d.ts +1 -0
  1274. package/dist/task/contracts/_module-exports.js +2 -0
  1275. package/dist/task/contracts/_module-exports.js.map +1 -0
  1276. package/dist/task/contracts/_module.d.ts +1 -0
  1277. package/dist/task/contracts/_module.js +2 -0
  1278. package/dist/task/contracts/_module.js.map +1 -0
  1279. package/dist/task/contracts/task.contract.d.ts +20 -0
  1280. package/dist/task/contracts/task.contract.js +6 -0
  1281. package/dist/task/contracts/task.contract.js.map +1 -0
  1282. package/dist/task/implementations/_module-exports.d.ts +1 -0
  1283. package/dist/task/implementations/_module-exports.js +2 -0
  1284. package/dist/task/implementations/_module-exports.js.map +1 -0
  1285. package/dist/task/implementations/_module.d.ts +1 -0
  1286. package/dist/task/implementations/_module.js +2 -0
  1287. package/dist/task/implementations/_module.js.map +1 -0
  1288. package/dist/task/implementations/abort-and-fail.js.map +1 -0
  1289. package/dist/task/{task.d.ts → implementations/task.d.ts} +27 -25
  1290. package/dist/task/{task.js → implementations/task.js} +19 -10
  1291. package/dist/task/implementations/task.js.map +1 -0
  1292. package/dist/time-span/contracts/_module.d.ts +1 -0
  1293. package/dist/time-span/contracts/_module.js +2 -0
  1294. package/dist/time-span/contracts/_module.js.map +1 -0
  1295. package/dist/time-span/implementations/_module.d.ts +1 -0
  1296. package/dist/time-span/implementations/_module.js +2 -0
  1297. package/dist/time-span/implementations/_module.js.map +1 -0
  1298. package/dist/time-span/implementations/time-span.d.ts +3 -3
  1299. package/dist/time-span/implementations/time-span.js +4 -2
  1300. package/dist/time-span/implementations/time-span.js.map +1 -1
  1301. package/dist/utilities/_module-exports.d.ts +2 -3
  1302. package/dist/utilities/_module-exports.js +0 -3
  1303. package/dist/utilities/_module-exports.js.map +1 -1
  1304. package/dist/utilities/_module.d.ts +5 -0
  1305. package/dist/utilities/_module.js +4 -0
  1306. package/dist/utilities/_module.js.map +1 -0
  1307. package/dist/utilities/contracts/_module.d.ts +5 -5
  1308. package/dist/utilities/contracts/_module.js +1 -5
  1309. package/dist/utilities/contracts/_module.js.map +1 -1
  1310. package/dist/utilities/errors.d.ts +2 -10
  1311. package/dist/utilities/errors.js +2 -13
  1312. package/dist/utilities/errors.js.map +1 -1
  1313. package/dist/utilities/functions/_module.d.ts +9 -2
  1314. package/dist/utilities/functions/_module.js +9 -2
  1315. package/dist/utilities/functions/_module.js.map +1 -1
  1316. package/dist/utilities/functions/array-like-to-iterable.d.ts +7 -0
  1317. package/dist/utilities/functions/array-like-to-iterable.js +20 -0
  1318. package/dist/utilities/functions/array-like-to-iterable.js.map +1 -0
  1319. package/dist/utilities/functions/error-policy.d.ts +7 -7
  1320. package/dist/utilities/functions/error-policy.js +17 -28
  1321. package/dist/utilities/functions/error-policy.js.map +1 -1
  1322. package/dist/utilities/functions/invokable.d.ts +2 -2
  1323. package/dist/utilities/functions/invokable.js +3 -1
  1324. package/dist/utilities/functions/invokable.js.map +1 -1
  1325. package/dist/utilities/functions/is-array-like.d.ts +7 -0
  1326. package/dist/utilities/functions/is-array-like.js +17 -0
  1327. package/dist/utilities/functions/is-array-like.js.map +1 -0
  1328. package/dist/utilities/functions/is-async-iterable.d.ts +7 -0
  1329. package/dist/utilities/functions/is-async-iterable.js +14 -0
  1330. package/dist/utilities/functions/is-async-iterable.js.map +1 -0
  1331. package/dist/utilities/functions/is-class.d.ts +1 -1
  1332. package/dist/utilities/functions/is-class.js +1 -0
  1333. package/dist/utilities/functions/is-class.js.map +1 -1
  1334. package/dist/utilities/functions/is-iterable.d.ts +7 -0
  1335. package/dist/utilities/functions/is-iterable.js +13 -0
  1336. package/dist/utilities/functions/is-iterable.js.map +1 -0
  1337. package/dist/utilities/functions/is-standard-schema.d.ts +1 -1
  1338. package/dist/utilities/functions/is-standard-schema.js +1 -0
  1339. package/dist/utilities/functions/is-standard-schema.js.map +1 -1
  1340. package/dist/utilities/functions/iterable-to-async-iterable.d.ts +7 -0
  1341. package/dist/utilities/functions/iterable-to-async-iterable.js +17 -0
  1342. package/dist/utilities/functions/iterable-to-async-iterable.js.map +1 -0
  1343. package/dist/utilities/functions/lazy.d.ts +4 -4
  1344. package/dist/utilities/functions/lazy.js +5 -3
  1345. package/dist/utilities/functions/lazy.js.map +1 -1
  1346. package/dist/utilities/functions/resolve-async-iterable-value.d.ts +8 -0
  1347. package/dist/utilities/functions/resolve-async-iterable-value.js +21 -0
  1348. package/dist/utilities/functions/resolve-async-iterable-value.js.map +1 -0
  1349. package/dist/utilities/functions/resolve-iterable-value.d.ts +8 -0
  1350. package/dist/utilities/functions/resolve-iterable-value.js +16 -0
  1351. package/dist/utilities/functions/resolve-iterable-value.js.map +1 -0
  1352. package/dist/utilities/functions/resolve-one-or-more.js +1 -1
  1353. package/dist/utilities/functions/resolve-one-or-more.js.map +1 -1
  1354. package/dist/utilities/functions/validate.d.ts +1 -1
  1355. package/dist/utilities/functions/validate.js +1 -0
  1356. package/dist/utilities/functions/validate.js.map +1 -1
  1357. package/dist/utilities/functions/with-jitter.d.ts +15 -0
  1358. package/dist/utilities/functions/with-jitter.js +14 -0
  1359. package/dist/utilities/functions/with-jitter.js.map +1 -0
  1360. package/dist/utilities/types/_module.d.ts +4 -4
  1361. package/dist/utilities/types/_module.js +1 -4
  1362. package/dist/utilities/types/_module.js.map +1 -1
  1363. package/dist/utilities/types/async-iterable-value.type.d.ts +6 -1
  1364. package/package.json +207 -28
  1365. package/dist/backoff-policies/constant-backoff-policy/_module.d.ts +0 -1
  1366. package/dist/backoff-policies/constant-backoff-policy/_module.js +0 -2
  1367. package/dist/backoff-policies/constant-backoff-policy/_module.js.map +0 -1
  1368. package/dist/backoff-policies/constant-backoff-policy/constant-backoff-policy.d.ts +0 -30
  1369. package/dist/backoff-policies/constant-backoff-policy/constant-backoff-policy.js +0 -29
  1370. package/dist/backoff-policies/constant-backoff-policy/constant-backoff-policy.js.map +0 -1
  1371. package/dist/backoff-policies/exponential-backoff-policy/_module.d.ts +0 -1
  1372. package/dist/backoff-policies/exponential-backoff-policy/_module.js +0 -2
  1373. package/dist/backoff-policies/exponential-backoff-policy/_module.js.map +0 -1
  1374. package/dist/backoff-policies/exponential-backoff-policy/exponential-backoff-policy.d.ts +0 -38
  1375. package/dist/backoff-policies/exponential-backoff-policy/exponential-backoff-policy.js +0 -30
  1376. package/dist/backoff-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +0 -1
  1377. package/dist/backoff-policies/linear-backoff-policy/_module.d.ts +0 -1
  1378. package/dist/backoff-policies/linear-backoff-policy/_module.js +0 -2
  1379. package/dist/backoff-policies/linear-backoff-policy/_module.js.map +0 -1
  1380. package/dist/backoff-policies/linear-backoff-policy/linear-backoff-policy.d.ts +0 -34
  1381. package/dist/backoff-policies/linear-backoff-policy/linear-backoff-policy.js +0 -30
  1382. package/dist/backoff-policies/linear-backoff-policy/linear-backoff-policy.js.map +0 -1
  1383. package/dist/backoff-policies/polynomial-backoff-policy/_module.d.ts +0 -1
  1384. package/dist/backoff-policies/polynomial-backoff-policy/_module.js +0 -2
  1385. package/dist/backoff-policies/polynomial-backoff-policy/_module.js.map +0 -1
  1386. package/dist/backoff-policies/polynomial-backoff-policy/polynomial-backoff-policy.d.ts +0 -38
  1387. package/dist/backoff-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +0 -30
  1388. package/dist/backoff-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +0 -1
  1389. package/dist/cache/implementations/adapters/_module-exports.js.map +0 -1
  1390. package/dist/event-bus/implementations/adapters/_module-exports.js.map +0 -1
  1391. package/dist/lock/implementations/adapters/_module-exports.js.map +0 -1
  1392. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.d.ts +0 -9
  1393. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.js.map +0 -1
  1394. package/dist/semaphore/implementations/adapters/_module-exports.js.map +0 -1
  1395. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.d.ts +0 -8
  1396. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.js.map +0 -1
  1397. package/dist/serde/implementations/adapters/_module-exports.js.map +0 -1
  1398. package/dist/shared-lock/implementations/adapters/_module-exports.js.map +0 -1
  1399. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.d.ts +0 -8
  1400. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.js.map +0 -1
  1401. package/dist/task/_module-exports.d.ts +0 -1
  1402. package/dist/task/_module-exports.js +0 -2
  1403. package/dist/task/_module-exports.js.map +0 -1
  1404. package/dist/task/abort-and-fail.js.map +0 -1
  1405. package/dist/task/task.js.map +0 -1
  1406. package/dist/utilities/classes/_module.d.ts +0 -1
  1407. package/dist/utilities/classes/_module.js +0 -2
  1408. package/dist/utilities/classes/_module.js.map +0 -1
  1409. package/dist/utilities/classes/kysely-table-name-transformer-plugin/_module.d.ts +0 -1
  1410. package/dist/utilities/classes/kysely-table-name-transformer-plugin/_module.js +0 -2
  1411. package/dist/utilities/classes/kysely-table-name-transformer-plugin/_module.js.map +0 -1
  1412. package/dist/utilities/classes/kysely-table-name-transformer-plugin/kysely-table-name-transformer-plugin.d.ts +0 -13
  1413. package/dist/utilities/classes/kysely-table-name-transformer-plugin/kysely-table-name-transformer-plugin.js +0 -51
  1414. package/dist/utilities/classes/kysely-table-name-transformer-plugin/kysely-table-name-transformer-plugin.js.map +0 -1
  1415. package/dist/utilities/functions/result.d.ts +0 -91
  1416. package/dist/utilities/functions/result.js +0 -59
  1417. package/dist/utilities/functions/result.js.map +0 -1
  1418. /package/dist/cache/implementations/adapters/{_module-exports.d.ts → _module.d.ts} +0 -0
  1419. /package/dist/event-bus/implementations/adapters/{_module-exports.d.ts → _module.d.ts} +0 -0
  1420. /package/dist/lock/implementations/adapters/{_module-exports.d.ts → _module.d.ts} +0 -0
  1421. /package/dist/semaphore/implementations/adapters/{_module-exports.d.ts → _module.d.ts} +0 -0
  1422. /package/dist/serde/implementations/adapters/{_module-exports.d.ts → _module.d.ts} +0 -0
  1423. /package/dist/shared-lock/implementations/adapters/{_module-exports.d.ts → _module.d.ts} +0 -0
  1424. /package/dist/task/{abort-and-fail.d.ts → implementations/abort-and-fail.d.ts} +0 -0
  1425. /package/dist/task/{abort-and-fail.js → implementations/abort-and-fail.js} +0 -0
@@ -2,11 +2,12 @@
2
2
  * @module Semaphore
3
3
  */
4
4
  import { vi, } from "vitest";
5
- import { LimitReachedSemaphoreError, SEMAPHORE_EVENTS, FailedReleaseSemaphoreError, FailedRefreshSemaphoreError, SEMAPHORE_STATE, } from "../../../semaphore/contracts/_module-exports.js";
6
- import { RESULT, resultSuccess, } from "../../../utilities/_module-exports.js";
7
- import { Task } from "../../../task/_module-exports.js";
8
- import { TimeSpan } from "../../../time-span/implementations/_module-exports.js";
9
- import { TO_MILLISECONDS } from "../../../time-span/contracts/_module-exports.js";
5
+ import { LimitReachedSemaphoreError, SEMAPHORE_EVENTS, FailedReleaseSemaphoreError, FailedRefreshSemaphoreError, SEMAPHORE_STATE, } from "../../../semaphore/contracts/_module.js";
6
+ import {} from "../../../serde/contracts/_module.js";
7
+ import { Task } from "../../../task/implementations/_module.js";
8
+ import { TO_MILLISECONDS } from "../../../time-span/contracts/_module.js";
9
+ import { TimeSpan } from "../../../time-span/implementations/_module.js";
10
+ import {} from "../../../utilities/_module.js";
10
11
  /**
11
12
  * The `semaphoreProviderTestSuite` function simplifies the process of testing your custom implementation of {@link ISemaphore | `ISemaphore`} with `vitest`.
12
13
  *
@@ -15,13 +16,13 @@ import { TO_MILLISECONDS } from "../../../time-span/contracts/_module-exports.js
15
16
  * @example
16
17
  * ```ts
17
18
  * import { describe, expect, test, beforeEach } from "vitest";
18
- * import { MemorySemaphoreAdapter } from "@daiso-tech/core/semaphore/adapters";
19
+ * import { MemorySemaphoreAdapter } from "@daiso-tech/core/semaphore/memory-semaphore-adapter";
19
20
  * import { SemaphoreProvider } from "@daiso-tech/core/semaphore";
20
21
  * import { EventBus } from "@daiso-tech/core/event-bus";
21
- * import { MemoryEventBusAdapter } from "@daiso-tech/core/event-bus/adapters";
22
+ * import { MemoryEventBusAdapter } from "@daiso-tech/core/event-bus/memory-event-bus-adapter";
22
23
  * import { semaphoreProviderTestSuite } from "@daiso-tech/core/semaphore/test-utilities";
23
24
  * import { Serde } from "@daiso-tech/core/serde";
24
- * import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/adapters";
25
+ * import { SuperJsonSerdeAdapter } from "@daiso-tech/core/serde/super-json-serde-adapter";
25
26
  * import type { ISemaphoreData } from "@daiso-tech/core/semaphore/contracts";
26
27
  *
27
28
  * describe("class: SemaphoreProvider", () => {
@@ -58,667 +59,8 @@ export function semaphoreProviderTestSuite(settings) {
58
59
  serde = serde_;
59
60
  });
60
61
  describe("Api tests:", () => {
61
- describe("method: run", () => {
62
- test("Should call acquire method", async () => {
63
- const key = "a";
64
- const ttl = null;
65
- const limit = 1;
66
- const semaphore = semaphoreProvider.create(key, {
67
- ttl,
68
- limit,
69
- });
70
- const acquireSpy = vi.spyOn(semaphore, "acquire");
71
- await semaphore.run(() => {
72
- return Promise.resolve(RETURN_VALUE);
73
- });
74
- expect(acquireSpy).toHaveBeenCalledTimes(1);
75
- });
76
- test("Should call acquire before release method", async () => {
77
- const key = "a";
78
- const ttl = null;
79
- const limit = 1;
80
- const semaphore = semaphoreProvider.create(key, {
81
- ttl,
82
- limit,
83
- });
84
- const acquireSpy = vi.spyOn(semaphore, "acquire");
85
- const releaseSpy = vi.spyOn(semaphore, "release");
86
- await semaphore.run(() => {
87
- return Promise.resolve(RETURN_VALUE);
88
- });
89
- expect(acquireSpy).toHaveBeenCalledBefore(releaseSpy);
90
- });
91
- test("Should call release method", async () => {
92
- const key = "a";
93
- const ttl = null;
94
- const limit = 1;
95
- const semaphore = semaphoreProvider.create(key, {
96
- ttl,
97
- limit,
98
- });
99
- const releaseSpy = vi.spyOn(semaphore, "release");
100
- await semaphore.run(() => {
101
- return Promise.resolve(RETURN_VALUE);
102
- });
103
- expect(releaseSpy).toHaveBeenCalledTimes(1);
104
- });
105
- test("Should call release after acquire method", async () => {
106
- const key = "a";
107
- const ttl = null;
108
- const limit = 1;
109
- const semaphore = semaphoreProvider.create(key, {
110
- ttl,
111
- limit,
112
- });
113
- const releaseSpy = vi.spyOn(semaphore, "release");
114
- const acquireSpy = vi.spyOn(semaphore, "acquire");
115
- await semaphore.run(() => {
116
- return Promise.resolve(RETURN_VALUE);
117
- });
118
- expect(releaseSpy).toHaveBeenCalledAfter(acquireSpy);
119
- });
120
- test("Should call release when an error is thrown", async () => {
121
- const key = "a";
122
- const ttl = null;
123
- const limit = 1;
124
- const semaphore = semaphoreProvider.create(key, {
125
- ttl,
126
- limit,
127
- });
128
- const releaseSpy = vi.spyOn(semaphore, "release");
129
- try {
130
- await semaphore.run(() => {
131
- return Promise.reject(new Error());
132
- });
133
- }
134
- catch {
135
- /* EMPTY */
136
- }
137
- expect(releaseSpy).toHaveBeenCalledTimes(1);
138
- });
139
- test("Should propagate thrown error", async () => {
140
- const key = "a";
141
- const ttl = null;
142
- const limit = 1;
143
- const semaphore = semaphoreProvider.create(key, {
144
- ttl,
145
- limit,
146
- });
147
- class CustomError extends Error {
148
- }
149
- const error = semaphore.run(() => {
150
- return Promise.reject(new CustomError());
151
- });
152
- await expect(error).rejects.toBeInstanceOf(CustomError);
153
- });
154
- test("Should call handler function when key doesnt exists", async () => {
155
- const key = "a";
156
- const ttl = null;
157
- const limit = 1;
158
- const handlerFn = vi.fn(() => {
159
- return Promise.resolve(RETURN_VALUE);
160
- });
161
- await semaphoreProvider
162
- .create(key, {
163
- ttl,
164
- limit,
165
- })
166
- .run(handlerFn);
167
- expect(handlerFn).toHaveBeenCalledTimes(1);
168
- });
169
- test("Should call handler function when key doesnt exists", async () => {
170
- const key = "a";
171
- const ttl = null;
172
- const limit = 1;
173
- const handlerFn = vi.fn(() => {
174
- return Promise.resolve(RETURN_VALUE);
175
- });
176
- await semaphoreProvider
177
- .create(key, {
178
- ttl,
179
- limit,
180
- })
181
- .run(handlerFn);
182
- expect(handlerFn).toHaveBeenCalledTimes(1);
183
- });
184
- test("Should call handler function when slot is expired", async () => {
185
- const key = "a";
186
- const ttl = TimeSpan.fromMilliseconds(50);
187
- const limit = 1;
188
- await semaphoreProvider
189
- .create(key, {
190
- ttl,
191
- limit,
192
- })
193
- .acquire();
194
- await delay(ttl);
195
- const handlerFn = vi.fn(() => {
196
- return Promise.resolve(RETURN_VALUE);
197
- });
198
- await semaphoreProvider
199
- .create(key, {
200
- ttl,
201
- limit,
202
- })
203
- .run(handlerFn);
204
- expect(handlerFn).toHaveBeenCalledTimes(1);
205
- });
206
- test("Should not call handler function when slot is unexpireable", async () => {
207
- const key = "a";
208
- const ttl = null;
209
- const limit = 1;
210
- const semaphore = semaphoreProvider.create(key, {
211
- ttl,
212
- limit,
213
- });
214
- await semaphore.acquire();
215
- const handlerFn = vi.fn(() => {
216
- return Promise.resolve(RETURN_VALUE);
217
- });
218
- await semaphore.run(handlerFn);
219
- expect(handlerFn).not.toHaveBeenCalled();
220
- });
221
- test("Should not call handler function when slot is unexpired", async () => {
222
- const key = "a";
223
- const ttl = TimeSpan.fromMilliseconds(50);
224
- const limit = 1;
225
- const semaphore = semaphoreProvider.create(key, {
226
- ttl,
227
- limit,
228
- });
229
- await semaphore.acquire();
230
- const handlerFn = vi.fn(() => {
231
- return Promise.resolve(RETURN_VALUE);
232
- });
233
- await semaphore.run(handlerFn);
234
- expect(handlerFn).not.toHaveBeenCalled();
235
- });
236
- test("Should not call handler function when slot is unexpireable", async () => {
237
- const key = "a";
238
- const ttl = null;
239
- const limit = 1;
240
- await semaphoreProvider
241
- .create(key, {
242
- ttl,
243
- limit,
244
- })
245
- .acquire();
246
- const handlerFn = vi.fn(() => {
247
- return Promise.resolve(RETURN_VALUE);
248
- });
249
- await semaphoreProvider
250
- .create(key, {
251
- ttl,
252
- limit,
253
- })
254
- .run(handlerFn);
255
- expect(handlerFn).not.toHaveBeenCalled();
256
- });
257
- test("Should not call handler function when slot is unexpired", async () => {
258
- const key = "a";
259
- const ttl = TimeSpan.fromMilliseconds(50);
260
- const limit = 1;
261
- await semaphoreProvider
262
- .create(key, {
263
- ttl,
264
- limit,
265
- })
266
- .acquire();
267
- const handlerFn = vi.fn(() => {
268
- return Promise.resolve(RETURN_VALUE);
269
- });
270
- await semaphoreProvider
271
- .create(key, {
272
- ttl,
273
- limit,
274
- })
275
- .run(handlerFn);
276
- expect(handlerFn).not.toHaveBeenCalled();
277
- });
278
- test("Should return value when key doesnt exists", async () => {
279
- const key = "a";
280
- const ttl = null;
281
- const limit = 1;
282
- const result = await semaphoreProvider
283
- .create(key, {
284
- ttl,
285
- limit,
286
- })
287
- .run(() => {
288
- return Promise.resolve(RETURN_VALUE);
289
- });
290
- expect(result).toEqual(resultSuccess(RETURN_VALUE));
291
- });
292
- test("Should return value when slot is expired", async () => {
293
- const key = "a";
294
- const ttl = TimeSpan.fromMilliseconds(50);
295
- const limit = 1;
296
- await semaphoreProvider
297
- .create(key, {
298
- ttl,
299
- limit,
300
- })
301
- .acquire();
302
- await delay(ttl);
303
- const result = await semaphoreProvider
304
- .create(key, {
305
- ttl,
306
- limit,
307
- })
308
- .run(() => {
309
- return Promise.resolve(RETURN_VALUE);
310
- });
311
- expect(result).toEqual(resultSuccess(RETURN_VALUE));
312
- });
313
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpireable", async () => {
314
- const key = "a";
315
- const ttl = null;
316
- const limit = 1;
317
- const lock = semaphoreProvider.create(key, {
318
- ttl,
319
- limit,
320
- });
321
- await lock.acquire();
322
- const result = await lock.run(() => {
323
- return Promise.resolve(RETURN_VALUE);
324
- });
325
- expect(result).toEqual(expect.objectContaining({
326
- type: RESULT.FAILURE,
327
- error: expect.any(LimitReachedSemaphoreError),
328
- }));
329
- });
330
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpired", async () => {
331
- const key = "a";
332
- const ttl = TimeSpan.fromMilliseconds(50);
333
- const limit = 1;
334
- const lock = semaphoreProvider.create(key, {
335
- ttl,
336
- limit,
337
- });
338
- await lock.acquire();
339
- const result = await lock.run(() => {
340
- return Promise.resolve(RETURN_VALUE);
341
- });
342
- expect(result).toEqual(expect.objectContaining({
343
- type: RESULT.FAILURE,
344
- error: expect.any(LimitReachedSemaphoreError),
345
- }));
346
- });
347
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpireable", async () => {
348
- const key = "a";
349
- const ttl = null;
350
- const limit = 1;
351
- await semaphoreProvider
352
- .create(key, {
353
- ttl,
354
- limit,
355
- })
356
- .acquire();
357
- const result = await semaphoreProvider
358
- .create(key, {
359
- ttl,
360
- limit,
361
- })
362
- .run(() => {
363
- return Promise.resolve(RETURN_VALUE);
364
- });
365
- expect(result).toEqual(expect.objectContaining({
366
- type: RESULT.FAILURE,
367
- error: expect.any(LimitReachedSemaphoreError),
368
- }));
369
- });
370
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpired", async () => {
371
- const key = "a";
372
- const ttl = TimeSpan.fromMilliseconds(50);
373
- const limit = 1;
374
- await semaphoreProvider
375
- .create(key, {
376
- ttl,
377
- limit,
378
- })
379
- .acquire();
380
- const result = await semaphoreProvider
381
- .create(key, {
382
- ttl,
383
- limit,
384
- })
385
- .run(() => {
386
- return Promise.resolve(RETURN_VALUE);
387
- });
388
- expect(result).toEqual(expect.objectContaining({
389
- type: RESULT.FAILURE,
390
- error: expect.any(LimitReachedSemaphoreError),
391
- }));
392
- });
393
- });
394
- describe("method: runOrFail", () => {
395
- test("Should call acquireOrFail method", async () => {
396
- const key = "a";
397
- const ttl = null;
398
- const limit = 1;
399
- const semaphore = semaphoreProvider.create(key, {
400
- ttl,
401
- limit,
402
- });
403
- const acquireOrFailSpy = vi.spyOn(semaphore, "acquireOrFail");
404
- await semaphore.runOrFail(() => {
405
- return Promise.resolve(RETURN_VALUE);
406
- });
407
- expect(acquireOrFailSpy).toHaveBeenCalledTimes(1);
408
- });
409
- test("Should call acquireOrFail before release method", async () => {
410
- const key = "a";
411
- const ttl = null;
412
- const limit = 1;
413
- const semaphore = semaphoreProvider.create(key, {
414
- ttl,
415
- limit,
416
- });
417
- const acquireOrFailSpy = vi.spyOn(semaphore, "acquireOrFail");
418
- const releaseSpy = vi.spyOn(semaphore, "release");
419
- await semaphore.runOrFail(() => {
420
- return Promise.resolve(RETURN_VALUE);
421
- });
422
- expect(acquireOrFailSpy).toHaveBeenCalledBefore(releaseSpy);
423
- });
424
- test("Should call release method", async () => {
425
- const key = "a";
426
- const ttl = null;
427
- const limit = 1;
428
- const semaphore = semaphoreProvider.create(key, {
429
- ttl,
430
- limit,
431
- });
432
- const releaseSpy = vi.spyOn(semaphore, "release");
433
- await semaphore.runOrFail(() => {
434
- return Promise.resolve(RETURN_VALUE);
435
- });
436
- expect(releaseSpy).toHaveBeenCalledTimes(1);
437
- });
438
- test("Should call release after acquireOrFail method", async () => {
439
- const key = "a";
440
- const ttl = null;
441
- const limit = 1;
442
- const semaphore = semaphoreProvider.create(key, {
443
- ttl,
444
- limit,
445
- });
446
- const releaseSpy = vi.spyOn(semaphore, "release");
447
- const acquireOrFailSpy = vi.spyOn(semaphore, "acquireOrFail");
448
- await semaphore.runOrFail(() => {
449
- return Promise.resolve(RETURN_VALUE);
450
- });
451
- expect(releaseSpy).toHaveBeenCalledAfter(acquireOrFailSpy);
452
- });
453
- test("Should call release when an error is thrown", async () => {
454
- const key = "a";
455
- const ttl = null;
456
- const limit = 1;
457
- const semaphore = semaphoreProvider.create(key, {
458
- ttl,
459
- limit,
460
- });
461
- const releaseSpy = vi.spyOn(semaphore, "release");
462
- try {
463
- await semaphore.runOrFail(() => {
464
- return Promise.reject(new Error());
465
- });
466
- }
467
- catch {
468
- /* EMPTY */
469
- }
470
- expect(releaseSpy).toHaveBeenCalledTimes(1);
471
- });
472
- test("Should propagate thrown error", async () => {
473
- const key = "a";
474
- const ttl = null;
475
- const limit = 1;
476
- const semaphore = semaphoreProvider.create(key, {
477
- ttl,
478
- limit,
479
- });
480
- class CustomError extends Error {
481
- }
482
- const error = semaphore.runOrFail(() => {
483
- return Promise.reject(new CustomError());
484
- });
485
- await expect(error).rejects.toBeInstanceOf(CustomError);
486
- });
487
- test("Should call handler function when key doesnt exists", async () => {
488
- const key = "a";
489
- const ttl = null;
490
- const limit = 1;
491
- const handlerFn = vi.fn(() => {
492
- return Promise.resolve(RETURN_VALUE);
493
- });
494
- await semaphoreProvider
495
- .create(key, {
496
- ttl,
497
- limit,
498
- })
499
- .runOrFail(handlerFn);
500
- expect(handlerFn).toHaveBeenCalledTimes(1);
501
- });
502
- test("Should call handler function when slot is expired", async () => {
503
- const key = "a";
504
- const ttl = TimeSpan.fromMilliseconds(50);
505
- const limit = 1;
506
- await semaphoreProvider
507
- .create(key, {
508
- ttl,
509
- limit,
510
- })
511
- .acquire();
512
- await delay(ttl);
513
- const handlerFn = vi.fn(() => {
514
- return Promise.resolve(RETURN_VALUE);
515
- });
516
- await semaphoreProvider
517
- .create(key, {
518
- ttl,
519
- limit,
520
- })
521
- .runOrFail(handlerFn);
522
- expect(handlerFn).toHaveBeenCalledTimes(1);
523
- });
524
- test("Should not call handler function when slot is unexpireable", async () => {
525
- const key = "a";
526
- const ttl = null;
527
- const limit = 1;
528
- const semaphore = semaphoreProvider.create(key, {
529
- ttl,
530
- limit,
531
- });
532
- await semaphore.acquire();
533
- const handlerFn = vi.fn(() => {
534
- return Promise.resolve(RETURN_VALUE);
535
- });
536
- try {
537
- await semaphore.runOrFail(handlerFn);
538
- }
539
- catch {
540
- /* EMPTY */
541
- }
542
- expect(handlerFn).not.toHaveBeenCalled();
543
- });
544
- test("Should not call handler function when slot is unexpired", async () => {
545
- const key = "a";
546
- const ttl = TimeSpan.fromMilliseconds(50);
547
- const limit = 1;
548
- const semaphore = semaphoreProvider.create(key, {
549
- ttl,
550
- limit,
551
- });
552
- await semaphore.acquire();
553
- const handlerFn = vi.fn(() => {
554
- return Promise.resolve(RETURN_VALUE);
555
- });
556
- try {
557
- await semaphore.runOrFail(handlerFn);
558
- }
559
- catch {
560
- /* EMPTY */
561
- }
562
- expect(handlerFn).not.toHaveBeenCalled();
563
- });
564
- test("Should not call handler function when slot is unexpireable", async () => {
565
- const key = "a";
566
- const ttl = null;
567
- const limit = 1;
568
- await semaphoreProvider
569
- .create(key, {
570
- ttl,
571
- limit,
572
- })
573
- .acquire();
574
- const handlerFn = vi.fn(() => {
575
- return Promise.resolve(RETURN_VALUE);
576
- });
577
- try {
578
- await semaphoreProvider
579
- .create(key, {
580
- ttl,
581
- limit,
582
- })
583
- .runOrFail(handlerFn);
584
- }
585
- catch {
586
- /* EMPTY */
587
- }
588
- expect(handlerFn).not.toHaveBeenCalled();
589
- });
590
- test("Should not call handler function when slot is unexpired", async () => {
591
- const key = "a";
592
- const ttl = TimeSpan.fromMilliseconds(50);
593
- const limit = 1;
594
- await semaphoreProvider
595
- .create(key, {
596
- ttl,
597
- limit,
598
- })
599
- .acquire();
600
- const handlerFn = vi.fn(() => {
601
- return Promise.resolve(RETURN_VALUE);
602
- });
603
- try {
604
- await semaphoreProvider
605
- .create(key, {
606
- ttl,
607
- limit,
608
- })
609
- .runOrFail(handlerFn);
610
- }
611
- catch {
612
- /* EMPTY */
613
- }
614
- expect(handlerFn).not.toHaveBeenCalled();
615
- });
616
- test("Should return value when key doesnt exists", async () => {
617
- const key = "a";
618
- const ttl = null;
619
- const limit = 1;
620
- const result = await semaphoreProvider
621
- .create(key, {
622
- ttl,
623
- limit,
624
- })
625
- .runOrFail(() => {
626
- return Promise.resolve(RETURN_VALUE);
627
- });
628
- expect(result).toBe(RETURN_VALUE);
629
- });
630
- test("Should return value when slot is expired", async () => {
631
- const key = "a";
632
- const ttl = TimeSpan.fromMilliseconds(50);
633
- const limit = 1;
634
- await semaphoreProvider
635
- .create(key, {
636
- ttl,
637
- limit,
638
- })
639
- .acquire();
640
- await delay(ttl);
641
- const result = await semaphoreProvider
642
- .create(key, {
643
- ttl,
644
- limit,
645
- })
646
- .runOrFail(() => {
647
- return Promise.resolve(RETURN_VALUE);
648
- });
649
- expect(result).toBe(RETURN_VALUE);
650
- });
651
- test("Should throw LimitReachedSemaphoreError when slot is unexpireable", async () => {
652
- const key = "a";
653
- const ttl = null;
654
- const limit = 1;
655
- const lock = semaphoreProvider.create(key, {
656
- ttl,
657
- limit,
658
- });
659
- await lock.acquire();
660
- const result = lock.runOrFail(() => {
661
- return Promise.resolve(RETURN_VALUE);
662
- });
663
- await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
664
- });
665
- test("Should throw LimitReachedSemaphoreError when slot is unexpired", async () => {
666
- const key = "a";
667
- const ttl = TimeSpan.fromMilliseconds(50);
668
- const limit = 1;
669
- const lock = semaphoreProvider.create(key, {
670
- ttl,
671
- limit,
672
- });
673
- await lock.acquire();
674
- const result = lock.runOrFail(() => {
675
- return Promise.resolve(RETURN_VALUE);
676
- });
677
- await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
678
- });
679
- test("Should throw LimitReachedSemaphoreError when slot is unexpireable", async () => {
680
- const key = "a";
681
- const ttl = null;
682
- const limit = 1;
683
- await semaphoreProvider
684
- .create(key, {
685
- ttl,
686
- limit,
687
- })
688
- .acquire();
689
- const result = semaphoreProvider
690
- .create(key, {
691
- ttl,
692
- limit,
693
- })
694
- .runOrFail(() => {
695
- return Promise.resolve(RETURN_VALUE);
696
- });
697
- await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
698
- });
699
- test("Should throw LimitReachedSemaphoreError when slot is unexpired", async () => {
700
- const key = "a";
701
- const ttl = TimeSpan.fromMilliseconds(50);
702
- const limit = 1;
703
- await semaphoreProvider
704
- .create(key, {
705
- ttl,
706
- limit,
707
- })
708
- .acquire();
709
- const result = semaphoreProvider
710
- .create(key, {
711
- ttl,
712
- limit,
713
- })
714
- .runOrFail(() => {
715
- return Promise.resolve(RETURN_VALUE);
716
- });
717
- await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
718
- });
719
- });
720
- describe("method: runBlocking", () => {
721
- test("Should call acquire method", async () => {
62
+ describe("method: runOrFail", () => {
63
+ test("Should call acquireOrFail method", async () => {
722
64
  const key = "a";
723
65
  const ttl = null;
724
66
  const limit = 1;
@@ -726,16 +68,13 @@ export function semaphoreProviderTestSuite(settings) {
726
68
  ttl,
727
69
  limit,
728
70
  });
729
- const acquireSpy = vi.spyOn(semaphore, "acquire");
730
- await semaphore.runBlocking(() => {
71
+ const acquireOrFailSpy = vi.spyOn(semaphore, "acquireOrFail");
72
+ await semaphore.runOrFail(() => {
731
73
  return Promise.resolve(RETURN_VALUE);
732
- }, {
733
- time: TimeSpan.fromMilliseconds(5),
734
- interval: TimeSpan.fromMilliseconds(5),
735
74
  });
736
- expect(acquireSpy).toHaveBeenCalledTimes(1);
75
+ expect(acquireOrFailSpy).toHaveBeenCalledTimes(1);
737
76
  });
738
- test("Should call acquire before release method", async () => {
77
+ test("Should call acquireOrFail before release method", async () => {
739
78
  const key = "a";
740
79
  const ttl = null;
741
80
  const limit = 1;
@@ -743,15 +82,12 @@ export function semaphoreProviderTestSuite(settings) {
743
82
  ttl,
744
83
  limit,
745
84
  });
746
- const acquireSpy = vi.spyOn(semaphore, "acquire");
85
+ const acquireOrFailSpy = vi.spyOn(semaphore, "acquireOrFail");
747
86
  const releaseSpy = vi.spyOn(semaphore, "release");
748
- await semaphore.runBlocking(() => {
87
+ await semaphore.runOrFail(() => {
749
88
  return Promise.resolve(RETURN_VALUE);
750
- }, {
751
- time: TimeSpan.fromMilliseconds(5),
752
- interval: TimeSpan.fromMilliseconds(5),
753
89
  });
754
- expect(acquireSpy).toHaveBeenCalledBefore(releaseSpy);
90
+ expect(acquireOrFailSpy).toHaveBeenCalledBefore(releaseSpy);
755
91
  });
756
92
  test("Should call release method", async () => {
757
93
  const key = "a";
@@ -762,15 +98,12 @@ export function semaphoreProviderTestSuite(settings) {
762
98
  limit,
763
99
  });
764
100
  const releaseSpy = vi.spyOn(semaphore, "release");
765
- await semaphore.runBlocking(() => {
101
+ await semaphore.runOrFail(() => {
766
102
  return Promise.resolve(RETURN_VALUE);
767
- }, {
768
- time: TimeSpan.fromMilliseconds(5),
769
- interval: TimeSpan.fromMilliseconds(5),
770
103
  });
771
104
  expect(releaseSpy).toHaveBeenCalledTimes(1);
772
105
  });
773
- test("Should call release after acquire method", async () => {
106
+ test("Should call release after acquireOrFail method", async () => {
774
107
  const key = "a";
775
108
  const ttl = null;
776
109
  const limit = 1;
@@ -779,14 +112,11 @@ export function semaphoreProviderTestSuite(settings) {
779
112
  limit,
780
113
  });
781
114
  const releaseSpy = vi.spyOn(semaphore, "release");
782
- const acquireSpy = vi.spyOn(semaphore, "acquire");
783
- await semaphore.runBlocking(() => {
115
+ const acquireOrFailSpy = vi.spyOn(semaphore, "acquireOrFail");
116
+ await semaphore.runOrFail(() => {
784
117
  return Promise.resolve(RETURN_VALUE);
785
- }, {
786
- time: TimeSpan.fromMilliseconds(5),
787
- interval: TimeSpan.fromMilliseconds(5),
788
118
  });
789
- expect(releaseSpy).toHaveBeenCalledAfter(acquireSpy);
119
+ expect(releaseSpy).toHaveBeenCalledAfter(acquireOrFailSpy);
790
120
  });
791
121
  test("Should call release when an error is thrown", async () => {
792
122
  const key = "a";
@@ -798,11 +128,8 @@ export function semaphoreProviderTestSuite(settings) {
798
128
  });
799
129
  const releaseSpy = vi.spyOn(semaphore, "release");
800
130
  try {
801
- await semaphore.runBlocking(() => {
131
+ await semaphore.runOrFail(() => {
802
132
  return Promise.reject(new Error());
803
- }, {
804
- time: TimeSpan.fromMilliseconds(5),
805
- interval: TimeSpan.fromMilliseconds(5),
806
133
  });
807
134
  }
808
135
  catch {
@@ -820,11 +147,8 @@ export function semaphoreProviderTestSuite(settings) {
820
147
  });
821
148
  class CustomError extends Error {
822
149
  }
823
- const error = semaphore.runBlocking(() => {
150
+ const error = semaphore.runOrFail(() => {
824
151
  return Promise.reject(new CustomError());
825
- }, {
826
- time: TimeSpan.fromMilliseconds(5),
827
- interval: TimeSpan.fromMilliseconds(5),
828
152
  });
829
153
  await expect(error).rejects.toBeInstanceOf(CustomError);
830
154
  });
@@ -840,10 +164,7 @@ export function semaphoreProviderTestSuite(settings) {
840
164
  ttl,
841
165
  limit,
842
166
  })
843
- .runBlocking(handlerFn, {
844
- time: TimeSpan.fromMilliseconds(5),
845
- interval: TimeSpan.fromMilliseconds(5),
846
- });
167
+ .runOrFail(handlerFn);
847
168
  expect(handlerFn).toHaveBeenCalledTimes(1);
848
169
  });
849
170
  test("Should call handler function when slot is expired", async () => {
@@ -865,10 +186,7 @@ export function semaphoreProviderTestSuite(settings) {
865
186
  ttl,
866
187
  limit,
867
188
  })
868
- .runBlocking(handlerFn, {
869
- time: TimeSpan.fromMilliseconds(5),
870
- interval: TimeSpan.fromMilliseconds(5),
871
- });
189
+ .runOrFail(handlerFn);
872
190
  expect(handlerFn).toHaveBeenCalledTimes(1);
873
191
  });
874
192
  test("Should not call handler function when slot is unexpireable", async () => {
@@ -883,10 +201,12 @@ export function semaphoreProviderTestSuite(settings) {
883
201
  const handlerFn = vi.fn(() => {
884
202
  return Promise.resolve(RETURN_VALUE);
885
203
  });
886
- await semaphore.runBlocking(handlerFn, {
887
- time: TimeSpan.fromMilliseconds(5),
888
- interval: TimeSpan.fromMilliseconds(5),
889
- });
204
+ try {
205
+ await semaphore.runOrFail(handlerFn);
206
+ }
207
+ catch {
208
+ /* EMPTY */
209
+ }
890
210
  expect(handlerFn).not.toHaveBeenCalled();
891
211
  });
892
212
  test("Should not call handler function when slot is unexpired", async () => {
@@ -901,10 +221,12 @@ export function semaphoreProviderTestSuite(settings) {
901
221
  const handlerFn = vi.fn(() => {
902
222
  return Promise.resolve(RETURN_VALUE);
903
223
  });
904
- await semaphore.runBlocking(handlerFn, {
905
- time: TimeSpan.fromMilliseconds(5),
906
- interval: TimeSpan.fromMilliseconds(5),
907
- });
224
+ try {
225
+ await semaphore.runOrFail(handlerFn);
226
+ }
227
+ catch {
228
+ /* EMPTY */
229
+ }
908
230
  expect(handlerFn).not.toHaveBeenCalled();
909
231
  });
910
232
  test("Should not call handler function when slot is unexpireable", async () => {
@@ -920,15 +242,17 @@ export function semaphoreProviderTestSuite(settings) {
920
242
  const handlerFn = vi.fn(() => {
921
243
  return Promise.resolve(RETURN_VALUE);
922
244
  });
923
- await semaphoreProvider
924
- .create(key, {
925
- ttl,
926
- limit,
927
- })
928
- .runBlocking(handlerFn, {
929
- time: TimeSpan.fromMilliseconds(5),
930
- interval: TimeSpan.fromMilliseconds(5),
931
- });
245
+ try {
246
+ await semaphoreProvider
247
+ .create(key, {
248
+ ttl,
249
+ limit,
250
+ })
251
+ .runOrFail(handlerFn);
252
+ }
253
+ catch {
254
+ /* EMPTY */
255
+ }
932
256
  expect(handlerFn).not.toHaveBeenCalled();
933
257
  });
934
258
  test("Should not call handler function when slot is unexpired", async () => {
@@ -944,15 +268,17 @@ export function semaphoreProviderTestSuite(settings) {
944
268
  const handlerFn = vi.fn(() => {
945
269
  return Promise.resolve(RETURN_VALUE);
946
270
  });
947
- await semaphoreProvider
948
- .create(key, {
949
- ttl,
950
- limit,
951
- })
952
- .runBlocking(handlerFn, {
953
- time: TimeSpan.fromMilliseconds(5),
954
- interval: TimeSpan.fromMilliseconds(5),
955
- });
271
+ try {
272
+ await semaphoreProvider
273
+ .create(key, {
274
+ ttl,
275
+ limit,
276
+ })
277
+ .runOrFail(handlerFn);
278
+ }
279
+ catch {
280
+ /* EMPTY */
281
+ }
956
282
  expect(handlerFn).not.toHaveBeenCalled();
957
283
  });
958
284
  test("Should return value when key doesnt exists", async () => {
@@ -964,13 +290,10 @@ export function semaphoreProviderTestSuite(settings) {
964
290
  ttl,
965
291
  limit,
966
292
  })
967
- .runBlocking(() => {
293
+ .runOrFail(() => {
968
294
  return Promise.resolve(RETURN_VALUE);
969
- }, {
970
- time: TimeSpan.fromMilliseconds(5),
971
- interval: TimeSpan.fromMilliseconds(5),
972
295
  });
973
- expect(result).toEqual(resultSuccess(RETURN_VALUE));
296
+ expect(result).toBe(RETURN_VALUE);
974
297
  });
975
298
  test("Should return value when slot is expired", async () => {
976
299
  const key = "a";
@@ -988,15 +311,12 @@ export function semaphoreProviderTestSuite(settings) {
988
311
  ttl,
989
312
  limit,
990
313
  })
991
- .runBlocking(() => {
314
+ .runOrFail(() => {
992
315
  return Promise.resolve(RETURN_VALUE);
993
- }, {
994
- time: TimeSpan.fromMilliseconds(5),
995
- interval: TimeSpan.fromMilliseconds(5),
996
316
  });
997
- expect(result).toEqual(resultSuccess(RETURN_VALUE));
317
+ expect(result).toBe(RETURN_VALUE);
998
318
  });
999
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpireable", async () => {
319
+ test("Should throw LimitReachedSemaphoreError when slot is unexpireable", async () => {
1000
320
  const key = "a";
1001
321
  const ttl = null;
1002
322
  const limit = 1;
@@ -1005,18 +325,12 @@ export function semaphoreProviderTestSuite(settings) {
1005
325
  limit,
1006
326
  });
1007
327
  await lock.acquire();
1008
- const result = await lock.runBlocking(() => {
328
+ const result = lock.runOrFail(() => {
1009
329
  return Promise.resolve(RETURN_VALUE);
1010
- }, {
1011
- time: TimeSpan.fromMilliseconds(5),
1012
- interval: TimeSpan.fromMilliseconds(5),
1013
330
  });
1014
- expect(result).toEqual(expect.objectContaining({
1015
- type: RESULT.FAILURE,
1016
- error: expect.any(LimitReachedSemaphoreError),
1017
- }));
331
+ await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
1018
332
  });
1019
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpired", async () => {
333
+ test("Should throw LimitReachedSemaphoreError when slot is unexpired", async () => {
1020
334
  const key = "a";
1021
335
  const ttl = TimeSpan.fromMilliseconds(50);
1022
336
  const limit = 1;
@@ -1025,18 +339,12 @@ export function semaphoreProviderTestSuite(settings) {
1025
339
  limit,
1026
340
  });
1027
341
  await lock.acquire();
1028
- const result = await lock.runBlocking(() => {
342
+ const result = lock.runOrFail(() => {
1029
343
  return Promise.resolve(RETURN_VALUE);
1030
- }, {
1031
- time: TimeSpan.fromMilliseconds(5),
1032
- interval: TimeSpan.fromMilliseconds(5),
1033
344
  });
1034
- expect(result).toEqual(expect.objectContaining({
1035
- type: RESULT.FAILURE,
1036
- error: expect.any(LimitReachedSemaphoreError),
1037
- }));
345
+ await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
1038
346
  });
1039
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpireable", async () => {
347
+ test("Should throw LimitReachedSemaphoreError when slot is unexpireable", async () => {
1040
348
  const key = "a";
1041
349
  const ttl = null;
1042
350
  const limit = 1;
@@ -1046,23 +354,17 @@ export function semaphoreProviderTestSuite(settings) {
1046
354
  limit,
1047
355
  })
1048
356
  .acquire();
1049
- const result = await semaphoreProvider
357
+ const result = semaphoreProvider
1050
358
  .create(key, {
1051
359
  ttl,
1052
360
  limit,
1053
361
  })
1054
- .runBlocking(() => {
362
+ .runOrFail(() => {
1055
363
  return Promise.resolve(RETURN_VALUE);
1056
- }, {
1057
- time: TimeSpan.fromMilliseconds(5),
1058
- interval: TimeSpan.fromMilliseconds(5),
1059
364
  });
1060
- expect(result).toEqual(expect.objectContaining({
1061
- type: RESULT.FAILURE,
1062
- error: expect.any(LimitReachedSemaphoreError),
1063
- }));
365
+ await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
1064
366
  });
1065
- test("Should return ResultFailure<LimitReachedSemaphoreError> when slot is unexpired", async () => {
367
+ test("Should throw LimitReachedSemaphoreError when slot is unexpired", async () => {
1066
368
  const key = "a";
1067
369
  const ttl = TimeSpan.fromMilliseconds(50);
1068
370
  const limit = 1;
@@ -1072,46 +374,15 @@ export function semaphoreProviderTestSuite(settings) {
1072
374
  limit,
1073
375
  })
1074
376
  .acquire();
1075
- const result = await semaphoreProvider
377
+ const result = semaphoreProvider
1076
378
  .create(key, {
1077
379
  ttl,
1078
380
  limit,
1079
381
  })
1080
- .runBlocking(() => {
1081
- return Promise.resolve(RETURN_VALUE);
1082
- }, {
1083
- time: TimeSpan.fromMilliseconds(5),
1084
- interval: TimeSpan.fromMilliseconds(5),
1085
- });
1086
- expect(result).toEqual(expect.objectContaining({
1087
- type: RESULT.FAILURE,
1088
- error: expect.any(LimitReachedSemaphoreError),
1089
- }));
1090
- });
1091
- test("Should retry acquire the lock", async () => {
1092
- const key = "a";
1093
- const ttl = TimeSpan.fromMilliseconds(50);
1094
- const limit = 1;
1095
- const lock1 = semaphoreProvider.create(key, {
1096
- ttl,
1097
- limit,
1098
- });
1099
- await lock1.acquire();
1100
- let index = 0;
1101
- await semaphoreProvider.addListener(SEMAPHORE_EVENTS.LIMIT_REACHED, (_event) => {
1102
- index++;
1103
- });
1104
- const lock2 = semaphoreProvider.create(key, {
1105
- ttl,
1106
- limit,
1107
- });
1108
- await lock2.runBlocking(() => {
382
+ .runOrFail(() => {
1109
383
  return Promise.resolve(RETURN_VALUE);
1110
- }, {
1111
- time: TimeSpan.fromMilliseconds(55),
1112
- interval: TimeSpan.fromMilliseconds(5),
1113
384
  });
1114
- expect(index).toBeGreaterThan(1);
385
+ await expect(result).rejects.toBeInstanceOf(LimitReachedSemaphoreError);
1115
386
  });
1116
387
  });
1117
388
  describe("method: runBlockingOrFail", () => {
@@ -3082,7 +2353,7 @@ export function semaphoreProviderTestSuite(settings) {
3082
2353
  });
3083
2354
  });
3084
2355
  describe("method: getId", () => {
3085
- test("Should return semaphore id of ILock instance when given explicitly", () => {
2356
+ test("Should return semaphore id of ISemaphore instance when given explicitly", () => {
3086
2357
  const key = "a";
3087
2358
  const limit = 2;
3088
2359
  const slotId = "1";
@@ -3092,7 +2363,7 @@ export function semaphoreProviderTestSuite(settings) {
3092
2363
  });
3093
2364
  expect(semaphore.id).toBe(slotId);
3094
2365
  });
3095
- test("Should return semaphore id of ILock instance when given explicitly", () => {
2366
+ test("Should return semaphore id of ISemaphore instance when given explicitly", () => {
3096
2367
  const key = "a";
3097
2368
  const limit = 2;
3098
2369
  const semaphore = semaphoreProvider.create(key, {