#!/bin/bash DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null && pwd )" # Source a file source_file() { if [ -f $1 ]; then source $1 elif [ -f "$1.tpl" ]; then source "$1.tpl" else echo "Unable to find file $1" fi } # Source config files source_file "$DIR/conf/docker-bitcoind.conf" source_file "$DIR/conf/docker-explorer.conf" source_file "$DIR/conf/docker-common.conf" source_file "$DIR/.env" # Export some variables for compose export BITCOIND_RPC_EXTERNAL_IP # Select YAML files select_yaml_files() { yamlFiles="-f $DIR/docker-compose.yaml" if [ "$BITCOIND_INSTALL" == "on" ]; then yamlFiles="$yamlFiles -f $DIR/overrides/bitcoind.install.yaml" if [ "$BITCOIND_RPC_EXTERNAL" == "on" ]; then yamlFiles="$yamlFiles -f $DIR/overrides/bitcoind.rpc.expose.yaml" fi fi if [ "$EXPLORER_INSTALL" == "on" ]; then yamlFiles="$yamlFiles -f $DIR/overrides/explorer.install.yaml" fi # Return yamlFiles echo "$yamlFiles" } # Docker up docker_up() { yamlFiles=$(select_yaml_files) eval "docker-compose $yamlFiles up $1 -d" } # Start start() { docker_up --remove-orphans } # Stop stop() { if [ "$BITCOIND_INSTALL" == "on" ]; then if [ "$BITCOIND_EPHEMERAL_HS" = "on" ]; then docker exec -it tor rm -rf /var/lib/tor/hsv2bitcoind fi docker exec -it bitcoind bitcoin-cli \ -rpcconnect=bitcoind \ --rpcport=28256 \ --rpcuser="$BITCOIND_RPC_USER" \ --rpcpassword="$BITCOIND_RPC_PASSWORD" \ stop echo "Preparing shutdown of dojo. Please wait." bitcoindDown=$(timeout 3m docker wait bitcoind) if [ $bitcoindDown -eq 0 ]; then echo "Bitcoin server stopped." else echo "Force shutdown of Bitcoin server." fi fi yamlFiles=$(select_yaml_files) eval "docker-compose $yamlFiles down" } # Restart dojo restart() { stop docker_up } # Install install() { source "$DIR/install/install-scripts.sh" launchInstall=1 if [ "$1" = "--auto" ]; then launchInstall=0 else get_confirmation launchInstall=$? fi if [ $launchInstall -eq 0 ]; then init_config_files docker_up --remove-orphans if [ "$1" != "--nolog" ]; then logs fi fi } # Delete everything uninstall() { docker-compose rm yamlFiles=$(select_yaml_files) eval "docker-compose $yamlFiles down" docker image rm samouraiwallet/dojo-db:"$DOJO_DB_VERSION_TAG" docker image rm samouraiwallet/dojo-bitcoind:"$DOJO_BITCOIND_VERSION_TAG" docker image rm samouraiwallet/dojo-explorer:"$DOJO_EXPLORER_VERSION_TAG" docker image rm samouraiwallet/dojo-nodejs:"$DOJO_NODEJS_VERSION_TAG" docker image rm samouraiwallet/dojo-nginx:"$DOJO_NGINX_VERSION_TAG" docker image rm samouraiwallet/dojo-tor:"$DOJO_TOR_VERSION_TAG" docker volume prune } # Clean-up (remove old docker images) del_images_for() { # $1: image name # $2: most recent version of the image (do not delete this one) docker image ls | grep "$1" | sed "s/ \+/,/g" | cut -d"," -f2 | while read -r version ; do if [ "$2" != "$version" ]; then docker image rm "$1:$version" fi done } clean() { docker image prune del_images_for samouraiwallet/dojo-db "$DOJO_DB_VERSION_TAG" del_images_for samouraiwallet/dojo-bitcoind "$DOJO_BITCOIND_VERSION_TAG" del_images_for samouraiwallet/dojo-explorer "$DOJO_EXPLORER_VERSION_TAG" del_images_for samouraiwallet/dojo-nodejs "$DOJO_NODEJS_VERSION_TAG" del_images_for samouraiwallet/dojo-nginx "$DOJO_NGINX_VERSION_TAG" del_images_for samouraiwallet/dojo-tor "$DOJO_TOR_VERSION_TAG" } # Upgrade upgrade() { source "$DIR/install/upgrade-scripts.sh" launchUpgrade=1 if [ "$1" = "--auto" ]; then launchUpgrade=0 else get_confirmation launchUpgrade=$? fi if [ $launchUpgrade -eq 0 ]; then yamlFiles=$(select_yaml_files) update_config_files cleanup source_file "$DIR/conf/docker-bitcoind.conf" export BITCOIND_RPC_EXTERNAL_IP eval "docker-compose $yamlFiles build --no-cache" docker_up --remove-orphans update_dojo_db if [ "$1" != "--nolog" ]; then logs fi fi } # Display the onion address onion() { if [ "$EXPLORER_INSTALL" == "on" ]; then V3_ADDR_EXPLORER=$( docker exec -it tor cat /var/lib/tor/hsv3explorer/hostname ) echo "Explorer hidden service address (v3) = $V3_ADDR_EXPLORER" fi V2_ADDR=$( docker exec -it tor cat /var/lib/tor/hsv2dojo/hostname ) V3_ADDR=$( docker exec -it tor cat /var/lib/tor/hsv3dojo/hostname ) echo "API hidden service address (v3) = $V3_ADDR" echo "API hidden service address (v2) = $V2_ADDR" if [ "$BITCOIND_INSTALL" == "on" ]; then V2_ADDR_BTCD=$( docker exec -it tor cat /var/lib/tor/hsv2bitcoind/hostname ) echo "bitcoind hidden service address (v2) = $V2_ADDR_BTCD" fi } # Display the version of this dojo version() { echo "Dojo v$DOJO_VERSION_TAG" } # Display logs logs_node() { if [ $3 -eq 0 ]; then docker exec -ti nodejs tail -f /data/logs/$1-$2.log else docker exec -ti nodejs tail -n $3 /data/logs/$1-$2.log fi } logs_explorer() { if [ $3 -eq 0 ]; then docker exec -ti explorer tail -f /data/logs/$1-$2.log else docker exec -ti explorer tail -n $3 /data/logs/$1-$2.log fi } logs() { source_file "$DIR/conf/docker-bitcoind.conf" source_file "$DIR/conf/docker-common.conf" case $1 in db ) docker-compose logs --tail=50 --follow db ;; bitcoind ) if [ "$BITCOIND_INSTALL" == "on" ]; then if [ "$COMMON_BTC_NETWORK" == "testnet" ]; then bitcoindDataDir="/home/bitcoin/.bitcoin/testnet3" else bitcoindDataDir="/home/bitcoin/.bitcoin" fi docker exec -ti bitcoind tail -f "$bitcoindDataDir/debug.log" else echo -e "Command not supported for your setup.\nCause: Your Dojo is using an external bitcoind" fi ;; tor ) docker-compose logs --tail=50 --follow tor ;; api | pushtx | pushtx-orchest | tracker ) logs_node $1 $2 $3 ;; explorer ) logs_explorer $1 $2 $3 ;; * ) yamlFiles=$(select_yaml_files) services="nginx node tor db" if [ "$BITCOIND_INSTALL" == "on" ]; then services="$services bitcoind" fi if [ "$EXPLORER_INSTALL" == "on" ]; then services="$services explorer" fi eval "docker-compose $yamlFiles logs --tail=0 --follow $services" ;; esac } # Display the help help() { echo "Usage: dojo.sh command [module] [options]" echo "Interact with your dojo." echo " " echo "Available commands:" echo " " echo " help Display this help message." echo " " echo " bitcoin-cli Launch a bitcoin-cli console allowing to interact with your full node through its RPC API." echo " " echo " clean Free disk space by deleting docker dangling images and images of previous versions." echo " " echo " install Install your dojo." echo " " echo " logs [module] [options] Display the logs of your dojo. Use CTRL+C to stop the logs." echo " " echo " Available modules:" echo " dojo.sh logs : display the logs of all the Docker containers" echo " dojo.sh logs bitcoind : display the logs of bitcoind" echo " dojo.sh logs db : display the logs of the MySQL database" echo " dojo.sh logs tor : display the logs of tor" echo " dojo.sh logs api : display the logs of the REST API (nodejs)" echo " dojo.sh logs tracker : display the logs of the Tracker (nodejs)" echo " dojo.sh logs pushtx : display the logs of the pushTx API (nodejs)" echo " dojo.sh logs pushtx-orchest : display the logs of the pushTx Orchestrator (nodejs)" echo " dojo.sh logs explorer : display the logs of the Explorer" echo " " echo " Available options (only available for api, tracker, pushtx, pushtx-orchest and explorer modules):" echo " -d [VALUE] : select the type of log to be displayed." echo " VALUE can be output (default) or error." echo " -n [VALUE] : display the last VALUE lines" echo " " echo " onion Display the Tor onion address allowing your wallet to access your dojo." echo " " echo " restart Restart your dojo." echo " " echo " start Start your dojo." echo " " echo " stop Stop your dojo." echo " " echo " uninstall Delete your dojo. Be careful! This command will also remove all data." echo " " echo " upgrade Upgrade your dojo." echo " " echo " version Display the version of dojo" } # # Parse options to the dojo command # while getopts ":h" opt; do case ${opt} in h ) help exit 0 ;; \? ) echo "Invalid Option: -$OPTARG" 1>&2 exit 1 ;; esac done shift $((OPTIND -1)) subcommand=$1; shift case "$subcommand" in bitcoin-cli ) if [ "$BITCOIND_INSTALL" == "on" ]; then docker exec -it bitcoind bitcoin-cli \ -rpcconnect=bitcoind \ --rpcport=28256 \ --rpcuser="$BITCOIND_RPC_USER" \ --rpcpassword="$BITCOIND_RPC_PASSWORD" \ $1 $2 $3 $4 $5 else echo -e "Command not supported for your setup.\nCause: Your Dojo is using an external bitcoind" fi ;; help ) help ;; clean ) clean ;; install ) install $1 ;; logs ) module=$1; shift display="output" numlines=0 # Process package options while getopts ":d:n:" opt; do case ${opt} in d ) display=$OPTARG ;; n ) numlines=$OPTARG ;; \? ) echo "Invalid Option: -$OPTARG" 1>&2 exit 1 ;; : ) echo "Invalid Option: -$OPTARG requires an argument" 1>&2 exit 1 ;; esac done shift $((OPTIND -1)) logs $module $display $numlines ;; onion ) onion ;; restart ) restart ;; start ) start ;; stop ) stop ;; uninstall ) uninstall ;; upgrade ) upgrade $1 ;; version ) version ;; esac