@metamask-previews/eth-json-rpc-middleware 21.0.0-preview-468843ab
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/CHANGELOG.md +23 -0
- package/LICENSE +15 -0
- package/README.md +23 -0
- package/dist/block-cache.cjs +165 -0
- package/dist/block-cache.cjs.map +1 -0
- package/dist/block-cache.d.cts +9 -0
- package/dist/block-cache.d.cts.map +1 -0
- package/dist/block-cache.d.mts +9 -0
- package/dist/block-cache.d.mts.map +1 -0
- package/dist/block-cache.mjs +161 -0
- package/dist/block-cache.mjs.map +1 -0
- package/dist/block-ref-rewrite.cjs +33 -0
- package/dist/block-ref-rewrite.cjs.map +1 -0
- package/dist/block-ref-rewrite.d.cts +9 -0
- package/dist/block-ref-rewrite.d.cts.map +1 -0
- package/dist/block-ref-rewrite.d.mts +9 -0
- package/dist/block-ref-rewrite.d.mts.map +1 -0
- package/dist/block-ref-rewrite.mjs +29 -0
- package/dist/block-ref-rewrite.mjs.map +1 -0
- package/dist/block-ref.cjs +46 -0
- package/dist/block-ref.cjs.map +1 -0
- package/dist/block-ref.d.cts +11 -0
- package/dist/block-ref.d.cts.map +1 -0
- package/dist/block-ref.d.mts +11 -0
- package/dist/block-ref.d.mts.map +1 -0
- package/dist/block-ref.mjs +42 -0
- package/dist/block-ref.mjs.map +1 -0
- package/dist/block-tracker-inspector.cjs +58 -0
- package/dist/block-tracker-inspector.cjs.map +1 -0
- package/dist/block-tracker-inspector.d.cts +9 -0
- package/dist/block-tracker-inspector.d.cts.map +1 -0
- package/dist/block-tracker-inspector.d.mts +9 -0
- package/dist/block-tracker-inspector.d.mts.map +1 -0
- package/dist/block-tracker-inspector.mjs +54 -0
- package/dist/block-tracker-inspector.mjs.map +1 -0
- package/dist/fetch.cjs +48 -0
- package/dist/fetch.cjs.map +1 -0
- package/dist/fetch.d.cts +22 -0
- package/dist/fetch.d.cts.map +1 -0
- package/dist/fetch.d.mts +22 -0
- package/dist/fetch.d.mts.map +1 -0
- package/dist/fetch.mjs +44 -0
- package/dist/fetch.mjs.map +1 -0
- package/dist/index.cjs +28 -0
- package/dist/index.cjs.map +1 -0
- package/dist/index.d.cts +12 -0
- package/dist/index.d.cts.map +1 -0
- package/dist/index.d.mts +12 -0
- package/dist/index.d.mts.map +1 -0
- package/dist/index.mjs +10 -0
- package/dist/index.mjs.map +1 -0
- package/dist/inflight-cache.cjs +80 -0
- package/dist/inflight-cache.cjs.map +1 -0
- package/dist/inflight-cache.d.cts +4 -0
- package/dist/inflight-cache.d.cts.map +1 -0
- package/dist/inflight-cache.d.mts +4 -0
- package/dist/inflight-cache.d.mts.map +1 -0
- package/dist/inflight-cache.mjs +76 -0
- package/dist/inflight-cache.mjs.map +1 -0
- package/dist/logging-utils.cjs +7 -0
- package/dist/logging-utils.cjs.map +1 -0
- package/dist/logging-utils.d.cts +5 -0
- package/dist/logging-utils.d.cts.map +1 -0
- package/dist/logging-utils.d.mts +5 -0
- package/dist/logging-utils.d.mts.map +1 -0
- package/dist/logging-utils.mjs +4 -0
- package/dist/logging-utils.mjs.map +1 -0
- package/dist/methods/wallet-request-execution-permissions.cjs +41 -0
- package/dist/methods/wallet-request-execution-permissions.cjs.map +1 -0
- package/dist/methods/wallet-request-execution-permissions.d.cts +131 -0
- package/dist/methods/wallet-request-execution-permissions.d.cts.map +1 -0
- package/dist/methods/wallet-request-execution-permissions.d.mts +131 -0
- package/dist/methods/wallet-request-execution-permissions.d.mts.map +1 -0
- package/dist/methods/wallet-request-execution-permissions.mjs +37 -0
- package/dist/methods/wallet-request-execution-permissions.mjs.map +1 -0
- package/dist/methods/wallet-revoke-execution-permission.cjs +20 -0
- package/dist/methods/wallet-revoke-execution-permission.cjs.map +1 -0
- package/dist/methods/wallet-revoke-execution-permission.d.cts +13 -0
- package/dist/methods/wallet-revoke-execution-permission.d.cts.map +1 -0
- package/dist/methods/wallet-revoke-execution-permission.d.mts +13 -0
- package/dist/methods/wallet-revoke-execution-permission.d.mts.map +1 -0
- package/dist/methods/wallet-revoke-execution-permission.mjs +16 -0
- package/dist/methods/wallet-revoke-execution-permission.mjs.map +1 -0
- package/dist/providerAsMiddleware.cjs +11 -0
- package/dist/providerAsMiddleware.cjs.map +1 -0
- package/dist/providerAsMiddleware.d.cts +5 -0
- package/dist/providerAsMiddleware.d.cts.map +1 -0
- package/dist/providerAsMiddleware.d.mts +5 -0
- package/dist/providerAsMiddleware.d.mts.map +1 -0
- package/dist/providerAsMiddleware.mjs +7 -0
- package/dist/providerAsMiddleware.mjs.map +1 -0
- package/dist/retryOnEmpty.cjs +100 -0
- package/dist/retryOnEmpty.cjs.map +1 -0
- package/dist/retryOnEmpty.d.cts +11 -0
- package/dist/retryOnEmpty.d.cts.map +1 -0
- package/dist/retryOnEmpty.d.mts +11 -0
- package/dist/retryOnEmpty.d.mts.map +1 -0
- package/dist/retryOnEmpty.mjs +96 -0
- package/dist/retryOnEmpty.mjs.map +1 -0
- package/dist/types.cjs +3 -0
- package/dist/types.cjs.map +1 -0
- package/dist/types.d.cts +25 -0
- package/dist/types.d.cts.map +1 -0
- package/dist/types.d.mts +25 -0
- package/dist/types.d.mts.map +1 -0
- package/dist/types.mjs +2 -0
- package/dist/types.mjs.map +1 -0
- package/dist/utils/cache.cjs +186 -0
- package/dist/utils/cache.cjs.map +1 -0
- package/dist/utils/cache.d.cts +68 -0
- package/dist/utils/cache.d.cts.map +1 -0
- package/dist/utils/cache.d.mts +68 -0
- package/dist/utils/cache.d.mts.map +1 -0
- package/dist/utils/cache.mjs +178 -0
- package/dist/utils/cache.mjs.map +1 -0
- package/dist/utils/common.cjs +17 -0
- package/dist/utils/common.cjs.map +1 -0
- package/dist/utils/common.d.cts +8 -0
- package/dist/utils/common.d.cts.map +1 -0
- package/dist/utils/common.d.mts +8 -0
- package/dist/utils/common.d.mts.map +1 -0
- package/dist/utils/common.mjs +13 -0
- package/dist/utils/common.mjs.map +1 -0
- package/dist/utils/error.cjs +12 -0
- package/dist/utils/error.cjs.map +1 -0
- package/dist/utils/error.d.cts +3 -0
- package/dist/utils/error.d.cts.map +1 -0
- package/dist/utils/error.d.mts +3 -0
- package/dist/utils/error.d.mts.map +1 -0
- package/dist/utils/error.mjs +8 -0
- package/dist/utils/error.mjs.map +1 -0
- package/dist/utils/normalize.cjs +52 -0
- package/dist/utils/normalize.cjs.map +1 -0
- package/dist/utils/normalize.d.cts +26 -0
- package/dist/utils/normalize.d.cts.map +1 -0
- package/dist/utils/normalize.d.mts +26 -0
- package/dist/utils/normalize.d.mts.map +1 -0
- package/dist/utils/normalize.mjs +47 -0
- package/dist/utils/normalize.mjs.map +1 -0
- package/dist/utils/timeout.cjs +14 -0
- package/dist/utils/timeout.cjs.map +1 -0
- package/dist/utils/timeout.d.cts +8 -0
- package/dist/utils/timeout.d.cts.map +1 -0
- package/dist/utils/timeout.d.mts +8 -0
- package/dist/utils/timeout.d.mts.map +1 -0
- package/dist/utils/timeout.mjs +10 -0
- package/dist/utils/timeout.mjs.map +1 -0
- package/dist/utils/validation.cjs +43 -0
- package/dist/utils/validation.cjs.map +1 -0
- package/dist/utils/validation.d.cts +8 -0
- package/dist/utils/validation.d.cts.map +1 -0
- package/dist/utils/validation.d.mts +8 -0
- package/dist/utils/validation.d.mts.map +1 -0
- package/dist/utils/validation.mjs +37 -0
- package/dist/utils/validation.mjs.map +1 -0
- package/dist/wallet.cjs +327 -0
- package/dist/wallet.cjs.map +1 -0
- package/dist/wallet.d.cts +33 -0
- package/dist/wallet.d.cts.map +1 -0
- package/dist/wallet.d.mts +33 -0
- package/dist/wallet.d.mts.map +1 -0
- package/dist/wallet.mjs +300 -0
- package/dist/wallet.mjs.map +1 -0
- package/package.json +95 -0
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import type { JsonRpcMiddleware } from "@metamask/json-rpc-engine";
|
|
2
|
+
import type { JsonRpcRequest } from "@metamask/utils";
|
|
3
|
+
import { type ProcessRequestExecutionPermissionsHook } from "./methods/wallet-request-execution-permissions.mjs";
|
|
4
|
+
import { type ProcessRevokeExecutionPermissionHook } from "./methods/wallet-revoke-execution-permission.mjs";
|
|
5
|
+
import type { Block } from "./types.mjs";
|
|
6
|
+
export type TransactionParams = {
|
|
7
|
+
from: string;
|
|
8
|
+
};
|
|
9
|
+
export type MessageParams = TransactionParams & {
|
|
10
|
+
data: string;
|
|
11
|
+
signatureMethod?: string;
|
|
12
|
+
};
|
|
13
|
+
export type TypedMessageParams = MessageParams & {
|
|
14
|
+
version: string;
|
|
15
|
+
};
|
|
16
|
+
export type TypedMessageV1Params = Omit<TypedMessageParams, 'data'> & {
|
|
17
|
+
data: Record<string, unknown>[];
|
|
18
|
+
};
|
|
19
|
+
export interface WalletMiddlewareOptions {
|
|
20
|
+
getAccounts: (req: JsonRpcRequest) => Promise<string[]>;
|
|
21
|
+
processDecryptMessage?: (msgParams: MessageParams, req: JsonRpcRequest) => Promise<string>;
|
|
22
|
+
processEncryptionPublicKey?: (address: string, req: JsonRpcRequest) => Promise<string>;
|
|
23
|
+
processPersonalMessage?: (msgParams: MessageParams, req: JsonRpcRequest) => Promise<string>;
|
|
24
|
+
processTransaction?: (txParams: TransactionParams, req: JsonRpcRequest) => Promise<string>;
|
|
25
|
+
processSignTransaction?: (txParams: TransactionParams, req: JsonRpcRequest) => Promise<string>;
|
|
26
|
+
processTypedMessage?: (msgParams: TypedMessageV1Params, req: JsonRpcRequest, version: string) => Promise<string>;
|
|
27
|
+
processTypedMessageV3?: (msgParams: TypedMessageParams, req: JsonRpcRequest, version: string) => Promise<string>;
|
|
28
|
+
processTypedMessageV4?: (msgParams: TypedMessageParams, req: JsonRpcRequest, version: string) => Promise<string>;
|
|
29
|
+
processRequestExecutionPermissions?: ProcessRequestExecutionPermissionsHook;
|
|
30
|
+
processRevokeExecutionPermission?: ProcessRevokeExecutionPermissionHook;
|
|
31
|
+
}
|
|
32
|
+
export declare function createWalletMiddleware({ getAccounts, processDecryptMessage, processEncryptionPublicKey, processPersonalMessage, processTransaction, processSignTransaction, processTypedMessage, processTypedMessageV3, processTypedMessageV4, processRequestExecutionPermissions, processRevokeExecutionPermission, }: WalletMiddlewareOptions): JsonRpcMiddleware<any, Block>;
|
|
33
|
+
//# sourceMappingURL=wallet.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wallet.d.mts","sourceRoot":"","sources":["../src/wallet.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,iBAAiB,EAAE,kCAAkC;AAOnE,OAAO,KAAK,EACV,cAAc,EAIf,wBAAwB;AAEzB,OAAO,EACL,KAAK,sCAAsC,EAE5C,2DAAuD;AACxD,OAAO,EACL,KAAK,oCAAoC,EAE1C,yDAAqD;AACtD,OAAO,KAAK,EAAE,KAAK,EAAE,oBAAgB;AAqBrC,MAAM,MAAM,iBAAiB,GAAG;IAC9B,IAAI,EAAE,MAAM,CAAC;CACd,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG,iBAAiB,GAAG;IAC9C,IAAI,EAAE,MAAM,CAAC;IACb,eAAe,CAAC,EAAE,MAAM,CAAC;CAC1B,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG,aAAa,GAAG;IAC/C,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,oBAAoB,GAAG,IAAI,CAAC,kBAAkB,EAAE,MAAM,CAAC,GAAG;IACpE,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;CACjC,CAAC;AAEF,MAAM,WAAW,uBAAuB;IACtC,WAAW,EAAE,CAAC,GAAG,EAAE,cAAc,KAAK,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;IACxD,qBAAqB,CAAC,EAAE,CACtB,SAAS,EAAE,aAAa,EACxB,GAAG,EAAE,cAAc,KAChB,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,0BAA0B,CAAC,EAAE,CAC3B,OAAO,EAAE,MAAM,EACf,GAAG,EAAE,cAAc,KAChB,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,sBAAsB,CAAC,EAAE,CACvB,SAAS,EAAE,aAAa,EACxB,GAAG,EAAE,cAAc,KAChB,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,kBAAkB,CAAC,EAAE,CACnB,QAAQ,EAAE,iBAAiB,EAC3B,GAAG,EAAE,cAAc,KAChB,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,sBAAsB,CAAC,EAAE,CACvB,QAAQ,EAAE,iBAAiB,EAC3B,GAAG,EAAE,cAAc,KAChB,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,mBAAmB,CAAC,EAAE,CACpB,SAAS,EAAE,oBAAoB,EAC/B,GAAG,EAAE,cAAc,EACnB,OAAO,EAAE,MAAM,KACZ,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,qBAAqB,CAAC,EAAE,CACtB,SAAS,EAAE,kBAAkB,EAC7B,GAAG,EAAE,cAAc,EACnB,OAAO,EAAE,MAAM,KACZ,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,qBAAqB,CAAC,EAAE,CACtB,SAAS,EAAE,kBAAkB,EAC7B,GAAG,EAAE,cAAc,EACnB,OAAO,EAAE,MAAM,KACZ,OAAO,CAAC,MAAM,CAAC,CAAC;IACrB,kCAAkC,CAAC,EAAE,sCAAsC,CAAC;IAC5E,gCAAgC,CAAC,EAAE,oCAAoC,CAAC;CACzE;AAED,wBAAgB,sBAAsB,CAAC,EACrC,WAAW,EACX,qBAAqB,EACrB,0BAA0B,EAC1B,sBAAsB,EACtB,kBAAkB,EAClB,sBAAsB,EACtB,mBAAmB,EACnB,qBAAqB,EACrB,qBAAqB,EACrB,kCAAkC,EAClC,gCAAgC,GACjC,EACD,uBAAuB,GAAG,iBAAiB,CAAC,GAAG,EAAE,KAAK,CAAC,CAoWtD"}
|
package/dist/wallet.mjs
ADDED
|
@@ -0,0 +1,300 @@
|
|
|
1
|
+
import * as sigUtil from "@metamask/eth-sig-util";
|
|
2
|
+
import { createAsyncMiddleware, createScaffoldMiddleware } from "@metamask/json-rpc-engine";
|
|
3
|
+
import { rpcErrors } from "@metamask/rpc-errors";
|
|
4
|
+
import { isValidHexAddress } from "@metamask/utils";
|
|
5
|
+
import { walletRequestExecutionPermissions } from "./methods/wallet-request-execution-permissions.mjs";
|
|
6
|
+
import { walletRevokeExecutionPermission } from "./methods/wallet-revoke-execution-permission.mjs";
|
|
7
|
+
import { stripArrayTypeIfPresent } from "./utils/common.mjs";
|
|
8
|
+
import { normalizeTypedMessage, parseTypedMessage } from "./utils/normalize.mjs";
|
|
9
|
+
import { resemblesAddress, validateAndNormalizeKeyholder as validateKeyholder } from "./utils/validation.mjs";
|
|
10
|
+
export function createWalletMiddleware({ getAccounts, processDecryptMessage, processEncryptionPublicKey, processPersonalMessage, processTransaction, processSignTransaction, processTypedMessage, processTypedMessageV3, processTypedMessageV4, processRequestExecutionPermissions, processRevokeExecutionPermission, }) {
|
|
11
|
+
if (!getAccounts) {
|
|
12
|
+
throw new Error('opts.getAccounts is required');
|
|
13
|
+
}
|
|
14
|
+
return createScaffoldMiddleware({
|
|
15
|
+
// account lookups
|
|
16
|
+
eth_accounts: createAsyncMiddleware(lookupAccounts),
|
|
17
|
+
eth_coinbase: createAsyncMiddleware(lookupDefaultAccount),
|
|
18
|
+
// tx signatures
|
|
19
|
+
eth_sendTransaction: createAsyncMiddleware(sendTransaction),
|
|
20
|
+
eth_signTransaction: createAsyncMiddleware(signTransaction),
|
|
21
|
+
// message signatures
|
|
22
|
+
eth_signTypedData: createAsyncMiddleware(signTypedData),
|
|
23
|
+
eth_signTypedData_v3: createAsyncMiddleware(signTypedDataV3),
|
|
24
|
+
eth_signTypedData_v4: createAsyncMiddleware(signTypedDataV4),
|
|
25
|
+
personal_sign: createAsyncMiddleware(personalSign),
|
|
26
|
+
eth_getEncryptionPublicKey: createAsyncMiddleware(encryptionPublicKey),
|
|
27
|
+
eth_decrypt: createAsyncMiddleware(decryptMessage),
|
|
28
|
+
personal_ecRecover: createAsyncMiddleware(personalRecover),
|
|
29
|
+
// EIP-7715
|
|
30
|
+
wallet_requestExecutionPermissions: createAsyncMiddleware(async (req, res) => walletRequestExecutionPermissions(req, res, {
|
|
31
|
+
processRequestExecutionPermissions,
|
|
32
|
+
})),
|
|
33
|
+
wallet_revokeExecutionPermission: createAsyncMiddleware(async (req, res) => walletRevokeExecutionPermission(req, res, {
|
|
34
|
+
processRevokeExecutionPermission,
|
|
35
|
+
})),
|
|
36
|
+
});
|
|
37
|
+
//
|
|
38
|
+
// account lookups
|
|
39
|
+
//
|
|
40
|
+
async function lookupAccounts(req, res) {
|
|
41
|
+
res.result = await getAccounts(req);
|
|
42
|
+
}
|
|
43
|
+
async function lookupDefaultAccount(req, res) {
|
|
44
|
+
const accounts = await getAccounts(req);
|
|
45
|
+
res.result = accounts[0] || null;
|
|
46
|
+
}
|
|
47
|
+
//
|
|
48
|
+
// transaction signatures
|
|
49
|
+
//
|
|
50
|
+
async function sendTransaction(req, res) {
|
|
51
|
+
if (!processTransaction) {
|
|
52
|
+
throw rpcErrors.methodNotSupported();
|
|
53
|
+
}
|
|
54
|
+
if (!req.params ||
|
|
55
|
+
!Array.isArray(req.params) ||
|
|
56
|
+
!(req.params.length >= 1)) {
|
|
57
|
+
throw rpcErrors.invalidInput();
|
|
58
|
+
}
|
|
59
|
+
const params = req.params[0];
|
|
60
|
+
const txParams = {
|
|
61
|
+
...params,
|
|
62
|
+
from: await validateAndNormalizeKeyholder(params?.from || '', req),
|
|
63
|
+
};
|
|
64
|
+
res.result = await processTransaction(txParams, req);
|
|
65
|
+
}
|
|
66
|
+
async function signTransaction(req, res) {
|
|
67
|
+
if (!processSignTransaction) {
|
|
68
|
+
throw rpcErrors.methodNotSupported();
|
|
69
|
+
}
|
|
70
|
+
if (!req.params ||
|
|
71
|
+
!Array.isArray(req.params) ||
|
|
72
|
+
!(req.params.length >= 1)) {
|
|
73
|
+
throw rpcErrors.invalidInput();
|
|
74
|
+
}
|
|
75
|
+
const params = req.params[0];
|
|
76
|
+
const txParams = {
|
|
77
|
+
...params,
|
|
78
|
+
from: await validateAndNormalizeKeyholder(params?.from || '', req),
|
|
79
|
+
};
|
|
80
|
+
res.result = await processSignTransaction(txParams, req);
|
|
81
|
+
}
|
|
82
|
+
//
|
|
83
|
+
// message signatures
|
|
84
|
+
//
|
|
85
|
+
async function signTypedData(req, res) {
|
|
86
|
+
if (!processTypedMessage) {
|
|
87
|
+
throw rpcErrors.methodNotSupported();
|
|
88
|
+
}
|
|
89
|
+
if (!req?.params ||
|
|
90
|
+
!Array.isArray(req.params) ||
|
|
91
|
+
!(req.params.length >= 2)) {
|
|
92
|
+
throw rpcErrors.invalidInput();
|
|
93
|
+
}
|
|
94
|
+
const params = req.params;
|
|
95
|
+
const message = params[0];
|
|
96
|
+
const address = await validateAndNormalizeKeyholder(params[1], req);
|
|
97
|
+
const version = 'V1';
|
|
98
|
+
const extraParams = params[2] || {};
|
|
99
|
+
const msgParams = {
|
|
100
|
+
...extraParams,
|
|
101
|
+
from: address,
|
|
102
|
+
data: message,
|
|
103
|
+
signatureMethod: 'eth_signTypedData',
|
|
104
|
+
version,
|
|
105
|
+
};
|
|
106
|
+
res.result = await processTypedMessage(msgParams, req, version);
|
|
107
|
+
}
|
|
108
|
+
async function signTypedDataV3(req, res) {
|
|
109
|
+
if (!processTypedMessageV3) {
|
|
110
|
+
throw rpcErrors.methodNotSupported();
|
|
111
|
+
}
|
|
112
|
+
if (!req?.params ||
|
|
113
|
+
!Array.isArray(req.params) ||
|
|
114
|
+
!(req.params.length >= 2)) {
|
|
115
|
+
throw rpcErrors.invalidInput();
|
|
116
|
+
}
|
|
117
|
+
const params = req.params;
|
|
118
|
+
const address = await validateAndNormalizeKeyholder(params[0], req);
|
|
119
|
+
const message = normalizeTypedMessage(params[1]);
|
|
120
|
+
validatePrimaryType(message);
|
|
121
|
+
validateVerifyingContract(message);
|
|
122
|
+
const version = 'V3';
|
|
123
|
+
const msgParams = {
|
|
124
|
+
data: message,
|
|
125
|
+
from: address,
|
|
126
|
+
version,
|
|
127
|
+
signatureMethod: 'eth_signTypedData_v3',
|
|
128
|
+
};
|
|
129
|
+
res.result = await processTypedMessageV3(msgParams, req, version);
|
|
130
|
+
}
|
|
131
|
+
async function signTypedDataV4(req, res) {
|
|
132
|
+
if (!processTypedMessageV4) {
|
|
133
|
+
throw rpcErrors.methodNotSupported();
|
|
134
|
+
}
|
|
135
|
+
if (!req?.params ||
|
|
136
|
+
!Array.isArray(req.params) ||
|
|
137
|
+
!(req.params.length >= 2)) {
|
|
138
|
+
throw rpcErrors.invalidInput();
|
|
139
|
+
}
|
|
140
|
+
const params = req.params;
|
|
141
|
+
const address = await validateAndNormalizeKeyholder(params[0], req);
|
|
142
|
+
const message = normalizeTypedMessage(params[1]);
|
|
143
|
+
validatePrimaryType(message);
|
|
144
|
+
validateVerifyingContract(message);
|
|
145
|
+
const version = 'V4';
|
|
146
|
+
const msgParams = {
|
|
147
|
+
data: message,
|
|
148
|
+
from: address,
|
|
149
|
+
version,
|
|
150
|
+
signatureMethod: 'eth_signTypedData_v4',
|
|
151
|
+
};
|
|
152
|
+
res.result = await processTypedMessageV4(msgParams, req, version);
|
|
153
|
+
}
|
|
154
|
+
async function personalSign(req, res) {
|
|
155
|
+
if (!processPersonalMessage) {
|
|
156
|
+
throw rpcErrors.methodNotSupported();
|
|
157
|
+
}
|
|
158
|
+
if (!req?.params ||
|
|
159
|
+
!Array.isArray(req.params) ||
|
|
160
|
+
!(req.params.length >= 2)) {
|
|
161
|
+
throw rpcErrors.invalidInput();
|
|
162
|
+
}
|
|
163
|
+
const params = req.params;
|
|
164
|
+
// process normally
|
|
165
|
+
const firstParam = params[0];
|
|
166
|
+
const secondParam = params[1];
|
|
167
|
+
// non-standard "extraParams" to be appended to our "msgParams" obj
|
|
168
|
+
const extraParams = params[2] || {};
|
|
169
|
+
// We initially incorrectly ordered these parameters.
|
|
170
|
+
// To gracefully respect users who adopted this API early,
|
|
171
|
+
// we are currently gracefully recovering from the wrong param order
|
|
172
|
+
// when it is clearly identifiable.
|
|
173
|
+
//
|
|
174
|
+
// That means when the first param is definitely an address,
|
|
175
|
+
// and the second param is definitely not, but is hex.
|
|
176
|
+
let address, message;
|
|
177
|
+
if (resemblesAddress(firstParam) && !resemblesAddress(secondParam)) {
|
|
178
|
+
let warning = `The eth_personalSign method requires params ordered `;
|
|
179
|
+
warning += `[message, address]. This was previously handled incorrectly, `;
|
|
180
|
+
warning += `and has been corrected automatically. `;
|
|
181
|
+
warning += `Please switch this param order for smooth behavior in the future.`;
|
|
182
|
+
res.warning = warning;
|
|
183
|
+
address = firstParam;
|
|
184
|
+
message = secondParam;
|
|
185
|
+
}
|
|
186
|
+
else {
|
|
187
|
+
message = firstParam;
|
|
188
|
+
address = secondParam;
|
|
189
|
+
}
|
|
190
|
+
address = await validateAndNormalizeKeyholder(address, req);
|
|
191
|
+
const msgParams = {
|
|
192
|
+
...extraParams,
|
|
193
|
+
from: address,
|
|
194
|
+
data: message,
|
|
195
|
+
signatureMethod: 'personal_sign',
|
|
196
|
+
};
|
|
197
|
+
res.result = await processPersonalMessage(msgParams, req);
|
|
198
|
+
}
|
|
199
|
+
async function personalRecover(req, res) {
|
|
200
|
+
if (!req?.params ||
|
|
201
|
+
!Array.isArray(req.params) ||
|
|
202
|
+
!(req.params.length >= 2)) {
|
|
203
|
+
throw rpcErrors.invalidInput();
|
|
204
|
+
}
|
|
205
|
+
const params = req.params;
|
|
206
|
+
const message = params[0];
|
|
207
|
+
const signature = params[1];
|
|
208
|
+
const signerAddress = sigUtil.recoverPersonalSignature({
|
|
209
|
+
data: message,
|
|
210
|
+
signature,
|
|
211
|
+
});
|
|
212
|
+
res.result = signerAddress;
|
|
213
|
+
}
|
|
214
|
+
async function encryptionPublicKey(req, res) {
|
|
215
|
+
if (!processEncryptionPublicKey) {
|
|
216
|
+
throw rpcErrors.methodNotSupported();
|
|
217
|
+
}
|
|
218
|
+
if (!req?.params ||
|
|
219
|
+
!Array.isArray(req.params) ||
|
|
220
|
+
!(req.params.length >= 1)) {
|
|
221
|
+
throw rpcErrors.invalidInput();
|
|
222
|
+
}
|
|
223
|
+
const params = req.params;
|
|
224
|
+
const address = await validateAndNormalizeKeyholder(params[0], req);
|
|
225
|
+
res.result = await processEncryptionPublicKey(address, req);
|
|
226
|
+
}
|
|
227
|
+
async function decryptMessage(req, res) {
|
|
228
|
+
if (!processDecryptMessage) {
|
|
229
|
+
throw rpcErrors.methodNotSupported();
|
|
230
|
+
}
|
|
231
|
+
if (!req?.params ||
|
|
232
|
+
!Array.isArray(req.params) ||
|
|
233
|
+
!(req.params.length >= 1)) {
|
|
234
|
+
throw rpcErrors.invalidInput();
|
|
235
|
+
}
|
|
236
|
+
const params = req.params;
|
|
237
|
+
const ciphertext = params[0];
|
|
238
|
+
const address = await validateAndNormalizeKeyholder(params[1], req);
|
|
239
|
+
const extraParams = params[2] || {};
|
|
240
|
+
const msgParams = {
|
|
241
|
+
...extraParams,
|
|
242
|
+
from: address,
|
|
243
|
+
data: ciphertext,
|
|
244
|
+
};
|
|
245
|
+
res.result = await processDecryptMessage(msgParams, req);
|
|
246
|
+
}
|
|
247
|
+
//
|
|
248
|
+
// utility
|
|
249
|
+
//
|
|
250
|
+
/**
|
|
251
|
+
* Validates the keyholder address, and returns a normalized (i.e. lowercase)
|
|
252
|
+
* copy of it.
|
|
253
|
+
*
|
|
254
|
+
* @param address - The address to validate and normalize.
|
|
255
|
+
* @param req - The request object.
|
|
256
|
+
* @returns The normalized address, if valid. Otherwise, throws
|
|
257
|
+
* an error
|
|
258
|
+
*/
|
|
259
|
+
async function validateAndNormalizeKeyholder(address, req) {
|
|
260
|
+
return validateKeyholder(address, req, { getAccounts });
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
/**
|
|
264
|
+
* Validates primary of typedSignMessage, to ensure that it's type definition is present in message.
|
|
265
|
+
*
|
|
266
|
+
* @param data - The data passed in typedSign request.
|
|
267
|
+
*/
|
|
268
|
+
function validatePrimaryType(data) {
|
|
269
|
+
const { primaryType, types } = parseTypedMessage(data);
|
|
270
|
+
if (!types) {
|
|
271
|
+
throw rpcErrors.invalidInput();
|
|
272
|
+
}
|
|
273
|
+
// Primary type can be an array.
|
|
274
|
+
const baseType = stripArrayTypeIfPresent(primaryType);
|
|
275
|
+
// Return if the base type is not defined in the types
|
|
276
|
+
const baseTypeDefinitions = types[baseType];
|
|
277
|
+
if (!baseTypeDefinitions) {
|
|
278
|
+
throw rpcErrors.invalidInput();
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
/**
|
|
282
|
+
* Validates verifyingContract of typedSignMessage.
|
|
283
|
+
*
|
|
284
|
+
* @param data - The data passed in typedSign request.
|
|
285
|
+
* This function allows the verifyingContract to be either:
|
|
286
|
+
* - A valid hex address
|
|
287
|
+
* - The string "cosmos" (as it is hard-coded in some Cosmos ecosystem's EVM adapters)
|
|
288
|
+
* - An empty string
|
|
289
|
+
*/
|
|
290
|
+
function validateVerifyingContract(data) {
|
|
291
|
+
const { domain: { verifyingContract } = {} } = parseTypedMessage(data);
|
|
292
|
+
// Explicit check for cosmos here has been added to address this issue
|
|
293
|
+
// https://github.com/MetaMask/eth-json-rpc-middleware/issues/337
|
|
294
|
+
if (verifyingContract &&
|
|
295
|
+
verifyingContract !== 'cosmos' &&
|
|
296
|
+
!isValidHexAddress(verifyingContract)) {
|
|
297
|
+
throw rpcErrors.invalidInput();
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
//# sourceMappingURL=wallet.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"wallet.mjs","sourceRoot":"","sources":["../src/wallet.ts"],"names":[],"mappings":"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","sourcesContent":["import * as sigUtil from '@metamask/eth-sig-util';\nimport type { JsonRpcMiddleware } from '@metamask/json-rpc-engine';\nimport {\n createAsyncMiddleware,\n createScaffoldMiddleware,\n} from '@metamask/json-rpc-engine';\nimport { rpcErrors } from '@metamask/rpc-errors';\nimport { isValidHexAddress } from '@metamask/utils';\nimport type {\n JsonRpcRequest,\n PendingJsonRpcResponse,\n Json,\n Hex,\n} from '@metamask/utils';\n\nimport {\n type ProcessRequestExecutionPermissionsHook,\n walletRequestExecutionPermissions,\n} from './methods/wallet-request-execution-permissions';\nimport {\n type ProcessRevokeExecutionPermissionHook,\n walletRevokeExecutionPermission,\n} from './methods/wallet-revoke-execution-permission';\nimport type { Block } from './types';\nimport { stripArrayTypeIfPresent } from './utils/common';\nimport { normalizeTypedMessage, parseTypedMessage } from './utils/normalize';\nimport {\n resemblesAddress,\n validateAndNormalizeKeyholder as validateKeyholder,\n} from './utils/validation';\n\n/*\nexport type TransactionParams = {\n [prop: string]: Json;\n from: string;\n}\n*/\n\n/*\nexport type TransactionParams = JsonRpcParams & {\n from: string;\n}\n*/\n\nexport type TransactionParams = {\n from: string;\n};\n\nexport type MessageParams = TransactionParams & {\n data: string;\n signatureMethod?: string;\n};\n\nexport type TypedMessageParams = MessageParams & {\n version: string;\n};\n\nexport type TypedMessageV1Params = Omit<TypedMessageParams, 'data'> & {\n data: Record<string, unknown>[];\n};\n\nexport interface WalletMiddlewareOptions {\n getAccounts: (req: JsonRpcRequest) => Promise<string[]>;\n processDecryptMessage?: (\n msgParams: MessageParams,\n req: JsonRpcRequest,\n ) => Promise<string>;\n processEncryptionPublicKey?: (\n address: string,\n req: JsonRpcRequest,\n ) => Promise<string>;\n processPersonalMessage?: (\n msgParams: MessageParams,\n req: JsonRpcRequest,\n ) => Promise<string>;\n processTransaction?: (\n txParams: TransactionParams,\n req: JsonRpcRequest,\n ) => Promise<string>;\n processSignTransaction?: (\n txParams: TransactionParams,\n req: JsonRpcRequest,\n ) => Promise<string>;\n processTypedMessage?: (\n msgParams: TypedMessageV1Params,\n req: JsonRpcRequest,\n version: string,\n ) => Promise<string>;\n processTypedMessageV3?: (\n msgParams: TypedMessageParams,\n req: JsonRpcRequest,\n version: string,\n ) => Promise<string>;\n processTypedMessageV4?: (\n msgParams: TypedMessageParams,\n req: JsonRpcRequest,\n version: string,\n ) => Promise<string>;\n processRequestExecutionPermissions?: ProcessRequestExecutionPermissionsHook;\n processRevokeExecutionPermission?: ProcessRevokeExecutionPermissionHook;\n}\n\nexport function createWalletMiddleware({\n getAccounts,\n processDecryptMessage,\n processEncryptionPublicKey,\n processPersonalMessage,\n processTransaction,\n processSignTransaction,\n processTypedMessage,\n processTypedMessageV3,\n processTypedMessageV4,\n processRequestExecutionPermissions,\n processRevokeExecutionPermission,\n}: // }: WalletMiddlewareOptions): JsonRpcMiddleware<string, Block> {\nWalletMiddlewareOptions): JsonRpcMiddleware<any, Block> {\n if (!getAccounts) {\n throw new Error('opts.getAccounts is required');\n }\n\n return createScaffoldMiddleware({\n // account lookups\n eth_accounts: createAsyncMiddleware(lookupAccounts),\n eth_coinbase: createAsyncMiddleware(lookupDefaultAccount),\n\n // tx signatures\n eth_sendTransaction: createAsyncMiddleware(sendTransaction),\n eth_signTransaction: createAsyncMiddleware(signTransaction),\n\n // message signatures\n eth_signTypedData: createAsyncMiddleware(signTypedData),\n eth_signTypedData_v3: createAsyncMiddleware(signTypedDataV3),\n eth_signTypedData_v4: createAsyncMiddleware(signTypedDataV4),\n personal_sign: createAsyncMiddleware(personalSign),\n eth_getEncryptionPublicKey: createAsyncMiddleware(encryptionPublicKey),\n eth_decrypt: createAsyncMiddleware(decryptMessage),\n personal_ecRecover: createAsyncMiddleware(personalRecover),\n\n // EIP-7715\n wallet_requestExecutionPermissions: createAsyncMiddleware(\n async (req, res) =>\n walletRequestExecutionPermissions(req, res, {\n processRequestExecutionPermissions,\n }),\n ),\n wallet_revokeExecutionPermission: createAsyncMiddleware(async (req, res) =>\n walletRevokeExecutionPermission(req, res, {\n processRevokeExecutionPermission,\n }),\n ),\n });\n\n //\n // account lookups\n //\n\n async function lookupAccounts(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n res.result = await getAccounts(req);\n }\n\n async function lookupDefaultAccount(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n const accounts = await getAccounts(req);\n res.result = accounts[0] || null;\n }\n\n //\n // transaction signatures\n //\n\n async function sendTransaction(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processTransaction) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 1)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params[0] as TransactionParams | undefined;\n const txParams: TransactionParams = {\n ...params,\n from: await validateAndNormalizeKeyholder(params?.from || '', req),\n };\n res.result = await processTransaction(txParams, req);\n }\n\n async function signTransaction(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processSignTransaction) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 1)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params[0] as TransactionParams | undefined;\n const txParams: TransactionParams = {\n ...params,\n from: await validateAndNormalizeKeyholder(params?.from || '', req),\n };\n res.result = await processSignTransaction(txParams, req);\n }\n\n //\n // message signatures\n //\n async function signTypedData(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processTypedMessage) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req?.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 2)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params as [\n Record<string, unknown>[],\n string,\n Record<string, string>?,\n ];\n const message = params[0];\n const address = await validateAndNormalizeKeyholder(params[1], req);\n const version = 'V1';\n const extraParams = params[2] || {};\n const msgParams: TypedMessageV1Params = {\n ...extraParams,\n from: address,\n data: message,\n signatureMethod: 'eth_signTypedData',\n version,\n };\n\n res.result = await processTypedMessage(msgParams, req, version);\n }\n\n async function signTypedDataV3(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processTypedMessageV3) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req?.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 2)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params as [string, string];\n\n const address = await validateAndNormalizeKeyholder(params[0], req);\n const message = normalizeTypedMessage(params[1]);\n validatePrimaryType(message);\n validateVerifyingContract(message);\n const version = 'V3';\n const msgParams: TypedMessageParams = {\n data: message,\n from: address,\n version,\n signatureMethod: 'eth_signTypedData_v3',\n };\n\n res.result = await processTypedMessageV3(msgParams, req, version);\n }\n\n async function signTypedDataV4(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processTypedMessageV4) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req?.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 2)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params as [string, string];\n\n const address = await validateAndNormalizeKeyholder(params[0], req);\n const message = normalizeTypedMessage(params[1]);\n validatePrimaryType(message);\n validateVerifyingContract(message);\n const version = 'V4';\n const msgParams: TypedMessageParams = {\n data: message,\n from: address,\n version,\n signatureMethod: 'eth_signTypedData_v4',\n };\n\n res.result = await processTypedMessageV4(msgParams, req, version);\n }\n\n async function personalSign(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processPersonalMessage) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req?.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 2)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params as [string, string, TransactionParams?];\n\n // process normally\n const firstParam = params[0];\n const secondParam = params[1];\n // non-standard \"extraParams\" to be appended to our \"msgParams\" obj\n const extraParams = params[2] || {};\n\n // We initially incorrectly ordered these parameters.\n // To gracefully respect users who adopted this API early,\n // we are currently gracefully recovering from the wrong param order\n // when it is clearly identifiable.\n //\n // That means when the first param is definitely an address,\n // and the second param is definitely not, but is hex.\n let address: string, message: string;\n if (resemblesAddress(firstParam) && !resemblesAddress(secondParam)) {\n let warning = `The eth_personalSign method requires params ordered `;\n warning += `[message, address]. This was previously handled incorrectly, `;\n warning += `and has been corrected automatically. `;\n warning += `Please switch this param order for smooth behavior in the future.`;\n (res as any).warning = warning;\n\n address = firstParam;\n message = secondParam;\n } else {\n message = firstParam;\n address = secondParam;\n }\n address = await validateAndNormalizeKeyholder(address, req);\n\n const msgParams: MessageParams = {\n ...extraParams,\n from: address,\n data: message,\n signatureMethod: 'personal_sign',\n };\n\n res.result = await processPersonalMessage(msgParams, req);\n }\n\n async function personalRecover(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (\n !req?.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 2)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params as [string, string];\n const message = params[0];\n const signature = params[1];\n const signerAddress = sigUtil.recoverPersonalSignature({\n data: message,\n signature,\n });\n\n res.result = signerAddress;\n }\n\n async function encryptionPublicKey(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processEncryptionPublicKey) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req?.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 1)\n ) {\n throw rpcErrors.invalidInput();\n }\n\n const params = req.params as [string];\n\n const address = await validateAndNormalizeKeyholder(params[0], req);\n\n res.result = await processEncryptionPublicKey(address, req);\n }\n\n async function decryptMessage(\n req: JsonRpcRequest,\n res: PendingJsonRpcResponse,\n ): Promise<void> {\n if (!processDecryptMessage) {\n throw rpcErrors.methodNotSupported();\n }\n if (\n !req?.params ||\n !Array.isArray(req.params) ||\n !(req.params.length >= 1)\n ) {\n throw rpcErrors.invalidInput();\n }\n const params = req.params as [string, string, Record<string, Json>?];\n\n const ciphertext: string = params[0];\n const address: string = await validateAndNormalizeKeyholder(params[1], req);\n const extraParams = params[2] || {};\n const msgParams: MessageParams = {\n ...extraParams,\n from: address,\n data: ciphertext,\n };\n\n res.result = await processDecryptMessage(msgParams, req);\n }\n\n //\n // utility\n //\n\n /**\n * Validates the keyholder address, and returns a normalized (i.e. lowercase)\n * copy of it.\n *\n * @param address - The address to validate and normalize.\n * @param req - The request object.\n * @returns The normalized address, if valid. Otherwise, throws\n * an error\n */\n async function validateAndNormalizeKeyholder(\n address: string,\n req: JsonRpcRequest,\n ): Promise<string> {\n return validateKeyholder(address as Hex, req, { getAccounts });\n }\n}\n\n/**\n * Validates primary of typedSignMessage, to ensure that it's type definition is present in message.\n *\n * @param data - The data passed in typedSign request.\n */\nfunction validatePrimaryType(data: string) {\n const { primaryType, types } = parseTypedMessage(data);\n if (!types) {\n throw rpcErrors.invalidInput();\n }\n\n // Primary type can be an array.\n const baseType = stripArrayTypeIfPresent(primaryType);\n\n // Return if the base type is not defined in the types\n const baseTypeDefinitions = types[baseType];\n if (!baseTypeDefinitions) {\n throw rpcErrors.invalidInput();\n }\n}\n\n/**\n * Validates verifyingContract of typedSignMessage.\n *\n * @param data - The data passed in typedSign request.\n * This function allows the verifyingContract to be either:\n * - A valid hex address\n * - The string \"cosmos\" (as it is hard-coded in some Cosmos ecosystem's EVM adapters)\n * - An empty string\n */\nfunction validateVerifyingContract(data: string) {\n const { domain: { verifyingContract } = {} } = parseTypedMessage(data);\n // Explicit check for cosmos here has been added to address this issue\n // https://github.com/MetaMask/eth-json-rpc-middleware/issues/337\n if (\n verifyingContract &&\n (verifyingContract as string) !== 'cosmos' &&\n !isValidHexAddress(verifyingContract)\n ) {\n throw rpcErrors.invalidInput();\n }\n}\n"]}
|
package/package.json
ADDED
|
@@ -0,0 +1,95 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "@metamask-previews/eth-json-rpc-middleware",
|
|
3
|
+
"version": "21.0.0-preview-468843ab",
|
|
4
|
+
"description": "Ethereum-related json-rpc-engine middleware",
|
|
5
|
+
"keywords": [
|
|
6
|
+
"MetaMask",
|
|
7
|
+
"Ethereum"
|
|
8
|
+
],
|
|
9
|
+
"homepage": "https://github.com/MetaMask/core/tree/main/packages/eth-json-rpc-middleware#readme",
|
|
10
|
+
"bugs": {
|
|
11
|
+
"url": "https://github.com/MetaMask/core/issues"
|
|
12
|
+
},
|
|
13
|
+
"repository": {
|
|
14
|
+
"type": "git",
|
|
15
|
+
"url": "https://github.com/MetaMask/core.git"
|
|
16
|
+
},
|
|
17
|
+
"license": "ISC",
|
|
18
|
+
"sideEffects": false,
|
|
19
|
+
"exports": {
|
|
20
|
+
".": {
|
|
21
|
+
"import": {
|
|
22
|
+
"types": "./dist/index.d.mts",
|
|
23
|
+
"default": "./dist/index.mjs"
|
|
24
|
+
},
|
|
25
|
+
"require": {
|
|
26
|
+
"types": "./dist/index.d.cts",
|
|
27
|
+
"default": "./dist/index.cjs"
|
|
28
|
+
}
|
|
29
|
+
},
|
|
30
|
+
"./package.json": "./package.json"
|
|
31
|
+
},
|
|
32
|
+
"main": "./dist/index.cjs",
|
|
33
|
+
"module": "./dist/index.mjs",
|
|
34
|
+
"types": "./dist/index.d.cts",
|
|
35
|
+
"files": [
|
|
36
|
+
"dist/"
|
|
37
|
+
],
|
|
38
|
+
"scripts": {
|
|
39
|
+
"build": "ts-bridge --project tsconfig.build.json --verbose --clean --no-references",
|
|
40
|
+
"build:docs": "typedoc",
|
|
41
|
+
"changelog:update": "../../scripts/update-changelog.sh @metamask/eth-json-rpc-middleware --tag-prefix-before-package-rename eth-json-rpc-middleware@ --version-before-package-rename 6.1.0",
|
|
42
|
+
"changelog:validate": "../../scripts/validate-changelog.sh @metamask/eth-json-rpc-middleware --tag-prefix-before-package-rename eth-json-rpc-middleware@ --version-before-package-rename 6.1.0",
|
|
43
|
+
"lint": "yarn lint:eslint && yarn lint:misc --check && yarn lint:dependencies && yarn lint:changelog",
|
|
44
|
+
"lint:changelog": "auto-changelog validate",
|
|
45
|
+
"lint:dependencies": "depcheck",
|
|
46
|
+
"lint:eslint": "eslint . --cache --ext js,ts",
|
|
47
|
+
"lint:fix": "yarn lint:eslint --fix && yarn lint:misc --write && yarn lint:dependencies && yarn lint:changelog",
|
|
48
|
+
"lint:misc": "prettier '**/*.json' '**/*.md' '!CHANGELOG.md' '**/*.yml' '!.yarnrc.yml' --ignore-path .gitignore --no-error-on-unmatched-pattern",
|
|
49
|
+
"publish:preview": "yarn npm publish --tag preview",
|
|
50
|
+
"since-latest-release": "../../scripts/since-latest-release.sh",
|
|
51
|
+
"test": "NODE_OPTIONS=--experimental-vm-modules jest --reporters=jest-silent-reporter",
|
|
52
|
+
"test:clean": "NODE_OPTIONS=--experimental-vm-modules jest --clearCache",
|
|
53
|
+
"test:verbose": "NODE_OPTIONS=--experimental-vm-modules jest --verbose",
|
|
54
|
+
"test:watch": "NODE_OPTIONS=--experimental-vm-modules jest --watch"
|
|
55
|
+
},
|
|
56
|
+
"dependencies": {
|
|
57
|
+
"@metamask/eth-block-tracker": "^14.0.0",
|
|
58
|
+
"@metamask/eth-json-rpc-provider": "^5.0.1",
|
|
59
|
+
"@metamask/eth-sig-util": "^8.2.0",
|
|
60
|
+
"@metamask/json-rpc-engine": "^10.1.1",
|
|
61
|
+
"@metamask/rpc-errors": "^7.0.2",
|
|
62
|
+
"@metamask/superstruct": "^3.1.0",
|
|
63
|
+
"@metamask/utils": "^11.8.1",
|
|
64
|
+
"klona": "^2.0.6",
|
|
65
|
+
"pify": "^5.0.0",
|
|
66
|
+
"safe-stable-stringify": "^2.4.3"
|
|
67
|
+
},
|
|
68
|
+
"devDependencies": {
|
|
69
|
+
"@metamask/auto-changelog": "^3.4.4",
|
|
70
|
+
"@metamask/error-reporting-service": "^2.2.1",
|
|
71
|
+
"@metamask/network-controller": "^24.3.0",
|
|
72
|
+
"@types/jest": "^27.4.1",
|
|
73
|
+
"@types/pify": "^5.0.2",
|
|
74
|
+
"deepmerge": "^4.2.2",
|
|
75
|
+
"jest": "^27.5.1",
|
|
76
|
+
"tsd": "^0.31.2",
|
|
77
|
+
"typedoc": "^0.24.8",
|
|
78
|
+
"typescript": "~5.2.2"
|
|
79
|
+
},
|
|
80
|
+
"engines": {
|
|
81
|
+
"node": "^18.18 || >=20"
|
|
82
|
+
},
|
|
83
|
+
"publishConfig": {
|
|
84
|
+
"access": "public",
|
|
85
|
+
"registry": "https://registry.npmjs.org/"
|
|
86
|
+
},
|
|
87
|
+
"lavamoat": {
|
|
88
|
+
"allowScripts": {
|
|
89
|
+
"@lavamoat/preinstall-always-fail": false,
|
|
90
|
+
"@metamask/eth-sig-util>ethereumjs-util>ethereum-cryptography>keccak": false,
|
|
91
|
+
"@metamask/eth-sig-util>ethereumjs-util>ethereum-cryptography>secp256k1": false,
|
|
92
|
+
"eslint-plugin-import-x>unrs-resolver": false
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}
|