Skip to content

Latest commit

 

History

History
357 lines (239 loc) · 14.4 KB

README.md

File metadata and controls

357 lines (239 loc) · 14.4 KB

EWF Token Bridge

Installation tutorial step by step

Primary maintainer: Kamil Rosenberger @Berger91

Table of Content

Required software on local machine

  • git
  • ansible

Additional requirements

  • Prepared validator address and validator private key for bridge
  • static public IP Address
  • domains pointed to machine public IP
    • domain for common resources: rpc, gasprice services. This domain isn't included in the configuration files
    • domain for main bridge
    • domain for main bridge monitor (optional)
    • domain for dai brige (optional)
    • domain for dai bridge monitor (optional)
  • CloudFlare as certificate provider or trusted ssl certificate for bridge components domain
  • Installed python +2.7.17 on your instance

AWS Instance preparation

AWS EC2

We need pretty big instance with 3 additional ebs drives

Type

m5.xlarge

Volumes

/bridge-data - 100 GB
/parity-main - 600 GB
/parity-ewc - 300 GB
/ - 60 GB

Security group

SSH Should be restricted to specified IP's At least we need only to expose HTTP & HTTPS ports becase whole traffic will be forwarded through nginx. In some cases security groups should be modified to fits your needs

80	tcp	0.0.0.0/0	✔
22	tcp	0.0.0.0/0	✔
443	tcp	0.0.0.0/0	✔

Other requirements

Static Public IP Address

Currently we use ubuntu 18.04 for bridge purposes AMI ID: ubuntu/images/hvm-ssd/ubuntu-bionic-18.04-amd64-server-20200112 (ami-03ba3948f6c37a4b0)

Volumes preparation

Whole process has been described in AWS documentation

sudo mkdir /bridge-data
sudo mkdir /parity-main
sudo mkdir /parity-ewc
sudo yum install xfsprogs

sudo mkfs -t xfs /dev/nvme0n1
sudo mount /dev/nvme0n1 /parity-ewc

sudo mkfs -t xfs /dev/nvme1n1
sudo mount /dev/nvme1n1 /bridge-data

sudo mkfs -t xfs /dev/nvme2n1
sudo mount /dev/nvme2n1 /parity-main

sudo cp /etc/fstab /etc/fstab.orig
sudo lsblk -o +UUID
sudo vim /etc/fstab

# Added these lines without '#' and replace UUID's with ones outputed by above commands
# UUID=ea1086b2-f097-4edb-8ebf-1768f0d3250b  /parity-ewc  xfs  defaults,nofail  0  2
# UUID=5242378c-c216-4fb3-82b5-d725becc95cf  /bridge-data  xfs  defaults,nofail  0  2
# UUID=726d4247-605f-4220-9667-3d846a3a0fa1  /parity-main  xfs  defaults,nofail  0  2

sudo mount -a

Expected result example

nvme0n1     259:0    0  300G  0 disk /parity-ewc                 ea1086b2-f097-4edb-8ebf-1768f0d3250b
nvme1n1     259:1    0  100G  0 disk /bridge-data                5242378c-c216-4fb3-82b5-d725becc95cf
nvme2n1     259:2    0  500G  0 disk /parity-main                726d4247-605f-4220-9667-3d846a3a0fa1
nvme3n1     259:3    0   60G  0 disk
└─nvme3n1p1 259:4    0   60G  0 part /                           c03b791b-60ef-4ae1-82b5-5c9ab6b4d08f

AWS Instance required configuration

Prepare directories for blockchain data

  1. Open terminal

  2. Connect via SSH to your instance

  3. Run bellow commands

    sudo chown ubuntu:ubuntu /bridge-data
    sudo chown ubuntu:ubuntu /parity-main
    sudo chown ubuntu:ubuntu /parity-ewc

Ansible common stack (cs)

In this part we are going to install basic dependencies & common resources stack on our bridge instance. This stack contains a required blockchain node with RPC endpoint which should be fully synced before we can continue the bridge installation. All files related to this part are located in the ansible-common-stack directory.

Ansible configuration (cs)

Variables file (cs)

Configuration file location: /ansible-common-stack/group_vars/ewc_bridge.yml

  1. Open that file with your favourite editor to edit variables of interest:

    • bridge_main_domain
    • bridge_main_monitor_domain or switch bridge_main_monitor_expose to false
    • bridge_dai_domain_enable switch to true if you plan to install dai brige too
    • bridge_dai_domain (optional)

Hosts file (cs)

To work with ansible we have to prepare inventory file where we will keep all hosts where we would like to run our playbooks.

  1. Copy example file: cp ansible-common-stack/hosts.yml.example ansible-common-stack/hosts-ewc.yml
  2. Replace example IP with new one associated with your AWS instance. This is necessary for ansible to make a ssh connection and run all commands.

Ansible run (cs)

Now when everything has been prepared follow below steps

  1. Open terminal

  2. Go to the common stack directory: ansible-common-stack

  3. Run ansible playbooks. Remember to provide --private-key flag with value to the location where we keep key for ssh connection with that instance.

    ansible-playbook -i hosts-ewc.yml site.yml --private-key=~/.ssh/id_rsa

You have to wait for RPC to be fully synced

RPC logs - check in (cs)

For convenience we have prepared the possibility to verify RPC status with ansible command as well:

  1. Edit variables file with your favourite editor: ansible-common-stack/group_vars/ewc_bridge.yml

  2. Uncomment this line check_rpc_status_only: true and save file.

  3. Run ansible command but instead of installation proccess we should see parity logs with sync status

    ansible-playbook -i hosts-ewc.yml site.yml --private-key=~/.ssh/id_rsa

Ansible ewc bridge stack (ebs)

Warning: Before starting bridge installation you should be sure that our rpc's are fully synced and below services are accessible

Services list:

In this part you are going to setup & install all necessary bridge components.

All files related to this part are located in the ansible-ewc-bridge directory

Ansible configuration (ebs)

Variables file (ebs)

Configuration file location: /ansible-ewc-bridge/group_vars/ewc_mainnet_native.yml

  1. Open that file with your favourite editor, find and adjust these variables:

    • ORACLE_VALIDATOR_ADDRESS_PRIVATE_KEY - The private key of the bridge validator used to sign confirmations before sending transactions to the bridge contracts. The validator account is calculated automatically from the private key. Every bridge instance (set of watchers and senders) must have its own unique private key. The specified private key is used to sign transactions on both sides of the bridge. Value type: hexidecimal without "0x"
    • ORACLE_VALIDATOR_ADDRESS - The public address of the bridge validator. Value type: hexidecimal with "0x"
    • COMMON_HOME_RPC_URL - Home RPC address
    • COMMON_FOREIGN_RPC_URL - Foreign RPC address
    • COMMON_HOME_GAS_PRICE_SUPPLIER_URL - Home Gasprice service
    • COMMON_FOREIGN_GAS_PRICE_SUPPLIER_URL - Foreign Gasprice service

Warning: Do not share adjusted configuration with anybody, especially validator private key

Hosts file (ebs)

To work with ansible you have to prepare inventory file where we will keep all hosts where we would like to run our playbooks.

  1. Copy example file: cp ansible-ewc-bridge/hosts.yml.example ansible-ewc-bridge/hosts-ewc.yml
  2. Replace IP with new one associated with your AWS instance where you already installed common resources.

Ansible run (ebs)

  1. Open terminal

  2. Go to the ansible-ewc-bridge directory

  3. Run ansible playbooks with below command and watch output. Remember to provide --private-key flag with value to the location where we keep key for ssh connection with that instance.

    ansible-playbook -i hosts-ewc.yml site.yml --private-key=~/.ssh/id_rsa
  4. Check output - If the whole proccess went fine, we should get output from ansible similar to this one:

    PLAY RECAP *****************************************************************************************************
    
    33.123.33.232               : ok=54   changed=30   unreachable=0    failed=0    skipped=6    rescued=0    ignored=2

Ansible dai bridge stack (dbs)

Warning: This is optional section for those who decided to host DAI Bridge

Warning: Before starting bridge installation you should be sure that our rpc's are fully synced and below services are accessible

Services list:

In this part you are going to setup & install all necessary bridge components with configuration dedicated for DAI Bridge.

All files related to this part are located in the ansible-ewc-bridge directory

Ansible configuration (dbs)

Variables file (dbs)

Configuration file location: /ansible-ewc-bridge/group_vars/ewc_mainnet_dai.yml

  1. Open that file with your favourite editor, find and adjust these variables:

    • ORACLE_VALIDATOR_ADDRESS_PRIVATE_KEY - The private key of the bridge validator used to sign confirmations before sending transactions to the bridge contracts. The validator account is calculated automatically from the private key. Every bridge instance (set of watchers and senders) must have its own unique private key. The specified private key is used to sign transactions on both sides of the bridge. Value type: hexidecimal without "0x"
    • ORACLE_VALIDATOR_ADDRESS - The public address of the bridge validator. Value type: hexidecimal with "0x"
    • COMMON_HOME_RPC_URL - Home RPC address
    • COMMON_FOREIGN_RPC_URL - Foreign RPC address
    • COMMON_HOME_GAS_PRICE_SUPPLIER_URL - Home Gasprice service
    • COMMON_FOREIGN_GAS_PRICE_SUPPLIER_URL - Foreign Gasprice service

Warning: Do not share adjusted configuration with anybody, especially validator private key

Hosts file (dbs)

To work with ansible you have to prepare inventory file where we will keep all hosts where we would like to run our playbooks.

  1. Copy example file: cp ansible-ewc-bridge/hosts-dai.yml.example ansible-ewc-bridge/hosts-dai.yml
  2. Replace IP with new one associated with your AWS instance where you already installed common resources.

Ansible run (dbs)

  1. Open terminal

  2. Go to the ansible-ewc-bridge directory

  3. Run ansible playbooks with below command and watch output. Remember to provide --private-key flag with value to the location where we keep key for ssh connection with that instance.

    ansible-playbook -i hosts-dai.yml site.yml --private-key=~/.ssh/id_rsa
  4. Check output - If the whole proccess went fine, we should get output from ansible similar to this one:

    PLAY RECAP *****************************************************************************************************
    
    33.123.33.232               : ok=54   changed=30   unreachable=0    failed=0    skipped=6    rescued=0    ignored=2

Common Stack final run

When you run common stack resources first time, proxy was provided only for common services. Now you are going to run again same scripts but with proxy for bridge UI.

Configuration file location: /ansible-common-stack/group_vars/ewc_bridge.yml

  1. Open configuration file
  2. Switch value for bridge_already_installed from false to true
  3. Run ansible the same way like it was described here: Ansible run (cs)

After this step our bridge site should be available under domain provided in configuration bridge_main_domain and bridge_dai_domain if you decided to configure and install DAI Bridge too.

It is important to note if you do not use Cloudflare with provided certificates, then our browser will see untrusted self generated certs, which might cause e.g. Chrome to deny such connections. You can add an exception or replace certs.

In some cases it is required to restart Nginx. Connect through ssh into the instance, go to the common resources directory (default:/bridge-data/resources-docker-stack) and run:

docker-compose up -d --force-recreate nginx

Proxy certificate adjustment

Ansible scripts generate self signed untrusted certificates just to run over ssl. If you do not use CloudFlare on top of it then it is required to replace that certificates with trusted version for your domain.

Certificates default location:

/bridge-data/resources-docker-stack/nginx/nginx.crt
/bridge-data/resources-docker-stack/nginx/nginx.key

After replacing files, you should restart nginx proxy. Go to the common resources directory (default:/bridge-data/resources-docker-stack) and run:

docker-compose up -d --force-recreate nginx

If you feel comfortable with docker and nginx configuration then you can manually adjust whole configuration to fit your needs.

License

GPL-3.0