ASGARDEX is a desktop wallet and decentralized exchange client designed to facilitate secure asset management and trading on the THORChain network. Offering features such as cross-chain interoperability, real-time transaction monitoring, and support for multiple cryptocurrencies, it empowers users with seamless access to decentralized financial services.
Key Features:
Secure storage and management of digital assets.
Decentralized exchange capabilities enabling direct swaps between supported tokens.
Cross-chain functionality to interact with various blockchain networks via THORChain.
User-friendly interface for intuitive navigation and transaction execution.
Advanced security measures, including two-factor authentication.
Support for THORChain’s native assets and integrations with popular cryptocurrencies.
Audience & Benefit:
Ideal for crypto enthusiasts, traders, and developers seeking to engage with the THORChain ecosystem. ASGARDEX provides a reliable platform for secure asset management, seamless cross-chain transactions, and access to decentralized exchange services, enabling users to fully leverage the potential of blockchain technology. It can be installed via winget for ease of use.
README
Website
This is the developer source repository, general information, and download page can be found at Asgardex
Feature list
Symbols
:heavy_check_mark: implemented
:white_check_mark: planned
- not needed
(*) Ledger RUNE is not supported at stagenet. Ledger LTC/BCH/DOGE are not supported at testnet.
(**) With or without memo
(***) Vultisig MPC wallet (BETA). Also supports ZEC, ADA, XRP, XRD, SOL, and TRON beyond the chains listed in the table. See Vultisig section for details.
THORChain Exchange
RUNE
BSC /BEP20
BTC
BCH
DOGE
ETH / ERC20
LTC
COSMOS
AVAX
ARB
BASE
Pools overview
-
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Pool detail
-
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Swap
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Deposit *
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Withdraw *
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Recovery tool
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
(*) Symmetrical deposit/withdraw only
MAYA Exchange
MAYA
RUNE
BTC
ETH / ERC20
KUJI
DASH
ARB
Pools overview
-
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Pool detail
-
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Swap
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Deposit *
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Withdraw *
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Recovery tool
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
:white_check_mark:
Synths
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Savers
:heavy_multiplication_x:
:heavy_multiplication_x:
:heavy_multiplication_x:
:heavy_multiplication_x:
:heavy_multiplication_x:
:heavy_multiplication_x:
:heavy_multiplication_x:
(*) Symmetrical deposit/withdraw only
THORNode
Overview
Status
BOND
UNBOND
LEAVE
THORName
:heavy_check_mark:
:white_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
MAYANode
Overview
Status
BOND
UNBOND
LEAVE
MAYAName
:heavy_check_mark:
:white_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_multiplication_x:
:heavy_check_mark:
Languages
ENGLISH :us:
GERMAN :de:
FRENCH :fr:
RUSSIAN :ru:
HINDI :hi:
SPANISH :es:
KOREAN :ko:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
:heavy_check_mark:
Misc
100% open-source (built by the community)
Security first
30 bps affiliate fees only on swaps over $1001
No affiliate fee on: RunePool, LP actions
ASGARDEX utilizes the following libraries, frameworks, and more:
It's recommended to use a Node version as same as Electron is running with (currently: Electron 35 / Node 22.14). It's recommended to install nvm to run as the same Node version locally as used for building ASGARDEX on CI.
git clone https://github.com/asgardex/asgardex-desktop.git asgardex
cd asgardex
yarn
In case you get an an ENAMETOOLONG: name too long error or similar by running yarn install, e.g.
YN0001: │ Error: @storybook/react-docgen-typescript-plugin@npm:1.0.2-canary.6.9d540b91e815f8fc2f8829189deb00553559ff63.0: ENAMETOOLONG: name too long, unlink '~/.yarn/berry/cache/@storybook-react-docgen-typescript-plugin-npm-1.0.2-canary.6.9d540b91e815f8fc2f8829189deb00553559ff63.0-b31cc57c40-8.zip' -> 'asgardex-desktop/.yarn/cache/@storybook-react-docgen-typescript-plugin-npm-1.0.2-canary.6.9d540b91e815f8fc2f8829189deb00553559ff63.0-b31cc57c40-91a3015d38.zip-3439e0483605ccee.tmp'
While environment variables are not required (defaults are set), you can configure them. Create an .env file by copying all content of .env.sample and change these for your needs.
Development
Build everything needed (main, preload and renderer) and run application in watch mode
yarn dev
In case Node might run into memory issues locally set --max-old-space-size as follow:
export NODE_OPTIONS="--max-old-space-size=4096"
Tips & tricks for windows
You may need to install the following dependencies in your local machine in order to build the native libraries used by Asgardex
Install python3
Install 'Microsoft C++ build tools'
Tips & tricks for Linux
You may need to install the following dependencies in your local machine in order to build the native libraries used by Asgardex
Install python3
Install dependency build-essential
sudo apt-get install build-essential
Install dependency libudev-dev
sudo apt-get install libudev-dev
Generate ERC20/BEP20 & Avax & ARB asset white list
Whenever THORChain ERC20 asset whitelist has been updated (usually with a new release of THORNode), run following script to auto-generate this list for ASGARDEX
For synths to have an icon the asset in the whitelist needs to be duplicated and the synth boolean flipped true
How to auto-unlock a locked wallet while hot-reloading the app (for development only, disabled in production build)
Use VITE_WALLET_PASSWORD to run the app by replacing password with your own password
VITE_WALLET_PASSWORD=password yarn dev
Or add to VITE_WALLET_PASSWORD=password to .env file and run yarn dev
Tests
unit
yarn test
lint
yarn lint
Storybook
yarn storybook
bundle analyze
visualize the bundle map using source-map-explorer
yarn analyze
Auto updates
To check locally if auto-update works correctly create dev-app-update.yml file at the root
directory with a content based on dev-app-update.sample.yml with providing
your GutHub personal access token. After that just play locally with version provided by package.json
Folder structure
src
src
├── main # sources of Electron's main process
├── renderer # sources of Electron's renderer process (aka webapp)
└── shared # shared sources for Electron's main and renderer processes
src/main (Electron's "main" app)
src/main
├── electron.ts # entry point
├── i18n # internationalization (needed for menus)
└── menu # "native" menus
By creating or importing a keystore wallet, ASGARDEX is adding its encrypted keystore into wallets.json in Electron's appData folder at following location:
Windows
# ASGARDEX installed from *.exe
%APPDATA%/ASGARDEX/storage/wallets.json
# ASGARDEX built and run locally
%APPDATA%/Electron/storage/wallets.json
macOS
# ASGARDEX installed from *.dmg
~/Library/Application Support/ASGARDEX/storage/wallets.json
# ASGARDEX built and run locally
~/Library/Application Support/Electron/storage/wallets.json
Linux
# ASGARDEX installed from *.deb
~/.config/ASGARDEX/storage/wallets.json
# ASGARDEX built and run locally
~/.config/Electron/storage/wallets.json
By removing a wallet in Wallet -> Settings its data will be removed from wallets.json. ASGARDEX will prompt a message to users to inform about saving its phrase on a save place before removing the wallet.
After removing all wallets wallets.json will be empty and won't include any wallet related data.
Ledger accounts
By adding a Ledger account to a wallet, ASGARDEX saves its address and some extra information (chain, network, walletIndex, hdMode) into ledgers.json located in Electron's appData folder:
Windows
# ASGARDEX installed from *.exe
%APPDATA%/ASGARDEX/storage/ledgers.json
# ASGARDEX built and run locally
%APPDATA%/Electron/storage/ledgers.json
macOS
# ASGARDEX installed from *.dmg
~/Library/Application Support/ASGARDEX/storage/ledgers.json
# ASGARDEX built and run locally
~/Library/Application Support/Electron/storage/ledgers.json
Linux
# ASGARDEX installed from *.deb
~/.config/ASGARDEX/storage/ledgers.json
# ASGARDEX built and run locally
~/.config/Electron/storage/ledgers.json
Whenever a Ledger has been removed in Wallet -> Settings, its data will be removed from ledgers.json. By removing all Ledger accounts from each wallet ledgers.json will be empty and won't include any Ledger related data. The same by removing all wallets.
Vultisig (BETA)
ASGARDEX supports Vultisig MPC (multi-party computation) wallets as a third wallet mode alongside Keystore and Ledger. The integration is currently in beta -- a "BETA" indicator is shown in the UI when Vultisig mode is active.
What's implemented
Vault creation -- Two modes: Fast vault (email + password, server-assisted) and Secure vault (2-of-2 MPC with phone pairing via QR code)
Token swaps via THORChain and MAYAChain (verified: BTC, ETH, CACAO, ERC20 tokens)
ERC20 token approvals
Vault import/export using .vult files
Vault lock/unlock with password encryption
Unified wallet dropdown -- switch between Keystore, Ledger, and Vultisig vaults from the header
Not yet implemented
The following features are guarded with "not implemented" warnings when using a Vultisig wallet:
Trade deposits
Liquidity provision (add/withdraw)
Bonds management
Architecture
Vultisig uses the Vultisig MPC SDK, which runs exclusively in Electron's main process. The renderer communicates with the SDK via IPC through window.apiMpc (exposed in the preload script). Key files:
Everyone is welcome to contribute. Check open issues or create a new one to start your work with and open a PR afterwards. Newcomers might want to check issues labeled as good first issues.