Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
21 commits
Select commit Hold shift + click to select a range
6fa9296
refactor: Support JsonRpcEngineV2
rekmarks Oct 28, 2025
7c06c59
test: Add missing test case
rekmarks Oct 29, 2025
047f815
docs: Update changelog
rekmarks Oct 29, 2025
5893198
fix: Ensure json-rpc-engine/v2 can be resolved without builds
rekmarks Oct 31, 2025
560f6b2
refactor(provider): prefer v2 JsonRpcServer; wrap legacy engines; tig…
rekmarks Nov 1, 2025
84d3ae2
docs: Update changelogs
rekmarks Nov 1, 2025
e41057a
fix: Handle errors properly in asV2Middleware
rekmarks Nov 3, 2025
38b66a0
test: Remove `undefined` from NetworkController "empty values" test c…
rekmarks Nov 4, 2025
3c58ca3
chore: Restore eslint directive
rekmarks Nov 4, 2025
fa7e3e8
refactor: Touch up internal types, docs
rekmarks Nov 4, 2025
3156a14
refactor!: Remove providerFromEngine
rekmarks Nov 4, 2025
ea28c55
refactor: Remove undefined from empty values array
rekmarks Nov 4, 2025
4c0a2f4
docs: Update changelogs
rekmarks Nov 4, 2025
4685f4a
refactor: Use JsonRpcEngineV2 instead of JsonRpcServer
rekmarks Nov 4, 2025
7aff105
test: Remove red herring from test matcher
rekmarks Nov 4, 2025
35ecbdf
docs: Update changelogs per review feedback
rekmarks Nov 4, 2025
4ebd3d4
refactor: Replace uuid with nanoid for internal provider ids
rekmarks Nov 5, 2025
5280dc1
chore: Lint
rekmarks Nov 5, 2025
3af776f
Merge branch 'main' into rekm/ejrpcp-v2
rekmarks Nov 5, 2025
4a63eea
docs: Explain the typecasts in provider-from-middleware
rekmarks Nov 5, 2025
684a40c
Merge branch 'main' into rekm/ejrpcp-v2
rekmarks Nov 5, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 3 additions & 0 deletions jest.config.packages.js
Original file line number Diff line number Diff line change
Expand Up @@ -80,6 +80,9 @@ module.exports = {
// Here we ensure that Jest resolves `@metamask/*` imports to the uncompiled source code for packages that live in this repo.
// NOTE: This must be synchronized with the `paths` option in `tsconfig.packages.json`.
moduleNameMapper: {
'^@metamask/json-rpc-engine/v2$': [
'<rootDir>/../json-rpc-engine/src/v2/index.ts',
],
'^@metamask/(.+)$': [
'<rootDir>/../$1/src',
// Some @metamask/* packages we are referencing aren't in this monorepo,
Expand Down
8 changes: 2 additions & 6 deletions packages/eth-block-tracker/tests/withBlockTracker.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,4 @@
import { providerFromEngine } from '@metamask/eth-json-rpc-provider';
import type {
// Eip1193Request,
InternalProvider,
} from '@metamask/eth-json-rpc-provider';
import { InternalProvider } from '@metamask/eth-json-rpc-provider';
import { JsonRpcEngine } from '@metamask/json-rpc-engine';
import type { Json } from '@metamask/utils';
import util from 'util';
Expand Down Expand Up @@ -98,7 +94,7 @@ function getFakeProvider({
});
}

const provider = providerFromEngine(new JsonRpcEngine());
const provider = new InternalProvider({ engine: new JsonRpcEngine() });
jest
.spyOn(provider, 'request')
.mockImplementation(async (eip1193Request): Promise<Json> => {
Expand Down
4 changes: 4 additions & 0 deletions packages/eth-json-rpc-middleware/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,10 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

- **BREAKING:** Use `InternalProvider` instead of `SafeEventEmitterProvider` ([#6796](https://github.com/MetaMask/core/pull/6796))
- Wherever a `SafeEventEmitterProvider` was expected, an `InternalProvider` is now expected instead.
- **BREAKING:** Stop retrying `undefined` results for methods that include a block tag parameter ([#7001](https://github.com/MetaMask/core/pull/7001))
- The `retryOnEmpty` middleware will now throw an error if it encounters an `undefined` result when dispatching
a request with a later block number than the originally requested block number.
- In practice, this should happen rarely if ever.
- Migrate all uses of `interface` to `type` ([#6885](https://github.com/MetaMask/core/pull/6885))

## [21.0.0]
Expand Down
6 changes: 1 addition & 5 deletions packages/eth-json-rpc-middleware/src/retryOnEmpty.ts
Original file line number Diff line number Diff line change
Expand Up @@ -21,11 +21,7 @@ import { timeout } from './utils/timeout';
const log = createModuleLogger(projectLogger, 'retry-on-empty');
// empty values used to determine if a request should be retried
// `<nil>` comes from https://github.com/ethereum/go-ethereum/issues/16925
const emptyValues: (string | null | undefined)[] = [
undefined,
null,
'\u003cnil\u003e',
];
const emptyValues = [null, '\u003cnil\u003e'];

/**
* Creates a middleware that retries requests with empty responses.
Expand Down
7 changes: 2 additions & 5 deletions packages/eth-json-rpc-middleware/test/util/helpers.ts
Original file line number Diff line number Diff line change
@@ -1,8 +1,5 @@
import { PollingBlockTracker } from '@metamask/eth-block-tracker';
import {
providerFromEngine,
type InternalProvider,
} from '@metamask/eth-json-rpc-provider';
import { InternalProvider } from '@metamask/eth-json-rpc-provider';
import {
JsonRpcEngine,
type JsonRpcMiddleware,
Expand Down Expand Up @@ -96,7 +93,7 @@ export function createFinalMiddlewareWithDefaultResult<
*/
export function createProviderAndBlockTracker() {
const engine = new JsonRpcEngine();
const provider = providerFromEngine(engine);
const provider = new InternalProvider({ engine });

const blockTracker = new PollingBlockTracker({
provider,
Expand Down
18 changes: 18 additions & 0 deletions packages/eth-json-rpc-provider/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,11 +7,29 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0

## [Unreleased]

### Added

- Add `providerFromMiddlewareV2` ([#7001](https://github.com/MetaMask/core/pull/7001))
- This accepts the new middleware from `@metamask/json-rpc-engine/v2`.

### Changed

- **BREAKING:** Replace `SafeEventEmitterProvider` with `InternalProvider` ([#6796](https://github.com/MetaMask/core/pull/6796))
- The new class is behaviorally equivalent to the previous version except it does not extend `SafeEventEmitter`.
- `SafeEventEmitterProvider` is for now still exported as a deprecated alias of `InternalProvider` for backwards compatibility.
- **BREAKING:** Migrate from `JsonRpcEngine` to `JsonRpcEngineV2` ([#7001](https://github.com/MetaMask/core/pull/7001))
- Legacy `JsonRpcEngine` instances are wrapped in a `JsonRpcEngineV2` internally wherever they appear.
This change should mostly be unobservable. However, due to differences in error handling, this may be breaking for consumers.

### Deprecated

- Deprecate `providerFromMiddleware` ([#7001](https://github.com/MetaMask/core/pull/7001))
- Use `providerFromMiddlewareV2` instead, which supports the new middleware from `@metamask/json-rpc-engine/v2`.

### Removed

- **BREAKING:** Remove `providerFromEngine` ([#7001](https://github.com/MetaMask/core/pull/7001))
- Use `InternalProvider` directly instead.

## [5.0.1]

Expand Down
2 changes: 1 addition & 1 deletion packages/eth-json-rpc-provider/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -56,7 +56,7 @@
"@metamask/json-rpc-engine": "^10.1.1",
"@metamask/rpc-errors": "^7.0.2",
"@metamask/utils": "^11.8.1",
"uuid": "^8.3.2"
"nanoid": "^3.3.8"
},
"devDependencies": {
"@ethersproject/providers": "^5.7.0",
Expand Down
4 changes: 2 additions & 2 deletions packages/eth-json-rpc-provider/src/index.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,12 +2,12 @@ import * as allExports from '.';

describe('Package exports', () => {
it('has expected exports', () => {
expect(Object.keys(allExports)).toMatchInlineSnapshot(`
expect(Object.keys(allExports).sort()).toMatchInlineSnapshot(`
Array [
"InternalProvider",
"SafeEventEmitterProvider",
"providerFromEngine",
"providerFromMiddleware",
"providerFromMiddlewareV2",
]
`);
});
Expand Down
1 change: 0 additions & 1 deletion packages/eth-json-rpc-provider/src/index.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { InternalProvider } from './internal-provider';

export * from './provider-from-engine';
export * from './provider-from-middleware';

/**
Expand Down
Loading
Loading