update installer
This commit is contained in:
		
							parent
							
								
									a5d3576ab6
								
							
						
					
					
						commit
						986dc1c17f
					
				
							
								
								
									
										221
									
								
								installer/get.sh
									
									
									
									
									
								
							
							
						
						
									
										221
									
								
								installer/get.sh
									
									
									
									
									
								
							| @ -1,11 +1,6 @@ | |||||||
| #!/bin/bash | #!/bin/bash | ||||||
| #<pre><code> | #<pre><code> | ||||||
| 
 | 
 | ||||||
| # This is a 3 step process |  | ||||||
| #   1. First we need to figure out whether to use wget or curl for fetching remote files |  | ||||||
| #   2. Next we need to figure out whether to use unzip or tar for downloading releases |  | ||||||
| #   3. We need to actually install the stuff |  | ||||||
| 
 |  | ||||||
| set -e | set -e | ||||||
| set -u | set -u | ||||||
| 
 | 
 | ||||||
| @ -18,9 +13,9 @@ set -u | |||||||
| 
 | 
 | ||||||
| # See https://git.coolaj86.com/coolaj86/snippets/blob/master/bash/http-get.sh | # See https://git.coolaj86.com/coolaj86/snippets/blob/master/bash/http-get.sh | ||||||
| 
 | 
 | ||||||
| _my_http_get="" | export _my_http_get="" | ||||||
| _my_http_opts="" | export _my_http_opts="" | ||||||
| _my_http_out="" | export _my_http_out="" | ||||||
| 
 | 
 | ||||||
| detect_http_get() | detect_http_get() | ||||||
| { | { | ||||||
| @ -55,215 +50,15 @@ http_bash() | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| detect_http_get | detect_http_get | ||||||
|  | export http_get | ||||||
|  | export http_bash | ||||||
| 
 | 
 | ||||||
| ############################### | ############################### | ||||||
| ##       END HTTP_GET        ## | ##       END HTTP_GET        ## | ||||||
| ############################### | ############################### | ||||||
| 
 | 
 | ||||||
| my_email=${1:-} | if [ -e "installer/install.sh" ]; then | ||||||
| my_relay=${2:-} |   bash installer/install.sh "$@" | ||||||
| my_servernames=${3:-} |  | ||||||
| my_secret=${4:-} |  | ||||||
| my_user="telebit" |  | ||||||
| my_app="telebit" |  | ||||||
| my_bin="telebit.js" |  | ||||||
| my_name="Telebit Remote" |  | ||||||
| my_repo="telebit.js" |  | ||||||
| 
 |  | ||||||
| if [ -z "${my_email}" ]; then |  | ||||||
|   echo "" |  | ||||||
|   echo "" |  | ||||||
|   echo "Telebit uses Greenlock for free automated ssl through Let's Encrypt." |  | ||||||
|   echo "" |  | ||||||
|   echo "To accept the Terms of Service for Telebit, Greenlock and Let's Encrypt," |  | ||||||
|   echo "please enter your email." |  | ||||||
|   echo "" |  | ||||||
|   read -p "email: " my_email |  | ||||||
|   echo "" |  | ||||||
|   # UX - just want a smooth transition |  | ||||||
|   sleep 0.5 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if [ -z "${my_relay}" ]; then |  | ||||||
|   echo "What relay will you be using?" |  | ||||||
|   echo "" |  | ||||||
|   read -p "relay (ex: wss://telebit.cloud): " my_relay |  | ||||||
|   echo "" |  | ||||||
|   # UX - just want a smooth transition |  | ||||||
|   sleep 0.5 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if [ -z "${my_servernames}" ]; then |  | ||||||
|   echo "What servername(s) will you be relaying here?" |  | ||||||
|   echo "" |  | ||||||
|   read -p "domain (ex: example.com,example.net): " my_servernames |  | ||||||
|   echo "" |  | ||||||
|   # UX - just want a smooth transition |  | ||||||
|   sleep 0.5 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| if [ -z "${my_secret}" ]; then |  | ||||||
|   echo "What's your authorization for the relay server?" |  | ||||||
|   echo "" |  | ||||||
|   read -p "auth: " my_secret |  | ||||||
|   echo "" |  | ||||||
|   # UX - just want a smooth transition |  | ||||||
|   sleep 0.5 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| echo "" |  | ||||||
| 
 |  | ||||||
| if [ -z "${TELEBIT_PATH:-}" ]; then |  | ||||||
|   echo 'TELEBIT_PATH="'${TELEBIT_PATH:-}'"' |  | ||||||
|   TELEBIT_PATH=/opt/$my_app |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| echo "Installing $my_name to '$TELEBIT_PATH'" |  | ||||||
| 
 |  | ||||||
| echo "Installing node.js dependencies into $TELEBIT_PATH" |  | ||||||
| # v10.2+ has much needed networking fixes, but breaks ursa. v9.x has severe networking bugs. v8.x has working ursa, but requires tls workarounds" |  | ||||||
| NODEJS_VER="${NODEJS_VER:-v10}" |  | ||||||
| export NODEJS_VER |  | ||||||
| export NODE_PATH="$TELEBIT_PATH/lib/node_modules" |  | ||||||
| export NPM_CONFIG_PREFIX="$TELEBIT_PATH" |  | ||||||
| export PATH="$TELEBIT_PATH/bin:$PATH" |  | ||||||
| sleep 1 |  | ||||||
| http_bash https://git.coolaj86.com/coolaj86/node-installer.sh/raw/branch/master/install.sh --no-dev-deps >/dev/null 2>/dev/null |  | ||||||
| 
 |  | ||||||
| my_tree="master" |  | ||||||
| my_node="$TELEBIT_PATH/bin/node" |  | ||||||
| my_secret=$($my_node -e "console.info(crypto.randomBytes(16).toString('hex'))") |  | ||||||
| my_npm="$my_node $TELEBIT_PATH/bin/npm" |  | ||||||
| my_tmp="$TELEBIT_PATH/tmp" |  | ||||||
| mkdir -p $my_tmp |  | ||||||
| 
 |  | ||||||
| echo "sudo mkdir -p '$TELEBIT_PATH'" |  | ||||||
| sudo mkdir -p "$TELEBIT_PATH" |  | ||||||
| echo "sudo mkdir -p '/etc/$my_user/'" |  | ||||||
| sudo mkdir -p "/etc/$my_user/" |  | ||||||
| 
 |  | ||||||
| set +e |  | ||||||
| #https://git.coolaj86.com/coolaj86/telebit.js.git |  | ||||||
| #https://git.coolaj86.com/coolaj86/telebit.js/archive/:tree:.tar.gz |  | ||||||
| #https://git.coolaj86.com/coolaj86/telebit.js/archive/:tree:.zip |  | ||||||
| my_unzip=$(type -p unzip) |  | ||||||
| my_tar=$(type -p tar) |  | ||||||
| if [ -n "$my_unzip" ]; then |  | ||||||
|   rm -f $my_tmp/$my_app-$my_tree.zip |  | ||||||
|   http_get https://git.coolaj86.com/coolaj86/$my_repo/archive/$my_tree.zip $my_tmp/$my_app-$my_tree.zip |  | ||||||
|   # -o means overwrite, and there is no option to strip |  | ||||||
|   $my_unzip -o $my_tmp/$my_app-$my_tree.zip -d $TELEBIT_PATH/ > /dev/null 2>&1 |  | ||||||
|   cp -ar  $TELEBIT_PATH/$my_repo/* $TELEBIT_PATH/ > /dev/null |  | ||||||
|   rm -rf $TELEBIT_PATH/$my_bin |  | ||||||
| elif [ -n "$my_tar" ]; then |  | ||||||
|   rm -f $my_tmp/$my_app-$my_tree.tar.gz |  | ||||||
|   http_get https://git.coolaj86.com/coolaj86/$my_repo/archive/$my_tree.tar.gz $my_tmp/$my_app-$my_tree.tar.gz |  | ||||||
|   ls -lah $my_tmp/$my_app-$my_tree.tar.gz |  | ||||||
|   $my_tar -xzf $my_tmp/$my_app-$my_tree.tar.gz --strip 1 -C $TELEBIT_PATH/ |  | ||||||
| else | else | ||||||
|   echo "Neither tar nor unzip found. Abort." |   http_bash https://git.coolaj86.com/coolaj86/telebit.js/raw/branch/master/installer/install.sh "$@" | ||||||
|   exit 13 |  | ||||||
| fi | fi | ||||||
| set -e |  | ||||||
| 
 |  | ||||||
| pushd $TELEBIT_PATH >/dev/null |  | ||||||
|   $my_npm install >/dev/null 2>/dev/null |  | ||||||
| popd >/dev/null |  | ||||||
| 
 |  | ||||||
| cat << EOF > $TELEBIT_PATH/bin/$my_app |  | ||||||
| #!/bin/bash |  | ||||||
| $my_node $TELEBIT_PATH/bin/$my_bin |  | ||||||
| EOF |  | ||||||
| chmod a+x $TELEBIT_PATH/bin/$my_app |  | ||||||
| echo "sudo ln -sf $TELEBIT_PATH/bin/$my_app /usr/local/bin/$my_app" |  | ||||||
| sudo ln -sf $TELEBIT_PATH/bin/$my_app /usr/local/bin/$my_app |  | ||||||
| 
 |  | ||||||
| set +e |  | ||||||
| if type -p setcap >/dev/null 2>&1; then |  | ||||||
|   #echo "Setting permissions to allow $my_app to run on port 80 and port 443 without sudo or root" |  | ||||||
|   echo "sudo setcap cap_net_bind_service=+ep $TELEBIT_PATH/bin/node" |  | ||||||
|   sudo setcap cap_net_bind_service=+ep $TELEBIT_PATH/bin/node |  | ||||||
| fi |  | ||||||
| set -e |  | ||||||
| 
 |  | ||||||
| if [ -z "$(cat /etc/passwd | grep $my_user)" ]; then |  | ||||||
|   echo "sudo adduser --home $TELEBIT_PATH --gecos '' --disabled-password $my_user" |  | ||||||
|   sudo adduser --home $TELEBIT_PATH --gecos '' --disabled-password $my_user >/dev/null 2>&1 |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| my_config="$TELEBIT_PATH/etc/$my_app.yml" |  | ||||||
| mkdir -p "$(dirname $my_config)" |  | ||||||
| if [ ! -e "$my_config" ]; then |  | ||||||
|   #rsync -a examples/$my_app.yml "$my_config" |  | ||||||
|   echo "email: $my_email" >> "$my_config" |  | ||||||
|   echo "secret: $my_secret" >> "$my_config" |  | ||||||
|   echo "servernames:\n  $my_servernames: {}" >> "$my_config" |  | ||||||
|   #echo "dynamic_ports:\n  {}" >> "$my_config" |  | ||||||
|   cat examples/$my_app.yml.tpl >> "$my_config" |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| my_config="$HOME/.config/$my_user/$my_app.yml" |  | ||||||
| mkdir -p "$(dirname $my_config)" |  | ||||||
| if [ ! -e "$my_config" ]; then |  | ||||||
|   echo "cli: true" >> "$my_config" |  | ||||||
|   echo "email: $my_email" >> "$my_config" |  | ||||||
|   echo "secret: $my_secret" >> "$my_config" |  | ||||||
|   cat examples/$my_app.yml.tpl >> "$my_config" |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| my_config_link="/etc/$my_user/$my_app.yml" |  | ||||||
| if [ ! -e "$my_config_link" ]; then |  | ||||||
|   echo "sudo ln -sf '$my_config' '$my_config_link'" |  | ||||||
|   #sudo mkdir -p /etc/$my_user |  | ||||||
|   sudo ln -sf "$my_config" "$my_config_link" |  | ||||||
| fi |  | ||||||
| 
 |  | ||||||
| echo "sudo chown -R $my_user '$TELEBIT_PATH' '/etc/$my_user'" |  | ||||||
| sudo chown -R $my_user "$TELEBIT_PATH" "/etc/$my_user" |  | ||||||
| 
 |  | ||||||
| # ~/.config/systemd/user/ |  | ||||||
| # %h/.config/telebit/telebit.yml |  | ||||||
| echo "### Adding $my_app is a system service" |  | ||||||
| echo "sudo rsync -a $TELEBIT_PATH/dist/etc/systemd/system/$my_app.service /etc/systemd/system/$my_app.service" |  | ||||||
| sudo rsync -a $TELEBIT_PATH/dist/etc/systemd/system/$my_app.service /etc/systemd/system/$my_app.service |  | ||||||
| sudo systemctl daemon-reload |  | ||||||
| echo "sudo systemctl enable $my_app" |  | ||||||
| sudo systemctl enable $my_app |  | ||||||
| echo "sudo systemctl start $my_app" |  | ||||||
| sudo systemctl restart $my_app |  | ||||||
| 
 |  | ||||||
| sleep 1 |  | ||||||
| echo "" |  | ||||||
| echo "" |  | ||||||
| echo "" |  | ||||||
| echo "==============================================" |  | ||||||
| echo "  Privacy Settings in Config" |  | ||||||
| echo "==============================================" |  | ||||||
| echo "" |  | ||||||
| echo "The example config file /etc/$my_user/$my_app.yml opts-in to" |  | ||||||
| echo "contributing telemetrics and receiving infrequent relevant updates" |  | ||||||
| echo "(probably once per quarter or less) such as important notes on" |  | ||||||
| echo "a new release, an important API change, etc. No spam." |  | ||||||
| echo "" |  | ||||||
| echo "Please edit the config file to meet your needs before starting." |  | ||||||
| echo "" |  | ||||||
| sleep 2 |  | ||||||
| 
 |  | ||||||
| echo "" |  | ||||||
| echo "" |  | ||||||
| echo "==============================================" |  | ||||||
| echo "Installed successfully. Last steps:" |  | ||||||
| echo "==============================================" |  | ||||||
| echo "" |  | ||||||
| echo "Edit the config and restart, if desired:" |  | ||||||
| echo "" |  | ||||||
| echo "    sudo vim /etc/$my_user/$my_app.yml" |  | ||||||
| echo "    sudo systemctl restart $my_app" |  | ||||||
| echo "" |  | ||||||
| echo "Or disabled the service and start manually:" |  | ||||||
| echo "" |  | ||||||
| echo "    sudo systemctl stop $my_app" |  | ||||||
| echo "    sudo systemctl disable $my_app" |  | ||||||
| echo "    $my_app --config /etc/$my_user/$my_app.yml" |  | ||||||
| echo "" |  | ||||||
| sleep 1 |  | ||||||
|  | |||||||
							
								
								
									
										225
									
								
								installer/install.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										225
									
								
								installer/install.sh
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,225 @@ | |||||||
|  | #!/bin/bash | ||||||
|  | #<pre><code> | ||||||
|  | 
 | ||||||
|  | # This is a 3 step process | ||||||
|  | #   1. First we need to figure out whether to use wget or curl for fetching remote files | ||||||
|  | #   2. Next we need to figure out whether to use unzip or tar for downloading releases | ||||||
|  | #   3. We need to actually install the stuff | ||||||
|  | 
 | ||||||
|  | set -e | ||||||
|  | set -u | ||||||
|  | 
 | ||||||
|  | ### http_bash exported by get.sh | ||||||
|  | 
 | ||||||
|  | my_email=${1:-} | ||||||
|  | my_relay=${2:-} | ||||||
|  | my_servernames=${3:-} | ||||||
|  | my_secret=${4:-} | ||||||
|  | my_user="telebit" | ||||||
|  | my_app="telebit" | ||||||
|  | my_bin="telebit.js" | ||||||
|  | my_name="Telebit Remote" | ||||||
|  | my_repo="telebit.js" | ||||||
|  | 
 | ||||||
|  | if [ -z "${my_email}" ]; then | ||||||
|  |   echo "" | ||||||
|  |   echo "" | ||||||
|  |   echo "Telebit uses Greenlock for free automated ssl through Let's Encrypt." | ||||||
|  |   echo "" | ||||||
|  |   echo "To accept the Terms of Service for Telebit, Greenlock and Let's Encrypt," | ||||||
|  |   echo "please enter your email." | ||||||
|  |   echo "" | ||||||
|  |   read -p "email: " my_email | ||||||
|  |   echo "" | ||||||
|  |   # UX - just want a smooth transition | ||||||
|  |   sleep 0.5 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if [ -z "${my_relay}" ]; then | ||||||
|  |   echo "What relay will you be using? (press enter for default)" | ||||||
|  |   echo "" | ||||||
|  |   read -p "relay [default: wss://telebit.cloud]: " my_relay | ||||||
|  |   echo "" | ||||||
|  |   # UX - just want a smooth transition | ||||||
|  |   sleep 0.5 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if [ -z "${my_servernames}" ]; then | ||||||
|  |   echo "What servername(s) will you be relaying here? (press enter for default)" | ||||||
|  |   echo "" | ||||||
|  |   read -p "domain [default: <random>.telebit.cloud]: " my_servernames | ||||||
|  |   echo "" | ||||||
|  |   # UX - just want a smooth transition | ||||||
|  |   sleep 0.5 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | if [ -z "${my_secret}" ]; then | ||||||
|  |   echo "What's your authorization for the relay server? (press enter for default)" | ||||||
|  |   echo "" | ||||||
|  |   read -p "auth [default: new account]: " my_secret | ||||||
|  |   echo "" | ||||||
|  |   # UX - just want a smooth transition | ||||||
|  |   sleep 0.5 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | echo "" | ||||||
|  | 
 | ||||||
|  | if [ -z "${TELEBIT_PATH:-}" ]; then | ||||||
|  |   echo 'TELEBIT_PATH="'${TELEBIT_PATH:-}'"' | ||||||
|  |   TELEBIT_PATH=/opt/$my_app | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | echo "Installing $my_name to '$TELEBIT_PATH'" | ||||||
|  | 
 | ||||||
|  | echo "Installing node.js dependencies into '$TELEBIT_PATH'" | ||||||
|  | # v10.2+ has much needed networking fixes, but breaks ursa. v9.x has severe networking bugs. v8.x has working ursa, but requires tls workarounds" | ||||||
|  | NODEJS_VER="${NODEJS_VER:-v10}" | ||||||
|  | export NODEJS_VER | ||||||
|  | export NODE_PATH="$TELEBIT_PATH/lib/node_modules" | ||||||
|  | export NPM_CONFIG_PREFIX="$TELEBIT_PATH" | ||||||
|  | export PATH="$TELEBIT_PATH/bin:$PATH" | ||||||
|  | sleep 1 | ||||||
|  | http_bash https://git.coolaj86.com/coolaj86/node-installer.sh/raw/branch/master/install.sh --no-dev-deps >/dev/null 2>/dev/null | ||||||
|  | 
 | ||||||
|  | my_tree="master" | ||||||
|  | my_node="$TELEBIT_PATH/bin/node" | ||||||
|  | my_npm="$my_node $TELEBIT_PATH/bin/npm" | ||||||
|  | my_tmp="$TELEBIT_PATH/tmp" | ||||||
|  | mkdir -p $my_tmp | ||||||
|  | 
 | ||||||
|  | echo "sudo mkdir -p '$TELEBIT_PATH'" | ||||||
|  | sudo mkdir -p "$TELEBIT_PATH" | ||||||
|  | echo "sudo mkdir -p '/etc/$my_user/'" | ||||||
|  | sudo mkdir -p "/etc/$my_user/" | ||||||
|  | 
 | ||||||
|  | set +e | ||||||
|  | #https://git.coolaj86.com/coolaj86/telebit.js.git | ||||||
|  | #https://git.coolaj86.com/coolaj86/telebit.js/archive/:tree:.tar.gz | ||||||
|  | #https://git.coolaj86.com/coolaj86/telebit.js/archive/:tree:.zip | ||||||
|  | my_unzip=$(type -p unzip) | ||||||
|  | my_tar=$(type -p tar) | ||||||
|  | if [ -n "$my_unzip" ]; then | ||||||
|  |   rm -f $my_tmp/$my_app-$my_tree.zip | ||||||
|  |   http_get https://git.coolaj86.com/coolaj86/$my_repo/archive/$my_tree.zip $my_tmp/$my_app-$my_tree.zip | ||||||
|  |   # -o means overwrite, and there is no option to strip | ||||||
|  |   $my_unzip -o $my_tmp/$my_app-$my_tree.zip -d $TELEBIT_PATH/ > /dev/null 2>&1 | ||||||
|  |   cp -ar  $TELEBIT_PATH/$my_repo/* $TELEBIT_PATH/ > /dev/null | ||||||
|  |   rm -rf $TELEBIT_PATH/$my_bin | ||||||
|  | elif [ -n "$my_tar" ]; then | ||||||
|  |   rm -f $my_tmp/$my_app-$my_tree.tar.gz | ||||||
|  |   http_get https://git.coolaj86.com/coolaj86/$my_repo/archive/$my_tree.tar.gz $my_tmp/$my_app-$my_tree.tar.gz | ||||||
|  |   ls -lah $my_tmp/$my_app-$my_tree.tar.gz | ||||||
|  |   $my_tar -xzf $my_tmp/$my_app-$my_tree.tar.gz --strip 1 -C $TELEBIT_PATH/ | ||||||
|  | else | ||||||
|  |   echo "Neither tar nor unzip found. Abort." | ||||||
|  |   exit 13 | ||||||
|  | fi | ||||||
|  | set -e | ||||||
|  | 
 | ||||||
|  | pushd $TELEBIT_PATH >/dev/null | ||||||
|  |   $my_npm install >/dev/null 2>/dev/null | ||||||
|  | popd >/dev/null | ||||||
|  | 
 | ||||||
|  | cat << EOF > $TELEBIT_PATH/bin/$my_app | ||||||
|  | #!/bin/bash | ||||||
|  | $my_node $TELEBIT_PATH/bin/$my_bin | ||||||
|  | EOF | ||||||
|  | chmod a+x $TELEBIT_PATH/bin/$my_app | ||||||
|  | echo "sudo ln -sf $TELEBIT_PATH/bin/$my_app /usr/local/bin/$my_app" | ||||||
|  | sudo ln -sf $TELEBIT_PATH/bin/$my_app /usr/local/bin/$my_app | ||||||
|  | 
 | ||||||
|  | set +e | ||||||
|  | if type -p setcap >/dev/null 2>&1; then | ||||||
|  |   #echo "Setting permissions to allow $my_app to run on port 80 and port 443 without sudo or root" | ||||||
|  |   echo "sudo setcap cap_net_bind_service=+ep $TELEBIT_PATH/bin/node" | ||||||
|  |   sudo setcap cap_net_bind_service=+ep $TELEBIT_PATH/bin/node | ||||||
|  | fi | ||||||
|  | set -e | ||||||
|  | 
 | ||||||
|  | if [ -z "$(cat /etc/passwd | grep $my_user)" ]; then | ||||||
|  |   echo "sudo adduser --home $TELEBIT_PATH --gecos '' --disabled-password $my_user" | ||||||
|  |   sudo adduser --home $TELEBIT_PATH --gecos '' --disabled-password $my_user >/dev/null 2>&1 | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | my_config="$TELEBIT_PATH/etc/$my_app.yml" | ||||||
|  | mkdir -p "$(dirname $my_config)" | ||||||
|  | if [ ! -e "$my_config" ]; then | ||||||
|  |   #rsync -a examples/$my_app.yml "$my_config" | ||||||
|  |   echo "email: $my_email" >> "$my_config" | ||||||
|  |   if [ -n "$my_secret" ]; then | ||||||
|  |     echo "secret: $my_secret" >> "$my_config" | ||||||
|  |   fi | ||||||
|  |   if [ -n "$my_servernames" ]; then | ||||||
|  |     echo "servernames:\n  $my_servernames: {}" >> "$my_config" | ||||||
|  |   fi | ||||||
|  |   #echo "dynamic_ports:\n  []" >> "$my_config" | ||||||
|  |   cat examples/$my_app.yml.tpl >> "$my_config" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | my_config="$HOME/.config/$my_user/$my_app.yml" | ||||||
|  | mkdir -p "$(dirname $my_config)" | ||||||
|  | if [ ! -e "$my_config" ]; then | ||||||
|  |   echo "cli: true" >> "$my_config" | ||||||
|  |   echo "email: $my_email" >> "$my_config" | ||||||
|  |   if [ -n "$my_secret" ]; then | ||||||
|  |     echo "secret: $my_secret" >> "$my_config" | ||||||
|  |   fi | ||||||
|  |   cat examples/$my_app.yml.tpl >> "$my_config" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | my_config_link="/etc/$my_user/$my_app.yml" | ||||||
|  | if [ ! -e "$my_config_link" ]; then | ||||||
|  |   echo "sudo ln -sf '$my_config' '$my_config_link'" | ||||||
|  |   #sudo mkdir -p /etc/$my_user | ||||||
|  |   sudo ln -sf "$my_config" "$my_config_link" | ||||||
|  | fi | ||||||
|  | 
 | ||||||
|  | echo "sudo chown -R $my_user '$TELEBIT_PATH' '/etc/$my_user'" | ||||||
|  | sudo chown -R $my_user "$TELEBIT_PATH" "/etc/$my_user" | ||||||
|  | 
 | ||||||
|  | # ~/.config/systemd/user/ | ||||||
|  | # %h/.config/telebit/telebit.yml | ||||||
|  | echo "### Adding $my_app is a system service" | ||||||
|  | echo "sudo rsync -a $TELEBIT_PATH/dist/etc/systemd/system/$my_app.service /etc/systemd/system/$my_app.service" | ||||||
|  | sudo rsync -a "$TELEBIT_PATH/dist/etc/systemd/system/$my_app.service" "/etc/systemd/system/$my_app.service" | ||||||
|  | sudo systemctl daemon-reload | ||||||
|  | echo "sudo systemctl enable $my_app" | ||||||
|  | sudo systemctl enable $my_app | ||||||
|  | echo "sudo systemctl start $my_app" | ||||||
|  | sudo systemctl restart $my_app | ||||||
|  | 
 | ||||||
|  | sleep 1 | ||||||
|  | echo "" | ||||||
|  | echo "" | ||||||
|  | echo "" | ||||||
|  | echo "==============================================" | ||||||
|  | echo "  Privacy Settings in Config" | ||||||
|  | echo "==============================================" | ||||||
|  | echo "" | ||||||
|  | echo "The example config file /etc/$my_user/$my_app.yml opts-in to" | ||||||
|  | echo "contributing telemetrics and receiving infrequent relevant updates" | ||||||
|  | echo "(probably once per quarter or less) such as important notes on" | ||||||
|  | echo "a new release, an important API change, etc. No spam." | ||||||
|  | echo "" | ||||||
|  | echo "Please edit the config file to meet your needs before starting." | ||||||
|  | echo "" | ||||||
|  | sleep 2 | ||||||
|  | 
 | ||||||
|  | echo "" | ||||||
|  | echo "" | ||||||
|  | echo "==============================================" | ||||||
|  | echo "Installed successfully. Last steps:" | ||||||
|  | echo "==============================================" | ||||||
|  | echo "" | ||||||
|  | echo "Edit the config and restart, if desired:" | ||||||
|  | echo "" | ||||||
|  | echo "    sudo vim /etc/$my_user/$my_app.yml" | ||||||
|  | echo "    sudo systemctl restart $my_app" | ||||||
|  | echo "" | ||||||
|  | echo "Or disabled the service and start manually:" | ||||||
|  | echo "" | ||||||
|  | echo "    sudo systemctl stop $my_app" | ||||||
|  | echo "    sudo systemctl disable $my_app" | ||||||
|  | echo "    $my_app --config /etc/$my_user/$my_app.yml" | ||||||
|  | echo "" | ||||||
|  | sleep 1 | ||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user