-
Notifications
You must be signed in to change notification settings - Fork 0
Client Installation and Configuration
The DEX client can be installed in one of the following ways. Download the application from just one of the following locations:
- Download the standalone DEX client for your operating system for the latest
release on GitHub. Extract the
"dexc" executable from the archive and run it. Open any web browser to the
link shown by the application. You may also put the dexc executable's
folder on your
PATH
. - Use Decrediton, the official graphical Decred wallet, which integrates the DEX client, and go to the DEX tab.
- (Legacy users) Use the Decred command line application installer, dcrinstall. This is no longer recommended.
- Build the standalone client from source.
WARNING: If you decide to build from source, use the latest release branch,
not master
.
If using external wallet software (e.g. dcrd+dcrwallet, bitcoind, Electrum, etc.), they must remain running while the DEX client is running. Do not shut down, lock, unlock, or otherwise modify your wallet settings while the client is running. Also, only send funds from within the DEX application, not directly from the external wallet's own controls. Finally, do not manually lock or unlock any coins while the DEX client is running.
These instructions assume you've obtained the DEX client as described in the Client Quick Start Installation section.
If you use the standalone DEX client, you will need a web browser to open the DEX client user interface as described in the next section.
Most users will use the native wallets that are already built into the DEX client. Depending on the asset, you may be able to choose from: (1) a native wallet, (2) an external full node wallet, or (3) an Electrum-based wallet. Consult the following table for a summary of wallet support. If there is a checkmark in the "native" column, no external software is required.
Coin | native | full node | Electrum | notes |
---|---|---|---|---|
Bitcoin | ✓ | v0.21-v24 | v4.2.x | |
Decred | ✓ | v1.7-1.8 | x | |
Ethereum | ✓ | geth IPC/http/ws | N/A | see https://github.com/decred/dcrdex/wiki/Ethereum |
Litecoin | ✓ | v0.21.2.2 | v4.2.x | may require a bootstrap peer |
Bitcoin Cash | ✓ | v24+ | x | use only Bitcoin Cash Node for full node |
Dogecoin | x | v1.14.5+ | x | |
Zcash | x | v5.4.2 | x |
NOTE: The Electrum option is less mature and provides less privacy than the other wallet types. Some manual configuration of the Electrum wallet's RPC server is also necessary (example).
If using the native wallets that are integrated with the DEX client (see above), you can skip this section.
If you choose to use an external wallet (full node or Electrum), you must start and synchronize them with their networks before running the DEX client.
Note that Bitcoin Core and most "clones" support block pruning, which can keep your blockchain storage down to a few GB, not the size of the full blockchain, but a large size should be used to avoid full reindexing if used infrequently. Also, for good network fee estimates, the full node should be running for several blocks.
-
Start the client. For the standalone client (dexc), open a command prompt in the folder containing the dexc application and run it. e.g.
./dexc
on Mac and Linux, ordexc.exe
on Windows. To avoid the command prompt on Windows,dexc-tray.exe
may be run instead. If using Decrediton instead of dexc, just click the "DEX" tab and skip to step 3.Note: You can start dexc with another network via a command line flag:
--testnet
or--simnet
, the default ismainnet
. -
In your web browser, navigate to http://localhost:5758. Skip this step if using Decrediton.
-
Set your new client application password. You will use this password to perform all future security-sensitive client operations.
NOTE: Checking the "Remember my password" box only applies to the current session. It is easiest for most users to have it checked.
-
After creating your app password, you'll be taken to the
Quick Configuration
form:The selected native wallets will be created for you and you'll be connected to the selected DEX server when you submit the form.
-
Backup your app seed. This seed is used to restore your DEX accounts and any native wallets, so keep it safe.
If you skip this step now (not recommended), you can go to the Settings page via the "gears" icon in the top navigation bar to retrieve your application seed later.
-
That's it! You'll be redirected to the wallets page after step 4 above.
-
To start trading, follow the guide to Setting Up Your DEX Trading Account.
Note: If you encounter an error about not being able to connect to the selected DEX server during the quick configuration, you can manually add the DEX server. You will see a list of known DEX server(s) you can choose from.
- Go 1.19 or 1.20
- (optional) Node 18 or 20 is used to bundle resources for the browser interface. It's important to note that the DEX client has no external JavaScript dependencies. The client doesn't import any Node packages. We only use Node to lint and compile our own JavaScript and css resources. This build step is not required if building from a release branch such as
release-v0.6
. - At least 2 GB of available system memory.
Build the web assets from client/webserver/site/.
If building from the master
branch, bundle the CSS and JavaScript with Webpack:
npm clean-install && npm run build
Build and run the client from client/cmd/dexc.
go build
./dexc
Connect to the client from your browser at localhost:5758
.
While dexc
may be run from within the git workspace as described above, the
dexc
binary executable generated with go build
can be copied into a
different folder (e.g. /opt/dcrdex/dexc
).
docker build -t user/dcrdex -f client/Dockerfile .
docker volume create --name=dcrdex_data
docker run -d --rm -p 127.0.0.1:5758:5758 -v dcrdex_data:/root/.dexc user/dcrdex