pond-ts 0.2.0 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (97) hide show
  1. package/dist/LiveAggregation.d.ts +54 -0
  2. package/dist/LiveAggregation.d.ts.map +1 -0
  3. package/dist/LiveAggregation.js +240 -0
  4. package/dist/LiveAggregation.js.map +1 -0
  5. package/dist/LiveRollingAggregation.d.ts +43 -0
  6. package/dist/LiveRollingAggregation.d.ts.map +1 -0
  7. package/dist/LiveRollingAggregation.js +178 -0
  8. package/dist/LiveRollingAggregation.js.map +1 -0
  9. package/dist/LiveSeries.d.ts +63 -0
  10. package/dist/LiveSeries.d.ts.map +1 -0
  11. package/dist/LiveSeries.js +340 -0
  12. package/dist/LiveSeries.js.map +1 -0
  13. package/dist/LiveView.d.ts +59 -0
  14. package/dist/LiveView.d.ts.map +1 -0
  15. package/dist/LiveView.js +337 -0
  16. package/dist/LiveView.js.map +1 -0
  17. package/dist/Sequence.d.ts +2 -2
  18. package/dist/Sequence.d.ts.map +1 -1
  19. package/dist/Sequence.js +4 -57
  20. package/dist/Sequence.js.map +1 -1
  21. package/dist/TimeSeries.d.ts +133 -3
  22. package/dist/TimeSeries.d.ts.map +1 -1
  23. package/dist/TimeSeries.js +748 -444
  24. package/dist/TimeSeries.js.map +1 -1
  25. package/dist/index.d.ts +11 -2
  26. package/dist/index.d.ts.map +1 -1
  27. package/dist/index.js +4 -0
  28. package/dist/index.js.map +1 -1
  29. package/dist/reducers/avg.d.ts +3 -0
  30. package/dist/reducers/avg.d.ts.map +1 -0
  31. package/dist/reducers/avg.js +45 -0
  32. package/dist/reducers/avg.js.map +1 -0
  33. package/dist/reducers/count.d.ts +3 -0
  34. package/dist/reducers/count.d.ts.map +1 -0
  35. package/dist/reducers/count.js +35 -0
  36. package/dist/reducers/count.js.map +1 -0
  37. package/dist/reducers/difference.d.ts +3 -0
  38. package/dist/reducers/difference.d.ts.map +1 -0
  39. package/dist/reducers/difference.js +48 -0
  40. package/dist/reducers/difference.js.map +1 -0
  41. package/dist/reducers/first.d.ts +3 -0
  42. package/dist/reducers/first.d.ts.map +1 -0
  43. package/dist/reducers/first.js +23 -0
  44. package/dist/reducers/first.js.map +1 -0
  45. package/dist/reducers/index.d.ts +4 -0
  46. package/dist/reducers/index.d.ts.map +1 -0
  47. package/dist/reducers/index.js +35 -0
  48. package/dist/reducers/index.js.map +1 -0
  49. package/dist/reducers/keep.d.ts +3 -0
  50. package/dist/reducers/keep.d.ts.map +1 -0
  51. package/dist/reducers/keep.js +56 -0
  52. package/dist/reducers/keep.js.map +1 -0
  53. package/dist/reducers/last.d.ts +3 -0
  54. package/dist/reducers/last.d.ts.map +1 -0
  55. package/dist/reducers/last.js +23 -0
  56. package/dist/reducers/last.js.map +1 -0
  57. package/dist/reducers/max.d.ts +3 -0
  58. package/dist/reducers/max.d.ts.map +1 -0
  59. package/dist/reducers/max.js +25 -0
  60. package/dist/reducers/max.js.map +1 -0
  61. package/dist/reducers/median.d.ts +3 -0
  62. package/dist/reducers/median.d.ts.map +1 -0
  63. package/dist/reducers/median.js +39 -0
  64. package/dist/reducers/median.js.map +1 -0
  65. package/dist/reducers/min.d.ts +3 -0
  66. package/dist/reducers/min.d.ts.map +1 -0
  67. package/dist/reducers/min.js +25 -0
  68. package/dist/reducers/min.js.map +1 -0
  69. package/dist/reducers/percentile.d.ts +5 -0
  70. package/dist/reducers/percentile.d.ts.map +1 -0
  71. package/dist/reducers/percentile.js +56 -0
  72. package/dist/reducers/percentile.js.map +1 -0
  73. package/dist/reducers/rolling.d.ts +15 -0
  74. package/dist/reducers/rolling.d.ts.map +1 -0
  75. package/dist/reducers/rolling.js +84 -0
  76. package/dist/reducers/rolling.js.map +1 -0
  77. package/dist/reducers/stdev.d.ts +3 -0
  78. package/dist/reducers/stdev.d.ts.map +1 -0
  79. package/dist/reducers/stdev.js +58 -0
  80. package/dist/reducers/stdev.js.map +1 -0
  81. package/dist/reducers/sum.d.ts +3 -0
  82. package/dist/reducers/sum.d.ts.map +1 -0
  83. package/dist/reducers/sum.js +35 -0
  84. package/dist/reducers/sum.js.map +1 -0
  85. package/dist/reducers/types.d.ts +58 -0
  86. package/dist/reducers/types.d.ts.map +1 -0
  87. package/dist/reducers/types.js +2 -0
  88. package/dist/reducers/types.js.map +1 -0
  89. package/dist/types.d.ts +35 -4
  90. package/dist/types.d.ts.map +1 -1
  91. package/dist/utils/duration.d.ts +3 -0
  92. package/dist/utils/duration.d.ts.map +1 -0
  93. package/dist/utils/duration.js +25 -0
  94. package/dist/utils/duration.js.map +1 -0
  95. package/package.json +5 -2
  96. package/LICENSE +0 -21
  97. package/README.md +0 -415
@@ -0,0 +1,54 @@
1
+ import { Event } from './Event.js';
2
+ import { Interval } from './Interval.js';
3
+ import { LiveView, type LiveFillMapping, type LiveFillStrategy } from './LiveView.js';
4
+ import { LiveRollingAggregation, type RollingWindow } from './LiveRollingAggregation.js';
5
+ import { TimeSeries } from './TimeSeries.js';
6
+ import type { Sequence } from './Sequence.js';
7
+ import type { AggregateMap, DiffSchema, LiveSource, NumericColumnNameForSchema, ScalarValue, SelectSchema, SeriesSchema } from './types.js';
8
+ import type { DurationInput } from './utils/duration.js';
9
+ type ClosedEvent = Event<Interval, Record<string, ScalarValue | undefined>>;
10
+ type BucketListener = (event: ClosedEvent) => void;
11
+ type CloseListener = (event: ClosedEvent) => void;
12
+ type UpdateListener = () => void;
13
+ export type LiveAggregationOptions = {
14
+ grace?: DurationInput | `${number}${'ms' | 's' | 'm' | 'h' | 'd'}`;
15
+ };
16
+ export declare class LiveAggregation<S extends SeriesSchema> {
17
+ #private;
18
+ readonly name: string;
19
+ readonly schema: SeriesSchema;
20
+ constructor(source: LiveSource<S>, sequence: Sequence, mapping: AggregateMap<S>, options?: LiveAggregationOptions);
21
+ get length(): number;
22
+ get closedCount(): number;
23
+ get hasOpenBucket(): boolean;
24
+ at(index: number): ClosedEvent | undefined;
25
+ closed(): TimeSeries<SeriesSchema>;
26
+ snapshot(): TimeSeries<SeriesSchema>;
27
+ on(type: 'event', fn: CloseListener): () => void;
28
+ on(type: 'bucket', fn: BucketListener): this;
29
+ on(type: 'close', fn: CloseListener): this;
30
+ on(type: 'update', fn: UpdateListener): this;
31
+ filter(predicate: (event: ClosedEvent) => boolean): LiveView<SeriesSchema>;
32
+ map(fn: (event: ClosedEvent) => ClosedEvent): LiveView<SeriesSchema>;
33
+ select<const Keys extends readonly string[]>(...keys: Keys): LiveView<SelectSchema<SeriesSchema, Keys[number] & string>>;
34
+ window(size: RollingWindow): LiveView<SeriesSchema>;
35
+ diff<const Target extends NumericColumnNameForSchema<SeriesSchema>>(columns: Target | readonly Target[], options?: {
36
+ drop?: boolean;
37
+ }): LiveView<DiffSchema<SeriesSchema, Target>>;
38
+ rate<const Target extends NumericColumnNameForSchema<SeriesSchema>>(columns: Target | readonly Target[], options?: {
39
+ drop?: boolean;
40
+ }): LiveView<DiffSchema<SeriesSchema, Target>>;
41
+ pctChange<const Target extends NumericColumnNameForSchema<SeriesSchema>>(columns: Target | readonly Target[], options?: {
42
+ drop?: boolean;
43
+ }): LiveView<DiffSchema<SeriesSchema, Target>>;
44
+ fill(strategy: LiveFillStrategy | LiveFillMapping<SeriesSchema>, options?: {
45
+ limit?: number;
46
+ }): LiveView<SeriesSchema>;
47
+ cumulative<const Targets extends NumericColumnNameForSchema<SeriesSchema>>(spec: {
48
+ [K in Targets]: 'sum' | 'max' | 'min' | 'count' | ((acc: number, value: number) => number);
49
+ }): LiveView<DiffSchema<SeriesSchema, Targets>>;
50
+ rolling(windowSize: RollingWindow, mapping: AggregateMap<SeriesSchema>): LiveRollingAggregation<SeriesSchema>;
51
+ dispose(): void;
52
+ }
53
+ export {};
54
+ //# sourceMappingURL=LiveAggregation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveAggregation.d.ts","sourceRoot":"","sources":["../src/LiveAggregation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,240 @@
1
+ import { Event } from './Event.js';
2
+ import { Interval } from './Interval.js';
3
+ import { LiveView, makeDiffView, makeFillView, makeCumulativeView, } from './LiveView.js';
4
+ import { LiveRollingAggregation, } from './LiveRollingAggregation.js';
5
+ import { TimeSeries } from './TimeSeries.js';
6
+ import { resolveReducer } from './reducers/index.js';
7
+ import { parseDuration } from './utils/duration.js';
8
+ export class LiveAggregation {
9
+ name;
10
+ schema;
11
+ #columns;
12
+ #stepMs;
13
+ #anchorMs;
14
+ #graceMs;
15
+ #pending;
16
+ #watermark;
17
+ #closedEvents;
18
+ #onBucket;
19
+ #onClose;
20
+ #onUpdate;
21
+ #unsubscribe;
22
+ constructor(source, sequence, mapping, options) {
23
+ this.name = source.name;
24
+ this.#stepMs = sequence.stepMs();
25
+ this.#anchorMs = sequence.anchor();
26
+ const sourceGraceMs = 'graceWindowMs' in source &&
27
+ typeof source.graceWindowMs === 'number' &&
28
+ isFinite(source.graceWindowMs)
29
+ ? source.graceWindowMs
30
+ : 0;
31
+ this.#graceMs = options?.grace
32
+ ? parseDuration(options.grace)
33
+ : sourceGraceMs;
34
+ const colsByName = new Map(source.schema.slice(1).map((c) => [c.name, c]));
35
+ this.#columns = [];
36
+ for (const [name, reducer] of Object.entries(mapping)) {
37
+ const col = colsByName.get(name);
38
+ if (!col)
39
+ throw new TypeError(`unknown column '${name}'`);
40
+ const kind = resolveReducer(reducer).outputKind === 'number' ? 'number' : col.kind;
41
+ this.#columns.push({ output: name, source: name, reducer, kind });
42
+ }
43
+ this.schema = Object.freeze([
44
+ { name: 'time', kind: 'interval' },
45
+ ...this.#columns.map((c) => ({
46
+ name: c.output,
47
+ kind: c.kind,
48
+ required: false,
49
+ })),
50
+ ]);
51
+ this.#pending = new Map();
52
+ this.#watermark = -Infinity;
53
+ this.#closedEvents = [];
54
+ this.#onBucket = new Set();
55
+ this.#onClose = new Set();
56
+ this.#onUpdate = new Set();
57
+ for (let i = 0; i < source.length; i++) {
58
+ this.#ingest(source.at(i));
59
+ }
60
+ this.#unsubscribe = source.on('event', (event) => {
61
+ this.#ingest(event);
62
+ for (const fn of this.#onUpdate)
63
+ fn();
64
+ });
65
+ }
66
+ get length() {
67
+ return this.#closedEvents.length;
68
+ }
69
+ get closedCount() {
70
+ return this.#closedEvents.length;
71
+ }
72
+ get hasOpenBucket() {
73
+ return this.#pending.size > 0;
74
+ }
75
+ at(index) {
76
+ if (index < 0)
77
+ index = this.#closedEvents.length + index;
78
+ return this.#closedEvents[index];
79
+ }
80
+ closed() {
81
+ return this.#buildSeries(false);
82
+ }
83
+ snapshot() {
84
+ return this.#buildSeries(true);
85
+ }
86
+ on(type, fn) {
87
+ if (type === 'event' || type === 'close') {
88
+ this.#onClose.add(fn);
89
+ if (type === 'event')
90
+ return () => {
91
+ this.#onClose.delete(fn);
92
+ };
93
+ return this;
94
+ }
95
+ if (type === 'bucket') {
96
+ this.#onBucket.add(fn);
97
+ return this;
98
+ }
99
+ this.#onUpdate.add(fn);
100
+ return this;
101
+ }
102
+ // ── View transforms ─────────────────────────────────────────
103
+ filter(predicate) {
104
+ return new LiveView(this, (event) => predicate(event) ? event : undefined);
105
+ }
106
+ map(fn) {
107
+ return new LiveView(this, fn);
108
+ }
109
+ select(...keys) {
110
+ const newSchema = Object.freeze([
111
+ this.schema[0],
112
+ ...this.schema.slice(1).filter((c) => keys.includes(c.name)),
113
+ ]);
114
+ return new LiveView(this, (event) => event.select(...keys), {
115
+ schema: newSchema,
116
+ });
117
+ }
118
+ window(size) {
119
+ return new LiveView(this, (event) => event).window(size);
120
+ }
121
+ diff(columns, options) {
122
+ return makeDiffView(this, 'diff', columns, options);
123
+ }
124
+ rate(columns, options) {
125
+ return makeDiffView(this, 'rate', columns, options);
126
+ }
127
+ pctChange(columns, options) {
128
+ return makeDiffView(this, 'pctChange', columns, options);
129
+ }
130
+ fill(strategy, options) {
131
+ return makeFillView(this, strategy, options);
132
+ }
133
+ cumulative(spec) {
134
+ return makeCumulativeView(this, spec);
135
+ }
136
+ rolling(windowSize, mapping) {
137
+ return new LiveRollingAggregation(this, windowSize, mapping);
138
+ }
139
+ dispose() {
140
+ this.#unsubscribe();
141
+ }
142
+ // ── Private ─────────────────────────────────────────────────
143
+ #bucketFor(timestamp) {
144
+ const start = Math.floor((timestamp - this.#anchorMs) / this.#stepMs) * this.#stepMs +
145
+ this.#anchorMs;
146
+ return { start, end: start + this.#stepMs };
147
+ }
148
+ #ingest(event) {
149
+ const bucket = this.#bucketFor(event.begin());
150
+ const ts = event.begin();
151
+ if (ts > this.#watermark)
152
+ this.#watermark = ts;
153
+ const closeCutoff = this.#watermark - this.#graceMs;
154
+ if (bucket.end <= closeCutoff)
155
+ return;
156
+ let pending = this.#pending.get(bucket.start);
157
+ if (!pending) {
158
+ pending = {
159
+ start: bucket.start,
160
+ end: bucket.end,
161
+ states: this.#columns.map((c) => resolveReducer(c.reducer).bucketState()),
162
+ };
163
+ this.#pending.set(bucket.start, pending);
164
+ }
165
+ const data = event.data();
166
+ for (let i = 0; i < this.#columns.length; i++) {
167
+ pending.states[i].add(data[this.#columns[i].source]);
168
+ }
169
+ if (this.#onBucket.size > 0) {
170
+ const interval = new Interval({
171
+ value: pending.start,
172
+ start: pending.start,
173
+ end: pending.end,
174
+ });
175
+ const record = {};
176
+ for (let i = 0; i < this.#columns.length; i++) {
177
+ record[this.#columns[i].output] = pending.states[i].snapshot();
178
+ }
179
+ const evt = new Event(interval, record);
180
+ for (const fn of this.#onBucket)
181
+ fn(evt);
182
+ }
183
+ this.#closeEligible(closeCutoff);
184
+ }
185
+ #closeEligible(closeCutoff) {
186
+ const eligible = [];
187
+ for (const [start, b] of this.#pending) {
188
+ if (b.end <= closeCutoff)
189
+ eligible.push(start);
190
+ }
191
+ if (eligible.length === 0)
192
+ return;
193
+ eligible.sort((a, b) => a - b);
194
+ for (const start of eligible) {
195
+ const b = this.#pending.get(start);
196
+ this.#pending.delete(start);
197
+ this.#finalizeBucket(b);
198
+ }
199
+ }
200
+ #finalizeBucket(bucket) {
201
+ const interval = new Interval({
202
+ value: bucket.start,
203
+ start: bucket.start,
204
+ end: bucket.end,
205
+ });
206
+ const record = {};
207
+ for (let i = 0; i < this.#columns.length; i++) {
208
+ record[this.#columns[i].output] = bucket.states[i].snapshot();
209
+ }
210
+ const evt = new Event(interval, record);
211
+ this.#closedEvents.push(evt);
212
+ for (const fn of this.#onClose)
213
+ fn(evt);
214
+ }
215
+ #buildSeries(includeOpen) {
216
+ const rows = this.#closedEvents.map((event) => {
217
+ const data = event.data();
218
+ return [event.key(), ...this.#columns.map((c) => data[c.output])];
219
+ });
220
+ if (includeOpen) {
221
+ const pendingBuckets = [...this.#pending.values()].sort((a, b) => a.start - b.start);
222
+ for (const b of pendingBuckets) {
223
+ rows.push([
224
+ new Interval({
225
+ value: b.start,
226
+ start: b.start,
227
+ end: b.end,
228
+ }),
229
+ ...b.states.map((s) => s.snapshot()),
230
+ ]);
231
+ }
232
+ }
233
+ return new TimeSeries({
234
+ name: this.name,
235
+ schema: this.schema,
236
+ rows: rows,
237
+ });
238
+ }
239
+ }
240
+ //# sourceMappingURL=LiveAggregation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveAggregation.js","sourceRoot":"","sources":["../src/LiveAggregation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,43 @@
1
+ import { LiveAggregation } from './LiveAggregation.js';
2
+ import { LiveView, type LiveFillMapping, type LiveFillStrategy } from './LiveView.js';
3
+ import type { Sequence } from './Sequence.js';
4
+ import type { AggregateMap, DiffSchema, LiveSource, NumericColumnNameForSchema, ScalarValue, SelectSchema, SeriesSchema } from './types.js';
5
+ import type { DurationInput } from './utils/duration.js';
6
+ type UpdateListener = (value: Record<string, ScalarValue | undefined>) => void;
7
+ type EventListener = (event: any) => void;
8
+ export type RollingWindow = DurationInput | number;
9
+ export declare class LiveRollingAggregation<S extends SeriesSchema> {
10
+ #private;
11
+ readonly name: string;
12
+ readonly schema: SeriesSchema;
13
+ constructor(source: LiveSource<S>, window: RollingWindow, mapping: AggregateMap<S>);
14
+ get length(): number;
15
+ at(index: number): any;
16
+ value(): Record<string, ScalarValue | undefined>;
17
+ get windowSize(): number;
18
+ on(type: 'event', fn: EventListener): () => void;
19
+ on(type: 'update', fn: UpdateListener): this;
20
+ filter(predicate: (event: any) => boolean): LiveView<SeriesSchema>;
21
+ map(fn: (event: any) => any): LiveView<SeriesSchema>;
22
+ select<const Keys extends readonly string[]>(...keys: Keys): LiveView<SelectSchema<SeriesSchema, Keys[number] & string>>;
23
+ window(size: RollingWindow): LiveView<SeriesSchema>;
24
+ diff<const Target extends NumericColumnNameForSchema<SeriesSchema>>(columns: Target | readonly Target[], options?: {
25
+ drop?: boolean;
26
+ }): LiveView<DiffSchema<SeriesSchema, Target>>;
27
+ rate<const Target extends NumericColumnNameForSchema<SeriesSchema>>(columns: Target | readonly Target[], options?: {
28
+ drop?: boolean;
29
+ }): LiveView<DiffSchema<SeriesSchema, Target>>;
30
+ pctChange<const Target extends NumericColumnNameForSchema<SeriesSchema>>(columns: Target | readonly Target[], options?: {
31
+ drop?: boolean;
32
+ }): LiveView<DiffSchema<SeriesSchema, Target>>;
33
+ fill(strategy: LiveFillStrategy | LiveFillMapping<SeriesSchema>, options?: {
34
+ limit?: number;
35
+ }): LiveView<SeriesSchema>;
36
+ cumulative<const Targets extends NumericColumnNameForSchema<SeriesSchema>>(spec: {
37
+ [K in Targets]: 'sum' | 'max' | 'min' | 'count' | ((acc: number, value: number) => number);
38
+ }): LiveView<DiffSchema<SeriesSchema, Targets>>;
39
+ aggregate(sequence: Sequence, mapping: AggregateMap<SeriesSchema>): LiveAggregation<SeriesSchema>;
40
+ dispose(): void;
41
+ }
42
+ export {};
43
+ //# sourceMappingURL=LiveRollingAggregation.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveRollingAggregation.d.ts","sourceRoot":"","sources":["../src/LiveRollingAggregation.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EACL,QAAQ,EAIR,KAAK,eAAe,EACpB,KAAK,gBAAgB,EACtB,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,EACV,YAAY,EACZ,UAAU,EAEV,UAAU,EACV,0BAA0B,EAC1B,WAAW,EACX,YAAY,EACZ,YAAY,EACb,MAAM,YAAY,CAAC;AAEpB,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAezD,KAAK,cAAc,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,WAAW,GAAG,SAAS,CAAC,KAAK,IAAI,CAAC;AAC/E,KAAK,aAAa,GAAG,CAAC,KAAK,EAAE,GAAG,KAAK,IAAI,CAAC;AAE1C,MAAM,MAAM,aAAa,GAAG,aAAa,GAAG,MAAM,CAAC;AAEnD,qBAAa,sBAAsB,CAAC,CAAC,SAAS,YAAY;;IACxD,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,MAAM,EAAE,YAAY,CAAC;gBAgB5B,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,EACrB,MAAM,EAAE,aAAa,EACrB,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC;IA6D1B,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,GAAG;IAKtB,KAAK,IAAI,MAAM,CAAC,MAAM,EAAE,WAAW,GAAG,SAAS,CAAC;IAQhD,IAAI,UAAU,IAAI,MAAM,CAEvB;IAED,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,aAAa,GAAG,MAAM,IAAI;IAChD,EAAE,CAAC,IAAI,EAAE,QAAQ,EAAE,EAAE,EAAE,cAAc,GAAG,IAAI;IAiB5C,MAAM,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,OAAO,GAAG,QAAQ,CAAC,YAAY,CAAC;IAMlE,GAAG,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,GAAG,KAAK,GAAG,GAAG,QAAQ,CAAC,YAAY,CAAC;IAIpD,MAAM,CAAC,KAAK,CAAC,IAAI,SAAS,SAAS,MAAM,EAAE,EACzC,GAAG,IAAI,EAAE,IAAI,GACZ,QAAQ,CAAC,YAAY,CAAC,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC;IAW9D,MAAM,CAAC,IAAI,EAAE,aAAa,GAAG,QAAQ,CAAC,YAAY,CAAC;IAInD,IAAI,CAAC,KAAK,CAAC,MAAM,SAAS,0BAA0B,CAAC,YAAY,CAAC,EAChE,OAAO,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,EACnC,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,OAAO,CAAA;KAAE,GAC3B,QAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;IAI7C,IAAI,CAAC,KAAK,CAAC,MAAM,SAAS,0BAA0B,CAAC,YAAY,CAAC,EAChE,OAAO,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,EACnC,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,OAAO,CAAA;KAAE,GAC3B,QAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;IAI7C,SAAS,CAAC,KAAK,CAAC,MAAM,SAAS,0BAA0B,CAAC,YAAY,CAAC,EACrE,OAAO,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,EACnC,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,OAAO,CAAA;KAAE,GAC3B,QAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;IAI7C,IAAI,CACF,QAAQ,EAAE,gBAAgB,GAAG,eAAe,CAAC,YAAY,CAAC,EAC1D,OAAO,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAC3B,QAAQ,CAAC,YAAY,CAAC;IAIzB,UAAU,CACR,KAAK,CAAC,OAAO,SAAS,0BAA0B,CAAC,YAAY,CAAC,EAC9D,IAAI,EAAE;SACL,CAAC,IAAI,OAAO,GACT,KAAK,GACL,KAAK,GACL,KAAK,GACL,OAAO,GACP,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;KAC7C,GAAG,QAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,OAAO,CAAC,CAAC;IAI/C,SAAS,CACP,QAAQ,EAAE,QAAQ,EAClB,OAAO,EAAE,YAAY,CAAC,YAAY,CAAC,GAClC,eAAe,CAAC,YAAY,CAAC;IAIhC,OAAO,IAAI,IAAI;CAqDhB"}
@@ -0,0 +1,178 @@
1
+ import { Event } from './Event.js';
2
+ import { LiveAggregation } from './LiveAggregation.js';
3
+ import { LiveView, makeDiffView, makeFillView, makeCumulativeView, } from './LiveView.js';
4
+ import { resolveReducer } from './reducers/index.js';
5
+ import { parseDuration } from './utils/duration.js';
6
+ export class LiveRollingAggregation {
7
+ name;
8
+ schema;
9
+ #columns;
10
+ #states;
11
+ #entries;
12
+ #windowMs;
13
+ #windowCount;
14
+ #nextIndex;
15
+ #outputEvents;
16
+ #onUpdate;
17
+ #onEvent;
18
+ #unsubscribe;
19
+ constructor(source, window, mapping) {
20
+ this.name = source.name;
21
+ if (typeof window === 'number' && Number.isInteger(window) && window > 0) {
22
+ this.#windowMs = undefined;
23
+ this.#windowCount = window;
24
+ }
25
+ else {
26
+ this.#windowMs =
27
+ typeof window === 'string' ? parseDuration(window) : undefined;
28
+ if (this.#windowMs === undefined && typeof window === 'number') {
29
+ throw new TypeError('window must be a positive integer (event count) or duration string');
30
+ }
31
+ this.#windowCount = undefined;
32
+ }
33
+ const colsByName = new Map(source.schema.slice(1).map((c) => [c.name, c]));
34
+ this.#columns = [];
35
+ for (const [name, reducer] of Object.entries(mapping)) {
36
+ const col = colsByName.get(name);
37
+ if (!col)
38
+ throw new TypeError(`unknown column '${name}'`);
39
+ const kind = resolveReducer(reducer).outputKind === 'number' ? 'number' : col.kind;
40
+ this.#columns.push({ source: name, reducer, kind });
41
+ }
42
+ this.schema = Object.freeze([
43
+ source.schema[0],
44
+ ...this.#columns.map((c) => ({
45
+ name: c.source,
46
+ kind: c.kind,
47
+ required: false,
48
+ })),
49
+ ]);
50
+ this.#states = this.#columns.map((c) => resolveReducer(c.reducer).rollingState());
51
+ this.#entries = [];
52
+ this.#nextIndex = 0;
53
+ this.#outputEvents = [];
54
+ this.#onUpdate = new Set();
55
+ this.#onEvent = new Set();
56
+ for (let i = 0; i < source.length; i++) {
57
+ this.#ingest(source.at(i));
58
+ }
59
+ this.#unsubscribe = source.on('event', (event) => {
60
+ this.#ingest(event);
61
+ const val = this.value();
62
+ for (const fn of this.#onUpdate)
63
+ fn(val);
64
+ });
65
+ }
66
+ get length() {
67
+ return this.#outputEvents.length;
68
+ }
69
+ at(index) {
70
+ if (index < 0)
71
+ index = this.#outputEvents.length + index;
72
+ return this.#outputEvents[index];
73
+ }
74
+ value() {
75
+ const result = {};
76
+ for (let i = 0; i < this.#columns.length; i++) {
77
+ result[this.#columns[i].source] = this.#states[i].snapshot();
78
+ }
79
+ return result;
80
+ }
81
+ get windowSize() {
82
+ return this.#entries.length;
83
+ }
84
+ on(type, fn) {
85
+ if (type === 'event') {
86
+ this.#onEvent.add(fn);
87
+ return () => {
88
+ this.#onEvent.delete(fn);
89
+ };
90
+ }
91
+ this.#onUpdate.add(fn);
92
+ return this;
93
+ }
94
+ // ── View transforms ─────────────────────────────────────────
95
+ filter(predicate) {
96
+ return new LiveView(this, (event) => predicate(event) ? event : undefined);
97
+ }
98
+ map(fn) {
99
+ return new LiveView(this, fn);
100
+ }
101
+ select(...keys) {
102
+ const newSchema = Object.freeze([
103
+ this.schema[0],
104
+ ...this.schema.slice(1).filter((c) => keys.includes(c.name)),
105
+ ]);
106
+ return new LiveView(this, (event) => event.select(...keys), {
107
+ schema: newSchema,
108
+ });
109
+ }
110
+ window(size) {
111
+ return new LiveView(this, (event) => event).window(size);
112
+ }
113
+ diff(columns, options) {
114
+ return makeDiffView(this, 'diff', columns, options);
115
+ }
116
+ rate(columns, options) {
117
+ return makeDiffView(this, 'rate', columns, options);
118
+ }
119
+ pctChange(columns, options) {
120
+ return makeDiffView(this, 'pctChange', columns, options);
121
+ }
122
+ fill(strategy, options) {
123
+ return makeFillView(this, strategy, options);
124
+ }
125
+ cumulative(spec) {
126
+ return makeCumulativeView(this, spec);
127
+ }
128
+ aggregate(sequence, mapping) {
129
+ return new LiveAggregation(this, sequence, mapping);
130
+ }
131
+ dispose() {
132
+ this.#unsubscribe();
133
+ }
134
+ // ── Private ─────────────────────────────────────────────────
135
+ #ingest(event) {
136
+ const data = event.data();
137
+ const values = this.#columns.map((c) => data[c.source]);
138
+ const index = this.#nextIndex++;
139
+ const entry = {
140
+ index,
141
+ timestamp: event.begin(),
142
+ values,
143
+ };
144
+ for (let i = 0; i < this.#columns.length; i++) {
145
+ this.#states[i].add(index, values[i]);
146
+ }
147
+ this.#entries.push(entry);
148
+ this.#evict(event.begin());
149
+ const record = {};
150
+ for (let i = 0; i < this.#columns.length; i++) {
151
+ record[this.#columns[i].source] = this.#states[i].snapshot();
152
+ }
153
+ const outputEvent = new Event(event.key(), record);
154
+ this.#outputEvents.push(outputEvent);
155
+ for (const fn of this.#onEvent)
156
+ fn(outputEvent);
157
+ }
158
+ #evict(latestTimestamp) {
159
+ if (this.#windowMs !== undefined) {
160
+ const cutoff = latestTimestamp - this.#windowMs;
161
+ while (this.#entries.length > 0 && this.#entries[0].timestamp < cutoff) {
162
+ this.#removeFirst();
163
+ }
164
+ }
165
+ if (this.#windowCount !== undefined) {
166
+ while (this.#entries.length > this.#windowCount) {
167
+ this.#removeFirst();
168
+ }
169
+ }
170
+ }
171
+ #removeFirst() {
172
+ const entry = this.#entries.shift();
173
+ for (let i = 0; i < this.#columns.length; i++) {
174
+ this.#states[i].remove(entry.index, entry.values[i]);
175
+ }
176
+ }
177
+ }
178
+ //# sourceMappingURL=LiveRollingAggregation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveRollingAggregation.js","sourceRoot":"","sources":["../src/LiveRollingAggregation.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,63 @@
1
+ import { LiveAggregation } from './LiveAggregation.js';
2
+ import { LiveView, type LiveFillMapping, type LiveFillStrategy } from './LiveView.js';
3
+ import { LiveRollingAggregation, type RollingWindow } from './LiveRollingAggregation.js';
4
+ import { TimeSeries } from './TimeSeries.js';
5
+ import type { Sequence } from './Sequence.js';
6
+ import type { AggregateMap, DiffSchema, EventDataForSchema, EventForSchema, NumericColumnNameForSchema, RowForSchema, SelectSchema, SeriesSchema } from './types.js';
7
+ import type { DurationInput } from './utils/duration.js';
8
+ export type OrderingMode = 'strict' | 'drop' | 'reorder';
9
+ export type RetentionPolicy = {
10
+ maxEvents?: number;
11
+ maxAge?: DurationInput;
12
+ maxBytes?: number;
13
+ };
14
+ export type LiveSeriesOptions<S extends SeriesSchema> = {
15
+ name: string;
16
+ schema: S;
17
+ ordering?: OrderingMode;
18
+ graceWindow?: DurationInput;
19
+ retention?: RetentionPolicy;
20
+ };
21
+ type EventListener<S extends SeriesSchema> = (event: EventForSchema<S>) => void;
22
+ type BatchListener<S extends SeriesSchema> = (events: ReadonlyArray<EventForSchema<S>>) => void;
23
+ type EvictListener<S extends SeriesSchema> = (events: ReadonlyArray<EventForSchema<S>>) => void;
24
+ export declare class LiveSeries<S extends SeriesSchema> {
25
+ #private;
26
+ readonly name: string;
27
+ readonly schema: S;
28
+ constructor(options: LiveSeriesOptions<S>);
29
+ get length(): number;
30
+ get graceWindowMs(): number;
31
+ at(index: number): EventForSchema<S> | undefined;
32
+ first(): EventForSchema<S> | undefined;
33
+ last(): EventForSchema<S> | undefined;
34
+ push(...rows: RowForSchema<S>[]): void;
35
+ clear(): void;
36
+ toTimeSeries(name?: string): TimeSeries<S>;
37
+ filter(predicate: (event: EventForSchema<S>) => boolean): LiveView<S>;
38
+ map(fn: (event: EventForSchema<S>) => EventForSchema<S>): LiveView<S>;
39
+ select<const Keys extends readonly (keyof EventDataForSchema<S>)[]>(...keys: Keys): LiveView<SelectSchema<S, Keys[number] & string>>;
40
+ window(size: RollingWindow): LiveView<S>;
41
+ aggregate(sequence: Sequence, mapping: AggregateMap<S>): LiveAggregation<S>;
42
+ rolling(window: RollingWindow, mapping: AggregateMap<S>): LiveRollingAggregation<S>;
43
+ diff<const Target extends NumericColumnNameForSchema<S>>(columns: Target | readonly Target[], options?: {
44
+ drop?: boolean;
45
+ }): LiveView<DiffSchema<S, Target>>;
46
+ rate<const Target extends NumericColumnNameForSchema<S>>(columns: Target | readonly Target[], options?: {
47
+ drop?: boolean;
48
+ }): LiveView<DiffSchema<S, Target>>;
49
+ pctChange<const Target extends NumericColumnNameForSchema<S>>(columns: Target | readonly Target[], options?: {
50
+ drop?: boolean;
51
+ }): LiveView<DiffSchema<S, Target>>;
52
+ fill(strategy: LiveFillStrategy | LiveFillMapping<S>, options?: {
53
+ limit?: number;
54
+ }): LiveView<S>;
55
+ cumulative<const Targets extends NumericColumnNameForSchema<S>>(spec: {
56
+ [K in Targets]: 'sum' | 'max' | 'min' | 'count' | ((acc: number, value: number) => number);
57
+ }): LiveView<DiffSchema<S, Targets>>;
58
+ on(type: 'event', fn: EventListener<S>): () => void;
59
+ on(type: 'batch', fn: BatchListener<S>): () => void;
60
+ on(type: 'evict', fn: EvictListener<S>): () => void;
61
+ }
62
+ export {};
63
+ //# sourceMappingURL=LiveSeries.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"LiveSeries.d.ts","sourceRoot":"","sources":["../src/LiveSeries.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EACL,QAAQ,EAIR,KAAK,eAAe,EACpB,KAAK,gBAAgB,EACtB,MAAM,eAAe,CAAC;AAGvB,OAAO,EACL,sBAAsB,EACtB,KAAK,aAAa,EACnB,MAAM,6BAA6B,CAAC;AACrC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAG7C,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AAC9C,OAAO,KAAK,EACV,YAAY,EACZ,UAAU,EACV,kBAAkB,EAClB,cAAc,EAEd,0BAA0B,EAC1B,YAAY,EACZ,YAAY,EACZ,YAAY,EACb,MAAM,YAAY,CAAC;AAEpB,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAmFzD,MAAM,MAAM,YAAY,GAAG,QAAQ,GAAG,MAAM,GAAG,SAAS,CAAC;AAEzD,MAAM,MAAM,eAAe,GAAG;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,aAAa,CAAC;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB,CAAC;AAEF,MAAM,MAAM,iBAAiB,CAAC,CAAC,SAAS,YAAY,IAAI;IACtD,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,EAAE,CAAC,CAAC;IACV,QAAQ,CAAC,EAAE,YAAY,CAAC;IACxB,WAAW,CAAC,EAAE,aAAa,CAAC;IAC5B,SAAS,CAAC,EAAE,eAAe,CAAC;CAC7B,CAAC;AAEF,KAAK,aAAa,CAAC,CAAC,SAAS,YAAY,IAAI,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC;AAChF,KAAK,aAAa,CAAC,CAAC,SAAS,YAAY,IAAI,CAC3C,MAAM,EAAE,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,KACrC,IAAI,CAAC;AACV,KAAK,aAAa,CAAC,CAAC,SAAS,YAAY,IAAI,CAC3C,MAAM,EAAE,aAAa,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,KACrC,IAAI,CAAC;AAIV,qBAAa,UAAU,CAAC,CAAC,SAAS,YAAY;;IAC5C,QAAQ,CAAC,IAAI,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;gBAeP,OAAO,EAAE,iBAAiB,CAAC,CAAC,CAAC;IA6BzC,IAAI,MAAM,IAAI,MAAM,CAEnB;IAED,IAAI,aAAa,IAAI,MAAM,CAE1B;IAED,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,cAAc,CAAC,CAAC,CAAC,GAAG,SAAS;IAKhD,KAAK,IAAI,cAAc,CAAC,CAAC,CAAC,GAAG,SAAS;IAItC,IAAI,IAAI,cAAc,CAAC,CAAC,CAAC,GAAG,SAAS;IAIrC,IAAI,CAAC,GAAG,IAAI,EAAE,YAAY,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI;IAwBtC,KAAK,IAAI,IAAI;IASb,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,UAAU,CAAC,CAAC,CAAC;IAe1C,MAAM,CAAC,SAAS,EAAE,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,KAAK,OAAO,GAAG,QAAQ,CAAC,CAAC,CAAC;IAMrE,GAAG,CAAC,EAAE,EAAE,CAAC,KAAK,EAAE,cAAc,CAAC,CAAC,CAAC,KAAK,cAAc,CAAC,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC;IAIrE,MAAM,CAAC,KAAK,CAAC,IAAI,SAAS,SAAS,CAAC,MAAM,kBAAkB,CAAC,CAAC,CAAC,CAAC,EAAE,EAChE,GAAG,IAAI,EAAE,IAAI,GACZ,QAAQ,CAAC,YAAY,CAAC,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC,CAAC;IAWnD,MAAM,CAAC,IAAI,EAAE,aAAa,GAAG,QAAQ,CAAC,CAAC,CAAC;IAyBxC,SAAS,CAAC,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC;IAI3E,OAAO,CACL,MAAM,EAAE,aAAa,EACrB,OAAO,EAAE,YAAY,CAAC,CAAC,CAAC,GACvB,sBAAsB,CAAC,CAAC,CAAC;IAI5B,IAAI,CAAC,KAAK,CAAC,MAAM,SAAS,0BAA0B,CAAC,CAAC,CAAC,EACrD,OAAO,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,EACnC,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,OAAO,CAAA;KAAE,GAC3B,QAAQ,CAAC,UAAU,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IAIlC,IAAI,CAAC,KAAK,CAAC,MAAM,SAAS,0BAA0B,CAAC,CAAC,CAAC,EACrD,OAAO,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,EACnC,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,OAAO,CAAA;KAAE,GAC3B,QAAQ,CAAC,UAAU,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IAIlC,SAAS,CAAC,KAAK,CAAC,MAAM,SAAS,0BAA0B,CAAC,CAAC,CAAC,EAC1D,OAAO,EAAE,MAAM,GAAG,SAAS,MAAM,EAAE,EACnC,OAAO,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,OAAO,CAAA;KAAE,GAC3B,QAAQ,CAAC,UAAU,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;IAIlC,IAAI,CACF,QAAQ,EAAE,gBAAgB,GAAG,eAAe,CAAC,CAAC,CAAC,EAC/C,OAAO,CAAC,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,GAC3B,QAAQ,CAAC,CAAC,CAAC;IAId,UAAU,CAAC,KAAK,CAAC,OAAO,SAAS,0BAA0B,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE;SACnE,CAAC,IAAI,OAAO,GACT,KAAK,GACL,KAAK,GACL,KAAK,GACL,OAAO,GACP,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;KAC7C,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC;IAIpC,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI;IACnD,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI;IACnD,EAAE,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,EAAE,aAAa,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI;CAoIpD"}