Skip to content

Commit

Permalink
Installation wizard TUI (#17)
Browse files Browse the repository at this point in the history
  • Loading branch information
shesek committed Feb 16, 2022
1 parent 6b54d7f commit 4d91b7c
Show file tree
Hide file tree
Showing 9 changed files with 789 additions and 10 deletions.
2 changes: 2 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

## Unreleased

- New installation wizard TUI

- Update Bitcoin Core to v0.21.1

- Update Specter Desktop to v1.5.0
Expand Down
2 changes: 1 addition & 1 deletion Dockerfile
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ FROM $BASE_IMAGE
# See the 'docker' directory for arm32v7/arm64v8

# Build settings
ARG INSTALL=bitcoind,bwt,btc-rpc-explorer,specter,tor,nginx,letsencrypt,dropbear
ARG INSTALL=bitcoind,bwt,btc-rpc-explorer,specter,tor,nginx,letsencrypt,dropbear,wizard
ARG DEV

ARG BWT_VERSION=0.2.4
Expand Down
9 changes: 2 additions & 7 deletions docker/networking.sh
Original file line number Diff line number Diff line change
@@ -1,18 +1,13 @@
# -- expected to be `source`ed

# Detect host OS. Docker on macOS/Widows behaves differently:
# https://docs.docker.com/docker-for-mac/networking/#known-limitations-use-cases-and-workarounds
# https://docs.docker.com/docker-for-windows/networking/#known-limitations-use-cases-and-workarounds
HOST_OS=$(uname -r | grep -Eq -- '-(moby|linuxkit)' && echo macOS \
|| (uname -r | grep -Eq -- '-microsoft' && echo Windows \
|| echo Linux))

# Detect Docker's networking mode and determine the address to bind on
if [ -z "$BIND_ADDR" ]; then
addrs=$(hostname -I)

# macOS/windows doesn't support host networking mode and doesn't allow accessing
# the container by its virtual IP address, so we can just bind on 0.0.0.0.
# https://docs.docker.com/docker-for-mac/networking/#known-limitations-use-cases-and-workarounds
# https://docs.docker.com/docker-for-windows/networking/#known-limitations-use-cases-and-workarounds
if [ $HOST_OS != Linux ]; then
export BIND_ADDR=0.0.0.0

Expand Down
2 changes: 1 addition & 1 deletion docker/release.sh
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,7 @@ echo -e "Releasing eznode v$version\n\n$changelog\n\n"
if [ -z "$SKIP_BUILD" ]; then
echo -n > SHA256SUMS
#build_variant $version latest bitcoind,btc-rpc-explorer
build_variant $version latest bitcoind,bwt,btc-rpc-explorer,specter,tor,nginx,letsencrypt,dropbear
build_variant $version latest bitcoind,bwt,btc-rpc-explorer,specter,tor,nginx,letsencrypt,dropbear,wizard
#build_variant $version-local local bitcoind,bwt,specter,btc-rpc-explorer
#build_variant $version-minimal minimal bitcoind,bwt

Expand Down
11 changes: 11 additions & 0 deletions entrypoint.sh
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,17 @@ export S6_KEEP_ENV=1
export S6_SERVICES_GRACETIME=2700000 # 45 minutes, to allow Bitcoin Core to shutdown cleanly
export S6_KILL_FINISH_MAXTIME=$S6_SERVICES_GRACETIME # for the shutdown-status script

# Detect host OS
export HOST_OS=$(uname -r | grep -Eq -- '-(moby|linuxkit)' && echo macOS \
|| (uname -r | grep -Eq -- '-microsoft' && echo Windows \
|| echo Linux))

# Installation wizard
if [ "$1" == wizard ]; then
/ez/wizard/wizard
shift
fi

# Load config options from file
# `set -a` exports all defined variables without requiring an explicit `export`
if [ -f /data/config ]; then set -a; source /data/config; set +a
Expand Down
4 changes: 3 additions & 1 deletion util.sh
Original file line number Diff line number Diff line change
Expand Up @@ -74,9 +74,11 @@ restart_with() {
}

BOLD=$(echo -en '\e[1m')
UNDER=$(echo -en '\e[4m')
UNDER_R=$(echo -en '\e[24m')
RED=$(echo -en '\e[31m')
GREEN=$(echo -en '\e[32m')
#LGREEN=$(echo -en '\e[92m')
LGREEN=$(echo -en '\e[92m')
YELLOW=$(echo -en '\e[33m')
#LYELLOW=$(echo -en '\e[93m')
ORANGE=$(echo -en '\e[0;33m')
Expand Down
146 changes: 146 additions & 0 deletions wizard/dialogrc
Original file line number Diff line number Diff line change
@@ -0,0 +1,146 @@
#
# Run-time configuration file for dialog
#
# Automatically generated by "dialog --create-rc ~/.dialogrc"
# Then edited for Feliz by Elizabeth Mills
# Revision date: 9th December 2017
#
# Types of values:
#
# Number - <number>
# String - "string"
# Boolean - <ON|OFF>
# Attribute - (foreground,background,highlight?)
# 0 black, 1 red, 2 green, 3 yellow, 4 blue, 5 magenta, 6 cyan and 7 white

# Set aspect-ratio
aspect = 0

# Set separator (for multiple widgets output)
separate_widget = ""

# Set tab-length (for textbox tab-conversion)
tab_len = 0

# Make tab-traversal for checklist, etc., include the list
visit_items = OFF

# Shadow dialog boxes? This also turns on color.
use_shadow = OFF

# Turn color support ON or OFF
use_colors = ON

# Screen color
screen_color = (WHITE,BLUE,OFF)

# Shadow color
shadow_color = (BLACK,BLACK,ON)

# Dialog box color
dialog_color = (BLACK,WHITE,OFF)

# Dialog box title color
title_color = (BLUE,WHITE,ON)

# Dialog box border color
border_color = (BLACK,WHITE,ON)

# Active button color
button_active_color = (WHITE,BLUE,ON)

# Inactive button color
button_inactive_color = dialog_color

# Active button key color
button_key_active_color = button_active_color

# Inactive button key color
button_key_inactive_color = (BLACK,WHITE,ON)

# Active button label color
button_label_active_color = (WHITE,BLUE,ON)

# Inactive button label color
button_label_inactive_color = (BLACK,WHITE,ON)

# Input box color
inputbox_color = dialog_color

# Input box border color
inputbox_border_color = dialog_color

# Search box color
searchbox_color = dialog_color

# Search box title color
searchbox_title_color = title_color

# Search box border color
searchbox_border_color = border_color

# File position indicator color
position_indicator_color = title_color

# Menu box color
menubox_color = dialog_color

# Menu box border color
menubox_border_color = border_color

# Item color
item_color = dialog_color

# Selected item color
item_selected_color = button_active_color

# Tag color
tag_color = (BLACK,WHITE,OFF)

# Selected tag color
tag_selected_color = button_label_active_color

# Tag key color
tag_key_color = button_key_inactive_color

# Selected tag key color
tag_key_selected_color = (WHITE,BLUE,ON)

# Check box color
check_color = dialog_color

# Selected check box color
check_selected_color = button_active_color

# Up arrow color
uarrow_color = (GREEN,WHITE,ON)

# Down arrow color
darrow_color = uarrow_color

# Item help-text color
itemhelp_color = (WHITE,BLACK,OFF)

# Active form text color
form_active_text_color = (BLACK,WHITE,OFF)

# Form text color
form_text_color = (BLACK,WHITE,OFF)

# Readonly form item color
form_item_readonly_color = (BLACK,WHITE,ON)

# Dialog box gauge color
gauge_color = title_color

# Dialog box border2 color
border2_color = dialog_color

# Input box border2 color
inputbox_border2_color = dialog_color

# Search box border2 color
searchbox_border2_color = dialog_color

# Menu box border2 color
menubox_border2_color = dialog_color
7 changes: 7 additions & 0 deletions wizard/install
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
#!/bin/bash
set -xeo pipefail

apt-get install -qqy dialog

mkdir /ez/wizard
mv wizard dialogrc /ez/wizard
Loading

0 comments on commit 4d91b7c

Please sign in to comment.