@omnitronix/rng-client-core 1.0.10 → 1.1.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/dist/core/rng-client-core.d.ts +0 -1
- package/dist/core/rng-client-core.js +1 -1
- package/dist/errors/rng-errors.d.ts +0 -1
- package/dist/errors/rng-errors.js +1 -1
- package/dist/grpc/grpc-rng-client.d.ts +0 -1
- package/dist/grpc/grpc-rng-client.js +1 -1
- package/dist/grpc/grpc-rng-interface.d.ts +0 -1
- package/dist/grpc/grpc-rng-interface.js +1 -1
- package/dist/http/http-client.types.d.ts +0 -1
- package/dist/http/http-client.types.js +1 -1
- package/dist/http/http-rng-client.d.ts +0 -1
- package/dist/http/http-rng-client.js +1 -1
- package/dist/http/rest-client.d.ts +0 -1
- package/dist/http/rest-client.js +1 -1
- package/dist/http/rng-client.interface.d.ts +0 -1
- package/dist/http/rng-client.interface.js +1 -1
- package/dist/index.d.ts +6 -6
- package/dist/index.js +1 -1
- package/dist/interfaces/client-interfaces.d.ts +6 -3
- package/dist/interfaces/client-interfaces.js +1 -1
- package/dist/interfaces/metrics.d.ts +30 -0
- package/dist/interfaces/metrics.js +3 -0
- package/dist/metrics/default-metrics-handlers.d.ts +2 -0
- package/dist/metrics/default-metrics-handlers.js +23 -0
- package/dist/ring-buffer/interfaces.d.ts +0 -38
- package/dist/ring-buffer/interfaces.js +1 -1
- package/dist/ring-buffer/ring-buffer.d.ts +7 -14
- package/dist/ring-buffer/ring-buffer.js +63 -207
- package/dist/ring-buffer/ring-storage-memory.d.ts +1 -3
- package/dist/ring-buffer/ring-storage-memory.js +1 -25
- package/dist/ring-buffer/ring-storage.d.ts +1 -3
- package/dist/ring-buffer/ring-storage.js +1 -7
- package/dist/rng-client.d.ts +2 -5
- package/dist/rng-client.js +6 -4
- package/package.json +3 -2
- package/src/__tests__/grpc-rng-client.test.ts +167 -0
- package/src/__tests__/rng-client-core.integration.test.ts +117 -0
- package/src/__tests__/rng-client-core.test.ts +249 -0
- package/src/__tests__/rng-client-grpc.test.ts +324 -0
- package/src/__tests__/rng-client.test.ts +296 -0
- package/src/core/rng-client-core.ts +80 -0
- package/src/errors/rng-errors.ts +96 -0
- package/src/grpc/grpc-rng-client.ts +162 -0
- package/src/grpc/grpc-rng-interface.ts +36 -0
- package/src/http/http-client.types.ts +48 -0
- package/src/http/http-rng-client.ts +140 -0
- package/src/http/rest-client.ts +151 -0
- package/src/http/rng-client.interface.ts +22 -0
- package/src/index.ts +21 -0
- package/src/interfaces/client-interfaces.ts +15 -0
- package/src/interfaces/metrics.ts +38 -0
- package/src/metrics/default-metrics-handlers.ts +29 -0
- package/src/ring-buffer/interfaces.ts +9 -0
- package/src/ring-buffer/ring-buffer.ts +214 -0
- package/src/ring-buffer/ring-storage-memory.ts +48 -0
- package/src/ring-buffer/ring-storage.ts +59 -0
- package/src/rng-client.ts +190 -0
- package/src/rng.proto +102 -0
- package/dist/core/rng-client-core.d.ts.map +0 -1
- package/dist/core/rng-client-core.js.map +0 -1
- package/dist/errors/rng-errors.d.ts.map +0 -1
- package/dist/errors/rng-errors.js.map +0 -1
- package/dist/grpc/grpc-rng-client.d.ts.map +0 -1
- package/dist/grpc/grpc-rng-client.js.map +0 -1
- package/dist/grpc/grpc-rng-interface.d.ts.map +0 -1
- package/dist/grpc/grpc-rng-interface.js.map +0 -1
- package/dist/http/http-client.types.d.ts.map +0 -1
- package/dist/http/http-client.types.js.map +0 -1
- package/dist/http/http-rng-client.d.ts.map +0 -1
- package/dist/http/http-rng-client.js.map +0 -1
- package/dist/http/rest-client.d.ts.map +0 -1
- package/dist/http/rest-client.js.map +0 -1
- package/dist/http/rng-client.interface.d.ts.map +0 -1
- package/dist/http/rng-client.interface.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/interfaces/client-interfaces.d.ts.map +0 -1
- package/dist/interfaces/client-interfaces.js.map +0 -1
- package/dist/ring-buffer/interfaces.d.ts.map +0 -1
- package/dist/ring-buffer/interfaces.js.map +0 -1
- package/dist/ring-buffer/ring-buffer.d.ts.map +0 -1
- package/dist/ring-buffer/ring-buffer.js.map +0 -1
- package/dist/ring-buffer/ring-storage-memory.d.ts.map +0 -1
- package/dist/ring-buffer/ring-storage-memory.js.map +0 -1
- package/dist/ring-buffer/ring-storage.d.ts.map +0 -1
- package/dist/ring-buffer/ring-storage.js.map +0 -1
- package/dist/rng-client.d.ts.map +0 -1
- package/dist/rng-client.js.map +0 -1
|
@@ -4,264 +4,116 @@ exports.RingBuffer = exports.FILL_UP_BUFFER_DELAY = void 0;
|
|
|
4
4
|
const ring_storage_1 = require("./ring-storage");
|
|
5
5
|
exports.FILL_UP_BUFFER_DELAY = 5;
|
|
6
6
|
class RingBuffer {
|
|
7
|
-
constructor({ size, clientCore, storageType }) {
|
|
8
|
-
this.refillRequests = [];
|
|
9
|
-
this.refillFailures = [];
|
|
10
|
-
this.starvationEvents = [];
|
|
11
|
-
this.refillDurations = [];
|
|
12
|
-
this.latencies = [];
|
|
7
|
+
constructor({ size, clientCore, storageType, metrics }) {
|
|
13
8
|
this.size = size ?? 2000;
|
|
14
9
|
this.maxSize = this.size * 2;
|
|
15
10
|
this.clientCore = clientCore;
|
|
16
11
|
this.storageType = storageType;
|
|
17
12
|
this.storage = new ring_storage_1.RingStorage(storageType);
|
|
13
|
+
this.metrics = metrics;
|
|
18
14
|
}
|
|
19
15
|
getRangeKey(min, max) {
|
|
20
16
|
return `${min}-${max}`;
|
|
21
17
|
}
|
|
22
18
|
getEngineType() {
|
|
23
|
-
return
|
|
24
|
-
}
|
|
25
|
-
incrementCounter(counters, rng_range, reason, error) {
|
|
26
|
-
const engine_type = this.getEngineType();
|
|
27
|
-
let counter = counters.find((c) => c.rng_range === rng_range &&
|
|
28
|
-
c.engine_type === engine_type &&
|
|
29
|
-
c.reason === reason &&
|
|
30
|
-
c.error === error);
|
|
31
|
-
if (!counter) {
|
|
32
|
-
counter = { rng_range, engine_type, reason, error, count: 0 };
|
|
33
|
-
counters.push(counter);
|
|
34
|
-
}
|
|
35
|
-
counter.count++;
|
|
36
|
-
}
|
|
37
|
-
recordHistogram(histograms, rng_range, value, reason) {
|
|
38
|
-
const engine_type = this.getEngineType();
|
|
39
|
-
let histogram = histograms.find((h) => h.rng_range === rng_range &&
|
|
40
|
-
h.engine_type === engine_type &&
|
|
41
|
-
h.reason === reason);
|
|
42
|
-
if (!histogram) {
|
|
43
|
-
histogram = { rng_range, engine_type, reason, values: [] };
|
|
44
|
-
histograms.push(histogram);
|
|
45
|
-
}
|
|
46
|
-
histogram.values.push(value);
|
|
47
|
-
}
|
|
48
|
-
createHistogramBuckets(values) {
|
|
49
|
-
const buckets = {};
|
|
50
|
-
const standardBuckets = [
|
|
51
|
-
0, 10, 25, 50, 100, 250, 500, 1000, 2500, 5000, 10000,
|
|
52
|
-
];
|
|
53
|
-
let sum = 0;
|
|
54
|
-
const count = values.length;
|
|
55
|
-
for (const value of values) {
|
|
56
|
-
sum += value;
|
|
57
|
-
for (const bucket of standardBuckets) {
|
|
58
|
-
const bucketKey = bucket.toString();
|
|
59
|
-
if (value <= bucket) {
|
|
60
|
-
buckets[bucketKey] = (buckets[bucketKey] || 0) + 1;
|
|
61
|
-
}
|
|
62
|
-
}
|
|
63
|
-
buckets["+Inf"] = (buckets["+Inf"] || 0) + 1;
|
|
64
|
-
}
|
|
65
|
-
return { buckets, sum, count };
|
|
66
|
-
}
|
|
67
|
-
async getStats() {
|
|
68
|
-
const baseStats = await this.storage.getStats();
|
|
69
|
-
if (!baseStats) {
|
|
70
|
-
return undefined;
|
|
71
|
-
}
|
|
72
|
-
const rangesMap = {};
|
|
73
|
-
for (const [rangeKey, rangeMetrics] of Object.entries(baseStats.ranges)) {
|
|
74
|
-
rangesMap[rangeKey] = {
|
|
75
|
-
capacity: this.size,
|
|
76
|
-
fill_level: rangeMetrics.fill_level,
|
|
77
|
-
fill_ratio: this.size > 0 ? rangeMetrics.fill_level / this.size : 0,
|
|
78
|
-
refill_requests_total: [],
|
|
79
|
-
refill_failures_total: [],
|
|
80
|
-
starvation_events_total: 0,
|
|
81
|
-
refill_duration_ms: [],
|
|
82
|
-
latency_ms: [],
|
|
83
|
-
};
|
|
84
|
-
}
|
|
85
|
-
const allRangeKeys = new Set();
|
|
86
|
-
Object.keys(baseStats.ranges).forEach((k) => allRangeKeys.add(k));
|
|
87
|
-
this.refillRequests.forEach((r) => allRangeKeys.add(r.rng_range));
|
|
88
|
-
this.refillFailures.forEach((r) => allRangeKeys.add(r.rng_range));
|
|
89
|
-
this.starvationEvents.forEach((r) => allRangeKeys.add(r.rng_range));
|
|
90
|
-
this.refillDurations.forEach((r) => allRangeKeys.add(r.rng_range));
|
|
91
|
-
this.latencies.forEach((r) => allRangeKeys.add(r.rng_range));
|
|
92
|
-
allRangeKeys.forEach((rangeKey) => {
|
|
93
|
-
if (!rangesMap[rangeKey]) {
|
|
94
|
-
rangesMap[rangeKey] = {
|
|
95
|
-
capacity: this.size,
|
|
96
|
-
fill_level: 0,
|
|
97
|
-
fill_ratio: 0,
|
|
98
|
-
refill_requests_total: [],
|
|
99
|
-
refill_failures_total: [],
|
|
100
|
-
starvation_events_total: 0,
|
|
101
|
-
refill_duration_ms: [],
|
|
102
|
-
latency_ms: [],
|
|
103
|
-
};
|
|
104
|
-
}
|
|
105
|
-
});
|
|
106
|
-
this.refillRequests.forEach((req) => {
|
|
107
|
-
if (!rangesMap[req.rng_range]) {
|
|
108
|
-
rangesMap[req.rng_range] = {
|
|
109
|
-
capacity: this.size,
|
|
110
|
-
fill_level: 0,
|
|
111
|
-
fill_ratio: 0,
|
|
112
|
-
refill_requests_total: [],
|
|
113
|
-
refill_failures_total: [],
|
|
114
|
-
starvation_events_total: 0,
|
|
115
|
-
refill_duration_ms: [],
|
|
116
|
-
latency_ms: [],
|
|
117
|
-
};
|
|
118
|
-
}
|
|
119
|
-
rangesMap[req.rng_range].refill_requests_total.push({
|
|
120
|
-
engine_type: req.engine_type,
|
|
121
|
-
reason: req.reason,
|
|
122
|
-
count: req.count,
|
|
123
|
-
});
|
|
124
|
-
});
|
|
125
|
-
this.refillFailures.forEach((fail) => {
|
|
126
|
-
if (!rangesMap[fail.rng_range]) {
|
|
127
|
-
rangesMap[fail.rng_range] = {
|
|
128
|
-
capacity: this.size,
|
|
129
|
-
fill_level: 0,
|
|
130
|
-
fill_ratio: 0,
|
|
131
|
-
refill_requests_total: [],
|
|
132
|
-
refill_failures_total: [],
|
|
133
|
-
starvation_events_total: 0,
|
|
134
|
-
refill_duration_ms: [],
|
|
135
|
-
latency_ms: [],
|
|
136
|
-
};
|
|
137
|
-
}
|
|
138
|
-
rangesMap[fail.rng_range].refill_failures_total.push({
|
|
139
|
-
engine_type: fail.engine_type,
|
|
140
|
-
reason: fail.reason,
|
|
141
|
-
error: fail.error,
|
|
142
|
-
count: fail.count,
|
|
143
|
-
});
|
|
144
|
-
});
|
|
145
|
-
this.starvationEvents.forEach((starvation) => {
|
|
146
|
-
if (!rangesMap[starvation.rng_range]) {
|
|
147
|
-
rangesMap[starvation.rng_range] = {
|
|
148
|
-
capacity: this.size,
|
|
149
|
-
fill_level: 0,
|
|
150
|
-
fill_ratio: 0,
|
|
151
|
-
refill_requests_total: [],
|
|
152
|
-
refill_failures_total: [],
|
|
153
|
-
starvation_events_total: 0,
|
|
154
|
-
refill_duration_ms: [],
|
|
155
|
-
latency_ms: [],
|
|
156
|
-
};
|
|
157
|
-
}
|
|
158
|
-
rangesMap[starvation.rng_range].starvation_events_total +=
|
|
159
|
-
starvation.count;
|
|
160
|
-
});
|
|
161
|
-
this.refillDurations.forEach((duration) => {
|
|
162
|
-
if (!rangesMap[duration.rng_range]) {
|
|
163
|
-
rangesMap[duration.rng_range] = {
|
|
164
|
-
capacity: this.size,
|
|
165
|
-
fill_level: 0,
|
|
166
|
-
fill_ratio: 0,
|
|
167
|
-
refill_requests_total: [],
|
|
168
|
-
refill_failures_total: [],
|
|
169
|
-
starvation_events_total: 0,
|
|
170
|
-
refill_duration_ms: [],
|
|
171
|
-
latency_ms: [],
|
|
172
|
-
};
|
|
173
|
-
}
|
|
174
|
-
const { buckets, sum, count } = this.createHistogramBuckets(duration.values);
|
|
175
|
-
rangesMap[duration.rng_range].refill_duration_ms.push({
|
|
176
|
-
engine_type: duration.engine_type,
|
|
177
|
-
reason: duration.reason,
|
|
178
|
-
buckets,
|
|
179
|
-
sum,
|
|
180
|
-
count,
|
|
181
|
-
});
|
|
182
|
-
});
|
|
183
|
-
this.latencies.forEach((latency) => {
|
|
184
|
-
if (!rangesMap[latency.rng_range]) {
|
|
185
|
-
rangesMap[latency.rng_range] = {
|
|
186
|
-
capacity: this.size,
|
|
187
|
-
fill_level: 0,
|
|
188
|
-
fill_ratio: 0,
|
|
189
|
-
refill_requests_total: [],
|
|
190
|
-
refill_failures_total: [],
|
|
191
|
-
starvation_events_total: 0,
|
|
192
|
-
refill_duration_ms: [],
|
|
193
|
-
latency_ms: [],
|
|
194
|
-
};
|
|
195
|
-
}
|
|
196
|
-
const { buckets, sum, count } = this.createHistogramBuckets(latency.values);
|
|
197
|
-
rangesMap[latency.rng_range].latency_ms.push({
|
|
198
|
-
engine_type: latency.engine_type,
|
|
199
|
-
reason: latency.reason,
|
|
200
|
-
buckets,
|
|
201
|
-
sum,
|
|
202
|
-
count,
|
|
203
|
-
});
|
|
204
|
-
});
|
|
205
|
-
return {
|
|
206
|
-
...baseStats,
|
|
207
|
-
ranges: rangesMap,
|
|
208
|
-
};
|
|
19
|
+
return 'default';
|
|
209
20
|
}
|
|
210
21
|
async getNumbersByRange(min, max, count = 1) {
|
|
211
22
|
const rangeKey = this.getRangeKey(min, max);
|
|
212
23
|
let requestStartTime = Date.now();
|
|
213
24
|
const buffer = await this.storage.getBufferByRange(min, max);
|
|
214
25
|
if (!buffer) {
|
|
215
|
-
this.
|
|
26
|
+
this.metrics.rngBufferStarvationEventsTotal.inc({
|
|
27
|
+
rng_range: rangeKey,
|
|
28
|
+
engine_type: this.getEngineType(),
|
|
29
|
+
});
|
|
216
30
|
const newBuffer = this.createBuffer(min, max);
|
|
217
31
|
await this.storage.saveBuffer(newBuffer);
|
|
218
32
|
setTimeout(async () => {
|
|
219
33
|
requestStartTime = Date.now();
|
|
220
|
-
await this.fillUpBuffer(newBuffer,
|
|
34
|
+
await this.fillUpBuffer(newBuffer, 'initial');
|
|
221
35
|
const latency = Date.now() - requestStartTime;
|
|
222
|
-
this.
|
|
36
|
+
this.metrics.rngBufferLatencyMs.observe({
|
|
37
|
+
rng_range: rangeKey,
|
|
38
|
+
engine_type: this.getEngineType(),
|
|
39
|
+
}, latency);
|
|
223
40
|
}, exports.FILL_UP_BUFFER_DELAY);
|
|
224
41
|
return undefined;
|
|
225
42
|
}
|
|
226
43
|
const item = await this.storage.getFromBuffer(buffer, count);
|
|
227
44
|
if (!item) {
|
|
228
|
-
this.
|
|
45
|
+
this.metrics.rngBufferStarvationEventsTotal.inc({
|
|
46
|
+
rng_range: rangeKey,
|
|
47
|
+
engine_type: this.getEngineType(),
|
|
48
|
+
});
|
|
229
49
|
setTimeout(async () => {
|
|
230
50
|
requestStartTime = Date.now();
|
|
231
|
-
await this.fillUpBuffer(buffer,
|
|
51
|
+
await this.fillUpBuffer(buffer, 'starvation');
|
|
232
52
|
const latency = Date.now() - requestStartTime;
|
|
233
|
-
this.
|
|
53
|
+
this.metrics.rngBufferLatencyMs.observe({
|
|
54
|
+
rng_range: rangeKey,
|
|
55
|
+
engine_type: this.getEngineType(),
|
|
56
|
+
}, latency);
|
|
234
57
|
}, exports.FILL_UP_BUFFER_DELAY);
|
|
235
58
|
return undefined;
|
|
236
59
|
}
|
|
237
60
|
setTimeout(async () => {
|
|
238
61
|
requestStartTime = Date.now();
|
|
239
|
-
await this.fillUpBuffer(buffer,
|
|
62
|
+
await this.fillUpBuffer(buffer, 'refill');
|
|
240
63
|
const latency = Date.now() - requestStartTime;
|
|
241
|
-
this.
|
|
64
|
+
this.metrics.rngBufferLatencyMs.observe({
|
|
65
|
+
rng_range: rangeKey,
|
|
66
|
+
engine_type: this.getEngineType(),
|
|
67
|
+
}, latency);
|
|
242
68
|
}, exports.FILL_UP_BUFFER_DELAY);
|
|
243
69
|
return item;
|
|
244
70
|
}
|
|
245
|
-
async fillUpBuffer(buffer, reason =
|
|
71
|
+
async fillUpBuffer(buffer, reason = 'scheduled') {
|
|
246
72
|
const rangeKey = this.getRangeKey(buffer.range.min, buffer.range.max);
|
|
247
73
|
const refillStartTime = Date.now();
|
|
248
|
-
this.
|
|
74
|
+
this.metrics.rngBufferRefillRequestsTotal.inc({
|
|
75
|
+
rng_range: rangeKey,
|
|
76
|
+
engine_type: this.getEngineType(),
|
|
77
|
+
reason,
|
|
78
|
+
});
|
|
249
79
|
try {
|
|
250
80
|
const values = await this.pullNumberByBuffer(buffer);
|
|
251
81
|
if (values.length === 0 || buffer.items.length >= this.maxSize) {
|
|
252
82
|
const duration = Date.now() - refillStartTime;
|
|
253
|
-
this.
|
|
83
|
+
this.metrics.rngBufferRefillDurationMs.observe({
|
|
84
|
+
rng_range: rangeKey,
|
|
85
|
+
engine_type: this.getEngineType(),
|
|
86
|
+
}, duration);
|
|
254
87
|
return;
|
|
255
88
|
}
|
|
256
89
|
await this.storage.addItemsToBuffer(buffer, values);
|
|
90
|
+
this.metrics.rngBufferFillLevel.set({
|
|
91
|
+
rng_range: rangeKey,
|
|
92
|
+
engine_type: this.getEngineType(),
|
|
93
|
+
}, buffer.items.length);
|
|
94
|
+
this.metrics.rngBufferFillRatio.set({
|
|
95
|
+
rng_range: rangeKey,
|
|
96
|
+
engine_type: this.getEngineType(),
|
|
97
|
+
}, buffer.items.length / this.size);
|
|
257
98
|
const duration = Date.now() - refillStartTime;
|
|
258
|
-
this.
|
|
99
|
+
this.metrics.rngBufferRefillDurationMs.observe({
|
|
100
|
+
rng_range: rangeKey,
|
|
101
|
+
engine_type: this.getEngineType(),
|
|
102
|
+
}, duration);
|
|
259
103
|
}
|
|
260
104
|
catch (error) {
|
|
261
105
|
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
262
|
-
this.
|
|
106
|
+
this.metrics.rngBufferRefillFailuresTotal.inc({
|
|
107
|
+
rng_range: rangeKey,
|
|
108
|
+
engine_type: this.getEngineType(),
|
|
109
|
+
reason,
|
|
110
|
+
error: errorMessage,
|
|
111
|
+
});
|
|
263
112
|
const duration = Date.now() - refillStartTime;
|
|
264
|
-
this.
|
|
113
|
+
this.metrics.rngBufferRefillDurationMs.observe({
|
|
114
|
+
rng_range: rangeKey,
|
|
115
|
+
engine_type: this.getEngineType(),
|
|
116
|
+
}, duration);
|
|
265
117
|
throw error;
|
|
266
118
|
}
|
|
267
119
|
}
|
|
@@ -278,6 +130,10 @@ class RingBuffer {
|
|
|
278
130
|
return values.result;
|
|
279
131
|
}
|
|
280
132
|
createBuffer(min, max) {
|
|
133
|
+
this.metrics.rngBufferCapacity.set({
|
|
134
|
+
rng_range: this.getRangeKey(min, max),
|
|
135
|
+
engine_type: this.getEngineType(),
|
|
136
|
+
}, this.size);
|
|
281
137
|
return {
|
|
282
138
|
items: [],
|
|
283
139
|
range: { min, max },
|
|
@@ -285,4 +141,4 @@ class RingBuffer {
|
|
|
285
141
|
}
|
|
286
142
|
}
|
|
287
143
|
exports.RingBuffer = RingBuffer;
|
|
288
|
-
//# sourceMappingURL=ring-buffer.js.map
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ring-buffer.js","sourceRoot":"","sources":["../../src/ring-buffer/ring-buffer.ts"],"names":[],"mappings":"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","sourcesContent":["import { RingBufferValue, SingleRingBuffer } from './interfaces';\nimport { RngClientCore } from '../core/rng-client-core';\nimport { RingStorage, StorageType } from './ring-storage';\nimport { RngBufferMetricsHandlers } from '../interfaces/metrics';\n\nexport const FILL_UP_BUFFER_DELAY = 5;\n\nexport interface RingBufferConfig {\n  size?: number;\n  clientCore: RngClientCore;\n  storageType: StorageType;\n  metrics: RngBufferMetricsHandlers;\n}\n\nexport class RingBuffer {\n  private size: number;\n  private maxSize: number;\n  private clientCore: RngClientCore;\n  private storageType: StorageType;\n  private storage: RingStorage;\n  private readonly metrics: RngBufferMetricsHandlers;\n\n  constructor({ size, clientCore, storageType, metrics }: RingBufferConfig) {\n    this.size = size ?? 2000;\n    this.maxSize = this.size * 2;\n    this.clientCore = clientCore;\n    this.storageType = storageType;\n    this.storage = new RingStorage(storageType);\n    this.metrics = metrics;\n  }\n\n  private getRangeKey(min: number, max: number): string {\n    return `${min}-${max}`;\n  }\n\n  private getEngineType(): string {\n    return 'default';\n  }\n\n  async getNumbersByRange(\n    min: number,\n    max: number,\n    count = 1\n  ): Promise<RingBufferValue[] | undefined> {\n    const rangeKey = this.getRangeKey(min, max);\n    let requestStartTime = Date.now();\n\n    const buffer = await this.storage.getBufferByRange(min, max);\n    if (!buffer) {\n      this.metrics.rngBufferStarvationEventsTotal.inc({\n        rng_range: rangeKey,\n        engine_type: this.getEngineType(),\n      });\n\n      const newBuffer = this.createBuffer(min, max);\n      await this.storage.saveBuffer(newBuffer);\n      setTimeout(async () => {\n        requestStartTime = Date.now();\n        await this.fillUpBuffer(newBuffer, 'initial');\n        const latency = Date.now() - requestStartTime;\n        this.metrics.rngBufferLatencyMs.observe(\n          {\n            rng_range: rangeKey,\n            engine_type: this.getEngineType(),\n          },\n          latency\n        );\n      }, FILL_UP_BUFFER_DELAY);\n\n      return undefined;\n    }\n\n    const item = await this.storage.getFromBuffer(buffer, count);\n    if (!item) {\n      this.metrics.rngBufferStarvationEventsTotal.inc({\n        rng_range: rangeKey,\n        engine_type: this.getEngineType(),\n      });\n\n      setTimeout(async () => {\n        requestStartTime = Date.now();\n        await this.fillUpBuffer(buffer, 'starvation');\n        const latency = Date.now() - requestStartTime;\n        this.metrics.rngBufferLatencyMs.observe(\n          {\n            rng_range: rangeKey,\n            engine_type: this.getEngineType(),\n          },\n          latency\n        );\n      }, FILL_UP_BUFFER_DELAY);\n\n      return undefined;\n    }\n\n    setTimeout(async () => {\n      requestStartTime = Date.now();\n      await this.fillUpBuffer(buffer, 'refill');\n      const latency = Date.now() - requestStartTime;\n      this.metrics.rngBufferLatencyMs.observe(\n        {\n          rng_range: rangeKey,\n          engine_type: this.getEngineType(),\n        },\n        latency\n      );\n    }, FILL_UP_BUFFER_DELAY);\n\n    return item;\n  }\n\n  async fillUpBuffer(\n    buffer: SingleRingBuffer,\n    reason: string = 'scheduled'\n  ): Promise<void> {\n    const rangeKey = this.getRangeKey(buffer.range.min, buffer.range.max);\n    const refillStartTime = Date.now();\n\n    this.metrics.rngBufferRefillRequestsTotal.inc({\n      rng_range: rangeKey,\n      engine_type: this.getEngineType(),\n      reason,\n    });\n\n    try {\n      const values = await this.pullNumberByBuffer(buffer);\n      if (values.length === 0 || buffer.items.length >= this.maxSize) {\n        const duration = Date.now() - refillStartTime;\n        this.metrics.rngBufferRefillDurationMs.observe(\n          {\n            rng_range: rangeKey,\n            engine_type: this.getEngineType(),\n          },\n          duration\n        );\n        return;\n      }\n      await this.storage.addItemsToBuffer(buffer, values);\n      this.metrics.rngBufferFillLevel.set(\n        {\n          rng_range: rangeKey,\n          engine_type: this.getEngineType(),\n        },\n        buffer.items.length\n      );\n      this.metrics.rngBufferFillRatio.set(\n        {\n          rng_range: rangeKey,\n          engine_type: this.getEngineType(),\n        },\n        buffer.items.length / this.size\n      );\n\n      const duration = Date.now() - refillStartTime;\n      this.metrics.rngBufferRefillDurationMs.observe(\n        {\n          rng_range: rangeKey,\n          engine_type: this.getEngineType(),\n        },\n        duration\n      );\n    } catch (error) {\n      const errorMessage =\n        error instanceof Error ? error.message : String(error);\n      this.metrics.rngBufferRefillFailuresTotal.inc({\n        rng_range: rangeKey,\n        engine_type: this.getEngineType(),\n        reason,\n        error: errorMessage,\n      });\n\n      const duration = Date.now() - refillStartTime;\n      this.metrics.rngBufferRefillDurationMs.observe(\n        {\n          rng_range: rangeKey,\n          engine_type: this.getEngineType(),\n        },\n        duration\n      );\n\n      throw error;\n    }\n  }\n\n  async pullNumberByBuffer(\n    buffer: SingleRingBuffer\n  ): Promise<RingBufferValue[]> {\n    const count = this.size - buffer.items.length;\n    if (count <= 0) {\n      return [];\n    }\n    const values = await this.clientCore.getBatchNumbersWithSeeds({\n      min: buffer.range.min,\n      max: buffer.range.max,\n      count,\n    });\n    return values.result as RingBufferValue[];\n  }\n\n  createBuffer(min: number, max: number): SingleRingBuffer {\n    this.metrics.rngBufferCapacity.set(\n      {\n        rng_range: this.getRangeKey(min, max),\n        engine_type: this.getEngineType(),\n      },\n      this.size\n    );\n\n    return {\n      items: [],\n      range: { min, max },\n    };\n  }\n}\n"]}
|
|
@@ -1,12 +1,10 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { RingBufferValue, SingleRingBuffer } from './interfaces';
|
|
2
2
|
export declare class RingStorageMemory {
|
|
3
3
|
private storage;
|
|
4
4
|
constructor();
|
|
5
|
-
getStats(): Promise<RingBufferStats>;
|
|
6
5
|
getBufferName(min: number, max: number): string;
|
|
7
6
|
saveBuffer(buffer: SingleRingBuffer): Promise<void>;
|
|
8
7
|
getBuffer(name: string): Promise<SingleRingBuffer>;
|
|
9
8
|
getFromBuffer(name: string, count?: number): Promise<RingBufferValue[] | undefined>;
|
|
10
9
|
addItemsToBuffer(buffer: SingleRingBuffer, items: RingBufferValue[]): Promise<void>;
|
|
11
10
|
}
|
|
12
|
-
//# sourceMappingURL=ring-storage-memory.d.ts.map
|
|
@@ -5,30 +5,6 @@ class RingStorageMemory {
|
|
|
5
5
|
constructor() {
|
|
6
6
|
this.storage = {};
|
|
7
7
|
}
|
|
8
|
-
async getStats() {
|
|
9
|
-
const ranges = {};
|
|
10
|
-
for (const key in this.storage) {
|
|
11
|
-
ranges[key] = this.storage[key].items.length;
|
|
12
|
-
}
|
|
13
|
-
const partialRanges = {};
|
|
14
|
-
for (const [key, fillLevel] of Object.entries(ranges)) {
|
|
15
|
-
partialRanges[key] = {
|
|
16
|
-
capacity: 0,
|
|
17
|
-
fill_level: fillLevel,
|
|
18
|
-
fill_ratio: 0,
|
|
19
|
-
refill_requests_total: [],
|
|
20
|
-
refill_failures_total: [],
|
|
21
|
-
starvation_events_total: 0,
|
|
22
|
-
refill_duration_ms: [],
|
|
23
|
-
latency_ms: [],
|
|
24
|
-
};
|
|
25
|
-
}
|
|
26
|
-
return {
|
|
27
|
-
id: "in_memory",
|
|
28
|
-
size: Object.keys(this.storage).length,
|
|
29
|
-
ranges: partialRanges,
|
|
30
|
-
};
|
|
31
|
-
}
|
|
32
8
|
getBufferName(min, max) {
|
|
33
9
|
return `${min}-${max}`;
|
|
34
10
|
}
|
|
@@ -59,4 +35,4 @@ class RingStorageMemory {
|
|
|
59
35
|
}
|
|
60
36
|
}
|
|
61
37
|
exports.RingStorageMemory = RingStorageMemory;
|
|
62
|
-
//# sourceMappingURL=
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmluZy1zdG9yYWdlLW1lbW9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yaW5nLWJ1ZmZlci9yaW5nLXN0b3JhZ2UtbWVtb3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLE1BQWEsaUJBQWlCO0lBRzVCO1FBQ0UsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUVELGFBQWEsQ0FBQyxHQUFXLEVBQUUsR0FBVztRQUNwQyxPQUFPLEdBQUcsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQXdCO1FBQ3ZDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2xFLE1BQU0sQ0FBQztJQUNYLENBQUM7SUFFRCxLQUFLLENBQUMsU0FBUyxDQUFDLElBQVk7UUFDMUIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxLQUFLLENBQUMsYUFBYSxDQUNqQixJQUFZLEVBQ1osS0FBSyxHQUFHLENBQUM7UUFFVCxNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ1osT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztRQUNELElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsS0FBSyxFQUFFLENBQUM7WUFDaEMsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztRQUNELE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUM1QyxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdkIsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELEtBQUssQ0FBQyxnQkFBZ0IsQ0FDcEIsTUFBd0IsRUFDeEIsS0FBd0I7UUFFeEIsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQztRQUM1QixNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDaEMsQ0FBQztDQUNGO0FBN0NELDhDQTZDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJpbmdCdWZmZXJWYWx1ZSwgU2luZ2xlUmluZ0J1ZmZlciB9IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCBjbGFzcyBSaW5nU3RvcmFnZU1lbW9yeSB7XG4gIHByaXZhdGUgc3RvcmFnZTogeyBba2V5OiBzdHJpbmddOiBTaW5nbGVSaW5nQnVmZmVyIH07XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5zdG9yYWdlID0ge307XG4gIH1cblxuICBnZXRCdWZmZXJOYW1lKG1pbjogbnVtYmVyLCBtYXg6IG51bWJlcik6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke21pbn0tJHttYXh9YDtcbiAgfVxuXG4gIGFzeW5jIHNhdmVCdWZmZXIoYnVmZmVyOiBTaW5nbGVSaW5nQnVmZmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgdGhpcy5zdG9yYWdlW3RoaXMuZ2V0QnVmZmVyTmFtZShidWZmZXIucmFuZ2UubWluLCBidWZmZXIucmFuZ2UubWF4KV0gPVxuICAgICAgYnVmZmVyO1xuICB9XG5cbiAgYXN5bmMgZ2V0QnVmZmVyKG5hbWU6IHN0cmluZyk6IFByb21pc2U8U2luZ2xlUmluZ0J1ZmZlcj4ge1xuICAgIHJldHVybiB0aGlzLnN0b3JhZ2VbbmFtZV07XG4gIH1cblxuICBhc3luYyBnZXRGcm9tQnVmZmVyKFxuICAgIG5hbWU6IHN0cmluZyxcbiAgICBjb3VudCA9IDFcbiAgKTogUHJvbWlzZTxSaW5nQnVmZmVyVmFsdWVbXSB8IHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IGJ1ZmZlciA9IGF3YWl0IHRoaXMuZ2V0QnVmZmVyKG5hbWUpO1xuICAgIGlmICghYnVmZmVyKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgICBpZiAoYnVmZmVyLml0ZW1zLmxlbmd0aCA8IGNvdW50KSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgICBjb25zdCBpdGVtcyA9IGJ1ZmZlci5pdGVtcy5zcGxpY2UoMCwgY291bnQpO1xuICAgIGlmIChpdGVtcy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuICAgIHJldHVybiBpdGVtcztcbiAgfVxuXG4gIGFzeW5jIGFkZEl0ZW1zVG9CdWZmZXIoXG4gICAgYnVmZmVyOiBTaW5nbGVSaW5nQnVmZmVyLFxuICAgIGl0ZW1zOiBSaW5nQnVmZmVyVmFsdWVbXVxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBidWZmZXIuaXRlbXMucHVzaCguLi5pdGVtcyk7XG4gICAgYXdhaXQgdGhpcy5zYXZlQnVmZmVyKGJ1ZmZlcik7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { RingBufferValue, SingleRingBuffer } from './interfaces';
|
|
2
2
|
export declare enum StorageType {
|
|
3
3
|
IN_MEMORY = "in_memory",
|
|
4
4
|
REDIS = "redis"
|
|
@@ -7,11 +7,9 @@ export declare class RingStorage {
|
|
|
7
7
|
private readonly storageType;
|
|
8
8
|
private storage;
|
|
9
9
|
constructor(storageType: StorageType);
|
|
10
|
-
getStats(): Promise<RingBufferStats | undefined>;
|
|
11
10
|
getFromBuffer(buffer: SingleRingBuffer, count?: number): Promise<RingBufferValue[] | undefined>;
|
|
12
11
|
saveBuffer(buffer: SingleRingBuffer): Promise<void>;
|
|
13
12
|
getBufferByRange(min: number, max: number): Promise<SingleRingBuffer | undefined>;
|
|
14
13
|
getBuffer(name: string): Promise<SingleRingBuffer | undefined>;
|
|
15
14
|
addItemsToBuffer(buffer: SingleRingBuffer, items: RingBufferValue[]): Promise<void>;
|
|
16
15
|
}
|
|
17
|
-
//# sourceMappingURL=ring-storage.d.ts.map
|
|
@@ -12,12 +12,6 @@ class RingStorage {
|
|
|
12
12
|
this.storageType = storageType;
|
|
13
13
|
this.storage = new ring_storage_memory_1.RingStorageMemory();
|
|
14
14
|
}
|
|
15
|
-
async getStats() {
|
|
16
|
-
if (this.storageType === StorageType.IN_MEMORY) {
|
|
17
|
-
return this.storage.getStats();
|
|
18
|
-
}
|
|
19
|
-
return undefined;
|
|
20
|
-
}
|
|
21
15
|
async getFromBuffer(buffer, count = 1) {
|
|
22
16
|
if (this.storageType === StorageType.IN_MEMORY) {
|
|
23
17
|
return this.storage.getFromBuffer(this.storage.getBufferName(buffer.range.min, buffer.range.max), count);
|
|
@@ -48,4 +42,4 @@ class RingStorage {
|
|
|
48
42
|
}
|
|
49
43
|
}
|
|
50
44
|
exports.RingStorage = RingStorage;
|
|
51
|
-
//# sourceMappingURL=
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmluZy1zdG9yYWdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3JpbmctYnVmZmVyL3Jpbmctc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSwrREFBMEQ7QUFFMUQsSUFBWSxXQUdYO0FBSEQsV0FBWSxXQUFXO0lBQ3JCLHNDQUF1QixDQUFBO0lBQ3ZCLDhCQUFlLENBQUE7QUFDakIsQ0FBQyxFQUhXLFdBQVcsMkJBQVgsV0FBVyxRQUd0QjtBQUVELE1BQWEsV0FBVztJQUV0QixZQUE2QixXQUF3QjtRQUF4QixnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNuRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksdUNBQWlCLEVBQUUsQ0FBQztJQUN6QyxDQUFDO0lBRUQsS0FBSyxDQUFDLGFBQWEsQ0FDakIsTUFBd0IsRUFDeEIsS0FBSyxHQUFHLENBQUM7UUFFVCxJQUFJLElBQUksQ0FBQyxXQUFXLEtBQUssV0FBVyxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQy9DLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQy9CLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEVBQzlELEtBQUssQ0FDTixDQUFDO1FBQ0osQ0FBQztRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFFRCxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQXdCO1FBQ3ZDLElBQUksSUFBSSxDQUFDLFdBQVcsS0FBSyxXQUFXLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDbEMsQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsZ0JBQWdCLENBQ3BCLEdBQVcsRUFDWCxHQUFXO1FBRVgsSUFBSSxJQUFJLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMvQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ3RFLENBQUM7UUFDRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFZO1FBQzFCLElBQUksSUFBSSxDQUFDLFdBQVcsS0FBSyxXQUFXLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDL0MsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN0QyxDQUFDO1FBQ0QsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELEtBQUssQ0FBQyxnQkFBZ0IsQ0FDcEIsTUFBd0IsRUFDeEIsS0FBd0I7UUFFeEIsSUFBSSxJQUFJLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztRQUMvQyxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBbERELGtDQWtEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJpbmdCdWZmZXJWYWx1ZSwgU2luZ2xlUmluZ0J1ZmZlciB9IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBSaW5nU3RvcmFnZU1lbW9yeSB9IGZyb20gJy4vcmluZy1zdG9yYWdlLW1lbW9yeSc7XG5cbmV4cG9ydCBlbnVtIFN0b3JhZ2VUeXBlIHtcbiAgSU5fTUVNT1JZID0gJ2luX21lbW9yeScsXG4gIFJFRElTID0gJ3JlZGlzJyxcbn1cblxuZXhwb3J0IGNsYXNzIFJpbmdTdG9yYWdlIHtcbiAgcHJpdmF0ZSBzdG9yYWdlOiBSaW5nU3RvcmFnZU1lbW9yeTtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBzdG9yYWdlVHlwZTogU3RvcmFnZVR5cGUpIHtcbiAgICB0aGlzLnN0b3JhZ2UgPSBuZXcgUmluZ1N0b3JhZ2VNZW1vcnkoKTtcbiAgfVxuXG4gIGFzeW5jIGdldEZyb21CdWZmZXIoXG4gICAgYnVmZmVyOiBTaW5nbGVSaW5nQnVmZmVyLFxuICAgIGNvdW50ID0gMVxuICApOiBQcm9taXNlPFJpbmdCdWZmZXJWYWx1ZVtdIHwgdW5kZWZpbmVkPiB7XG4gICAgaWYgKHRoaXMuc3RvcmFnZVR5cGUgPT09IFN0b3JhZ2VUeXBlLklOX01FTU9SWSkge1xuICAgICAgcmV0dXJuIHRoaXMuc3RvcmFnZS5nZXRGcm9tQnVmZmVyKFxuICAgICAgICB0aGlzLnN0b3JhZ2UuZ2V0QnVmZmVyTmFtZShidWZmZXIucmFuZ2UubWluLCBidWZmZXIucmFuZ2UubWF4KSxcbiAgICAgICAgY291bnRcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBhc3luYyBzYXZlQnVmZmVyKGJ1ZmZlcjogU2luZ2xlUmluZ0J1ZmZlcik6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICh0aGlzLnN0b3JhZ2VUeXBlID09PSBTdG9yYWdlVHlwZS5JTl9NRU1PUlkpIHtcbiAgICAgIHRoaXMuc3RvcmFnZS5zYXZlQnVmZmVyKGJ1ZmZlcik7XG4gICAgfVxuICB9XG5cbiAgYXN5bmMgZ2V0QnVmZmVyQnlSYW5nZShcbiAgICBtaW46IG51bWJlcixcbiAgICBtYXg6IG51bWJlclxuICApOiBQcm9taXNlPFNpbmdsZVJpbmdCdWZmZXIgfCB1bmRlZmluZWQ+IHtcbiAgICBpZiAodGhpcy5zdG9yYWdlVHlwZSA9PT0gU3RvcmFnZVR5cGUuSU5fTUVNT1JZKSB7XG4gICAgICByZXR1cm4gdGhpcy5zdG9yYWdlLmdldEJ1ZmZlcih0aGlzLnN0b3JhZ2UuZ2V0QnVmZmVyTmFtZShtaW4sIG1heCkpO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgYXN5bmMgZ2V0QnVmZmVyKG5hbWU6IHN0cmluZyk6IFByb21pc2U8U2luZ2xlUmluZ0J1ZmZlciB8IHVuZGVmaW5lZD4ge1xuICAgIGlmICh0aGlzLnN0b3JhZ2VUeXBlID09PSBTdG9yYWdlVHlwZS5JTl9NRU1PUlkpIHtcbiAgICAgIHJldHVybiB0aGlzLnN0b3JhZ2UuZ2V0QnVmZmVyKG5hbWUpO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgYXN5bmMgYWRkSXRlbXNUb0J1ZmZlcihcbiAgICBidWZmZXI6IFNpbmdsZVJpbmdCdWZmZXIsXG4gICAgaXRlbXM6IFJpbmdCdWZmZXJWYWx1ZVtdXG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICh0aGlzLnN0b3JhZ2VUeXBlID09PSBTdG9yYWdlVHlwZS5JTl9NRU1PUlkpIHtcbiAgICAgIHRoaXMuc3RvcmFnZS5hZGRJdGVtc1RvQnVmZmVyKGJ1ZmZlciwgaXRlbXMpO1xuICAgIH1cbiAgfVxufVxuIl19
|
package/dist/rng-client.d.ts
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
|
-
import { RngClientConfig } from
|
|
2
|
-
import { RngSingleResponse, RngBatchResponse } from
|
|
3
|
-
import { RingBufferStats } from "./ring-buffer/interfaces";
|
|
1
|
+
import { RngClientConfig } from './interfaces/client-interfaces';
|
|
2
|
+
import { RngSingleResponse, RngBatchResponse } from './http/http-client.types';
|
|
4
3
|
/**
|
|
5
4
|
* RNG Client - High-level API for client-side random number generation
|
|
6
5
|
*
|
|
@@ -23,7 +22,6 @@ export declare class RngClient {
|
|
|
23
22
|
value: number;
|
|
24
23
|
seed: number;
|
|
25
24
|
}>;
|
|
26
|
-
getRingBuffersStats(): Promise<RingBufferStats | undefined>;
|
|
27
25
|
/**
|
|
28
26
|
* Get a batch of random numbers
|
|
29
27
|
* @param min Minimum value (inclusive)
|
|
@@ -73,4 +71,3 @@ export declare class RngClient {
|
|
|
73
71
|
*/
|
|
74
72
|
getRandomFloat(seed?: number): Promise<RngSingleResponse>;
|
|
75
73
|
}
|
|
76
|
-
//# sourceMappingURL=rng-client.d.ts.map
|
package/dist/rng-client.js
CHANGED
|
@@ -4,6 +4,7 @@ exports.RngClient = void 0;
|
|
|
4
4
|
const rng_client_core_1 = require("./core/rng-client-core");
|
|
5
5
|
const ring_storage_1 = require("./ring-buffer/ring-storage");
|
|
6
6
|
const ring_buffer_1 = require("./ring-buffer/ring-buffer");
|
|
7
|
+
const default_metrics_handlers_1 = require("./metrics/default-metrics-handlers");
|
|
7
8
|
/**
|
|
8
9
|
* RNG Client - High-level API for client-side random number generation
|
|
9
10
|
*
|
|
@@ -18,6 +19,10 @@ class RngClient {
|
|
|
18
19
|
size: config.poolingSize || 2000,
|
|
19
20
|
clientCore: this.clientCore,
|
|
20
21
|
storageType: config.storageType || ring_storage_1.StorageType.IN_MEMORY,
|
|
22
|
+
metrics: {
|
|
23
|
+
...default_metrics_handlers_1.defaultMetricsHandlers,
|
|
24
|
+
...config.metrics?.handlers,
|
|
25
|
+
},
|
|
21
26
|
});
|
|
22
27
|
}
|
|
23
28
|
/**
|
|
@@ -44,9 +49,6 @@ class RngClient {
|
|
|
44
49
|
const response = await this.clientCore.getSingleNumber(data);
|
|
45
50
|
return { value: response.result, seed: response.seed };
|
|
46
51
|
}
|
|
47
|
-
async getRingBuffersStats() {
|
|
48
|
-
return this.ringBuffer.getStats();
|
|
49
|
-
}
|
|
50
52
|
/**
|
|
51
53
|
* Get a batch of random numbers
|
|
52
54
|
* @param min Minimum value (inclusive)
|
|
@@ -149,4 +151,4 @@ class RngClient {
|
|
|
149
151
|
}
|
|
150
152
|
}
|
|
151
153
|
exports.RngClient = RngClient;
|
|
152
|
-
//# sourceMappingURL=rng-client.js.map
|
|
154
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rng-client.js","sourceRoot":"","sources":["../src/rng-client.ts"],"names":[],"mappings":"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","sourcesContent":["import { RngClientCore } from './core/rng-client-core';\nimport { RngClientConfig } from './interfaces/client-interfaces';\nimport { StorageType } from './ring-buffer/ring-storage';\nimport {\n  RngSingleResponse,\n  RngBatchResponse,\n  RngSingleRequest,\n  RngBatchRequest,\n  RngSingleFloatRequest,\n  RngBatchFloatRequest,\n} from './http/http-client.types';\nimport { RingBuffer } from './ring-buffer/ring-buffer';\nimport { defaultMetricsHandlers } from './metrics/default-metrics-handlers';\n\n/**\n * RNG Client - High-level API for client-side random number generation\n *\n * This is the main entry point for client-side RNG operations.\n * It provides a simple interface for generating random numbers\n * via HTTP communication with the RNG service.\n */\nexport class RngClient {\n  private readonly clientCore: RngClientCore;\n  private readonly ringBuffer: RingBuffer;\n\n  constructor(config: RngClientConfig) {\n    this.clientCore = new RngClientCore(config);\n    this.ringBuffer = new RingBuffer({\n      size: config.poolingSize || 2000,\n      clientCore: this.clientCore,\n      storageType: config.storageType || StorageType.IN_MEMORY,\n      metrics: {\n        ...defaultMetricsHandlers,\n        ...config.metrics?.handlers,\n      },\n    });\n  }\n\n  /**\n   * Get a single random number\n   * @param min Minimum value (inclusive)\n   * @param max Maximum value (inclusive)\n   * @param seed Optional seed for deterministic generation\n   * @returns Random integer result\n   */\n  async getSingleNumber(\n    min: number,\n    max: number,\n    seed?: number\n  ): Promise<{ value: number; seed: number }> {\n    const data: RngSingleRequest = {\n      min,\n      max,\n    };\n    if (seed) {\n      data.seed = seed;\n    } else {\n      const item = await this.ringBuffer.getNumbersByRange(min, max, 1);\n      if (item && item.length > 0) {\n        return { value: item[0].value, seed: item[0].seed };\n      }\n    }\n    const response = await this.clientCore.getSingleNumber(data);\n    return { value: response.result, seed: response.seed };\n  }\n\n  /**\n   * Get a batch of random numbers\n   * @param min Minimum value (inclusive)\n   * @param max Maximum value (inclusive)\n   * @param count Number of values to generate\n   * @param seed Optional seed for deterministic generation\n   * @returns Batch of random integers\n   */\n  async getBatchNumbers(\n    min: number,\n    max: number,\n    count: number,\n    seed?: number\n  ): Promise<number[]> {\n    const data: RngBatchRequest = {\n      min,\n      max,\n      count,\n    };\n    if (seed) {\n      data.seed = seed;\n    }\n    const response = await this.clientCore.getBatchNumbers(data);\n\n    return response.result;\n  }\n\n  /**\n   * Get a batch of random numbers with seeds\n   * @param min Minimum value (inclusive)\n   * @param max Maximum value (inclusive)\n   * @param count Number of values to generate\n   * @param seed Optional seed for deterministic generation\n   * @returns Batch of random integers\n   */\n  async getBatchNumbersWithSeeds(\n    min: number,\n    max: number,\n    count: number,\n    seed?: number\n  ): Promise<{ value: number; seed: number }[]> {\n    const data: RngBatchRequest = {\n      min,\n      max,\n      count,\n    };\n    if (seed) {\n      data.seed = seed;\n    } else {\n      const item = await this.ringBuffer.getNumbersByRange(min, max, count);\n      if (item && item.length > 0) {\n        return item;\n      }\n    }\n    const response = await this.clientCore.getBatchNumbersWithSeeds(data);\n\n    return response.result.map((item) => ({\n      value: item.value,\n      seed: item.seed,\n    }));\n  }\n\n  /**\n   * Get a single random float\n   * @param seed Optional seed for deterministic generation\n   * @returns Random float result\n   */\n  async getSingleFloat(seed?: number): Promise<RngSingleResponse> {\n    const data: RngSingleFloatRequest = {};\n    if (seed) {\n      data.seed = seed;\n    }\n    return this.clientCore.getSingleFloat(data);\n  }\n\n  /**\n   * Get a batch of random floats\n   * @param count Number of values to generate\n   * @param seed Optional seed for deterministic generation\n   * @returns Batch of random floats\n   */\n  async getBatchFloats(\n    count: number,\n    seed?: number\n  ): Promise<RngBatchResponse> {\n    const data: RngBatchFloatRequest = { count };\n    if (seed) {\n      data.seed = seed;\n    }\n    return this.clientCore.getBatchFloats(data);\n  }\n\n  /**\n   * Get a random number\n   * @param min Minimum value (inclusive)\n   * @param max Maximum value (inclusive)\n   * @param seed Optional seed for deterministic generation\n   * @returns Random integer result\n   */\n  async getRandomNumber(\n    min: number,\n    max: number,\n    seed?: number\n  ): Promise<RngSingleResponse> {\n    const data: RngSingleRequest = { min, max };\n    if (seed) {\n      data.seed = seed;\n    }\n    return this.clientCore.getRandomNumber(data);\n  }\n\n  /**\n   * Get a random float\n   * @param seed Optional seed for deterministic generation\n   * @returns Random float result\n   */\n  async getRandomFloat(seed?: number): Promise<RngSingleResponse> {\n    const data: RngSingleFloatRequest = {};\n    if (seed) {\n      data.seed = seed;\n    }\n    return this.clientCore.getRandomFloat(data);\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@omnitronix/rng-client-core",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.1.2",
|
|
4
4
|
"description": "Simple HTTP client for random number generation",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
@@ -43,7 +43,8 @@
|
|
|
43
43
|
},
|
|
44
44
|
"files": [
|
|
45
45
|
"dist/**/*",
|
|
46
|
-
"README.md"
|
|
46
|
+
"README.md",
|
|
47
|
+
"src"
|
|
47
48
|
],
|
|
48
49
|
"publishConfig": {
|
|
49
50
|
"registry": "https://registry.npmjs.org/"
|