--- title: Dapp browser API usage version: 0.1.0 permalink: /spec/14 parent: Draft specs status: Draft authors: --- # Dapp browser API usage ## Table of Contents 1. [Abstract](#abstract) 2. [Definitions](#definitions) 4. [Overview](#overview) 4. [Usage](#usage) * [Properties](#properties) * [`isStatus`](#isStatus) * [`status`](#status) * [Methods](#methods) * [`isConnected`](#isConnected) * [`request`](#request) * [`scanQRCode`](#scanQRCode) * [Unused](#unused) * [`enable`](#enable) * [`send`](#send) * [`sendAsync`](#sendAsync) * [`sendSync`](#sendSync) 5. [Implementation](#implementation) 6. [Compatibility](#compatibility) 7. [Changelog](#changelog) 8. [Copyright](#copyright) ## Abstract This document describes requirements that an application must fulfill in order to provide a proper environment for Dapps running inside a browser. A description of the Status Dapp API is provided, along with an overview of bidirectional communication underlying the API implementation. The document also includes a list of EIPs that this API implements. ## Definitions | Term | Description | |------------|-------------------------------------------------------------------------------------| | **Webview** | Platform-specific browser core implementation. | | **Ethereum Provider** | A JS object (`window.ethereum`) injected into each web page opened in the browser providing web3 compatible provider. | | **Bridge** | A set of facilities allow bidirectional communication between JS code and the application. | ## Overview The application should expose an Ethereum Provider object (`window.ethereum`) to JS code running inside the browser. It is important to have the `window.ethereum` object available before the page loads, otherwise Dapps might not work correctly. Additionally, the browser component should also provide bidirectional communication between JS code and the application. ## Usage in Dapps Dapps can use the below properties and methods of `window.ethereum` object. ### Properties #### `isStatus` Returns true. Can be used by the Dapp to find out whether it's running inside Status. #### `status` Returns a `StatusAPI` object. For now it supports one method: `getContactCode` that sends a `contact-code` request to Status. ### Methods #### `isConnected` Similarly to Ethereum JS API [docs](https://github.com/ethereum/wiki/wiki/JavaScript-API#web3isconnected), it should be called to check if connection to a node exists. On Status, this fn always returns true, as once Status is up and running, node is automatically started. #### `scanQRCode` Sends a `qr-code` Status API request. #### `request` `request` method as defined by EIP-1193. ### Unused Below are some legacy methods that some Dapps might still use. #### `enable` (DEPRECATED) Sends a `web3` Status API request. It returns a first entry in the list of available accounts. Legacy `enable` method as defined by [EIP1102](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1102.md). #### `send` (DEPRECATED) Legacy `send` method as defined by [EIP1193](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1193.md). #### `sendAsync` (DEPRECATED) Legacy `sendAsync` method as defined by [EIP1193](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1193.md). #### `sendSync` (DEPRECATED) Legacy `send` method. ## Implementation Status uses a [forked version](https://github.com/status-im/react-native-webview) of [react-native-webview](https://github.com/react-native-community/react-native-webview) to display web or dapps content. The fork provides an Android implementation of JS injection before page load. It is required in order to properly inject Ethereum Provider object. Status injects two JS scripts: - [provider.js](https://github.com/status-im/status-react/blob/develop/resources/js/provider.js): `window.ethereum` object - [webview.js](https://github.com/status-im/status-react/blob/develop/resources/js/webview.js): override for `history.pushState` used internally Dapps running inside a browser communicate with Status Ethereum node by means of a *bridge* provided by react-native-webview library. The bridge allows for bidirectional communication between browser and Status. In order to do so, it injects a special `ReactNativeWebview` object into each page it loads. On Status (React Native) end, `react-native-webview` library provides `WebView.injectJavascript` function on a webview component that allows to execute arbitrary code inside the webview. Thus it is possible to inject a function call passing Status node response back to the Dapp. Below is the table briefly describing what functions/properties are used. More details available in package [docs](https://github.com/react-native-community/react-native-webview/blob/master/docs/Guide.md#communicating-between-js-and-native). | Direction | Side | Method | |-----------|------|----------- | Browser->Status | JS | `ReactNativeWebView.postMessage()` | Browser->Status | RN | `WebView.onMessage()` | Status->Browser | JS | `ReactNativeWebView.onMessage()` | Status->Browser | RN | `WebView.injectJavascript()` ## Compatibility Status browser supports the following EIPs: - [EIP1102](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1102.md): `eth_requestAccounts` support - [EIP1193](https://github.com/ethereum/EIPs/blob/master/EIPS/eip-1193.md): `connect`, `disconnect`, `chainChanged`, and `accountsChanged` event support is not implemented ## Changelog | Version | Comment | | :-----: | ------- | | [0.1.0](https://github.com/specs/...) | Initial Release | ## Copyright Copyright and related rights waived via [CC0](https://creativecommons.org/publicdomain/zero/1.0/).