@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.
Files changed (88) hide show
  1. package/dist/core/rng-client-core.d.ts +0 -1
  2. package/dist/core/rng-client-core.js +1 -1
  3. package/dist/errors/rng-errors.d.ts +0 -1
  4. package/dist/errors/rng-errors.js +1 -1
  5. package/dist/grpc/grpc-rng-client.d.ts +0 -1
  6. package/dist/grpc/grpc-rng-client.js +1 -1
  7. package/dist/grpc/grpc-rng-interface.d.ts +0 -1
  8. package/dist/grpc/grpc-rng-interface.js +1 -1
  9. package/dist/http/http-client.types.d.ts +0 -1
  10. package/dist/http/http-client.types.js +1 -1
  11. package/dist/http/http-rng-client.d.ts +0 -1
  12. package/dist/http/http-rng-client.js +1 -1
  13. package/dist/http/rest-client.d.ts +0 -1
  14. package/dist/http/rest-client.js +1 -1
  15. package/dist/http/rng-client.interface.d.ts +0 -1
  16. package/dist/http/rng-client.interface.js +1 -1
  17. package/dist/index.d.ts +6 -6
  18. package/dist/index.js +1 -1
  19. package/dist/interfaces/client-interfaces.d.ts +6 -3
  20. package/dist/interfaces/client-interfaces.js +1 -1
  21. package/dist/interfaces/metrics.d.ts +30 -0
  22. package/dist/interfaces/metrics.js +3 -0
  23. package/dist/metrics/default-metrics-handlers.d.ts +2 -0
  24. package/dist/metrics/default-metrics-handlers.js +23 -0
  25. package/dist/ring-buffer/interfaces.d.ts +0 -38
  26. package/dist/ring-buffer/interfaces.js +1 -1
  27. package/dist/ring-buffer/ring-buffer.d.ts +7 -14
  28. package/dist/ring-buffer/ring-buffer.js +63 -207
  29. package/dist/ring-buffer/ring-storage-memory.d.ts +1 -3
  30. package/dist/ring-buffer/ring-storage-memory.js +1 -25
  31. package/dist/ring-buffer/ring-storage.d.ts +1 -3
  32. package/dist/ring-buffer/ring-storage.js +1 -7
  33. package/dist/rng-client.d.ts +2 -5
  34. package/dist/rng-client.js +6 -4
  35. package/package.json +3 -2
  36. package/src/__tests__/grpc-rng-client.test.ts +167 -0
  37. package/src/__tests__/rng-client-core.integration.test.ts +117 -0
  38. package/src/__tests__/rng-client-core.test.ts +249 -0
  39. package/src/__tests__/rng-client-grpc.test.ts +324 -0
  40. package/src/__tests__/rng-client.test.ts +296 -0
  41. package/src/core/rng-client-core.ts +80 -0
  42. package/src/errors/rng-errors.ts +96 -0
  43. package/src/grpc/grpc-rng-client.ts +162 -0
  44. package/src/grpc/grpc-rng-interface.ts +36 -0
  45. package/src/http/http-client.types.ts +48 -0
  46. package/src/http/http-rng-client.ts +140 -0
  47. package/src/http/rest-client.ts +151 -0
  48. package/src/http/rng-client.interface.ts +22 -0
  49. package/src/index.ts +21 -0
  50. package/src/interfaces/client-interfaces.ts +15 -0
  51. package/src/interfaces/metrics.ts +38 -0
  52. package/src/metrics/default-metrics-handlers.ts +29 -0
  53. package/src/ring-buffer/interfaces.ts +9 -0
  54. package/src/ring-buffer/ring-buffer.ts +214 -0
  55. package/src/ring-buffer/ring-storage-memory.ts +48 -0
  56. package/src/ring-buffer/ring-storage.ts +59 -0
  57. package/src/rng-client.ts +190 -0
  58. package/src/rng.proto +102 -0
  59. package/dist/core/rng-client-core.d.ts.map +0 -1
  60. package/dist/core/rng-client-core.js.map +0 -1
  61. package/dist/errors/rng-errors.d.ts.map +0 -1
  62. package/dist/errors/rng-errors.js.map +0 -1
  63. package/dist/grpc/grpc-rng-client.d.ts.map +0 -1
  64. package/dist/grpc/grpc-rng-client.js.map +0 -1
  65. package/dist/grpc/grpc-rng-interface.d.ts.map +0 -1
  66. package/dist/grpc/grpc-rng-interface.js.map +0 -1
  67. package/dist/http/http-client.types.d.ts.map +0 -1
  68. package/dist/http/http-client.types.js.map +0 -1
  69. package/dist/http/http-rng-client.d.ts.map +0 -1
  70. package/dist/http/http-rng-client.js.map +0 -1
  71. package/dist/http/rest-client.d.ts.map +0 -1
  72. package/dist/http/rest-client.js.map +0 -1
  73. package/dist/http/rng-client.interface.d.ts.map +0 -1
  74. package/dist/http/rng-client.interface.js.map +0 -1
  75. package/dist/index.d.ts.map +0 -1
  76. package/dist/index.js.map +0 -1
  77. package/dist/interfaces/client-interfaces.d.ts.map +0 -1
  78. package/dist/interfaces/client-interfaces.js.map +0 -1
  79. package/dist/ring-buffer/interfaces.d.ts.map +0 -1
  80. package/dist/ring-buffer/interfaces.js.map +0 -1
  81. package/dist/ring-buffer/ring-buffer.d.ts.map +0 -1
  82. package/dist/ring-buffer/ring-buffer.js.map +0 -1
  83. package/dist/ring-buffer/ring-storage-memory.d.ts.map +0 -1
  84. package/dist/ring-buffer/ring-storage-memory.js.map +0 -1
  85. package/dist/ring-buffer/ring-storage.d.ts.map +0 -1
  86. package/dist/ring-buffer/ring-storage.js.map +0 -1
  87. package/dist/rng-client.d.ts.map +0 -1
  88. 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 "default";
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.incrementCounter(this.starvationEvents, rangeKey);
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, "initial");
34
+ await this.fillUpBuffer(newBuffer, 'initial');
221
35
  const latency = Date.now() - requestStartTime;
222
- this.recordHistogram(this.latencies, rangeKey, latency);
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.incrementCounter(this.starvationEvents, rangeKey);
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, "starvation");
51
+ await this.fillUpBuffer(buffer, 'starvation');
232
52
  const latency = Date.now() - requestStartTime;
233
- this.recordHistogram(this.latencies, rangeKey, latency);
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, "refill");
62
+ await this.fillUpBuffer(buffer, 'refill');
240
63
  const latency = Date.now() - requestStartTime;
241
- this.recordHistogram(this.latencies, rangeKey, latency);
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 = "scheduled") {
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.incrementCounter(this.refillRequests, rangeKey, reason);
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.recordHistogram(this.refillDurations, rangeKey, duration, reason);
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.recordHistogram(this.refillDurations, rangeKey, duration, reason);
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.incrementCounter(this.refillFailures, rangeKey, reason, errorMessage);
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.recordHistogram(this.refillDurations, rangeKey, duration, reason);
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 { RingBufferStats, RingBufferValue, SingleRingBuffer } from "./interfaces";
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=ring-storage-memory.js.map
38
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmluZy1zdG9yYWdlLW1lbW9yeS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9yaW5nLWJ1ZmZlci9yaW5nLXN0b3JhZ2UtbWVtb3J5LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLE1BQWEsaUJBQWlCO0lBRzVCO1FBQ0UsSUFBSSxDQUFDLE9BQU8sR0FBRyxFQUFFLENBQUM7SUFDcEIsQ0FBQztJQUVELGFBQWEsQ0FBQyxHQUFXLEVBQUUsR0FBVztRQUNwQyxPQUFPLEdBQUcsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFFRCxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQXdCO1FBQ3ZDLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsRUFBRSxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ2xFLE1BQU0sQ0FBQztJQUNYLENBQUM7SUFFRCxLQUFLLENBQUMsU0FBUyxDQUFDLElBQVk7UUFDMUIsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQzVCLENBQUM7SUFFRCxLQUFLLENBQUMsYUFBYSxDQUNqQixJQUFZLEVBQ1osS0FBSyxHQUFHLENBQUM7UUFFVCxNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDMUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ1osT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztRQUNELElBQUksTUFBTSxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsS0FBSyxFQUFFLENBQUM7WUFDaEMsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztRQUNELE1BQU0sS0FBSyxHQUFHLE1BQU0sQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztRQUM1QyxJQUFJLEtBQUssQ0FBQyxNQUFNLEtBQUssQ0FBQyxFQUFFLENBQUM7WUFDdkIsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQztRQUNELE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztJQUVELEtBQUssQ0FBQyxnQkFBZ0IsQ0FDcEIsTUFBd0IsRUFDeEIsS0FBd0I7UUFFeEIsTUFBTSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQztRQUM1QixNQUFNLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDaEMsQ0FBQztDQUNGO0FBN0NELDhDQTZDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJpbmdCdWZmZXJWYWx1ZSwgU2luZ2xlUmluZ0J1ZmZlciB9IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5cbmV4cG9ydCBjbGFzcyBSaW5nU3RvcmFnZU1lbW9yeSB7XG4gIHByaXZhdGUgc3RvcmFnZTogeyBba2V5OiBzdHJpbmddOiBTaW5nbGVSaW5nQnVmZmVyIH07XG5cbiAgY29uc3RydWN0b3IoKSB7XG4gICAgdGhpcy5zdG9yYWdlID0ge307XG4gIH1cblxuICBnZXRCdWZmZXJOYW1lKG1pbjogbnVtYmVyLCBtYXg6IG51bWJlcik6IHN0cmluZyB7XG4gICAgcmV0dXJuIGAke21pbn0tJHttYXh9YDtcbiAgfVxuXG4gIGFzeW5jIHNhdmVCdWZmZXIoYnVmZmVyOiBTaW5nbGVSaW5nQnVmZmVyKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgdGhpcy5zdG9yYWdlW3RoaXMuZ2V0QnVmZmVyTmFtZShidWZmZXIucmFuZ2UubWluLCBidWZmZXIucmFuZ2UubWF4KV0gPVxuICAgICAgYnVmZmVyO1xuICB9XG5cbiAgYXN5bmMgZ2V0QnVmZmVyKG5hbWU6IHN0cmluZyk6IFByb21pc2U8U2luZ2xlUmluZ0J1ZmZlcj4ge1xuICAgIHJldHVybiB0aGlzLnN0b3JhZ2VbbmFtZV07XG4gIH1cblxuICBhc3luYyBnZXRGcm9tQnVmZmVyKFxuICAgIG5hbWU6IHN0cmluZyxcbiAgICBjb3VudCA9IDFcbiAgKTogUHJvbWlzZTxSaW5nQnVmZmVyVmFsdWVbXSB8IHVuZGVmaW5lZD4ge1xuICAgIGNvbnN0IGJ1ZmZlciA9IGF3YWl0IHRoaXMuZ2V0QnVmZmVyKG5hbWUpO1xuICAgIGlmICghYnVmZmVyKSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgICBpZiAoYnVmZmVyLml0ZW1zLmxlbmd0aCA8IGNvdW50KSB7XG4gICAgICByZXR1cm4gdW5kZWZpbmVkO1xuICAgIH1cbiAgICBjb25zdCBpdGVtcyA9IGJ1ZmZlci5pdGVtcy5zcGxpY2UoMCwgY291bnQpO1xuICAgIGlmIChpdGVtcy5sZW5ndGggPT09IDApIHtcbiAgICAgIHJldHVybiB1bmRlZmluZWQ7XG4gICAgfVxuICAgIHJldHVybiBpdGVtcztcbiAgfVxuXG4gIGFzeW5jIGFkZEl0ZW1zVG9CdWZmZXIoXG4gICAgYnVmZmVyOiBTaW5nbGVSaW5nQnVmZmVyLFxuICAgIGl0ZW1zOiBSaW5nQnVmZmVyVmFsdWVbXVxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBidWZmZXIuaXRlbXMucHVzaCguLi5pdGVtcyk7XG4gICAgYXdhaXQgdGhpcy5zYXZlQnVmZmVyKGJ1ZmZlcik7XG4gIH1cbn1cbiJdfQ==
@@ -1,4 +1,4 @@
1
- import { RingBufferStats, RingBufferValue, SingleRingBuffer } from "./interfaces";
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=ring-storage.js.map
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmluZy1zdG9yYWdlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3JpbmctYnVmZmVyL3Jpbmctc3RvcmFnZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSwrREFBMEQ7QUFFMUQsSUFBWSxXQUdYO0FBSEQsV0FBWSxXQUFXO0lBQ3JCLHNDQUF1QixDQUFBO0lBQ3ZCLDhCQUFlLENBQUE7QUFDakIsQ0FBQyxFQUhXLFdBQVcsMkJBQVgsV0FBVyxRQUd0QjtBQUVELE1BQWEsV0FBVztJQUV0QixZQUE2QixXQUF3QjtRQUF4QixnQkFBVyxHQUFYLFdBQVcsQ0FBYTtRQUNuRCxJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksdUNBQWlCLEVBQUUsQ0FBQztJQUN6QyxDQUFDO0lBRUQsS0FBSyxDQUFDLGFBQWEsQ0FDakIsTUFBd0IsRUFDeEIsS0FBSyxHQUFHLENBQUM7UUFFVCxJQUFJLElBQUksQ0FBQyxXQUFXLEtBQUssV0FBVyxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQy9DLE9BQU8sSUFBSSxDQUFDLE9BQU8sQ0FBQyxhQUFhLENBQy9CLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxFQUFFLE1BQU0sQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLEVBQzlELEtBQUssQ0FDTixDQUFDO1FBQ0osQ0FBQztRQUNELE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFFRCxLQUFLLENBQUMsVUFBVSxDQUFDLE1BQXdCO1FBQ3ZDLElBQUksSUFBSSxDQUFDLFdBQVcsS0FBSyxXQUFXLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDL0MsSUFBSSxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDbEMsQ0FBQztJQUNILENBQUM7SUFFRCxLQUFLLENBQUMsZ0JBQWdCLENBQ3BCLEdBQVcsRUFDWCxHQUFXO1FBRVgsSUFBSSxJQUFJLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMvQyxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ3RFLENBQUM7UUFDRCxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO0lBRUQsS0FBSyxDQUFDLFNBQVMsQ0FBQyxJQUFZO1FBQzFCLElBQUksSUFBSSxDQUFDLFdBQVcsS0FBSyxXQUFXLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDL0MsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN0QyxDQUFDO1FBQ0QsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUVELEtBQUssQ0FBQyxnQkFBZ0IsQ0FDcEIsTUFBd0IsRUFDeEIsS0FBd0I7UUFFeEIsSUFBSSxJQUFJLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxTQUFTLEVBQUUsQ0FBQztZQUMvQyxJQUFJLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztRQUMvQyxDQUFDO0lBQ0gsQ0FBQztDQUNGO0FBbERELGtDQWtEQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJpbmdCdWZmZXJWYWx1ZSwgU2luZ2xlUmluZ0J1ZmZlciB9IGZyb20gJy4vaW50ZXJmYWNlcyc7XG5pbXBvcnQgeyBSaW5nU3RvcmFnZU1lbW9yeSB9IGZyb20gJy4vcmluZy1zdG9yYWdlLW1lbW9yeSc7XG5cbmV4cG9ydCBlbnVtIFN0b3JhZ2VUeXBlIHtcbiAgSU5fTUVNT1JZID0gJ2luX21lbW9yeScsXG4gIFJFRElTID0gJ3JlZGlzJyxcbn1cblxuZXhwb3J0IGNsYXNzIFJpbmdTdG9yYWdlIHtcbiAgcHJpdmF0ZSBzdG9yYWdlOiBSaW5nU3RvcmFnZU1lbW9yeTtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZWFkb25seSBzdG9yYWdlVHlwZTogU3RvcmFnZVR5cGUpIHtcbiAgICB0aGlzLnN0b3JhZ2UgPSBuZXcgUmluZ1N0b3JhZ2VNZW1vcnkoKTtcbiAgfVxuXG4gIGFzeW5jIGdldEZyb21CdWZmZXIoXG4gICAgYnVmZmVyOiBTaW5nbGVSaW5nQnVmZmVyLFxuICAgIGNvdW50ID0gMVxuICApOiBQcm9taXNlPFJpbmdCdWZmZXJWYWx1ZVtdIHwgdW5kZWZpbmVkPiB7XG4gICAgaWYgKHRoaXMuc3RvcmFnZVR5cGUgPT09IFN0b3JhZ2VUeXBlLklOX01FTU9SWSkge1xuICAgICAgcmV0dXJuIHRoaXMuc3RvcmFnZS5nZXRGcm9tQnVmZmVyKFxuICAgICAgICB0aGlzLnN0b3JhZ2UuZ2V0QnVmZmVyTmFtZShidWZmZXIucmFuZ2UubWluLCBidWZmZXIucmFuZ2UubWF4KSxcbiAgICAgICAgY291bnRcbiAgICAgICk7XG4gICAgfVxuICAgIHJldHVybiB1bmRlZmluZWQ7XG4gIH1cblxuICBhc3luYyBzYXZlQnVmZmVyKGJ1ZmZlcjogU2luZ2xlUmluZ0J1ZmZlcik6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICh0aGlzLnN0b3JhZ2VUeXBlID09PSBTdG9yYWdlVHlwZS5JTl9NRU1PUlkpIHtcbiAgICAgIHRoaXMuc3RvcmFnZS5zYXZlQnVmZmVyKGJ1ZmZlcik7XG4gICAgfVxuICB9XG5cbiAgYXN5bmMgZ2V0QnVmZmVyQnlSYW5nZShcbiAgICBtaW46IG51bWJlcixcbiAgICBtYXg6IG51bWJlclxuICApOiBQcm9taXNlPFNpbmdsZVJpbmdCdWZmZXIgfCB1bmRlZmluZWQ+IHtcbiAgICBpZiAodGhpcy5zdG9yYWdlVHlwZSA9PT0gU3RvcmFnZVR5cGUuSU5fTUVNT1JZKSB7XG4gICAgICByZXR1cm4gdGhpcy5zdG9yYWdlLmdldEJ1ZmZlcih0aGlzLnN0b3JhZ2UuZ2V0QnVmZmVyTmFtZShtaW4sIG1heCkpO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgYXN5bmMgZ2V0QnVmZmVyKG5hbWU6IHN0cmluZyk6IFByb21pc2U8U2luZ2xlUmluZ0J1ZmZlciB8IHVuZGVmaW5lZD4ge1xuICAgIGlmICh0aGlzLnN0b3JhZ2VUeXBlID09PSBTdG9yYWdlVHlwZS5JTl9NRU1PUlkpIHtcbiAgICAgIHJldHVybiB0aGlzLnN0b3JhZ2UuZ2V0QnVmZmVyKG5hbWUpO1xuICAgIH1cbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG5cbiAgYXN5bmMgYWRkSXRlbXNUb0J1ZmZlcihcbiAgICBidWZmZXI6IFNpbmdsZVJpbmdCdWZmZXIsXG4gICAgaXRlbXM6IFJpbmdCdWZmZXJWYWx1ZVtdXG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIGlmICh0aGlzLnN0b3JhZ2VUeXBlID09PSBTdG9yYWdlVHlwZS5JTl9NRU1PUlkpIHtcbiAgICAgIHRoaXMuc3RvcmFnZS5hZGRJdGVtc1RvQnVmZmVyKGJ1ZmZlciwgaXRlbXMpO1xuICAgIH1cbiAgfVxufVxuIl19
@@ -1,6 +1,5 @@
1
- import { RngClientConfig } from "./interfaces/client-interfaces";
2
- import { RngSingleResponse, RngBatchResponse } from "./http/http-client.types";
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
@@ -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.0.10",
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/"