WBIP001 — JSON RPC

WBIP001 — Wallet API JSON RPC

draft

This WBIP proposes using JSON RPC 2.0 for interacting with wallets (be it via browser extensions or other methods).

History

WebBTC has documented the .request method for extensability for a long time. Yet, it has not been used much. This WBIP proposes to make the request method more common and standardized. If the request method is the default/go-to way of interacting with wallets, it will be easier for developers to add new non-standard functions, without reinventing the wheel (or worse creating a new standard (opens in a new tab)).

This WBIP introduces new WBIP tags: "rpc" and "event" meant for future WBIPs adding definitions for JSON RPC methods, listenable events, or respectively describing common rules to follow.

For proposing new request methods the following applies:

  • The method parameters SHOULD be named for clarity and easier handling of default/optional values; opposed to an parameter array.

Web Interface

For usage in web applications, wallets (e.g. browser extensions) MUST provide a provider object. The provider object MAY be injected into the global/window object (e.g. window.WalletProvider) or re-use an existing compatible interface (e.g. the WebBTC object).

This object SHOULD have at least the .request method for allowing to send JSON RPC requests to the wallet. This object MAY also include the .listen and .unlisten methods for listening to events.

Specification

  • provider.request(method: string, params: {}): Promise<>
  • provider.listen(event: string, listener: (args: any) => void): void
  • provider.unlisten(event: string, listener: (args: any) => void): void

Open Thoughts

  • The .listen could return a callable unsubscribe function.
  • The response from the .request method could be a promise that resolves with the result or rejects with an error.