@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,52 @@
1
+ /**
2
+ * @module Lock
3
+ */
4
+ import type { TimeSpan } from "../../time-span/implementations/_module-exports.js";
5
+ /**
6
+ *
7
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
8
+ * @group Contracts
9
+ */
10
+ export declare const LOCK_STATE: {
11
+ readonly EXPIRED: "EXPIRED";
12
+ readonly UNAVAILABLE: "UNAVAILABLE";
13
+ readonly ACQUIRED: "ACQUIRED";
14
+ };
15
+ /**
16
+ *
17
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
18
+ * @group Contracts
19
+ */
20
+ export type LockState = (typeof LOCK_STATE)[keyof typeof LOCK_STATE];
21
+ /**
22
+ *
23
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
24
+ * @group Contracts
25
+ */
26
+ export type ILockExpiredState = {
27
+ type: (typeof LOCK_STATE)["EXPIRED"];
28
+ };
29
+ /**
30
+ *
31
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
32
+ * @group Contracts
33
+ */
34
+ export type ILockUnavailableState = {
35
+ type: (typeof LOCK_STATE)["UNAVAILABLE"];
36
+ owner: string;
37
+ };
38
+ /**
39
+ *
40
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
41
+ * @group Contracts
42
+ */
43
+ export type ILockAcquiredState = {
44
+ type: (typeof LOCK_STATE)["ACQUIRED"];
45
+ remainingTime: TimeSpan | null;
46
+ };
47
+ /**
48
+ *
49
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
50
+ * @group Contracts
51
+ */
52
+ export type ILockState = ILockUnavailableState | ILockAcquiredState | ILockExpiredState;
@@ -0,0 +1,14 @@
1
+ /**
2
+ * @module Lock
3
+ */
4
+ /**
5
+ *
6
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
7
+ * @group Contracts
8
+ */
9
+ export const LOCK_STATE = {
10
+ EXPIRED: "EXPIRED",
11
+ UNAVAILABLE: "UNAVAILABLE",
12
+ ACQUIRED: "ACQUIRED",
13
+ };
14
+ //# sourceMappingURL=lock-state.contract.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"lock-state.contract.js","sourceRoot":"","sources":["../../../src/lock/contracts/lock-state.contract.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH;;;;GAIG;AACH,MAAM,CAAC,MAAM,UAAU,GAAG;IACtB,OAAO,EAAE,SAAS;IAClB,WAAW,EAAE,aAAa;IAC1B,QAAQ,EAAE,UAAU;CACd,CAAC"}
@@ -1,115 +1,129 @@
1
1
  /**
2
2
  * @module Lock
3
3
  */
4
- import type { AsyncLazy, Result, TimeSpan } from "../../utilities/_module-exports.js";
5
- import type { LazyPromise } from "../../async/_module-exports.js";
6
- import type { KeyAlreadyAcquiredLockError } from "../../lock/contracts/lock.errors.js";
4
+ import type { AsyncLazy, Result } from "../../utilities/_module-exports.js";
5
+ import type { Task } from "../../task/_module-exports.js";
6
+ import type { FailedAcquireLockError } from "../../lock/contracts/lock.errors.js";
7
+ import type { ILockState } from "../../lock/contracts/lock-state.contract.js";
8
+ import type { ITimeSpan } from "../../time-span/contracts/_module-exports.js";
7
9
  /**
8
10
  *
9
11
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
10
12
  * @group Contracts
11
13
  */
12
14
  export type LockAquireBlockingSettings = {
13
- time?: TimeSpan;
14
- interval?: TimeSpan;
15
+ time?: ITimeSpan;
16
+ interval?: ITimeSpan;
15
17
  };
16
18
  /**
17
19
  *
18
20
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
19
21
  * @group Contracts
20
22
  */
21
- export type ILock = {
23
+ export type ILockStateMethods = {
24
+ getState(): Task<ILockState>;
22
25
  /**
23
- * The `run` method wraps an {@link Invokable | `Invokable`} or {@link LazyPromise| `LazyPromise`} with the `acquire` and `release` method.
26
+ * The `key` of the `ILock` instance.
24
27
  */
25
- run<TValue = void>(asyncFn: AsyncLazy<TValue>): LazyPromise<Result<TValue, KeyAlreadyAcquiredLockError>>;
28
+ readonly key: string;
26
29
  /**
27
- * The `runOrFail` method wraps an {@link Invokable | `Invokable`} or {@link LazyPromise| `LazyPromise`} with the `acquireOrFail` and `release` method.
28
- * @throws {KeyAlreadyAcquiredLockError} {@link KeyAlreadyAcquiredLockError}
30
+ * The `id` of the `ILock` instance.
29
31
  */
30
- runOrFail<TValue = void>(asyncFn: AsyncLazy<TValue>): LazyPromise<TValue>;
32
+ readonly id: string;
31
33
  /**
32
- * The `runBlocking` method wraps an {@link Invokable | `Invokable`} or {@link LazyPromise| `LazyPromise`} with the `acquireBlocking` and `release` method.
34
+ * The `ttl` of `ILock` instance.
33
35
  */
34
- runBlocking<TValue = void>(asyncFn: AsyncLazy<TValue>, settings?: LockAquireBlockingSettings): LazyPromise<Result<TValue, KeyAlreadyAcquiredLockError>>;
36
+ readonly ttl: ITimeSpan | null;
37
+ };
38
+ /**
39
+ *
40
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
41
+ * @group Contracts
42
+ */
43
+ export type ILockBase = {
35
44
  /**
36
- * The `runBlockingOrFail` method wraps an {@link Invokable | `Invokable`} or {@link LazyPromise| `LazyPromise`} with the `acquireBlockingOrFail` and `release` method.
37
- * @throws {KeyAlreadyAcquiredLockError} {@link KeyAlreadyAcquiredLockError}
45
+ * The `run` method wraps an {@link Invokable | `Invokable`} or {@link Task | `Task`} with the `acquire` and `release` method.
38
46
  */
39
- runBlockingOrFail<TValue = void>(asyncFn: AsyncLazy<TValue>, settings?: LockAquireBlockingSettings): LazyPromise<TValue>;
47
+ run<TValue = void>(asyncFn: AsyncLazy<TValue>): Task<Result<TValue, FailedAcquireLockError>>;
40
48
  /**
41
- * The `acquire` method acquires a lock only if the lock is available.
49
+ * The `runOrFail` method wraps an {@link Invokable | `Invokable`} or {@link Task | `Task`} with the `acquireOrFail` and `release` method.
50
+ * @throws {FailedAcquireLockError} {@link FailedAcquireLockError}
51
+ */
52
+ runOrFail<TValue = void>(asyncFn: AsyncLazy<TValue>): Task<TValue>;
53
+ /**
54
+ * The `runBlocking` method wraps an {@link Invokable | `Invokable`} or {@link Task | `Task`} with the `acquireBlocking` and `release` method.
55
+ */
56
+ runBlocking<TValue = void>(asyncFn: AsyncLazy<TValue>, settings?: LockAquireBlockingSettings): Task<Result<TValue, FailedAcquireLockError>>;
57
+ /**
58
+ * The `runBlockingOrFail` method wraps an {@link Invokable | `Invokable`} or {@link Task | `Task`} with the `acquireBlockingOrFail` and `release` method.
59
+ * @throws {FailedAcquireLockError} {@link FailedAcquireLockError}
60
+ */
61
+ runBlockingOrFail<TValue = void>(asyncFn: AsyncLazy<TValue>, settings?: LockAquireBlockingSettings): Task<TValue>;
62
+ /**
63
+ * The `acquire` method acquires a lock only if the key is not already acquired by different owner.
42
64
  *
43
- * @returns Returns true if the lock is acquired otherwise false is returned.
65
+ * @returns Returns true if the lock is not already acquired otherwise false is returned.
44
66
  */
45
- acquire(): LazyPromise<boolean>;
67
+ acquire(): Task<boolean>;
46
68
  /**
47
- * The `acquireOrFail` method acquires a lock only if the lock is available.
48
- * Throws an error if already acquired.
69
+ * The `acquireOrFail` method acquires a lock only if the key is not already acquired by different owner.
70
+ * Throws an error if the lock is already acquired by different owner.
49
71
  *
50
- * @throws {KeyAlreadyAcquiredLockError} {@link KeyAlreadyAcquiredLockError}
72
+ * @throws {FailedAcquireLockError} {@link FailedAcquireLockError}
51
73
  */
52
- acquireOrFail(): LazyPromise<void>;
74
+ acquireOrFail(): Task<void>;
53
75
  /**
54
- * The `acquireBlocking` method acquires a lock only if the lock is available.
76
+ * The `acquireBlocking` method acquires a lock only if the key is not already acquired by different owner.
55
77
  * If the lock is not acquired, it retries every `settings.interval` until `settings.time` is reached.
56
78
  *
57
- * @returns Returns true if the lock is acquired otherwise false is returned.
79
+ * @returns Returns true if the lock is not already acquired otherwise false is returned.
58
80
  */
59
- acquireBlocking(settings?: LockAquireBlockingSettings): LazyPromise<boolean>;
81
+ acquireBlocking(settings?: LockAquireBlockingSettings): Task<boolean>;
60
82
  /**
61
- * The `acquireBlockingOrFail` method acquires a lock only if the lock is available.
83
+ * The `acquireBlockingOrFail` method acquires a lock only if the key is not already acquired by different owner.
62
84
  * If the lock is not acquired, it retries every `settings.interval` until `settings.time` is reached.
63
- * Throws an error if the lock cannot be acquired after the given `settings.time`.
85
+ * Throws an error if the lock is already acquired by different owner.
64
86
  *
65
- * @throws {KeyAlreadyAcquiredLockError} {@link KeyAlreadyAcquiredLockError}
87
+ * @throws {FailedAcquireLockError} {@link FailedAcquireLockError}
66
88
  */
67
- acquireBlockingOrFail(settings?: LockAquireBlockingSettings): LazyPromise<void>;
89
+ acquireBlockingOrFail(settings?: LockAquireBlockingSettings): Task<void>;
68
90
  /**
69
91
  * The `release` method releases a lock if owned by the same owner.
70
92
  *
71
93
  * @returns Returns true if the lock is released otherwise false is returned.
72
94
  */
73
- release(): LazyPromise<boolean>;
95
+ release(): Task<boolean>;
74
96
  /**
75
97
  * The `releaseOrFail` method releases a lock if owned by the same owner.
76
- * Throws an error if a different owner attempts to release the lock.
98
+ * Throws an error if the lock is not owned by same owner.
77
99
  *
78
- * @throws {UnownedReleaseLockError} {@link UnownedReleaseLockError}
100
+ * @throws {FailedReleaseLockError} {@link FailedReleaseLockError}
79
101
  */
80
- releaseOrFail(): LazyPromise<void>;
102
+ releaseOrFail(): Task<void>;
81
103
  /**
82
104
  * The `forceRelease` method releases a lock regardless of the owner.
105
+ *
106
+ * @returns Returns true if the lock exists or false if the lock doesnt exists.
83
107
  */
84
- forceRelease(): LazyPromise<void>;
85
- /**
86
- * The `isExpired` method returns true if the lock is expired otherwise false is returned.
87
- */
88
- isExpired(): LazyPromise<boolean>;
89
- /**
90
- * The `isLocked` method returns true if the locked otherwise false is returned.
91
- */
92
- isLocked(): LazyPromise<boolean>;
108
+ forceRelease(): Task<boolean>;
93
109
  /**
94
- * The `refresh` method updates the `ttl` of the lock if owned by the same owner.
110
+ * The `refresh` method updates the `ttl` of the lock if expireable and owned by the same owner.
95
111
  *
96
112
  * @returns Returns true if the lock is refreshed otherwise false is returned.
97
113
  */
98
- refresh(ttl?: TimeSpan): LazyPromise<boolean>;
114
+ refresh(ttl?: ITimeSpan): Task<boolean>;
99
115
  /**
100
- * The `refreshOrFail` method updates the `ttl` of the lock if owned by the same owner.
101
- * Throws an error if a different owner attempts to refresh the lock.
102
- * @throws {UnownedRefreshLockError} {@link UnownedRefreshLockError}
103
- */
104
- refreshOrFail(ttl?: TimeSpan): LazyPromise<void>;
105
- /**
106
- * The `getRemainingTime` return the reaming time as {@link TimeSpan | `TimeSpan`}.
116
+ * The `refreshOrFail` method updates the `ttl` of the lock if expireable and owned by the same owner.
117
+ * Throws an error if the lock is not owned by same owner.
118
+ * Throws an error if the key is unexpirable.
107
119
  *
108
- * @returns Returns null if the key doesnt exist, key has no expiration and key has expired.
120
+ * @throws {FailedRefreshLockError} {@link FailedRefreshLockError}
109
121
  */
110
- getRemainingTime(): LazyPromise<TimeSpan | null>;
111
- /**
112
- * The `getOwner` method return the current owner.
113
- */
114
- getOwner(): LazyPromise<string>;
122
+ refreshOrFail(ttl?: ITimeSpan): Task<void>;
115
123
  };
124
+ /**
125
+ *
126
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
127
+ * @group Contracts
128
+ */
129
+ export type ILock = ILockBase & ILockStateMethods;
@@ -1,21 +1,13 @@
1
1
  /**
2
2
  * @module Lock
3
3
  */
4
- /**
5
- *
6
- * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
7
- * @group Errors
8
- */
9
- export declare class LockError extends Error {
10
- constructor(message: string, cause?: unknown);
11
- }
12
4
  /**
13
5
  * The error is thrown when trying to acquire a lock that is owned by a different owner.
14
6
  *
15
7
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
16
8
  * @group Errors
17
9
  */
18
- export declare class KeyAlreadyAcquiredLockError extends LockError {
10
+ export declare class FailedAcquireLockError extends Error {
19
11
  constructor(message: string, cause?: unknown);
20
12
  }
21
13
  /**
@@ -24,7 +16,7 @@ export declare class KeyAlreadyAcquiredLockError extends LockError {
24
16
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
25
17
  * @group Errors
26
18
  */
27
- export declare class UnownedReleaseLockError extends LockError {
19
+ export declare class FailedReleaseLockError extends Error {
28
20
  constructor(message: string, cause?: unknown);
29
21
  }
30
22
  /**
@@ -33,7 +25,7 @@ export declare class UnownedReleaseLockError extends LockError {
33
25
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
34
26
  * @group Errors
35
27
  */
36
- export declare class UnownedRefreshLockError extends LockError {
28
+ export declare class FailedRefreshLockError extends Error {
37
29
  constructor(message: string, cause?: unknown);
38
30
  }
39
31
  /**
@@ -42,8 +34,19 @@ export declare class UnownedRefreshLockError extends LockError {
42
34
  * @group Errors
43
35
  */
44
36
  export declare const LOCK_ERRORS: {
45
- readonly Base: typeof LockError;
46
- readonly KeyAlreadyAcquired: typeof KeyAlreadyAcquiredLockError;
47
- readonly UnownedRelease: typeof UnownedReleaseLockError;
48
- readonly UnownedRefresh: typeof UnownedRefreshLockError;
37
+ readonly FailedAcquire: typeof FailedAcquireLockError;
38
+ readonly FailedRelease: typeof FailedReleaseLockError;
39
+ readonly FailedRefresh: typeof FailedRefreshLockError;
49
40
  };
41
+ /**
42
+ *
43
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
44
+ * @group Errors
45
+ */
46
+ export type AllLockErrors = FailedAcquireLockError | FailedReleaseLockError | FailedRefreshLockError;
47
+ /**
48
+ *
49
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
50
+ * @group Errors
51
+ */
52
+ export declare function isLockError(value: unknown): value is AllLockErrors;
@@ -1,25 +1,16 @@
1
1
  /**
2
2
  * @module Lock
3
3
  */
4
- /**
5
- *
6
- * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
7
- * @group Errors
8
- */
9
- export class LockError extends Error {
10
- constructor(message, cause) {
11
- super(message, { cause });
12
- }
13
- }
14
4
  /**
15
5
  * The error is thrown when trying to acquire a lock that is owned by a different owner.
16
6
  *
17
7
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
18
8
  * @group Errors
19
9
  */
20
- export class KeyAlreadyAcquiredLockError extends LockError {
10
+ export class FailedAcquireLockError extends Error {
21
11
  constructor(message, cause) {
22
12
  super(message, { cause });
13
+ this.name = FailedAcquireLockError.name;
23
14
  }
24
15
  }
25
16
  /**
@@ -28,9 +19,10 @@ export class KeyAlreadyAcquiredLockError extends LockError {
28
19
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
29
20
  * @group Errors
30
21
  */
31
- export class UnownedReleaseLockError extends LockError {
22
+ export class FailedReleaseLockError extends Error {
32
23
  constructor(message, cause) {
33
24
  super(message, { cause });
25
+ this.name = FailedReleaseLockError.name;
34
26
  }
35
27
  }
36
28
  /**
@@ -39,9 +31,10 @@ export class UnownedReleaseLockError extends LockError {
39
31
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
40
32
  * @group Errors
41
33
  */
42
- export class UnownedRefreshLockError extends LockError {
34
+ export class FailedRefreshLockError extends Error {
43
35
  constructor(message, cause) {
44
36
  super(message, { cause });
37
+ this.name = FailedRefreshLockError.name;
45
38
  }
46
39
  }
47
40
  /**
@@ -50,9 +43,21 @@ export class UnownedRefreshLockError extends LockError {
50
43
  * @group Errors
51
44
  */
52
45
  export const LOCK_ERRORS = {
53
- Base: LockError,
54
- KeyAlreadyAcquired: KeyAlreadyAcquiredLockError,
55
- UnownedRelease: UnownedReleaseLockError,
56
- UnownedRefresh: UnownedRefreshLockError,
46
+ FailedAcquire: FailedAcquireLockError,
47
+ FailedRelease: FailedReleaseLockError,
48
+ FailedRefresh: FailedRefreshLockError,
57
49
  };
50
+ /**
51
+ *
52
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
53
+ * @group Errors
54
+ */
55
+ export function isLockError(value) {
56
+ for (const ErrorClass of Object.values(LOCK_ERRORS)) {
57
+ if (!(value instanceof ErrorClass)) {
58
+ return false;
59
+ }
60
+ }
61
+ return true;
62
+ }
58
63
  //# sourceMappingURL=lock.errors.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"lock.errors.js","sourceRoot":"","sources":["../../../src/lock/contracts/lock.errors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH;;;;GAIG;AACH,MAAM,OAAO,SAAU,SAAQ,KAAK;IAChC,YAAY,OAAe,EAAE,KAAe;QACxC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAC9B,CAAC;CACJ;AAED;;;;;GAKG;AACH,MAAM,OAAO,2BAA4B,SAAQ,SAAS;IACtD,YAAY,OAAe,EAAE,KAAe;QACxC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAC9B,CAAC;CACJ;AAED;;;;;GAKG;AACH,MAAM,OAAO,uBAAwB,SAAQ,SAAS;IAClD,YAAY,OAAe,EAAE,KAAe;QACxC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAC9B,CAAC;CACJ;AAED;;;;;GAKG;AACH,MAAM,OAAO,uBAAwB,SAAQ,SAAS;IAClD,YAAY,OAAe,EAAE,KAAe;QACxC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAC9B,CAAC;CACJ;AAED;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG;IACvB,IAAI,EAAE,SAAS;IACf,kBAAkB,EAAE,2BAA2B;IAC/C,cAAc,EAAE,uBAAuB;IACvC,cAAc,EAAE,uBAAuB;CACjC,CAAC"}
1
+ {"version":3,"file":"lock.errors.js","sourceRoot":"","sources":["../../../src/lock/contracts/lock.errors.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH;;;;;GAKG;AACH,MAAM,OAAO,sBAAuB,SAAQ,KAAK;IAC7C,YAAY,OAAe,EAAE,KAAe;QACxC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,sBAAsB,CAAC,IAAI,CAAC;IAC5C,CAAC;CACJ;AAED;;;;;GAKG;AACH,MAAM,OAAO,sBAAuB,SAAQ,KAAK;IAC7C,YAAY,OAAe,EAAE,KAAe;QACxC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,sBAAsB,CAAC,IAAI,CAAC;IAC5C,CAAC;CACJ;AAED;;;;;GAKG;AACH,MAAM,OAAO,sBAAuB,SAAQ,KAAK;IAC7C,YAAY,OAAe,EAAE,KAAe;QACxC,KAAK,CAAC,OAAO,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;QAC1B,IAAI,CAAC,IAAI,GAAG,sBAAsB,CAAC,IAAI,CAAC;IAC5C,CAAC;CACJ;AAED;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG;IACvB,aAAa,EAAE,sBAAsB;IACrC,aAAa,EAAE,sBAAsB;IACrC,aAAa,EAAE,sBAAsB;CAC/B,CAAC;AAYX;;;;GAIG;AACH,MAAM,UAAU,WAAW,CAAC,KAAc;IACtC,KAAK,MAAM,UAAU,IAAI,MAAM,CAAC,MAAM,CAAC,WAAW,CAAC,EAAE,CAAC;QAClD,IAAI,CAAC,CAAC,KAAK,YAAY,UAAU,CAAC,EAAE,CAAC;YACjC,OAAO,KAAK,CAAC;QACjB,CAAC;IACL,CAAC;IACD,OAAO,IAAI,CAAC;AAChB,CAAC"}
@@ -1,36 +1,36 @@
1
1
  /**
2
2
  * @module Lock
3
3
  */
4
- import type { TimeSpan } from "../../utilities/_module-exports.js";
4
+ import type { ILockStateMethods } from "../../lock/contracts/lock.contract.js";
5
+ /**
6
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
7
+ * @group Events
8
+ */
9
+ export type LockEventBase = {
10
+ lock: ILockStateMethods;
11
+ };
5
12
  /**
6
13
  * The event is dispatched when a lock is aquired.
7
14
  *
8
15
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
9
16
  * @group Events
10
17
  */
11
- export type AcquiredLockEvent = {
12
- key: string;
13
- owner: string;
14
- ttl: TimeSpan | null;
15
- };
18
+ export type AcquiredLockEvent = LockEventBase;
16
19
  /**
17
20
  * The event is dispatched when a lock is released.
18
21
  *
19
22
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
20
23
  * @group Events
21
24
  */
22
- export type ReleasedLockEvent = {
23
- key: string;
24
- owner: string;
25
- };
25
+ export type ReleasedLockEvent = LockEventBase;
26
26
  /**
27
27
  * The event is dispatched when a lock is forcefully released.
28
28
  *
29
29
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
30
30
  * @group Events
31
31
  */
32
- export type ForceReleasedLockEvent = {
33
- key: string;
32
+ export type ForceReleasedLockEvent = LockEventBase & {
33
+ hasReleased: boolean;
34
34
  };
35
35
  /**
36
36
  * The event is dispatched when trying to release a lock that is owned by a different owner.
@@ -38,50 +38,34 @@ export type ForceReleasedLockEvent = {
38
38
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
39
39
  * @group Events
40
40
  */
41
- export type UnownedReleaseTryLockEvent = {
42
- key: string;
43
- owner: string;
44
- };
41
+ export type FailedReleaseLockEvent = LockEventBase;
45
42
  /**
46
43
  * The event is dispatched when trying to refefresh a lock that is owned by a different owner.
47
44
  *
48
45
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
49
46
  * @group Events
50
47
  */
51
- export type UnownedRefreshTryLockEvent = {
52
- key: string;
53
- owner: string;
54
- };
48
+ export type FailedRefreshLockEvent = LockEventBase;
55
49
  /**
56
50
  * The event is dispatched when trying to acquire a lock that is owned by a different owner.
57
51
  *
58
52
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
59
53
  * @group Events
60
54
  */
61
- export type UnavailableLockEvent = {
62
- key: string;
63
- owner: string;
64
- };
55
+ export type UnavailableLockEvent = LockEventBase;
65
56
  /**
66
57
  * The event is dispatched when a lock is refreshed.
67
58
  *
68
59
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
69
60
  * @group Events
70
61
  */
71
- export type RefreshedLockEvent = {
72
- key: string;
73
- owner: string;
74
- ttl: TimeSpan;
75
- };
62
+ export type RefreshedLockEvent = LockEventBase;
76
63
  /**
77
64
  *
78
65
  * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
79
66
  * @group Events
80
67
  */
81
- export type UnexpectedErrorLockEvent = {
82
- key: string;
83
- owner: string;
84
- ttl: TimeSpan | null;
68
+ export type UnexpectedErrorLockEvent = LockEventBase & {
85
69
  error: unknown;
86
70
  };
87
71
  /**
@@ -92,8 +76,8 @@ export type UnexpectedErrorLockEvent = {
92
76
  export declare const LOCK_EVENTS: {
93
77
  readonly ACQUIRED: "ACQUIRED";
94
78
  readonly RELEASED: "RELEASED";
95
- readonly UNOWNED_RELEASE_TRY: "UNOWNED_RELEASE_TRY";
96
- readonly UNOWNED_REFRESH_TRY: "UNOWNED_REFRESH_TRY";
79
+ readonly FAILED_RELEASE: "FAILED_RELEASE";
80
+ readonly FAILED_REFRESH: "FAILED_REFRESH";
97
81
  readonly UNAVAILABLE: "UNAVAILABLE";
98
82
  readonly FORCE_RELEASED: "FORCE_RELEASED";
99
83
  readonly REFRESHED: "REFRESHED";
@@ -107,8 +91,8 @@ export declare const LOCK_EVENTS: {
107
91
  export type LockEventMap = {
108
92
  [LOCK_EVENTS.ACQUIRED]: AcquiredLockEvent;
109
93
  [LOCK_EVENTS.RELEASED]: ReleasedLockEvent;
110
- [LOCK_EVENTS.UNOWNED_RELEASE_TRY]: UnownedReleaseTryLockEvent;
111
- [LOCK_EVENTS.UNOWNED_REFRESH_TRY]: UnownedRefreshTryLockEvent;
94
+ [LOCK_EVENTS.FAILED_RELEASE]: FailedReleaseLockEvent;
95
+ [LOCK_EVENTS.FAILED_REFRESH]: FailedRefreshLockEvent;
112
96
  [LOCK_EVENTS.UNAVAILABLE]: UnavailableLockEvent;
113
97
  [LOCK_EVENTS.FORCE_RELEASED]: ForceReleasedLockEvent;
114
98
  [LOCK_EVENTS.REFRESHED]: RefreshedLockEvent;
@@ -9,8 +9,8 @@
9
9
  export const LOCK_EVENTS = {
10
10
  ACQUIRED: "ACQUIRED",
11
11
  RELEASED: "RELEASED",
12
- UNOWNED_RELEASE_TRY: "UNOWNED_RELEASE_TRY",
13
- UNOWNED_REFRESH_TRY: "UNOWNED_REFRESH_TRY",
12
+ FAILED_RELEASE: "FAILED_RELEASE",
13
+ FAILED_REFRESH: "FAILED_REFRESH",
14
14
  UNAVAILABLE: "UNAVAILABLE",
15
15
  FORCE_RELEASED: "FORCE_RELEASED",
16
16
  REFRESHED: "REFRESHED",
@@ -1 +1 @@
1
- {"version":3,"file":"lock.events.js","sourceRoot":"","sources":["../../../src/lock/contracts/lock.events.ts"],"names":[],"mappings":"AAAA;;GAEG;AAgGH;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG;IACvB,QAAQ,EAAE,UAAU;IACpB,QAAQ,EAAE,UAAU;IACpB,mBAAmB,EAAE,qBAAqB;IAC1C,mBAAmB,EAAE,qBAAqB;IAC1C,WAAW,EAAE,aAAa;IAC1B,cAAc,EAAE,gBAAgB;IAChC,SAAS,EAAE,WAAW;IACtB,gBAAgB,EAAE,kBAAkB;CAC9B,CAAC"}
1
+ {"version":3,"file":"lock.events.js","sourceRoot":"","sources":["../../../src/lock/contracts/lock.events.ts"],"names":[],"mappings":"AAAA;;GAEG;AAiFH;;;;GAIG;AACH,MAAM,CAAC,MAAM,WAAW,GAAG;IACvB,QAAQ,EAAE,UAAU;IACpB,QAAQ,EAAE,UAAU;IACpB,cAAc,EAAE,gBAAgB;IAChC,cAAc,EAAE,gBAAgB;IAChC,WAAW,EAAE,aAAa;IAC1B,cAAc,EAAE,gBAAgB;IAChC,SAAS,EAAE,WAAW;IACtB,gBAAgB,EAAE,kBAAkB;CAC9B,CAAC"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * @module Lock
3
+ */
4
+ import type { IDatabaseLockAdapter } from "../../lock/contracts/database-lock-adapter.contract.js";
5
+ import type { ILockAdapter } from "../../lock/contracts/lock-adapter.contract.js";
6
+ /**
7
+ *
8
+ * IMPORT_PATH: `"@daiso-tech/core/lock/contracts"`
9
+ * @group Contracts
10
+ */
11
+ export type LockAdapterVariants = ILockAdapter | IDatabaseLockAdapter;
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @module Lock
3
+ */
4
+ export {};
5
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../../src/lock/contracts/types.ts"],"names":[],"mappings":"AAAA;;GAEG"}