@welshman/net 0.0.22 → 0.0.24

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.
@@ -0,0 +1,516 @@
1
+ "use strict";
2
+ // (C) 2023 Doug Hoyte. MIT license
3
+ // @ts-nocheck
4
+ Object.defineProperty(exports, "__esModule", { value: true });
5
+ exports.NegentropyStorageVector = exports.Negentropy = void 0;
6
+ const PROTOCOL_VERSION = 0x61; // Version 1
7
+ const ID_SIZE = 32;
8
+ const FINGERPRINT_SIZE = 16;
9
+ const Mode = {
10
+ Skip: 0,
11
+ Fingerprint: 1,
12
+ IdList: 2,
13
+ };
14
+ class WrappedBuffer {
15
+ constructor(buffer) {
16
+ this._raw = new Uint8Array(buffer || 512);
17
+ this.length = buffer ? buffer.length : 0;
18
+ }
19
+ unwrap() {
20
+ return this._raw.subarray(0, this.length);
21
+ }
22
+ get capacity() {
23
+ return this._raw.byteLength;
24
+ }
25
+ extend(buf) {
26
+ if (buf._raw)
27
+ buf = buf.unwrap();
28
+ if (typeof (buf.length) !== 'number')
29
+ throw Error("bad length");
30
+ const targetSize = buf.length + this.length;
31
+ if (this.capacity < targetSize) {
32
+ const oldRaw = this._raw;
33
+ const newCapacity = Math.max(this.capacity * 2, targetSize);
34
+ this._raw = new Uint8Array(newCapacity);
35
+ this._raw.set(oldRaw);
36
+ }
37
+ this._raw.set(buf, this.length);
38
+ this.length += buf.length;
39
+ }
40
+ shift() {
41
+ const first = this._raw[0];
42
+ this._raw = this._raw.subarray(1);
43
+ this.length--;
44
+ return first;
45
+ }
46
+ shiftN(n = 1) {
47
+ const firstSubarray = this._raw.subarray(0, n);
48
+ this._raw = this._raw.subarray(n);
49
+ this.length -= n;
50
+ return firstSubarray;
51
+ }
52
+ }
53
+ function decodeVarInt(buf) {
54
+ let res = 0;
55
+ while (1) {
56
+ if (buf.length === 0)
57
+ throw Error("parse ends prematurely");
58
+ const byte = buf.shift();
59
+ res = (res << 7) | (byte & 127);
60
+ if ((byte & 128) === 0)
61
+ break;
62
+ }
63
+ return res;
64
+ }
65
+ function encodeVarInt(n) {
66
+ if (n === 0)
67
+ return new WrappedBuffer([0]);
68
+ const o = [];
69
+ while (n !== 0) {
70
+ o.push(n & 127);
71
+ n >>>= 7;
72
+ }
73
+ o.reverse();
74
+ for (let i = 0; i < o.length - 1; i++)
75
+ o[i] |= 128;
76
+ return new WrappedBuffer(o);
77
+ }
78
+ function getByte(buf) {
79
+ return getBytes(buf, 1)[0];
80
+ }
81
+ function getBytes(buf, n) {
82
+ if (buf.length < n)
83
+ throw Error("parse ends prematurely");
84
+ return buf.shiftN(n);
85
+ }
86
+ class Accumulator {
87
+ constructor() {
88
+ this.setToZero();
89
+ if (typeof window === 'undefined') { // node.js
90
+ const crypto = require('crypto');
91
+ this.sha256 = async (slice) => new Uint8Array(crypto.createHash('sha256').update(slice).digest());
92
+ }
93
+ else { // browser
94
+ this.sha256 = async (slice) => new Uint8Array(await crypto.subtle.digest("SHA-256", slice));
95
+ }
96
+ }
97
+ setToZero() {
98
+ this.buf = new Uint8Array(ID_SIZE);
99
+ }
100
+ add(otherBuf) {
101
+ let currCarry = 0, nextCarry = 0;
102
+ const p = new DataView(this.buf.buffer);
103
+ const po = new DataView(otherBuf.buffer);
104
+ for (let i = 0; i < 8; i++) {
105
+ const offset = i * 4;
106
+ const orig = p.getUint32(offset, true);
107
+ const otherV = po.getUint32(offset, true);
108
+ let next = orig;
109
+ next += currCarry;
110
+ next += otherV;
111
+ if (next > 0xFFFFFFFF)
112
+ nextCarry = 1;
113
+ p.setUint32(offset, next & 0xFFFFFFFF, true);
114
+ currCarry = nextCarry;
115
+ nextCarry = 0;
116
+ }
117
+ }
118
+ negate() {
119
+ const p = new DataView(this.buf.buffer);
120
+ for (let i = 0; i < 8; i++) {
121
+ const offset = i * 4;
122
+ p.setUint32(offset, ~p.getUint32(offset, true));
123
+ }
124
+ const one = new Uint8Array(ID_SIZE);
125
+ one[0] = 1;
126
+ this.add(one);
127
+ }
128
+ async getFingerprint(n) {
129
+ const input = new WrappedBuffer();
130
+ input.extend(this.buf);
131
+ input.extend(encodeVarInt(n));
132
+ const hash = await this.sha256(input.unwrap());
133
+ return hash.subarray(0, FINGERPRINT_SIZE);
134
+ }
135
+ }
136
+ class NegentropyStorageVector {
137
+ constructor() {
138
+ this.items = [];
139
+ this.sealed = false;
140
+ }
141
+ insert(timestamp, id) {
142
+ if (this.sealed)
143
+ throw Error("already sealed");
144
+ id = loadInputBuffer(id);
145
+ if (id.byteLength !== ID_SIZE)
146
+ throw Error("bad id size for added item");
147
+ this.items.push({ timestamp, id });
148
+ }
149
+ seal() {
150
+ if (this.sealed)
151
+ throw Error("already sealed");
152
+ this.sealed = true;
153
+ this.items.sort(itemCompare);
154
+ for (let i = 1; i < this.items.length; i++) {
155
+ if (itemCompare(this.items[i - 1], this.items[i]) === 0)
156
+ throw Error("duplicate item inserted");
157
+ }
158
+ }
159
+ unseal() {
160
+ this.sealed = false;
161
+ }
162
+ size() {
163
+ this._checkSealed();
164
+ return this.items.length;
165
+ }
166
+ getItem(i) {
167
+ this._checkSealed();
168
+ if (i >= this.items.length)
169
+ throw Error("out of range");
170
+ return this.items[i];
171
+ }
172
+ iterate(begin, end, cb) {
173
+ this._checkSealed();
174
+ this._checkBounds(begin, end);
175
+ for (let i = begin; i < end; ++i) {
176
+ if (!cb(this.items[i], i))
177
+ break;
178
+ }
179
+ }
180
+ findLowerBound(begin, end, bound) {
181
+ this._checkSealed();
182
+ this._checkBounds(begin, end);
183
+ return this._binarySearch(this.items, begin, end, (a) => itemCompare(a, bound) < 0);
184
+ }
185
+ async fingerprint(begin, end) {
186
+ const out = new Accumulator();
187
+ out.setToZero();
188
+ this.iterate(begin, end, (item, i) => {
189
+ out.add(item.id);
190
+ return true;
191
+ });
192
+ return await out.getFingerprint(end - begin);
193
+ }
194
+ _checkSealed() {
195
+ if (!this.sealed)
196
+ throw Error("not sealed");
197
+ }
198
+ _checkBounds(begin, end) {
199
+ if (begin > end || end > this.items.length)
200
+ throw Error("bad range");
201
+ }
202
+ _binarySearch(arr, first, last, cmp) {
203
+ let count = last - first;
204
+ while (count > 0) {
205
+ let it = first;
206
+ const step = Math.floor(count / 2);
207
+ it += step;
208
+ if (cmp(arr[it])) {
209
+ first = ++it;
210
+ count -= step + 1;
211
+ }
212
+ else {
213
+ count = step;
214
+ }
215
+ }
216
+ return first;
217
+ }
218
+ }
219
+ exports.NegentropyStorageVector = NegentropyStorageVector;
220
+ class Negentropy {
221
+ constructor(storage, frameSizeLimit = 0) {
222
+ if (frameSizeLimit !== 0 && frameSizeLimit < 4096)
223
+ throw Error("frameSizeLimit too small");
224
+ this.storage = storage;
225
+ this.frameSizeLimit = frameSizeLimit;
226
+ this.lastTimestampIn = 0;
227
+ this.lastTimestampOut = 0;
228
+ }
229
+ _bound(timestamp, id) {
230
+ return { timestamp, id: id ? id : new Uint8Array(0) };
231
+ }
232
+ async initiate() {
233
+ if (this.isInitiator)
234
+ throw Error("already initiated");
235
+ this.isInitiator = true;
236
+ const output = new WrappedBuffer();
237
+ output.extend([PROTOCOL_VERSION]);
238
+ await this.splitRange(0, this.storage.size(), this._bound(Number.MAX_VALUE), output);
239
+ return this._renderOutput(output);
240
+ }
241
+ setInitiator() {
242
+ this.isInitiator = true;
243
+ }
244
+ async reconcile(query) {
245
+ const haveIds = [], needIds = [];
246
+ query = new WrappedBuffer(loadInputBuffer(query));
247
+ this.lastTimestampIn = this.lastTimestampOut = 0; // reset for each message
248
+ const fullOutput = new WrappedBuffer();
249
+ fullOutput.extend([PROTOCOL_VERSION]);
250
+ const protocolVersion = getByte(query);
251
+ if (protocolVersion < 0x60 || protocolVersion > 0x6F)
252
+ throw Error("invalid negentropy protocol version byte");
253
+ if (protocolVersion !== PROTOCOL_VERSION) {
254
+ if (this.isInitiator)
255
+ throw Error("unsupported negentropy protocol version requested: " + (protocolVersion - 0x60));
256
+ else
257
+ return [this._renderOutput(fullOutput), haveIds, needIds];
258
+ }
259
+ const storageSize = this.storage.size();
260
+ let prevBound = this._bound(0);
261
+ let prevIndex = 0;
262
+ let skip = false;
263
+ while (query.length !== 0) {
264
+ let o = new WrappedBuffer();
265
+ const doSkip = () => {
266
+ if (skip) {
267
+ skip = false;
268
+ o.extend(this.encodeBound(prevBound));
269
+ o.extend(encodeVarInt(Mode.Skip));
270
+ }
271
+ };
272
+ const currBound = this.decodeBound(query);
273
+ const mode = decodeVarInt(query);
274
+ const lower = prevIndex;
275
+ let upper = this.storage.findLowerBound(prevIndex, storageSize, currBound);
276
+ if (mode === Mode.Skip) {
277
+ skip = true;
278
+ }
279
+ else if (mode === Mode.Fingerprint) {
280
+ const theirFingerprint = getBytes(query, FINGERPRINT_SIZE);
281
+ const ourFingerprint = await this.storage.fingerprint(lower, upper);
282
+ if (compareUint8Array(theirFingerprint, ourFingerprint) !== 0) {
283
+ doSkip();
284
+ await this.splitRange(lower, upper, currBound, o);
285
+ }
286
+ else {
287
+ skip = true;
288
+ }
289
+ }
290
+ else if (mode === Mode.IdList) {
291
+ const numIds = decodeVarInt(query);
292
+ const theirElems = {}; // stringified Uint8Array -> original Uint8Array (or hex)
293
+ for (let i = 0; i < numIds; i++) {
294
+ const e = getBytes(query, ID_SIZE);
295
+ if (this.isInitiator)
296
+ theirElems[e] = e;
297
+ }
298
+ if (this.isInitiator) {
299
+ skip = true;
300
+ this.storage.iterate(lower, upper, (item) => {
301
+ const k = item.id;
302
+ if (!theirElems[k]) {
303
+ // ID exists on our side, but not their side
304
+ if (this.isInitiator)
305
+ haveIds.push(this.wantUint8ArrayOutput ? k : uint8ArrayToHex(k));
306
+ }
307
+ else {
308
+ // ID exists on both sides
309
+ delete theirElems[k];
310
+ }
311
+ return true;
312
+ });
313
+ for (const v of Object.values(theirElems)) {
314
+ // ID exists on their side, but not our side
315
+ needIds.push(this.wantUint8ArrayOutput ? v : uint8ArrayToHex(v));
316
+ }
317
+ }
318
+ else {
319
+ doSkip();
320
+ const responseIds = new WrappedBuffer();
321
+ let numResponseIds = 0;
322
+ let endBound = currBound;
323
+ this.storage.iterate(lower, upper, (item, index) => {
324
+ if (this.exceededFrameSizeLimit(fullOutput.length + responseIds.length)) {
325
+ endBound = item;
326
+ upper = index; // shrink upper so that remaining range gets correct fingerprint
327
+ return false;
328
+ }
329
+ responseIds.extend(item.id);
330
+ numResponseIds++;
331
+ return true;
332
+ });
333
+ o.extend(this.encodeBound(endBound));
334
+ o.extend(encodeVarInt(Mode.IdList));
335
+ o.extend(encodeVarInt(numResponseIds));
336
+ o.extend(responseIds);
337
+ fullOutput.extend(o);
338
+ o = new WrappedBuffer();
339
+ }
340
+ }
341
+ else {
342
+ throw Error("unexpected mode");
343
+ }
344
+ if (this.exceededFrameSizeLimit(fullOutput.length + o.length)) {
345
+ // frameSizeLimit exceeded: Stop range processing and return a fingerprint for the remaining range
346
+ const remainingFingerprint = await this.storage.fingerprint(upper, storageSize);
347
+ fullOutput.extend(this.encodeBound(this._bound(Number.MAX_VALUE)));
348
+ fullOutput.extend(encodeVarInt(Mode.Fingerprint));
349
+ fullOutput.extend(remainingFingerprint);
350
+ break;
351
+ }
352
+ else {
353
+ fullOutput.extend(o);
354
+ }
355
+ prevIndex = upper;
356
+ prevBound = currBound;
357
+ }
358
+ return [fullOutput.length === 1 && this.isInitiator ? null : this._renderOutput(fullOutput), haveIds, needIds];
359
+ }
360
+ async splitRange(lower, upper, upperBound, o) {
361
+ const numElems = upper - lower;
362
+ const buckets = 16;
363
+ if (numElems < buckets * 2) {
364
+ o.extend(this.encodeBound(upperBound));
365
+ o.extend(encodeVarInt(Mode.IdList));
366
+ o.extend(encodeVarInt(numElems));
367
+ this.storage.iterate(lower, upper, (item) => {
368
+ o.extend(item.id);
369
+ return true;
370
+ });
371
+ }
372
+ else {
373
+ const itemsPerBucket = Math.floor(numElems / buckets);
374
+ const bucketsWithExtra = numElems % buckets;
375
+ let curr = lower;
376
+ for (let i = 0; i < buckets; i++) {
377
+ const bucketSize = itemsPerBucket + (i < bucketsWithExtra ? 1 : 0);
378
+ const ourFingerprint = await this.storage.fingerprint(curr, curr + bucketSize);
379
+ curr += bucketSize;
380
+ let nextBound;
381
+ if (curr === upper) {
382
+ nextBound = upperBound;
383
+ }
384
+ else {
385
+ let prevItem, currItem;
386
+ this.storage.iterate(curr - 1, curr + 1, (item, index) => {
387
+ if (index === curr - 1)
388
+ prevItem = item;
389
+ else
390
+ currItem = item;
391
+ return true;
392
+ });
393
+ nextBound = this.getMinimalBound(prevItem, currItem);
394
+ }
395
+ o.extend(this.encodeBound(nextBound));
396
+ o.extend(encodeVarInt(Mode.Fingerprint));
397
+ o.extend(ourFingerprint);
398
+ }
399
+ }
400
+ }
401
+ _renderOutput(o) {
402
+ o = o.unwrap();
403
+ if (!this.wantUint8ArrayOutput)
404
+ o = uint8ArrayToHex(o);
405
+ return o;
406
+ }
407
+ exceededFrameSizeLimit(n) {
408
+ return this.frameSizeLimit && n > this.frameSizeLimit - 200;
409
+ }
410
+ // Decoding
411
+ decodeTimestampIn(encoded) {
412
+ let timestamp = decodeVarInt(encoded);
413
+ timestamp = timestamp === 0 ? Number.MAX_VALUE : timestamp - 1;
414
+ if (this.lastTimestampIn === Number.MAX_VALUE || timestamp === Number.MAX_VALUE) {
415
+ this.lastTimestampIn = Number.MAX_VALUE;
416
+ return Number.MAX_VALUE;
417
+ }
418
+ timestamp += this.lastTimestampIn;
419
+ this.lastTimestampIn = timestamp;
420
+ return timestamp;
421
+ }
422
+ decodeBound(encoded) {
423
+ const timestamp = this.decodeTimestampIn(encoded);
424
+ const len = decodeVarInt(encoded);
425
+ if (len > ID_SIZE)
426
+ throw Error("bound key too long");
427
+ const id = getBytes(encoded, len);
428
+ return { timestamp, id };
429
+ }
430
+ // Encoding
431
+ encodeTimestampOut(timestamp) {
432
+ if (timestamp === Number.MAX_VALUE) {
433
+ this.lastTimestampOut = Number.MAX_VALUE;
434
+ return encodeVarInt(0);
435
+ }
436
+ const temp = timestamp;
437
+ timestamp -= this.lastTimestampOut;
438
+ this.lastTimestampOut = temp;
439
+ return encodeVarInt(timestamp + 1);
440
+ }
441
+ encodeBound(key) {
442
+ const output = new WrappedBuffer();
443
+ output.extend(this.encodeTimestampOut(key.timestamp));
444
+ output.extend(encodeVarInt(key.id.length));
445
+ output.extend(key.id);
446
+ return output;
447
+ }
448
+ getMinimalBound(prev, curr) {
449
+ if (curr.timestamp !== prev.timestamp) {
450
+ return this._bound(curr.timestamp);
451
+ }
452
+ else {
453
+ let sharedPrefixBytes = 0;
454
+ const currKey = curr.id;
455
+ const prevKey = prev.id;
456
+ for (let i = 0; i < ID_SIZE; i++) {
457
+ if (currKey[i] !== prevKey[i])
458
+ break;
459
+ sharedPrefixBytes++;
460
+ }
461
+ return this._bound(curr.timestamp, curr.id.subarray(0, sharedPrefixBytes + 1));
462
+ }
463
+ }
464
+ }
465
+ exports.Negentropy = Negentropy;
466
+ function loadInputBuffer(inp) {
467
+ if (typeof (inp) === 'string')
468
+ inp = hexToUint8Array(inp);
469
+ else if (__proto__ !== Uint8Array.prototype)
470
+ inp = new Uint8Array(inp); // node Buffer?
471
+ return inp;
472
+ }
473
+ function hexToUint8Array(h) {
474
+ if (h.startsWith('0x'))
475
+ h = h.substr(2);
476
+ if (h.length % 2 === 1)
477
+ throw Error("odd length of hex string");
478
+ const arr = new Uint8Array(h.length / 2);
479
+ for (let i = 0; i < arr.length; i++)
480
+ arr[i] = parseInt(h.substr(i * 2, 2), 16);
481
+ return arr;
482
+ }
483
+ const uint8ArrayToHexLookupTable = new Array(256);
484
+ {
485
+ const hexAlphabet = ['0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f'];
486
+ for (let i = 0; i < 256; i++) {
487
+ uint8ArrayToHexLookupTable[i] = hexAlphabet[(i >>> 4) & 0xF] + hexAlphabet[i & 0xF];
488
+ }
489
+ }
490
+ function uint8ArrayToHex(arr) {
491
+ let out = '';
492
+ for (let i = 0, edx = arr.length; i < edx; i++) {
493
+ out += uint8ArrayToHexLookupTable[arr[i]];
494
+ }
495
+ return out;
496
+ }
497
+ function compareUint8Array(a, b) {
498
+ for (let i = 0; i < a.byteLength; i++) {
499
+ if (a[i] < b[i])
500
+ return -1;
501
+ if (a[i] > b[i])
502
+ return 1;
503
+ }
504
+ if (a.byteLength > b.byteLength)
505
+ return 1;
506
+ if (a.byteLength < b.byteLength)
507
+ return -1;
508
+ return 0;
509
+ }
510
+ function itemCompare(a, b) {
511
+ if (a.timestamp === b.timestamp) {
512
+ return compareUint8Array(a.id, b.id);
513
+ }
514
+ return a.timestamp - b.timestamp;
515
+ }
516
+ //# sourceMappingURL=Negentropy.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Negentropy.cjs","sourceRoot":"","sources":["../../src/Negentropy.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,47 @@
1
+ declare class WrappedBuffer {
2
+ constructor(buffer: any);
3
+ unwrap(): any;
4
+ get capacity(): any;
5
+ extend(buf: any): void;
6
+ shift(): any;
7
+ shiftN(n?: number): any;
8
+ }
9
+ declare class NegentropyStorageVector {
10
+ constructor();
11
+ insert(timestamp: any, id: any): void;
12
+ seal(): void;
13
+ unseal(): void;
14
+ size(): any;
15
+ getItem(i: any): any;
16
+ iterate(begin: any, end: any, cb: any): void;
17
+ findLowerBound(begin: any, end: any, bound: any): any;
18
+ fingerprint(begin: any, end: any): Promise<any>;
19
+ _checkSealed(): void;
20
+ _checkBounds(begin: any, end: any): void;
21
+ _binarySearch(arr: any, first: any, last: any, cmp: any): any;
22
+ }
23
+ declare class Negentropy {
24
+ constructor(storage: any, frameSizeLimit?: number);
25
+ _bound(timestamp: any, id: any): {
26
+ timestamp: any;
27
+ id: any;
28
+ };
29
+ initiate(): Promise<any>;
30
+ setInitiator(): void;
31
+ reconcile(query: any): Promise<any[]>;
32
+ splitRange(lower: any, upper: any, upperBound: any, o: any): Promise<void>;
33
+ _renderOutput(o: any): any;
34
+ exceededFrameSizeLimit(n: any): any;
35
+ decodeTimestampIn(encoded: any): number;
36
+ decodeBound(encoded: any): {
37
+ timestamp: number;
38
+ id: any;
39
+ };
40
+ encodeTimestampOut(timestamp: any): WrappedBuffer;
41
+ encodeBound(key: any): WrappedBuffer;
42
+ getMinimalBound(prev: any, curr: any): {
43
+ timestamp: any;
44
+ id: any;
45
+ };
46
+ }
47
+ export { Negentropy, NegentropyStorageVector, };