@peerbit/shared-log 9.2.13 → 10.0.0-05f4bef
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/benchmark/get-samples.js +190 -64
- package/dist/benchmark/get-samples.js.map +1 -1
- package/dist/benchmark/index.js +16 -38
- package/dist/benchmark/index.js.map +1 -1
- package/dist/benchmark/memory/child.js.map +1 -1
- package/dist/benchmark/partial-sync.d.ts +3 -0
- package/dist/benchmark/partial-sync.d.ts.map +1 -0
- package/dist/benchmark/partial-sync.js +121 -0
- package/dist/benchmark/partial-sync.js.map +1 -0
- package/dist/benchmark/replication-prune.js.map +1 -1
- package/dist/benchmark/replication.js.map +1 -1
- package/dist/benchmark/to-rebalance.d.ts +2 -0
- package/dist/benchmark/to-rebalance.d.ts.map +1 -0
- package/dist/benchmark/to-rebalance.js +117 -0
- package/dist/benchmark/to-rebalance.js.map +1 -0
- package/dist/benchmark/utils.d.ts +24 -0
- package/dist/benchmark/utils.d.ts.map +1 -0
- package/dist/benchmark/utils.js +47 -0
- package/dist/benchmark/utils.js.map +1 -0
- package/dist/src/debounce.d.ts +2 -2
- package/dist/src/debounce.d.ts.map +1 -1
- package/dist/src/debounce.js +17 -47
- package/dist/src/debounce.js.map +1 -1
- package/dist/src/exchange-heads.d.ts +1 -13
- package/dist/src/exchange-heads.d.ts.map +1 -1
- package/dist/src/exchange-heads.js +0 -32
- package/dist/src/exchange-heads.js.map +1 -1
- package/dist/src/index.d.ts +119 -60
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1116 -762
- package/dist/src/index.js.map +1 -1
- package/dist/src/integers.d.ts +22 -0
- package/dist/src/integers.d.ts.map +1 -0
- package/dist/src/integers.js +76 -0
- package/dist/src/integers.js.map +1 -0
- package/dist/src/pid.d.ts.map +1 -1
- package/dist/src/pid.js +22 -22
- package/dist/src/pid.js.map +1 -1
- package/dist/src/ranges.d.ts +168 -38
- package/dist/src/ranges.d.ts.map +1 -1
- package/dist/src/ranges.js +869 -272
- package/dist/src/ranges.js.map +1 -1
- package/dist/src/replication-domain-hash.d.ts +2 -3
- package/dist/src/replication-domain-hash.d.ts.map +1 -1
- package/dist/src/replication-domain-hash.js +40 -15
- package/dist/src/replication-domain-hash.js.map +1 -1
- package/dist/src/replication-domain-time.d.ts +5 -5
- package/dist/src/replication-domain-time.d.ts.map +1 -1
- package/dist/src/replication-domain-time.js +2 -0
- package/dist/src/replication-domain-time.js.map +1 -1
- package/dist/src/replication-domain.d.ts +17 -19
- package/dist/src/replication-domain.d.ts.map +1 -1
- package/dist/src/replication-domain.js +2 -6
- package/dist/src/replication-domain.js.map +1 -1
- package/dist/src/replication.d.ts +6 -6
- package/dist/src/replication.d.ts.map +1 -1
- package/dist/src/replication.js +4 -4
- package/dist/src/replication.js.map +1 -1
- package/dist/src/role.d.ts +3 -6
- package/dist/src/role.d.ts.map +1 -1
- package/dist/src/role.js +4 -5
- package/dist/src/role.js.map +1 -1
- package/dist/src/sync/index.d.ts +40 -0
- package/dist/src/sync/index.d.ts.map +1 -0
- package/dist/src/sync/index.js +2 -0
- package/dist/src/sync/index.js.map +1 -0
- package/dist/src/sync/rateless-iblt.d.ts +124 -0
- package/dist/src/sync/rateless-iblt.d.ts.map +1 -0
- package/dist/src/sync/rateless-iblt.js +495 -0
- package/dist/src/sync/rateless-iblt.js.map +1 -0
- package/dist/src/sync/simple.d.ts +69 -0
- package/dist/src/sync/simple.d.ts.map +1 -0
- package/dist/src/sync/simple.js +338 -0
- package/dist/src/sync/simple.js.map +1 -0
- package/dist/src/sync/wasm-init.browser.d.ts +1 -0
- package/dist/src/sync/wasm-init.browser.d.ts.map +1 -0
- package/dist/src/sync/wasm-init.browser.js +3 -0
- package/dist/src/sync/wasm-init.browser.js.map +1 -0
- package/dist/src/sync/wasm-init.d.ts +2 -0
- package/dist/src/sync/wasm-init.d.ts.map +1 -0
- package/dist/src/sync/wasm-init.js +13 -0
- package/dist/src/sync/wasm-init.js.map +1 -0
- package/dist/src/utils.d.ts +3 -3
- package/dist/src/utils.d.ts.map +1 -1
- package/dist/src/utils.js +2 -2
- package/dist/src/utils.js.map +1 -1
- package/package.json +73 -69
- package/src/debounce.ts +16 -51
- package/src/exchange-heads.ts +1 -23
- package/src/index.ts +1532 -1038
- package/src/integers.ts +102 -0
- package/src/pid.ts +23 -22
- package/src/ranges.ts +1204 -413
- package/src/replication-domain-hash.ts +43 -18
- package/src/replication-domain-time.ts +9 -9
- package/src/replication-domain.ts +21 -31
- package/src/replication.ts +10 -9
- package/src/role.ts +4 -6
- package/src/sync/index.ts +51 -0
- package/src/sync/rateless-iblt.ts +617 -0
- package/src/sync/simple.ts +403 -0
- package/src/sync/wasm-init.browser.ts +1 -0
- package/src/sync/wasm-init.ts +14 -0
- package/src/utils.ts +10 -4
package/dist/src/role.js
CHANGED
|
@@ -14,9 +14,7 @@ var NoType_1, Observer_1, Replicator_1;
|
|
|
14
14
|
* Roles have been replaces with just replication segments.
|
|
15
15
|
*/
|
|
16
16
|
import { field, variant, vec } from "@dao-xyz/borsh";
|
|
17
|
-
|
|
18
|
-
export const HALF_MAX_U32 = 2147483647; // rounded down
|
|
19
|
-
export const scaleToU32 = (value) => Math.round(MAX_U32 * value);
|
|
17
|
+
import { MAX_U32, denormalizer } from "./integers.js";
|
|
20
18
|
export const overlaps = (x1, x2, y1, y2) => {
|
|
21
19
|
if (x1 <= y2 && y1 <= x2) {
|
|
22
20
|
return true;
|
|
@@ -46,6 +44,7 @@ Observer = Observer_1 = __decorate([
|
|
|
46
44
|
], Observer);
|
|
47
45
|
export { Observer };
|
|
48
46
|
export const REPLICATOR_TYPE_VARIANT = new Uint8Array([2]);
|
|
47
|
+
const denormalizeru32 = denormalizer("u32");
|
|
49
48
|
export class RoleReplicationSegment {
|
|
50
49
|
timestamp;
|
|
51
50
|
factorNominator;
|
|
@@ -56,11 +55,11 @@ export class RoleReplicationSegment {
|
|
|
56
55
|
throw new Error("Expecting factor to be between 0 and 1, got: " + factor);
|
|
57
56
|
}
|
|
58
57
|
this.timestamp = timestamp ?? BigInt(+new Date());
|
|
59
|
-
this.factorNominator =
|
|
58
|
+
this.factorNominator = denormalizeru32(factor);
|
|
60
59
|
if (offset > 1 || offset < 0) {
|
|
61
60
|
throw new Error("Expecting offset to be between 0 and 1, got: " + offset);
|
|
62
61
|
}
|
|
63
|
-
this.offsetNominator =
|
|
62
|
+
this.offsetNominator = denormalizeru32(factor);
|
|
64
63
|
}
|
|
65
64
|
get factor() {
|
|
66
65
|
return this.factorNominator / MAX_U32;
|
package/dist/src/role.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"role.js","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":";;;;;;;;;;AAAA;;;;GAIG;AACH,OAAO,EAAE,KAAK,EAAE,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"role.js","sourceRoot":"","sources":["../../src/role.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import type { Cache } from "@peerbit/cache";
|
|
2
|
+
import type { PublicSignKey } from "@peerbit/crypto";
|
|
3
|
+
import type { Index } from "@peerbit/indexer-interface";
|
|
4
|
+
import type { Entry, Log } from "@peerbit/log";
|
|
5
|
+
import type { RPC, RequestContext } from "@peerbit/rpc";
|
|
6
|
+
import type { EntryWithRefs } from "../exchange-heads.js";
|
|
7
|
+
import type { Numbers } from "../integers.js";
|
|
8
|
+
import type { TransportMessage } from "../message.js";
|
|
9
|
+
import type { EntryReplicated, ReplicationRangeIndexable } from "../ranges.js";
|
|
10
|
+
export type SynchronizerComponents<R extends "u32" | "u64"> = {
|
|
11
|
+
rpc: RPC<TransportMessage, TransportMessage>;
|
|
12
|
+
rangeIndex: Index<ReplicationRangeIndexable<R>, any>;
|
|
13
|
+
entryIndex: Index<EntryReplicated<R>, any>;
|
|
14
|
+
log: Log<any>;
|
|
15
|
+
coordinateToHash: Cache<string>;
|
|
16
|
+
numbers: Numbers<R>;
|
|
17
|
+
};
|
|
18
|
+
export type SynchronizerConstructor<R extends "u32" | "u64"> = new (properties: SynchronizerComponents<R>) => Syncronizer<R>;
|
|
19
|
+
export type SyncableKey = string | bigint;
|
|
20
|
+
export interface Syncronizer<R extends "u32" | "u64"> {
|
|
21
|
+
onMaybeMissingEntries(properties: {
|
|
22
|
+
entries: Map<string, EntryReplicated<R>>;
|
|
23
|
+
targets: string[];
|
|
24
|
+
}): Promise<void> | void;
|
|
25
|
+
onMessage(message: TransportMessage, context: RequestContext): Promise<boolean> | boolean;
|
|
26
|
+
onReceivedEntries(properties: {
|
|
27
|
+
entries: EntryWithRefs<any>[];
|
|
28
|
+
from: PublicSignKey;
|
|
29
|
+
}): Promise<void> | void;
|
|
30
|
+
onEntryAdded(entry: Entry<any>): void;
|
|
31
|
+
onEntryRemoved(hash: string): void;
|
|
32
|
+
onPeerDisconnected(key: PublicSignKey): void;
|
|
33
|
+
open(): Promise<void> | void;
|
|
34
|
+
close(): Promise<void> | void;
|
|
35
|
+
get pending(): number;
|
|
36
|
+
get syncInFlight(): Map<string, Map<SyncableKey, {
|
|
37
|
+
timestamp: number;
|
|
38
|
+
}>>;
|
|
39
|
+
}
|
|
40
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/sync/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAC5C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AACrD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,4BAA4B,CAAC;AACxD,OAAO,KAAK,EAAE,KAAK,EAAE,GAAG,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,KAAK,EAAE,GAAG,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AACxD,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,KAAK,EAAE,eAAe,EAAE,yBAAyB,EAAE,MAAM,cAAc,CAAC;AAE/E,MAAM,MAAM,sBAAsB,CAAC,CAAC,SAAS,KAAK,GAAG,KAAK,IAAI;IAC7D,GAAG,EAAE,GAAG,CAAC,gBAAgB,EAAE,gBAAgB,CAAC,CAAC;IAC7C,UAAU,EAAE,KAAK,CAAC,yBAAyB,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACrD,UAAU,EAAE,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC3C,GAAG,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC;IACd,gBAAgB,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;IAChC,OAAO,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;CACpB,CAAC;AACF,MAAM,MAAM,uBAAuB,CAAC,CAAC,SAAS,KAAK,GAAG,KAAK,IAAI,KAC9D,UAAU,EAAE,sBAAsB,CAAC,CAAC,CAAC,KACjC,WAAW,CAAC,CAAC,CAAC,CAAC;AAEpB,MAAM,MAAM,WAAW,GAAG,MAAM,GAAG,MAAM,CAAC;AAE1C,MAAM,WAAW,WAAW,CAAC,CAAC,SAAS,KAAK,GAAG,KAAK;IACnD,qBAAqB,CAAC,UAAU,EAAE;QACjC,OAAO,EAAE,GAAG,CAAC,MAAM,EAAE,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC;QACzC,OAAO,EAAE,MAAM,EAAE,CAAC;KAClB,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAEzB,SAAS,CACR,OAAO,EAAE,gBAAgB,EACzB,OAAO,EAAE,cAAc,GACrB,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;IAE9B,iBAAiB,CAAC,UAAU,EAAE;QAC7B,OAAO,EAAE,aAAa,CAAC,GAAG,CAAC,EAAE,CAAC;QAC9B,IAAI,EAAE,aAAa,CAAC;KACpB,GAAG,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAEzB,YAAY,CAAC,KAAK,EAAE,KAAK,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;IACtC,cAAc,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,kBAAkB,CAAC,GAAG,EAAE,aAAa,GAAG,IAAI,CAAC;IAE7C,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC7B,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAE9B,IAAI,OAAO,IAAI,MAAM,CAAC;IAEtB,IAAI,YAAY,IAAI,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,WAAW,EAAE;QAAE,SAAS,EAAE,MAAM,CAAA;KAAE,CAAC,CAAC,CAAC;CACzE"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sync/index.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,124 @@
|
|
|
1
|
+
import { Cache } from "@peerbit/cache";
|
|
2
|
+
import { type PublicSignKey } from "@peerbit/crypto";
|
|
3
|
+
import { type Index } from "@peerbit/indexer-interface";
|
|
4
|
+
import type { Entry, Log } from "@peerbit/log";
|
|
5
|
+
import { DecoderWrapper, EncoderWrapper } from "@peerbit/riblt";
|
|
6
|
+
import type { RPC, RequestContext } from "@peerbit/rpc";
|
|
7
|
+
import type { SyncableKey, Syncronizer } from ".";
|
|
8
|
+
import { type EntryWithRefs } from "../exchange-heads.js";
|
|
9
|
+
import { type NumberFromType, type Numbers } from "../integers.js";
|
|
10
|
+
import { TransportMessage } from "../message.js";
|
|
11
|
+
import { type EntryReplicated, type ReplicationRangeIndexable } from "../ranges.js";
|
|
12
|
+
import { SimpleSyncronizer } from "./simple.js";
|
|
13
|
+
import "./wasm-init.js";
|
|
14
|
+
type NumberOrBigint = number | bigint;
|
|
15
|
+
declare class SymbolSerialized implements SSymbol {
|
|
16
|
+
count: bigint;
|
|
17
|
+
hash: bigint;
|
|
18
|
+
symbol: bigint;
|
|
19
|
+
constructor(props: {
|
|
20
|
+
count: bigint;
|
|
21
|
+
hash: bigint;
|
|
22
|
+
symbol: bigint;
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
export declare class StartSync extends TransportMessage {
|
|
26
|
+
syncId: Uint8Array;
|
|
27
|
+
start: bigint;
|
|
28
|
+
end: bigint;
|
|
29
|
+
symbols: SymbolSerialized[];
|
|
30
|
+
constructor(props: {
|
|
31
|
+
from: NumberOrBigint;
|
|
32
|
+
to: NumberOrBigint;
|
|
33
|
+
symbols: SymbolSerialized[];
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
export declare class MoreSymbols extends TransportMessage {
|
|
37
|
+
syncId: Uint8Array;
|
|
38
|
+
seqNo: bigint;
|
|
39
|
+
symbols: SymbolSerialized[];
|
|
40
|
+
constructor(props: {
|
|
41
|
+
syncId: Uint8Array;
|
|
42
|
+
lastSeqNo: bigint;
|
|
43
|
+
symbols: SymbolSerialized[];
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
export declare class RequestMoreSymbols extends TransportMessage {
|
|
47
|
+
syncId: Uint8Array;
|
|
48
|
+
lastSeqNo: bigint;
|
|
49
|
+
constructor(props: {
|
|
50
|
+
syncId: Uint8Array;
|
|
51
|
+
lastSeqNo: bigint;
|
|
52
|
+
});
|
|
53
|
+
}
|
|
54
|
+
export declare class RequestAll extends TransportMessage {
|
|
55
|
+
syncId: Uint8Array;
|
|
56
|
+
constructor(props: {
|
|
57
|
+
syncId: Uint8Array;
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
export interface SSymbol {
|
|
61
|
+
count: bigint;
|
|
62
|
+
hash: bigint;
|
|
63
|
+
symbol: bigint;
|
|
64
|
+
}
|
|
65
|
+
export declare class RatelessIBLTSynchronizer<D extends "u32" | "u64", N = NumberFromType<D>> implements Syncronizer<D> {
|
|
66
|
+
readonly properties: {
|
|
67
|
+
rpc: RPC<TransportMessage, TransportMessage>;
|
|
68
|
+
rangeIndex: Index<ReplicationRangeIndexable<D>, any>;
|
|
69
|
+
entryIndex: Index<EntryReplicated<D>, any>;
|
|
70
|
+
log: Log<any>;
|
|
71
|
+
coordinateToHash: Cache<string>;
|
|
72
|
+
numbers: Numbers<D>;
|
|
73
|
+
};
|
|
74
|
+
simple: SimpleSyncronizer<D>;
|
|
75
|
+
startedOrCompletedSynchronizations: Cache<string>;
|
|
76
|
+
ingoingSyncProcesses: Map<string, {
|
|
77
|
+
decoder: DecoderWrapper;
|
|
78
|
+
timeout: ReturnType<typeof setTimeout>;
|
|
79
|
+
refresh: () => void;
|
|
80
|
+
process: (message: {
|
|
81
|
+
seqNo: bigint;
|
|
82
|
+
symbols: SSymbol[];
|
|
83
|
+
}) => Promise<boolean | undefined>;
|
|
84
|
+
free: () => void;
|
|
85
|
+
}>;
|
|
86
|
+
outgoingSyncProcesses: Map<string, {
|
|
87
|
+
outgoing: Map<string, EntryReplicated<D>>;
|
|
88
|
+
encoder: EncoderWrapper;
|
|
89
|
+
timeout: ReturnType<typeof setTimeout>;
|
|
90
|
+
refresh: () => void;
|
|
91
|
+
next: (message: {
|
|
92
|
+
lastSeqNo: bigint;
|
|
93
|
+
}) => SSymbol[];
|
|
94
|
+
free: () => void;
|
|
95
|
+
}>;
|
|
96
|
+
constructor(properties: {
|
|
97
|
+
rpc: RPC<TransportMessage, TransportMessage>;
|
|
98
|
+
rangeIndex: Index<ReplicationRangeIndexable<D>, any>;
|
|
99
|
+
entryIndex: Index<EntryReplicated<D>, any>;
|
|
100
|
+
log: Log<any>;
|
|
101
|
+
coordinateToHash: Cache<string>;
|
|
102
|
+
numbers: Numbers<D>;
|
|
103
|
+
});
|
|
104
|
+
onMaybeMissingEntries(properties: {
|
|
105
|
+
entries: Map<string, EntryReplicated<D>>;
|
|
106
|
+
targets: string[];
|
|
107
|
+
}): Promise<void>;
|
|
108
|
+
onMessage(message: TransportMessage, context: RequestContext): Promise<boolean>;
|
|
109
|
+
onReceivedEntries(properties: {
|
|
110
|
+
entries: EntryWithRefs<any>[];
|
|
111
|
+
from: PublicSignKey;
|
|
112
|
+
}): Promise<void> | void;
|
|
113
|
+
onEntryAdded(entry: Entry<any>): void;
|
|
114
|
+
onEntryRemoved(hash: string): void;
|
|
115
|
+
onPeerDisconnected(key: PublicSignKey): void | Promise<void>;
|
|
116
|
+
open(): Promise<void> | void;
|
|
117
|
+
close(): Promise<void> | void;
|
|
118
|
+
get syncInFlight(): Map<string, Map<SyncableKey, {
|
|
119
|
+
timestamp: number;
|
|
120
|
+
}>>;
|
|
121
|
+
get pending(): number;
|
|
122
|
+
}
|
|
123
|
+
export {};
|
|
124
|
+
//# sourceMappingURL=rateless-iblt.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rateless-iblt.d.ts","sourceRoot":"","sources":["../../../src/sync/rateless-iblt.ts"],"names":[],"mappings":"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"}
|