@synnaxlabs/client 0.1.0 → 0.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 (89) hide show
  1. package/build/main/index.d.ts +4 -0
  2. package/build/main/index.js +36 -0
  3. package/build/main/lib/channel/channel.spec.d.ts +1 -0
  4. package/build/main/lib/channel/channel.spec.js +35 -0
  5. package/build/main/lib/channel/client.d.ts +94 -0
  6. package/build/main/lib/channel/client.js +131 -0
  7. package/build/main/lib/channel/creator.d.ts +19 -0
  8. package/build/main/lib/channel/creator.js +44 -0
  9. package/build/main/lib/channel/payload.d.ts +25 -0
  10. package/build/main/lib/channel/payload.js +18 -0
  11. package/build/main/lib/channel/registry.d.ts +9 -0
  12. package/build/main/lib/channel/registry.js +37 -0
  13. package/build/main/lib/channel/retriever.d.ts +11 -0
  14. package/build/main/lib/channel/retriever.js +39 -0
  15. package/build/main/lib/client.d.ts +23 -0
  16. package/build/main/lib/client.js +34 -0
  17. package/build/main/lib/errors.d.ts +53 -0
  18. package/build/main/lib/errors.js +122 -0
  19. package/build/main/lib/segment/client.d.ts +62 -0
  20. package/build/main/lib/segment/client.js +95 -0
  21. package/build/main/lib/segment/iterator.d.ts +134 -0
  22. package/build/main/lib/segment/iterator.js +253 -0
  23. package/build/main/lib/segment/iterator.spec.d.ts +1 -0
  24. package/build/main/lib/segment/iterator.spec.js +62 -0
  25. package/build/main/lib/segment/payload.d.ts +16 -0
  26. package/build/main/lib/segment/payload.js +13 -0
  27. package/build/main/lib/segment/splitter.d.ts +7 -0
  28. package/build/main/lib/segment/splitter.js +25 -0
  29. package/build/main/lib/segment/typed.d.ts +15 -0
  30. package/build/main/lib/segment/typed.js +49 -0
  31. package/build/main/lib/segment/validator.d.ts +22 -0
  32. package/build/main/lib/segment/validator.js +64 -0
  33. package/build/main/lib/segment/writer.d.ts +98 -0
  34. package/build/main/lib/segment/writer.js +183 -0
  35. package/build/main/lib/segment/writer.spec.d.ts +1 -0
  36. package/build/main/lib/segment/writer.spec.js +76 -0
  37. package/build/main/lib/telem.d.ts +395 -0
  38. package/build/main/lib/telem.js +553 -0
  39. package/build/main/lib/telem.spec.d.ts +1 -0
  40. package/build/main/lib/telem.spec.js +150 -0
  41. package/build/main/lib/transport.d.ts +9 -0
  42. package/build/main/lib/transport.js +18 -0
  43. package/build/main/lib/util/telem.d.ts +2 -0
  44. package/build/main/lib/util/telem.js +13 -0
  45. package/build/module/index.d.ts +4 -0
  46. package/build/module/index.js +5 -0
  47. package/build/module/lib/channel/channel.spec.d.ts +1 -0
  48. package/build/module/lib/channel/channel.spec.js +30 -0
  49. package/build/module/lib/channel/client.d.ts +94 -0
  50. package/build/module/lib/channel/client.js +131 -0
  51. package/build/module/lib/channel/creator.d.ts +19 -0
  52. package/build/module/lib/channel/creator.js +42 -0
  53. package/build/module/lib/channel/payload.d.ts +25 -0
  54. package/build/module/lib/channel/payload.js +15 -0
  55. package/build/module/lib/channel/registry.d.ts +9 -0
  56. package/build/module/lib/channel/registry.js +36 -0
  57. package/build/module/lib/channel/retriever.d.ts +11 -0
  58. package/build/module/lib/channel/retriever.js +37 -0
  59. package/build/module/lib/client.d.ts +23 -0
  60. package/build/module/lib/client.js +31 -0
  61. package/build/module/lib/errors.d.ts +53 -0
  62. package/build/module/lib/errors.js +113 -0
  63. package/build/module/lib/segment/client.d.ts +62 -0
  64. package/build/module/lib/segment/client.js +94 -0
  65. package/build/module/lib/segment/iterator.d.ts +134 -0
  66. package/build/module/lib/segment/iterator.js +248 -0
  67. package/build/module/lib/segment/iterator.spec.d.ts +1 -0
  68. package/build/module/lib/segment/iterator.spec.js +57 -0
  69. package/build/module/lib/segment/payload.d.ts +16 -0
  70. package/build/module/lib/segment/payload.js +10 -0
  71. package/build/module/lib/segment/splitter.d.ts +7 -0
  72. package/build/module/lib/segment/splitter.js +26 -0
  73. package/build/module/lib/segment/typed.d.ts +15 -0
  74. package/build/module/lib/segment/typed.js +49 -0
  75. package/build/module/lib/segment/validator.d.ts +22 -0
  76. package/build/module/lib/segment/validator.js +60 -0
  77. package/build/module/lib/segment/writer.d.ts +98 -0
  78. package/build/module/lib/segment/writer.js +183 -0
  79. package/build/module/lib/segment/writer.spec.d.ts +1 -0
  80. package/build/module/lib/segment/writer.spec.js +71 -0
  81. package/build/module/lib/telem.d.ts +395 -0
  82. package/build/module/lib/telem.js +545 -0
  83. package/build/module/lib/telem.spec.d.ts +1 -0
  84. package/build/module/lib/telem.spec.js +145 -0
  85. package/build/module/lib/transport.d.ts +9 -0
  86. package/build/module/lib/transport.js +18 -0
  87. package/build/module/lib/util/telem.d.ts +2 -0
  88. package/build/module/lib/util/telem.js +9 -0
  89. package/package.json +2 -2
@@ -0,0 +1,248 @@
1
+ import { EOF, ErrorPayloadSchema, } from '@synnaxlabs/freighter';
2
+ import { z } from 'zod';
3
+ import { TimeRange } from '../telem';
4
+ import { SegmentPayloadSchema } from './payload';
5
+ import TypedSegment from './typed';
6
+ var Command;
7
+ (function (Command) {
8
+ Command[Command["Open"] = 0] = "Open";
9
+ Command[Command["Next"] = 1] = "Next";
10
+ Command[Command["Prev"] = 2] = "Prev";
11
+ Command[Command["First"] = 3] = "First";
12
+ Command[Command["Last"] = 4] = "Last";
13
+ Command[Command["NextSpan"] = 5] = "NextSpan";
14
+ Command[Command["PrevSpan"] = 6] = "PrevSpan";
15
+ Command[Command["NextRange"] = 7] = "NextRange";
16
+ Command[Command["Valid"] = 8] = "Valid";
17
+ Command[Command["Error"] = 9] = "Error";
18
+ Command[Command["SeekFirst"] = 10] = "SeekFirst";
19
+ Command[Command["SeekLast"] = 11] = "SeekLast";
20
+ Command[Command["SeekLT"] = 12] = "SeekLT";
21
+ Command[Command["SeekGE"] = 13] = "SeekGE";
22
+ })(Command || (Command = {}));
23
+ var ResponseVariant;
24
+ (function (ResponseVariant) {
25
+ ResponseVariant[ResponseVariant["None"] = 0] = "None";
26
+ ResponseVariant[ResponseVariant["Ack"] = 1] = "Ack";
27
+ ResponseVariant[ResponseVariant["Data"] = 2] = "Data";
28
+ })(ResponseVariant || (ResponseVariant = {}));
29
+ const RequestSchema = z.object({
30
+ command: z.nativeEnum(Command),
31
+ span: z.number().optional(),
32
+ range: z.instanceof(TimeRange).optional(),
33
+ stamp: z.number().optional(),
34
+ keys: z.string().array().optional(),
35
+ });
36
+ const ResponseSchema = z.object({
37
+ variant: z.nativeEnum(ResponseVariant),
38
+ ack: z.boolean(),
39
+ command: z.nativeEnum(Command),
40
+ error: ErrorPayloadSchema.optional(),
41
+ segments: SegmentPayloadSchema.array().nullable(),
42
+ });
43
+ /**
44
+ * Used to iterate over a clusters telemetry in time-order. It should not be
45
+ * instantiated directly, and should instead be instantiated via the SegmentClient.
46
+ *
47
+ * Using an iterator is ideal when querying/processing large ranges of data, but
48
+ * is relatively complex and difficult to use. If you're looking to retrieve
49
+ * telemetry between two timestamps, see the SegmentClient.read method.
50
+ */
51
+ export class CoreIterator {
52
+ static ENDPOINT = '/segment/iterate';
53
+ client;
54
+ stream;
55
+ aggregate = false;
56
+ values = [];
57
+ constructor(client, aggregate = false) {
58
+ this.client = client;
59
+ this.aggregate = aggregate;
60
+ }
61
+ /**
62
+ * Opens the iterator, configuring it to iterate over the telemetry in the
63
+ * channels with the given keys within the provided time range.
64
+ *
65
+ * @param tr - The time range to iterate over.
66
+ * @param keys - The keys of the channels to iterate over.
67
+ */
68
+ async open(tr, keys) {
69
+ this.stream = await this.client.stream(CoreIterator.ENDPOINT, RequestSchema,
70
+ // eslint-disable-next-line @typescript-eslint/ban-ts-comment
71
+ // @ts-ignore
72
+ ResponseSchema);
73
+ await this.execute({ command: Command.Open, keys, range: tr });
74
+ this.values = [];
75
+ }
76
+ /**
77
+ * Reads the next segment for each channel in the iterator.
78
+ *
79
+ * @returns false if the next segment can't be found for one or more channels or
80
+ * the iterator has accumulated an error.
81
+ */
82
+ async next() {
83
+ return this.execute({ command: Command.Next });
84
+ }
85
+ /**
86
+ * Reads the previous segment for each channel in the iterator.
87
+ *
88
+ * @returns false if the next segment can't be found for one or more channels or
89
+ * the iterator has accumulated an error.
90
+ */
91
+ async prev() {
92
+ return this.execute({ command: Command.Prev });
93
+ }
94
+ /**
95
+ * Seeks to the beginning of the time range and reads the first segment of each
96
+ * channel in the iterator.
97
+ *
98
+ * @returns false if no segments exists in the time range for a particular channel
99
+ * or the iterator has accumulated an error.
100
+ */
101
+ async first() {
102
+ return this.execute({ command: Command.First });
103
+ }
104
+ /**
105
+ * Seeks to the end of the time range and reads the last segment of each channel
106
+ * in the iterator.
107
+ *
108
+ * @returns false if no segments exists in the time range for a particular channel,
109
+ * or the iterator has accumulated an error.
110
+ */
111
+ async last() {
112
+ return this.execute({ command: Command.Last });
113
+ }
114
+ /**
115
+ * Reads the next time span of telemetry for each channel in the iterator.
116
+ *
117
+ * @returns false if a segment satisfying the request can't be found for a
118
+ * particular channel or the iterator has accumulated an error.
119
+ */
120
+ async nextSpan(span) {
121
+ return this.execute({ command: Command.NextSpan, span });
122
+ }
123
+ /**
124
+ * Reads the previous time span of telemetry for each channel in the iterator.
125
+ *
126
+ * @returns false if a segment satisfying the request can't be found for a particular
127
+ * channel or the iterator has accumulated an error.
128
+ */
129
+ async prevSpan(span) {
130
+ return this.execute({ command: Command.PrevSpan, span });
131
+ }
132
+ /**
133
+ * Seeks the iterator to the start of the time range and reads the telemetry within
134
+ * the range for each channel.
135
+ *
136
+ * @returns: False if a segment satisfying the request can't be found for a particular
137
+ * channel or the iterator has accumulated an error.
138
+ */
139
+ async nextRange(range) {
140
+ return this.execute({ command: Command.NextRange, range });
141
+ }
142
+ /**
143
+ * Seeks the iterator to the first segment in the time range, but does not read
144
+ * it. Also invalidates the iterator. The iterator will not be considered valid
145
+ * until a call to first, last, next, prev, prev_span, next_span, or next_range.
146
+ *
147
+ * @returns false if the iterator is not pointing to a valid segment for a particular
148
+ * channel or has accumulated an error.
149
+ */
150
+ async seekFirst() {
151
+ return this.execute({ command: Command.SeekFirst });
152
+ }
153
+ /** Seeks the iterator to the last segment in the time range, but does not read it.
154
+ * Also invalidates the iterator. The iterator will not be considered valid
155
+ * until a call to first, last, next, prev, prev_span, next_span, or next_range.
156
+ *
157
+ * @returns false if the iterator is not pointing to a valid segment for a particular
158
+ * channel or has accumulated an error.
159
+ */
160
+ async seekLast() {
161
+ return this.execute({ command: Command.SeekLast });
162
+ }
163
+ /**
164
+ * Seeks the iterator to the first segment whose start is less than or equal to
165
+ * the provided timestamp. Also invalidates the iterator. The iterator will not be
166
+ * considered valid until a call to first, last, next, prev, prev_span, next_span, or next_range.
167
+ *
168
+ * @returns false if the iterator is not pointing to a valid segment for a particular
169
+ * channel or has accumulated an error.
170
+ */
171
+ async seekLT(stamp) {
172
+ return this.execute({ command: Command.SeekLT, stamp });
173
+ }
174
+ /**
175
+ * Seeks the iterator to the first segment whose start is greater than or equal to
176
+ * the provided timestamp. Also invalidates the iterator. The iterator will not be
177
+ * considered valid until a call to first, last, next, prev, prev_span, next_span, or next_range.
178
+ *
179
+ * @returns false if the iterator is not pointing to a valid segment for a particular
180
+ * channel or has accumulated an error.
181
+ */
182
+ async seekGE(stamp) {
183
+ return this.execute({ command: Command.SeekGE, stamp });
184
+ }
185
+ /**
186
+ * @returns true if the iterator value contains a valid segment, and fale otherwise.
187
+ * valid most commonly returns false when the iterator is exhausted or has
188
+ * accumulated an error.
189
+ */
190
+ async valid() {
191
+ return this.execute({ command: Command.Valid });
192
+ }
193
+ /**
194
+ * Closes the iterator. An iterator MUST be closed after use, and this method
195
+ * should probably be placed in a 'finally' block. If the iterator is not closed,
196
+ * it may leak resources.
197
+ */
198
+ async close() {
199
+ if (!this.stream)
200
+ throw new Error('iterator.open() must be called before any other method');
201
+ this.stream.closeSend();
202
+ const [, exc] = await this.stream.receive();
203
+ if (!(exc instanceof EOF))
204
+ throw exc;
205
+ }
206
+ async execute(request) {
207
+ if (!this.stream)
208
+ throw new Error('iterator.open() must be called before any other method');
209
+ const err = this.stream.send(request);
210
+ if (err)
211
+ throw err;
212
+ if (!this.aggregate)
213
+ this.values = [];
214
+ for (;;) {
215
+ const [res, err] = await this.stream.receive();
216
+ if (err || !res)
217
+ throw err;
218
+ if (res.variant == ResponseVariant.Ack)
219
+ return res.ack;
220
+ if (res.segments)
221
+ this.values.push(...res.segments);
222
+ }
223
+ }
224
+ }
225
+ export class TypedIterator extends CoreIterator {
226
+ channels;
227
+ constructor(client, channels, aggregate = false) {
228
+ super(client, aggregate);
229
+ this.channels = channels;
230
+ }
231
+ async value() {
232
+ const result = {};
233
+ this.values.sort((a, b) => a.start.valueOf() - b.start.valueOf());
234
+ const keys = this.values.map((v) => v.channelKey);
235
+ const channels = await this.channels.getN(...keys);
236
+ this.values.forEach((v) => {
237
+ const sugared = new TypedSegment(channels.find((c) => c.key == v.channelKey), v);
238
+ if (v.channelKey in result) {
239
+ result[v.channelKey].extend(sugared);
240
+ }
241
+ else {
242
+ result[v.channelKey] = sugared;
243
+ }
244
+ });
245
+ return result;
246
+ }
247
+ }
248
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlcmF0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NlZ21lbnQvaXRlcmF0b3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLEdBQUcsRUFDSCxrQkFBa0IsR0FHbkIsTUFBTSx1QkFBdUIsQ0FBQztBQUMvQixPQUFPLEVBQUUsQ0FBQyxFQUFFLE1BQU0sS0FBSyxDQUFDO0FBSXhCLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFFckMsT0FBTyxFQUFrQixvQkFBb0IsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUNqRSxPQUFPLFlBQVksTUFBTSxTQUFTLENBQUM7QUFFbkMsSUFBSyxPQWVKO0FBZkQsV0FBSyxPQUFPO0lBQ1YscUNBQVEsQ0FBQTtJQUNSLHFDQUFRLENBQUE7SUFDUixxQ0FBUSxDQUFBO0lBQ1IsdUNBQVMsQ0FBQTtJQUNULHFDQUFRLENBQUE7SUFDUiw2Q0FBWSxDQUFBO0lBQ1osNkNBQVksQ0FBQTtJQUNaLCtDQUFhLENBQUE7SUFDYix1Q0FBUyxDQUFBO0lBQ1QsdUNBQVMsQ0FBQTtJQUNULGdEQUFjLENBQUE7SUFDZCw4Q0FBYSxDQUFBO0lBQ2IsMENBQVcsQ0FBQTtJQUNYLDBDQUFXLENBQUE7QUFDYixDQUFDLEVBZkksT0FBTyxLQUFQLE9BQU8sUUFlWDtBQUVELElBQUssZUFJSjtBQUpELFdBQUssZUFBZTtJQUNsQixxREFBUSxDQUFBO0lBQ1IsbURBQU8sQ0FBQTtJQUNQLHFEQUFRLENBQUE7QUFDVixDQUFDLEVBSkksZUFBZSxLQUFmLGVBQWUsUUFJbkI7QUFFRCxNQUFNLGFBQWEsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQzdCLE9BQU8sRUFBRSxDQUFDLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQztJQUM5QixJQUFJLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLFFBQVEsRUFBRTtJQUMzQixLQUFLLEVBQUUsQ0FB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
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,57 @@
1
+ import test from 'ava';
2
+ import Synnax from '../client';
3
+ import { DataType, Rate, TimeRange, TimeSpan } from '../telem';
4
+ import { randomTypedArray } from '../util/telem';
5
+ const client = new Synnax({ host: 'localhost', port: 8080 });
6
+ const newChannel = async () => {
7
+ return await client.channel.create({
8
+ name: 'test',
9
+ nodeId: 1,
10
+ rate: Rate.Hz(25),
11
+ dataType: DataType.Float64,
12
+ });
13
+ };
14
+ test('TypedIterator - basic iteration', async (t) => {
15
+ const ch = await newChannel();
16
+ const writer = await client.data.newWriter([ch.key]);
17
+ const data = randomTypedArray(25, ch.dataType);
18
+ try {
19
+ await writer.write(ch.key, TimeSpan.Second, data);
20
+ await writer.write(ch.key, TimeSpan.Seconds(2), data);
21
+ await writer.write(ch.key, TimeSpan.Seconds(3), data);
22
+ }
23
+ finally {
24
+ await writer.close();
25
+ }
26
+ const iterator = await client.data.newIterator(new TimeRange(TimeSpan.Zero, TimeSpan.Seconds(4)), [ch.key], false);
27
+ try {
28
+ t.true(await iterator.first());
29
+ t.true((await iterator.value())[ch.key].view.length === 25);
30
+ let c = 1;
31
+ while (await iterator.next()) {
32
+ c++;
33
+ t.true((await iterator.value())[ch.key].view.length === 25);
34
+ }
35
+ t.true(c === 3);
36
+ }
37
+ finally {
38
+ await iterator.close();
39
+ }
40
+ });
41
+ test('Client - basic read', async (t) => {
42
+ const ch = await newChannel();
43
+ const writer = await client.data.newWriter([ch.key]);
44
+ const data = randomTypedArray(25, ch.dataType);
45
+ try {
46
+ await writer.write(ch.key, TimeSpan.Second, data);
47
+ await writer.write(ch.key, TimeSpan.Seconds(2), data);
48
+ await writer.write(ch.key, TimeSpan.Seconds(3), data);
49
+ }
50
+ finally {
51
+ await writer.close();
52
+ }
53
+ const resData = await client.data.read(ch.key, TimeSpan.Zero, TimeSpan.Seconds(4));
54
+ resData.slice(0, 25).forEach((v, i) => t.true(v === data[i]));
55
+ t.true(resData.length === 75);
56
+ });
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaXRlcmF0b3Iuc3BlYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvc2VnbWVudC9pdGVyYXRvci5zcGVjLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sSUFBSSxNQUFNLEtBQUssQ0FBQztBQUV2QixPQUFPLE1BQU0sTUFBTSxXQUFXLENBQUM7QUFDL0IsT0FBTyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUMvRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsTUFBTSxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsRUFBRSxJQUFJLEVBQUUsV0FBVyxFQUFFLElBQUksRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDO0FBRTdELE1BQU0sVUFBVSxHQUFHLEtBQUssSUFBSSxFQUFFO0lBQzVCLE9BQU8sTUFBTSxNQUFNLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQztRQUNqQyxJQUFJLEVBQUUsTUFBTTtRQUNaLE1BQU0sRUFBRSxDQUFDO1FBQ1QsSUFBSSxFQUFFLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDO1FBQ2pCLFFBQVEsRUFBRSxRQUFRLENBQUMsT0FBTztLQUMzQixDQUFDLENBQUM7QUFDTCxDQUFDLENBQUM7QUFFRixJQUFJLENBQUMsaUNBQWlDLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxFQUFFO0lBQ2xELE1BQU0sRUFBRSxHQUFHLE1BQU0sVUFBVSxFQUFFLENBQUM7SUFDOUIsTUFBTSxNQUFNLEdBQUcsTUFBTSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3JELE1BQU0sSUFBSSxHQUFHLGdCQUFnQixDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDL0MsSUFBSTtRQUNGLE1BQU0sTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDbEQsTUFBTSxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN0RCxNQUFNLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO0tBQ3ZEO1lBQVM7UUFDUixNQUFNLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztLQUN0QjtJQUNELE1BQU0sUUFBUSxHQUFHLE1BQU0sTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQzVDLElBQUksU0FBUyxDQUFDLFFBQVEsQ0FBQyxJQUFJLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUNqRCxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFDUixLQUFLLENBQ04sQ0FBQztJQUNGLElBQUk7UUFDRixDQUFDLENBQUMsSUFBSSxDQUFDLE1BQU0sUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDL0IsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLE1BQU0sUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDLENBQUMsRUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLEtBQUssRUFBRSxDQUFDLENBQUM7UUFDNUQsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ1YsT0FBTyxNQUFNLFFBQVEsQ0FBQyxJQUFJLEVBQUUsRUFBRTtZQUM1QixDQUFDLEVBQUUsQ0FBQztZQUNKLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxNQUFNLFFBQVEsQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLEVBQUUsQ0FBQyxDQUFDO1NBQzdEO1FBQ0QsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7S0FDakI7WUFBUztRQUNSLE1BQU0sUUFBUSxDQUFDLEtBQUssRUFBRSxDQUFDO0tBQ3hCO0FBQ0gsQ0FBQyxDQUFDLENBQUM7QUFFSCxJQUFJLENBQUMscUJBQXFCLEVBQUUsS0FBSyxFQUFFLENBQUMsRUFBRSxFQUFFO0lBQ3RDLE1BQU0sRUFBRSxHQUFHLE1BQU0sVUFBVSxFQUFFLENBQUM7SUFDOUIsTUFBTSxNQUFNLEdBQUcsTUFBTSxNQUFNLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO0lBQ3JELE1BQU0sSUFBSSxHQUFHLGdCQUFnQixDQUFDLEVBQUUsRUFBRSxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDL0MsSUFBSTtRQUNGLE1BQU0sTUFBTSxDQUFDLEtBQUssQ0FBQyxFQUFFLENBQUMsR0FBRyxFQUFFLFFBQVEsQ0FBQyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUM7UUFDbEQsTUFBTSxNQUFNLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FBQyxHQUFHLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsRUFBRSxJQUFJLENBQUMsQ0FBQztRQUN0RCxNQUFNLE1BQU0sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEdBQUcsRUFBRSxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLElBQUksQ0FBQyxDQUFDO0tBQ3ZEO1lBQVM7UUFDUixNQUFNLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQztLQUN0QjtJQUNELE1BQU0sT0FBTyxHQUFHLE1BQU0sTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQ3BDLEVBQUUsQ0FBQyxHQUFHLEVBQ04sUUFBUSxDQUFDLElBQUksRUFDYixRQUFRLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxDQUNwQixDQUFDO0lBQ0YsT0FBTyxDQUFDLEtBQUssQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5RCxDQUFDLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEtBQUssRUFBRSxDQUFDLENBQUM7QUFDaEMsQ0FBQyxDQUFDLENBQUMifQ==
@@ -0,0 +1,16 @@
1
+ import { z } from 'zod';
2
+ import { TimeStamp } from '../telem';
3
+ export declare const SegmentPayloadSchema: z.ZodObject<{
4
+ channelKey: z.ZodString;
5
+ start: z.ZodEffects<z.ZodNumber, TimeStamp, number>;
6
+ data: z.ZodEffects<z.ZodString, Uint8Array, string>;
7
+ }, "strip", z.ZodTypeAny, {
8
+ data: Uint8Array;
9
+ channelKey: string;
10
+ start: TimeStamp;
11
+ }, {
12
+ data: string;
13
+ channelKey: string;
14
+ start: number;
15
+ }>;
16
+ export declare type SegmentPayload = z.infer<typeof SegmentPayloadSchema>;
@@ -0,0 +1,10 @@
1
+ import { z } from 'zod';
2
+ import { TimeStamp } from '../telem';
3
+ export const SegmentPayloadSchema = z.object({
4
+ channelKey: z.string(),
5
+ start: z.number().transform((n) => new TimeStamp(n)),
6
+ data: z.string().transform((s) => new Uint8Array(atob(s)
7
+ .split('')
8
+ .map((c) => c.charCodeAt(0)))),
9
+ });
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGF5bG9hZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvc2VnbWVudC9wYXlsb2FkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxDQUFDLEVBQUUsTUFBTSxLQUFLLENBQUM7QUFFeEIsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUVyQyxNQUFNLENBQUMsTUFBTSxvQkFBb0IsR0FBRyxDQUFDLENBQUMsTUFBTSxDQUFDO0lBQzNDLFVBQVUsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFO0lBQ3RCLEtBQUssRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxJQUFJLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUNwRCxJQUFJLEVBQUUsQ0FBQyxDQUFDLE1BQU0sRUFBRSxDQUFDLFNBQVMsQ0FDeEIsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUNKLElBQUksVUFBVSxDQUNaLElBQUksQ0FBQyxDQUFDLENBQUM7U0FDSixLQUFLLENBQUMsRUFBRSxDQUFDO1NBQ1QsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQy9CLENBQ0o7Q0FDRixDQUFDLENBQUMifQ==
@@ -0,0 +1,7 @@
1
+ import { Size } from '../telem';
2
+ import TypedSegment from './typed';
3
+ export default class Splitter {
4
+ threshold: Size;
5
+ constructor(threshold: Size);
6
+ split(segment: TypedSegment): TypedSegment[];
7
+ }
@@ -0,0 +1,26 @@
1
+ import { ValidationError } from '../errors';
2
+ import TypedSegment from './typed';
3
+ export default class Splitter {
4
+ threshold;
5
+ constructor(threshold) {
6
+ this.threshold = threshold;
7
+ }
8
+ split(segment) {
9
+ if (segment.size.smallerThan(this.threshold))
10
+ return [segment];
11
+ if (!segment.channel.density)
12
+ throw new ValidationError('Cannot split segment because channel density is undefined');
13
+ const splitPoint = this.threshold.valueOf() -
14
+ (this.threshold.valueOf() % segment.channel.density.valueOf());
15
+ const truncated = new TypedSegment(segment.channel, {
16
+ ...segment.payload,
17
+ data: segment.payload.data.slice(0, splitPoint),
18
+ });
19
+ const next = new TypedSegment(segment.channel, {
20
+ ...segment.payload,
21
+ data: segment.payload.data.slice(splitPoint),
22
+ });
23
+ return [truncated, ...this.split(next)];
24
+ }
25
+ }
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3BsaXR0ZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NlZ21lbnQvc3BsaXR0ZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUc1QyxPQUFPLFlBQVksTUFBTSxTQUFTLENBQUM7QUFFbkMsTUFBTSxDQUFDLE9BQU8sT0FBTyxRQUFRO0lBQzNCLFNBQVMsQ0FBTztJQUVoQixZQUFZLFNBQWU7UUFDekIsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7SUFDN0IsQ0FBQztJQUVELEtBQUssQ0FBQyxPQUFxQjtRQUN6QixJQUFJLE9BQU8sQ0FBQyxJQUFJLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7WUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDL0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsT0FBTztZQUMxQixNQUFNLElBQUksZUFBZSxDQUN2QiwyREFBMkQsQ0FDNUQsQ0FBQztRQUNKLE1BQU0sVUFBVSxHQUNkLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxFQUFFO1lBQ3hCLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxPQUFPLEVBQUUsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ2pFLE1BQU0sU0FBUyxHQUFHLElBQUksWUFBWSxDQUFDLE9BQU8sQ0FBQyxPQUFPLEVBQUU7WUFDbEQsR0FBRyxPQUFPLENBQUMsT0FBTztZQUNsQixJQUFJLEVBQUUsT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsRUFBRSxVQUFVLENBQUM7U0FDaEQsQ0FBQyxDQUFDO1FBQ0gsTUFBTSxJQUFJLEdBQUcsSUFBSSxZQUFZLENBQUMsT0FBTyxDQUFDLE9BQU8sRUFBRTtZQUM3QyxHQUFHLE9BQU8sQ0FBQyxPQUFPO1lBQ2xCLElBQUksRUFBRSxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDO1NBQzdDLENBQUMsQ0FBQztRQUNILE9BQU8sQ0FBQyxTQUFTLEVBQUUsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQztDQUNGIn0=
@@ -0,0 +1,15 @@
1
+ import { ChannelPayload } from '../channel/payload';
2
+ import { Size, TimeRange, TimeSpan, TimeStamp, TypedArray } from '../telem';
3
+ import { SegmentPayload } from './payload';
4
+ export default class TypedSegment {
5
+ payload: SegmentPayload;
6
+ channel: ChannelPayload;
7
+ view: TypedArray;
8
+ constructor(channel: ChannelPayload, payload: SegmentPayload);
9
+ get start(): TimeStamp;
10
+ get span(): TimeSpan;
11
+ get range(): TimeRange;
12
+ get end(): TimeStamp;
13
+ get size(): Size;
14
+ extend(other: TypedSegment): void;
15
+ }
@@ -0,0 +1,49 @@
1
+ import { ValidationError } from '../errors';
2
+ import { Size, } from '../telem';
3
+ export default class TypedSegment {
4
+ payload;
5
+ channel;
6
+ view;
7
+ constructor(channel, payload) {
8
+ this.channel = channel;
9
+ this.payload = payload;
10
+ this.view = new this.channel.dataType.arrayConstructor(this.payload.data.buffer);
11
+ }
12
+ get start() {
13
+ return this.payload.start;
14
+ }
15
+ get span() {
16
+ return this.channel.rate.byteSpan(this.view.byteLength, this.channel.density);
17
+ }
18
+ get range() {
19
+ return this.start.spanRange(this.span);
20
+ }
21
+ get end() {
22
+ return this.range.end;
23
+ }
24
+ get size() {
25
+ return Size.Bytes(this.view.byteLength);
26
+ }
27
+ extend(other) {
28
+ if (other.channel.key !== this.channel.key) {
29
+ throw new ValidationError(`
30
+ Cannot extend segment because channel keys mismatch.
31
+ Segment Channel Key: ${this.channel.key}
32
+ Other Segment Channel Key: ${other.channel.key}
33
+ `);
34
+ }
35
+ if (!this.end.equals(other.start)) {
36
+ throw new Error(`
37
+ Cannot extend segment because segments are not contiguous.
38
+ Segment End: ${this.end}
39
+ Other Segment Start: ${other.start}
40
+ `);
41
+ }
42
+ const newData = new Uint8Array(this.view.byteLength + other.view.byteLength);
43
+ newData.set(this.payload.data, 0);
44
+ newData.set(other.payload.data, this.view.byteLength);
45
+ this.payload.data = newData;
46
+ this.view = new this.channel.dataType.arrayConstructor(this.payload.data.buffer);
47
+ }
48
+ }
49
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3NlZ21lbnQvdHlwZWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFdBQVcsQ0FBQztBQUM1QyxPQUFPLEVBRUwsSUFBSSxHQUtMLE1BQU0sVUFBVSxDQUFDO0FBSWxCLE1BQU0sQ0FBQyxPQUFPLE9BQU8sWUFBWTtJQUMvQixPQUFPLENBQWlCO0lBQ3hCLE9BQU8sQ0FBaUI7SUFDeEIsSUFBSSxDQUFhO0lBRWpCLFlBQVksT0FBdUIsRUFBRSxPQUF1QjtRQUMxRCxJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQztRQUN2QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLENBQ3BELElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FDekIsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDO0lBQzVCLENBQUM7SUFFRCxJQUFJLElBQUk7UUFDTixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FDL0IsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLEVBQ3BCLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBa0IsQ0FDaEMsQ0FBQztJQUNKLENBQUM7SUFFRCxJQUFJLEtBQUs7UUFDUCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRUQsSUFBSSxHQUFHO1FBQ0wsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQztJQUN4QixDQUFDO0lBRUQsSUFBSSxJQUFJO1FBQ04sT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDMUMsQ0FBQztJQUVELE1BQU0sQ0FBQyxLQUFtQjtRQUN4QixJQUFJLEtBQUssQ0FBQyxPQUFPLENBQUMsR0FBRyxLQUFLLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFO1lBQzFDLE1BQU0sSUFBSSxlQUFlLENBQUM7OytCQUVELElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRztxQ0FDVixLQUFLLENBQUMsT0FBTyxDQUFDLEdBQUc7T0FDL0MsQ0FBQyxDQUFDO1NBQ0o7UUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ2pDLE1BQU0sSUFBSSxLQUFLLENBQUM7O3FCQUVELElBQUksQ0FBQyxHQUFHOzZCQUNBLEtBQUssQ0FBQyxLQUFLO09BQ2pDLENBQUMsQ0FBQztTQUNKO1FBQ0QsTUFBTSxPQUFPLEdBQUcsSUFBSSxVQUFVLENBQzVCLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxHQUFHLEtBQUssQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUM3QyxDQUFDO1FBQ0YsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNsQyxPQUFPLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLEdBQUcsT0FBTyxDQUFDO1FBQzVCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxnQkFBZ0IsQ0FDcEQsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUN6QixDQUFDO0lBQ0osQ0FBQztDQUNGIn0=
@@ -0,0 +1,22 @@
1
+ import { DataType, TimeStamp, TypedArray } from '../telem';
2
+ import TypedSegment from './typed';
3
+ export declare class ScalarTypeValidator {
4
+ validate(array: TypedArray, dataType: DataType): void;
5
+ }
6
+ export declare type ContiguityValidatorProps = {
7
+ allowNoHighWaterMark: boolean;
8
+ allowOverlap: boolean;
9
+ allowGaps: boolean;
10
+ };
11
+ export declare class ContiguityValidator {
12
+ highWaterMarks: Map<string, TimeStamp>;
13
+ allowNoHighWaterMark: boolean;
14
+ allowOverlap: boolean;
15
+ allowGaps: boolean;
16
+ constructor(props: ContiguityValidatorProps);
17
+ validate(segment: TypedSegment): void;
18
+ private enforceNoOverlap;
19
+ private enforceNoGaps;
20
+ private getHighWaterMark;
21
+ private updateHighWaterMark;
22
+ }
@@ -0,0 +1,60 @@
1
+ import { ContiguityError, UnexpectedError, ValidationError } from '../errors';
2
+ export class ScalarTypeValidator {
3
+ validate(array, dataType) {
4
+ if (!dataType.checkArray(array)) {
5
+ throw new ValidationError({
6
+ field: 'data',
7
+ message: `Data type mismatch. Expected ${dataType} but got ${array.constructor.name}`,
8
+ });
9
+ }
10
+ }
11
+ }
12
+ export class ContiguityValidator {
13
+ highWaterMarks;
14
+ allowNoHighWaterMark = false;
15
+ allowOverlap = false;
16
+ allowGaps = false;
17
+ constructor(props) {
18
+ this.highWaterMarks = new Map();
19
+ this.allowNoHighWaterMark = props.allowNoHighWaterMark;
20
+ this.allowOverlap = props.allowOverlap;
21
+ this.allowGaps = props.allowGaps;
22
+ }
23
+ validate(segment) {
24
+ if (!segment.channel.key) {
25
+ throw new UnexpectedError('Channel key is not set');
26
+ }
27
+ const hwm = this.getHighWaterMark(segment.channel.key);
28
+ if (hwm) {
29
+ this.enforceNoOverlap(hwm, segment);
30
+ this.enforceNoGaps(hwm, segment);
31
+ }
32
+ this.updateHighWaterMark(segment);
33
+ }
34
+ enforceNoOverlap(hwm, seg) {
35
+ if (!this.allowOverlap && seg.start.before(hwm)) {
36
+ throw new ContiguityError(`Segment overlaps with previous segment. Previous segment ends at ${hwm.toString()}
37
+ Segment starts at ${seg.start.toString()}`);
38
+ }
39
+ }
40
+ enforceNoGaps(hwm, seg) {
41
+ if (!this.allowGaps && !seg.start.equals(hwm)) {
42
+ throw new ContiguityError(`Segment is not contiguous with previous segment. Previous segment ends at ${hwm.toString()}
43
+ Segment starts at ${seg.start.toString()}`);
44
+ }
45
+ }
46
+ getHighWaterMark(key) {
47
+ const hwm = this.highWaterMarks.get(key);
48
+ if (!hwm && !this.allowNoHighWaterMark) {
49
+ throw new UnexpectedError('No high water mark found for channel key ' + key);
50
+ }
51
+ return hwm;
52
+ }
53
+ updateHighWaterMark(seg) {
54
+ if (!seg.channel.key) {
55
+ throw new UnexpectedError('Channel key is not set');
56
+ }
57
+ this.highWaterMarks.set(seg.channel.key, seg.end);
58
+ }
59
+ }
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdG9yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9zZWdtZW50L3ZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFLOUUsTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixRQUFRLENBQUMsS0FBaUIsRUFBRSxRQUFrQjtRQUM1QyxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUMvQixNQUFNLElBQUksZUFBZSxDQUFDO2dCQUN4QixLQUFLLEVBQUUsTUFBTTtnQkFDYixPQUFPLEVBQUUsZ0NBQWdDLFFBQVEsWUFBWSxLQUFLLENBQUMsV0FBVyxDQUFDLElBQUksRUFBRTthQUN0RixDQUFDLENBQUM7U0FDSjtJQUNILENBQUM7Q0FDRjtBQVFELE1BQU0sT0FBTyxtQkFBbUI7SUFDOUIsY0FBYyxDQUF5QjtJQUN2QyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7SUFDN0IsWUFBWSxHQUFHLEtBQUssQ0FBQztJQUNyQixTQUFTLEdBQUcsS0FBSyxDQUFDO0lBRWxCLFlBQVksS0FBK0I7UUFDekMsSUFBSSxDQUFDLGNBQWMsR0FBRyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ2hDLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUMsb0JBQW9CLENBQUM7UUFDdkQsSUFBSSxDQUFDLFlBQVksR0FBRyxLQUFLLENBQUMsWUFBWSxDQUFDO1FBQ3ZDLElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDLFNBQVMsQ0FBQztJQUNuQyxDQUFDO0lBRUQsUUFBUSxDQUFDLE9BQXFCO1FBQzVCLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRTtZQUN4QixNQUFNLElBQUksZUFBZSxDQUFDLHdCQUF3QixDQUFDLENBQUM7U0FDckQ7UUFDRCxNQUFNLEdBQUcsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQztRQUN2RCxJQUFJLEdBQUcsRUFBRTtZQUNQLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7WUFDcEMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7U0FDbEM7UUFDRCxJQUFJLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDcEMsQ0FBQztJQUVPLGdCQUFnQixDQUFDLEdBQWMsRUFBRSxHQUFpQjtRQUN4RCxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksSUFBSSxHQUFHLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsRUFBRTtZQUMvQyxNQUFNLElBQUksZUFBZSxDQUN2QixvRUFBb0UsR0FBRyxDQUFDLFFBQVEsRUFBRTs0QkFDOUQsR0FBRyxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUMzQyxDQUFDO1NBQ0g7SUFDSCxDQUFDO0lBRU8sYUFBYSxDQUFDLEdBQWMsRUFBRSxHQUFpQjtRQUNyRCxJQUFJLENBQUMsSUFBSSxDQUFDLFNBQVMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQzdDLE1BQU0sSUFBSSxlQUFlLENBQ3ZCLDZFQUE2RSxHQUFHLENBQUMsUUFBUSxFQUFFOzRCQUN2RSxHQUFHLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQzNDLENBQUM7U0FDSDtJQUNILENBQUM7SUFFTyxnQkFBZ0IsQ0FBQyxHQUFXO1FBQ2xDLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxHQUFHLElBQUksQ0FBQyxJQUFJLENBQUMsb0JBQW9CLEVBQUU7WUFDdEMsTUFBTSxJQUFJLGVBQWUsQ0FDdkIsMkNBQTJDLEdBQUcsR0FBRyxDQUNsRCxDQUFDO1NBQ0g7UUFDRCxPQUFPLEdBQUcsQ0FBQztJQUNiLENBQUM7SUFFTyxtQkFBbUIsQ0FBQyxHQUFpQjtRQUMzQyxJQUFJLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUU7WUFDcEIsTUFBTSxJQUFJLGVBQWUsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO1NBQ3JEO1FBQ0QsSUFBSSxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQ3BELENBQUM7Q0FDRiJ9
@@ -0,0 +1,98 @@
1
+ import { StreamClient } from '@synnaxlabs/freighter';
2
+ import ChannelRegistry from '../channel/registry';
3
+ import { TypedArray, UnparsedTimeStamp } from '../telem';
4
+ import { SegmentPayload } from './payload';
5
+ /**
6
+ * CoreWriter is used to write telemetry to a set of channels in time-order. It
7
+ * should not be instantiated directly, but rather through a {@link SegmentClient}.
8
+ *
9
+ * Using a writer is ideal when writing large volumes of data (such as recording
10
+ * telemetry from a sensor), but it is relatively complex and challenging to use.
11
+ * If you're looking to write a contiguous block of telemetry, see the {@link SegmentClient}
12
+ * write() method.
13
+ */
14
+ export declare class CoreWriter {
15
+ private static ENDPOINT;
16
+ private client;
17
+ private stream;
18
+ private keys;
19
+ constructor(client: StreamClient);
20
+ /**
21
+ * Opens the writer, acquiring an exclusive lock on the given channels for
22
+ * the duration of the writer's lifetime. open must be called before any other
23
+ * writer methods.
24
+ *
25
+ * @param keys - A list of keys representing the channels the writer will write
26
+ * to.
27
+ */
28
+ open(keys: string[]): Promise<void>;
29
+ /**
30
+ * Validates and writes the given segments to the database. The provided segments
31
+ * must:
32
+ *
33
+ * 1. Be in time order (on a per-channel basis)
34
+ * 2. Have channel keys in the set of keys this writer was opened with.
35
+ * 3. Have non-zero length data with the correct data type.
36
+ *
37
+ * @param segments - A list of segments to write to the database.
38
+ * @returns false if the writer has accumulated an error. In this case,
39
+ * the caller should stop executing requests and close the writer.
40
+ */
41
+ write(segments: SegmentPayload[]): Promise<boolean>;
42
+ /**
43
+ * Closes the writer, raising any accumulated error encountered during operation.
44
+ * A writer MUST be closed after use, and this method should probably be placed
45
+ * in a 'finally' block. If the writer is not closed, the database will not release
46
+ * the exclusive lock on the channels, preventing any other callers from
47
+ * writing to them. It also might leak resources and threads.
48
+ */
49
+ close(): Promise<void>;
50
+ private checkKeys;
51
+ }
52
+ /**
53
+ * TypedWriter is used to write telemetry to a set of channels in time-order. It
54
+ * should not be instantiated directly, but rather through a {@link SegmentClient}.
55
+ *
56
+ * Using a writer is ideal when writing large volumes of data (such as recording
57
+ * telemetry from a sensor), but it is relatively complex and challenging to use.
58
+ * If you're looking to write a contiguous block of telemetry, see the {@link SegmentClient}
59
+ * write() method.
60
+ */
61
+ export declare class TypedWriter {
62
+ private core;
63
+ private splitter;
64
+ private channels;
65
+ private scalarTypeValidator;
66
+ private contiguityValidator;
67
+ constructor(client: StreamClient, channels: ChannelRegistry);
68
+ /**
69
+ * Opens the writer, acquiring an exclusive lock on the given channels for
70
+ * the duration of the writer's lifetime. open must be called before any other
71
+ * writer methods.
72
+ *
73
+ * @param keys - A list of keys representing the channels the writer will write
74
+ * to.
75
+ */
76
+ open(keys: string[]): Promise<void>;
77
+ /**
78
+ * Writes the given telemetry to the database.
79
+ *
80
+ * @param to - They key of the channel to write to. This must be in the set of
81
+ * keys this writer was opened with.
82
+ * @param start - The start time of the telemetry. This must be equal to
83
+ * the end of the previous segment written to the channel (unless it's the first
84
+ * write to that channel).
85
+ * @param data - The telemetry to write. This must be a valid type for the channel.
86
+ * @returns false if the writer has accumulated an error. In this case,
87
+ * the caller should stop executing requests and close the writer.
88
+ */
89
+ write(to: string, start: UnparsedTimeStamp, data: TypedArray): Promise<boolean>;
90
+ /**
91
+ * Closes the writer, raising any accumulated error encountered during operation.
92
+ * A writer MUST be closed after use, and this method should probably be placed
93
+ * in a 'finally' block. If the writer is not closed, the database will not release
94
+ * the exclusive lock on the channels, preventing any other callers from
95
+ * writing to them. It also might leak resources and threads.
96
+ */
97
+ close(): Promise<void>;
98
+ }