diff --git a/usr/share/install_helper.sh b/usr/share/install_helper.sh index 8a8c2c6..3944be8 100644 --- a/usr/share/install_helper.sh +++ b/usr/share/install_helper.sh @@ -1,574 +1,41 @@ #!/bin/bash #

 
-# What does this do.. and why?
-# (and why is it so complicated?)
-#
-# What this does
-#
-#   1. Sets some vars and asks some questions
-#   2. Installs everything into a single place
-#      (inculding deps like node.js, with the correct version)
-#   3. Depending on OS, creates a user for the service
-#   4. Depending on OS, register with system launcher
-#
-# Why
-#
-#   So that you can get a fully configured, running product,
-#   with zero manual configuration in a matter of seconds -
-#   and have an uninstall that's just as easy.
-#
-# Why so complicated?
-#
-#  To support nuance differences between various versions of
-#  Linux, macOS, and Android, including whether it's being
-#  installed with user privileges, as root, wit a system user
-#  system daemon launcher, etc. Also, this is designed to be
-#  reusable with many apps and services, so it's very variabled...
+# This downloads the telebit zip (Windows) or tarball (Mac, Linux),
+# unpacks it, and then completes the installation
 
 set -e
 set -u
 
-### http_bash exported by get.sh
+### http_get, http_bash, archiver, and archive_ext are exported by get.sh
 
-TELEBIT_DEBUG=${TELEBIT_DEBUG:-}
-
-# NOTE: On OS X logname works from a pipe, but on Linux it does not
-my_logname=$(who am i /dev/null && \
-  chown -R $(id -u -n):$(id -g -n) $my_tmp "$TELEBIT_REAL_PATH" 2>/dev/null
-if [ $? -eq 0 ]; then
-  soft_sudo_cmd=" "
-  soft_sudo_cmde=""
-else
-  $soft_sudo_cmd mkdir -p $my_tmp "$TELEBIT_REAL_PATH" "$TELEBIT_REAL_PATH/etc" "$TELEBIT_REAL_PATH/var/log"
-  $soft_sudo_cmd chown -R $(id -u -n):$(id -g -n) $my_tmp "$TELEBIT_REAL_PATH"
-fi
-set -e
-
-
-if [ -n "${TELEBIT_DEBUG}" ]; then
-  echo "  - installing node.js runtime to '$TELEBIT_REAL_PATH'..."
-  http_bash https://git.coolaj86.com/coolaj86/node-installer.sh/raw/branch/master/install.sh --no-dev-deps
-else
-  echo -n "."
-  #bash -c 'while true; do echo -n "."; sleep 2; done' 2>/dev/null &
-  #_my_pid=$!
-  http_bash https://git.coolaj86.com/coolaj86/node-installer.sh/raw/branch/master/install.sh --no-dev-deps >/dev/null 2>/dev/null
-  #kill $_my_pid >/dev/null 2>/dev/null
-fi
-
-#
-# TODO create "upgrade" script and run that instead
-#
-
-my_node="$TELEBIT_REAL_PATH/bin/node"
-tmp_node="$TELEBIT_TMP/bin/node"
-my_npm="$my_node $TELEBIT_TMP/bin/npm"
-tmp_npm="$tmp_node $TELEBIT_TMP/bin/npm"
-
-#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
-set +e
-my_unzip=$(type -p unzip)
-my_tar=$(type -p tar)
-# TODO extract to temporary directory, configure, copy etc, replace
-if [ -n "$my_unzip" ]; then
-  rm -f $my_tmp/$my_app-$TELEBIT_VERSION.zip
-  if [ -n "${TELEBIT_DEBUG}" ]; then
-    echo "  - installing telebit zip to '$TELEBIT_REAL_PATH'"
-  fi
-  echo -n "."
-  #bash -c 'while true; do echo -n "."; sleep 2; done' 2>/dev/null &
-  #_my_pid=$!
-  http_get https://git.coolaj86.com/coolaj86/$my_repo/archive/$TELEBIT_VERSION.zip $my_tmp/$my_app-$TELEBIT_VERSION.zip
-  #kill $_my_pid >/dev/null 2>/dev/null
-  # -o means overwrite, and there is no option to strip
-  $my_unzip -o $my_tmp/$my_app-$TELEBIT_VERSION.zip -d $my_tmp/ >/dev/null
-  $rsync_cmd  $my_tmp/$my_repo/* $TELEBIT_TMP/ > /dev/null
-  rm -rf $my_tmp/$my_repo
-elif [ -n "$my_tar" ]; then
-  rm -f $my_tmp/$my_app-$TELEBIT_VERSION.tar.gz
-  if [ -n "${TELEBIT_DEBUG}" ]; then
-    echo "  - installing telebit tar.gz to '$TELEBIT_REAL_PATH'"
-  fi
-  echo -n "."
-  #bash -c 'while true; do echo -n "."; sleep 2; done' 2>/dev/null &
-  #_my_pid=$!
-  http_get https://git.coolaj86.com/coolaj86/$my_repo/archive/$TELEBIT_VERSION.tar.gz $my_tmp/$my_app-$TELEBIT_VERSION.tar.gz
-  #kill $_my_pid >/dev/null 2>/dev/null
-  $my_tar -xzf $my_tmp/$my_app-$TELEBIT_VERSION.tar.gz --strip 1 -C $TELEBIT_TMP/ >/dev/null
-else
-  echo "Neither tar nor unzip found. Abort."
-  exit 13
-fi
-set -e
-
-#
-# TODO create slim packages that contain all the deps on each os and cpu
-#
-pushd $TELEBIT_TMP >/dev/null
-  if [ -n "${TELEBIT_DEBUG}" ]; then
-    echo "  - installing telebit npm dependencies to '$TELEBIT_REAL_PATH'..."
+mkdir -p $HOME/Downloads
+my_tmp="$(mktemp -d -t telebit.XXXX)"
+http_get "https://rootprojects.org/telebit/dist/index.tab" "$my_tmp/index.tab"
+latest=$(grep $TELEBIT_RELEASE $my_tmp/index.tab | grep $TELEBIT_OS | grep $TELEBIT_ARCH | head -n 1 | cut -f 1)
+major=$(grep $TELEBIT_RELEASE $my_tmp/index.tab | grep $TELEBIT_OS | grep $TELEBIT_ARCH | head -n 1 | cut -f 2)
+size=$(grep $TELEBIT_RELEASE $my_tmp/index.tab | grep $TELEBIT_OS | grep $TELEBIT_ARCH | head -n 1 | cut -f 3)
+#latest=$(grep $TELEBIT_RELEASE $my_tmp/index.tab | grep $TELEBIT_OS | grep $TELEBIT_ARCH | head -n 1 | cut -f 1)
+my_dir="telebit-$latest-$TELEBIT_OS-$TELEBIT_ARCH"
+my_file="$my_dir.$archive_ext"
+if [ -f "$HOME/Downloads/$my_file" ]; then
+  my_size=$(($(wc -c < "$HOME/Downloads/$my_file")))
+  if [ "$my_size" -eq "$size" ]; then
+    echo "File exists in ~/Downloads, skipping download"
   else
-    echo -n "."
+    echo "Removing corrupt download '~/Downloads/$my_file'"
+    rm -f "$HOME/Downloads/$my_file"
   fi
-  set +e
-  $tmp_npm install >/dev/null 2>/dev/null &
-  tmp_npm_pid=$!
-  while [ -n "$tmp_npm_pid" ]; do
-    sleep 2
-    echo -n "."
-    kill -s 0 $tmp_npm_pid >/dev/null 2>/dev/null || tmp_npm_pid=""
-  done
-  set -e
-  echo -n "."
-  $tmp_npm install >/dev/null 2>/dev/null
-  # ursa is now an entirely optional dependency for key generation
-  # but very much needed on ARM devices
-  $tmp_npm install ursa >/dev/null 2>/dev/null || true
-popd >/dev/null
-
-if [ -n "${TELEBIT_DEBUG}" ]; then
-  echo "  - configuring telebit..."
+fi
+if [ ! -f "$HOME/Downloads/$my_file" ]; then
+  echo "Downloading from https://rootprojects.org/telebit/dist/$major/$my_file ..."
+  sleep 0.3
+  http_get "https://rootprojects.org/telebit/dist/$major/$my_file" "$HOME/Downloads/$my_file"
+  echo "Saved to '$HOME/Downloads/$my_file' ..."
   echo ""
+  sleep 0.3
 fi
-
-###############################################
-#
-# TODO convert to node script
-#
-# Now that node is installed and the telebit
-# packeage is downloaded, everything can be
-# run from node, except things requiring sudo
-#
-###############################################
-
-# telebit remote
-echo '#!/bin/bash' > "$TELEBIT_TMP/bin/$my_app"
-echo "$my_node $TELEBIT_REAL_PATH/bin/$my_bin "'"$@"' >> "$TELEBIT_TMP/bin/$my_app"
-chmod a+x "$TELEBIT_TMP/bin/$my_app"
-
-# telebit daemon
-echo '#!/bin/bash' > "$TELEBIT_TMP/bin/$my_daemon"
-echo "$my_node $TELEBIT_REAL_PATH/bin/$my_daemon.js daemon "'"$@"' >> "$TELEBIT_TMP/bin/$my_daemon"
-chmod a+x "$TELEBIT_TMP/bin/$my_daemon"
-
-# Create uninstall script based on the install script variables
-cat << EOF > $TELEBIT_TMP/bin/${my_app}_uninstall
-#!/bin/bash
-set -x
-if [ "$(type -p launchctl)" ]; then
-  sudo launchctl unload -w /Library/LaunchDaemons/${my_app_pkg_name}.plist
-  sudo rm -f /Library/LaunchDaemons/${my_app_pkg_name}.plist
-
-  launchctl unload -w $HOME/Library/LaunchAgents/${my_app_pkg_name}.plist
-  rm -f $HOME/Library/LaunchAgents/${my_app_pkg_name}.plist
-fi
-if [ "$(type -p systemctl)" ]; then
-  systemctl --user disable $my_app >/dev/null
-  systemctl --user stop $my_app
-  rm -f $HOME/.config/systemd/user/$my_app.service
-
-  sudo systemctl disable $my_app >/dev/null
-  sudo systemctl stop $my_app
-  sudo rm -f /etc/systemd/system/$my_app.service
-fi
-sudo rm -rf $TELEBIT_REAL_PATH /usr/local/bin/$my_app
-sudo rm -rf $TELEBIT_REAL_PATH /usr/local/bin/$my_daemon
-rm -rf $HOME/.config/$my_app $HOME/.local/share/$my_app
-EOF
-chmod a+x $TELEBIT_TMP/bin/${my_app}_uninstall
-
-#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 "    > ${real_sudo_cmde}setcap cap_net_bind_service=+ep $TELEBIT_REAL_PATH/bin/node"
-#  $real_sudo_cmd setcap cap_net_bind_service=+ep $TELEBIT_REAL_PATH/bin/node
-#fi
-#set -e
-
-my_skip=""
-set +e
-# TODO for macOS https://apple.stackexchange.com/questions/286749/how-to-add-a-user-from-the-command-line-in-macos
-# TODO do stuff for groups too
-# TODO add ending $
-if type -p dscl >/dev/null 2>/dev/null; then
-  if [ -n "$(dscl . list /users | grep ^$TELEBIT_USER)" ] && [ -n "$(dscl . list /groups | grep ^$TELEBIT_GROUP)" ]; then
-    my_skip="yes"
-  fi
-elif [ -n "$(cat $my_root/etc/passwd | grep $TELEBIT_USER)" ] && [ -n "$(cat $my_root/etc/group | grep $TELEBIT_GROUP)" ]; then
-  my_skip="yes"
-fi
-
-if [ -z "$my_skip" ]; then
-  if type -p adduser >/dev/null 2>/dev/null; then
-    $real_sudo_cmd adduser --home $TELEBIT_REAL_PATH --gecos '' --disabled-password $TELEBIT_USER >/dev/null 2>&1
-    #TELEBIT_USER=$my_app_name
-    TELEBIT_GROUP=$TELEBIT_USER
-  elif [ -n "$(cat /etc/passwd | grep www-data:)" ]; then
-    # Linux (Ubuntu)
-    TELEBIT_USER=www-data
-    TELEBIT_GROUP=www-data
-  elif [ -n "$(cat /etc/passwd | grep _www:)" ]; then
-    # Mac
-    TELEBIT_USER=_www
-    TELEBIT_GROUP=_www
-  else
-    # Unsure
-    TELEBIT_USER=$(id -u -n) # $(whoami)
-    TELEBIT_GROUP=$(id -g -n)
-  fi
-fi
-set -e
-
-export TELEBIT_USER
-export TELEBIT_GROUP
-export TELEBIT_PATH
-export TELEBIT_CONFIG=$HOME/.config/$my_app/$my_app.yml
-# TODO check both expected sock paths in client by default
-if [ "yes" == "$TELEBIT_USERSPACE" ]; then
-  TELEBIT_TMP_CONFIGD=$HOME/.config/$my_app/$my_daemon.yml
-  TELEBITD_CONFIG=$HOME/.config/$my_app/$my_daemon.yml
-  TELEBIT_LOG_DIR=${TELEBIT_LOG_DIR:-$HOME/.local/share/$my_app/var/log/}
-  TELEBIT_SOCK_DIR=${TELEBIT_SOCK_DIR:-$HOME/.local/share/$my_app/var/run/}
-  TELEBIT_SOCK=${TELEBIT_SOCK:-$HOME/.local/share/$my_app/var/run/$my_app.sock}
-else
-  TELEBIT_TMP_CONFIGD=$TELEBIT_TMP/etc/$my_daemon.yml
-  TELEBITD_CONFIG=$TELEBIT_REAL_PATH/etc/$my_daemon.yml
-  TELEBIT_LOG_DIR=${TELEBIT_LOG_DIR:-$TELEBIT_REAL_PATH/var/log/}
-  TELEBIT_SOCK_DIR=${TELEBIT_SOCK_DIR:-$TELEBIT_REAL_PATH/var/run/}
-  TELEBIT_SOCK=${TELEBIT_SOCK:-$TELEBIT_REAL_PATH/var/run/$my_app.sock}
-fi
-export TELEBITD_CONFIG
-export TELEBIT_SOCK
-export TELEBIT_NODE=$TELEBIT_REAL_PATH/bin/node
-export TELEBIT_NPM=$TELEBIT_REAL_PATH/bin/npm
-export TELEBIT_BIN=$TELEBIT_REAL_PATH/bin/telebit
-export TELEBITD_BIN=$TELEBIT_REAL_PATH/bin/telebitd
-export TELEBIT_JS=$TELEBIT_REAL_PATH/bin/telebit.js
-export TELEBITD_JS=$TELEBIT_REAL_PATH/bin/telebitd.js
-export TELEBIT_LOG_DIR
-export TELEBIT_SOCK_DIR
-export NODE_PATH="$TELEBIT_REAL_PATH/lib/node_modules"
-export NPM_CONFIG_PREFIX="$TELEBIT_REAL_PATH"
-
-$my_node $TELEBIT_TMP/usr/share/template-launcher.js
-
-# TODO don't create this in TMP_PATH if it exists in TELEBIT_REAL_PATH
-mkdir -p "$(dirname $TELEBIT_TMP_CONFIGD)"
-if [ ! -e "$TELEBITD_CONFIG" ]; then
-
-  echo "sock: $TELEBIT_SOCK" >> "$TELEBIT_TMP_CONFIGD"
-  echo "root: $TELEBIT_REAL_PATH" >> "$TELEBIT_TMP_CONFIGD"
-  cat $TELEBIT_REAL_PATH/usr/share/$my_daemon.tpl.yml >> "$TELEBIT_TMP_CONFIGD"
-
-fi
-
-mkdir -p "$(dirname $TELEBIT_CONFIG)"
-if [ ! -e "$TELEBIT_CONFIG" ]; then
-
-  echo "sock: $TELEBIT_SOCK" >> "$TELEBIT_CONFIG"
-
-fi
-
-
-
-# TODO
-# Backup final directory, if it exists
-# Move everything over to final directory
-# Restore config files, if they exist
-# rewrite system service file with real variables
-
-# This should only affect non-USERSPACE installs
-#echo "${soft_sudo_cmde}chown -R $TELEBIT_USER '$TELEBIT_REAL_PATH'
-$soft_sudo_cmd mkdir -p $TELEBIT_LOG_DIR
-$soft_sudo_cmd mkdir -p $TELEBIT_SOCK_DIR
-$soft_sudo_cmd chown -R $TELEBIT_USER "$TELEBIT_REAL_PATH"
-
-# $HOME/.config/systemd/user/
-# %h/.config/telebit/telebit.yml
-if [ -n "${TELEBIT_DEBUG}" ]; then
-  echo "  - adding $my_app as a system service"
-fi
-# TODO detect with type -p
-my_system_launcher=""
-my_app_launchd_service=""
-if [ -d "/Library/LaunchDaemons" ]; then
-  my_system_launcher="launchd"
-  my_sudo_cmde="$real_sudo_cmde"
-  my_sudo_cmd="$real_sudo_cmd"
-
-
-  if [ "yes" == "$TELEBIT_USERSPACE" ]; then
-    my_app_launchd_service_skel="etc/skel/Library/LaunchAgents/${my_app_pkg_name}.plist"
-    my_app_launchd_service="$HOME/Library/LaunchAgents/${my_app_pkg_name}.plist"
-    if [ -n "${TELEBIT_DEBUG}" ]; then
-      echo "    > $rsync_cmd $TELEBIT_REAL_PATH/usr/share/dist/$my_app_launchd_service $my_app_launchd_service"
-    fi
-    mkdir -p $HOME/Library/LaunchAgents
-    $rsync_cmd "$TELEBIT_REAL_PATH/usr/share/dist/$my_app_launchd_service_skel" "$my_app_launchd_service"
-
-    if [ -n "${TELEBIT_DEBUG}" ]; then
-      echo "    > chown $(id -u -n):$(id -g -n) $my_app_launchd_service"
-    fi
-    chown $(id -u -n):$(id -g -n) "$my_app_launchd_service"
-    my_sudo_cmd=""
-    my_sudo_cmde=""
-
-    if [ -n "${TELEBIT_DEBUG}" ]; then
-      echo "    > launchctl unload -w $my_app_launchd_service >/dev/null 2>/dev/null"
-    fi
-    launchctl unload -w "$my_app_launchd_service" >/dev/null 2>/dev/null
-  else
-    my_app_launchd_service_skel="usr/share/dist/Library/LaunchDaemons/${my_app_pkg_name}.plist"
-    my_app_launchd_service="$my_root/Library/LaunchDaemons/${my_app_pkg_name}.plist"
-    echo "    > ${real_sudo_cmde}$rsync_cmd $TELEBIT_REAL_PATH/usr/share/dist/$my_app_launchd_service $my_app_launchd_service"
-    $real_sudo_cmd $rsync_cmd "$TELEBIT_REAL_PATH/usr/share/dist/$my_app_launchd_service_skel" "$my_app_launchd_service"
-
-    echo "    > ${real_sudo_cmde}chown root:wheel $my_app_launchd_service"
-    $real_sudo_cmd chown root:wheel "$my_app_launchd_service"
-
-    echo "    > ${real_sudo_cmde}launchctl unload -w $my_app_launchd_service >/dev/null 2>/dev/null"
-    $real_sudo_cmd launchctl unload -w "$my_app_launchd_service" >/dev/null 2>/dev/null
-  fi
-
-elif [ -d "$my_root/etc/systemd/system" ]; then
-  my_system_launcher="systemd"
-
-  if [ "yes" == "$TELEBIT_USERSPACE" ]; then
-    if [ -n "${TELEBIT_DEBUG}" ]; then
-      echo "    > $rsync_cmd $TELEBIT_REAL_PATH/usr/share/dist/etc/skel/.config/systemd/user/$my_app.service $HOME/.config/systemd/user/$my_app.service"
-    fi
-    mkdir -p $HOME/.config/systemd/user
-    $rsync_cmd "$TELEBIT_REAL_PATH/usr/share/dist/etc/skel/.config/systemd/user/$my_app.service" "$HOME/.config/systemd/user/$my_app.service"
-  else
-    echo "    > ${real_sudo_cmde}$rsync_cmd $TELEBIT_REAL_PATH/usr/share/dist/etc/systemd/system/$my_app.service /etc/systemd/system/$my_app.service"
-    $real_sudo_cmd $rsync_cmd "$TELEBIT_REAL_PATH/usr/share/dist/etc/systemd/system/$my_app.service" "/etc/systemd/system/$my_app.service"
-  fi
-fi
-
-sleep 1
-
-###############################
-# Actually Launch the Service #
-###############################
-if [ -n "${TELEBIT_DEBUG}" ]; then
-  echo ""
-fi
-if [ "launchd" == "$my_system_launcher" ]; then
-
-  if [ "yes" == "$TELEBIT_USERSPACE" ]; then
-    if [ -n "${TELEBIT_DEBUG}" ]; then
-      echo "  > launchctl load -w $my_app_launchd_service"
-    else
-      echo -n "."
-    fi
-    launchctl load -w "$my_app_launchd_service"
-  else
-    echo "  > ${real_sudo_cmde}launchctl load -w $my_app_launchd_service"
-    $real_sudo_cmd launchctl load -w "$my_app_launchd_service"
-  fi
-  sleep 2; # give it time to start
-
-elif [ "systemd" == "$my_system_launcher" ]; then
-
-  if [ "yes" == "$TELEBIT_USERSPACE" ]; then
-    # https://wiki.archlinux.org/index.php/Systemd/User
-    # sudo loginctl enable-linger username
-
-    if [ -n "${TELEBIT_DEBUG}" ]; then
-      echo "    > systemctl --user enable $my_app"
-    else
-      echo -n "."
-    fi
-    set +e
-    if systemctl --user daemon-reload; then
-      # enable also puts success output to stderr... why?
-      systemctl --user enable $my_app >/dev/null 2>/dev/null
-      #echo "    > systemctl --user enable systemd-tmpfiles-setup.service systemd-tmpfiles-clean.timer"
-      #systemctl --user enable systemd-tmpfiles-setup.service systemd-tmpfiles-clean.timer
-      if [ -n "${TELEBIT_DEBUG}" ]; then
-        echo "    > systemctl --user start $my_app"
-      fi
-      systemctl --user stop $my_app >/dev/null 2>/dev/null
-      systemctl --user start $my_app >/dev/null
-
-      sleep 2; # give it time to start
-      _is_running=$(systemctl --user status --no-pager $my_app 2>/dev/null | grep "active.*running")
-      if [ -z "$_is_running" ]; then
-        echo "Something went wrong:"
-        systemctl --user status --no-pager $my_app
-      fi
-    else
-      echo "libpam-systemd is missing, which is required on Linux to register Telebit with the user launcher."
-      echo "sudo apt-get install -y libpam-systemd"
-      sudo apt-get install -y libpam-systemd
-    fi
-    set -e
-    echo -n "."
-  else
-
-    $real_sudo_cmd systemctl daemon-reload
-    echo "    > ${real_sudo_cmde}systemctl enable $my_app"
-    $real_sudo_cmd systemctl enable $my_app >/dev/null
-    echo "    > ${real_sudo_cmde}systemctl start $my_app"
-    $real_sudo_cmd systemctl daemon-reload
-    $real_sudo_cmd systemctl restart $my_app
-    sleep 2; # give it time to start
-    $real_sudo_cmd systemctl status --no-pager $my_app
-  fi
-
-else
-
-  echo "Run the service manually (we couldn't detect your system service to do that automatically):"
-  echo ""
-  echo "    $TELEBITD_BIN --config $TELEBITD_CONFIG"
-  echo "    ~/$my_app --config $TELEBIT_CONFIG"
-
-fi
-
-# NOTE: ln -sf *should* replace an existing link... but sometimes it doesn't, hence rm -f
-if [ "yes" == "$TELEBIT_USERSPACE" ]; then
-  if [ -n "${TELEBIT_DEBUG}" ]; then
-    echo "    > ${real_sudo_cmde}ln -sf $TELEBIT_REAL_PATH/bin/$my_app /usr/local/bin/$my_app"
-  fi
-  rm -f /usr/local/bin/$my_app 2>/dev/null || true
-  ln -sf $TELEBIT_REAL_PATH/bin/$my_app /usr/local/bin/$my_app 2>/dev/null || true
-else
-  echo "    > ${real_sudo_cmde}ln -sf $TELEBIT_REAL_PATH/bin/$my_app /usr/local/bin/$my_app"
-  rm -f /usr/local/bin/$my_app 2>/dev/null || \
-    $real_sudo_cmd rm -f /usr/local/bin/$my_app
-  ln -sf $TELEBIT_REAL_PATH/bin/$my_app /usr/local/bin/$my_app 2>/dev/null || \
-    $real_sudo_cmd ln -sf $TELEBIT_REAL_PATH/bin/$my_app /usr/local/bin/$my_app
-  # telebitd
-  echo "    > ${real_sudo_cmde}ln -sf $TELEBIT_REAL_PATH/bin/$my_daemon /usr/local/bin/$my_daemon"
-  rm -f $TELEBIT_REAL_PATH/bin/$my_daemon || $real_sudo_cmd rm -f $TELEBIT_REAL_PATH/bin/$my_daemon
-  ln -sf $TELEBIT_REAL_PATH/bin/$my_daemon /usr/local/bin/$my_daemon || \
-    $real_sudo_cmd ln -sf $TELEBIT_REAL_PATH/bin/$my_daemon /usr/local/bin/$my_daemon
-fi
-rm -f $HOME/$my_app; ln -s $TELEBIT_REAL_PATH/bin/$my_app $HOME/
-
-
-if [ -n "${TELEBIT_DEBUG}" ]; then
-  echo "  > telebit init --tty"
-  echo ""
-fi
-sleep 0.25
-
-echo ""
-$TELEBIT_REAL_PATH/bin/node $TELEBIT_REAL_PATH/bin/telebit.js init --tty
+echo "Unpacking and installing Telebit ..."
+unarchiver $my_file $my_tmp
+pushd $my_tmp/$my_dir
+bash ./setup.sh