@daiso-tech/core 0.44.0 → 0.46.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.
- package/README.md +50 -41
- package/dist/cache/contracts/cache.errors.d.ts +3 -3
- package/dist/cache/contracts/cache.errors.js +1 -1
- package/dist/cache/contracts/cache.errors.js.map +1 -1
- package/dist/cache/contracts/cache.events.d.ts +8 -8
- package/dist/cache/contracts/cache.events.js +1 -1
- package/dist/cache/contracts/cache.events.js.map +1 -1
- package/dist/cache/contracts/database-cache-adapter.contract.d.ts +10 -48
- package/dist/cache/contracts/database-cache-adapter.contract.js +1 -1
- package/dist/cache/contracts/database-cache-adapter.contract.js.map +1 -1
- package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.d.ts +24 -19
- package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js +138 -134
- package/dist/cache/implementations/adapters/kysely-cache-adapter/kysely-cache-adapter.js.map +1 -1
- package/dist/cache/implementations/derivables/cache/cache.d.ts +2 -8
- package/dist/cache/implementations/derivables/cache/cache.js +3 -8
- package/dist/cache/implementations/derivables/cache/cache.js.map +1 -1
- package/dist/cache/implementations/derivables/cache/database-cache-adapter.d.ts +3 -1
- package/dist/cache/implementations/derivables/cache/database-cache-adapter.js +49 -64
- package/dist/cache/implementations/derivables/cache/database-cache-adapter.js.map +1 -1
- package/dist/cache/implementations/derivables/cache/is-database-cache-adapter.js +5 -10
- package/dist/cache/implementations/derivables/cache/is-database-cache-adapter.js.map +1 -1
- package/dist/cache/implementations/derivables/cache-factory/cache-factory.d.ts +2 -2
- package/dist/cache/implementations/derivables/cache-factory/cache-factory.js +2 -4
- package/dist/cache/implementations/derivables/cache-factory/cache-factory.js.map +1 -1
- package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js +240 -238
- package/dist/cache/implementations/test-utilities/cache-adapter.test-suite.js.map +1 -1
- package/dist/cache/implementations/test-utilities/cache.test-suite.js +141 -36
- package/dist/cache/implementations/test-utilities/cache.test-suite.js.map +1 -1
- package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.d.ts +0 -1
- package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js +215 -630
- package/dist/cache/implementations/test-utilities/database-cache-dapter.test-suite.js.map +1 -1
- package/dist/circuit-breaker/contracts/circuit-breaker.errors.d.ts +3 -3
- package/dist/circuit-breaker/contracts/circuit-breaker.errors.js +1 -1
- package/dist/circuit-breaker/contracts/circuit-breaker.errors.js.map +1 -1
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-provider.d.ts +11 -8
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-provider.js +3 -8
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-provider.js.map +1 -1
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-serde-transformer.d.ts +2 -2
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-serde-transformer.js +1 -1
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker-serde-transformer.js.map +1 -1
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker.d.ts +4 -4
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker.js +1 -1
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider/circuit-breaker.js.map +1 -1
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/circuit-breaker-provider-factory.d.ts +2 -2
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/circuit-breaker-provider-factory.js +2 -4
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/circuit-breaker-provider-factory.js.map +1 -1
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/database-circuit-breaker-provider-factory.d.ts +2 -2
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/database-circuit-breaker-provider-factory.js +2 -4
- package/dist/circuit-breaker/implementations/derivables/circuit-breaker-provider-factory/database-circuit-breaker-provider-factory.js.map +1 -1
- package/dist/event-bus/implementations/derivables/event-bus/event-bus.d.ts +2 -8
- package/dist/event-bus/implementations/derivables/event-bus/event-bus.js +3 -8
- package/dist/event-bus/implementations/derivables/event-bus/event-bus.js.map +1 -1
- package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.d.ts +2 -2
- package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js +2 -4
- package/dist/event-bus/implementations/derivables/event-bus-factory/event-bus-factory.js.map +1 -1
- package/dist/lock/contracts/lock.errors.d.ts +4 -4
- package/dist/lock/contracts/lock.errors.js +1 -1
- package/dist/lock/contracts/lock.errors.js.map +1 -1
- package/dist/lock/implementations/derivables/lock-provider/lock-provider.d.ts +11 -8
- package/dist/lock/implementations/derivables/lock-provider/lock-provider.js +3 -8
- package/dist/lock/implementations/derivables/lock-provider/lock-provider.js.map +1 -1
- package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.d.ts +2 -2
- package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js +1 -1
- package/dist/lock/implementations/derivables/lock-provider/lock-serde-transformer.js.map +1 -1
- package/dist/lock/implementations/derivables/lock-provider/lock.d.ts +4 -4
- package/dist/lock/implementations/derivables/lock-provider/lock.js +1 -1
- package/dist/lock/implementations/derivables/lock-provider/lock.js.map +1 -1
- package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.d.ts +2 -2
- package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js +2 -4
- package/dist/lock/implementations/derivables/lock-provider-factory/lock-provider-factory.js.map +1 -1
- package/dist/namespace/contracts/_module-exports.d.ts +1 -0
- package/dist/namespace/contracts/_module-exports.js +2 -0
- package/dist/namespace/contracts/_module-exports.js.map +1 -0
- package/dist/namespace/contracts/_module.d.ts +1 -0
- package/dist/namespace/contracts/_module.js +2 -0
- package/dist/namespace/contracts/_module.js.map +1 -0
- package/dist/namespace/contracts/namespace.contract.d.ts +17 -0
- package/dist/namespace/contracts/namespace.contract.js +5 -0
- package/dist/namespace/contracts/namespace.contract.js.map +1 -0
- package/dist/namespace/implementations/_module-exports.d.ts +2 -0
- package/dist/namespace/implementations/_module-exports.js +3 -0
- package/dist/namespace/implementations/_module-exports.js.map +1 -0
- package/dist/namespace/implementations/_module.d.ts +2 -0
- package/dist/namespace/implementations/_module.js +3 -0
- package/dist/namespace/implementations/_module.js.map +1 -0
- package/dist/namespace/{namespace.d.ts → implementations/namespace.d.ts} +18 -33
- package/dist/namespace/{namespace.js → implementations/namespace.js} +20 -4
- package/dist/namespace/implementations/namespace.js.map +1 -0
- package/dist/namespace/implementations/no-op-namespace.d.ts +14 -0
- package/dist/namespace/implementations/no-op-namespace.js +34 -0
- package/dist/namespace/implementations/no-op-namespace.js.map +1 -0
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-provider.d.ts +21 -9
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-provider.js +30 -10
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-provider.js.map +1 -1
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-serde-transformer.d.ts +38 -0
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-serde-transformer.js +75 -0
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter-serde-transformer.js.map +1 -0
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter.d.ts +21 -2
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter.js +25 -2
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider/rate-limiter.js.map +1 -1
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/database-rate-limiter-provider-factory.d.ts +2 -2
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/database-rate-limiter-provider-factory.js +2 -4
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/database-rate-limiter-provider-factory.js.map +1 -1
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/rate-limiter-provider-factory.d.ts +2 -2
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/rate-limiter-provider-factory.js +2 -4
- package/dist/rate-limiter/implementations/derivables/rate-limiter-provider-factory/rate-limiter-provider-factory.js.map +1 -1
- package/dist/semaphore/contracts/semaphore.errors.d.ts +4 -4
- package/dist/semaphore/contracts/semaphore.errors.js +1 -1
- package/dist/semaphore/contracts/semaphore.errors.js.map +1 -1
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.d.ts +11 -8
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js +3 -8
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-provider.js.map +1 -1
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.d.ts +2 -2
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js +1 -1
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore-serde-transformer.js.map +1 -1
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.d.ts +4 -4
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js +1 -1
- package/dist/semaphore/implementations/derivables/semaphore-provider/semaphore.js.map +1 -1
- package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.d.ts +2 -2
- package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js +2 -4
- package/dist/semaphore/implementations/derivables/semaphore-provider-factory/semaphore-provider-factory.js.map +1 -1
- package/dist/shared-lock/contracts/shared-lock.errors.d.ts +7 -7
- package/dist/shared-lock/contracts/shared-lock.errors.js +1 -1
- package/dist/shared-lock/contracts/shared-lock.errors.js.map +1 -1
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.d.ts +11 -8
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js +3 -8
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-provider.js.map +1 -1
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.d.ts +2 -2
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js +1 -1
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock-serde-transformer.js.map +1 -1
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.d.ts +4 -4
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js +1 -1
- package/dist/shared-lock/implementations/derivables/shared-lock-provider/shared-lock.js.map +1 -1
- package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.d.ts +2 -2
- package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js +2 -4
- package/dist/shared-lock/implementations/derivables/shared-lock-provider-factory/shared-lock-provider-factory.js.map +1 -1
- package/dist/task/implementations/task.d.ts +1 -1
- package/dist/task/implementations/task.js +1 -1
- package/dist/task/implementations/task.js.map +1 -1
- package/dist/time-span/implementations/time-span.d.ts +17 -0
- package/dist/time-span/implementations/time-span.js +27 -1
- package/dist/time-span/implementations/time-span.js.map +1 -1
- package/dist/utilities/functions/error-policy.d.ts +1 -1
- package/dist/utilities/functions/error-policy.js +1 -2
- package/dist/utilities/functions/error-policy.js.map +1 -1
- package/package.json +48 -65
- package/dist/namespace/_module-exports.d.ts +0 -1
- package/dist/namespace/_module-exports.js +0 -2
- package/dist/namespace/_module-exports.js.map +0 -1
- package/dist/namespace/_module.d.ts +0 -1
- package/dist/namespace/_module.js +0 -2
- package/dist/namespace/_module.js.map +0 -1
- package/dist/namespace/namespace.js.map +0 -1
|
@@ -11,21 +11,29 @@ export class DatabaseCacheAdapter {
|
|
|
11
11
|
constructor(adapter) {
|
|
12
12
|
this.adapter = adapter;
|
|
13
13
|
}
|
|
14
|
-
|
|
15
|
-
const data = await this.adapter.find(key);
|
|
14
|
+
static handleData(data) {
|
|
16
15
|
if (data === null) {
|
|
17
16
|
return null;
|
|
18
17
|
}
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
return value;
|
|
18
|
+
if (data.expiration === null) {
|
|
19
|
+
return data.value;
|
|
22
20
|
}
|
|
23
|
-
|
|
24
|
-
if (hasExpired) {
|
|
25
|
-
await this.adapter.removeExpiredMany([key]);
|
|
21
|
+
if (data.expiration <= new Date()) {
|
|
26
22
|
return null;
|
|
27
23
|
}
|
|
28
|
-
return value;
|
|
24
|
+
return data.value;
|
|
25
|
+
}
|
|
26
|
+
static isExpired(cacheExpiration) {
|
|
27
|
+
if (cacheExpiration === null) {
|
|
28
|
+
return true;
|
|
29
|
+
}
|
|
30
|
+
if (cacheExpiration.expiration === null) {
|
|
31
|
+
return false;
|
|
32
|
+
}
|
|
33
|
+
return cacheExpiration.expiration <= new Date();
|
|
34
|
+
}
|
|
35
|
+
async get(key) {
|
|
36
|
+
return DatabaseCacheAdapter.handleData(await this.adapter.find(key));
|
|
29
37
|
}
|
|
30
38
|
async getAndRemove(key) {
|
|
31
39
|
const value = await this.get(key);
|
|
@@ -35,75 +43,52 @@ export class DatabaseCacheAdapter {
|
|
|
35
43
|
return value;
|
|
36
44
|
}
|
|
37
45
|
async add(key, value, ttl) {
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
}
|
|
46
|
+
const expiration = ttl?.toEndDate() ?? null;
|
|
47
|
+
return await this.adapter.transaction(async (trx) => {
|
|
48
|
+
const storedValue = DatabaseCacheAdapter.handleData(await trx.find(key));
|
|
49
|
+
if (storedValue !== null) {
|
|
50
|
+
return false;
|
|
51
|
+
}
|
|
52
|
+
await trx.upsert(key, value, expiration);
|
|
44
53
|
return true;
|
|
45
|
-
}
|
|
46
|
-
catch {
|
|
47
|
-
const result = await this.adapter.updateExpired({
|
|
48
|
-
expiration: ttl?.toEndDate() ?? null,
|
|
49
|
-
key,
|
|
50
|
-
value,
|
|
51
|
-
});
|
|
52
|
-
return result > 0;
|
|
53
|
-
}
|
|
54
|
+
});
|
|
54
55
|
}
|
|
55
56
|
async put(key, value, ttl) {
|
|
56
|
-
const
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
57
|
+
const expiration = ttl?.toEndDate() ?? null;
|
|
58
|
+
return await this.adapter.transaction(async (trx) => {
|
|
59
|
+
const storedValue = DatabaseCacheAdapter.handleData(await trx.find(key));
|
|
60
|
+
await trx.upsert(key, value, expiration);
|
|
61
|
+
return storedValue !== null;
|
|
60
62
|
});
|
|
61
|
-
if (data === null) {
|
|
62
|
-
return false;
|
|
63
|
-
}
|
|
64
|
-
const { expiration } = data;
|
|
65
|
-
if (expiration === null) {
|
|
66
|
-
return true;
|
|
67
|
-
}
|
|
68
|
-
const hasExpired = expiration.getTime() <= new Date().getTime();
|
|
69
|
-
return !hasExpired;
|
|
70
63
|
}
|
|
71
64
|
async update(key, value) {
|
|
72
|
-
|
|
73
|
-
key,
|
|
74
|
-
value,
|
|
75
|
-
});
|
|
76
|
-
return result > 0;
|
|
65
|
+
return !DatabaseCacheAdapter.isExpired(await this.adapter.update(key, value));
|
|
77
66
|
}
|
|
78
67
|
async increment(key, value) {
|
|
79
|
-
|
|
80
|
-
const
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
68
|
+
return await this.adapter.transaction(async (trx) => {
|
|
69
|
+
const storedValue = DatabaseCacheAdapter.handleData(await trx.find(key));
|
|
70
|
+
if (storedValue === null) {
|
|
71
|
+
return false;
|
|
72
|
+
}
|
|
73
|
+
if (typeof storedValue !== "number") {
|
|
74
|
+
throw new TypeError("!!__MESSAGE__!!");
|
|
75
|
+
}
|
|
76
|
+
await trx.upsert(key, (storedValue + value));
|
|
77
|
+
return true;
|
|
78
|
+
});
|
|
79
|
+
}
|
|
80
|
+
async removeMany(keys) {
|
|
81
|
+
const results = await this.adapter.removeMany(keys);
|
|
82
|
+
for (const result of results) {
|
|
83
|
+
if (!DatabaseCacheAdapter.isExpired(result)) {
|
|
84
|
+
return true;
|
|
89
85
|
}
|
|
90
|
-
throw new TypeError(`Unable to increment or decrement none number type key "${key}"`, { cause: error });
|
|
91
86
|
}
|
|
87
|
+
return false;
|
|
92
88
|
}
|
|
93
89
|
async removeAll() {
|
|
94
90
|
await this.adapter.removeAll();
|
|
95
91
|
}
|
|
96
|
-
async removeMany(keys) {
|
|
97
|
-
const [promiseResult] = await Promise.allSettled([
|
|
98
|
-
this.adapter.removeUnexpiredMany(keys),
|
|
99
|
-
this.adapter.removeExpiredMany(keys),
|
|
100
|
-
]);
|
|
101
|
-
if (promiseResult.status === "rejected") {
|
|
102
|
-
throw promiseResult.reason;
|
|
103
|
-
}
|
|
104
|
-
const { value: result } = promiseResult;
|
|
105
|
-
return result > 0;
|
|
106
|
-
}
|
|
107
92
|
async removeByKeyPrefix(prefix) {
|
|
108
93
|
await this.adapter.removeByKeyPrefix(prefix);
|
|
109
94
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"database-cache-adapter.js","sourceRoot":"","sources":["../../../../../src/cache/implementations/derivables/cache/database-cache-adapter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,
|
|
1
|
+
{"version":3,"file":"database-cache-adapter.js","sourceRoot":"","sources":["../../../../../src/cache/implementations/derivables/cache/database-cache-adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -9,16 +9,11 @@ export function isDatabaseCacheAdapter(adapter) {
|
|
|
9
9
|
const adapter_ = adapter;
|
|
10
10
|
return (typeof adapter_["find"] === "function" &&
|
|
11
11
|
adapter_["find"].length === 1 &&
|
|
12
|
-
typeof adapter_["
|
|
13
|
-
adapter_["
|
|
14
|
-
typeof adapter_["
|
|
15
|
-
adapter_["
|
|
16
|
-
typeof adapter_["
|
|
17
|
-
adapter_["updateUnexpired"].length === 1 &&
|
|
18
|
-
typeof adapter_["incrementUnexpired"] === "function" &&
|
|
19
|
-
adapter_["incrementUnexpired"].length === 1 &&
|
|
20
|
-
typeof adapter_["removeExpiredMany"] === "function" &&
|
|
21
|
-
typeof adapter_["removeUnexpiredMany"] === "function" &&
|
|
12
|
+
typeof adapter_["transaction"] === "function" &&
|
|
13
|
+
adapter_["transaction"].length === 1 &&
|
|
14
|
+
typeof adapter_["update"] === "function" &&
|
|
15
|
+
adapter_["update"].length === 2 &&
|
|
16
|
+
typeof adapter_["removeMany"] === "function" &&
|
|
22
17
|
typeof adapter_["removeAll"] === "function" &&
|
|
23
18
|
adapter_["removeAll"].length === 0 &&
|
|
24
19
|
typeof adapter_["removeByKeyPrefix"] === "function" &&
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"is-database-cache-adapter.js","sourceRoot":"","sources":["../../../../../src/cache/implementations/derivables/cache/is-database-cache-adapter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAGN,MAAM,8BAA8B,CAAC;AAEtC;;GAEG;AACH,MAAM,UAAU,sBAAsB,CAClC,OAAoC;IAEpC,MAAM,QAAQ,GAAG,OAAkD,CAAC;IACpE,OAAO,CACH,OAAO,QAAQ,CAAC,MAAM,CAAC,KAAK,UAAU;QACtC,QAAQ,CAAC,MAAM,CAAC,CAAC,MAAM,KAAK,CAAC;QAC7B,OAAO,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"is-database-cache-adapter.js","sourceRoot":"","sources":["../../../../../src/cache/implementations/derivables/cache/is-database-cache-adapter.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAGN,MAAM,8BAA8B,CAAC;AAEtC;;GAEG;AACH,MAAM,UAAU,sBAAsB,CAClC,OAAoC;IAEpC,MAAM,QAAQ,GAAG,OAAkD,CAAC;IACpE,OAAO,CACH,OAAO,QAAQ,CAAC,MAAM,CAAC,KAAK,UAAU;QACtC,QAAQ,CAAC,MAAM,CAAC,CAAC,MAAM,KAAK,CAAC;QAC7B,OAAO,QAAQ,CAAC,aAAa,CAAC,KAAK,UAAU;QAC7C,QAAQ,CAAC,aAAa,CAAC,CAAC,MAAM,KAAK,CAAC;QACpC,OAAO,QAAQ,CAAC,QAAQ,CAAC,KAAK,UAAU;QACxC,QAAQ,CAAC,QAAQ,CAAC,CAAC,MAAM,KAAK,CAAC;QAC/B,OAAO,QAAQ,CAAC,YAAY,CAAC,KAAK,UAAU;QAC5C,OAAO,QAAQ,CAAC,WAAW,CAAC,KAAK,UAAU;QAC3C,QAAQ,CAAC,WAAW,CAAC,CAAC,MAAM,KAAK,CAAC;QAClC,OAAO,QAAQ,CAAC,mBAAmB,CAAC,KAAK,UAAU;QACnD,QAAQ,CAAC,mBAAmB,CAAC,CAAC,MAAM,KAAK,CAAC,CAC7C,CAAC;AACN,CAAC"}
|
|
@@ -5,7 +5,7 @@ import { type StandardSchemaV1 } from "@standard-schema/spec";
|
|
|
5
5
|
import { type CacheAdapterVariants, type ICache, type ICacheFactory } from "../../../../cache/contracts/_module.js";
|
|
6
6
|
import { type CacheSettingsBase } from "../../../../cache/implementations/derivables/cache/_module.js";
|
|
7
7
|
import { type IEventBus } from "../../../../event-bus/contracts/_module.js";
|
|
8
|
-
import { type
|
|
8
|
+
import { type INamespace } from "../../../../namespace/contracts/_module.js";
|
|
9
9
|
import { type ITimeSpan } from "../../../../time-span/contracts/_module.js";
|
|
10
10
|
/**
|
|
11
11
|
*
|
|
@@ -54,7 +54,7 @@ export declare class CacheFactory<TAdapters extends string = string, TType = unk
|
|
|
54
54
|
* });
|
|
55
55
|
*/
|
|
56
56
|
constructor(settings: CacheFactorySettings<TAdapters, TType>);
|
|
57
|
-
setNamespace(namespace:
|
|
57
|
+
setNamespace(namespace: INamespace): CacheFactory<TAdapters, TType>;
|
|
58
58
|
setDefaultTtl(ttl: ITimeSpan): CacheFactory<TAdapters, TType>;
|
|
59
59
|
setEventBus(eventBus: IEventBus): CacheFactory<TAdapters, TType>;
|
|
60
60
|
setSchema<TSchemaOutputType>(schema: StandardSchemaV1<TSchemaOutputType>): CacheFactory<TAdapters, TSchemaOutputType>;
|
|
@@ -3,9 +3,9 @@
|
|
|
3
3
|
*/
|
|
4
4
|
import {} from "@standard-schema/spec";
|
|
5
5
|
import {} from "../../../../cache/contracts/_module.js";
|
|
6
|
-
import { Cache,
|
|
6
|
+
import { Cache, } from "../../../../cache/implementations/derivables/cache/_module.js";
|
|
7
7
|
import {} from "../../../../event-bus/contracts/_module.js";
|
|
8
|
-
import {} from "../../../../namespace/_module.js";
|
|
8
|
+
import {} from "../../../../namespace/contracts/_module.js";
|
|
9
9
|
import {} from "../../../../time-span/contracts/_module.js";
|
|
10
10
|
import { DefaultAdapterNotDefinedError, UnregisteredAdapterError, } from "../../../../utilities/_module.js";
|
|
11
11
|
/**
|
|
@@ -124,11 +124,9 @@ export class CacheFactory {
|
|
|
124
124
|
if (adapter === undefined) {
|
|
125
125
|
throw new UnregisteredAdapterError(adapterName);
|
|
126
126
|
}
|
|
127
|
-
const { namespace = DEFAULT_CACHE_NAMESPACE } = this.settings;
|
|
128
127
|
return new Cache({
|
|
129
128
|
...this.settings,
|
|
130
129
|
adapter,
|
|
131
|
-
namespace: namespace.appendRoot(adapterName),
|
|
132
130
|
});
|
|
133
131
|
}
|
|
134
132
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cache-factory.js","sourceRoot":"","sources":["../../../../../src/cache/implementations/derivables/cache-factory/cache-factory.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAyB,MAAM,uBAAuB,CAAC;AAE9D,OAAO,EAIN,MAAM,8BAA8B,CAAC;AACtC,OAAO,EACH,KAAK,
|
|
1
|
+
{"version":3,"file":"cache-factory.js","sourceRoot":"","sources":["../../../../../src/cache/implementations/derivables/cache-factory/cache-factory.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAyB,MAAM,uBAAuB,CAAC;AAE9D,OAAO,EAIN,MAAM,8BAA8B,CAAC;AACtC,OAAO,EACH,KAAK,GAER,MAAM,qDAAqD,CAAC;AAC7D,OAAO,EAAkB,MAAM,kCAAkC,CAAC;AAClE,OAAO,EAAmB,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAkB,MAAM,kCAAkC,CAAC;AAClE,OAAO,EACH,6BAA6B,EAC7B,wBAAwB,GAC3B,MAAM,wBAAwB,CAAC;AAyBhC;;;;;GAKG;AACH,MAAM,OAAO,YAAY;IA2BA;IAxBrB;;;;;;;;;;;;;;;;;;;;;;OAsBG;IACH,YACqB,QAAgD;QAAhD,aAAQ,GAAR,QAAQ,CAAwC;IAClE,CAAC;IAEJ,YAAY,CAAC,SAAqB;QAC9B,OAAO,IAAI,YAAY,CAAC;YACpB,GAAG,IAAI,CAAC,QAAQ;YAChB,SAAS;SACZ,CAAC,CAAC;IACP,CAAC;IAED,aAAa,CAAC,GAAc;QACxB,OAAO,IAAI,YAAY,CAAC;YACpB,GAAG,IAAI,CAAC,QAAQ;YAChB,UAAU,EAAE,GAAG;SAClB,CAAC,CAAC;IACP,CAAC;IAED,WAAW,CAAC,QAAmB;QAC3B,OAAO,IAAI,YAAY,CAAC;YACpB,GAAG,IAAI,CAAC,QAAQ;YAChB,QAAQ;SACX,CAAC,CAAC;IACP,CAAC;IAED,SAAS,CACL,MAA2C;QAE3C,OAAO,IAAI,YAAY,CAAC;YACpB,GAAG,IAAI,CAAC,QAAQ;YAChB,MAAM;SACT,CAAC,CAAC;IACP,CAAC;IAED,OAAO;QACH,OAAO,IAAI,YAAY,CACnB,IAAI,CAAC,QAAwD,CAChE,CAAC;IACN,CAAC;IAED,SAAS,CAAC,MAAc;QACpB,OAAO,IAAI,YAAY,CAAC;YACpB,GAAG,IAAI,CAAC,QAAQ;YAChB,aAAa,EAAE,MAAM;SACxB,CAAC,CAAC;IACP,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OAwCG;IACH,GAAG,CACC,cAAqC,IAAI,CAAC,QAAQ,CAAC,cAAc;QAEjE,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;YAC5B,MAAM,IAAI,6BAA6B,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;QAC/D,CAAC;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;QACpD,IAAI,OAAO,KAAK,SAAS,EAAE,CAAC;YACxB,MAAM,IAAI,wBAAwB,CAAC,WAAW,CAAC,CAAC;QACpD,CAAC;QACD,OAAO,IAAI,KAAK,CAAC;YACb,GAAG,IAAI,CAAC,QAAQ;YAChB,OAAO;SACV,CAAC,CAAC;IACP,CAAC;CACJ"}
|