@daiso-tech/core 0.39.0 → 0.41.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (679) hide show
  1. package/dist/backoff-policies/_module-exports.d.ts +5 -0
  2. package/dist/backoff-policies/_module-exports.js +6 -0
  3. package/dist/backoff-policies/_module-exports.js.map +1 -0
  4. package/dist/{async/backof-policies → backoff-policies}/_shared.d.ts +6 -7
  5. package/dist/{async/backof-policies → backoff-policies}/_shared.js +1 -1
  6. package/dist/backoff-policies/_shared.js.map +1 -0
  7. package/dist/backoff-policies/constant-backoff-policy/_module.d.ts +1 -0
  8. package/dist/backoff-policies/constant-backoff-policy/_module.js +2 -0
  9. package/dist/backoff-policies/constant-backoff-policy/_module.js.map +1 -0
  10. package/dist/{async/backof-policies → backoff-policies}/constant-backoff-policy/constant-backoff-policy.d.ts +6 -8
  11. package/dist/{async/backof-policies → backoff-policies}/constant-backoff-policy/constant-backoff-policy.js +8 -10
  12. package/dist/backoff-policies/constant-backoff-policy/constant-backoff-policy.js.map +1 -0
  13. package/dist/backoff-policies/exponential-backoff-policy/_module.d.ts +1 -0
  14. package/dist/backoff-policies/exponential-backoff-policy/_module.js +2 -0
  15. package/dist/backoff-policies/exponential-backoff-policy/_module.js.map +1 -0
  16. package/dist/{async/backof-policies → backoff-policies}/exponential-backoff-policy/exponential-backoff-policy.d.ts +7 -9
  17. package/dist/backoff-policies/exponential-backoff-policy/exponential-backoff-policy.js +30 -0
  18. package/dist/backoff-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +1 -0
  19. package/dist/backoff-policies/linear-backoff-policy/_module.d.ts +1 -0
  20. package/dist/backoff-policies/linear-backoff-policy/_module.js +2 -0
  21. package/dist/backoff-policies/linear-backoff-policy/_module.js.map +1 -0
  22. package/dist/{async/backof-policies → backoff-policies}/linear-backoff-policy/linear-backoff-policy.d.ts +7 -9
  23. package/dist/backoff-policies/linear-backoff-policy/linear-backoff-policy.js +30 -0
  24. package/dist/backoff-policies/linear-backoff-policy/linear-backoff-policy.js.map +1 -0
  25. package/dist/backoff-policies/polynomial-backoff-policy/_module.d.ts +1 -0
  26. package/dist/backoff-policies/polynomial-backoff-policy/_module.js +2 -0
  27. package/dist/backoff-policies/polynomial-backoff-policy/_module.js.map +1 -0
  28. package/dist/{async/backof-policies → backoff-policies}/polynomial-backoff-policy/polynomial-backoff-policy.d.ts +7 -9
  29. package/dist/backoff-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +30 -0
  30. package/dist/backoff-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +1 -0
  31. package/dist/cache/contracts/cache-adapter.contract.d.ts +12 -12
  32. package/dist/cache/contracts/cache.contract.d.ts +22 -22
  33. package/dist/cache/contracts/cache.errors.d.ts +7 -14
  34. package/dist/cache/contracts/cache.errors.js +12 -24
  35. package/dist/cache/contracts/cache.errors.js.map +1 -1
  36. package/dist/cache/contracts/cache.events.d.ts +1 -1
  37. package/dist/cache/contracts/database-cache-adapter.contract.d.ts +10 -10
  38. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.d.ts +1 -1
  39. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js +4 -4
  40. package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js.map +1 -1
  41. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.d.ts +1 -1
  42. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js +2 -2
  43. package/dist/cache/implementations/adapters/memory-cache-adapter/memory-cache-adapter.js.map +1 -1
  44. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.d.ts +3 -2
  45. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js +3 -3
  46. package/dist/cache/implementations/adapters/mongodb-cache-adapter/mongodb-cache-adapter.js.map +1 -1
  47. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.d.ts +10 -10
  48. package/dist/cache/implementations/adapters/no-op-cache-adapter/no-op-cache-adapter.js.map +1 -1
  49. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.d.ts +1 -1
  50. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js +2 -2
  51. package/dist/cache/implementations/adapters/redis-cache-adapter/redis-cache-adapter.js.map +1 -1
  52. package/dist/cache/implementations/derivables/cache/cache.d.ts +38 -43
  53. package/dist/cache/implementations/derivables/cache/cache.js +106 -101
  54. package/dist/cache/implementations/derivables/cache/cache.js.map +1 -1
  55. package/dist/cache/implementations/derivables/cache/database-cache-adapter.d.ts +1 -1
  56. package/dist/cache/implementations/derivables/cache/database-cache-adapter.js +3 -3
  57. package/dist/cache/implementations/derivables/cache/database-cache-adapter.js.map +1 -1
  58. package/dist/cache/implementations/derivables/cache-factory/cache-factory.d.ts +6 -8
  59. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js +5 -15
  60. package/dist/cache/implementations/derivables/cache-factory/cache-factory.js.map +1 -1
  61. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.d.ts +1 -1
  62. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js +48 -48
  63. package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js.map +1 -1
  64. package/dist/cache/implementations/test-utilities/cache.test-suite.js +107 -107
  65. package/dist/cache/implementations/test-utilities/cache.test-suite.js.map +1 -1
  66. package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js +2 -1
  67. package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js.map +1 -1
  68. package/dist/collection/contracts/async-collection.contract.d.ts +43 -43
  69. package/dist/collection/contracts/collection.contract.d.ts +15 -1
  70. package/dist/collection/contracts/collection.contract.js +1 -3
  71. package/dist/collection/contracts/collection.contract.js.map +1 -1
  72. package/dist/collection/contracts/collection.errors.d.ts +4 -13
  73. package/dist/collection/contracts/collection.errors.js +4 -16
  74. package/dist/collection/contracts/collection.errors.js.map +1 -1
  75. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.d.ts +6 -0
  76. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.js +3 -0
  77. package/dist/collection/implementations/async-iterable-collection/_shared/async-validate-iterable.js.map +1 -1
  78. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.d.ts +40 -51
  79. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js +31 -37
  80. package/dist/collection/implementations/async-iterable-collection/async-iterable-collection.js.map +1 -1
  81. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.d.ts +3 -0
  82. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.js +6 -0
  83. package/dist/collection/implementations/iterable-collection/_shared/validate-iterable.js.map +1 -1
  84. package/dist/collection/implementations/iterable-collection/iterable-collection.d.ts +3 -3
  85. package/dist/collection/implementations/iterable-collection/iterable-collection.js +5 -2
  86. package/dist/collection/implementations/iterable-collection/iterable-collection.js.map +1 -1
  87. package/dist/collection/implementations/list-collection/list-collection.d.ts +3 -3
  88. package/dist/collection/implementations/list-collection/list-collection.js +5 -2
  89. package/dist/collection/implementations/list-collection/list-collection.js.map +1 -1
  90. package/dist/event-bus/contracts/event-bus-adapter.contract.d.ts +3 -3
  91. package/dist/event-bus/contracts/event-bus.contract.d.ts +10 -10
  92. package/dist/event-bus/implementations/adapters/no-op-event-bus-adapter/no-op-event-bus-adapter.d.ts +3 -3
  93. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.d.ts +3 -6
  94. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js +7 -9
  95. package/dist/event-bus/implementations/adapters/redis-pub-sub-event-bus-adapter/redis-pub-sub-event-bus-adapter.js.map +1 -1
  96. package/dist/event-bus/implementations/derivables/event-bus/event-bus.d.ts +18 -24
  97. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js +51 -51
  98. package/dist/event-bus/implementations/derivables/event-bus/event-bus.js.map +1 -1
  99. package/dist/event-bus/implementations/derivables/event-bus/listener-store.d.ts +11 -4
  100. package/dist/event-bus/implementations/derivables/event-bus/listener-store.js +17 -12
  101. package/dist/event-bus/implementations/derivables/event-bus/listener-store.js.map +1 -1
  102. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.d.ts +1 -3
  103. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js +4 -8
  104. package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js.map +1 -1
  105. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js +36 -37
  106. package/dist/event-bus/implementations/test-utilities/event-bus-adapter.test-suite.js.map +1 -1
  107. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js +86 -674
  108. package/dist/event-bus/implementations/test-utilities/event-bus.test-suite.js.map +1 -1
  109. package/dist/hooks/_module-exports.d.ts +3 -0
  110. package/dist/hooks/_module-exports.js +4 -0
  111. package/dist/hooks/_module-exports.js.map +1 -0
  112. package/dist/{utilities/classes/hooks → hooks}/async-hooks.d.ts +15 -26
  113. package/dist/{utilities/classes/hooks → hooks}/async-hooks.js +4 -6
  114. package/dist/hooks/async-hooks.js.map +1 -0
  115. package/dist/{utilities/classes/hooks → hooks}/hooks.d.ts +11 -18
  116. package/dist/{utilities/classes/hooks → hooks}/hooks.js +4 -5
  117. package/dist/hooks/hooks.js.map +1 -0
  118. package/dist/{utilities/classes/hooks → hooks}/types.d.ts +2 -3
  119. package/dist/hooks/types.js +5 -0
  120. package/dist/hooks/types.js.map +1 -0
  121. package/dist/lock/contracts/_module-exports.d.ts +4 -2
  122. package/dist/lock/contracts/_module-exports.js +4 -2
  123. package/dist/lock/contracts/_module-exports.js.map +1 -1
  124. package/dist/lock/contracts/database-lock-adapter.contract.d.ts +59 -14
  125. package/dist/lock/contracts/lock-adapter.contract.d.ts +22 -10
  126. package/dist/lock/contracts/lock-provider.contract.d.ts +5 -5
  127. package/dist/lock/contracts/lock-state.contract.d.ts +52 -0
  128. package/dist/lock/contracts/lock-state.contract.js +14 -0
  129. package/dist/lock/contracts/lock-state.contract.js.map +1 -0
  130. package/dist/lock/contracts/lock.contract.d.ts +72 -58
  131. package/dist/lock/contracts/lock.errors.d.ts +18 -15
  132. package/dist/lock/contracts/lock.errors.js +22 -17
  133. package/dist/lock/contracts/lock.errors.js.map +1 -1
  134. package/dist/lock/contracts/lock.events.d.ts +21 -37
  135. package/dist/lock/contracts/lock.events.js +2 -2
  136. package/dist/lock/contracts/lock.events.js.map +1 -1
  137. package/dist/lock/contracts/types.d.ts +11 -0
  138. package/dist/lock/contracts/types.js +5 -0
  139. package/dist/lock/contracts/types.js.map +1 -0
  140. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.d.ts +33 -13
  141. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js +182 -56
  142. package/dist/lock/implementations/adapters/kysely-lock-adapter/kysely-lock-adapter.js.map +1 -1
  143. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.d.ts +25 -9
  144. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js +80 -36
  145. package/dist/lock/implementations/adapters/memory-lock-adapter/memory-lock-adapter.js.map +1 -1
  146. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.d.ts +11 -12
  147. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js +164 -79
  148. package/dist/lock/implementations/adapters/mongodb-lock-adapter/mongodb-lock-adapter.js.map +1 -1
  149. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.d.ts +7 -6
  150. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.js +7 -4
  151. package/dist/lock/implementations/adapters/no-op-lock-adapter/no-op-lock-adapter.js.map +1 -1
  152. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.d.ts +27 -9
  153. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js +87 -32
  154. package/dist/lock/implementations/adapters/redis-lock-adapter/redis-lock-adapter.js.map +1 -1
  155. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.d.ts +7 -6
  156. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js +56 -24
  157. package/dist/lock/implementations/derivables/lock-provider/database-lock-adapter.js.map +1 -1
  158. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.d.ts +2 -2
  159. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.js +7 -7
  160. package/dist/lock/implementations/derivables/lock-provider/is-database-lock-adapter.js.map +1 -1
  161. package/dist/lock/implementations/derivables/lock-provider/lock-provider.d.ts +29 -39
  162. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js +31 -35
  163. package/dist/lock/implementations/derivables/lock-provider/lock-provider.js.map +1 -1
  164. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.d.ts +5 -8
  165. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js +27 -23
  166. package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js.map +1 -1
  167. package/dist/lock/implementations/derivables/lock-provider/lock.d.ts +38 -33
  168. package/dist/lock/implementations/derivables/lock-provider/lock.js +178 -234
  169. package/dist/lock/implementations/derivables/lock-provider/lock.js.map +1 -1
  170. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.d.ts +9 -0
  171. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.js +12 -0
  172. package/dist/lock/implementations/derivables/lock-provider/resolve-database-lock-adapter.js.map +1 -0
  173. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.d.ts +12 -13
  174. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js +7 -16
  175. package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js.map +1 -1
  176. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js +312 -191
  177. package/dist/lock/implementations/test-utilities/database-lock-adapter.test-suite.js.map +1 -1
  178. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.d.ts +1 -1
  179. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js +378 -95
  180. package/dist/lock/implementations/test-utilities/lock-adapter.test-suite.js.map +1 -1
  181. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.d.ts +15 -5
  182. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js +3110 -1611
  183. package/dist/lock/implementations/test-utilities/lock-provider.test-suite.js.map +1 -1
  184. package/dist/namespace/_module-exports.d.ts +1 -0
  185. package/dist/namespace/_module-exports.js +2 -0
  186. package/dist/namespace/_module-exports.js.map +1 -0
  187. package/dist/namespace/namespace.d.ts +87 -0
  188. package/dist/namespace/namespace.js +117 -0
  189. package/dist/namespace/namespace.js.map +1 -0
  190. package/dist/resilience/_module-exports.d.ts +2 -0
  191. package/dist/resilience/_module-exports.js +3 -0
  192. package/dist/resilience/_module-exports.js.map +1 -0
  193. package/dist/resilience/middlewares/_module.d.ts +5 -0
  194. package/dist/resilience/middlewares/_module.js +6 -0
  195. package/dist/resilience/middlewares/_module.js.map +1 -0
  196. package/dist/resilience/middlewares/dynamic/_module.d.ts +1 -0
  197. package/dist/resilience/middlewares/dynamic/_module.js +2 -0
  198. package/dist/resilience/middlewares/dynamic/_module.js.map +1 -0
  199. package/dist/{async → resilience}/middlewares/dynamic/dynamic.middleware.d.ts +6 -6
  200. package/dist/{async → resilience}/middlewares/dynamic/dynamic.middleware.js +5 -5
  201. package/dist/resilience/middlewares/dynamic/dynamic.middleware.js.map +1 -0
  202. package/dist/resilience/middlewares/fallback/_module.d.ts +2 -0
  203. package/dist/resilience/middlewares/fallback/_module.js +3 -0
  204. package/dist/resilience/middlewares/fallback/_module.js.map +1 -0
  205. package/dist/{async → resilience}/middlewares/fallback/fallback.middleware.d.ts +9 -9
  206. package/dist/{async → resilience}/middlewares/fallback/fallback.middleware.js +7 -6
  207. package/dist/resilience/middlewares/fallback/fallback.middleware.js.map +1 -0
  208. package/dist/{async → resilience}/middlewares/fallback/fallback.types.d.ts +7 -6
  209. package/dist/{async → resilience}/middlewares/fallback/fallback.types.js +1 -1
  210. package/dist/resilience/middlewares/fallback/fallback.types.js.map +1 -0
  211. package/dist/resilience/middlewares/observe/_module.d.ts +2 -0
  212. package/dist/resilience/middlewares/observe/_module.js +3 -0
  213. package/dist/resilience/middlewares/observe/_module.js.map +1 -0
  214. package/dist/{async → resilience}/middlewares/observe/observe.middleware.d.ts +13 -11
  215. package/dist/{async → resilience}/middlewares/observe/observe.middleware.js +14 -10
  216. package/dist/resilience/middlewares/observe/observe.middleware.js.map +1 -0
  217. package/dist/{async → resilience}/middlewares/observe/observe.types.d.ts +13 -12
  218. package/dist/resilience/middlewares/observe/observe.types.js +5 -0
  219. package/dist/resilience/middlewares/observe/observe.types.js.map +1 -0
  220. package/dist/resilience/middlewares/retry/_module.d.ts +2 -0
  221. package/dist/resilience/middlewares/retry/_module.js +3 -0
  222. package/dist/resilience/middlewares/retry/_module.js.map +1 -0
  223. package/dist/{async → resilience}/middlewares/retry/retry.middleware.d.ts +12 -9
  224. package/dist/{async → resilience}/middlewares/retry/retry.middleware.js +19 -15
  225. package/dist/resilience/middlewares/retry/retry.middleware.js.map +1 -0
  226. package/dist/{async → resilience}/middlewares/retry/retry.types.d.ts +14 -12
  227. package/dist/resilience/middlewares/retry/retry.types.js +7 -0
  228. package/dist/resilience/middlewares/retry/retry.types.js.map +1 -0
  229. package/dist/resilience/middlewares/timeout/_module.d.ts +2 -0
  230. package/dist/resilience/middlewares/timeout/_module.js +3 -0
  231. package/dist/resilience/middlewares/timeout/_module.js.map +1 -0
  232. package/dist/{async → resilience}/middlewares/timeout/timeout.middleware.d.ts +9 -7
  233. package/dist/{async → resilience}/middlewares/timeout/timeout.middleware.js +12 -11
  234. package/dist/resilience/middlewares/timeout/timeout.middleware.js.map +1 -0
  235. package/dist/{async → resilience}/middlewares/timeout/timeout.type.d.ts +10 -9
  236. package/dist/resilience/middlewares/timeout/timeout.type.js +5 -0
  237. package/dist/resilience/middlewares/timeout/timeout.type.js.map +1 -0
  238. package/dist/resilience/resilience.errors.d.ts +40 -0
  239. package/dist/resilience/resilience.errors.js +48 -0
  240. package/dist/resilience/resilience.errors.js.map +1 -0
  241. package/dist/resilience/utilities/_module.d.ts +2 -0
  242. package/dist/resilience/utilities/_module.js +3 -0
  243. package/dist/resilience/utilities/_module.js.map +1 -0
  244. package/dist/resilience/utilities/abort-and-fail/_module.d.ts +1 -0
  245. package/dist/resilience/utilities/abort-and-fail/_module.js +2 -0
  246. package/dist/resilience/utilities/abort-and-fail/_module.js.map +1 -0
  247. package/dist/resilience/utilities/abort-and-fail/abort-and-fail.d.ts +7 -0
  248. package/dist/resilience/utilities/abort-and-fail/abort-and-fail.js +51 -0
  249. package/dist/resilience/utilities/abort-and-fail/abort-and-fail.js.map +1 -0
  250. package/dist/resilience/utilities/timeout-and-fail/_module.d.ts +1 -0
  251. package/dist/resilience/utilities/timeout-and-fail/_module.js +2 -0
  252. package/dist/resilience/utilities/timeout-and-fail/_module.js.map +1 -0
  253. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.d.ts +7 -0
  254. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.js +23 -0
  255. package/dist/resilience/utilities/timeout-and-fail/timeout-and-fail.js.map +1 -0
  256. package/dist/semaphore/contracts/_module-exports.d.ts +9 -0
  257. package/dist/semaphore/contracts/_module-exports.js +10 -0
  258. package/dist/semaphore/contracts/_module-exports.js.map +1 -0
  259. package/dist/semaphore/contracts/database-semaphore-adapter.contract.d.ts +90 -0
  260. package/dist/semaphore/contracts/database-semaphore-adapter.contract.js +5 -0
  261. package/dist/semaphore/contracts/database-semaphore-adapter.contract.js.map +1 -0
  262. package/dist/semaphore/contracts/semaphore-adapter.contract.d.ts +61 -0
  263. package/dist/semaphore/contracts/semaphore-adapter.contract.js +5 -0
  264. package/dist/semaphore/contracts/semaphore-adapter.contract.js.map +1 -0
  265. package/dist/semaphore/contracts/semaphore-provider-factory.contract.d.ts +19 -0
  266. package/dist/semaphore/contracts/semaphore-provider-factory.contract.js +9 -0
  267. package/dist/semaphore/contracts/semaphore-provider-factory.contract.js.map +1 -0
  268. package/dist/semaphore/contracts/semaphore-provider.contract.d.ts +50 -0
  269. package/dist/semaphore/contracts/semaphore-provider.contract.js +5 -0
  270. package/dist/semaphore/contracts/semaphore-provider.contract.js.map +1 -0
  271. package/dist/semaphore/contracts/semaphore-state.contract.d.ts +70 -0
  272. package/dist/semaphore/contracts/semaphore-state.contract.js +15 -0
  273. package/dist/semaphore/contracts/semaphore-state.contract.js.map +1 -0
  274. package/dist/semaphore/contracts/semaphore.contract.d.ts +127 -0
  275. package/dist/semaphore/contracts/semaphore.contract.js +5 -0
  276. package/dist/semaphore/contracts/semaphore.contract.js.map +1 -0
  277. package/dist/semaphore/contracts/semaphore.errors.d.ts +52 -0
  278. package/dist/semaphore/contracts/semaphore.errors.js +63 -0
  279. package/dist/semaphore/contracts/semaphore.errors.js.map +1 -0
  280. package/dist/semaphore/contracts/semaphore.events.d.ts +101 -0
  281. package/dist/semaphore/contracts/semaphore.events.js +19 -0
  282. package/dist/semaphore/contracts/semaphore.events.js.map +1 -0
  283. package/dist/semaphore/contracts/types.d.ts +11 -0
  284. package/dist/semaphore/contracts/types.js +5 -0
  285. package/dist/semaphore/contracts/types.js.map +1 -0
  286. package/dist/semaphore/implementations/adapters/_module-exports.d.ts +5 -0
  287. package/dist/semaphore/implementations/adapters/_module-exports.js +6 -0
  288. package/dist/semaphore/implementations/adapters/_module-exports.js.map +1 -0
  289. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module.d.ts +1 -0
  290. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module.js +2 -0
  291. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/_module.js.map +1 -0
  292. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.d.ts +97 -0
  293. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.js +313 -0
  294. package/dist/semaphore/implementations/adapters/kysely-semaphore-adapter/kysely-semaphore-adapter.js.map +1 -0
  295. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module.d.ts +1 -0
  296. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module.js +2 -0
  297. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/_module.js.map +1 -0
  298. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.d.ts +49 -0
  299. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.js +141 -0
  300. package/dist/semaphore/implementations/adapters/memory-semaphore-adapter/memory-semaphore-adapter.js.map +1 -0
  301. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module.d.ts +1 -0
  302. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module.js +2 -0
  303. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/_module.js.map +1 -0
  304. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.d.ts +80 -0
  305. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.js +390 -0
  306. package/dist/semaphore/implementations/adapters/mongodb-semaphore-adapter/mongodb-semaphore-adapter.js.map +1 -0
  307. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module.d.ts +1 -0
  308. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module.js +2 -0
  309. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/_module.js.map +1 -0
  310. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.d.ts +18 -0
  311. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.js +30 -0
  312. package/dist/semaphore/implementations/adapters/no-op-semaphore-adapter/no-op-semaphore-adapter.js.map +1 -0
  313. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module.d.ts +1 -0
  314. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module.js +2 -0
  315. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/_module.js.map +1 -0
  316. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.d.ts +48 -0
  317. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.js +338 -0
  318. package/dist/semaphore/implementations/adapters/redis-semaphore-adapter/redis-semaphore-adapter.js.map +1 -0
  319. package/dist/semaphore/implementations/derivables/_module-exports.d.ts +2 -0
  320. package/dist/semaphore/implementations/derivables/_module-exports.js +3 -0
  321. package/dist/semaphore/implementations/derivables/_module-exports.js.map +1 -0
  322. package/dist/semaphore/implementations/derivables/semaphore-provider/_module.d.ts +1 -0
  323. package/dist/semaphore/implementations/derivables/semaphore-provider/_module.js +2 -0
  324. package/dist/semaphore/implementations/derivables/semaphore-provider/_module.js.map +1 -0
  325. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.d.ts +17 -0
  326. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.js +74 -0
  327. package/dist/semaphore/implementations/derivables/semaphore-provider/database-semaphore-adapter.js.map +1 -0
  328. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.d.ts +8 -0
  329. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.js +15 -0
  330. package/dist/semaphore/implementations/derivables/semaphore-provider/is-database-semaphore-adapter.js.map +1 -0
  331. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.d.ts +8 -0
  332. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.js +15 -0
  333. package/dist/semaphore/implementations/derivables/semaphore-provider/resolve-database-semaphore-adapter.js.map +1 -0
  334. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.d.ts +149 -0
  335. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js +135 -0
  336. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js.map +1 -0
  337. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.d.ts +41 -0
  338. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js +77 -0
  339. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js.map +1 -0
  340. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.d.ts +83 -0
  341. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js +336 -0
  342. package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js.map +1 -0
  343. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.d.ts +1 -0
  344. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.js +2 -0
  345. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/_module.js.map +1 -0
  346. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.d.ts +40 -0
  347. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js +67 -0
  348. package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js.map +1 -0
  349. package/dist/semaphore/implementations/test-utilities/_module-exports.d.ts +3 -0
  350. package/dist/semaphore/implementations/test-utilities/_module-exports.js +4 -0
  351. package/dist/semaphore/implementations/test-utilities/_module-exports.js.map +1 -0
  352. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.d.ts +59 -0
  353. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.js +536 -0
  354. package/dist/semaphore/implementations/test-utilities/database-semaphore-adapter.test-suite.js.map +1 -0
  355. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.d.ts +59 -0
  356. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.js +961 -0
  357. package/dist/semaphore/implementations/test-utilities/semaphore-adapter.test-suite.js.map +1 -0
  358. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.d.ts +67 -0
  359. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.js +4981 -0
  360. package/dist/semaphore/implementations/test-utilities/semaphore-provider.test-suite.js.map +1 -0
  361. package/dist/serde/contracts/_module-exports.d.ts +0 -1
  362. package/dist/serde/contracts/_module-exports.js +0 -1
  363. package/dist/serde/contracts/_module-exports.js.map +1 -1
  364. package/dist/serde/contracts/flexible-serde.contract.d.ts +21 -5
  365. package/dist/serde/contracts/serde.errors.d.ts +14 -11
  366. package/dist/serde/contracts/serde.errors.js +15 -14
  367. package/dist/serde/contracts/serde.errors.js.map +1 -1
  368. package/dist/serde/implementations/adapters/_module-exports.d.ts +0 -3
  369. package/dist/serde/implementations/adapters/_module-exports.js +0 -3
  370. package/dist/serde/implementations/adapters/_module-exports.js.map +1 -1
  371. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js +6 -0
  372. package/dist/serde/implementations/adapters/super-json-serde-adapter/super-json-serde-adapter.js.map +1 -1
  373. package/dist/serde/implementations/derivables/serde-transformers.d.ts +38 -30
  374. package/dist/serde/implementations/derivables/serde-transformers.js +62 -20
  375. package/dist/serde/implementations/derivables/serde-transformers.js.map +1 -1
  376. package/dist/serde/implementations/derivables/serde.d.ts +12 -3
  377. package/dist/serde/implementations/derivables/serde.js +5 -2
  378. package/dist/serde/implementations/derivables/serde.js.map +1 -1
  379. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js +85 -1
  380. package/dist/serde/implementations/test-utilities/flexible-serde-adapter.test-suite.js.map +1 -1
  381. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js +85 -1
  382. package/dist/serde/implementations/test-utilities/flexible-serde.test-suite.js.map +1 -1
  383. package/dist/shared-lock/contracts/_module-exports.d.ts +10 -0
  384. package/dist/shared-lock/contracts/_module-exports.js +11 -0
  385. package/dist/shared-lock/contracts/_module-exports.js.map +1 -0
  386. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.d.ts +145 -0
  387. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.js +5 -0
  388. package/dist/shared-lock/contracts/database-shared-lock-adapter.contract.js.map +1 -0
  389. package/dist/shared-lock/contracts/shared-lock-adapter.contract.d.ts +96 -0
  390. package/dist/shared-lock/contracts/shared-lock-adapter.contract.js +5 -0
  391. package/dist/shared-lock/contracts/shared-lock-adapter.contract.js.map +1 -0
  392. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.d.ts +19 -0
  393. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.js +9 -0
  394. package/dist/shared-lock/contracts/shared-lock-provider-factory.contract.js.map +1 -0
  395. package/dist/shared-lock/contracts/shared-lock-provider.contract.d.ts +53 -0
  396. package/dist/shared-lock/contracts/shared-lock-provider.contract.js +5 -0
  397. package/dist/shared-lock/contracts/shared-lock-provider.contract.js.map +1 -0
  398. package/dist/shared-lock/contracts/shared-lock-state.contract.d.ts +133 -0
  399. package/dist/shared-lock/contracts/shared-lock-state.contract.js +33 -0
  400. package/dist/shared-lock/contracts/shared-lock-state.contract.js.map +1 -0
  401. package/dist/shared-lock/contracts/shared-lock.contract.d.ts +222 -0
  402. package/dist/shared-lock/contracts/shared-lock.contract.js +13 -0
  403. package/dist/shared-lock/contracts/shared-lock.contract.js.map +1 -0
  404. package/dist/shared-lock/contracts/shared-lock.errors.d.ts +124 -0
  405. package/dist/shared-lock/contracts/shared-lock.errors.js +136 -0
  406. package/dist/shared-lock/contracts/shared-lock.errors.js.map +1 -0
  407. package/dist/shared-lock/contracts/shared-lock.events.d.ts +205 -0
  408. package/dist/shared-lock/contracts/shared-lock.events.js +43 -0
  409. package/dist/shared-lock/contracts/shared-lock.events.js.map +1 -0
  410. package/dist/shared-lock/contracts/types.d.ts +10 -0
  411. package/dist/shared-lock/contracts/types.js +5 -0
  412. package/dist/shared-lock/contracts/types.js.map +1 -0
  413. package/dist/shared-lock/implementations/adapters/_module-exports.d.ts +5 -0
  414. package/dist/shared-lock/implementations/adapters/_module-exports.js +6 -0
  415. package/dist/shared-lock/implementations/adapters/_module-exports.js.map +1 -0
  416. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module.d.ts +1 -0
  417. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module.js +2 -0
  418. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/_module.js.map +1 -0
  419. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.d.ts +114 -0
  420. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.js +496 -0
  421. package/dist/shared-lock/implementations/adapters/kysely-shared-lock-adapter/kysely-shared-lock-adapter.js.map +1 -0
  422. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module.d.ts +1 -0
  423. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module.js +2 -0
  424. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/_module.js.map +1 -0
  425. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.d.ts +79 -0
  426. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.js +347 -0
  427. package/dist/shared-lock/implementations/adapters/memory-shared-lock-adapter/memory-shared-lock-adapter.js.map +1 -0
  428. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module.d.ts +1 -0
  429. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module.js +2 -0
  430. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/_module.js.map +1 -0
  431. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.d.ts +112 -0
  432. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.js +805 -0
  433. package/dist/shared-lock/implementations/adapters/mongodb-shared-lock-adapter/mongodb-shared-lock-adapter.js.map +1 -0
  434. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module.d.ts +1 -0
  435. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module.js +2 -0
  436. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/_module.js.map +1 -0
  437. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.d.ts +23 -0
  438. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.js +42 -0
  439. package/dist/shared-lock/implementations/adapters/no-op-shared-lock-adapter/no-op-shared-lock-adapter.js.map +1 -0
  440. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module.d.ts +1 -0
  441. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module.js +2 -0
  442. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/_module.js.map +1 -0
  443. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.d.ts +79 -0
  444. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.js +630 -0
  445. package/dist/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.js.map +1 -0
  446. package/dist/shared-lock/implementations/derivables/_module-exports.d.ts +2 -0
  447. package/dist/shared-lock/implementations/derivables/_module-exports.js +3 -0
  448. package/dist/shared-lock/implementations/derivables/_module-exports.js.map +1 -0
  449. package/dist/shared-lock/implementations/derivables/shared-lock-provider/_module.d.ts +1 -0
  450. package/dist/shared-lock/implementations/derivables/shared-lock-provider/_module.js +2 -0
  451. package/dist/shared-lock/implementations/derivables/shared-lock-provider/_module.js.map +1 -0
  452. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.d.ts +27 -0
  453. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.js +208 -0
  454. package/dist/shared-lock/implementations/derivables/shared-lock-provider/database-shared-lock-adapter.js.map +1 -0
  455. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.d.ts +8 -0
  456. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.js +12 -0
  457. package/dist/shared-lock/implementations/derivables/shared-lock-provider/is-database-shared-lock-adapter.js.map +1 -0
  458. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.d.ts +8 -0
  459. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.js +15 -0
  460. package/dist/shared-lock/implementations/derivables/shared-lock-provider/resolve-database-shared-lock-adapter.js.map +1 -0
  461. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.d.ts +190 -0
  462. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js +177 -0
  463. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js.map +1 -0
  464. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.d.ts +41 -0
  465. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js +77 -0
  466. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js.map +1 -0
  467. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.d.ts +95 -0
  468. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js +542 -0
  469. package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js.map +1 -0
  470. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/_module.d.ts +1 -0
  471. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/_module.js +2 -0
  472. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/_module.js.map +1 -0
  473. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.d.ts +97 -0
  474. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js +128 -0
  475. package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js.map +1 -0
  476. package/dist/shared-lock/implementations/test-utilities/_module-exports.d.ts +3 -0
  477. package/dist/shared-lock/implementations/test-utilities/_module-exports.js +4 -0
  478. package/dist/shared-lock/implementations/test-utilities/_module-exports.js.map +1 -0
  479. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.d.ts +59 -0
  480. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.js +944 -0
  481. package/dist/shared-lock/implementations/test-utilities/database-shared-lock-adapter.test-suite.js.map +1 -0
  482. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.d.ts +59 -0
  483. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.js +1921 -0
  484. package/dist/shared-lock/implementations/test-utilities/shared-lock-adapter.test-suite.js.map +1 -0
  485. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.d.ts +67 -0
  486. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.js +9833 -0
  487. package/dist/shared-lock/implementations/test-utilities/shared-lock-provider.test-suite.js.map +1 -0
  488. package/dist/task/_module-exports.d.ts +1 -0
  489. package/dist/task/_module-exports.js +2 -0
  490. package/dist/task/_module-exports.js.map +1 -0
  491. package/dist/{async/utilities/abort-and-fail → task}/abort-and-fail.d.ts +1 -1
  492. package/dist/{async/utilities/abort-and-fail → task}/abort-and-fail.js +1 -1
  493. package/dist/task/abort-and-fail.js.map +1 -0
  494. package/dist/task/task.d.ts +194 -0
  495. package/dist/task/task.js +212 -0
  496. package/dist/task/task.js.map +1 -0
  497. package/dist/time-span/contracts/_module-exports.d.ts +1 -0
  498. package/dist/time-span/contracts/_module-exports.js +2 -0
  499. package/dist/time-span/contracts/_module-exports.js.map +1 -0
  500. package/dist/time-span/contracts/time-span.contract.d.ts +19 -0
  501. package/dist/time-span/contracts/time-span.contract.js +10 -0
  502. package/dist/time-span/contracts/time-span.contract.js.map +1 -0
  503. package/dist/time-span/implementations/_module-exports.d.ts +1 -0
  504. package/dist/time-span/implementations/_module-exports.js +2 -0
  505. package/dist/time-span/implementations/_module-exports.js.map +1 -0
  506. package/dist/{utilities/classes/time-span → time-span/implementations}/time-span.d.ts +49 -11
  507. package/dist/{utilities/classes/time-span → time-span/implementations}/time-span.js +33 -11
  508. package/dist/time-span/implementations/time-span.js.map +1 -0
  509. package/dist/utilities/classes/_module.d.ts +0 -3
  510. package/dist/utilities/classes/_module.js +0 -3
  511. package/dist/utilities/classes/_module.js.map +1 -1
  512. package/dist/utilities/contracts/_module.d.ts +1 -1
  513. package/dist/utilities/contracts/_module.js +1 -1
  514. package/dist/utilities/contracts/_module.js.map +1 -1
  515. package/dist/utilities/contracts/comparable.contract.d.ts +49 -0
  516. package/dist/utilities/contracts/comparable.contract.js +5 -0
  517. package/dist/utilities/contracts/comparable.contract.js.map +1 -0
  518. package/dist/utilities/contracts/deinitizable.contract.d.ts +1 -1
  519. package/dist/utilities/contracts/initizable.contract.d.ts +1 -1
  520. package/dist/utilities/contracts/prunable.contract.d.ts +1 -1
  521. package/dist/utilities/functions/is-standard-schema.d.ts +6 -0
  522. package/dist/utilities/functions/is-standard-schema.js +6 -0
  523. package/dist/utilities/functions/is-standard-schema.js.map +1 -1
  524. package/dist/utilities/functions/lazy.d.ts +3 -3
  525. package/dist/utilities/functions/lazy.js +3 -3
  526. package/dist/utilities/functions/lazy.js.map +1 -1
  527. package/dist/utilities/functions/option.d.ts +3 -0
  528. package/dist/utilities/functions/option.js +3 -0
  529. package/dist/utilities/functions/option.js.map +1 -1
  530. package/dist/utilities/functions/validate.d.ts +5 -0
  531. package/dist/utilities/functions/validate.js +5 -0
  532. package/dist/utilities/functions/validate.js.map +1 -1
  533. package/dist/utilities/types/any-class.type.d.ts +6 -0
  534. package/dist/utilities/types/any-class.type.js +3 -0
  535. package/dist/utilities/types/any-class.type.js.map +1 -1
  536. package/package.json +67 -5
  537. package/dist/async/_module-exports.d.ts +0 -4
  538. package/dist/async/_module-exports.js +0 -5
  539. package/dist/async/_module-exports.js.map +0 -1
  540. package/dist/async/async.errors.d.ts +0 -47
  541. package/dist/async/async.errors.js +0 -61
  542. package/dist/async/async.errors.js.map +0 -1
  543. package/dist/async/backof-policies/_module.d.ts +0 -5
  544. package/dist/async/backof-policies/_module.js +0 -6
  545. package/dist/async/backof-policies/_module.js.map +0 -1
  546. package/dist/async/backof-policies/_shared.js.map +0 -1
  547. package/dist/async/backof-policies/constant-backoff-policy/_module.d.ts +0 -1
  548. package/dist/async/backof-policies/constant-backoff-policy/_module.js +0 -2
  549. package/dist/async/backof-policies/constant-backoff-policy/_module.js.map +0 -1
  550. package/dist/async/backof-policies/constant-backoff-policy/constant-backoff-policy.js.map +0 -1
  551. package/dist/async/backof-policies/exponential-backoff-policy/_module.d.ts +0 -1
  552. package/dist/async/backof-policies/exponential-backoff-policy/_module.js +0 -2
  553. package/dist/async/backof-policies/exponential-backoff-policy/_module.js.map +0 -1
  554. package/dist/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js +0 -35
  555. package/dist/async/backof-policies/exponential-backoff-policy/exponential-backoff-policy.js.map +0 -1
  556. package/dist/async/backof-policies/linear-backoff-policy/_module.d.ts +0 -1
  557. package/dist/async/backof-policies/linear-backoff-policy/_module.js +0 -2
  558. package/dist/async/backof-policies/linear-backoff-policy/_module.js.map +0 -1
  559. package/dist/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js +0 -35
  560. package/dist/async/backof-policies/linear-backoff-policy/linear-backoff-policy.js.map +0 -1
  561. package/dist/async/backof-policies/polynomial-backoff-policy/_module.d.ts +0 -1
  562. package/dist/async/backof-policies/polynomial-backoff-policy/_module.js +0 -2
  563. package/dist/async/backof-policies/polynomial-backoff-policy/_module.js.map +0 -1
  564. package/dist/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js +0 -35
  565. package/dist/async/backof-policies/polynomial-backoff-policy/polynomial-backoff-policy.js.map +0 -1
  566. package/dist/async/middlewares/_module.d.ts +0 -7
  567. package/dist/async/middlewares/_module.js +0 -8
  568. package/dist/async/middlewares/_module.js.map +0 -1
  569. package/dist/async/middlewares/bulkhead/_module.d.ts +0 -1
  570. package/dist/async/middlewares/bulkhead/_module.js +0 -2
  571. package/dist/async/middlewares/bulkhead/_module.js.map +0 -1
  572. package/dist/async/middlewares/bulkhead/bulkhead.middleware.d.ts +0 -80
  573. package/dist/async/middlewares/bulkhead/bulkhead.middleware.js +0 -46
  574. package/dist/async/middlewares/bulkhead/bulkhead.middleware.js.map +0 -1
  575. package/dist/async/middlewares/dynamic/_module.d.ts +0 -1
  576. package/dist/async/middlewares/dynamic/_module.js +0 -2
  577. package/dist/async/middlewares/dynamic/_module.js.map +0 -1
  578. package/dist/async/middlewares/dynamic/dynamic.middleware.js.map +0 -1
  579. package/dist/async/middlewares/fallback/_module.d.ts +0 -2
  580. package/dist/async/middlewares/fallback/_module.js +0 -3
  581. package/dist/async/middlewares/fallback/_module.js.map +0 -1
  582. package/dist/async/middlewares/fallback/fallback.middleware.js.map +0 -1
  583. package/dist/async/middlewares/fallback/fallback.types.js.map +0 -1
  584. package/dist/async/middlewares/hedging/_module.d.ts +0 -2
  585. package/dist/async/middlewares/hedging/_module.js +0 -3
  586. package/dist/async/middlewares/hedging/_module.js.map +0 -1
  587. package/dist/async/middlewares/hedging/hedging.types.d.ts +0 -121
  588. package/dist/async/middlewares/hedging/hedging.types.js +0 -6
  589. package/dist/async/middlewares/hedging/hedging.types.js.map +0 -1
  590. package/dist/async/middlewares/hedging/sequential-hedging.middleware.d.ts +0 -51
  591. package/dist/async/middlewares/hedging/sequential-hedging.middleware.js +0 -133
  592. package/dist/async/middlewares/hedging/sequential-hedging.middleware.js.map +0 -1
  593. package/dist/async/middlewares/observe/_module.d.ts +0 -2
  594. package/dist/async/middlewares/observe/_module.js +0 -3
  595. package/dist/async/middlewares/observe/_module.js.map +0 -1
  596. package/dist/async/middlewares/observe/observe.middleware.js.map +0 -1
  597. package/dist/async/middlewares/observe/observe.types.js +0 -6
  598. package/dist/async/middlewares/observe/observe.types.js.map +0 -1
  599. package/dist/async/middlewares/retry/_module.d.ts +0 -2
  600. package/dist/async/middlewares/retry/_module.js +0 -3
  601. package/dist/async/middlewares/retry/_module.js.map +0 -1
  602. package/dist/async/middlewares/retry/retry.middleware.js.map +0 -1
  603. package/dist/async/middlewares/retry/retry.types.js +0 -7
  604. package/dist/async/middlewares/retry/retry.types.js.map +0 -1
  605. package/dist/async/middlewares/timeout/_module.d.ts +0 -2
  606. package/dist/async/middlewares/timeout/_module.js +0 -3
  607. package/dist/async/middlewares/timeout/_module.js.map +0 -1
  608. package/dist/async/middlewares/timeout/timeout.middleware.js.map +0 -1
  609. package/dist/async/middlewares/timeout/timeout.type.js +0 -6
  610. package/dist/async/middlewares/timeout/timeout.type.js.map +0 -1
  611. package/dist/async/utilities/_module.d.ts +0 -4
  612. package/dist/async/utilities/_module.js +0 -5
  613. package/dist/async/utilities/_module.js.map +0 -1
  614. package/dist/async/utilities/abort-and-fail/_module.d.ts +0 -1
  615. package/dist/async/utilities/abort-and-fail/_module.js +0 -2
  616. package/dist/async/utilities/abort-and-fail/_module.js.map +0 -1
  617. package/dist/async/utilities/abort-and-fail/abort-and-fail.js.map +0 -1
  618. package/dist/async/utilities/lazy-promise/_module.d.ts +0 -1
  619. package/dist/async/utilities/lazy-promise/_module.js +0 -2
  620. package/dist/async/utilities/lazy-promise/_module.js.map +0 -1
  621. package/dist/async/utilities/lazy-promise/lazy-promise.d.ts +0 -153
  622. package/dist/async/utilities/lazy-promise/lazy-promise.js +0 -176
  623. package/dist/async/utilities/lazy-promise/lazy-promise.js.map +0 -1
  624. package/dist/async/utilities/promise-queue/_module.d.ts +0 -1
  625. package/dist/async/utilities/promise-queue/_module.js +0 -2
  626. package/dist/async/utilities/promise-queue/_module.js.map +0 -1
  627. package/dist/async/utilities/promise-queue/promise-queue.d.ts +0 -32
  628. package/dist/async/utilities/promise-queue/promise-queue.js +0 -118
  629. package/dist/async/utilities/promise-queue/promise-queue.js.map +0 -1
  630. package/dist/async/utilities/timeout-and-fail/_module.d.ts +0 -1
  631. package/dist/async/utilities/timeout-and-fail/_module.js +0 -2
  632. package/dist/async/utilities/timeout-and-fail/_module.js.map +0 -1
  633. package/dist/async/utilities/timeout-and-fail/timeout-and-fail.d.ts +0 -7
  634. package/dist/async/utilities/timeout-and-fail/timeout-and-fail.js +0 -22
  635. package/dist/async/utilities/timeout-and-fail/timeout-and-fail.js.map +0 -1
  636. package/dist/lock/implementations/derivables/lock-provider/lock-state.d.ts +0 -40
  637. package/dist/lock/implementations/derivables/lock-provider/lock-state.js +0 -60
  638. package/dist/lock/implementations/derivables/lock-provider/lock-state.js.map +0 -1
  639. package/dist/serde/contracts/serializable.contract.d.ts +0 -12
  640. package/dist/serde/contracts/serializable.contract.js +0 -5
  641. package/dist/serde/contracts/serializable.contract.js.map +0 -1
  642. package/dist/serde/implementations/adapters/mongodb-serde/_module.d.ts +0 -1
  643. package/dist/serde/implementations/adapters/mongodb-serde/_module.js +0 -2
  644. package/dist/serde/implementations/adapters/mongodb-serde/_module.js.map +0 -1
  645. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.d.ts +0 -13
  646. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.js +0 -38
  647. package/dist/serde/implementations/adapters/mongodb-serde/mongodb-serde.js.map +0 -1
  648. package/dist/serde/implementations/adapters/redis-serde/_module.d.ts +0 -1
  649. package/dist/serde/implementations/adapters/redis-serde/_module.js +0 -2
  650. package/dist/serde/implementations/adapters/redis-serde/_module.js.map +0 -1
  651. package/dist/serde/implementations/adapters/redis-serde/redis-serde.d.ts +0 -13
  652. package/dist/serde/implementations/adapters/redis-serde/redis-serde.js +0 -39
  653. package/dist/serde/implementations/adapters/redis-serde/redis-serde.js.map +0 -1
  654. package/dist/serde/implementations/adapters/sql-serde/_module.d.ts +0 -1
  655. package/dist/serde/implementations/adapters/sql-serde/_module.js +0 -2
  656. package/dist/serde/implementations/adapters/sql-serde/_module.js.map +0 -1
  657. package/dist/serde/implementations/adapters/sql-serde/sql-serde.d.ts +0 -13
  658. package/dist/serde/implementations/adapters/sql-serde/sql-serde.js +0 -39
  659. package/dist/serde/implementations/adapters/sql-serde/sql-serde.js.map +0 -1
  660. package/dist/utilities/classes/hooks/_module.d.ts +0 -3
  661. package/dist/utilities/classes/hooks/_module.js +0 -4
  662. package/dist/utilities/classes/hooks/_module.js.map +0 -1
  663. package/dist/utilities/classes/hooks/async-hooks.js.map +0 -1
  664. package/dist/utilities/classes/hooks/hooks.js.map +0 -1
  665. package/dist/utilities/classes/hooks/types.js +0 -5
  666. package/dist/utilities/classes/hooks/types.js.map +0 -1
  667. package/dist/utilities/classes/namespace/_module.d.ts +0 -1
  668. package/dist/utilities/classes/namespace/_module.js +0 -2
  669. package/dist/utilities/classes/namespace/_module.js.map +0 -1
  670. package/dist/utilities/classes/namespace/namespace.d.ts +0 -85
  671. package/dist/utilities/classes/namespace/namespace.js +0 -125
  672. package/dist/utilities/classes/namespace/namespace.js.map +0 -1
  673. package/dist/utilities/classes/time-span/_module.d.ts +0 -1
  674. package/dist/utilities/classes/time-span/_module.js +0 -2
  675. package/dist/utilities/classes/time-span/_module.js.map +0 -1
  676. package/dist/utilities/classes/time-span/time-span.js.map +0 -1
  677. package/dist/utilities/contracts/serialized-error.contract.d.ts +0 -13
  678. package/dist/utilities/contracts/serialized-error.contract.js +0 -5
  679. package/dist/utilities/contracts/serialized-error.contract.js.map +0 -1
@@ -0,0 +1,630 @@
1
+ /**
2
+ * @module SharedLock
3
+ */
4
+ import { UnexpectedError } from "../../../../utilities/errors.js";
5
+ /**
6
+ * To utilize the `RedisSharedLockAdapter`, you must install the [`"ioredis"`](https://www.npmjs.com/package/ioredis) package.
7
+ *
8
+ * Note in order to use `RedisSharedLockAdapter` correctly, ensure you use a single, consistent database across all server instances.
9
+ *
10
+ * IMPORT_PATH: `"@daiso-tech/core/shared-lock/adapters"`
11
+ * @group Adapters
12
+ */
13
+ export class RedisSharedLockAdapter {
14
+ database;
15
+ /**
16
+ * @example
17
+ * ```ts
18
+ * import { RedisSharedLockAdapter } from "@daiso-tech/core/shared-lock/adapters";
19
+ * import Redis from "ioredis";
20
+ *
21
+ * const database = new Redis("YOUR_REDIS_CONNECTION_STRING");
22
+ * const lockAdapter = new RedisSharedLockAdapter(database);
23
+ * ```
24
+ */
25
+ constructor(database) {
26
+ this.database = database;
27
+ this.initAquireWriterCommand();
28
+ this.initReleaseWriterCommand();
29
+ this.initRefreshWriterCommand();
30
+ this.initForceReleaseWriterCommand();
31
+ this.initAquireReaderCommand();
32
+ this.initReleaseReaderCommand();
33
+ this.initRefreshReaderCommand();
34
+ this.initForceReleaseAllReadersCommand();
35
+ this.initForceReleaseCommand();
36
+ this.initGetStateCommand();
37
+ }
38
+ static getWriterKey(keyVar) {
39
+ return `
40
+ (function(key)
41
+ return key .. "__writer";
42
+ end)(${keyVar});
43
+ `;
44
+ }
45
+ static getReaderKey(keyVar) {
46
+ return `
47
+ (function(key)
48
+ return key .. "__reader";
49
+ end)(${keyVar});
50
+ `;
51
+ }
52
+ initAquireWriterCommand() {
53
+ if (typeof this.database.daiso_shared_lock_acquire_writer === "function") {
54
+ return;
55
+ }
56
+ this.database.defineCommand("daiso_shared_lock_acquire_writer", {
57
+ numberOfKeys: 1,
58
+ lua: `
59
+ local key = KEYS[1];
60
+ local lockId = ARGV[1];
61
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
62
+
63
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
64
+ if redis.call("exists", readerKey) == 1 then
65
+ return 0
66
+ end
67
+
68
+ -- Expiration time as unix timestamp in ms
69
+ local expiration = tonumber(ARGV[2]);
70
+
71
+ if redis.call("exists", writerKey) == 1 then
72
+ return redis.call("get", writerKey) == lockId;
73
+ end
74
+
75
+ if expiration == nil then
76
+ redis.call("set", writerKey, lockId, "nx");
77
+ else
78
+ redis.call("set", writerKey, lockId, "pxat", expiration, "nx");
79
+ end
80
+
81
+ return 1;
82
+ `,
83
+ });
84
+ }
85
+ initReleaseWriterCommand() {
86
+ if (typeof this.database.daiso_shared_lock_release_writer === "function") {
87
+ return;
88
+ }
89
+ this.database.defineCommand("daiso_shared_lock_release_writer", {
90
+ numberOfKeys: 1,
91
+ lua: `
92
+ local key = KEYS[1];
93
+ local lockId = ARGV[1];
94
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
95
+
96
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
97
+ if redis.call("exists", readerKey) == 1 then
98
+ return 0
99
+ end
100
+
101
+ if redis.call("exists", writerKey) == 0 then
102
+ return 0
103
+ end
104
+
105
+ local isNotCurrentOwner = redis.call("get", writerKey) ~= lockId
106
+ if isNotCurrentOwner then
107
+ return 0
108
+ end
109
+
110
+ redis.call("del", writerKey)
111
+
112
+ return 1
113
+ `,
114
+ });
115
+ }
116
+ initRefreshWriterCommand() {
117
+ if (typeof this.database.daiso_shared_lock_refresh_writer === "function") {
118
+ return;
119
+ }
120
+ this.database.defineCommand("daiso_shared_lock_refresh_writer", {
121
+ numberOfKeys: 1,
122
+ lua: `
123
+ -- Arguments
124
+ local key = KEYS[1];
125
+ local lockId = ARGV[1];
126
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
127
+
128
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
129
+ if redis.call("exists", readerKey) == 1 then
130
+ return 0
131
+ end
132
+
133
+ -- Expiration time as unix timestamp in ms
134
+ local expiration = tonumber(ARGV[2]);
135
+
136
+ if redis.call("exists", writerKey) == 0 then
137
+ return 0
138
+ end
139
+
140
+ local isNotCurrentOwner = redis.call("get", writerKey) ~= lockId
141
+ if redis.call("get", writerKey) ~= lockId then
142
+ return 0
143
+ end
144
+
145
+ local currentExpiration = redis.call("pttl", writerKey)
146
+ local isUnexpireable = currentExpiration == -1
147
+ if isUnexpireable then
148
+ return 0
149
+ end
150
+
151
+ redis.call("pexpireat", writerKey, expiration)
152
+ return 1
153
+ `,
154
+ });
155
+ }
156
+ static _forceReleaseWriter(keyVar) {
157
+ return `
158
+ (function(key)
159
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
160
+
161
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
162
+ if redis.call("exists", readerKey) == 1 then
163
+ return 0
164
+ end
165
+
166
+ return redis.call("del", writerKey);
167
+ end)(${keyVar});
168
+ `;
169
+ }
170
+ initForceReleaseWriterCommand() {
171
+ if (typeof this.database.daiso_shared_lock_force_release_writer ===
172
+ "function") {
173
+ return;
174
+ }
175
+ this.database.defineCommand("daiso_shared_lock_force_release_writer", {
176
+ numberOfKeys: 1,
177
+ lua: `
178
+ -- Arguments
179
+ local key = KEYS[1];
180
+
181
+ return ${RedisSharedLockAdapter._forceReleaseWriter("key")}
182
+ `,
183
+ });
184
+ }
185
+ static getLimitKey(keyVar) {
186
+ return `
187
+ (function(key)
188
+ return key .. "__limit";
189
+ end)(${keyVar});
190
+ `;
191
+ }
192
+ static removeExpiredSlots(keyVar, nowVar) {
193
+ return `
194
+ (function(key, now)
195
+ redis.call("zremrangebyscore", key, 1, now + 1);
196
+ end)(${keyVar}, ${nowVar});
197
+ `;
198
+ }
199
+ static getOrSetLimit(limitKeyVar, limitVar) {
200
+ return `
201
+ (function(limitKey, limit)
202
+ local currentLimit = tonumber(redis.call("set", limitKey, limit, "nx", "get"));
203
+ if currentLimit == nil then
204
+ currentLimit = limit;
205
+ end
206
+ return currentLimit;
207
+ end)(${limitKeyVar}, ${limitVar});
208
+ `;
209
+ }
210
+ static isLimitReached(keyVar, limitVar) {
211
+ return `
212
+ (function(key, limit)
213
+ return tonumber(redis.call("zcard", key)) >= limit;
214
+ end)(${keyVar}, ${limitVar});
215
+ `;
216
+ }
217
+ static hasSlotId(keyVar, slotIdVar) {
218
+ return `
219
+ (function(key, slotId)
220
+ return tonumber(redis.call("zscore", key, slotId)) ~= nil;
221
+ end)(${keyVar}, ${slotIdVar});
222
+ `;
223
+ }
224
+ static addSlot(keyVar, slotIdVar, expirationVar) {
225
+ return `
226
+ (function(key, slotId, expiration)
227
+ local isSlotNotExpirable = expiration == nil;
228
+ if isSlotNotExpirable then
229
+ redis.call("zadd", key, 0, slotId);
230
+ else
231
+ redis.call("zadd", key, expiration, slotId);
232
+ end
233
+ end)(${keyVar}, ${slotIdVar}, ${expirationVar});
234
+ `;
235
+ }
236
+ static updateKeyExpiration(keyVar, limitKeyVar) {
237
+ return `
238
+ (function(key, limitKey)
239
+ local hasAtLeastOneUnexpirableSlot = tonumber(redis.call("zcount", key, 0, 0)) > 0;
240
+ if hasAtLeastOneUnexpirableSlot then
241
+ redis.call("persist", key);
242
+ redis.call("persist", limitKey);
243
+ return
244
+ end
245
+
246
+ local longestExpiration = tonumber(redis.call("zrange", key, 0, 0, "BYSCORE", "REV", "WITHSCORES")[2]);
247
+ local hasAtLeastOneExpireableSlot = longestExpiration ~= nil and longestExpiration > 0;
248
+
249
+ if hasAtLeastOneExpireableSlot then
250
+ redis.call("pexpireat", key, longestExpiration);
251
+ redis.call("pexpireat", limitKey, longestExpiration);
252
+ end
253
+ end)(${keyVar}, ${limitKeyVar});
254
+ `;
255
+ }
256
+ static removeSemaphoreIfEmpty(keyVar, limitKeyVar) {
257
+ return `
258
+ (function(key, limitKey)
259
+ local slotCount = redis.call("zcard", key)
260
+ if slotCount <= 0 then
261
+ redis.call("del", key)
262
+ redis.call("del", limitKey)
263
+ end
264
+ end)(${keyVar}, ${limitKeyVar});
265
+ `;
266
+ }
267
+ initAquireReaderCommand() {
268
+ if (typeof this.database.daiso_shared_lock_acquire_reader === "function") {
269
+ return;
270
+ }
271
+ this.database.defineCommand("daiso_shared_lock_acquire_reader", {
272
+ numberOfKeys: 1,
273
+ lua: `
274
+ local key = KEYS[1];
275
+ local slotId = ARGV[1];
276
+ local limit = tonumber(ARGV[2]);
277
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
278
+
279
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
280
+ if redis.call("exists", writerKey) == 1 then
281
+ return 0
282
+ end
283
+
284
+ -- Expiration time as unix timestamp in ms
285
+ local expiration = tonumber(ARGV[3]);
286
+
287
+ -- Current time as unix timestamp in ms
288
+ local now = tonumber(ARGV[4]);
289
+
290
+ local limitKey = ${RedisSharedLockAdapter.getLimitKey("readerKey")}
291
+ limit = ${RedisSharedLockAdapter.getOrSetLimit("limitKey", "limit")}
292
+
293
+ ${RedisSharedLockAdapter.removeExpiredSlots("readerKey", "now")}
294
+
295
+ local isLimitReached = ${RedisSharedLockAdapter.isLimitReached("readerKey", "limit")}
296
+ if isLimitReached then
297
+ return 0;
298
+ end
299
+
300
+ local hasSlotId = ${RedisSharedLockAdapter.hasSlotId("readerKey", "slotId")}
301
+ if hasSlotId then
302
+ return 1;
303
+ end
304
+
305
+ ${RedisSharedLockAdapter.addSlot("readerKey", "slotId", "expiration")}
306
+
307
+ ${RedisSharedLockAdapter.updateKeyExpiration("readerKey", "limitKey")}
308
+
309
+ return 1;
310
+ `,
311
+ });
312
+ }
313
+ initReleaseReaderCommand() {
314
+ if (typeof this.database.daiso_shared_lock_release_reader === "function") {
315
+ return;
316
+ }
317
+ this.database.defineCommand("daiso_shared_lock_release_reader", {
318
+ numberOfKeys: 1,
319
+ lua: `
320
+ local key = KEYS[1];
321
+ local lockId = ARGV[1];
322
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
323
+
324
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
325
+ if redis.call("exists", writerKey) == 1 then
326
+ return 0
327
+ end
328
+
329
+ -- The key where the slot limit will be stored
330
+ local limitKey = ${RedisSharedLockAdapter.getLimitKey("readerKey")}
331
+
332
+ -- Current time as unix timestamp in ms
333
+ local now = tonumber(ARGV[2]);
334
+
335
+ ${RedisSharedLockAdapter.removeExpiredSlots("readerKey", "now")}
336
+
337
+ -- Removes the given slot
338
+ local removedCount = redis.call("zrem", readerKey, lockId);
339
+ local hasRemoved = removedCount == 1;
340
+
341
+ ${RedisSharedLockAdapter.removeSemaphoreIfEmpty("readerKey", "limitKey")}
342
+
343
+ ${RedisSharedLockAdapter.updateKeyExpiration("readerKey", "limitKey")}
344
+
345
+ return removedCount;
346
+ `,
347
+ });
348
+ }
349
+ initRefreshReaderCommand() {
350
+ if (typeof this.database.daiso_shared_lock_refresh_reader === "function") {
351
+ return;
352
+ }
353
+ this.database.defineCommand("daiso_shared_lock_refresh_reader", {
354
+ numberOfKeys: 1,
355
+ lua: `
356
+ local key = KEYS[1];
357
+ local lockId = ARGV[1];
358
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
359
+
360
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
361
+ if redis.call("exists", writerKey) == 1 then
362
+ return 0
363
+ end
364
+
365
+ -- unix timestamp in ms
366
+ local newExpiration = tonumber(ARGV[2]);
367
+
368
+ -- current time as unix timestamp in ms
369
+ local now = tonumber(ARGV[3]);
370
+
371
+ -- The key where the slot limit will be stored
372
+ local limitKey = ${RedisSharedLockAdapter.getLimitKey("readerKey")}
373
+
374
+ ${RedisSharedLockAdapter.removeExpiredSlots("readerKey", "now")}
375
+
376
+ local expiration = tonumber(redis.call("zscore", readerKey, lockId));
377
+ local isExpiredOrDoesNotExist = expiration == nil;
378
+ if isExpiredOrDoesNotExist then
379
+ return 0
380
+ end
381
+
382
+ local isUnexpireable = expiration == 0;
383
+ if isUnexpireable then
384
+ return 0
385
+ end
386
+
387
+ -- Update expiration if lockId exists
388
+ redis.call("zadd", readerKey, "xx", newExpiration, lockId);
389
+
390
+ local hasAtLeastOneUnexpirableSlot = tonumber(redis.call("zcount", readerKey, 0, 0)) > 0;
391
+ local longestExpiration = tonumber(redis.call("zrange", readerKey, 0, 0, "BYSCORE", "REV", "WITHSCORES")[2]);
392
+ if hasAtLeastOneUnexpirableSlot then
393
+ redis.call("persist", readerKey);
394
+ redis.call("persist", limitKey);
395
+ elseif longestExpiration ~= nil and longestExpiration > 0 then
396
+ redis.call("pexpireat", readerKey, longestExpiration);
397
+ redis.call("pexpireat", limitKey, longestExpiration);
398
+ end
399
+
400
+ return 1
401
+ `,
402
+ });
403
+ }
404
+ static _forceReleaseAllReaders(keyVar, nowVar) {
405
+ return `
406
+ (function(key, now)
407
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
408
+
409
+ -- The key where the slot limit will be stored
410
+ local limitKey = ${RedisSharedLockAdapter.getLimitKey("readerKey")}
411
+
412
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
413
+ if redis.call("exists", writerKey) == 1 then
414
+ return 0
415
+ end
416
+
417
+ ${RedisSharedLockAdapter.removeExpiredSlots("readerKey", "now")}
418
+
419
+ local slotCount = redis.call("zcard", readerKey);
420
+ redis.call("del", readerKey);
421
+ redis.call("del", limitKey);
422
+
423
+ local hasSlots = slotCount > 0
424
+ if hasSlots then
425
+ return 1;
426
+ end
427
+
428
+ return 0;
429
+ end)(${keyVar}, ${nowVar});
430
+ `;
431
+ }
432
+ initForceReleaseAllReadersCommand() {
433
+ if (typeof this.database.daiso_shared_lock_force_release_all_readers ===
434
+ "function") {
435
+ return;
436
+ }
437
+ this.database.defineCommand("daiso_shared_lock_force_release_all_readers", {
438
+ numberOfKeys: 1,
439
+ lua: `
440
+ local key = KEYS[1];
441
+
442
+ -- current time as unix timestamp in ms
443
+ local now = ARGV[1];
444
+
445
+ return ${RedisSharedLockAdapter._forceReleaseAllReaders("key", "now")}
446
+ `,
447
+ });
448
+ }
449
+ initForceReleaseCommand() {
450
+ if (typeof this.database.daiso_shared_lock_force_release === "function") {
451
+ return;
452
+ }
453
+ this.database.defineCommand("daiso_shared_lock_force_release", {
454
+ numberOfKeys: 1,
455
+ lua: `
456
+ local key = KEYS[1];
457
+
458
+ -- current time as unix timestamp in ms
459
+ local now = ARGV[1];
460
+
461
+ local hasReleasedReader = ${RedisSharedLockAdapter._forceReleaseAllReaders("key", "now")}
462
+ local hasReleasedWriter = ${RedisSharedLockAdapter._forceReleaseWriter("key")}
463
+
464
+ return hasReleasedReader == 1 or hasReleasedWriter == 1
465
+ `,
466
+ });
467
+ }
468
+ static getWriterState(keyVar) {
469
+ return `
470
+ (function(key)
471
+ local writerKey = ${RedisSharedLockAdapter.getWriterKey("key")}
472
+
473
+ if tonumber(redis.call("exists", writerKey)) == 0 then
474
+ return nil;
475
+ end
476
+
477
+ local state = {
478
+ owner = redis.call("get", writerKey),
479
+ expiration = tonumber(redis.call("pexpiretime", writerKey))
480
+ };
481
+
482
+ return state;
483
+ end)(${keyVar});
484
+ `;
485
+ }
486
+ static getReaderState(keyVar, nowVar) {
487
+ return `
488
+ (function(key, now)
489
+ local readerKey = ${RedisSharedLockAdapter.getReaderKey("key")}
490
+
491
+ if tonumber(redis.call("exists", readerKey)) == 0 then
492
+ return nil;
493
+ end
494
+
495
+ local limitKey = ${RedisSharedLockAdapter.getLimitKey("readerKey")}
496
+
497
+ ${RedisSharedLockAdapter.removeExpiredSlots("readerKey", "now")}
498
+
499
+ local limit = redis.call("get", limitKey);
500
+ if limit == nil then
501
+ return nil;
502
+ end
503
+
504
+ local acquiredSlots = {};
505
+
506
+ local unexpiredSlotsArr = redis.call("zrange", readerKey, now + 1, "+inf", "BYSCORE", "WITHSCORES");
507
+ for i = 1, #unexpiredSlotsArr, 2 do
508
+ local member = unexpiredSlotsArr[i];
509
+ local score = unexpiredSlotsArr[i+1];
510
+ acquiredSlots[member] = tonumber(score);
511
+ end
512
+
513
+ local unexpireableSlotsArr = redis.call("zrange", readerKey, 0, 0, "BYSCORE", "WITHSCORES");
514
+ for i = 1, #unexpireableSlotsArr, 2 do
515
+ local member = unexpireableSlotsArr[i];
516
+ local score = unexpireableSlotsArr[i+1];
517
+ acquiredSlots[member] = tonumber(score);
518
+ end
519
+
520
+ local isEmpty = next(acquiredSlots) == nil;
521
+ if isEmpty then
522
+ return nil;
523
+ end
524
+
525
+ local state = {
526
+ limit = tonumber(limit),
527
+ acquiredSlots = acquiredSlots
528
+ }
529
+
530
+ return state;
531
+ end)(${keyVar}, ${nowVar});
532
+ `;
533
+ }
534
+ initGetStateCommand() {
535
+ if (typeof this.database.daiso_shared_lock_get_state === "function") {
536
+ return;
537
+ }
538
+ this.database.defineCommand("daiso_shared_lock_get_state", {
539
+ numberOfKeys: 1,
540
+ lua: `
541
+ local key = KEYS[1];
542
+
543
+ -- current time as unix timestamp in ms
544
+ local now = tonumber(ARGV[1]);
545
+
546
+ local writerState = ${RedisSharedLockAdapter.getWriterState("key")}
547
+ local readerState = ${RedisSharedLockAdapter.getReaderState("key", "now")}
548
+
549
+ if writerState == nil and readerState == nil then
550
+ return cjson.encode(nil);
551
+ end
552
+
553
+ return cjson.encode({
554
+ writer = writerState,
555
+ reader = readerState
556
+ });
557
+ `,
558
+ });
559
+ }
560
+ async acquireWriter(key, lockId, ttl) {
561
+ const result = await this.database.daiso_shared_lock_acquire_writer(key, lockId, ttl?.toEndDate().getTime() ?? null);
562
+ return result === 1;
563
+ }
564
+ async releaseWriter(key, lockId) {
565
+ const result = await this.database.daiso_shared_lock_release_writer(key, lockId);
566
+ return result === 1;
567
+ }
568
+ async refreshWriter(key, lockId, ttl) {
569
+ const result = await this.database.daiso_shared_lock_refresh_writer(key, lockId, ttl.toEndDate().getTime());
570
+ return result === 1;
571
+ }
572
+ async forceReleaseWriter(key) {
573
+ const result = await this.database.daiso_shared_lock_force_release_writer(key);
574
+ return result === 1;
575
+ }
576
+ async acquireReader(settings) {
577
+ const { key, lockId, limit, ttl } = settings;
578
+ const result = await this.database.daiso_shared_lock_acquire_reader(key, lockId, limit, ttl?.toEndDate().getTime() ?? null, Date.now());
579
+ return result === 1;
580
+ }
581
+ async releaseReader(key, lockId) {
582
+ const result = await this.database.daiso_shared_lock_release_reader(key, lockId, Date.now());
583
+ return result === 1;
584
+ }
585
+ async refreshReader(key, lockId, ttl) {
586
+ const result = await this.database.daiso_shared_lock_refresh_reader(key, lockId, ttl.toEndDate().getTime(), Date.now());
587
+ return result === 1;
588
+ }
589
+ async forceReleaseAllReaders(key) {
590
+ const result = await this.database.daiso_shared_lock_force_release_all_readers(key, Date.now());
591
+ return result === 1;
592
+ }
593
+ async forceRelease(key) {
594
+ const result = await this.database.daiso_shared_lock_force_release(key, Date.now());
595
+ return result === 1;
596
+ }
597
+ async getState(key) {
598
+ const json = JSON.parse(await this.database.daiso_shared_lock_get_state(key, Date.now()));
599
+ if (json === null) {
600
+ return null;
601
+ }
602
+ if (json.reader === undefined && json.writer !== undefined) {
603
+ return {
604
+ reader: null,
605
+ writer: {
606
+ owner: json.writer.owner,
607
+ expiration: json.writer.expiration === -1
608
+ ? null
609
+ : new Date(json.writer.expiration),
610
+ },
611
+ };
612
+ }
613
+ if (json.writer === undefined && json.reader !== undefined) {
614
+ return {
615
+ writer: null,
616
+ reader: {
617
+ limit: json.reader.limit,
618
+ acquiredSlots: new Map(Object.entries(json.reader.acquiredSlots).map(([key, expiration]) => {
619
+ if (expiration === 0) {
620
+ return [key, null];
621
+ }
622
+ return [key, new Date(expiration)];
623
+ })),
624
+ },
625
+ };
626
+ }
627
+ throw new UnexpectedError("Invalid ISharedLockAdapterState, expected either the reader field must be defined or the writer field must be defined, but not both.");
628
+ }
629
+ }
630
+ //# sourceMappingURL=redis-shared-lock-adapter.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redis-shared-lock-adapter.js","sourceRoot":"","sources":["../../../../../src/shared-lock/implementations/adapters/redis-shared-lock-adapter/redis-shared-lock-adapter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from "../../../shared-lock/implementations/derivables/shared-lock-provider/_module.js";
2
+ export * from "../../../shared-lock/implementations/derivables/shared-lock-provider-factory/_module.js";
@@ -0,0 +1,3 @@
1
+ export * from "../../../shared-lock/implementations/derivables/shared-lock-provider/_module.js";
2
+ export * from "../../../shared-lock/implementations/derivables/shared-lock-provider-factory/_module.js";
3
+ //# sourceMappingURL=_module-exports.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_module-exports.js","sourceRoot":"","sources":["../../../../src/shared-lock/implementations/derivables/_module-exports.ts"],"names":[],"mappings":"AAAA,cAAc,0EAA0E,CAAC;AACzF,cAAc,kFAAkF,CAAC"}
@@ -0,0 +1 @@
1
+ export * from "../../../../shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js";
@@ -0,0 +1,2 @@
1
+ export * from "../../../../shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js";
2
+ //# sourceMappingURL=_module.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"_module.js","sourceRoot":"","sources":["../../../../../src/shared-lock/implementations/derivables/shared-lock-provider/_module.ts"],"names":[],"mappings":"AAAA,cAAc,uFAAuF,CAAC"}