Features ⁃ Installation ⁃ Usage ⁃ Related
Frame is a web3 platform that creates a secure system-wide interface to your chains and accounts. Now any browser, command-line, or native application has the ability to access web3.
- First-class Hardware Signer Support
- Use your GridPlus, Ledger and Trezor accounts with any dapp!
- Extensive Software Signer Support
- Use a mnemonic phrase, keystore.json or standalone private keys to create and backup accounts!
- Permissions
- You'll always have full control of which dapps have permission to access Frame and can monitor with full transparency what requests are being made to the network.
- Omnichain Routing
- With Frame's Omnichain routing dapps can seamlessly use multiple chains at the same time, enabling truly multichain experiences.
- Transaction Decoding
- By utilizing verified contract ABIs, transaction calldata can be decoded into concise and informative summaries, allowing you to sign transactions with confidence.
- Set your own connections to Ethereum and IPFS
- Never be locked into using a centralized gateway
- Menu Bar Support
- Frame stays out of the way and sits quietly in your menu bar until needed
- Cross Platform
- MacOS, Windows and Linux!
If you use an arch-based distro, you can use an AUR Helper like yay to install Frame by running yay -S frame-eth
or for the development version: yay -S frame-eth-dev
.
On Ubuntu: Run sudo apt-get install build-essential libudev-dev
.
Set environment variables in .env
following the example from .env.example
file.
RPCH_SECRET_TOKEN
- secret token retrieved from hopr degen
DISCOVERY_PLATFORM_API_ENDPOINT
- (OPTIONAL) - set to overwrite the default setting for RPCh discovery platform API endpoint
# Clone
› git clone https://github.com/floating/frame
# Use node v18
› nvm install 18.12.1
› nvm use 18.12.1
# Install
› npm run setup
# Run
› npm run prod
› npm run bundle # Create bundle
› npm run build # Build Frame for current platform
Frame exposes system-wide JSON-RPC endpoints ws://127.0.0.1:1248
and http://127.0.0.1:1248
that you can connect to from any app. We recommend using eth-provider to create a connection const provider = ethProvider('frame')
as eth-provider
will handle any connection edge cases across browsers and environments
Frame also has a browser extension for injecting a Frame-connected EIP-1193 provider into web apps as window.ethereum
. This can be used to inject a connection when an app does not provide the option to connect to Frame natively.
- Frame Chat - Feel free to drop in and ask questions!
- Frame Browser Extension - Use Frame with any web dapp
- eth-provider - A universal Ethereum provider
- Restore - A predictable and observable state container for React apps