@0xsequence/wallet-core 3.0.0-beta.17 → 3.0.0-beta.19
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/.turbo/turbo-lint.log +4 -0
- package/.turbo/turbo-typecheck.log +4 -0
- package/CHANGELOG.md +20 -0
- package/dist/bundler/bundlers/pimlico.d.ts +1 -1
- package/dist/bundler/bundlers/pimlico.d.ts.map +1 -1
- package/dist/bundler/bundlers/pimlico.js +1 -1
- package/dist/signers/index.d.ts +1 -1
- package/dist/signers/passkey.d.ts +1 -1
- package/dist/signers/pk/index.d.ts +1 -1
- package/dist/signers/session/explicit.d.ts.map +1 -1
- package/dist/signers/session/explicit.js +2 -2
- package/dist/signers/session/implicit.d.ts.map +1 -1
- package/dist/signers/session/implicit.js +1 -1
- package/dist/state/local/index.d.ts.map +1 -1
- package/dist/state/local/index.js +3 -2
- package/dist/state/remote/dev-http.js +3 -3
- package/dist/state/sequence/index.d.ts.map +1 -1
- package/dist/state/sequence/index.js +8 -3
- package/dist/wallet.js +2 -2
- package/eslint.config.js +12 -0
- package/package.json +12 -10
- package/src/bundler/bundlers/pimlico.ts +2 -2
- package/src/signers/index.ts +1 -1
- package/src/signers/passkey.ts +1 -1
- package/src/signers/pk/index.ts +1 -1
- package/src/signers/session/explicit.ts +2 -9
- package/src/signers/session/implicit.ts +1 -2
- package/src/state/local/index.ts +4 -2
- package/src/state/remote/dev-http.ts +3 -3
- package/src/state/sequence/index.ts +8 -3
- package/src/wallet.ts +2 -2
- package/test/constants.ts +2 -0
- package/test/envelope.test.ts +0 -1
- package/test/signers-pk.test.ts +1 -1
- package/test/signers-session-implicit.test.ts +0 -2
- package/test/state/debug.test.ts +2 -3
package/.turbo/turbo-build.log
CHANGED
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,25 @@
|
|
|
1
1
|
# @0xsequence/wallet-core
|
|
2
2
|
|
|
3
|
+
## 3.0.0-beta.19
|
|
4
|
+
|
|
5
|
+
### Patch Changes
|
|
6
|
+
|
|
7
|
+
- Final RC before 3.0.0
|
|
8
|
+
- Updated dependencies
|
|
9
|
+
- @0xsequence/guard@3.0.0-beta.19
|
|
10
|
+
- @0xsequence/relayer@3.0.0-beta.19
|
|
11
|
+
- @0xsequence/wallet-primitives@3.0.0-beta.19
|
|
12
|
+
|
|
13
|
+
## 3.0.0-beta.18
|
|
14
|
+
|
|
15
|
+
### Patch Changes
|
|
16
|
+
|
|
17
|
+
- multicall3 optimization
|
|
18
|
+
- Updated dependencies
|
|
19
|
+
- @0xsequence/guard@3.0.0-beta.18
|
|
20
|
+
- @0xsequence/relayer@3.0.0-beta.18
|
|
21
|
+
- @0xsequence/wallet-primitives@3.0.0-beta.18
|
|
22
|
+
|
|
3
23
|
## 3.0.0-beta.17
|
|
4
24
|
|
|
5
25
|
### Patch Changes
|
|
@@ -4,7 +4,7 @@ import { Provider, Hex, Address } from 'ox';
|
|
|
4
4
|
import { UserOperation } from 'ox/erc4337';
|
|
5
5
|
import { Relayer } from '@0xsequence/relayer';
|
|
6
6
|
export declare class PimlicoBundler implements Bundler {
|
|
7
|
-
readonly kind
|
|
7
|
+
readonly kind = "bundler";
|
|
8
8
|
readonly id: string;
|
|
9
9
|
readonly provider: Provider.Provider;
|
|
10
10
|
readonly bundlerRpcUrl: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"pimlico.d.ts","sourceRoot":"","sources":["../../../src/bundler/bundlers/pimlico.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAA;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,OAAO,EAAgB,MAAM,IAAI,CAAA;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAA;AAa7C,qBAAa,cAAe,YAAW,OAAO;IAC5C,SAAgB,IAAI,
|
|
1
|
+
{"version":3,"file":"pimlico.d.ts","sourceRoot":"","sources":["../../../src/bundler/bundlers/pimlico.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,+BAA+B,CAAA;AACvD,OAAO,EAAE,OAAO,EAAE,MAAM,eAAe,CAAA;AACvC,OAAO,EAAE,QAAQ,EAAE,GAAG,EAAE,OAAO,EAAgB,MAAM,IAAI,CAAA;AACzD,OAAO,EAAE,aAAa,EAAE,MAAM,YAAY,CAAA;AAC1C,OAAO,EAAE,OAAO,EAAE,MAAM,qBAAqB,CAAA;AAa7C,qBAAa,cAAe,YAAW,OAAO;IAC5C,SAAgB,IAAI,aAAY;IAChC,SAAgB,EAAE,EAAE,MAAM,CAAA;IAE1B,SAAgB,QAAQ,EAAE,QAAQ,CAAC,QAAQ,CAAA;IAC3C,SAAgB,aAAa,EAAE,MAAM,CAAA;IACrC,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAc;gBAE1B,aAAa,EAAE,MAAM,EAAE,QAAQ,EAAE,QAAQ,CAAC,QAAQ,GAAG,MAAM,EAAE,OAAO,CAAC,EAAE,OAAO,KAAK;IAWzF,WAAW,CAAC,UAAU,EAAE,OAAO,CAAC,OAAO,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAa3E,KAAK,CAAC,UAAU,EAAE,OAAO,CAAC,OAAO,EAAE,aAAa,EAAE,aAAa,CAAC,MAAM,GAAG,OAAO,CAAC;QAAE,MAAM,EAAE,GAAG,CAAC,GAAG,CAAA;KAAE,CAAC;IAKrG,cAAc,CAClB,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,OAAO,EAAE,OAAO,CAAC,YAAY,GAC5B,OAAO,CACR;QACE,KAAK,CAAC,EAAE,MAAM,GAAG,UAAU,GAAG,MAAM,CAAA;QACpC,OAAO,EAAE,OAAO,CAAC,YAAY,CAAA;KAC9B,EAAE,CACJ;IAgCD,OAAO,CAAC,4BAA4B;IAiB9B,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,GAAG,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,eAAe,CAAC;YA4DnE,UAAU;CAWzB"}
|
package/dist/signers/index.d.ts
CHANGED
|
@@ -16,7 +16,7 @@ export interface SapientSigner {
|
|
|
16
16
|
signSapient: (wallet: Address.Address, chainId: number, payload: Payload.Parented, imageHash: Hex.Hex) => Config.SignerSignature<Signature.SignatureOfSapientSignerLeaf>;
|
|
17
17
|
}
|
|
18
18
|
export interface Witnessable {
|
|
19
|
-
witness: (stateWriter: State.Writer, wallet: Address.Address, extra?:
|
|
19
|
+
witness: (stateWriter: State.Writer, wallet: Address.Address, extra?: object) => Promise<void>;
|
|
20
20
|
}
|
|
21
21
|
type MaybePromise<T> = T | Promise<T>;
|
|
22
22
|
export declare function isSapientSigner(signer: Signer | SapientSigner): signer is SapientSigner;
|
|
@@ -44,6 +44,6 @@ export declare class Passkey implements SapientSigner, Witnessable {
|
|
|
44
44
|
static create(extensions: Pick<Extensions.Extensions, 'passkeys'>, options?: CreatePasskeyOptions): Promise<Passkey>;
|
|
45
45
|
static find(stateReader: State.Reader, extensions: Pick<Extensions.Extensions, 'passkeys'>, options?: FindPasskeyOptions): Promise<Passkey | undefined>;
|
|
46
46
|
signSapient(wallet: Address.Address, chainId: number, payload: Payload.Parented, imageHash: Hex.Hex): Promise<SignatureTypes.SignatureOfSapientSignerLeaf>;
|
|
47
|
-
witness(stateWriter: State.Writer, wallet: Address.Address, extra?:
|
|
47
|
+
witness(stateWriter: State.Writer, wallet: Address.Address, extra?: object): Promise<void>;
|
|
48
48
|
}
|
|
49
49
|
//# sourceMappingURL=passkey.d.ts.map
|
|
@@ -29,7 +29,7 @@ export declare class Pk implements SignerInterface, Witnessable {
|
|
|
29
29
|
constructor(privateKey: Hex.Hex | PkStore);
|
|
30
30
|
sign(wallet: Address.Address, chainId: number, payload: PayloadTypes.Parented): Promise<SignatureTypes.SignatureOfSignerLeaf>;
|
|
31
31
|
signDigest(digest: Bytes.Bytes): Promise<SignatureTypes.SignatureOfSignerLeaf>;
|
|
32
|
-
witness(stateWriter: State.Writer, wallet: Address.Address, extra?:
|
|
32
|
+
witness(stateWriter: State.Writer, wallet: Address.Address, extra?: object): Promise<void>;
|
|
33
33
|
}
|
|
34
34
|
export * as Encrypted from './encrypted.js';
|
|
35
35
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"explicit.d.ts","sourceRoot":"","sources":["../../../src/signers/session/explicit.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"explicit.d.ts","sourceRoot":"","sources":["../../../src/signers/session/explicit.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,OAAO,EAAE,UAAU,EAAE,aAAa,EAAE,gBAAgB,EAAE,MAAM,+BAA+B,CAAA;AAC/G,OAAO,EAA8B,OAAO,EAAe,GAAG,EAAE,QAAQ,EAAE,MAAM,IAAI,CAAA;AACpF,OAAO,EAAiB,OAAO,EAAE,MAAM,gBAAgB,CAAA;AACvD,OAAO,EAAE,qBAAqB,EAAE,qBAAqB,EAAE,UAAU,EAAE,MAAM,cAAc,CAAA;AAEvF,MAAM,MAAM,cAAc,GAAG,IAAI,CAAC,UAAU,CAAC,kBAAkB,EAAE,QAAQ,CAAC,CAAA;AAI1E,qBAAa,QAAS,YAAW,qBAAqB;IACpD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IAErC,SAAgB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAA;IACxC,SAAgB,kBAAkB,EAAE,UAAU,CAAC,kBAAkB,CAAA;gBAErD,UAAU,EAAE,GAAG,CAAC,GAAG,GAAG,OAAO,EAAE,kBAAkB,EAAE,cAAc;IAS7E,OAAO,CAAC,eAAe,EAAE,aAAa,CAAC,gBAAgB,EAAE,OAAO,EAAE,MAAM,GAAG,qBAAqB;IA+C1F,uBAAuB,CAC3B,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,OAAO,CAAC,IAAI,EAClB,qBAAqB,EAAE,OAAO,CAAC,OAAO,EACtC,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ,GAC3B,OAAO,CAAC,UAAU,CAAC,UAAU,GAAG,SAAS,CAAC;IAmC7C,OAAO,CAAC,sBAAsB;IAmB9B,OAAO,CAAC,iBAAiB;IAYnB,kBAAkB,CACtB,UAAU,EAAE,UAAU,CAAC,UAAU,EACjC,IAAI,EAAE,OAAO,CAAC,IAAI,EAClB,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,qBAAqB,EAAE,OAAO,CAAC,OAAO,EACtC,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ,GAC3B,OAAO,CAAC,OAAO,CAAC;IAsDb,aAAa,CACjB,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,OAAO,EAAE,MAAM,EACf,IAAI,EAAE,OAAO,CAAC,IAAI,EAClB,qBAAqB,EAAE,OAAO,CAAC,OAAO,EACtC,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ,GAC3B,OAAO,CAAC,OAAO,CAAC;IAiBb,QAAQ,CACZ,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,CAAC,KAAK,EACtB,OAAO,EAAE,MAAM,EACf,qBAAqB,EAAE,OAAO,CAAC,OAAO,EACtC,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ,GAC3B,OAAO,CAAC,gBAAgB,CAAC,oBAAoB,CAAC;YAiCnC,qBAAqB;IAwB7B,iBAAiB,CACrB,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,OAAO,EAAE,MAAM,EACf,KAAK,EAAE,OAAO,CAAC,IAAI,EAAE,EACrB,qBAAqB,EAAE,OAAO,CAAC,OAAO,EACtC,QAAQ,EAAE,QAAQ,CAAC,QAAQ,GAC1B,OAAO,CAAC,UAAU,EAAE,CAAC;CA8EzB"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Constants, Permission, SessionConfig, SessionSignature
|
|
1
|
+
import { Constants, Permission, SessionConfig, SessionSignature } from '@0xsequence/wallet-primitives';
|
|
2
2
|
import { AbiFunction, AbiParameters, Address, Bytes, Hash, Hex } from 'ox';
|
|
3
3
|
import { MemoryPkStore } from '../pk/index.js';
|
|
4
4
|
const VALUE_TRACKING_ADDRESS = '0xEeeeeEeeeEeEeeEeEeEeeEEEeeeeEeeeeeeeEEeE';
|
|
@@ -220,7 +220,7 @@ export class Explicit {
|
|
|
220
220
|
}
|
|
221
221
|
// Extract the masked value
|
|
222
222
|
const callDataValue = Bytes.padRight(Bytes.fromHex(call.data).slice(Number(rule.offset), Number(rule.offset) + 32), 32);
|
|
223
|
-
|
|
223
|
+
const value = callDataValue.map((b, i) => b & rule.mask[i]);
|
|
224
224
|
if (Bytes.toBigInt(value) === 0n)
|
|
225
225
|
continue;
|
|
226
226
|
// Add to list
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"implicit.d.ts","sourceRoot":"","sources":["../../../src/signers/session/implicit.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,
|
|
1
|
+
{"version":3,"file":"implicit.d.ts","sourceRoot":"","sources":["../../../src/signers/session/implicit.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,WAAW,EACX,OAAO,EACP,SAAS,IAAI,iBAAiB,EAC9B,aAAa,EACb,gBAAgB,EACjB,MAAM,+BAA+B,CAAA;AACtC,OAAO,EAAe,OAAO,EAAS,GAAG,EAAE,QAAQ,EAAwB,MAAM,IAAI,CAAA;AACrF,OAAO,EAAiB,OAAO,EAAE,MAAM,gBAAgB,CAAA;AACvD,OAAO,EAAE,qBAAqB,EAAE,qBAAqB,EAAE,MAAM,cAAc,CAAA;AAE3E,MAAM,MAAM,iBAAiB,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,EAAE,gBAAgB,CAAC,CAAA;AAE/E,qBAAa,QAAS,YAAW,qBAAqB;IAOlD,OAAO,CAAC,QAAQ,CAAC,YAAY;IAE7B,OAAO,CAAC,QAAQ,CAAC,eAAe;IARlC,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAS;IACrC,OAAO,CAAC,QAAQ,CAAC,kBAAkB,CAAuB;IAC1D,SAAgB,OAAO,EAAE,OAAO,CAAC,OAAO,CAAA;gBAGtC,UAAU,EAAE,GAAG,CAAC,GAAG,GAAG,OAAO,EACZ,YAAY,EAAE,WAAW,CAAC,WAAW,EACtD,iBAAiB,EAAE,iBAAiB,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,EACjC,eAAe,EAAE,OAAO,CAAC,OAAO;IAcnD,IAAI,cAAc,IAAI,OAAO,CAAC,OAAO,CAKpC;IAED,OAAO,CAAC,eAAe,EAAE,aAAa,CAAC,gBAAgB,EAAE,QAAQ,EAAE,MAAM,GAAG,qBAAqB;IAa3F,aAAa,CACjB,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,QAAQ,EAAE,MAAM,EAChB,IAAI,EAAE,OAAO,CAAC,IAAI,EAClB,sBAAsB,EAAE,OAAO,CAAC,OAAO,EACvC,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ,GAC3B,OAAO,CAAC,OAAO,CAAC;IAyCb,QAAQ,CACZ,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,OAAO,CAAC,KAAK,EACtB,OAAO,EAAE,MAAM,EACf,qBAAqB,EAAE,OAAO,CAAC,OAAO,EACtC,QAAQ,CAAC,EAAE,QAAQ,CAAC,QAAQ,GAC3B,OAAO,CAAC,gBAAgB,CAAC,oBAAoB,CAAC;CAclD"}
|
|
@@ -73,7 +73,7 @@ export class Implicit {
|
|
|
73
73
|
const expectedResult = Bytes.toHex(Attestation.generateImplicitRequestMagic(this._attestation, wallet));
|
|
74
74
|
return acceptImplicitRequest === expectedResult;
|
|
75
75
|
}
|
|
76
|
-
catch
|
|
76
|
+
catch {
|
|
77
77
|
// console.log('implicit signer unsupported call', call, error)
|
|
78
78
|
return false;
|
|
79
79
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/state/local/index.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/state/local/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -83,7 +83,7 @@ export class Provider {
|
|
|
83
83
|
return;
|
|
84
84
|
}
|
|
85
85
|
async getConfigurationUpdates(wallet, fromImageHash, options) {
|
|
86
|
-
|
|
86
|
+
const fromConfig = await this.store.loadConfig(fromImageHash);
|
|
87
87
|
if (!fromConfig) {
|
|
88
88
|
return [];
|
|
89
89
|
}
|
|
@@ -219,12 +219,13 @@ export class Provider {
|
|
|
219
219
|
}
|
|
220
220
|
if (Signature.isSignatureOfSapientSignerLeaf(topology.signature)) {
|
|
221
221
|
switch (topology.signature.address.toLowerCase()) {
|
|
222
|
-
case this.extensions.passkeys.toLowerCase():
|
|
222
|
+
case this.extensions.passkeys.toLowerCase(): {
|
|
223
223
|
const decoded = Extensions.Passkeys.decode(Bytes.fromHex(topology.signature.data));
|
|
224
224
|
if (!Extensions.Passkeys.isValidSignature(subdigest, decoded)) {
|
|
225
225
|
throw new Error('Invalid passkey signature');
|
|
226
226
|
}
|
|
227
227
|
return this.store.saveSapientSignatureOfSubdigest(topology.signature.address, subdigest, Extensions.Passkeys.rootFor(decoded.publicKey), topology.signature);
|
|
228
|
+
}
|
|
228
229
|
default:
|
|
229
230
|
throw new Error(`Unsupported sapient signer: ${topology.signature.address}`);
|
|
230
231
|
}
|
|
@@ -38,13 +38,13 @@ export class DevHttpProvider {
|
|
|
38
38
|
const errorJson = await Utils.fromJSON(errorText);
|
|
39
39
|
errorPayload = { ...errorPayload, ...errorJson };
|
|
40
40
|
}
|
|
41
|
-
catch
|
|
41
|
+
catch {
|
|
42
42
|
try {
|
|
43
43
|
// If JSON parsing fails, try getting text for better error message
|
|
44
44
|
const errorText = await response.text();
|
|
45
45
|
errorPayload.body = errorText;
|
|
46
46
|
}
|
|
47
|
-
catch
|
|
47
|
+
catch {
|
|
48
48
|
// Ignore if reading text also fails
|
|
49
49
|
}
|
|
50
50
|
}
|
|
@@ -97,7 +97,7 @@ export class DevHttpProvider {
|
|
|
97
97
|
const text = await response.text(); // Try reading original response if not already done
|
|
98
98
|
throw new Error(`Failed to parse JSON response from server. Status: ${response.status}. Body: "${text}". Original error: ${error instanceof Error ? error.message : String(error)}`);
|
|
99
99
|
}
|
|
100
|
-
catch
|
|
100
|
+
catch {
|
|
101
101
|
throw new Error(`Failed to parse JSON response from server and could not read response body as text. Status: ${response.status}. Original error: ${error instanceof Error ? error.message : String(error)}`);
|
|
102
102
|
}
|
|
103
103
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/state/sequence/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAa,OAAO,EAAc,WAAW,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,+BAA+B,CAAA;AACvH,OAAO,EAEL,OAAO,EAEP,GAAG,EAIJ,MAAM,IAAI,CAAA;AACX,OAAO,EAAwB,QAAQ,IAAI,iBAAiB,EAAE,MAAM,aAAa,CAAA;AACjF,OAAO,EAA2B,KAAK,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAEvE,qBAAa,QAAS,YAAW,iBAAiB;IAChD,OAAO,CAAC,QAAQ,CAAC,OAAO,CAAU;gBAEtB,IAAI,SAAoC,EAAE,OAAO,CAAC,EAAE,KAAK;IAQ/D,gBAAgB,CAAC,SAAS,EAAE,GAAG,CAAC,GAAG,GAAG,OAAO,CAAC,MAAM,CAAC,MAAM,GAAG,SAAS,CAAC;IAUxE,SAAS,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC;QAAE,SAAS,EAAE,GAAG,CAAC,GAAG,CAAC;QAAC,OAAO,EAAE,OAAO,CAAC,OAAO,CAAA;KAAE,GAAG,SAAS,CAAC;IAoBzG,UAAU,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,GAAG,OAAO,CAAC;QACjD,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,GAAG;YACzB,OAAO,EAAE,MAAM,CAAA;YACf,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAA;YACzB,SAAS,EAAE,SAAS,CAAC,qBAAqB,CAAA;SAC3C,CAAA;KACF,CAAC;IA8CI,oBAAoB,CACxB,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,SAAS,EAAE,GAAG,CAAC,GAAG,GACjB,OAAO,CAAC;QACT,CAAC,MAAM,EAAE,OAAO,CAAC,OAAO,GAAG;YACzB,OAAO,EAAE,MAAM,CAAA;YACf,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAA;YACzB,SAAS,EAAE,SAAS,CAAC,4BAA4B,CAAA;SAClD,CAAA;KACF,CAAC;IA4CI,aAAa,CACjB,MAAM,EAAE,OAAO,CAAC,OAAO,EACvB,MAAM,EAAE,OAAO,CAAC,OAAO,GACtB,OAAO,CAAC;QAAE,OAAO,EAAE,MAAM,CAAC;QAAC,OAAO,EAAE,OAAO,CAAC,QAAQ,CAAC;QAAC,SAAS,EAAE,SAAS,CAAC,qBAAqB,CAAA;KAAE,GAAG,SAAS,CAAC;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/state/sequence/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -139,7 +139,9 @@ export class Provider {
|
|
|
139
139
|
throw new Error(`unexpected compact sapient signature by ${signer}`);
|
|
140
140
|
}
|
|
141
141
|
}
|
|
142
|
-
catch {
|
|
142
|
+
catch {
|
|
143
|
+
// ignore
|
|
144
|
+
}
|
|
143
145
|
}
|
|
144
146
|
async getWitnessForSapient(wallet, signer, imageHash) {
|
|
145
147
|
try {
|
|
@@ -166,7 +168,9 @@ export class Provider {
|
|
|
166
168
|
};
|
|
167
169
|
}
|
|
168
170
|
}
|
|
169
|
-
catch {
|
|
171
|
+
catch {
|
|
172
|
+
// ignore
|
|
173
|
+
}
|
|
170
174
|
}
|
|
171
175
|
async getConfigurationUpdates(wallet, fromImageHash, options) {
|
|
172
176
|
const { updates } = await this.service.configUpdates({ wallet, fromImageHash, allUpdates: options?.allUpdates });
|
|
@@ -284,7 +288,7 @@ const recoverSapientSignatureCompactFunction = AbiFunction.from(recoverSapientSi
|
|
|
284
288
|
class PasskeySignatureValidator {
|
|
285
289
|
request = (async (request) => {
|
|
286
290
|
switch (request.method) {
|
|
287
|
-
case 'eth_call':
|
|
291
|
+
case 'eth_call': {
|
|
288
292
|
if (!request.params || !Array.isArray(request.params) || request.params.length === 0) {
|
|
289
293
|
throw new Error('eth_call requires transaction parameters');
|
|
290
294
|
}
|
|
@@ -303,6 +307,7 @@ class PasskeySignatureValidator {
|
|
|
303
307
|
else {
|
|
304
308
|
throw new Error(`invalid passkey signature ${signature} for digest ${digest}`);
|
|
305
309
|
}
|
|
310
|
+
}
|
|
306
311
|
default:
|
|
307
312
|
throw new Error(`method ${request.method} not implemented`);
|
|
308
313
|
}
|
package/dist/wallet.js
CHANGED
|
@@ -253,7 +253,7 @@ export class Wallet {
|
|
|
253
253
|
if (!status.context.capabilities?.erc4337?.entrypoint) {
|
|
254
254
|
throw new Error('4337 is not enabled in this wallet');
|
|
255
255
|
}
|
|
256
|
-
const noncePromise = this.get4337Nonce(provider, status.context.capabilities
|
|
256
|
+
const noncePromise = this.get4337Nonce(provider, status.context.capabilities.erc4337.entrypoint, space);
|
|
257
257
|
// If the wallet is not deployed, then we need to include the initCode on
|
|
258
258
|
// the 4337 transaction
|
|
259
259
|
let factory;
|
|
@@ -425,7 +425,7 @@ export class Wallet {
|
|
|
425
425
|
encodedMessage = TypedData.encode(message);
|
|
426
426
|
}
|
|
427
427
|
else {
|
|
428
|
-
|
|
428
|
+
const hexMessage = Hex.validate(message) ? message : Hex.fromString(message);
|
|
429
429
|
const messageSize = Hex.size(hexMessage);
|
|
430
430
|
encodedMessage = Hex.concat(Hex.fromString(`${`\x19Ethereum Signed Message:\n${messageSize}`}`), hexMessage);
|
|
431
431
|
}
|
package/eslint.config.js
ADDED
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { config as baseConfig } from '@repo/eslint-config/base'
|
|
2
|
+
|
|
3
|
+
/** @type {import("eslint").Linter.Config} */
|
|
4
|
+
export default [
|
|
5
|
+
...baseConfig,
|
|
6
|
+
{
|
|
7
|
+
// files: ['**/*.{test,spec}.ts'],
|
|
8
|
+
rules: {
|
|
9
|
+
'@typescript-eslint/no-explicit-any': 'off',
|
|
10
|
+
},
|
|
11
|
+
},
|
|
12
|
+
]
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@0xsequence/wallet-core",
|
|
3
|
-
"version": "3.0.0-beta.
|
|
3
|
+
"version": "3.0.0-beta.19",
|
|
4
4
|
"license": "Apache-2.0",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"publishConfig": {
|
|
@@ -14,21 +14,22 @@
|
|
|
14
14
|
}
|
|
15
15
|
},
|
|
16
16
|
"devDependencies": {
|
|
17
|
-
"@types/node": "^25.0
|
|
18
|
-
"@vitest/coverage-v8": "^4.0.
|
|
19
|
-
"dotenv": "^17.
|
|
17
|
+
"@types/node": "^25.3.0",
|
|
18
|
+
"@vitest/coverage-v8": "^4.0.18",
|
|
19
|
+
"dotenv": "^17.3.1",
|
|
20
20
|
"fake-indexeddb": "^6.2.5",
|
|
21
21
|
"typescript": "^5.9.3",
|
|
22
|
-
"vitest": "^4.0.
|
|
23
|
-
"@repo/typescript-config": "^0.0.1-beta.1"
|
|
22
|
+
"vitest": "^4.0.18",
|
|
23
|
+
"@repo/typescript-config": "^0.0.1-beta.1",
|
|
24
|
+
"@repo/eslint-config": "^0.0.1-beta.1"
|
|
24
25
|
},
|
|
25
26
|
"dependencies": {
|
|
26
27
|
"mipd": "^0.0.7",
|
|
27
28
|
"ox": "^0.9.17",
|
|
28
29
|
"viem": "^2.40.3",
|
|
29
|
-
"@0xsequence/guard": "^3.0.0-beta.
|
|
30
|
-
"@0xsequence/wallet-primitives": "^3.0.0-beta.
|
|
31
|
-
"@0xsequence/relayer": "^3.0.0-beta.
|
|
30
|
+
"@0xsequence/guard": "^3.0.0-beta.19",
|
|
31
|
+
"@0xsequence/wallet-primitives": "^3.0.0-beta.19",
|
|
32
|
+
"@0xsequence/relayer": "^3.0.0-beta.19"
|
|
32
33
|
},
|
|
33
34
|
"scripts": {
|
|
34
35
|
"build": "tsc",
|
|
@@ -36,6 +37,7 @@
|
|
|
36
37
|
"test": "vitest run",
|
|
37
38
|
"test:coverage": "vitest run --coverage",
|
|
38
39
|
"typecheck": "tsc --noEmit",
|
|
39
|
-
"clean": "rimraf dist"
|
|
40
|
+
"clean": "rimraf dist",
|
|
41
|
+
"lint": "eslint . --max-warnings 0"
|
|
40
42
|
}
|
|
41
43
|
}
|
|
@@ -16,7 +16,7 @@ type PimlicoGasPrice = {
|
|
|
16
16
|
}
|
|
17
17
|
|
|
18
18
|
export class PimlicoBundler implements Bundler {
|
|
19
|
-
public readonly kind
|
|
19
|
+
public readonly kind = 'bundler'
|
|
20
20
|
public readonly id: string
|
|
21
21
|
|
|
22
22
|
public readonly provider: Provider.Provider
|
|
@@ -119,7 +119,7 @@ export class PimlicoBundler implements Bundler {
|
|
|
119
119
|
let pimlico: PimlicoStatusResp | undefined
|
|
120
120
|
try {
|
|
121
121
|
pimlico = await this.bundlerRpc<PimlicoStatusResp>('pimlico_getUserOperationStatus', [opHash])
|
|
122
|
-
} catch
|
|
122
|
+
} catch {
|
|
123
123
|
/* ignore - not Pimlico or endpoint down */
|
|
124
124
|
}
|
|
125
125
|
|
package/src/signers/index.ts
CHANGED
|
@@ -31,7 +31,7 @@ export interface SapientSigner {
|
|
|
31
31
|
}
|
|
32
32
|
|
|
33
33
|
export interface Witnessable {
|
|
34
|
-
witness: (stateWriter: State.Writer, wallet: Address.Address, extra?:
|
|
34
|
+
witness: (stateWriter: State.Writer, wallet: Address.Address, extra?: object) => Promise<void>
|
|
35
35
|
}
|
|
36
36
|
|
|
37
37
|
type MaybePromise<T> = T | Promise<T>
|
package/src/signers/passkey.ts
CHANGED
|
@@ -276,7 +276,7 @@ export class Passkey implements SapientSigner, Witnessable {
|
|
|
276
276
|
}
|
|
277
277
|
}
|
|
278
278
|
|
|
279
|
-
async witness(stateWriter: State.Writer, wallet: Address.Address, extra?:
|
|
279
|
+
async witness(stateWriter: State.Writer, wallet: Address.Address, extra?: object): Promise<void> {
|
|
280
280
|
const payload = Payload.fromMessage(
|
|
281
281
|
Hex.fromString(
|
|
282
282
|
JSON.stringify({
|
package/src/signers/pk/index.ts
CHANGED
|
@@ -52,7 +52,7 @@ export class Pk implements SignerInterface, Witnessable {
|
|
|
52
52
|
return { ...signature, type: 'hash' }
|
|
53
53
|
}
|
|
54
54
|
|
|
55
|
-
async witness(stateWriter: State.Writer, wallet: Address.Address, extra?:
|
|
55
|
+
async witness(stateWriter: State.Writer, wallet: Address.Address, extra?: object): Promise<void> {
|
|
56
56
|
const payload = Payload.fromMessage(
|
|
57
57
|
Hex.fromString(
|
|
58
58
|
JSON.stringify({
|
|
@@ -1,11 +1,4 @@
|
|
|
1
|
-
import {
|
|
2
|
-
Constants,
|
|
3
|
-
Extensions,
|
|
4
|
-
Payload,
|
|
5
|
-
Permission,
|
|
6
|
-
SessionConfig,
|
|
7
|
-
SessionSignature,
|
|
8
|
-
} from '@0xsequence/wallet-primitives'
|
|
1
|
+
import { Constants, Payload, Permission, SessionConfig, SessionSignature } from '@0xsequence/wallet-primitives'
|
|
9
2
|
import { AbiFunction, AbiParameters, Address, Bytes, Hash, Hex, Provider } from 'ox'
|
|
10
3
|
import { MemoryPkStore, PkStore } from '../pk/index.js'
|
|
11
4
|
import { ExplicitSessionSigner, SessionSignerValidity, UsageLimit } from './session.js'
|
|
@@ -323,7 +316,7 @@ export class Explicit implements ExplicitSessionSigner {
|
|
|
323
316
|
Bytes.fromHex(call.data).slice(Number(rule.offset), Number(rule.offset) + 32),
|
|
324
317
|
32,
|
|
325
318
|
)
|
|
326
|
-
|
|
319
|
+
const value: Bytes.Bytes = callDataValue.map((b, i) => b & rule.mask[i]!)
|
|
327
320
|
if (Bytes.toBigInt(value) === 0n) continue
|
|
328
321
|
|
|
329
322
|
// Add to list
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import {
|
|
2
2
|
Attestation,
|
|
3
|
-
Extensions,
|
|
4
3
|
Payload,
|
|
5
4
|
Signature as SequenceSignature,
|
|
6
5
|
SessionConfig,
|
|
@@ -96,7 +95,7 @@ export class Implicit implements ImplicitSessionSigner {
|
|
|
96
95
|
)
|
|
97
96
|
const expectedResult = Bytes.toHex(Attestation.generateImplicitRequestMagic(this._attestation, wallet))
|
|
98
97
|
return acceptImplicitRequest === expectedResult
|
|
99
|
-
} catch
|
|
98
|
+
} catch {
|
|
100
99
|
// console.log('implicit signer unsupported call', call, error)
|
|
101
100
|
return false
|
|
102
101
|
}
|
package/src/state/local/index.ts
CHANGED
|
@@ -203,7 +203,7 @@ export class Provider implements ProviderInterface {
|
|
|
203
203
|
fromImageHash: Hex.Hex,
|
|
204
204
|
options?: { allUpdates?: boolean },
|
|
205
205
|
): Promise<{ imageHash: Hex.Hex; signature: Signature.RawSignature }[]> {
|
|
206
|
-
|
|
206
|
+
const fromConfig = await this.store.loadConfig(fromImageHash)
|
|
207
207
|
if (!fromConfig) {
|
|
208
208
|
return []
|
|
209
209
|
}
|
|
@@ -384,7 +384,7 @@ export class Provider implements ProviderInterface {
|
|
|
384
384
|
|
|
385
385
|
if (Signature.isSignatureOfSapientSignerLeaf(topology.signature)) {
|
|
386
386
|
switch (topology.signature.address.toLowerCase()) {
|
|
387
|
-
case this.extensions.passkeys.toLowerCase():
|
|
387
|
+
case this.extensions.passkeys.toLowerCase(): {
|
|
388
388
|
const decoded = Extensions.Passkeys.decode(Bytes.fromHex(topology.signature.data))
|
|
389
389
|
|
|
390
390
|
if (!Extensions.Passkeys.isValidSignature(subdigest, decoded)) {
|
|
@@ -397,6 +397,8 @@ export class Provider implements ProviderInterface {
|
|
|
397
397
|
Extensions.Passkeys.rootFor(decoded.publicKey),
|
|
398
398
|
topology.signature,
|
|
399
399
|
)
|
|
400
|
+
}
|
|
401
|
+
|
|
400
402
|
default:
|
|
401
403
|
throw new Error(`Unsupported sapient signer: ${topology.signature.address}`)
|
|
402
404
|
}
|
|
@@ -44,12 +44,12 @@ export class DevHttpProvider implements Provider {
|
|
|
44
44
|
const errorText = await response.text()
|
|
45
45
|
const errorJson = await Utils.fromJSON(errorText)
|
|
46
46
|
errorPayload = { ...errorPayload, ...errorJson }
|
|
47
|
-
} catch
|
|
47
|
+
} catch {
|
|
48
48
|
try {
|
|
49
49
|
// If JSON parsing fails, try getting text for better error message
|
|
50
50
|
const errorText = await response.text()
|
|
51
51
|
errorPayload.body = errorText
|
|
52
|
-
} catch
|
|
52
|
+
} catch {
|
|
53
53
|
// Ignore if reading text also fails
|
|
54
54
|
}
|
|
55
55
|
}
|
|
@@ -105,7 +105,7 @@ export class DevHttpProvider implements Provider {
|
|
|
105
105
|
throw new Error(
|
|
106
106
|
`Failed to parse JSON response from server. Status: ${response.status}. Body: "${text}". Original error: ${error instanceof Error ? error.message : String(error)}`,
|
|
107
107
|
)
|
|
108
|
-
} catch
|
|
108
|
+
} catch {
|
|
109
109
|
throw new Error(
|
|
110
110
|
`Failed to parse JSON response from server and could not read response body as text. Status: ${response.status}. Original error: ${error instanceof Error ? error.message : String(error)}`,
|
|
111
111
|
)
|
|
@@ -190,7 +190,9 @@ export class Provider implements ProviderInterface {
|
|
|
190
190
|
case SignatureType.SapientCompact:
|
|
191
191
|
throw new Error(`unexpected compact sapient signature by ${signer}`)
|
|
192
192
|
}
|
|
193
|
-
} catch {
|
|
193
|
+
} catch {
|
|
194
|
+
// ignore
|
|
195
|
+
}
|
|
194
196
|
}
|
|
195
197
|
|
|
196
198
|
async getWitnessForSapient(
|
|
@@ -225,7 +227,9 @@ export class Provider implements ProviderInterface {
|
|
|
225
227
|
signature: { type: 'sapient_compact', address: signer, data: witness.signature },
|
|
226
228
|
}
|
|
227
229
|
}
|
|
228
|
-
} catch {
|
|
230
|
+
} catch {
|
|
231
|
+
// ignore
|
|
232
|
+
}
|
|
229
233
|
}
|
|
230
234
|
|
|
231
235
|
async getConfigurationUpdates(
|
|
@@ -384,7 +388,7 @@ const recoverSapientSignatureCompactFunction = AbiFunction.from(recoverSapientSi
|
|
|
384
388
|
class PasskeySignatureValidator implements oxProvider.Provider {
|
|
385
389
|
request: oxProvider.Provider['request'] = (async (request) => {
|
|
386
390
|
switch (request.method) {
|
|
387
|
-
case 'eth_call':
|
|
391
|
+
case 'eth_call': {
|
|
388
392
|
if (!request.params || !Array.isArray(request.params) || request.params.length === 0) {
|
|
389
393
|
throw new Error('eth_call requires transaction parameters')
|
|
390
394
|
}
|
|
@@ -410,6 +414,7 @@ class PasskeySignatureValidator implements oxProvider.Provider {
|
|
|
410
414
|
} else {
|
|
411
415
|
throw new Error(`invalid passkey signature ${signature} for digest ${digest}`)
|
|
412
416
|
}
|
|
417
|
+
}
|
|
413
418
|
|
|
414
419
|
default:
|
|
415
420
|
throw new Error(`method ${request.method} not implemented`)
|
package/src/wallet.ts
CHANGED
|
@@ -355,7 +355,7 @@ export class Wallet {
|
|
|
355
355
|
throw new Error('4337 is not enabled in this wallet')
|
|
356
356
|
}
|
|
357
357
|
|
|
358
|
-
const noncePromise = this.get4337Nonce(provider, status.context.capabilities
|
|
358
|
+
const noncePromise = this.get4337Nonce(provider, status.context.capabilities.erc4337.entrypoint, space)
|
|
359
359
|
|
|
360
360
|
// If the wallet is not deployed, then we need to include the initCode on
|
|
361
361
|
// the 4337 transaction
|
|
@@ -570,7 +570,7 @@ export class Wallet {
|
|
|
570
570
|
if (typeof message !== 'string') {
|
|
571
571
|
encodedMessage = TypedData.encode(message)
|
|
572
572
|
} else {
|
|
573
|
-
|
|
573
|
+
const hexMessage = Hex.validate(message) ? message : Hex.fromString(message)
|
|
574
574
|
const messageSize = Hex.size(hexMessage)
|
|
575
575
|
encodedMessage = Hex.concat(Hex.fromString(`${`\x19Ethereum Signed Message:\n${messageSize}`}`), hexMessage)
|
|
576
576
|
}
|
package/test/constants.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
import { config as dotenvConfig } from 'dotenv'
|
|
2
2
|
import { Abi, AbiEvent, Address } from 'ox'
|
|
3
3
|
|
|
4
|
+
// eslint-disable-next-line turbo/no-undeclared-env-vars
|
|
4
5
|
const envFile = process.env.CI ? '.env.test' : '.env.test.local'
|
|
5
6
|
dotenvConfig({ path: envFile })
|
|
6
7
|
|
|
@@ -16,4 +17,5 @@ export const EMITTER_EVENT_TOPICS = [
|
|
|
16
17
|
export const USDC_ADDRESS: Address.Address = '0xaf88d065e77c8cc2239327c5edb3a432268e5831'
|
|
17
18
|
|
|
18
19
|
// Environment variables
|
|
20
|
+
// eslint-disable-next-line turbo/no-undeclared-env-vars
|
|
19
21
|
export const LOCAL_RPC_URL = process.env.LOCAL_RPC_URL || 'http://localhost:8545'
|
package/test/envelope.test.ts
CHANGED
|
@@ -6,7 +6,6 @@ import * as Envelope from '../src/envelope.js'
|
|
|
6
6
|
|
|
7
7
|
// Test addresses and data
|
|
8
8
|
const TEST_ADDRESS_1 = Address.from('0x1234567890123456789012345678901234567890')
|
|
9
|
-
const TEST_ADDRESS_2 = Address.from('0xabcdefabcdefabcdefabcdefabcdefabcdefabcd')
|
|
10
9
|
const TEST_ADDRESS_3 = Address.from('0x9876543210987654321098765432109876543210')
|
|
11
10
|
const TEST_WALLET = Address.from('0xfedcbafedcbafedcbafedcbafedcbafedcbafe00')
|
|
12
11
|
const TEST_IMAGE_HASH = Hex.from('0xdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeefdeadbeef')
|
package/test/signers-pk.test.ts
CHANGED
|
@@ -143,7 +143,7 @@ describe('Private Key Signers', () => {
|
|
|
143
143
|
await pk.witness(mockStateWriter, testWallet)
|
|
144
144
|
|
|
145
145
|
expect(mockStateWriter.saveWitnesses).toHaveBeenCalledTimes(1)
|
|
146
|
-
const [wallet, chainId,
|
|
146
|
+
const [wallet, chainId, _payload, witness] = vi.mocked(mockStateWriter.saveWitnesses).mock.calls[0]
|
|
147
147
|
|
|
148
148
|
expect(wallet).toBe(testWallet)
|
|
149
149
|
expect(chainId).toBe(0)
|
|
@@ -236,7 +236,6 @@ describe('Implicit Session', () => {
|
|
|
236
236
|
},
|
|
237
237
|
}
|
|
238
238
|
const identitySignature = createValidIdentitySignature(attestation)
|
|
239
|
-
const topology = createValidTopology()
|
|
240
239
|
|
|
241
240
|
// This should throw an error during construction due to future issued time
|
|
242
241
|
expect(() => {
|
|
@@ -250,7 +249,6 @@ describe('Implicit Session', () => {
|
|
|
250
249
|
approvedSigner: randomAddress(), // Different approved signer
|
|
251
250
|
}
|
|
252
251
|
const identitySignature = createValidIdentitySignature(attestation)
|
|
253
|
-
const topology = createValidTopology()
|
|
254
252
|
|
|
255
253
|
// This should throw an error during construction due to mismatched approved signer
|
|
256
254
|
expect(() => {
|
package/test/state/debug.test.ts
CHANGED
|
@@ -5,7 +5,6 @@ import { multiplex } from '../../src/state/debug.js'
|
|
|
5
5
|
|
|
6
6
|
// Test data
|
|
7
7
|
const TEST_ADDRESS = Address.from('0x1234567890123456789012345678901234567890')
|
|
8
|
-
const TEST_HEX = Hex.from('0xabcdef123456')
|
|
9
8
|
const TEST_UINT8ARRAY = new Uint8Array([171, 205, 239, 18, 52, 86])
|
|
10
9
|
|
|
11
10
|
describe('State Debug', () => {
|
|
@@ -241,13 +240,13 @@ describe('State Debug', () => {
|
|
|
241
240
|
}
|
|
242
241
|
|
|
243
242
|
const complexRef: ComplexInterface = {
|
|
244
|
-
async complexMethod(
|
|
243
|
+
async complexMethod() {
|
|
245
244
|
return 'complex-ref'
|
|
246
245
|
},
|
|
247
246
|
}
|
|
248
247
|
|
|
249
248
|
const complexCand: ComplexInterface = {
|
|
250
|
-
async complexMethod(
|
|
249
|
+
async complexMethod() {
|
|
251
250
|
return 'complex-cand'
|
|
252
251
|
},
|
|
253
252
|
}
|