135 lines
4.2 KiB
Bash
135 lines
4.2 KiB
Bash
#!/bin/bash
|
|
set -e
|
|
set -u
|
|
set -x
|
|
|
|
# this should be provided through env by azure template
|
|
TEMPLATES_BRANCH="${TEMPLATES_BRANCH}"
|
|
|
|
echo "========== ${TEMPLATES_BRANCH}/bootnode/install.sh starting =========="
|
|
echo "===== current time: $(date)"
|
|
echo "===== username: $(whoami)"
|
|
echo "===== working directory: $(pwd)"
|
|
echo "===== operating system info:"
|
|
lsb_release -a
|
|
echo "===== memory usage info:"
|
|
free -m
|
|
|
|
EXT_IP="$(curl ifconfig.co)"
|
|
echo "===== external ip: ${EXT_IP}"
|
|
|
|
NGINX_FILE_LOC="https://raw.githubusercontent.com/oraclesorg/test-templates/${TEMPLATES_BRANCH}/TestTestNet/bootnode/nginx.default.site"
|
|
|
|
INSTALL_CONFIG_REPO="https://raw.githubusercontent.com/oraclesorg/test-templates/${TEMPLATES_BRANCH}/TestTestNet/bootnode"
|
|
echo "===== repo base path: ${INSTALL_CONFIG_REPO}"
|
|
|
|
echo "===== downloading common.vars"
|
|
curl -sLO "https://raw.githubusercontent.com/oraclesorg/test-templates/${TEMPLATES_BRANCH}/TestTestNet/common.vars"
|
|
source common.vars
|
|
|
|
# this should be provided through env by azure template
|
|
NETSTATS_SERVER="${NETSTATS_SERVER}"
|
|
NETSTATS_SECRET="${NETSTATS_SECRET}"
|
|
NODE_FULLNAME="${NODE_FULLNAME:-Bootnode}"
|
|
NODE_ADMIN_EMAIL="${NODE_ADMIN_EMAIL:-somebody@somehere}"
|
|
ADMIN_USERNAME="${ADMIN_USERNAME}"
|
|
|
|
export HOME="${HOME:-/home/${ADMIN_USERNAME}}"
|
|
|
|
echo "===== environmental variables:"
|
|
printenv
|
|
|
|
echo "===== downloading common.funcs"
|
|
curl -sLO "https://raw.githubusercontent.com/oraclesorg/test-templates/${TEMPLATES_BRANCH}/TestTestNet/common.funcs"
|
|
source common.funcs
|
|
|
|
setup_ufw() {
|
|
echo "=====> setup_ufw"
|
|
sudo sudo ufw enable
|
|
sudo ufw default deny incoming
|
|
sudo ufw allow 443
|
|
sudo ufw allow 8545
|
|
sudo ufw allow 22/tcp
|
|
sudo ufw allow 30303/tcp
|
|
sudo ufw allow 30303/udp
|
|
echo "<===== setup_ufw"
|
|
}
|
|
|
|
pull_image_and_configs() {
|
|
echo "=====> pull_image_and_configs"
|
|
# curl -s -O "${INSTALL_CONFIG_REPO}/../${GENESIS_JSON}"
|
|
curl -s -o "${GENESIS_JSON}" "${GENESIS_REPO_LOC}"
|
|
curl -s -o "bootnodes.txt" "${BOOTNODES_TXT}"
|
|
curl -s -O "${INSTALL_CONFIG_REPO}/node.toml"
|
|
sed -i "/\[network\]/a nat=\"extip:${EXT_IP}\"" ${NODE_TOML}
|
|
#sed -i "/\[network\]/a bootnodes=\[$(cat bootnodes.txt | sed 's/\r$//' | awk -F'#' '{ print $1 }' | awk '/enode/{ print "\""$1"\"" }' | paste -sd "," -)\]" ${NODE_TOML}
|
|
sed -i "/\[network\]/a reserved_peers=\"/home/${ADMIN_USERNAME}/bootnodes.txt\"" ${NODE_TOML}
|
|
cat >> ${NODE_TOML} <<EOF
|
|
[misc]
|
|
log_file = "/home/${ADMIN_USERNAME}/logs/parity.log"
|
|
EOF
|
|
mkdir -p parity_data/keys/OraclesPoA
|
|
|
|
echo "<===== pull_image_and_configs"
|
|
}
|
|
|
|
clone_dapps() {
|
|
echo "=====> clone_dapps"
|
|
mkdir -p parity_data/dapps
|
|
git clone -b ${DAPPS_BRANCH} --single-branch https://github.com/oraclesorg/oracles-dapps-keys-generation.git parity_data/dapps/KeysGenerator
|
|
git clone -b ${DAPPS_BRANCH} --single-branch https://github.com/oraclesorg/oracles-dapps-voting.git parity_data/dapps/Voting
|
|
git clone -b ${DAPPS_BRANCH} --single-branch https://github.com/oraclesorg/oracles-dapps-validators.git parity_data/dapps/ValidatorsList
|
|
echo "<===== clone_dapps"
|
|
}
|
|
|
|
gen_certs() {
|
|
echo "=====> gen_certs"
|
|
mkdir certs
|
|
openssl req -x509 -newkey rsa:4096 -nodes -subj "/CN=${EXT_IP}" -keyout certs/key.pem -out certs/cert.pem -days 1095
|
|
echo "<===== gen_certs"
|
|
}
|
|
|
|
install_nginx() {
|
|
echo "=====> install_nginx"
|
|
sudo apt-get install -y nginx
|
|
curl -sL "${NGINX_FILE_LOC}" | sed "s/ADMIN_USERNAME/${ADMIN_USERNAME}/g" | sudo tee /etc/nginx/sites-enabled/default > /dev/null
|
|
sudo service nginx restart
|
|
echo "<===== install_nginx"
|
|
}
|
|
|
|
# MAIN
|
|
main () {
|
|
sudo apt-get update
|
|
|
|
prepare_homedir
|
|
setup_ufw
|
|
increase_ulimit_n
|
|
install_ntpd
|
|
install_haveged
|
|
allocate_swap
|
|
|
|
install_nodejs
|
|
pull_image_and_configs
|
|
clone_dapps
|
|
|
|
if [ "${PARITY_INSTALLATION_MODE}" = "BIN" ]; then
|
|
use_bin_via_systemd
|
|
elif [ "${PARITY_INSTALLATION_MODE}" = "DEB" ]; then
|
|
use_deb_via_systemd
|
|
else
|
|
echo "===== invalid PARITY_INSTALLATION_MODE == ${PARITY_INSTALLATION_MODE}. Should be either BIN or DEB"
|
|
exit 1
|
|
fi
|
|
|
|
gen_certs
|
|
install_nginx
|
|
|
|
start_pm2_via_systemd
|
|
install_netstats_via_systemd
|
|
|
|
configure_logrotate
|
|
}
|
|
|
|
main
|
|
echo "========== ${TEMPLATES_BRANCH}/bootnode/install.sh finished =========="
|