Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/DePayFi/web3-wallets
👛 One-Stop-Shop JavaScript library to integrate various web3 crypto wallets and multiple blockchains at once with a single interface.
https://github.com/DePayFi/web3-wallets
crypto-wallet cryptocurrency wallets web3
Last synced: 3 months ago
JSON representation
👛 One-Stop-Shop JavaScript library to integrate various web3 crypto wallets and multiple blockchains at once with a single interface.
- Host: GitHub
- URL: https://github.com/DePayFi/web3-wallets
- Owner: DePayFi
- License: mit
- Created: 2021-06-16T07:38:53.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2024-08-01T14:22:31.000Z (3 months ago)
- Last Synced: 2024-08-01T16:04:07.380Z (3 months ago)
- Topics: crypto-wallet, cryptocurrency, wallets, web3
- Language: JavaScript
- Homepage: https://depay.com
- Size: 22.3 MB
- Stars: 66
- Watchers: 7
- Forks: 22
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
## Quickstart
```
yarn add @depay/web3-wallets
```or
```
npm install --save @depay/web3-wallets
``````javascript
import { getWallets } from '@depay/web3-wallets'let wallets = await getWallets()
// display wallets, have user pick one:
let wallet = wallets[0]
wallet.name // MetaMask
await wallet.connect() // 0x317D875cA3B9f8d14f960486C0d1D1913be74e90
```## Demo
https://depayfi.github.io/web3-wallets/demo.html
## Support
This library supports the following blockchains:
- [Ethereum](https://ethereum.org)
- [BNB Smart Chain](https://www.binance.org/smartChain)
- [Polygon](https://polygon.technology)
- [Solana](https://solana.com)
- [Fantom](https://fantom.foundation)
- [Arbitrum](https://arbitrum.io)
- [Avalanche](https://www.avax.network)
- [Gnosis](https://gnosis.io)
- [Optimism](https://www.optimism.io)
- [Base](https://base.org)This library supports most crypto wallets:
See https://depay.com/wallets for more details
## Platform specific packaging
In case you want to use and package only specific platforms, use platform-specific packages:
### EVM specific packaging
```javascript
import { getWallets } from '@depay/web3-wallets-evm'
```### SOLANA specific packaging
```javascript
import { getWallets } from '@depay/web3-wallets-solana'
```## Functionalities
### getWallets
`getWallets`: Returns an array of available/connectable wallets. Can wait up to 5 seconds because of checking existing WalletConnect connections.
Use `drip` to receive available wallets faster.```javascript
let availableWallets = await getWallets();
// [, ]
``````javascript
let availableWallets = await getWallets();
// [] no wallets detected. (you can still try have user connec via WalletConnect or WalletLink)
``````javascript
import { getWallets, wallets } from "@depay/web3-wallets"let availableWallets = await getWallets()
let wallet
if(availableWallets.length == 1) {
wallet = availableWallets[0]
} else if(availableWallets.length > 1) {
wallet = availableWallets[parseInt(prompt('Which wallet do you want to connect?'), 10)]
} else {
// Let the user choose:
// you can still try to connect via wallets.WalletConnect.connect()
// or wallets.WalletLink.connect()
wallet = wallets.WalletLink
}
```#### drip
Pass a `drip` callback to `getWallets` to receive available wallet as soon as they are found, without waiting for all wallets to be checked:
```javascript
getWallets({
drip: (wallet)=>{
setAvailableWallets(
availableWallets.concat([wallet])
)
}
})```
### Name
`name:string`: Returns the name of the wallet.
```javascript
wallet.name // 'MetaMask'
```### Logo
`logo:string`: Returns the logo of the wallet as PNG base64-encoded.
```javascript
wallet.logo // ''
```### Account
`async account():string`: Gets the currently connected and active account (without prompting a connect screen). Returns `undefined` if no account is connected.
```javascript
await wallet.account() // '0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B'
```### Connect an account
`async connect():string`: Connects account. Potentially opens wallet connect screen. Provides connected account in async return. If wallet fails to connect, it returns `undefined`.
```javascript
await wallet.connect() // '0xAb5801a7D398351b8bE11C439e05C5B3259aeC9B'
```### Platform
`platform:string`: Platform of the identified wallet. If a wallet has multiplatform support (e.g. EVM + SVM), it will provide 1 wallet instance per platform (e.g. Phantom, Exodus, etc.)
```javascript
wallet.platform // 'evm'
```### Supported Blockchains
`blockchains:Array`: Array containing the names of supported blockchains
```javascript
wallet.blockchains // ['ethereum', 'bsc', 'polygon']
```### Check if wallet is connected to a specific blockchain
`async connectedTo(blockchain):Boolean`: Checks if wallet is connected to a specific blockchain.
```javascript
await wallet.connectedTo('ethereum') // true
```If no param is given it well tell you to which blockchain the wallet is connected to:
```javascript
await wallet.connectedTo() // 'bsc'
```can provide an array if connected to multiple blockchains:
```javascript
await wallet.connectedTo() // ['ethereum', 'bsc']
```### Receive wallet events
`on(string, function):undefined`: Register a callback function for given events.
```javascript
wallet.on('account', (newAccount)=>{
doSomething(newAccount)
})
```#### Events
`on('account', (newAccount)=>{})`: Triggers when user changes the connected/active wallet account.
#### Deregister wallet events
`.on` returns a callback function that needs to be passed to `.off` if you want to deregister the event listener:
```javascript
let callback = wallet.on('account', (newAccount)=>{
doSomething(newAccount)
})//...
wallet.off('account', callback) // removes listener
```### Switch blockchain/network
`async switchTo(blockchain)`: Changes wallet connection to a specific network (adds it to the wallet in case it's missing)
```javascript
await wallet.switchTo('bsc')
```### Transaction
### Data Structure
`api: Array`: Api of the contract (e.g. abi for Ethereum, Layout/Struct for Solana).
`blockchain: String`: Name of the blockchain e.g. 'ethereum'.
`failed: Function (transaction, error)=>{}`: Callback to be executed if transaction failed (e.g. reverted).
`from: String`: Address of the transaction sender.
`id: String`: Identifier of the transaction.
`instructions: Array`: List of instructions (Solana).
`signers: Array`: List of signers (Solana).
`method: String`: Name of the contract method to be called (EVM).
`nonce: Integer`: Nonce (number only used once) of the transaction (EVM).
`params: Object or Array`: Parameters passed to the method (EVM).
`sent: Function (transaction)=>{}`: Callback to be executed if transaction has been sent to the network.
`succeeded: Function (transaction)=>{}`: Callback to be executed if transaction was successful and has been confirmed once by the network.
`to String`: Address of the contract to be transacted with (EVM).
`url String`: Url to open the transaction (e.g. in an explorer).
`value: Number or BigNumber as String`: Value of the transaction (amount of the native blockchain currency sent along with the transaction).
### sendTransaction
#### EVM: sendTransaction
Available arguments for EVM blockchains:
`api: Array`: Api of the contract (e.g. abi for Ethereum).
`blockchain: String`: Name of the blockchain e.g. 'ethereum'.
`failed: Function (transaction, error)=>{}`: Callback to be executed if transaction failed (e.g. reverted).
`method: String`: Name of the contract method to be called.
`params: Object or Array`: Parameters passed to the method.
`sent: Function (transaction)=>{}`: Callback to be executed if transaction has been sent to the network.
`succeeded: Function (transaction)=>{}`: Callback to be executed if transaction was successful and has been confirmed once by the network.
`to String`: Address of the contract to be transacted with.
`value: Number or BigNumber as String`: Value of the transaction (amount of the native blockchain currency sent along with the transaction).
##### EVM: Simple value transfer
e.g. sending 0.01 ETH on Ethereum:
```javascript
let sentTransaction = await wallet.sendTransaction({
blockchain: 'ethereum',
to: '0xae60aC8e69414C2Dc362D0e6a03af643d1D85b92',
value: 0.01,
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
```##### EVM: Smart contract interaction
```javascript
let sentTransaction = await wallet.sendTransaction({
blockchain: 'ethereum',
to: '0xae60aC8e69414C2Dc362D0e6a03af643d1D85b92',
api: [{"inputs":[{"internalType":"address","name":"_configuration","type":"address"}],"stateMutability":"nonpayable","type":"constructor"},{"inputs":[],"name":"ETH","outputs":[{"internalType":"address","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[],"name":"configuration","outputs":[{"internalType":"contract DePayRouterV1Configuration","name":"","type":"address"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address","name":"pluginAddress","type":"address"}],"name":"isApproved","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"view","type":"function"},{"inputs":[{"internalType":"address[]","name":"path","type":"address[]"},{"internalType":"uint256[]","name":"amounts","type":"uint256[]"},{"internalType":"address[]","name":"addresses","type":"address[]"},{"internalType":"address[]","name":"plugins","type":"address[]"},{"internalType":"string[]","name":"data","type":"string[]"}],"name":"route","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"payable","type":"function"},{"inputs":[{"internalType":"address","name":"token","type":"address"},{"internalType":"uint256","name":"amount","type":"uint256"}],"name":"withdraw","outputs":[{"internalType":"bool","name":"","type":"bool"}],"stateMutability":"nonpayable","type":"function"},{"stateMutability":"payable","type":"receive"}],
method: 'route',
params: {
path: ["0xb056c38f6b7Dc4064367403E26424CD2c60655e1","0xC02aaA39b223FE8D0A0e5C4F27eAD9083C756Cc2","0xa0bEd124a09ac2Bd941b10349d8d224fe3c955eb"],
amounts: ["11275067000000000000000","100000000000000000000", "1632063302"],
addresses: ["0x39794c3171d4D82eB9C6FBb764749Eb7ED92881d", "0x39794c3171d4D82eB9C6FBb764749Eb7ED92881d"],
plugins: ["0xe04b08Dfc6CaA0F4Ec523a3Ae283Ece7efE00019", "0x99F3F4685a7178F26EB4F4Ca8B75a1724F1577B9"],
data: []
},
value: "0",
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
```#### Solana: sendTransaction
Available arguments for Solana blockchains:
`blockchain: String`: Name of the blockchain e.g. 'solana'.
`failed: Function (transaction, error)=>{}`: Callback to be executed if transaction failed (e.g. reverted).
`sent: Function (transaction)=>{}`: Callback to be executed if transaction has been sent to the network.
`succeeded: Function (transaction)=>{}`: Callback to be executed if transaction was successful and has been confirmed once by the network.
##### Solana: Simple value transfer
e.g. send 0.01 SOL on Solana:
`to String`: Address of the receiver.
`value: Number or BigNumber as String`: Value of the transaction (only needed for simple SOL transfers).
```javascript
let sentTransaction = await wallet.sendTransaction({
blockchain: 'solana',
to: '2UgCJaHU5y8NC4uWQcZYeV9a5RyYLF7iKYCybCsdFFD1',
value: 0.01,
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
```##### Solana: Sign and send instructions
`instructions Array`: A set of TransactionInstructions
e.g. Send 1 USDC:
```javascript
import Token from '@depay/web3-tokens'let sentTransaction = await wallet.sendTransaction({
blockchain: 'solana',
instructions: [
await Token.solana.createTransferInstructions({
token: 'EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v',
amount: '1000000',
from: await wallet.account(),
to: '5AcFMJZkXo14r3Hj99iYd1HScPiM4hAcLZf552DfZkxas'
})
],
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
```###### Solana: Instruction signers
If you need to sign an instruction (e.g. creating "throw away" accounts)
you can pass `signers` as part of the transaction passed to `sendTransaction`:
```javascript
import { getProvider } from '@depay/web3-client'
import Token from '@depay/web3-tokens'
import { PublicKey, SystemProgram, Keypair } from '@depay/solana-web3.js'const wallets = await getWallets()
const wallet = wallets[0]
const fromAddress = await wallet.account()
const provider = await getProvider('solana')
const keypair = Keypair.generate()
const account = keypair.publicKey.toString()
const rent = await provider.getMinimumBalanceForRentExemption(Token.solana.TOKEN_LAYOUT.span)let instruction = SystemProgram.createAccount({
fromPubkey: new SolanaWeb3js.PublicKey(fromAddress),
newAccountPubkey: new SolanaWeb3js.PublicKey(wrappedAccount),
programId: new SolanaWeb3js.PublicKey(Web3Tokens.Token.solana.TOKEN_PROGRAM),
space: Web3Tokens.Token.solana.TOKEN_LAYOUT.span,
lamports: rent
})let sentTransaction = await wallet.sendTransaction({
blockchain: 'solana',
instructions: [instruction],
signers: [keypair],
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
```###### Solana: Address Lookup Tables
If you need to pass address lookup tables in order to reduce transaction size,
you can pass `alts` as part of the transaction passed to `sendTransaction`:
```javascript
import { getProvider } from '@depay/web3-client'
import Token from '@depay/web3-tokens'
import { PublicKey, SystemProgram, Keypair } from '@depay/solana-web3.js'const wallets = await getWallets()
const wallet = wallets[0]
const fromAddress = await wallet.account()
const provider = await getProvider('solana')
const keypair = Keypair.generate()
const account = keypair.publicKey.toString()
const rent = await provider.getMinimumBalanceForRentExemption(Token.solana.TOKEN_LAYOUT.span)let instruction = SystemProgram.createAccount({
fromPubkey: new SolanaWeb3js.PublicKey(fromAddress),
newAccountPubkey: new SolanaWeb3js.PublicKey(wrappedAccount),
programId: new SolanaWeb3js.PublicKey(Web3Tokens.Token.solana.TOKEN_PROGRAM),
space: Web3Tokens.Token.solana.TOKEN_LAYOUT.span,
lamports: rent
})let sentTransaction = await wallet.sendTransaction({
blockchain: 'solana',
instructions: [instruction],
signers: [keypair],
alts: ['3sEm5YYxgLnP1Z11WXHSgScWqFMrATSNDgZcXAcB1w9A'],
sent: function(transaction){},
succeeded: function(transaction){},
failed: function(transaction, error){}
})
```#### value
If value is passed as a number it's gonna be converted into a big number applying the individual blockchain's default decimals:
```javascript
let transaction = new Transaction({
...,
value: 1
})transaction.value // '1000000000000000000'
```If value is passed as a string or as a BigNumber, value is used just as provided:
```javascript
let transaction = new Transaction({
...,
value: '1000000000000000000'
})transaction.value // '1000000000000000000'
```#### wrong network
`sendTransaction` rejects with:
```javascript
{ code: 'WRONG_NETWORK' }
```in case wallet is connected to the wrong network and network cant be switched automatically.
### Get wallet transaction count
```javascript
import { transactionCount } from '@depay/web3-wallets'let count = await transactionCount({ blockchain: 'polygon', address: '0x8Ffdb4Ee24a625856c82db7FAAE5Bd8B3406eF86' })
```### Sign messages
```javascript
let signature = await wallet.sign("This is a message to be signed")
```## Logos
### Conversion
Use https://codebeautify.org
## Development
### Get started
```
yarn install
yarn dev
```### Release
```
npm publish
```