Skip to content

Client Installation and Configuration

Philemon Ukane edited this page Sep 25, 2023 · 7 revisions

Client Installation and Configuration

Client Quick Start Installation

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.

Important Note on External Wallets

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.

Client Configuration

These instructions assume you've obtained the DEX client as described in the Client Quick Start Installation section.

Prerequisites

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).

Synchronizing Wallets

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.

Initial Setup

  1. 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, or dexc.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 is mainnet.

  2. In your web browser, navigate to http://localhost:5758. Skip this step if using Decrediton.

  3. 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.

  4. 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.

  5. 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.

  6. That's it! You'll be redirected to the wallets page after step 4 above.

  7. 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.

Advanced Client Installation

Dependencies

  1. Go 1.19 or 1.20
  2. (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.
  3. At least 2 GB of available system memory.

Build from Source

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 the docker image

docker build -t user/dcrdex -f client/Dockerfile .

Create docker volume

docker volume create --name=dcrdex_data

Run image

docker run -d --rm -p 127.0.0.1:5758:5758 -v dcrdex_data:/root/.dexc user/dcrdex