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