@renown/sdk 6.0.0-dev.40 → 6.0.0-dev.42
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/src/crypto/index.d.ts +1 -1
- package/dist/src/crypto/index.d.ts.map +1 -1
- package/dist/src/crypto/index.js +1 -1
- package/dist/src/crypto/index.js.map +1 -1
- package/dist/src/crypto/signer.d.ts +48 -0
- package/dist/src/crypto/signer.d.ts.map +1 -1
- package/dist/src/crypto/signer.js +71 -2
- package/dist/src/crypto/signer.js.map +1 -1
- package/dist/test/crypto/signer.test.d.ts +2 -0
- package/dist/test/crypto/signer.test.d.ts.map +1 -0
- package/dist/test/crypto/signer.test.js +184 -0
- package/dist/test/crypto/signer.test.js.map +1 -0
- package/dist/test/script.test.js +110 -11
- package/dist/test/script.test.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- package/package.json +11 -11
|
@@ -3,5 +3,5 @@ export { RenownCryptoBuilder } from "./renown-crypto-builder.js";
|
|
|
3
3
|
export { ConnectCrypto, RenownCrypto } from "./renown-crypto.js";
|
|
4
4
|
export { BrowserKeyStorage } from "./browser-key-storage.js";
|
|
5
5
|
export { MemoryKeyStorage } from "./memory-key-storage.js";
|
|
6
|
-
export { createSignatureVerifier, RenownCryptoSigner } from "./signer.js";
|
|
6
|
+
export { createSignatureVerifier, RenownCryptoSigner, parseSignatureHashField, extractResultingHashFromSignature, signatureHasResultingHash, } from "./signer.js";
|
|
7
7
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/index.ts"],"names":[],"mappings":"AACA,YAAY,EACV,GAAG,EACH,cAAc,EACd,aAAa,EACb,qBAAqB,EACrB,UAAU,GACX,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAGjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/crypto/index.ts"],"names":[],"mappings":"AACA,YAAY,EACV,GAAG,EACH,cAAc,EACd,aAAa,EACb,qBAAqB,EACrB,UAAU,GACX,MAAM,YAAY,CAAC;AAGpB,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAGjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAG3D,OAAO,EACL,uBAAuB,EACvB,kBAAkB,EAClB,uBAAuB,EACvB,iCAAiC,EACjC,yBAAyB,GAC1B,MAAM,aAAa,CAAC"}
|
package/dist/src/crypto/index.js
CHANGED
|
@@ -5,5 +5,5 @@ export { ConnectCrypto, RenownCrypto } from "./renown-crypto.js";
|
|
|
5
5
|
export { BrowserKeyStorage } from "./browser-key-storage.js";
|
|
6
6
|
export { MemoryKeyStorage } from "./memory-key-storage.js";
|
|
7
7
|
// Signer utilities
|
|
8
|
-
export { createSignatureVerifier, RenownCryptoSigner } from "./signer.js";
|
|
8
|
+
export { createSignatureVerifier, RenownCryptoSigner, parseSignatureHashField, extractResultingHashFromSignature, signatureHasResultingHash, } from "./signer.js";
|
|
9
9
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/crypto/index.ts"],"names":[],"mappings":"AASA,UAAU;AACV,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEjE,0BAA0B;AAC1B,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,mBAAmB;AACnB,OAAO,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/crypto/index.ts"],"names":[],"mappings":"AASA,UAAU;AACV,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAEjE,0BAA0B;AAC1B,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,yBAAyB,CAAC;AAE3D,mBAAmB;AACnB,OAAO,EACL,uBAAuB,EACvB,kBAAkB,EAClB,uBAAuB,EACvB,iCAAiC,EACjC,yBAAyB,GAC1B,MAAM,aAAa,CAAC"}
|
|
@@ -13,6 +13,26 @@ export declare class RenownCryptoSigner implements ISigner {
|
|
|
13
13
|
sign(data: Uint8Array): Promise<Uint8Array>;
|
|
14
14
|
verify(data: Uint8Array, signature: Uint8Array): Promise<void>;
|
|
15
15
|
signAction(action: Action, abortSignal?: AbortSignal): Promise<Signature>;
|
|
16
|
+
/**
|
|
17
|
+
* Signs an action including a predicted resulting state hash.
|
|
18
|
+
*
|
|
19
|
+
* The resulting hash is packed into the signature tuple's 4th element (index 3)
|
|
20
|
+
* using the format: `${prevStateHash}:${resultingStateHash}`
|
|
21
|
+
*
|
|
22
|
+
* This allows offline verification of documents without reducer logic:
|
|
23
|
+
* - Verifier can check that the signature is valid for the claimed resulting state
|
|
24
|
+
* - Verifier can compare claimed resulting state to actual operation.hash
|
|
25
|
+
*
|
|
26
|
+
* @param action - The action to sign
|
|
27
|
+
* @param resultingStateHash - The predicted hash of document state AFTER this action runs
|
|
28
|
+
* @param abortSignal - Optional abort signal
|
|
29
|
+
* @returns A Signature tuple with the resulting hash encoded in element [3]
|
|
30
|
+
*/
|
|
31
|
+
signActionWithResultingState(action: Action, resultingStateHash: string, abortSignal?: AbortSignal): Promise<Signature>;
|
|
32
|
+
/**
|
|
33
|
+
* Internal signing implementation shared by signAction and signActionWithResultingState.
|
|
34
|
+
*/
|
|
35
|
+
private _signAction;
|
|
16
36
|
private hashAction;
|
|
17
37
|
private buildSignatureMessage;
|
|
18
38
|
private arrayBufferToHex;
|
|
@@ -23,4 +43,32 @@ export declare class RenownCryptoSigner implements ISigner {
|
|
|
23
43
|
* The verification uses ECDSA with P-256 curve and SHA-256 hash, matching the RenownCrypto signing algorithm.
|
|
24
44
|
*/
|
|
25
45
|
export declare function createSignatureVerifier(): SignatureVerificationHandler;
|
|
46
|
+
/**
|
|
47
|
+
* Parses the hash field (element [3]) from a signature tuple.
|
|
48
|
+
*
|
|
49
|
+
* Supports two formats:
|
|
50
|
+
* - Old format: just `prevStateHash` (no colon)
|
|
51
|
+
* - New format: `prevStateHash:resultingStateHash` (colon-separated)
|
|
52
|
+
*
|
|
53
|
+
* @param hashField - The 4th element of a Signature tuple
|
|
54
|
+
* @returns Object with prevStateHash and optional resultingStateHash
|
|
55
|
+
*/
|
|
56
|
+
export declare function parseSignatureHashField(hashField: string): {
|
|
57
|
+
prevStateHash: string;
|
|
58
|
+
resultingStateHash: string | undefined;
|
|
59
|
+
};
|
|
60
|
+
/**
|
|
61
|
+
* Extracts the resulting state hash from a signature, if present.
|
|
62
|
+
*
|
|
63
|
+
* @param signature - A Signature tuple
|
|
64
|
+
* @returns The resulting state hash, or undefined if not present
|
|
65
|
+
*/
|
|
66
|
+
export declare function extractResultingHashFromSignature(signature: Signature): string | undefined;
|
|
67
|
+
/**
|
|
68
|
+
* Checks if a signature includes a resulting state hash.
|
|
69
|
+
*
|
|
70
|
+
* @param signature - A Signature tuple
|
|
71
|
+
* @returns true if the signature includes a resulting state hash
|
|
72
|
+
*/
|
|
73
|
+
export declare function signatureHasResultingHash(signature: Signature): boolean;
|
|
26
74
|
//# sourceMappingURL=signer.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../../src/crypto/signer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,MAAM,EACN,eAAe,EACf,OAAO,EAEP,SAAS,EACT,4BAA4B,EAC5B,gBAAgB,EACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEhD,qBAAa,qBAAsB,SAAQ,KAAK;;CAI/C;AAED,qBAAa,kBAAmB,YAAW,OAAO;IAI9C,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACjB,IAAI,CAAC,EAAE,gBAAgB;IALhC,QAAQ,CAAC,GAAG,EAAE,eAAe,CAAC;gBAGX,MAAM,EAAE,aAAa,EACrB,OAAO,EAAE,MAAM,EACzB,IAAI,CAAC,EAAE,gBAAgB,YAAA;IAQhC,IAAI,SAAS,cAEZ;IAEK,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;IAI3C,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAO9D,UAAU,CACd,MAAM,EAAE,MAAM,EACd,WAAW,CAAC,EAAE,WAAW,GACxB,OAAO,CAAC,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"signer.d.ts","sourceRoot":"","sources":["../../../src/crypto/signer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,MAAM,EACN,eAAe,EACf,OAAO,EAEP,SAAS,EACT,4BAA4B,EAC5B,gBAAgB,EACjB,MAAM,gBAAgB,CAAC;AACxB,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEhD,qBAAa,qBAAsB,SAAQ,KAAK;;CAI/C;AAED,qBAAa,kBAAmB,YAAW,OAAO;IAI9C,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,OAAO;IACjB,IAAI,CAAC,EAAE,gBAAgB;IALhC,QAAQ,CAAC,GAAG,EAAE,eAAe,CAAC;gBAGX,MAAM,EAAE,aAAa,EACrB,OAAO,EAAE,MAAM,EACzB,IAAI,CAAC,EAAE,gBAAgB,YAAA;IAQhC,IAAI,SAAS,cAEZ;IAEK,IAAI,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;IAI3C,MAAM,CAAC,IAAI,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC;IAO9D,UAAU,CACd,MAAM,EAAE,MAAM,EACd,WAAW,CAAC,EAAE,WAAW,GACxB,OAAO,CAAC,SAAS,CAAC;IAKrB;;;;;;;;;;;;;;OAcG;IACG,4BAA4B,CAChC,MAAM,EAAE,MAAM,EACd,kBAAkB,EAAE,MAAM,EAC1B,WAAW,CAAC,EAAE,WAAW,GACxB,OAAO,CAAC,SAAS,CAAC;IAMrB;;OAEG;YACW,WAAW;YAiCX,UAAU;IAYxB,OAAO,CAAC,qBAAqB;IAS7B,OAAO,CAAC,gBAAgB;IAQxB,OAAO,CAAC,mBAAmB;CAQ5B;AAED;;;GAGG;AACH,wBAAgB,uBAAuB,IAAI,4BAA4B,CAuCtE;AA+JD;;;;;;;;;GASG;AACH,wBAAgB,uBAAuB,CAAC,SAAS,EAAE,MAAM,GAAG;IAC1D,aAAa,EAAE,MAAM,CAAC;IACtB,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;CACxC,CAcA;AAED;;;;;GAKG;AACH,wBAAgB,iCAAiC,CAC/C,SAAS,EAAE,SAAS,GACnB,MAAM,GAAG,SAAS,CAIpB;AAED;;;;;GAKG;AACH,wBAAgB,yBAAyB,CAAC,SAAS,EAAE,SAAS,GAAG,OAAO,CAEvE"}
|
|
@@ -30,6 +30,33 @@ export class RenownCryptoSigner {
|
|
|
30
30
|
}
|
|
31
31
|
}
|
|
32
32
|
async signAction(action, abortSignal) {
|
|
33
|
+
const hashField = action.context?.prevOpHash ?? "";
|
|
34
|
+
return this._signAction(action, hashField, abortSignal);
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* Signs an action including a predicted resulting state hash.
|
|
38
|
+
*
|
|
39
|
+
* The resulting hash is packed into the signature tuple's 4th element (index 3)
|
|
40
|
+
* using the format: `${prevStateHash}:${resultingStateHash}`
|
|
41
|
+
*
|
|
42
|
+
* This allows offline verification of documents without reducer logic:
|
|
43
|
+
* - Verifier can check that the signature is valid for the claimed resulting state
|
|
44
|
+
* - Verifier can compare claimed resulting state to actual operation.hash
|
|
45
|
+
*
|
|
46
|
+
* @param action - The action to sign
|
|
47
|
+
* @param resultingStateHash - The predicted hash of document state AFTER this action runs
|
|
48
|
+
* @param abortSignal - Optional abort signal
|
|
49
|
+
* @returns A Signature tuple with the resulting hash encoded in element [3]
|
|
50
|
+
*/
|
|
51
|
+
async signActionWithResultingState(action, resultingStateHash, abortSignal) {
|
|
52
|
+
const prevStateHash = action.context?.prevOpHash ?? "";
|
|
53
|
+
const hashField = `${prevStateHash}:${resultingStateHash}`;
|
|
54
|
+
return this._signAction(action, hashField, abortSignal);
|
|
55
|
+
}
|
|
56
|
+
/**
|
|
57
|
+
* Internal signing implementation shared by signAction and signActionWithResultingState.
|
|
58
|
+
*/
|
|
59
|
+
async _signAction(action, hashField, abortSignal) {
|
|
33
60
|
if (abortSignal?.aborted) {
|
|
34
61
|
throw new Error("Signing aborted");
|
|
35
62
|
}
|
|
@@ -38,12 +65,11 @@ export class RenownCryptoSigner {
|
|
|
38
65
|
if (abortSignal?.aborted) {
|
|
39
66
|
throw new Error("Signing aborted");
|
|
40
67
|
}
|
|
41
|
-
const prevStateHash = action.context?.prevOpHash ?? "";
|
|
42
68
|
const params = [
|
|
43
69
|
timestamp,
|
|
44
70
|
this.crypto.did,
|
|
45
71
|
hash,
|
|
46
|
-
|
|
72
|
+
hashField,
|
|
47
73
|
];
|
|
48
74
|
const message = this.buildSignatureMessage(params);
|
|
49
75
|
const signatureBytes = await this.crypto.sign(message);
|
|
@@ -234,4 +260,47 @@ function bigIntToBytes(n, length) {
|
|
|
234
260
|
}
|
|
235
261
|
return bytes;
|
|
236
262
|
}
|
|
263
|
+
/**
|
|
264
|
+
* Parses the hash field (element [3]) from a signature tuple.
|
|
265
|
+
*
|
|
266
|
+
* Supports two formats:
|
|
267
|
+
* - Old format: just `prevStateHash` (no colon)
|
|
268
|
+
* - New format: `prevStateHash:resultingStateHash` (colon-separated)
|
|
269
|
+
*
|
|
270
|
+
* @param hashField - The 4th element of a Signature tuple
|
|
271
|
+
* @returns Object with prevStateHash and optional resultingStateHash
|
|
272
|
+
*/
|
|
273
|
+
export function parseSignatureHashField(hashField) {
|
|
274
|
+
const colonIndex = hashField.indexOf(":");
|
|
275
|
+
if (colonIndex === -1) {
|
|
276
|
+
return {
|
|
277
|
+
prevStateHash: hashField,
|
|
278
|
+
resultingStateHash: undefined,
|
|
279
|
+
};
|
|
280
|
+
}
|
|
281
|
+
return {
|
|
282
|
+
prevStateHash: hashField.substring(0, colonIndex),
|
|
283
|
+
resultingStateHash: hashField.substring(colonIndex + 1),
|
|
284
|
+
};
|
|
285
|
+
}
|
|
286
|
+
/**
|
|
287
|
+
* Extracts the resulting state hash from a signature, if present.
|
|
288
|
+
*
|
|
289
|
+
* @param signature - A Signature tuple
|
|
290
|
+
* @returns The resulting state hash, or undefined if not present
|
|
291
|
+
*/
|
|
292
|
+
export function extractResultingHashFromSignature(signature) {
|
|
293
|
+
const hashField = signature[3];
|
|
294
|
+
const { resultingStateHash } = parseSignatureHashField(hashField);
|
|
295
|
+
return resultingStateHash;
|
|
296
|
+
}
|
|
297
|
+
/**
|
|
298
|
+
* Checks if a signature includes a resulting state hash.
|
|
299
|
+
*
|
|
300
|
+
* @param signature - A Signature tuple
|
|
301
|
+
* @returns true if the signature includes a resulting state hash
|
|
302
|
+
*/
|
|
303
|
+
export function signatureHasResultingHash(signature) {
|
|
304
|
+
return extractResultingHashFromSignature(signature) !== undefined;
|
|
305
|
+
}
|
|
237
306
|
//# sourceMappingURL=signer.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"signer.js","sourceRoot":"","sources":["../../../src/crypto/signer.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"signer.js","sourceRoot":"","sources":["../../../src/crypto/signer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signer.test.d.ts","sourceRoot":"","sources":["../../../test/crypto/signer.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import { MemoryKeyStorage, RenownCryptoBuilder, RenownCryptoSigner, createSignatureVerifier, parseSignatureHashField, extractResultingHashFromSignature, signatureHasResultingHash, } from "../../src/crypto/index.js";
|
|
2
|
+
import { deriveOperationId } from "document-model/core";
|
|
3
|
+
import { beforeEach, describe, expect, it } from "vitest";
|
|
4
|
+
const TEST_DOC_ID = "test-doc-id";
|
|
5
|
+
const TEST_BRANCH = "main";
|
|
6
|
+
const TEST_SCOPE = "global";
|
|
7
|
+
function createTestAction(options) {
|
|
8
|
+
return {
|
|
9
|
+
id: "action-1",
|
|
10
|
+
type: "TEST_ACTION",
|
|
11
|
+
timestampUtcMs: new Date().toISOString(),
|
|
12
|
+
input: { foo: "bar" },
|
|
13
|
+
scope: "global",
|
|
14
|
+
context: options?.prevOpHash
|
|
15
|
+
? { prevOpHash: options.prevOpHash }
|
|
16
|
+
: undefined,
|
|
17
|
+
};
|
|
18
|
+
}
|
|
19
|
+
function createOperationWithSignature(action, signature, did) {
|
|
20
|
+
const signedAction = {
|
|
21
|
+
...action,
|
|
22
|
+
context: {
|
|
23
|
+
...action.context,
|
|
24
|
+
signer: {
|
|
25
|
+
user: { address: did, chainId: 1, networkId: "eip155" },
|
|
26
|
+
app: { name: "test-app", key: did },
|
|
27
|
+
signatures: [signature],
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
return {
|
|
32
|
+
id: deriveOperationId(TEST_DOC_ID, TEST_SCOPE, TEST_BRANCH, signedAction.id),
|
|
33
|
+
index: 0,
|
|
34
|
+
timestampUtcMs: action.timestampUtcMs,
|
|
35
|
+
hash: "",
|
|
36
|
+
skip: 0,
|
|
37
|
+
action: signedAction,
|
|
38
|
+
};
|
|
39
|
+
}
|
|
40
|
+
describe("RenownCryptoSigner", () => {
|
|
41
|
+
let keyStorage;
|
|
42
|
+
let renownCrypto;
|
|
43
|
+
let signer;
|
|
44
|
+
let verifier;
|
|
45
|
+
beforeEach(async () => {
|
|
46
|
+
keyStorage = new MemoryKeyStorage();
|
|
47
|
+
renownCrypto = await new RenownCryptoBuilder()
|
|
48
|
+
.withKeyPairStorage(keyStorage)
|
|
49
|
+
.build();
|
|
50
|
+
signer = new RenownCryptoSigner(renownCrypto, "test-app");
|
|
51
|
+
verifier = createSignatureVerifier();
|
|
52
|
+
});
|
|
53
|
+
describe("signActionWithResultingState", () => {
|
|
54
|
+
it("should include resultingStateHash in signature element [3]", async () => {
|
|
55
|
+
const action = createTestAction();
|
|
56
|
+
const resultingHash = "resulting-hash-abc123";
|
|
57
|
+
const signature = await signer.signActionWithResultingState(action, resultingHash);
|
|
58
|
+
expect(signature).toHaveLength(5);
|
|
59
|
+
expect(signature[3]).toContain(":");
|
|
60
|
+
expect(signature[3]).toContain(resultingHash);
|
|
61
|
+
});
|
|
62
|
+
it("should format hashField as prevStateHash:resultingStateHash", async () => {
|
|
63
|
+
const action = createTestAction({ prevOpHash: "prev-hash-xyz" });
|
|
64
|
+
const resultingHash = "resulting-hash-abc123";
|
|
65
|
+
const signature = await signer.signActionWithResultingState(action, resultingHash);
|
|
66
|
+
expect(signature[3]).toBe("prev-hash-xyz:resulting-hash-abc123");
|
|
67
|
+
});
|
|
68
|
+
it("should handle empty prevStateHash", async () => {
|
|
69
|
+
const action = createTestAction(); // no prevOpHash
|
|
70
|
+
const resultingHash = "resulting-hash-abc123";
|
|
71
|
+
const signature = await signer.signActionWithResultingState(action, resultingHash);
|
|
72
|
+
expect(signature[3]).toBe(":resulting-hash-abc123");
|
|
73
|
+
});
|
|
74
|
+
it("should produce verifiable signatures", async () => {
|
|
75
|
+
const action = createTestAction();
|
|
76
|
+
const resultingHash = "resulting-hash-abc123";
|
|
77
|
+
const signature = await signer.signActionWithResultingState(action, resultingHash);
|
|
78
|
+
// The signature should still be cryptographically valid
|
|
79
|
+
// (verification rebuilds message from params[0-3])
|
|
80
|
+
const operation = createOperationWithSignature(action, signature, signer.app.key);
|
|
81
|
+
const result = await verifier(operation, signer.app.key);
|
|
82
|
+
expect(result).toBe(true);
|
|
83
|
+
});
|
|
84
|
+
it("should abort when signal is aborted before starting", async () => {
|
|
85
|
+
const action = createTestAction();
|
|
86
|
+
const controller = new AbortController();
|
|
87
|
+
controller.abort();
|
|
88
|
+
await expect(signer.signActionWithResultingState(action, "hash", controller.signal)).rejects.toThrow("Signing aborted");
|
|
89
|
+
});
|
|
90
|
+
it("should produce different signatures than signAction for same action", async () => {
|
|
91
|
+
const action = createTestAction({ prevOpHash: "prev-hash" });
|
|
92
|
+
const resultingHash = "resulting-hash";
|
|
93
|
+
const sig1 = await signer.signAction(action);
|
|
94
|
+
const sig2 = await signer.signActionWithResultingState(action, resultingHash);
|
|
95
|
+
// Element [3] should differ
|
|
96
|
+
expect(sig1[3]).toBe("prev-hash");
|
|
97
|
+
expect(sig2[3]).toBe("prev-hash:resulting-hash");
|
|
98
|
+
// Signature hex [4] should differ (different message signed)
|
|
99
|
+
expect(sig1[4]).not.toBe(sig2[4]);
|
|
100
|
+
});
|
|
101
|
+
it("should handle empty resultingStateHash", async () => {
|
|
102
|
+
const action = createTestAction({ prevOpHash: "prev-hash" });
|
|
103
|
+
const signature = await signer.signActionWithResultingState(action, "");
|
|
104
|
+
expect(signature[3]).toBe("prev-hash:");
|
|
105
|
+
});
|
|
106
|
+
it("should handle both empty hashes", async () => {
|
|
107
|
+
const action = createTestAction(); // no prevOpHash
|
|
108
|
+
const signature = await signer.signActionWithResultingState(action, "");
|
|
109
|
+
expect(signature[3]).toBe(":");
|
|
110
|
+
});
|
|
111
|
+
it("should include valid timestamp", async () => {
|
|
112
|
+
const action = createTestAction();
|
|
113
|
+
const beforeTimestamp = Math.floor(Date.now() / 1000);
|
|
114
|
+
const signature = await signer.signActionWithResultingState(action, "hash");
|
|
115
|
+
// Allow 2 second tolerance for timing variations
|
|
116
|
+
const afterTimestamp = Math.floor(Date.now() / 1000) + 2;
|
|
117
|
+
const signatureTimestamp = parseInt(signature[0], 10);
|
|
118
|
+
expect(signatureTimestamp).toBeGreaterThanOrEqual(beforeTimestamp);
|
|
119
|
+
expect(signatureTimestamp).toBeLessThanOrEqual(afterTimestamp);
|
|
120
|
+
});
|
|
121
|
+
it("should include signer DID in element [1]", async () => {
|
|
122
|
+
const action = createTestAction();
|
|
123
|
+
const signature = await signer.signActionWithResultingState(action, "hash");
|
|
124
|
+
expect(signature[1]).toBe(renownCrypto.did);
|
|
125
|
+
expect(signature[1].startsWith("did:key:z")).toBe(true);
|
|
126
|
+
});
|
|
127
|
+
it("should include action hash in element [2]", async () => {
|
|
128
|
+
const action = createTestAction();
|
|
129
|
+
const signature = await signer.signActionWithResultingState(action, "hash");
|
|
130
|
+
// Hash should be a non-empty base64 string
|
|
131
|
+
expect(signature[2]).toBeDefined();
|
|
132
|
+
expect(signature[2].length).toBeGreaterThan(0);
|
|
133
|
+
});
|
|
134
|
+
it("should include hex signature in element [4]", async () => {
|
|
135
|
+
const action = createTestAction();
|
|
136
|
+
const signature = await signer.signActionWithResultingState(action, "hash");
|
|
137
|
+
expect(signature[4].startsWith("0x")).toBe(true);
|
|
138
|
+
expect(signature[4].length).toBeGreaterThan(2);
|
|
139
|
+
});
|
|
140
|
+
});
|
|
141
|
+
});
|
|
142
|
+
describe("parseSignatureHashField", () => {
|
|
143
|
+
it("should parse old format (no resulting hash)", () => {
|
|
144
|
+
const result = parseSignatureHashField("prev-hash-abc");
|
|
145
|
+
expect(result.prevStateHash).toBe("prev-hash-abc");
|
|
146
|
+
expect(result.resultingStateHash).toBeUndefined();
|
|
147
|
+
});
|
|
148
|
+
it("should parse new format (with resulting hash)", () => {
|
|
149
|
+
const result = parseSignatureHashField("prev-hash:resulting-hash");
|
|
150
|
+
expect(result.prevStateHash).toBe("prev-hash");
|
|
151
|
+
expect(result.resultingStateHash).toBe("resulting-hash");
|
|
152
|
+
});
|
|
153
|
+
it("should handle empty prevStateHash", () => {
|
|
154
|
+
const result = parseSignatureHashField(":resulting-hash");
|
|
155
|
+
expect(result.prevStateHash).toBe("");
|
|
156
|
+
expect(result.resultingStateHash).toBe("resulting-hash");
|
|
157
|
+
});
|
|
158
|
+
it("should handle empty string", () => {
|
|
159
|
+
const result = parseSignatureHashField("");
|
|
160
|
+
expect(result.prevStateHash).toBe("");
|
|
161
|
+
expect(result.resultingStateHash).toBeUndefined();
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
describe("extractResultingHashFromSignature", () => {
|
|
165
|
+
it("should return undefined for old format signatures", () => {
|
|
166
|
+
const signature = ["ts", "did", "hash", "prevHash", "0xsig"];
|
|
167
|
+
expect(extractResultingHashFromSignature(signature)).toBeUndefined();
|
|
168
|
+
});
|
|
169
|
+
it("should return resulting hash for new format signatures", () => {
|
|
170
|
+
const signature = ["ts", "did", "hash", "prev:result", "0xsig"];
|
|
171
|
+
expect(extractResultingHashFromSignature(signature)).toBe("result");
|
|
172
|
+
});
|
|
173
|
+
});
|
|
174
|
+
describe("signatureHasResultingHash", () => {
|
|
175
|
+
it("should return false for old format", () => {
|
|
176
|
+
const signature = ["ts", "did", "hash", "prevHash", "0xsig"];
|
|
177
|
+
expect(signatureHasResultingHash(signature)).toBe(false);
|
|
178
|
+
});
|
|
179
|
+
it("should return true for new format", () => {
|
|
180
|
+
const signature = ["ts", "did", "hash", "prev:result", "0xsig"];
|
|
181
|
+
expect(signatureHasResultingHash(signature)).toBe(true);
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
//# sourceMappingURL=signer.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"signer.test.js","sourceRoot":"","sources":["../../../test/crypto/signer.test.ts"],"names":[],"mappings":"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"}
|
package/dist/test/script.test.js
CHANGED
|
@@ -1,23 +1,28 @@
|
|
|
1
1
|
import { ReactorBuilder, ReactorClientBuilder } from "@powerhousedao/reactor";
|
|
2
|
-
import {
|
|
3
|
-
import { documentModelDocumentModelModule, setName, } from "document-model";
|
|
2
|
+
import { MemoryKeyStorage, RenownCryptoBuilder, RenownCryptoSigner, } from "@renown/sdk/node";
|
|
3
|
+
import { actions, documentModelDocumentModelModule, setName, } from "document-model";
|
|
4
4
|
import { describe, expect, it } from "vitest";
|
|
5
5
|
describe("Renown on script", () => {
|
|
6
6
|
it("should create a document and add a signed SET_NAME action", async () => {
|
|
7
|
-
//
|
|
8
|
-
const
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
7
|
+
// Create user directly (parsed from DID format)
|
|
8
|
+
const testUser = {
|
|
9
|
+
address: "0x9aDdcBbaA28F7eB5f75E023F7C1Fcb13C9DFD8F7",
|
|
10
|
+
networkId: "eip155",
|
|
11
|
+
chainId: 1,
|
|
12
|
+
};
|
|
13
|
+
// Create signer without network access
|
|
14
|
+
const keyStorage = new MemoryKeyStorage();
|
|
15
|
+
const crypto = await new RenownCryptoBuilder()
|
|
16
|
+
.withKeyPairStorage(keyStorage)
|
|
17
|
+
.build();
|
|
18
|
+
const signer = new RenownCryptoSigner(crypto, "script", testUser);
|
|
14
19
|
// Build reactor
|
|
15
20
|
const reactorBuilder = new ReactorBuilder().withDocumentModels([
|
|
16
21
|
documentModelDocumentModelModule,
|
|
17
22
|
]);
|
|
18
23
|
const reactorClient = await new ReactorClientBuilder()
|
|
19
24
|
.withReactorBuilder(reactorBuilder)
|
|
20
|
-
.withSigner(
|
|
25
|
+
.withSigner(signer)
|
|
21
26
|
.build();
|
|
22
27
|
// Create new document
|
|
23
28
|
const document = await reactorClient.createEmpty("powerhouse/document-model");
|
|
@@ -29,7 +34,7 @@ describe("Renown on script", () => {
|
|
|
29
34
|
const operation = result.operations.global[0];
|
|
30
35
|
const actionSigner = operation.action.context?.signer;
|
|
31
36
|
expect(actionSigner?.app).toStrictEqual({
|
|
32
|
-
key:
|
|
37
|
+
key: crypto.did,
|
|
33
38
|
name: "script",
|
|
34
39
|
});
|
|
35
40
|
expect(actionSigner?.user).toStrictEqual({
|
|
@@ -41,5 +46,99 @@ describe("Renown on script", () => {
|
|
|
41
46
|
.flat()
|
|
42
47
|
.filter((sig) => sig.length > 0).length).toBeGreaterThan(0);
|
|
43
48
|
});
|
|
49
|
+
it("should NOT overwrite pre-signed actions with resulting-state-hash format", async () => {
|
|
50
|
+
// Create a test user that both signers will share
|
|
51
|
+
const testUser = {
|
|
52
|
+
address: "0x9aDdcBbaA28F7eB5f75E023F7C1Fcb13C9DFD8F7",
|
|
53
|
+
networkId: "eip155",
|
|
54
|
+
chainId: 1,
|
|
55
|
+
};
|
|
56
|
+
// Create two Renown signers with different keys (no network access needed)
|
|
57
|
+
const keyStorageA = new MemoryKeyStorage();
|
|
58
|
+
const cryptoA = await new RenownCryptoBuilder()
|
|
59
|
+
.withKeyPairStorage(keyStorageA)
|
|
60
|
+
.build();
|
|
61
|
+
const signerA = new RenownCryptoSigner(cryptoA, "scriptA", testUser);
|
|
62
|
+
const keyStorageB = new MemoryKeyStorage();
|
|
63
|
+
const cryptoB = await new RenownCryptoBuilder()
|
|
64
|
+
.withKeyPairStorage(keyStorageB)
|
|
65
|
+
.build();
|
|
66
|
+
const signerB = new RenownCryptoSigner(cryptoB, "scriptB", testUser);
|
|
67
|
+
// Verify different app DIDs (different keypairs = different DIDs)
|
|
68
|
+
expect(signerA.app.key).not.toBe(signerB.app.key);
|
|
69
|
+
// Build ReactorClient with signerB
|
|
70
|
+
const reactorBuilder = new ReactorBuilder().withDocumentModels([
|
|
71
|
+
documentModelDocumentModelModule,
|
|
72
|
+
]);
|
|
73
|
+
const reactorClient = await new ReactorClientBuilder()
|
|
74
|
+
.withReactorBuilder(reactorBuilder)
|
|
75
|
+
.withSigner(signerB)
|
|
76
|
+
.build();
|
|
77
|
+
// Create a document
|
|
78
|
+
const doc = await reactorClient.createEmpty("powerhouse/document-model");
|
|
79
|
+
// Step 1: Execute a FIRST action normally to establish a real prevOpHash
|
|
80
|
+
// This creates operation 0 with a real resulting state hash
|
|
81
|
+
await reactorClient.execute(doc.header.id, "main", [setName("First Name")]);
|
|
82
|
+
// Get the latest operation from the store
|
|
83
|
+
const operations = await reactorClient.getOperations(doc.header.id, {
|
|
84
|
+
scopes: ["global"],
|
|
85
|
+
});
|
|
86
|
+
const latestOp = operations.results[operations.results.length - 1];
|
|
87
|
+
// operation.hash IS the state hash (hash of document.state after this operation)
|
|
88
|
+
const prevOpHash = latestOp.hash;
|
|
89
|
+
// Step 2: For the SECOND action, pre-sign it with signerA
|
|
90
|
+
// Now we have a real prevOpHash to use in the signature
|
|
91
|
+
const secondAction = actions.setName("Second Name");
|
|
92
|
+
// For resultingStateHash, we predict what the state will be after this action.
|
|
93
|
+
// In a real script, you'd run the reducer locally to compute this.
|
|
94
|
+
// For this test, we use the prevOpHash as a stand-in (it's a real hash format).
|
|
95
|
+
// The key is testing signature PRESERVATION, not hash validation.
|
|
96
|
+
const predictedResultingHash = prevOpHash; // Use real hash format for testing
|
|
97
|
+
// Create the action with prevOpHash in context (required for signature)
|
|
98
|
+
const actionWithContext = {
|
|
99
|
+
...secondAction,
|
|
100
|
+
context: {
|
|
101
|
+
...secondAction.context,
|
|
102
|
+
prevOpHash,
|
|
103
|
+
},
|
|
104
|
+
};
|
|
105
|
+
const signatureA = await signerA.signActionWithResultingState(actionWithContext, predictedResultingHash);
|
|
106
|
+
// Verify signature has resulting-hash format: "prevOpHash:resultingHash"
|
|
107
|
+
expect(signatureA[3]).toContain(":");
|
|
108
|
+
expect(signatureA[3]).toBe(`${prevOpHash}:${predictedResultingHash}`);
|
|
109
|
+
const preSignedAction = {
|
|
110
|
+
...actionWithContext,
|
|
111
|
+
context: {
|
|
112
|
+
...actionWithContext.context,
|
|
113
|
+
signer: {
|
|
114
|
+
user: signerA.user,
|
|
115
|
+
app: signerA.app,
|
|
116
|
+
signatures: [signatureA],
|
|
117
|
+
},
|
|
118
|
+
},
|
|
119
|
+
};
|
|
120
|
+
// Verify the preSignedAction has the signature before executing
|
|
121
|
+
expect(preSignedAction.context?.signer?.signatures).toHaveLength(1);
|
|
122
|
+
expect(preSignedAction.context?.signer?.app.key).toBe(signerA.app.key);
|
|
123
|
+
// Step 3: Execute the pre-signed action via ReactorClient (which uses signerB)
|
|
124
|
+
await reactorClient.execute(doc.header.id, "main", [preSignedAction]);
|
|
125
|
+
// Get the second operation from the store
|
|
126
|
+
const allOperations = await reactorClient.getOperations(doc.header.id, {
|
|
127
|
+
scopes: ["global"],
|
|
128
|
+
});
|
|
129
|
+
const secondOp = allOperations.results[1]; // Second SET_NAME operation
|
|
130
|
+
const opSigner = secondOp.action.context?.signer;
|
|
131
|
+
expect(opSigner).toBeDefined();
|
|
132
|
+
// Signature should be from signerA, not signerB
|
|
133
|
+
expect(opSigner?.app.key).toBe(signerA.app.key);
|
|
134
|
+
expect(opSigner?.app.key).not.toBe(signerB.app.key);
|
|
135
|
+
// Should have exactly one signature (the original from signerA)
|
|
136
|
+
expect(opSigner?.signatures).toHaveLength(1);
|
|
137
|
+
// Signature should be byte-for-byte identical to signatureA
|
|
138
|
+
expect(opSigner?.signatures[0]).toEqual(signatureA);
|
|
139
|
+
// Verify the resulting-hash format is preserved: "prevOpHash:predictedResultingHash"
|
|
140
|
+
expect(opSigner?.signatures[0][3]).toContain(":");
|
|
141
|
+
expect(opSigner?.signatures[0][3]).toBe(`${prevOpHash}:${predictedResultingHash}`);
|
|
142
|
+
});
|
|
44
143
|
});
|
|
45
144
|
//# sourceMappingURL=script.test.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"script.test.js","sourceRoot":"","sources":["../../test/script.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,oBAAoB,EAAE,MAAM,wBAAwB,CAAC;AAC9E,OAAO,
|
|
1
|
+
{"version":3,"file":"script.test.js","sourceRoot":"","sources":["../../test/script.test.ts"],"names":[],"mappings":"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"}
|