Skip to content

Run a POA node on Windows

$ whoami edited this page Dec 30, 2023 · 16 revisions

How to run a POA node on Windows

If you are not confident in setting up a node on Catalyst / require a more in depth guide this an be found here: Run a POA node on Windows (Simple)

NOTE:

If at any point you have issues please check our FAQ which we will be constantly updating: FAQ

If the answers can not be found there then feel free to add a new issue to the repository here: Issues and one of our team members or members of the community will be able to assist you.

1. Install .Net

Catalyst.Node works with .Net 8. You'll need to have the .Net SDK installed.

If you don't have .Net Core installed you can follow the instructions for your platform bellow.

2. Install MongoDB

Instructions to install MongoDB can be found here for each operating system.

3. Clone the repository

To clone the repository it is assumed you have Git installed. If you do not, then follow the Git install instructions.

Prerequisite - Enable long paths

make sure that long paths are allowed in both windows and git

To clone the Catalyst repository use the command:

git clone https://github.com/catalyst-network/Catalyst.git

Then navigate into the repository:

cd Catalyst

Install the dependencies using the command:

git submodule update --init --recursive --force

4. Build the solution

Navigate to the src folder:

cd src

In the src folder build the solution:

dotnet build Catalyst.sln

5. Run the node

To run the node change to:

cd Catalyst.Node.POA.CE

Then use the command

dotnet run

You must now move on to configurifng your node as described below.

Configuring a Catalyst POA node

Currently on the POA network the catalyst peer ID and DFS peer ID are seperate. This will be changed soon however currently the node must be configured as follows:

  1. If this is the first time that you have ran the node then you will be asked to create three passwords:
  • Node password
  • IPFS Password
  • Certificate Password

Create these passwords and keep them safe (there is no way to recover these passwords as they are only held locally on your machine).

Once these three passwords have been set you must stop the node running this is generally done by pressing:

Ctrl + c

  1. Find and copy your public key for later use, it should show in the console output or in the Catalyst logs like the following:

using PublicKey: 3edzejbuvme3ed4wqr5pp23if7rguoy7yddlcy3whijywzvo7lfq

  1. Find your external ip address and copy it for later use: Whats My IP Address

  2. Go to your home profile directory:

WINDOWS(cd %userprofile%/.catalyst) or LINUX / MacOS(cd ~/.catalyst)

  1. Edit devnet.json and replace the Peer BindAddress and the RCP BindAddress with your internal IP address found using the command ipcconfig on Windows and ifconfig on Unix (MacOS / Linux) using IPV4. Then replace the Peer PublicIpAddress with your external ip address from Step 3 and replace the public key with your public key from Step 2.

  2. Port forward if you are behind NAT. If your internal and external IP Addresses in step 5 were different then you are behind NAT.

There are steps that you can follow which will allow us to forward the ports for you automatically. This will only work with compatible routers. To try this run:

dotnet run --project ../Catalyst.Modules.UPnP --filepath ~/.catalyst/devnet.json

This will run a program which will attempt to configure your ports, it will provide feedback on whether this was successful or not.

If the above is unsuccessful will you will have to log into your router with administrator passwords. These can generally be found on the router.

Some common default IP addresses for router login are:

  • BT - 192.168.1.254
  • TalkTalk - 192.168.1.1
  • EE - 192.168.1.1
  • Virgin - 192.168.0.1
  • Sky - 192.168.0.1

We have created a guide for the process for BT initially and to update with more examples however this process varies from router to router, some will not require log in and port forwarding can be performed via an app e.g. Google Nest. However, the process remains generally the same. The guide can be found here:

BT Home Hub Port Forwarding

The port forwards that will need to be set up are as follows : 42076(udp) 42066(tcp) 4001(tcp) / API: 5005(tcp). Here is a guide on how to port forward Port Forward.

  1. If not currently in 'Catalyst.Node.POA.CE' move to this directory. Re-run your node, enter your credentials again and the node should now be running.
Clone this wiki locally