cojson 0.19.22 → 0.20.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/.turbo/turbo-build.log +1 -1
- package/CHANGELOG.md +66 -0
- package/dist/PeerState.d.ts +6 -1
- package/dist/PeerState.d.ts.map +1 -1
- package/dist/PeerState.js +18 -3
- package/dist/PeerState.js.map +1 -1
- package/dist/coValueContentMessage.d.ts +0 -2
- package/dist/coValueContentMessage.d.ts.map +1 -1
- package/dist/coValueContentMessage.js +0 -8
- package/dist/coValueContentMessage.js.map +1 -1
- package/dist/coValueCore/SessionMap.d.ts +4 -2
- package/dist/coValueCore/SessionMap.d.ts.map +1 -1
- package/dist/coValueCore/SessionMap.js +30 -0
- package/dist/coValueCore/SessionMap.js.map +1 -1
- package/dist/coValueCore/coValueCore.d.ts +70 -5
- package/dist/coValueCore/coValueCore.d.ts.map +1 -1
- package/dist/coValueCore/coValueCore.js +302 -31
- package/dist/coValueCore/coValueCore.js.map +1 -1
- package/dist/coValueCore/verifiedState.d.ts +6 -1
- package/dist/coValueCore/verifiedState.d.ts.map +1 -1
- package/dist/coValueCore/verifiedState.js +9 -0
- package/dist/coValueCore/verifiedState.js.map +1 -1
- package/dist/coValues/coList.d.ts +4 -2
- package/dist/coValues/coList.d.ts.map +1 -1
- package/dist/coValues/coList.js +3 -0
- package/dist/coValues/coList.js.map +1 -1
- package/dist/coValues/group.d.ts.map +1 -1
- package/dist/coValues/group.js +3 -6
- package/dist/coValues/group.js.map +1 -1
- package/dist/config.d.ts +2 -8
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js +4 -12
- package/dist/config.js.map +1 -1
- package/dist/crypto/NapiCrypto.d.ts +1 -2
- package/dist/crypto/NapiCrypto.d.ts.map +1 -1
- package/dist/crypto/NapiCrypto.js +19 -4
- package/dist/crypto/NapiCrypto.js.map +1 -1
- package/dist/crypto/RNCrypto.d.ts.map +1 -1
- package/dist/crypto/RNCrypto.js +19 -4
- package/dist/crypto/RNCrypto.js.map +1 -1
- package/dist/crypto/WasmCrypto.d.ts +11 -4
- package/dist/crypto/WasmCrypto.d.ts.map +1 -1
- package/dist/crypto/WasmCrypto.js +52 -10
- package/dist/crypto/WasmCrypto.js.map +1 -1
- package/dist/crypto/WasmCryptoEdge.d.ts +1 -0
- package/dist/crypto/WasmCryptoEdge.d.ts.map +1 -1
- package/dist/crypto/WasmCryptoEdge.js +4 -1
- package/dist/crypto/WasmCryptoEdge.js.map +1 -1
- package/dist/crypto/crypto.d.ts +3 -3
- package/dist/crypto/crypto.d.ts.map +1 -1
- package/dist/crypto/crypto.js +6 -1
- package/dist/crypto/crypto.js.map +1 -1
- package/dist/exports.d.ts +5 -5
- package/dist/exports.d.ts.map +1 -1
- package/dist/exports.js +4 -3
- package/dist/exports.js.map +1 -1
- package/dist/ids.d.ts +4 -1
- package/dist/ids.d.ts.map +1 -1
- package/dist/ids.js +4 -0
- package/dist/ids.js.map +1 -1
- package/dist/knownState.d.ts +2 -0
- package/dist/knownState.d.ts.map +1 -1
- package/dist/localNode.d.ts +12 -0
- package/dist/localNode.d.ts.map +1 -1
- package/dist/localNode.js +14 -0
- package/dist/localNode.js.map +1 -1
- package/dist/platformUtils.d.ts +3 -0
- package/dist/platformUtils.d.ts.map +1 -0
- package/dist/platformUtils.js +24 -0
- package/dist/platformUtils.js.map +1 -0
- package/dist/queue/LinkedList.d.ts +9 -3
- package/dist/queue/LinkedList.d.ts.map +1 -1
- package/dist/queue/LinkedList.js +30 -1
- package/dist/queue/LinkedList.js.map +1 -1
- package/dist/queue/OutgoingLoadQueue.d.ts +95 -0
- package/dist/queue/OutgoingLoadQueue.d.ts.map +1 -0
- package/dist/queue/OutgoingLoadQueue.js +240 -0
- package/dist/queue/OutgoingLoadQueue.js.map +1 -0
- package/dist/storage/DeletedCoValuesEraserScheduler.d.ts +30 -0
- package/dist/storage/DeletedCoValuesEraserScheduler.d.ts.map +1 -0
- package/dist/storage/DeletedCoValuesEraserScheduler.js +84 -0
- package/dist/storage/DeletedCoValuesEraserScheduler.js.map +1 -0
- package/dist/storage/sqlite/client.d.ts +3 -0
- package/dist/storage/sqlite/client.d.ts.map +1 -1
- package/dist/storage/sqlite/client.js +44 -0
- package/dist/storage/sqlite/client.js.map +1 -1
- package/dist/storage/sqlite/sqliteMigrations.d.ts.map +1 -1
- package/dist/storage/sqlite/sqliteMigrations.js +7 -0
- package/dist/storage/sqlite/sqliteMigrations.js.map +1 -1
- package/dist/storage/sqliteAsync/client.d.ts +3 -0
- package/dist/storage/sqliteAsync/client.d.ts.map +1 -1
- package/dist/storage/sqliteAsync/client.js +42 -0
- package/dist/storage/sqliteAsync/client.js.map +1 -1
- package/dist/storage/storageAsync.d.ts +7 -0
- package/dist/storage/storageAsync.d.ts.map +1 -1
- package/dist/storage/storageAsync.js +48 -0
- package/dist/storage/storageAsync.js.map +1 -1
- package/dist/storage/storageSync.d.ts +6 -0
- package/dist/storage/storageSync.d.ts.map +1 -1
- package/dist/storage/storageSync.js +42 -0
- package/dist/storage/storageSync.js.map +1 -1
- package/dist/storage/types.d.ts +59 -0
- package/dist/storage/types.d.ts.map +1 -1
- package/dist/storage/types.js +12 -1
- package/dist/storage/types.js.map +1 -1
- package/dist/sync.d.ts.map +1 -1
- package/dist/sync.js +66 -43
- package/dist/sync.js.map +1 -1
- package/dist/tests/DeletedCoValuesEraserScheduler.test.d.ts +2 -0
- package/dist/tests/DeletedCoValuesEraserScheduler.test.d.ts.map +1 -0
- package/dist/tests/DeletedCoValuesEraserScheduler.test.js +149 -0
- package/dist/tests/DeletedCoValuesEraserScheduler.test.js.map +1 -0
- package/dist/tests/GarbageCollector.test.js +5 -6
- package/dist/tests/GarbageCollector.test.js.map +1 -1
- package/dist/tests/LinkedList.test.js +90 -0
- package/dist/tests/LinkedList.test.js.map +1 -1
- package/dist/tests/OutgoingLoadQueue.test.d.ts +2 -0
- package/dist/tests/OutgoingLoadQueue.test.d.ts.map +1 -0
- package/dist/tests/OutgoingLoadQueue.test.js +814 -0
- package/dist/tests/OutgoingLoadQueue.test.js.map +1 -0
- package/dist/tests/StorageApiAsync.test.js +484 -152
- package/dist/tests/StorageApiAsync.test.js.map +1 -1
- package/dist/tests/StorageApiSync.test.js +505 -136
- package/dist/tests/StorageApiSync.test.js.map +1 -1
- package/dist/tests/WasmCrypto.test.js +6 -3
- package/dist/tests/WasmCrypto.test.js.map +1 -1
- package/dist/tests/coValueCore.loadFromStorage.test.js +3 -0
- package/dist/tests/coValueCore.loadFromStorage.test.js.map +1 -1
- package/dist/tests/coValueCore.test.js +34 -13
- package/dist/tests/coValueCore.test.js.map +1 -1
- package/dist/tests/coreWasm.test.js +127 -4
- package/dist/tests/coreWasm.test.js.map +1 -1
- package/dist/tests/crypto.test.js +89 -93
- package/dist/tests/crypto.test.js.map +1 -1
- package/dist/tests/deleteCoValue.test.d.ts +2 -0
- package/dist/tests/deleteCoValue.test.d.ts.map +1 -0
- package/dist/tests/deleteCoValue.test.js +313 -0
- package/dist/tests/deleteCoValue.test.js.map +1 -0
- package/dist/tests/group.removeMember.test.js +18 -30
- package/dist/tests/group.removeMember.test.js.map +1 -1
- package/dist/tests/knownState.lazyLoading.test.js +3 -0
- package/dist/tests/knownState.lazyLoading.test.js.map +1 -1
- package/dist/tests/sync.concurrentLoad.test.d.ts +2 -0
- package/dist/tests/sync.concurrentLoad.test.d.ts.map +1 -0
- package/dist/tests/sync.concurrentLoad.test.js +481 -0
- package/dist/tests/sync.concurrentLoad.test.js.map +1 -0
- package/dist/tests/sync.deleted.test.d.ts +2 -0
- package/dist/tests/sync.deleted.test.d.ts.map +1 -0
- package/dist/tests/sync.deleted.test.js +214 -0
- package/dist/tests/sync.deleted.test.js.map +1 -0
- package/dist/tests/sync.mesh.test.js +3 -2
- package/dist/tests/sync.mesh.test.js.map +1 -1
- package/dist/tests/sync.storage.test.js +4 -3
- package/dist/tests/sync.storage.test.js.map +1 -1
- package/dist/tests/sync.test.js +3 -2
- package/dist/tests/sync.test.js.map +1 -1
- package/dist/tests/testStorage.d.ts +3 -0
- package/dist/tests/testStorage.d.ts.map +1 -1
- package/dist/tests/testStorage.js +17 -1
- package/dist/tests/testStorage.js.map +1 -1
- package/dist/tests/testUtils.d.ts +7 -3
- package/dist/tests/testUtils.d.ts.map +1 -1
- package/dist/tests/testUtils.js +19 -4
- package/dist/tests/testUtils.js.map +1 -1
- package/package.json +6 -16
- package/src/PeerState.ts +26 -3
- package/src/coValueContentMessage.ts +0 -14
- package/src/coValueCore/SessionMap.ts +43 -1
- package/src/coValueCore/coValueCore.ts +415 -27
- package/src/coValueCore/verifiedState.ts +26 -3
- package/src/coValues/coList.ts +9 -3
- package/src/coValues/group.ts +5 -6
- package/src/config.ts +4 -13
- package/src/crypto/NapiCrypto.ts +29 -13
- package/src/crypto/RNCrypto.ts +29 -11
- package/src/crypto/WasmCrypto.ts +67 -20
- package/src/crypto/WasmCryptoEdge.ts +5 -1
- package/src/crypto/crypto.ts +16 -4
- package/src/exports.ts +4 -2
- package/src/ids.ts +11 -1
- package/src/localNode.ts +15 -0
- package/src/platformUtils.ts +26 -0
- package/src/queue/LinkedList.ts +34 -4
- package/src/queue/OutgoingLoadQueue.ts +307 -0
- package/src/storage/DeletedCoValuesEraserScheduler.ts +124 -0
- package/src/storage/sqlite/client.ts +77 -0
- package/src/storage/sqlite/sqliteMigrations.ts +7 -0
- package/src/storage/sqliteAsync/client.ts +75 -0
- package/src/storage/storageAsync.ts +62 -0
- package/src/storage/storageSync.ts +58 -0
- package/src/storage/types.ts +69 -0
- package/src/sync.ts +78 -46
- package/src/tests/DeletedCoValuesEraserScheduler.test.ts +185 -0
- package/src/tests/GarbageCollector.test.ts +6 -10
- package/src/tests/LinkedList.test.ts +111 -0
- package/src/tests/OutgoingLoadQueue.test.ts +1129 -0
- package/src/tests/StorageApiAsync.test.ts +572 -162
- package/src/tests/StorageApiSync.test.ts +580 -143
- package/src/tests/WasmCrypto.test.ts +8 -3
- package/src/tests/coValueCore.loadFromStorage.test.ts +6 -0
- package/src/tests/coValueCore.test.ts +49 -14
- package/src/tests/coreWasm.test.ts +319 -10
- package/src/tests/crypto.test.ts +141 -150
- package/src/tests/deleteCoValue.test.ts +528 -0
- package/src/tests/group.removeMember.test.ts +35 -35
- package/src/tests/knownState.lazyLoading.test.ts +6 -0
- package/src/tests/sync.concurrentLoad.test.ts +650 -0
- package/src/tests/sync.deleted.test.ts +294 -0
- package/src/tests/sync.mesh.test.ts +5 -2
- package/src/tests/sync.storage.test.ts +6 -3
- package/src/tests/sync.test.ts +5 -2
- package/src/tests/testStorage.ts +31 -2
- package/src/tests/testUtils.ts +31 -10
- package/dist/crypto/PureJSCrypto.d.ts +0 -77
- package/dist/crypto/PureJSCrypto.d.ts.map +0 -1
- package/dist/crypto/PureJSCrypto.js +0 -236
- package/dist/crypto/PureJSCrypto.js.map +0 -1
- package/dist/tests/PureJSCrypto.test.d.ts +0 -2
- package/dist/tests/PureJSCrypto.test.d.ts.map +0 -1
- package/dist/tests/PureJSCrypto.test.js +0 -145
- package/dist/tests/PureJSCrypto.test.js.map +0 -1
- package/src/crypto/PureJSCrypto.ts +0 -429
- package/src/tests/PureJSCrypto.test.ts +0 -217
|
@@ -1,17 +1,15 @@
|
|
|
1
1
|
import { assert, describe, expect, it } from "vitest";
|
|
2
2
|
import { WasmCrypto } from "../crypto/WasmCrypto";
|
|
3
3
|
import { LocalNode } from "../exports";
|
|
4
|
-
import { agentAndSessionIDFromSecret
|
|
5
|
-
import { PureJSCrypto } from "../crypto/PureJSCrypto";
|
|
4
|
+
import { agentAndSessionIDFromSecret } from "./testUtils";
|
|
6
5
|
const wasmCrypto = await WasmCrypto.create();
|
|
7
|
-
const jsCrypto = await PureJSCrypto.create();
|
|
8
6
|
const agentSecret = "sealerSecret_zE3Nr7YFr1KkVbJSx4JDCzYn4ApYdm8kJ5ghNBxREHQya/signerSecret_z9fEu4eNG1eXHMak3YSzY7uLdoG8HESSJ8YW4xWdNNDSP";
|
|
9
7
|
function createTestNode() {
|
|
10
8
|
const [agent, session] = agentAndSessionIDFromSecret(agentSecret);
|
|
11
9
|
return {
|
|
12
10
|
agent,
|
|
13
11
|
session,
|
|
14
|
-
node: new LocalNode(agent.agentSecret, session,
|
|
12
|
+
node: new LocalNode(agent.agentSecret, session, wasmCrypto),
|
|
15
13
|
};
|
|
16
14
|
}
|
|
17
15
|
describe("SessionLog WASM", () => {
|
|
@@ -76,5 +74,130 @@ describe("SessionLog WASM", () => {
|
|
|
76
74
|
.decryptNextTransactionChangesJson(0, fixtures.key.secret);
|
|
77
75
|
expect(decrypted).toEqual(fixtures.decrypted);
|
|
78
76
|
});
|
|
77
|
+
function shuffleObjectKeys(obj) {
|
|
78
|
+
const keys = Object.keys(obj);
|
|
79
|
+
// Fisher-Yates shuffle
|
|
80
|
+
for (let i = keys.length - 1; i > 0; i--) {
|
|
81
|
+
const j = Math.floor(Math.random() * (i + 1));
|
|
82
|
+
[keys[i], keys[j]] = [keys[j], keys[i]];
|
|
83
|
+
}
|
|
84
|
+
const result = {};
|
|
85
|
+
for (const key of keys) {
|
|
86
|
+
result[key] = obj[key];
|
|
87
|
+
}
|
|
88
|
+
return result;
|
|
89
|
+
}
|
|
90
|
+
function shuffleTransactions(transactions) {
|
|
91
|
+
return transactions.map((t) => shuffleObjectKeys(t));
|
|
92
|
+
}
|
|
93
|
+
describe("Signature validation after shuffling transaction keys", () => {
|
|
94
|
+
it("trusting transactions with 100 k/v entries", () => {
|
|
95
|
+
const { agent, session, node } = createTestNode();
|
|
96
|
+
const group = node.createGroup();
|
|
97
|
+
const map = group.createMap();
|
|
98
|
+
// Create 100 trusting transactions with explicit test data
|
|
99
|
+
for (let i = 0; i < 100; i++) {
|
|
100
|
+
map.core.makeTransaction([{ op: "set", key: `key${i}`, value: `value${i}` }], "trusting", undefined, i * 1000);
|
|
101
|
+
}
|
|
102
|
+
const sessionContent = map.core.newContentSince(undefined)?.[0]?.new[session];
|
|
103
|
+
assert(sessionContent);
|
|
104
|
+
expect(sessionContent.newTransactions.length).toBe(100);
|
|
105
|
+
const log = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
106
|
+
const logShuffled = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
107
|
+
const shuffledTransactions = shuffleTransactions(sessionContent.newTransactions);
|
|
108
|
+
expect(() => log.tryAdd(sessionContent.newTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
109
|
+
expect(() => logShuffled.tryAdd(shuffledTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
110
|
+
});
|
|
111
|
+
it("private transactions with 100 k/v entries", () => {
|
|
112
|
+
const { agent, session, node } = createTestNode();
|
|
113
|
+
const group = node.createGroup();
|
|
114
|
+
const map = group.createMap();
|
|
115
|
+
// Create 100 private transactions with explicit test data
|
|
116
|
+
for (let i = 0; i < 100; i++) {
|
|
117
|
+
map.core.makeTransaction([{ op: "set", key: `secretKey${i}`, value: `secretValue${i}` }], "private", undefined, i * 1000);
|
|
118
|
+
}
|
|
119
|
+
const sessionContent = map.core.newContentSince(undefined)?.[0]?.new[session];
|
|
120
|
+
assert(sessionContent);
|
|
121
|
+
expect(sessionContent.newTransactions.length).toBe(100);
|
|
122
|
+
// Verify transactions are actually private (encrypted)
|
|
123
|
+
const firstTx = sessionContent.newTransactions[0];
|
|
124
|
+
assert(firstTx);
|
|
125
|
+
expect(firstTx.privacy).toBe("private");
|
|
126
|
+
expect("encryptedChanges" in firstTx).toBe(true);
|
|
127
|
+
const log = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
128
|
+
const logShuffled = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
129
|
+
const shuffledTransactions = shuffleTransactions(sessionContent.newTransactions);
|
|
130
|
+
expect(() => log.tryAdd(sessionContent.newTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
131
|
+
expect(() => logShuffled.tryAdd(shuffledTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
132
|
+
});
|
|
133
|
+
it("trusting transactions with metas", () => {
|
|
134
|
+
const { agent, session, node } = createTestNode();
|
|
135
|
+
const group = node.createGroup();
|
|
136
|
+
const map = group.createMap();
|
|
137
|
+
// Create transactions with metas
|
|
138
|
+
for (let i = 0; i < 50; i++) {
|
|
139
|
+
map.core.makeTransaction([{ op: "set", key: `key${i}`, value: `value${i}` }], "trusting", { index: i, timestamp: i * 1000, nested: { data: `meta${i}` } }, i * 1000);
|
|
140
|
+
}
|
|
141
|
+
const sessionContent = map.core.newContentSince(undefined)?.[0]?.new[session];
|
|
142
|
+
assert(sessionContent);
|
|
143
|
+
expect(sessionContent.newTransactions.length).toBe(50);
|
|
144
|
+
// Verify metas are present
|
|
145
|
+
const firstTx = sessionContent.newTransactions[0];
|
|
146
|
+
assert(firstTx);
|
|
147
|
+
expect(firstTx.meta).toBeDefined();
|
|
148
|
+
const log = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
149
|
+
const logShuffled = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
150
|
+
const shuffledTransactions = shuffleTransactions(sessionContent.newTransactions);
|
|
151
|
+
expect(() => log.tryAdd(sessionContent.newTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
152
|
+
expect(() => logShuffled.tryAdd(shuffledTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
153
|
+
});
|
|
154
|
+
it("private transactions with metas", () => {
|
|
155
|
+
const { agent, session, node } = createTestNode();
|
|
156
|
+
const group = node.createGroup();
|
|
157
|
+
const map = group.createMap();
|
|
158
|
+
// Create private transactions with encrypted metas
|
|
159
|
+
for (let i = 0; i < 50; i++) {
|
|
160
|
+
map.core.makeTransaction([{ op: "set", key: `secretKey${i}`, value: `secretValue${i}` }], "private", { index: i, secret: `confidential${i}` }, i * 1000);
|
|
161
|
+
}
|
|
162
|
+
const sessionContent = map.core.newContentSince(undefined)?.[0]?.new[session];
|
|
163
|
+
assert(sessionContent);
|
|
164
|
+
expect(sessionContent.newTransactions.length).toBe(50);
|
|
165
|
+
// Verify transactions are private with encrypted metas
|
|
166
|
+
const firstTx = sessionContent.newTransactions[0];
|
|
167
|
+
assert(firstTx);
|
|
168
|
+
expect(firstTx.privacy).toBe("private");
|
|
169
|
+
expect("encryptedChanges" in firstTx).toBe(true);
|
|
170
|
+
expect(firstTx.meta).toBeDefined();
|
|
171
|
+
const log = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
172
|
+
const logShuffled = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
173
|
+
const shuffledTransactions = shuffleTransactions(sessionContent.newTransactions);
|
|
174
|
+
expect(() => log.tryAdd(sessionContent.newTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
175
|
+
expect(() => logShuffled.tryAdd(shuffledTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
176
|
+
});
|
|
177
|
+
it("mixed trusting and private transactions across multiple sessions", () => {
|
|
178
|
+
const { agent, session, node } = createTestNode();
|
|
179
|
+
const group = node.createGroup();
|
|
180
|
+
const map = group.createMap();
|
|
181
|
+
// Create alternating trusting and private transactions
|
|
182
|
+
for (let i = 0; i < 50; i++) {
|
|
183
|
+
const privacy = i % 2 === 0 ? "trusting" : "private";
|
|
184
|
+
const hasMeta = i % 3 === 0;
|
|
185
|
+
map.core.makeTransaction([{ op: "set", key: `mixedKey${i}`, value: `mixedValue${i}` }], privacy, hasMeta ? { iteration: i, type: privacy } : undefined, i * 1000);
|
|
186
|
+
}
|
|
187
|
+
const sessionContent = map.core.newContentSince(undefined)?.[0]?.new[session];
|
|
188
|
+
assert(sessionContent);
|
|
189
|
+
expect(sessionContent.newTransactions.length).toBe(50);
|
|
190
|
+
// Verify we have a mix of trusting and private transactions
|
|
191
|
+
const trustingCount = sessionContent.newTransactions.filter((t) => t.privacy === "trusting").length;
|
|
192
|
+
const privateCount = sessionContent.newTransactions.filter((t) => t.privacy === "private").length;
|
|
193
|
+
expect(trustingCount).toBe(25);
|
|
194
|
+
expect(privateCount).toBe(25);
|
|
195
|
+
const log = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
196
|
+
const logShuffled = wasmCrypto.createSessionLog(map.id, session, agent.currentSignerID());
|
|
197
|
+
const shuffledTransactions = shuffleTransactions(sessionContent.newTransactions);
|
|
198
|
+
expect(() => log.tryAdd(sessionContent.newTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
199
|
+
expect(() => logShuffled.tryAdd(shuffledTransactions, sessionContent.lastSignature, false)).not.toThrow();
|
|
200
|
+
});
|
|
201
|
+
});
|
|
79
202
|
});
|
|
80
203
|
//# sourceMappingURL=coreWasm.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"coreWasm.test.js","sourceRoot":"","sources":["../../src/tests/coreWasm.test.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"coreWasm.test.js","sourceRoot":"","sources":["../../src/tests/coreWasm.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,101 +3,97 @@ import { x25519 } from "@noble/curves/ed25519";
|
|
|
3
3
|
import { blake3 } from "@noble/hashes/blake3";
|
|
4
4
|
import { base58, base64url } from "@scure/base";
|
|
5
5
|
import { expect, test, vi } from "vitest";
|
|
6
|
-
import { PureJSCrypto } from "../crypto/PureJSCrypto.js";
|
|
7
6
|
import { WasmCrypto } from "../crypto/WasmCrypto.js";
|
|
8
7
|
import { stableStringify } from "../jsonStringify.js";
|
|
9
|
-
const
|
|
10
|
-
const
|
|
11
|
-
[
|
|
12
|
-
const
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
to: crypto.getSealerID(sealer),
|
|
40
|
-
nOnceMaterial,
|
|
41
|
-
});
|
|
42
|
-
expect(crypto.unseal(sealed, sealer, crypto.getSealerID(sender), nOnceMaterial)).toEqual(data);
|
|
43
|
-
expect(() => crypto.unseal(sealed, wrongSealer, crypto.getSealerID(sender), nOnceMaterial)).toThrow(name === "PureJSCrypto" ? "invalid tag" : "Wrong tag");
|
|
44
|
-
// trying with wrong sealer secret, by hand
|
|
45
|
-
const nOnce = blake3(new TextEncoder().encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
46
|
-
const sealer3priv = base58.decode(wrongSealer.substring("sealerSecret_z".length));
|
|
47
|
-
const senderPub = base58.decode(crypto.getSealerID(sender).substring("sealer_z".length));
|
|
48
|
-
const sealedBytes = base64url.decode(sealed.substring("sealed_U".length));
|
|
49
|
-
const sharedSecret = x25519.getSharedSecret(sealer3priv, senderPub);
|
|
50
|
-
expect(() => {
|
|
51
|
-
const _ = xsalsa20poly1305(sharedSecret, nOnce).decrypt(sealedBytes);
|
|
52
|
-
}).toThrow("invalid tag");
|
|
53
|
-
});
|
|
54
|
-
test(`Hashing is deterministic [${name}]`, () => {
|
|
55
|
-
expect(crypto.secureHash({ b: "world", a: "hello" })).toEqual(crypto.secureHash({ a: "hello", b: "world" }));
|
|
56
|
-
expect(crypto.shortHash({ b: "world", a: "hello" })).toEqual(crypto.shortHash({ a: "hello", b: "world" }));
|
|
57
|
-
});
|
|
58
|
-
test(`Encryption of keySecrets round-trips [${name}]`, () => {
|
|
59
|
-
const toEncrypt = crypto.newRandomKeySecret();
|
|
60
|
-
const encrypting = crypto.newRandomKeySecret();
|
|
61
|
-
const keys = {
|
|
62
|
-
toEncrypt,
|
|
63
|
-
encrypting,
|
|
64
|
-
};
|
|
65
|
-
const encrypted = crypto.encryptKeySecret(keys);
|
|
66
|
-
const decrypted = crypto.decryptKeySecret(encrypted, encrypting.secret);
|
|
67
|
-
expect(decrypted).toEqual(toEncrypt.secret);
|
|
68
|
-
});
|
|
69
|
-
test(`Encryption of keySecrets doesn't decrypt with a wrong key [${name}]`, () => {
|
|
70
|
-
const toEncrypt = crypto.newRandomKeySecret();
|
|
71
|
-
const encrypting = crypto.newRandomKeySecret();
|
|
72
|
-
const encryptingWrong = crypto.newRandomKeySecret();
|
|
73
|
-
const keys = {
|
|
74
|
-
toEncrypt,
|
|
75
|
-
encrypting,
|
|
76
|
-
};
|
|
77
|
-
const encrypted = crypto.encryptKeySecret(keys);
|
|
78
|
-
const decrypted = crypto.decryptKeySecret(encrypted, encryptingWrong.secret);
|
|
79
|
-
expect(decrypted).toBeUndefined();
|
|
80
|
-
});
|
|
81
|
-
test(`Unsealing malformed JSON logs error [${name}]`, () => {
|
|
82
|
-
const data = "not valid json";
|
|
83
|
-
const sender = crypto.newRandomSealer();
|
|
84
|
-
const sealer = crypto.newRandomSealer();
|
|
85
|
-
const consoleSpy = vi.spyOn(console, "error").mockImplementation(() => { });
|
|
86
|
-
const nOnceMaterial = {
|
|
87
|
-
in: "co_zTEST",
|
|
88
|
-
tx: { sessionID: "co_zTEST_session_zTEST", txIndex: 0 },
|
|
89
|
-
};
|
|
90
|
-
// Create a sealed message with invalid JSON
|
|
91
|
-
const nOnce = blake3(new TextEncoder().encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
92
|
-
const senderPriv = base58.decode(sender.substring("sealerSecret_z".length));
|
|
93
|
-
const sealerPub = base58.decode(crypto.getSealerID(sealer).substring("sealer_z".length));
|
|
94
|
-
const plaintext = new TextEncoder().encode(data);
|
|
95
|
-
const sharedSecret = x25519.getSharedSecret(senderPriv, sealerPub);
|
|
96
|
-
const sealedBytes = xsalsa20poly1305(sharedSecret, nOnce).encrypt(plaintext);
|
|
97
|
-
const sealed = `sealed_U${base64url.encode(sealedBytes)}`;
|
|
98
|
-
const result = crypto.unseal(sealed, sealer, crypto.getSealerID(sender), nOnceMaterial);
|
|
99
|
-
expect(result).toBeUndefined();
|
|
100
|
-
expect(consoleSpy.mock.lastCall?.[0]).toContain("Failed to decrypt/parse sealed message");
|
|
8
|
+
const crypto = await WasmCrypto.create();
|
|
9
|
+
const name = crypto.constructor.name;
|
|
10
|
+
test(`Signatures round-trip and use stable stringify [${name}]`, () => {
|
|
11
|
+
const data = { b: "world", a: "hello" };
|
|
12
|
+
const signer = crypto.newRandomSigner();
|
|
13
|
+
const signature = crypto.sign(signer, data);
|
|
14
|
+
expect(signature).toMatch(/^signature_z/);
|
|
15
|
+
expect(crypto.verify(signature, { a: "hello", b: "world" }, crypto.getSignerID(signer))).toBe(true);
|
|
16
|
+
});
|
|
17
|
+
test(`Invalid signatures don't verify [${name}]`, () => {
|
|
18
|
+
const data = { b: "world", a: "hello" };
|
|
19
|
+
const signer = crypto.newRandomSigner();
|
|
20
|
+
const signer2 = crypto.newRandomSigner();
|
|
21
|
+
const wrongSignature = crypto.sign(signer2, data);
|
|
22
|
+
expect(crypto.verify(wrongSignature, data, crypto.getSignerID(signer))).toBe(false);
|
|
23
|
+
});
|
|
24
|
+
test(`encrypting round-trips, but invalid receiver can't unseal [${name}]`, () => {
|
|
25
|
+
const data = { b: "world", a: "hello" };
|
|
26
|
+
const sender = crypto.newRandomSealer();
|
|
27
|
+
const sealer = crypto.newRandomSealer();
|
|
28
|
+
const wrongSealer = crypto.newRandomSealer();
|
|
29
|
+
const nOnceMaterial = {
|
|
30
|
+
in: "co_zTEST",
|
|
31
|
+
tx: { sessionID: "co_zTEST_session_zTEST", txIndex: 0 },
|
|
32
|
+
};
|
|
33
|
+
const sealed = crypto.seal({
|
|
34
|
+
message: data,
|
|
35
|
+
from: sender,
|
|
36
|
+
to: crypto.getSealerID(sealer),
|
|
37
|
+
nOnceMaterial,
|
|
101
38
|
});
|
|
39
|
+
expect(crypto.unseal(sealed, sealer, crypto.getSealerID(sender), nOnceMaterial)).toEqual(data);
|
|
40
|
+
expect(() => crypto.unseal(sealed, wrongSealer, crypto.getSealerID(sender), nOnceMaterial)).toThrow("Wrong tag");
|
|
41
|
+
// trying with wrong sealer secret, by hand
|
|
42
|
+
const nOnce = blake3(new TextEncoder().encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
43
|
+
const sealer3priv = base58.decode(wrongSealer.substring("sealerSecret_z".length));
|
|
44
|
+
const senderPub = base58.decode(crypto.getSealerID(sender).substring("sealer_z".length));
|
|
45
|
+
const sealedBytes = base64url.decode(sealed.substring("sealed_U".length));
|
|
46
|
+
const sharedSecret = x25519.getSharedSecret(sealer3priv, senderPub);
|
|
47
|
+
expect(() => {
|
|
48
|
+
const _ = xsalsa20poly1305(sharedSecret, nOnce).decrypt(sealedBytes);
|
|
49
|
+
}).toThrow("invalid tag");
|
|
50
|
+
});
|
|
51
|
+
test(`Hashing is deterministic [${name}]`, () => {
|
|
52
|
+
expect(crypto.secureHash({ b: "world", a: "hello" })).toEqual(crypto.secureHash({ a: "hello", b: "world" }));
|
|
53
|
+
expect(crypto.shortHash({ b: "world", a: "hello" })).toEqual(crypto.shortHash({ a: "hello", b: "world" }));
|
|
54
|
+
});
|
|
55
|
+
test(`Encryption of keySecrets round-trips [${name}]`, () => {
|
|
56
|
+
const toEncrypt = crypto.newRandomKeySecret();
|
|
57
|
+
const encrypting = crypto.newRandomKeySecret();
|
|
58
|
+
const keys = {
|
|
59
|
+
toEncrypt,
|
|
60
|
+
encrypting,
|
|
61
|
+
};
|
|
62
|
+
const encrypted = crypto.encryptKeySecret(keys);
|
|
63
|
+
const decrypted = crypto.decryptKeySecret(encrypted, encrypting.secret);
|
|
64
|
+
expect(decrypted).toEqual(toEncrypt.secret);
|
|
65
|
+
});
|
|
66
|
+
test(`Encryption of keySecrets doesn't decrypt with a wrong key [${name}]`, () => {
|
|
67
|
+
const toEncrypt = crypto.newRandomKeySecret();
|
|
68
|
+
const encrypting = crypto.newRandomKeySecret();
|
|
69
|
+
const encryptingWrong = crypto.newRandomKeySecret();
|
|
70
|
+
const keys = {
|
|
71
|
+
toEncrypt,
|
|
72
|
+
encrypting,
|
|
73
|
+
};
|
|
74
|
+
const encrypted = crypto.encryptKeySecret(keys);
|
|
75
|
+
const decrypted = crypto.decryptKeySecret(encrypted, encryptingWrong.secret);
|
|
76
|
+
expect(decrypted).toBeUndefined();
|
|
77
|
+
});
|
|
78
|
+
test(`Unsealing malformed JSON logs error [${name}]`, () => {
|
|
79
|
+
const data = "not valid json";
|
|
80
|
+
const sender = crypto.newRandomSealer();
|
|
81
|
+
const sealer = crypto.newRandomSealer();
|
|
82
|
+
const consoleSpy = vi.spyOn(console, "error").mockImplementation(() => { });
|
|
83
|
+
const nOnceMaterial = {
|
|
84
|
+
in: "co_zTEST",
|
|
85
|
+
tx: { sessionID: "co_zTEST_session_zTEST", txIndex: 0 },
|
|
86
|
+
};
|
|
87
|
+
// Create a sealed message with invalid JSON
|
|
88
|
+
const nOnce = blake3(new TextEncoder().encode(stableStringify(nOnceMaterial))).slice(0, 24);
|
|
89
|
+
const senderPriv = base58.decode(sender.substring("sealerSecret_z".length));
|
|
90
|
+
const sealerPub = base58.decode(crypto.getSealerID(sealer).substring("sealer_z".length));
|
|
91
|
+
const plaintext = new TextEncoder().encode(data);
|
|
92
|
+
const sharedSecret = x25519.getSharedSecret(senderPriv, sealerPub);
|
|
93
|
+
const sealedBytes = xsalsa20poly1305(sharedSecret, nOnce).encrypt(plaintext);
|
|
94
|
+
const sealed = `sealed_U${base64url.encode(sealedBytes)}`;
|
|
95
|
+
const result = crypto.unseal(sealed, sealer, crypto.getSealerID(sender), nOnceMaterial);
|
|
96
|
+
expect(result).toBeUndefined();
|
|
97
|
+
expect(consoleSpy.mock.lastCall?.[0]).toContain("Failed to decrypt/parse sealed message");
|
|
102
98
|
});
|
|
103
99
|
//# sourceMappingURL=crypto.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"crypto.test.js","sourceRoot":"","sources":["../../src/tests/crypto.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AACxD,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAC9C,OAAO,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC1C,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"crypto.test.js","sourceRoot":"","sources":["../../src/tests/crypto.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"deleteCoValue.test.d.ts","sourceRoot":"","sources":["../../src/tests/deleteCoValue.test.ts"],"names":[],"mappings":""}
|