mirror of
https://github.com/status-im/status-desktop.git
synced 2025-01-24 05:21:58 +00:00
969998dd3f
Closes: #13008
Wallet Connect Integration
TODO
- test namespaces implementation https://se-sdk-dapp.vercel.app/
Design questions
- Do we report disabled chains? Update session in case of enabled/disabled chains?
- User error workflow: retry?
- Check the
Auth
request for verifyContext https://docs.walletconnect.com/web3wallet/verify - What
description
andicons
to use for the app? Seemetadata
parameter inWeb3Wallet.init
call
WalletConnect SDK management
Install dependencies steps by executing commands in this directory:
- update the
package.json
versions and runnpm install
- alternatively
- use the command
npm install <package-name>@<version/latest> --save
for individual packages - or to update to the latest run
ncu -u; npm install
in here- run
npm install -g npm-check-updates
forncu
command
- run
- use the command
- these commands will also create or update a
package-lock.json
file and populate thenode_modules
directory
- alternatively
- update the
bundle.js
file by runningnpm run build
- the result will be embedded with the app and loaded by
WalletConnectSDK.qml
component
- the result will be embedded with the app and loaded by
- add the newly generated files to index
git add --update .
to include in the commit
Testing
Use the web demo test client https://react-app.walletconnect.com/ for wallet pairing and https://react-auth-dapp.walletconnect.com/ for authentication
Log
Initial setup
npm init -y
npm install --save-dev webpack webpack-cli webpack-dev-server
npm install --save @walletconnect/web3wallet
npm run build
# npm run build:dev # for development
- Do we report all chains and all accounts combination or let user select?
- Wallet Connect require to report all chainIDs that were requested
- Answer: We only report the available chains for the current account. We will look into adding others to he same session instead of requiring a new link
- Can't respond to sign messages if the wallet-connect dialog/view is closed (app is minimized)
- Only apps that use deep links are expected to work seamlessly
- Also the main workflow will be driven by user
- Allow user to disconnect session? Manage sessions?
- Yes, in settings
- Support update session if one account is added/removed?
- Not at first
- User awareness of session expiration?
- Support extend session?
- Yes
- Support extend session?