This guide contains instructions for the multiple methods of installing and running a self-hosted instance of txnDuck. There are also upgrade and uninstallation instructions for each of the installation methods.
- For the fastest and easiest installation of the stable Production version using Node: Portable package installation
- For the fastest and easiest installation of the stable Production version using Docker: Production Docker image
- For more flexibility and customization with either the Production or Preview version: Source code installation
- For modifying and testing the code for development: Development environment installation
- For quickly and easily setting up the development environment using Docker: Development environment using Docker
Easily run a private instance of txnDuck by installing the portable, self-contained, "standalone" package for the latest stable release. It includes a lightweight server that allows for a private self-hosted instance of txnDuck to be quick and easy to run.
Important
This installation method is not for development.
- Access to the command-line interface (CLI), such as Terminal, PowerShell or Command Prompt
- Node.js version 18.18.0 or higher installed. Version 20.0.0 or higher is recommended.
-
Download the
txnduck-x.x.x.zip
file for the latest release. -
Unzip the downloaded file. There should now be a new folder that contains a bunch of files and folders, such as
public
andserver.js
. -
Open the CLI and go to the folder created in Step #2 by running the following in the CLI. Of course, replace
PATH/TO/SOURCE_CODE/FOLDER
with the actual path to the folder.cd PATH/TO/SOURCE_CODE/FOLDER
-
Run the web server.
node server.js
π‘ TIP: Makes sure the server is serving at localhost:3000. Click for more details.
The portable package installation assumes the web server is serving at
http://localhost:3000
. However, the installation on some machines may default to some other URL. The web server not serving athttp://localhost:3000
may cause certain features to not work correctly.To force the web server to serve at
http://localhost:3000
, set theHOSTNAME
andPORT
environment variables before running the server:PORT=3000 HOSTNAME=localhost node server.js
-
Open a web browser and go to http://localhost:3000 to start using your own txnDuck! π The web server must be running in the CLI (Command Line Interface) to use your txnDuck.
-
If you are finished using your txnDuck, stop the web server by closing the CLI window or by pressing Ctrl+C (or Cmd+C on Mac) while in the CLI. Start the web server again by following Steps #3β5.
- Make sure the web server is not running. Stop the server if it is. Refer to Step #6 in the installation instructions.
- Delete the folder created in Step #2 of the installation instructions.
- OPTIONAL: Uninstall software listed in the requirements if the software is not needed for something else.
Some time after installing the portable package, there will likely be a newer version of the txnDuck portable package. Upgrade to the latest version to get the latest features and bug fixes:
- Make sure the web server is not running. Stop the server if it is. Refer to Step #6 in the installation instructions.
- Follow the installation instructions again.
Use Docker to run an instance of the production version of txnDuck without installing extra dependencies on your machine.
Important
This installation method is not for development.
- Access to the command-line interface (CLI), such as Terminal, PowerShell or Command Prompt
- Docker installed.
-
Pull the image.
docker pull ghcr.io/no-cash-7970/txnduck
-
Create and run a container.
docker run -d -p 3000:3000 ghcr.io/no-cash-7970/txnduck
If you need to use a port other than 3000, use the following instead:
docker run -d -p [PORT]:3000 ghcr.io/no-cash-7970/txnduck
Replace
[PORT]
with the port number you would like to use. For example, use port 3001 instead of 3000:docker run -d -p 3001:3000 ghcr.io/no-cash-7970/txnduck
-
OPTIONAL: Stop the container.
docker stop container_name
-
OPTIONAL: Run the container after stopping it.
docker run -d container_name
-
Stop the container if it is running.
docker stop ghcr.io/no-cash-7970/txnduck
-
Delete the container.
docker rm ghcr.io/no-cash-7970/txnduck
-
Delete the image.
docker rmi ghcr.io/no-cash-7970/txnduck
Install a self-hosted instance of txnDuck by building the source code.
Important
Although this installation method is close to the installation method for development, it is not for development. It does not include the installation of the development tools.
- Access to the command-line interface (CLI), such as Terminal, PowerShell or Command Prompt
- Node.js version 18.18.0 or higher installed. Version 20.0.0 or higher is recommended.
- Yarn package manager installed.
Version 2.0.0 or higher, version 4.0.0 or higher is recommended.
NOTE: If you have Yarn 1.x.x installed, install and switch to Yarn 2.0.0 or higher by running
corepack enable && yarn set version berry
.
-
Download the latest source code.
- Production (
stable
branch): https://github.com/No-Cash-7970/txnDuck/archive/refs/heads/stable.zip - Preview (
main
branch): https://github.com/No-Cash-7970/txnDuck/archive/refs/heads/main.zip
- Production (
-
Unzip the downloaded file. There should now be a new folder that contains a bunch of files and folders, such as
public
andyarn.lock
. -
Open the CLI and go to the folder created in Step #2 by running the following in the CLI. Of course, replace
PATH/TO/SOURCE_CODE/FOLDER
with the actual path to the folder.cd PATH/TO/SOURCE_CODE/FOLDER
-
Install the source code dependencies.
yarn workspaces focus --all --production
-
Build the source code.
yarn build
π― ADVANCED TIP: Customize the build by setting environment variables. Click for more details.
The output of the build can be changed by setting certain environment variables before running the
yarn build
command. For a list of environment variables that change the build output, look within the.env.local.example
file in the source code.Example 1: Specify a different base URL by setting the
BASE_URL
. This allows for a web server to serve at the specified URL without issue.BASE_URL=localhost:8080 yarn build
Example 2: Enable WalletConnect as a wallet connection method by setting the WalletConnect Project ID.
NEXT_PUBLIC_WC_PROJECT_ID=f1696e8f42e091fd86849791bd309d82 yarn build
Example 3: Create and use a
.env.local
file to set environment variables. It is better to use a.env.local
file when setting many environment variables. Quickly create a.env.local
file by copying the.env.local.example
file and renaming the copy to.env.local
. Environment variables not set in the.env.local
file will use the values set in the.env.production
file. After creating a.env.local
file, use the normal build command:yarn build
-
Run the web server.
yarn start
π― ADVANCED TIP: Use "-H" and "-p" options to change the URL the web server serves at. Click for more details.
If the web server needs to serve at a URL other than
http://localhost:3000
, use the-H
and the-p
options foryarn start
to specify the hostname and the port of the web server.For example, to have the server serve at
http://192.168.1.42:80
, use both the-H
and the-p
options:yarn start -H 192.168.1.42 -p 80
If only the port on
localhost
needs to be changed, then only use the-p
option:yarn start -p 8080
-
Open a web browser and go to http://localhost:3000 to start using your own txnDuck! π The web server must be running in the CLI (Command Line Interface) to use your txnDuck.
-
If you are finished using your txnDuck, stop the web server by closing the CLI window or by pressing Ctrl+C (or Cmd+C on Mac) while in the CLI. Start the web server again by following Steps #5β7.
- Make sure the web server is not running. Stop the server if it is. Refer to Step #8 in the installation instructions.
- Delete the source code folder created in Step #2 of the installation instructions
- OPTIONAL: Uninstall the software listed in the requirements if the software is not needed for something else.
Some time after installing using the source code, there will likely be a newer version of the txnDuck source code. Upgrade to the latest version to get the latest features and bug fixes:
- Choose one of the following options:
- OPTION #1: Uninstall the old version by following Steps #1 and #2 of the uninstallation instructions.
- OPTION #2: Keep the old version and rename the source code folder for the old version.
- OPTION #3: Keep the old version without renaming its source code folder. When installing the new version, use a different name for the new version's source code folder.
- Make sure the web server is not running. Stop the server if it is. Refer to Step #8 in the installation instructions.
- Follow the installation instructions again. Make sure you download the latest source code.
Install a private instance of txnDuck with the tools for modifying and testing the source code.
Tip
Useful information about the development environment can be found in the Developers Documentation.
- Access to the command-line interface (CLI), such as Terminal, PowerShell or Command Prompt
- Git installed
- Node.js version 20.0.0 or higher installed.
- Yarn package manager installed.
Version 2.0.0 or higher, version 4.0.0 or higher is recommended.
NOTE: If you have Yarn 1.x.x installed, install and switch to Yarn 2.0.0 or higher by running
corepack enable && yarn set version berry
. - OPTIONAL BUT RECOMMENDED: Visual Studio Code IDE (integrated development environment)
-
Clone the repository.
git clone https://github.com/No-Cash-7970/txnDuck.git
-
Enter the project folder
cd txnDuck
-
Install the dependencies.
yarn install && yarn install:dev
- Delete the project directory that was created when cloning the repository (step #1 of the installation instructions).
- OPTIONAL: Uninstall the software listed in the requirements for the development environment if you do not need them for something else.
-
Pull the changes.
git pull
-
Update the dependencies.
yarn install:dev
Use Docker to run a private instance of txnDuck with the tools for modifying and testing the source code without installing extra dependencies on your machine.
Note
Running the development environment inside of a Docker container is significantly slower than running the development environment without Docker. To install the development environment without Docker, follow the instructions for installing the regular development environment.
Tip
Useful information about the development environment can be found in the Developers Documentation.
- Access to the command-line interface (CLI), such as Terminal, PowerShell or Command Prompt
- Docker version 23.0 or higher installed.
The development environment with Docker makes use of a bind mount. The changes to source code outside a Docker container are applied within the container, and changes to source code within the container are applied outside of the container.
-
Clone the repository.
git clone https://github.com/No-Cash-7970/txnDuck.git
-
Enter the project directory.
cd txnDuck
-
Create and run a container for the development environment. The docker image will be built if one does not exist.
docker compose run --rm -it -p 3000:3000 dev bash
This command runs the newly created docker container and starts the bash shell within the container where you can run commands like
yarn dev
orgit status
.If you need to use a port other than 3000 on your machine, use the following instead:
docker compose run --rm -it -p [PORT]:3000 dev bash
Replace
[PORT]
with the port number you would like to use. For example, use port 3001 instead of 3000:docker compose run --rm -it -p 3001:3000 dev bash
-
OPTIONAL: Exit the container's shell by running the
exit
command within the shell. If you used one of the commands in step #3, the container will automatically be stopped and deleted when you exit the shell. The source code on your machine remains intact when the container is deleted. Run a new container by running one of the commands in step #3 again. -
OPTIONAL: If you install, upgrade or uninstall Node dependencies for txnDuck, you will need to rebuild the image before you run a new container to apply the changes to the new container.
First, delete the old image.
docker rmi txnduck-dev
Then, build a new image and start a new container.
docker compose run --build --rm -it -p 3000:3000 dev bash
-
If the you are in the Docker container shell, exit the shell and stop the container by running the
exit
command within the shell. If you used one of the commands in step #3 of the installation instructions, the container will automatically be deleted when you exit the shell and the source code will remain intact. -
Delete the image.
docker rmi txnduck-dev
-
Delete the project directory that was created when cloning the repository (step #1 of the installation instructions).
-
Pull the changes.
git pull
-
Uninstall the image by following steps #1 and #2 of the uninstallation instructions.
-
Reinstall the development environment by following steps #2 and #3 of the installation instructions.
Important
This only applies to a Source code installation or a development installation.
If the build is going to deployed to a platform other than localhost, then the
BASE_URL
environment variable needs to be set to the URL of the deployed
website. The way in which to set environment variables for a deployment depends
of the platform (e.g. Vercel, AWS). Refer to the documentation for the platform
for how to set the environment variables. However, if your platform does not
provide a way to set environment variable, the BASE_URL
can be set in a
.env.local
file. Create a .env.local
file by copying the
.env.local.example
file and renaming it to .env.local
. Refer to
Next.JS's documentation on environment variables
for details about how environment variables are loaded.
An example of setting the BASE_URL
in a .env.local
file:
# .env.local file
# ...other settings here
BASE_URL=https://example.com
# some more settings here...