@zajno/common 2.7.0 → 2.7.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/api/call.js +5 -5
- package/cjs/api/call.js.map +1 -1
- package/cjs/api/config.js +30 -5
- package/cjs/api/config.js.map +1 -1
- package/cjs/api/index.js +5 -6
- package/cjs/api/index.js.map +1 -1
- package/cjs/api/interceptor.js +1 -1
- package/cjs/api/logging.js +3 -3
- package/cjs/api/logging.js.map +1 -1
- package/cjs/functions/assert.js +2 -4
- package/cjs/functions/assert.js.map +1 -1
- package/cjs/functions/disposer.js +10 -18
- package/cjs/functions/disposer.js.map +1 -1
- package/cjs/functions/throttle.js +8 -17
- package/cjs/functions/throttle.js.map +1 -1
- package/cjs/logger/batch.js +23 -3
- package/cjs/logger/batch.js.map +1 -1
- package/cjs/logger/buffered/base.js +52 -0
- package/cjs/logger/buffered/base.js.map +1 -0
- package/cjs/logger/buffered/buffered.logger.js +40 -0
- package/cjs/logger/buffered/buffered.logger.js.map +1 -0
- package/cjs/logger/buffered/buffered.memory.js +71 -0
- package/cjs/logger/buffered/buffered.memory.js.map +1 -0
- package/cjs/logger/buffered/file/buffered.file.js +43 -0
- package/cjs/logger/buffered/file/buffered.file.js.map +1 -0
- package/cjs/logger/buffered/file/index.js +5 -0
- package/cjs/logger/buffered/file/index.js.map +1 -0
- package/cjs/logger/buffered/index.js +7 -0
- package/cjs/logger/buffered/index.js.map +1 -0
- package/cjs/logger/console.js +1 -39
- package/cjs/logger/console.js.map +1 -1
- package/cjs/logger/empty.js +11 -0
- package/cjs/logger/empty.js.map +1 -0
- package/cjs/logger/index.js +5 -7
- package/cjs/logger/index.js.map +1 -1
- package/cjs/logger/loggable.js +39 -0
- package/cjs/logger/loggable.js.map +1 -0
- package/cjs/logger/manager.js +70 -20
- package/cjs/logger/manager.js.map +1 -1
- package/cjs/logger/named.js +15 -12
- package/cjs/logger/named.js.map +1 -1
- package/cjs/logger/provider.js +33 -0
- package/cjs/logger/provider.js.map +1 -0
- package/cjs/logger/proxy.js +3 -7
- package/cjs/logger/proxy.js.map +1 -1
- package/cjs/logger/types.js +9 -0
- package/cjs/logger/types.js.map +1 -0
- package/cjs/models/LogicModel.js +13 -11
- package/cjs/models/LogicModel.js.map +1 -1
- package/cjs/observing/event.js +5 -18
- package/cjs/observing/event.js.map +1 -1
- package/cjs/observing/progressTracker.js +8 -15
- package/cjs/observing/progressTracker.js.map +1 -1
- package/cjs/structures/promiseCache.js +14 -20
- package/cjs/structures/promiseCache.js.map +1 -1
- package/cjs/structures/queue/parallel.js +11 -13
- package/cjs/structures/queue/parallel.js.map +1 -1
- package/cjs/structures/subscribersMap.js +9 -7
- package/cjs/structures/subscribersMap.js.map +1 -1
- package/esm/api/call.js +5 -5
- package/esm/api/call.js.map +1 -1
- package/esm/api/config.js +28 -4
- package/esm/api/config.js.map +1 -1
- package/esm/api/index.js +4 -2
- package/esm/api/index.js.map +1 -1
- package/esm/api/interceptor.js +1 -1
- package/esm/api/logging.js +3 -3
- package/esm/api/logging.js.map +1 -1
- package/esm/functions/assert.js +2 -3
- package/esm/functions/assert.js.map +1 -1
- package/esm/functions/disposer.js +10 -17
- package/esm/functions/disposer.js.map +1 -1
- package/esm/functions/throttle.js +6 -15
- package/esm/functions/throttle.js.map +1 -1
- package/esm/logger/batch.js +23 -3
- package/esm/logger/batch.js.map +1 -1
- package/esm/logger/buffered/base.js +48 -0
- package/esm/logger/buffered/base.js.map +1 -0
- package/esm/logger/buffered/buffered.logger.js +36 -0
- package/esm/logger/buffered/buffered.logger.js.map +1 -0
- package/esm/logger/buffered/buffered.memory.js +67 -0
- package/esm/logger/buffered/buffered.memory.js.map +1 -0
- package/esm/logger/buffered/file/buffered.file.js +38 -0
- package/esm/logger/buffered/file/buffered.file.js.map +1 -0
- package/esm/logger/buffered/file/index.js +2 -0
- package/esm/logger/buffered/file/index.js.map +1 -0
- package/esm/logger/buffered/index.js +4 -0
- package/esm/logger/buffered/index.js.map +1 -0
- package/esm/logger/console.js +0 -37
- package/esm/logger/console.js.map +1 -1
- package/esm/logger/empty.js +7 -0
- package/esm/logger/empty.js.map +1 -0
- package/esm/logger/index.js +3 -7
- package/esm/logger/index.js.map +1 -1
- package/esm/logger/loggable.js +35 -0
- package/esm/logger/loggable.js.map +1 -0
- package/esm/logger/manager.js +70 -20
- package/esm/logger/manager.js.map +1 -1
- package/esm/logger/named.js +8 -4
- package/esm/logger/named.js.map +1 -1
- package/esm/logger/provider.js +29 -0
- package/esm/logger/provider.js.map +1 -0
- package/esm/logger/proxy.js +2 -6
- package/esm/logger/proxy.js.map +1 -1
- package/esm/logger/types.js +6 -0
- package/esm/logger/types.js.map +1 -0
- package/esm/models/LogicModel.js +13 -11
- package/esm/models/LogicModel.js.map +1 -1
- package/esm/observing/event.js +5 -18
- package/esm/observing/event.js.map +1 -1
- package/esm/observing/progressTracker.js +8 -14
- package/esm/observing/progressTracker.js.map +1 -1
- package/esm/structures/promiseCache.js +14 -20
- package/esm/structures/promiseCache.js.map +1 -1
- package/esm/structures/queue/parallel.js +11 -13
- package/esm/structures/queue/parallel.js.map +1 -1
- package/esm/structures/subscribersMap.js +9 -7
- package/esm/structures/subscribersMap.js.map +1 -1
- package/package.json +13 -1
- package/tsconfig.cjs.tsbuildinfo +1 -1
- package/tsconfig.esm.tsbuildinfo +1 -1
- package/tsconfig.types.tsbuildinfo +1 -1
- package/types/api/call.types.d.ts +2 -2
- package/types/api/config.d.ts +11 -4
- package/types/api/extensions/endpointHooks.d.ts +1 -1
- package/types/api/index.d.ts +4 -2
- package/types/api/interceptor.d.ts +1 -1
- package/types/api/logging.d.ts +8 -6
- package/types/functions/assert.d.ts +3 -3
- package/types/functions/disposer.d.ts +7 -6
- package/types/functions/throttle.d.ts +4 -5
- package/types/logger/batch.d.ts +3 -2
- package/types/logger/buffered/base.d.ts +23 -0
- package/types/logger/buffered/buffered.logger.d.ts +8 -0
- package/types/logger/buffered/buffered.memory.d.ts +19 -0
- package/types/logger/buffered/file/buffered.file.d.ts +9 -0
- package/types/logger/buffered/file/index.d.ts +1 -0
- package/types/logger/buffered/index.d.ts +3 -0
- package/types/logger/console.d.ts +1 -13
- package/types/logger/empty.d.ts +3 -0
- package/types/logger/index.d.ts +6 -10
- package/types/logger/loggable.d.ts +13 -0
- package/types/logger/manager.d.ts +31 -7
- package/types/logger/named.d.ts +4 -3
- package/types/logger/provider.d.ts +11 -0
- package/types/logger/proxy.d.ts +1 -2
- package/types/logger/types.d.ts +21 -0
- package/types/models/LogicModel.d.ts +4 -4
- package/types/observing/event.d.ts +3 -6
- package/types/observing/progressTracker.d.ts +3 -4
- package/types/structures/promiseCache.d.ts +3 -4
- package/types/structures/queue/parallel.d.ts +3 -3
- package/types/structures/subscribersMap.d.ts +3 -2
- package/cjs/logger/abstractions.js +0 -3
- package/cjs/logger/abstractions.js.map +0 -1
- package/cjs/logger/file.js +0 -65
- package/cjs/logger/file.js.map +0 -1
- package/cjs/logger/shared.js +0 -18
- package/cjs/logger/shared.js.map +0 -1
- package/esm/logger/abstractions.js +0 -2
- package/esm/logger/abstractions.js.map +0 -1
- package/esm/logger/file.js +0 -60
- package/esm/logger/file.js.map +0 -1
- package/esm/logger/shared.js +0 -15
- package/esm/logger/shared.js.map +0 -1
- package/types/logger/abstractions.d.ts +0 -10
- package/types/logger/file.d.ts +0 -15
- package/types/logger/shared.d.ts +0 -15
package/cjs/observing/event.js
CHANGED
|
@@ -3,26 +3,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.Event = void 0;
|
|
4
4
|
exports.oneTimeSubscription = oneTimeSubscription;
|
|
5
5
|
const arrays_js_1 = require("../async/arrays.js");
|
|
6
|
-
const shared_js_1 = require("../logger/shared.js");
|
|
7
6
|
const safe_js_1 = require("../functions/safe.js");
|
|
8
|
-
|
|
7
|
+
const loggable_js_1 = require("../logger/loggable.js");
|
|
8
|
+
class Event extends loggable_js_1.Loggable {
|
|
9
9
|
_handlers = [];
|
|
10
|
-
_logger = null;
|
|
11
|
-
constructor(withDefaultLogger = true) {
|
|
12
|
-
if (withDefaultLogger) {
|
|
13
|
-
this.withLogger('');
|
|
14
|
-
}
|
|
15
|
-
}
|
|
16
10
|
get isEmpty() { return this._handlers.length === 0; }
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
this._logger = null;
|
|
20
|
-
return this;
|
|
21
|
-
}
|
|
22
|
-
this._logger = typeof loggerOrName === 'string'
|
|
23
|
-
? (0, shared_js_1.createLogger)(`[Event:${loggerOrName || '?'}]`)
|
|
24
|
-
: loggerOrName;
|
|
25
|
-
return this;
|
|
11
|
+
getLoggerName(name) {
|
|
12
|
+
return `[Event:${name || '?'}]`;
|
|
26
13
|
}
|
|
27
14
|
/** Clears handlers list */
|
|
28
15
|
resetHandlers = () => {
|
|
@@ -80,7 +67,7 @@ class Event {
|
|
|
80
67
|
return this;
|
|
81
68
|
}
|
|
82
69
|
logError(data, cb, err) {
|
|
83
|
-
this.
|
|
70
|
+
this.logger?.error(`type:${typeof data} Handler ${cb.name} thrown an exception: `, err);
|
|
84
71
|
}
|
|
85
72
|
}
|
|
86
73
|
exports.Event = Event;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event.js","sourceRoot":"","sources":["../../../src/observing/event.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"event.js","sourceRoot":"","sources":["../../../src/observing/event.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,13 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ProgressTracker = void 0;
|
|
4
|
-
const
|
|
5
|
-
const
|
|
6
|
-
const MathHelpers = tslib_1.__importStar(require("../math/index.js"));
|
|
7
|
-
const shared_js_1 = tslib_1.__importDefault(require("../logger/shared.js"));
|
|
4
|
+
const decompose_js_1 = require("../dates/decompose.js");
|
|
5
|
+
const arrays_js_1 = require("../math/arrays.js");
|
|
8
6
|
const event_js_1 = require("./event.js");
|
|
9
7
|
class ProgressTracker {
|
|
10
|
-
|
|
8
|
+
logger;
|
|
11
9
|
_firstTimestamp = Date.now();
|
|
12
10
|
_lastTimestamp = null;
|
|
13
11
|
_lastCompleted = null;
|
|
@@ -16,18 +14,13 @@ class ProgressTracker {
|
|
|
16
14
|
_currentProgress = 0;
|
|
17
15
|
_deltas = [];
|
|
18
16
|
_changed = new event_js_1.Event();
|
|
19
|
-
constructor(
|
|
20
|
-
this.
|
|
17
|
+
constructor(logger) {
|
|
18
|
+
this.logger = logger;
|
|
21
19
|
}
|
|
22
20
|
get changed() { return this._changed.expose(); }
|
|
23
21
|
get total() { return this._total; }
|
|
24
22
|
get completed() { return this._completed; }
|
|
25
23
|
get current() { return this._currentProgress; }
|
|
26
|
-
get logger() {
|
|
27
|
-
return this.log === true
|
|
28
|
-
? shared_js_1.default
|
|
29
|
-
: (this.log || null);
|
|
30
|
-
}
|
|
31
24
|
setTotal(total) {
|
|
32
25
|
this._total = total;
|
|
33
26
|
return this;
|
|
@@ -51,10 +44,10 @@ class ProgressTracker {
|
|
|
51
44
|
}
|
|
52
45
|
this._currentProgress = Math.floor(completed / (total || 100) * 100);
|
|
53
46
|
const itemsLeft = total - completed;
|
|
54
|
-
const leftProgressTime = itemsLeft * (
|
|
47
|
+
const leftProgressTime = itemsLeft * ((0, arrays_js_1.arrayAverage)(this._deltas, true) || 1000);
|
|
55
48
|
this._lastTimestamp = Date.now();
|
|
56
49
|
const totalElapsedMs = this._lastTimestamp - this._firstTimestamp;
|
|
57
|
-
if (this.
|
|
50
|
+
if (this.logger) {
|
|
58
51
|
const totalElapsed = msToString(totalElapsedMs);
|
|
59
52
|
const totalEstimated = msToString(leftProgressTime);
|
|
60
53
|
this.logger.log(`Progress: ${completed}/${total} ${totalElapsed}/${totalEstimated} => ${this._currentProgress}%`);
|
|
@@ -70,7 +63,7 @@ class ProgressTracker {
|
|
|
70
63
|
}
|
|
71
64
|
exports.ProgressTracker = ProgressTracker;
|
|
72
65
|
function msToString(ms) {
|
|
73
|
-
const decs =
|
|
66
|
+
const decs = (0, decompose_js_1.decomposeMs)(ms, 'second', 'minute', 'hour');
|
|
74
67
|
const nf = (n) => n.toString().padStart(2, '0');
|
|
75
68
|
return `${nf(decs.hour)}:${nf(decs.minute)}:${nf(decs.second)}`;
|
|
76
69
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"progressTracker.js","sourceRoot":"","sources":["../../../src/observing/progressTracker.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"progressTracker.js","sourceRoot":"","sources":["../../../src/observing/progressTracker.ts"],"names":[],"mappings":"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"}
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.PromiseCache = exports.DeferredGetter = void 0;
|
|
4
4
|
const throttle_js_1 = require("../functions/throttle.js");
|
|
5
|
-
const
|
|
5
|
+
const loggable_js_1 = require("../logger/loggable.js");
|
|
6
6
|
const Model_js_1 = require("../models/Model.js");
|
|
7
7
|
var DeferredGetter;
|
|
8
8
|
(function (DeferredGetter) {
|
|
@@ -21,7 +21,7 @@ const BATCHING_DELAY = 200;
|
|
|
21
21
|
* - batching of fetches.
|
|
22
22
|
* - auto-invalidation of cached items.
|
|
23
23
|
*/
|
|
24
|
-
class PromiseCache {
|
|
24
|
+
class PromiseCache extends loggable_js_1.Loggable {
|
|
25
25
|
fetcher;
|
|
26
26
|
keyAdapter;
|
|
27
27
|
keyParser;
|
|
@@ -33,9 +33,9 @@ class PromiseCache {
|
|
|
33
33
|
_batch = null;
|
|
34
34
|
_invalidationTimeMs = null;
|
|
35
35
|
_keepInstanceDuringInvalidation = false;
|
|
36
|
-
_logger = null;
|
|
37
36
|
_version = 0;
|
|
38
37
|
constructor(fetcher, keyAdapter, keyParser) {
|
|
38
|
+
super();
|
|
39
39
|
this.fetcher = fetcher;
|
|
40
40
|
this.keyAdapter = keyAdapter;
|
|
41
41
|
this.keyParser = keyParser;
|
|
@@ -69,14 +69,8 @@ class PromiseCache {
|
|
|
69
69
|
}
|
|
70
70
|
return this.keyAdapter(k);
|
|
71
71
|
}
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
this._logger = nameOrLogger;
|
|
75
|
-
}
|
|
76
|
-
else {
|
|
77
|
-
this._logger = (0, shared_js_1.createLogger)(`[PromiseCache:${nameOrLogger || '?'}]`);
|
|
78
|
-
}
|
|
79
|
-
return this;
|
|
72
|
+
getLoggerName(name) {
|
|
73
|
+
return `[PromiseCache:${name || '?'}]`;
|
|
80
74
|
}
|
|
81
75
|
/**
|
|
82
76
|
* Provide a fetcher function that takes multiple ids and returns multiple results at once. Will be called with a slight delay to allow multiple ids to be collected.
|
|
@@ -123,7 +117,7 @@ class PromiseCache {
|
|
|
123
117
|
// make sure current item is hooked here from the cache (required by observers)
|
|
124
118
|
const item = this._itemsCache.get(key);
|
|
125
119
|
if (isInvalid) {
|
|
126
|
-
this.
|
|
120
|
+
this.logger?.log(key, 'item is invalidated');
|
|
127
121
|
}
|
|
128
122
|
return {
|
|
129
123
|
item: (isInvalid && !this._keepInstanceDuringInvalidation) ? undefined : item,
|
|
@@ -137,19 +131,19 @@ class PromiseCache {
|
|
|
137
131
|
// spin fetch
|
|
138
132
|
this.get(id);
|
|
139
133
|
}
|
|
140
|
-
this.
|
|
134
|
+
this.logger?.log(key, 'getCurrent: returns', item);
|
|
141
135
|
return item;
|
|
142
136
|
}
|
|
143
137
|
get(id) {
|
|
144
138
|
const { item, key, isInvalid } = this._getCurrent(id);
|
|
145
139
|
// return cached item if it's not invalidated
|
|
146
140
|
if (item !== undefined && !isInvalid) {
|
|
147
|
-
this.
|
|
141
|
+
this.logger?.log(key, 'get: item resolved to', item, isInvalid ? '(invalidated)' : '');
|
|
148
142
|
return Promise.resolve(item);
|
|
149
143
|
}
|
|
150
144
|
let promise = this._fetchCache.get(key);
|
|
151
145
|
if (promise != null) {
|
|
152
|
-
this.
|
|
146
|
+
this.logger?.log(key, 'get: item resolved to <promise>');
|
|
153
147
|
return promise;
|
|
154
148
|
}
|
|
155
149
|
this.setStatus(key, true);
|
|
@@ -169,7 +163,7 @@ class PromiseCache {
|
|
|
169
163
|
return res;
|
|
170
164
|
}
|
|
171
165
|
if (this._fetchCache.get(key) != null) {
|
|
172
|
-
this.
|
|
166
|
+
this.logger?.log(key, 'item\'s <promise> resolved to', res);
|
|
173
167
|
res = this.prepareResult(res);
|
|
174
168
|
this.storeResult(key, res);
|
|
175
169
|
}
|
|
@@ -180,7 +174,7 @@ class PromiseCache {
|
|
|
180
174
|
this.onFetchComplete(key);
|
|
181
175
|
}
|
|
182
176
|
else {
|
|
183
|
-
this.
|
|
177
|
+
this.logger?.log(key, 'skipping item\'s resolve due to version change ("clear()" has been called)');
|
|
184
178
|
}
|
|
185
179
|
}
|
|
186
180
|
};
|
|
@@ -239,7 +233,7 @@ class PromiseCache {
|
|
|
239
233
|
}
|
|
240
234
|
/** @override */
|
|
241
235
|
setStatus(key, status) {
|
|
242
|
-
this.
|
|
236
|
+
this.logger?.log(key, 'status update:', status);
|
|
243
237
|
this._itemsStatus.set(key, status);
|
|
244
238
|
}
|
|
245
239
|
/** @override */
|
|
@@ -268,7 +262,7 @@ class PromiseCache {
|
|
|
268
262
|
/** @pure */
|
|
269
263
|
async tryFetchInBatch(id) {
|
|
270
264
|
const fetchWrap = () => this.fetcher(id).catch(err => {
|
|
271
|
-
this.
|
|
265
|
+
this.logger?.warn('fetcher failed', id, err);
|
|
272
266
|
return null;
|
|
273
267
|
});
|
|
274
268
|
if (!this._batch) {
|
|
@@ -276,7 +270,7 @@ class PromiseCache {
|
|
|
276
270
|
}
|
|
277
271
|
const res = await this._batch.push(id)
|
|
278
272
|
.catch(err => {
|
|
279
|
-
this.
|
|
273
|
+
this.logger?.warn('batch fetch failed', id, err);
|
|
280
274
|
return null;
|
|
281
275
|
});
|
|
282
276
|
if (!res || !res.result || res.result[res.index] === undefined) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"promiseCache.js","sourceRoot":"","sources":["../../../src/structures/promiseCache.ts"],"names":[],"mappings":";;;AAAA,0DAA6D;AAC7D,
|
|
1
|
+
{"version":3,"file":"promiseCache.js","sourceRoot":"","sources":["../../../src/structures/promiseCache.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,15 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.ParallelQueue = void 0;
|
|
4
|
-
const
|
|
4
|
+
const loggable_js_1 = require("../../logger/loggable.js");
|
|
5
5
|
const event_js_1 = require("../../observing/event.js");
|
|
6
6
|
const event_late_js_1 = require("../../observing/event.late.js");
|
|
7
|
-
class ParallelQueue {
|
|
7
|
+
class ParallelQueue extends loggable_js_1.Loggable {
|
|
8
8
|
_queues = {};
|
|
9
9
|
_inProgress = null;
|
|
10
10
|
_currentIndex = 0;
|
|
11
11
|
_maxIndex = 0;
|
|
12
|
-
_logger = null;
|
|
13
12
|
_beforePriorityRun = new event_js_1.Event();
|
|
14
13
|
_afterPriorityRun = new event_js_1.Event();
|
|
15
14
|
_finished = new event_late_js_1.OneTimeLateEvent();
|
|
@@ -18,9 +17,8 @@ class ParallelQueue {
|
|
|
18
17
|
get beforePriorityRun() { return this._beforePriorityRun.expose(); }
|
|
19
18
|
get afterPriorityRun() { return this._afterPriorityRun.expose(); }
|
|
20
19
|
get finished() { return this._finished.expose(); }
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
return this;
|
|
20
|
+
getLoggerName(name) {
|
|
21
|
+
return `[Queue:${name || '?'}]`;
|
|
24
22
|
}
|
|
25
23
|
/** @returns A callback that will try to cancel queued item */
|
|
26
24
|
enqueue(cb, priority) {
|
|
@@ -61,7 +59,7 @@ class ParallelQueue {
|
|
|
61
59
|
await this.tryStartQueue();
|
|
62
60
|
}
|
|
63
61
|
catch (err) {
|
|
64
|
-
this.
|
|
62
|
+
this.logger?.warn('Failed to process queue:', err);
|
|
65
63
|
return false;
|
|
66
64
|
}
|
|
67
65
|
return true;
|
|
@@ -82,24 +80,24 @@ class ParallelQueue {
|
|
|
82
80
|
const MAX_ATTEMPTS = 5;
|
|
83
81
|
while ((current = this._queues[this._currentIndex])?.length) {
|
|
84
82
|
if (iterations++ > MAX_ATTEMPTS) {
|
|
85
|
-
this.
|
|
83
|
+
this.logger?.warn('Tried to purge queue for priority =', this._currentIndex, 'for too many times of', MAX_ATTEMPTS, '; totalItems =', totalItems, '; skipping.');
|
|
86
84
|
break;
|
|
87
85
|
}
|
|
88
|
-
this.
|
|
86
|
+
this.logger?.log('Processing priority =', this._currentIndex, '; count =', current.length);
|
|
89
87
|
const items = current.slice();
|
|
90
88
|
current.length = 0;
|
|
91
89
|
totalItems += items.length;
|
|
92
90
|
await Promise.all(items.map((loader, index) => this._executeLoader(loader, this._currentIndex, index)));
|
|
93
91
|
}
|
|
94
92
|
if (!current?.length && iterations === 0) {
|
|
95
|
-
this.
|
|
93
|
+
this.logger?.log('Skipping priority =', this._currentIndex, '; no items');
|
|
96
94
|
}
|
|
97
95
|
await this._afterPriorityRun.triggerAsync(this._currentIndex);
|
|
98
96
|
const next = this._currentIndex + 1;
|
|
99
97
|
if (next > this._maxIndex) {
|
|
100
98
|
// looks like we've finished!
|
|
101
99
|
this._inProgress = false;
|
|
102
|
-
this.
|
|
100
|
+
this.logger?.log('Finished processing at index =', this._currentIndex);
|
|
103
101
|
this._finished.trigger();
|
|
104
102
|
return;
|
|
105
103
|
}
|
|
@@ -111,8 +109,8 @@ class ParallelQueue {
|
|
|
111
109
|
await l();
|
|
112
110
|
}
|
|
113
111
|
catch (err) {
|
|
114
|
-
this.
|
|
115
|
-
this.
|
|
112
|
+
this.logger?.warn('Failed to process queue item at priority =', priority, ' at index =', index || '?');
|
|
113
|
+
this.logger?.error(err);
|
|
116
114
|
}
|
|
117
115
|
};
|
|
118
116
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parallel.js","sourceRoot":"","sources":["../../../../src/structures/queue/parallel.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"parallel.js","sourceRoot":"","sources":["../../../../src/structures/queue/parallel.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,24 +1,26 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.SubscribersMap = void 0;
|
|
4
|
-
const shared_js_1 = require("../logger/shared.js");
|
|
5
4
|
const disposer_js_1 = require("../functions/disposer.js");
|
|
6
5
|
const safe_js_1 = require("../functions/safe.js");
|
|
7
|
-
|
|
6
|
+
const loggable_js_1 = require("../logger/loggable.js");
|
|
7
|
+
class SubscribersMap extends loggable_js_1.Loggable {
|
|
8
8
|
subscribe;
|
|
9
9
|
name;
|
|
10
10
|
/** Unsubscribers map: key => unsub fn */
|
|
11
11
|
_map = new Map();
|
|
12
12
|
/** Timeouts map: key => timeout handle */
|
|
13
13
|
_timeouts = new Map();
|
|
14
|
-
_logger;
|
|
15
14
|
_count = 0;
|
|
16
15
|
constructor(subscribe, name) {
|
|
16
|
+
super();
|
|
17
17
|
this.subscribe = subscribe;
|
|
18
18
|
this.name = name;
|
|
19
|
-
this._logger = (0, shared_js_1.createLogger)(`[Observers:${this.name || '?'}]`);
|
|
20
19
|
}
|
|
21
20
|
get count() { return this._count; }
|
|
21
|
+
getLoggerName(name) {
|
|
22
|
+
return `[Observers:${name || '?'}]`;
|
|
23
|
+
}
|
|
22
24
|
getIsObserving(key) {
|
|
23
25
|
return this._map.has(key);
|
|
24
26
|
}
|
|
@@ -31,7 +33,7 @@ class SubscribersMap {
|
|
|
31
33
|
return;
|
|
32
34
|
}
|
|
33
35
|
if (enable) {
|
|
34
|
-
this.
|
|
36
|
+
this.logger?.log('Adding observer for key =', key, clearAfter ? `, clearAfter = ${clearAfter}` : '');
|
|
35
37
|
// this marker will help to determine whether unsubscribe was requested while we were in process of subscribing
|
|
36
38
|
let disabled = false;
|
|
37
39
|
const marker = () => { disabled = true; };
|
|
@@ -51,7 +53,7 @@ class SubscribersMap {
|
|
|
51
53
|
}
|
|
52
54
|
}
|
|
53
55
|
else {
|
|
54
|
-
this.
|
|
56
|
+
this.logger?.log('Removing observer for key =', key);
|
|
55
57
|
this.refreshTimeout(key, false);
|
|
56
58
|
const unsub = this._map.get(key);
|
|
57
59
|
this._map.delete(key);
|
|
@@ -70,7 +72,7 @@ class SubscribersMap {
|
|
|
70
72
|
return;
|
|
71
73
|
}
|
|
72
74
|
if (enable && timeout) {
|
|
73
|
-
const t = setTimeout(() => (0, safe_js_1.catchPromise)(this.enable(key, false), err => this.
|
|
75
|
+
const t = setTimeout(() => (0, safe_js_1.catchPromise)(this.enable(key, false), err => this.logger?.error('Unexpected error:', err)), timeout);
|
|
74
76
|
this._timeouts.set(key, t);
|
|
75
77
|
}
|
|
76
78
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"subscribersMap.js","sourceRoot":"","sources":["../../../src/structures/subscribersMap.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"subscribersMap.js","sourceRoot":"","sources":["../../../src/structures/subscribersMap.ts"],"names":[],"mappings":"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"}
|
package/esm/api/call.js
CHANGED
|
@@ -2,11 +2,11 @@ import { EndpointsPathsConfig } from './config.js';
|
|
|
2
2
|
import { CallerHooks } from './hooks.js';
|
|
3
3
|
import { createConfig } from './call.config.js';
|
|
4
4
|
export function buildApiCaller(options) {
|
|
5
|
-
const { request,
|
|
5
|
+
const { request, hooks: hooksSource = {}, } = options;
|
|
6
6
|
const hooks = CallerHooks.merge(hooksSource);
|
|
7
|
-
const
|
|
7
|
+
const pathConfig = new EndpointsPathsConfig(options?.config);
|
|
8
8
|
const caller = async function callApi(api, data, extra) {
|
|
9
|
-
const { config, resultInput, pathInputs, queryInputs } = createConfig(
|
|
9
|
+
const { config, resultInput, pathInputs, queryInputs } = createConfig(pathConfig, api, data, extra);
|
|
10
10
|
if (hooks.beforeConfig) {
|
|
11
11
|
// copy all inputs to avoid mutation
|
|
12
12
|
await hooks.beforeConfig(api, { ...resultInput }, { ...pathInputs }, { ...queryInputs });
|
|
@@ -23,8 +23,8 @@ export function buildApiCaller(options) {
|
|
|
23
23
|
}
|
|
24
24
|
return response?.data;
|
|
25
25
|
};
|
|
26
|
-
return Object.
|
|
27
|
-
|
|
26
|
+
return Object.defineProperty(caller, 'config', {
|
|
27
|
+
get: () => pathConfig,
|
|
28
28
|
});
|
|
29
29
|
}
|
|
30
30
|
//# sourceMappingURL=call.js.map
|
package/esm/api/call.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"call.js","sourceRoot":"","sources":["../../../src/api/call.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAIhD,MAAM,UAAU,cAAc,CAA8C,OAA8B;IAEtG,MAAM,EACF,OAAO,EACP,
|
|
1
|
+
{"version":3,"file":"call.js","sourceRoot":"","sources":["../../../src/api/call.ts"],"names":[],"mappings":"AAQA,OAAO,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AACzC,OAAO,EAAE,YAAY,EAAE,MAAM,kBAAkB,CAAC;AAIhD,MAAM,UAAU,cAAc,CAA8C,OAA8B;IAEtG,MAAM,EACF,OAAO,EACP,KAAK,EAAE,WAAW,GAAG,EAAE,GAC1B,GAAG,OAAO,CAAC;IAEZ,MAAM,KAAK,GAAG,WAAW,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;IAC7C,MAAM,UAAU,GAAG,IAAI,oBAAoB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;IAE7D,MAAM,MAAM,GAAG,KAAK,UAAU,OAAO,CACjC,GAAM,EACN,IAAiC,EACjC,KAAgC;QAIhC,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,UAAU,EAAE,WAAW,EAAE,GAAG,YAAY,CACjE,UAAU,EACV,GAAG,EACH,IAAI,EACJ,KAAK,CACR,CAAC;QAEF,IAAI,KAAK,CAAC,YAAY,EAAE,CAAC;YACrB,oCAAoC;YACpC,MAAM,KAAK,CAAC,YAAY,CACpB,GAAG,EACH,EAAE,GAAG,WAAW,EAAwC,EACxD,EAAE,GAAG,UAAU,EAA0C,EACzD,EAAE,GAAG,WAAW,EAA2C,CAC9D,CAAC;QACN,CAAC;QAED,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;YACtB,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;YACjD,IAAI,MAAM,IAAI,OAAO,MAAM,KAAK,QAAQ,EAAE,CAAC;gBACvC,MAAM,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;YAClC,CAAC;QACL,CAAC;QAED,IAAI,QAAQ,GAAyB,MAAM,OAAO,CAAC,MAAM,CAAC,CAAC;QAE3D,IAAI,QAAQ,IAAI,KAAK,CAAC,aAAa,EAAE,CAAC;YAClC,QAAQ,GAAG,MAAM,KAAK,CAAC,aAAa,CAAC,MAAM,EAAE,QAAQ,CAAC,IAAI,QAAQ,CAAC;QACvE,CAAC;QAED,OAAO,QAAQ,EAAE,IAAI,CAAC;IAC1B,CAAC,CAAC;IAEF,OAAO,MAAM,CAAC,cAAc,CACxB,MAAkC,EAClC,QAAQ,EACR;QACI,GAAG,EAAE,GAAG,EAAE,CAAC,UAAU;KACxB,CACJ,CAAC;AACN,CAAC"}
|
package/esm/api/config.js
CHANGED
|
@@ -1,13 +1,28 @@
|
|
|
1
|
+
import { transferFields } from '../fields/transfer.js';
|
|
1
2
|
import { Path } from '../structures/path/index.js';
|
|
2
3
|
export class EndpointsPathsConfig {
|
|
3
|
-
|
|
4
|
-
|
|
4
|
+
_value = {
|
|
5
|
+
templateArgPrefix: ':',
|
|
6
|
+
basePrefix: '/',
|
|
7
|
+
};
|
|
8
|
+
/** Creates a new instance of config. Follows the other instance if it's instanceof `EndpointsPathsConfig`. */
|
|
5
9
|
constructor(settings) {
|
|
6
10
|
if (settings) {
|
|
7
|
-
|
|
8
|
-
|
|
11
|
+
if (settings instanceof EndpointsPathsConfig) {
|
|
12
|
+
this._value = settings._value;
|
|
13
|
+
}
|
|
14
|
+
else {
|
|
15
|
+
this.updateValues(settings);
|
|
16
|
+
}
|
|
9
17
|
}
|
|
10
18
|
}
|
|
19
|
+
get templateArgPrefix() { return this._value.templateArgPrefix; }
|
|
20
|
+
get basePrefix() { return this._value.basePrefix; }
|
|
21
|
+
expose() {
|
|
22
|
+
return {
|
|
23
|
+
...this._value,
|
|
24
|
+
};
|
|
25
|
+
}
|
|
11
26
|
getPath(endpoint, pathArgs, prefix = true) {
|
|
12
27
|
const path = endpoint.path ?? Path.Empty;
|
|
13
28
|
return path.build(pathArgs || undefined, { addStart: this.getPrefix(prefix) });
|
|
@@ -33,6 +48,15 @@ export class EndpointsPathsConfig {
|
|
|
33
48
|
? prefix
|
|
34
49
|
: (prefix ? this.basePrefix : false);
|
|
35
50
|
}
|
|
51
|
+
updateValues(settings) {
|
|
52
|
+
transferFields.defined(settings, this._value, 'templateArgPrefix', 'basePrefix');
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
export class EndpointsPathsConfigMutable extends EndpointsPathsConfig {
|
|
56
|
+
update(settings) {
|
|
57
|
+
this.updateValues(settings);
|
|
58
|
+
return this;
|
|
59
|
+
}
|
|
36
60
|
}
|
|
37
61
|
/** @deprecated Be careful with using this shared instance. Don't be lazy and create your own! */
|
|
38
62
|
export const DefaultSettings = new EndpointsPathsConfig();
|
package/esm/api/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/api/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,6BAA6B,CAAC;AAanD,MAAM,OAAO,oBAAoB;
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../../../src/api/config.ts"],"names":[],"mappings":"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"}
|
package/esm/api/index.js
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
1
|
export { ApiEndpoint } from './endpoint.js';
|
|
2
2
|
export { EndpointMethods } from './methods.js';
|
|
3
3
|
export * from './config.js';
|
|
4
|
-
export
|
|
5
|
-
export
|
|
4
|
+
export * from './builder.js';
|
|
5
|
+
export * from './call.js';
|
|
6
|
+
export * from './hooks.js';
|
|
7
|
+
export * from './interceptor.js';
|
|
6
8
|
export { LogTypes } from './logging.js';
|
|
7
9
|
//# sourceMappingURL=index.js.map
|
package/esm/api/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/api/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/api/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAE5C,OAAO,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AAE/C,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,WAAW,CAAC;AAC1B,cAAc,YAAY,CAAC;AAC3B,cAAc,kBAAkB,CAAC;AAEjC,OAAO,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC"}
|
package/esm/api/interceptor.js
CHANGED
|
@@ -4,7 +4,7 @@ const eventKeys = hookKeys.map(k => `intercept${k.charAt(0).toUpperCase() + k.sl
|
|
|
4
4
|
/**
|
|
5
5
|
* Experimental. Creates linked caller hooks and interception events.
|
|
6
6
|
*
|
|
7
|
-
* Use hooks to
|
|
7
|
+
* Use hooks to inject into caller and events to subscribe to them externally.
|
|
8
8
|
*/
|
|
9
9
|
export function createInterceptor() {
|
|
10
10
|
const events = eventKeys.reduce((acc, key) => {
|
package/esm/api/logging.js
CHANGED
|
@@ -27,7 +27,7 @@ export var LogTypes;
|
|
|
27
27
|
return { enabled: false };
|
|
28
28
|
}
|
|
29
29
|
LogTypes.getIsEnabled = getIsEnabled;
|
|
30
|
-
function logCall(logger, cfg, dir,
|
|
30
|
+
function logCall(logger, cfg, dir, responseData) {
|
|
31
31
|
if (!cfg._meta.api || (dir === 'req' && cfg._meta.api.method === EndpointMethods.GET && cfg.data == null)) {
|
|
32
32
|
return;
|
|
33
33
|
}
|
|
@@ -36,8 +36,8 @@ export var LogTypes;
|
|
|
36
36
|
return;
|
|
37
37
|
}
|
|
38
38
|
const dataLogged = info.formatter
|
|
39
|
-
? info.formatter(
|
|
40
|
-
: (
|
|
39
|
+
? info.formatter(responseData ?? cfg.data)
|
|
40
|
+
: (responseData ?? cfg.data);
|
|
41
41
|
const prefix = dir === 'req'
|
|
42
42
|
? 'REQ ====>'
|
|
43
43
|
: 'RES <====';
|