refactor(moonraker.sh): full rewrite
Signed-off-by: Dominik Willner th33xitus@gmail.com
This commit is contained in:
@@ -1,16 +1,20 @@
|
|||||||
#Systemd service file for moonraker
|
#Systemd Moonraker Service
|
||||||
|
|
||||||
[Unit]
|
[Unit]
|
||||||
Description=Starts Moonraker %INST% on startup
|
Description=Starts Moonraker %INST% on startup
|
||||||
|
Documentation=https://moonraker.readthedocs.io/
|
||||||
After=network.target
|
After=network.target
|
||||||
|
|
||||||
[Install]
|
[Install]
|
||||||
WantedBy=multi-user.target
|
WantedBy=multi-user.target
|
||||||
|
|
||||||
[Service]
|
[Service]
|
||||||
|
Environment=MOONRAKER_CONF=%CFG%
|
||||||
|
Environment=MOONRAKER_LOG=%LOG%
|
||||||
Type=simple
|
Type=simple
|
||||||
SupplementaryGroups=moonraker-admin
|
SupplementaryGroups=moonraker-admin
|
||||||
User=%USER%
|
User=%USER%
|
||||||
RemainAfterExit=yes
|
RemainAfterExit=yes
|
||||||
ExecStart=%MR_ENV%/bin/python %MR_DIR%/moonraker/moonraker.py -l %MR_LOG% -c %MR_CONF%
|
ExecStart=%ENV%/bin/python %DIR%/moonraker/moonraker.py -c ${MOONRAKER_CONF} -l ${MOONRAKER_LOG}
|
||||||
Restart=always
|
Restart=always
|
||||||
RestartSec=10
|
RestartSec=10
|
||||||
@@ -1,321 +0,0 @@
|
|||||||
### base variables
|
|
||||||
SYSTEMDDIR="/etc/systemd/system"
|
|
||||||
MOONRAKER_ENV="${HOME}/moonraker-env"
|
|
||||||
MOONRAKER_DIR="${HOME}/moonraker"
|
|
||||||
MOONRAKER_REPO="https://github.com/Arksine/moonraker.git"
|
|
||||||
|
|
||||||
system_check_moonraker(){
|
|
||||||
### python 3 check
|
|
||||||
status_msg "Your Python 3 version is: $(python3 --version)"
|
|
||||||
major=$(python3 --version | cut -d" " -f2 | cut -d"." -f1)
|
|
||||||
minor=$(python3 --version | cut -d"." -f2)
|
|
||||||
if [ "$major" -ge 3 ] && [ "$minor" -ge 7 ]; then
|
|
||||||
py_chk_ok="true"
|
|
||||||
else
|
|
||||||
py_chk_ok="false"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
moonraker_setup_dialog(){
|
|
||||||
### check for existing moonraker service installations
|
|
||||||
SERVICE_FILES=$(find "$SYSTEMDDIR" -regextype posix-extended -regex "$SYSTEMDDIR/moonraker(-[^0])?[0-9]*.service")
|
|
||||||
if [ -n "$SERVICE_FILES" ]; then
|
|
||||||
ERROR_MSG="At least one Moonraker service is already installed:"
|
|
||||||
for service in $SERVICE_FILES; do
|
|
||||||
ERROR_MSG="${ERROR_MSG}\n ➔ $service"
|
|
||||||
done && return
|
|
||||||
fi
|
|
||||||
|
|
||||||
status_msg "Initializing Moonraker installation ..."
|
|
||||||
### checking system for python3.7+
|
|
||||||
system_check_moonraker
|
|
||||||
### exit moonraker setup if python versioncheck fails
|
|
||||||
if [ $py_chk_ok = "false" ]; then
|
|
||||||
ERROR_MSG="Versioncheck failed! Python 3.7 or newer required!\n"
|
|
||||||
ERROR_MSG="${ERROR_MSG} Please upgrade Python."
|
|
||||||
print_msg && clear_msg && return
|
|
||||||
fi
|
|
||||||
|
|
||||||
### count amount of klipper services
|
|
||||||
SERVICE_FILES=$(find "$SYSTEMDDIR" -regextype posix-extended -regex "$SYSTEMDDIR/klipper(-[^0])+[0-9]*.service")
|
|
||||||
if [ -f /etc/init.d/klipper ] || [ -f /etc/systemd/system/klipper.service ]; then
|
|
||||||
KLIPPER_COUNT=1
|
|
||||||
elif [ -n "$SERVICE_FILES" ]; then
|
|
||||||
KLIPPER_COUNT=$(echo "$SERVICE_FILES" | wc -l)
|
|
||||||
fi
|
|
||||||
|
|
||||||
### initial moonraker.conf path check
|
|
||||||
check_klipper_cfg_path
|
|
||||||
|
|
||||||
top_border
|
|
||||||
if [[ $KLIPPER_COUNT -eq 1 ]]; then
|
|
||||||
printf "|${green}%-55s${default}|\n" " 1 Klipper instance was found!"
|
|
||||||
elif [[ $KLIPPER_COUNT -gt 1 ]]; then
|
|
||||||
printf "|${green}%-55s${default}|\n" " $KLIPPER_COUNT Klipper instances were found!"
|
|
||||||
else
|
|
||||||
echo -e "| ${yellow}INFO: No existing Klipper installation found!${default} |"
|
|
||||||
fi
|
|
||||||
echo -e "| Usually you need one Moonraker instance per Klipper |"
|
|
||||||
echo -e "| instance. Though you can install as many as you wish. |"
|
|
||||||
bottom_border
|
|
||||||
echo
|
|
||||||
count=""
|
|
||||||
while [[ ! ($count =~ ^[1-9]+((0)+)?$) ]]; do
|
|
||||||
read -p "${cyan}###### Number of Moonraker instances to set up:${default} " count
|
|
||||||
if [[ ! ($count =~ ^[1-9]+((0)+)?$) ]]; then
|
|
||||||
warn_msg "Invalid Input!\n"
|
|
||||||
else
|
|
||||||
echo
|
|
||||||
read -p "${cyan}###### Install $count instance(s)? (Y/n):${default} " yn
|
|
||||||
case "$yn" in
|
|
||||||
Y|y|Yes|yes|"")
|
|
||||||
echo -e "###### > Yes"
|
|
||||||
status_msg "Installing Moonraker ...\n"
|
|
||||||
moonraker_setup "$count"
|
|
||||||
break;;
|
|
||||||
N|n|No|no)
|
|
||||||
echo -e "###### > No"
|
|
||||||
warn_msg "Exiting Moonraker setup ...\n"
|
|
||||||
break;;
|
|
||||||
*)
|
|
||||||
print_unkown_cmd
|
|
||||||
print_msg && clear_msg;;
|
|
||||||
esac
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
moonraker_setup(){
|
|
||||||
INSTANCE_COUNT=$1
|
|
||||||
### checking dependencies
|
|
||||||
dep=(wget curl unzip dfu-util virtualenv)
|
|
||||||
### additional deps for kiauh compatibility for armbian
|
|
||||||
dep+=(libjpeg-dev zlib1g-dev)
|
|
||||||
dependency_check
|
|
||||||
|
|
||||||
### step 1: clone moonraker
|
|
||||||
status_msg "Downloading Moonraker ..."
|
|
||||||
### force remove existing moonraker dir and clone into fresh moonraker dir
|
|
||||||
[ -d "$MOONRAKER_DIR" ] && rm -rf "$MOONRAKER_DIR"
|
|
||||||
cd "${HOME}" && git clone $MOONRAKER_REPO
|
|
||||||
ok_msg "Download complete!"
|
|
||||||
|
|
||||||
### step 2: install moonraker dependencies and create python virtualenv
|
|
||||||
status_msg "Installing dependencies ..."
|
|
||||||
install_moonraker_packages
|
|
||||||
create_moonraker_virtualenv
|
|
||||||
|
|
||||||
### step 3: create moonraker.conf folder and moonraker.confs
|
|
||||||
create_moonraker_conf
|
|
||||||
|
|
||||||
### step 4: create final moonraker instances
|
|
||||||
create_moonraker_service
|
|
||||||
|
|
||||||
### step 5: create polkit rules for moonraker
|
|
||||||
moonraker_polkit
|
|
||||||
|
|
||||||
### confirm message
|
|
||||||
if [[ $INSTANCE_COUNT -eq 1 ]]; then
|
|
||||||
CONFIRM_MSG="Moonraker has been set up!"
|
|
||||||
elif [[ $INSTANCE_COUNT -gt 1 ]]; then
|
|
||||||
CONFIRM_MSG="$INSTANCE_COUNT Moonraker instances have been set up!"
|
|
||||||
fi && print_msg && clear_msg
|
|
||||||
|
|
||||||
### display moonraker ips to the user
|
|
||||||
print_mr_ip_list; echo
|
|
||||||
}
|
|
||||||
|
|
||||||
install_moonraker_packages(){
|
|
||||||
### read PKGLIST from official install script
|
|
||||||
status_msg "Reading dependencies..."
|
|
||||||
install_script="${HOME}/moonraker/scripts/install-moonraker.sh"
|
|
||||||
PKGLIST=$(grep "PKGLIST=" "$install_script" | sed 's/PKGLIST//g; s/[$"{}=]//g; s/\s\s*/ /g' | tr -d '\n')
|
|
||||||
for pkg in $PKGLIST; do
|
|
||||||
echo "${cyan}$pkg${default}"
|
|
||||||
done
|
|
||||||
read -r -a PKGLIST <<< "$PKGLIST"
|
|
||||||
|
|
||||||
### Update system package info
|
|
||||||
status_msg "Running apt-get update..."
|
|
||||||
sudo apt-get update --allow-releaseinfo-change
|
|
||||||
|
|
||||||
### Install desired packages
|
|
||||||
status_msg "Installing packages..."
|
|
||||||
sudo apt-get install --yes "${PKGLIST[@]}"
|
|
||||||
}
|
|
||||||
|
|
||||||
create_moonraker_virtualenv(){
|
|
||||||
status_msg "Installing python virtual environment..."
|
|
||||||
|
|
||||||
### If venv exists and user prompts a rebuild, then do so
|
|
||||||
if [ -d "$MOONRAKER_ENV" ] && [ "$REBUILD_ENV" = "y" ]; then
|
|
||||||
status_msg "Removing old virtualenv"
|
|
||||||
rm -rf "$MOONRAKER_ENV"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ ! -d "$MOONRAKER_ENV" ]; then
|
|
||||||
virtualenv -p /usr/bin/python3 "$MOONRAKER_ENV"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### Install/update dependencies
|
|
||||||
"$MOONRAKER_ENV"/bin/pip install -r "$MOONRAKER_DIR"/scripts/moonraker-requirements.txt
|
|
||||||
}
|
|
||||||
|
|
||||||
create_moonraker_service(){
|
|
||||||
### get config directory
|
|
||||||
source_kiauh_ini
|
|
||||||
|
|
||||||
### set up default values
|
|
||||||
SINGLE_INST=1
|
|
||||||
CFG_PATH="$klipper_cfg_loc"
|
|
||||||
MR_ENV=$MOONRAKER_ENV
|
|
||||||
MR_DIR=$MOONRAKER_DIR
|
|
||||||
MR_LOG="${HOME}/klipper_logs/moonraker.log"
|
|
||||||
MR_CONF="$CFG_PATH/moonraker.conf"
|
|
||||||
MR_SERV_SRC="${SRCDIR}/kiauh/resources/moonraker.service"
|
|
||||||
MR_SERV_TARGET="$SYSTEMDDIR/moonraker.service"
|
|
||||||
|
|
||||||
write_mr_service(){
|
|
||||||
if [ ! -f $MR_SERV_TARGET ]; then
|
|
||||||
status_msg "Creating Moonraker Service $i ..."
|
|
||||||
sudo cp "$MR_SERV_SRC" $MR_SERV_TARGET
|
|
||||||
sudo sed -i "s|%INST%|$i|" $MR_SERV_TARGET
|
|
||||||
sudo sed -i "s|%USER%|${USER}|" $MR_SERV_TARGET
|
|
||||||
sudo sed -i "s|%MR_ENV%|$MR_ENV|" $MR_SERV_TARGET
|
|
||||||
sudo sed -i "s|%MR_DIR%|$MR_DIR|" $MR_SERV_TARGET
|
|
||||||
sudo sed -i "s|%MR_LOG%|$MR_LOG|" $MR_SERV_TARGET
|
|
||||||
sudo sed -i "s|%MR_CONF%|$MR_CONF|" $MR_SERV_TARGET
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
if [[ $SINGLE_INST -eq $INSTANCE_COUNT ]]; then
|
|
||||||
### write single instance service
|
|
||||||
write_mr_service
|
|
||||||
### enable instance
|
|
||||||
do_action_service "enable" "moonraker"
|
|
||||||
ok_msg "Single Moonraker instance created!"
|
|
||||||
### launching instance
|
|
||||||
do_action_service "start" "moonraker"
|
|
||||||
else
|
|
||||||
i=1
|
|
||||||
while [[ $i -le $INSTANCE_COUNT ]]; do
|
|
||||||
### rewrite default variables for multi instance cases
|
|
||||||
CFG_PATH="$klipper_cfg_loc/printer_$i"
|
|
||||||
MR_SERV_TARGET="$SYSTEMDDIR/moonraker-$i.service"
|
|
||||||
MR_CONF="$CFG_PATH/moonraker.conf"
|
|
||||||
MR_LOG="${HOME}/klipper_logs/moonraker-$i.log"
|
|
||||||
### write multi instance service
|
|
||||||
write_mr_service
|
|
||||||
### enable instance
|
|
||||||
do_action_service "enable" "moonraker-$i"
|
|
||||||
ok_msg "Moonraker instance #$i created!"
|
|
||||||
### launching instance
|
|
||||||
do_action_service "start" "moonraker-$i"
|
|
||||||
### raise values by 1
|
|
||||||
i=$((i+1))
|
|
||||||
done
|
|
||||||
unset i
|
|
||||||
|
|
||||||
### enable mainsails remoteMode if mainsail is found
|
|
||||||
if [ -d "$MAINSAIL_DIR" ]; then
|
|
||||||
status_msg "Mainsail installation found!"
|
|
||||||
status_msg "Enabling Mainsail remoteMode ..."
|
|
||||||
enable_mainsail_remotemode
|
|
||||||
ok_msg "Mainsails remoteMode enabled!"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
create_moonraker_conf(){
|
|
||||||
### get config directory
|
|
||||||
source_kiauh_ini
|
|
||||||
|
|
||||||
### set up default values
|
|
||||||
SINGLE_INST=1
|
|
||||||
PORT=7125
|
|
||||||
CFG_PATH="$klipper_cfg_loc"
|
|
||||||
LOG_PATH="${HOME}/klipper_logs"
|
|
||||||
MR_CONF="$CFG_PATH/moonraker.conf"
|
|
||||||
MR_DB="${HOME}/.moonraker_database"
|
|
||||||
KLIPPY_UDS="/tmp/klippy_uds"
|
|
||||||
MR_CONF_SRC="${SRCDIR}/kiauh/resources/moonraker.conf"
|
|
||||||
mr_ip_list=()
|
|
||||||
IP=$(hostname -I | cut -d" " -f1)
|
|
||||||
LAN="$(hostname -I | cut -d" " -f1 | cut -d"." -f1-2).0.0/16"
|
|
||||||
|
|
||||||
write_mr_conf(){
|
|
||||||
[ ! -d "$CFG_PATH" ] && mkdir -p "$CFG_PATH"
|
|
||||||
if [ ! -f "$MR_CONF" ]; then
|
|
||||||
status_msg "Creating moonraker.conf in $CFG_PATH ..."
|
|
||||||
cp "$MR_CONF_SRC" "$MR_CONF"
|
|
||||||
sed -i "s|%PORT%|$PORT|" "$MR_CONF"
|
|
||||||
sed -i "s|%CFG%|$CFG_PATH|" "$MR_CONF"
|
|
||||||
sed -i "s|%LOG%|$LOG_PATH|" "$MR_CONF"
|
|
||||||
sed -i "s|%MR_DB%|$MR_DB|" "$MR_CONF"
|
|
||||||
sed -i "s|%UDS%|$KLIPPY_UDS|" "$MR_CONF"
|
|
||||||
# if host ip is not in the default ip ranges, replace placeholder
|
|
||||||
# otherwise remove placeholder from config
|
|
||||||
if ! grep -q "$LAN" "$MR_CONF"; then
|
|
||||||
sed -i "s|%LAN%|$LAN|" "$MR_CONF"
|
|
||||||
else
|
|
||||||
sed -i "/%LAN%/d" "$MR_CONF"
|
|
||||||
fi
|
|
||||||
sed -i "s|%USER%|${USER}|g" "$MR_CONF"
|
|
||||||
ok_msg "moonraker.conf created!"
|
|
||||||
else
|
|
||||||
warn_msg "There is already a file called 'moonraker.conf'!"
|
|
||||||
warn_msg "Skipping..."
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
if [[ $SINGLE_INST -eq $INSTANCE_COUNT ]]; then
|
|
||||||
### write single instance config
|
|
||||||
write_mr_conf
|
|
||||||
mr_ip_list+=("$IP:$PORT")
|
|
||||||
else
|
|
||||||
i=1
|
|
||||||
while [[ $i -le $INSTANCE_COUNT ]]; do
|
|
||||||
### rewrite default variables for multi instance cases
|
|
||||||
CFG_PATH="$klipper_cfg_loc/printer_$i"
|
|
||||||
MR_CONF="$CFG_PATH/moonraker.conf"
|
|
||||||
MR_DB="${HOME}/.moonraker_database_$i"
|
|
||||||
KLIPPY_UDS="/tmp/klippy_uds-$i"
|
|
||||||
|
|
||||||
### write multi instance config
|
|
||||||
write_mr_conf
|
|
||||||
mr_ip_list+=("$IP:$PORT")
|
|
||||||
|
|
||||||
### raise values by 1
|
|
||||||
PORT=$((PORT+1))
|
|
||||||
i=$((i+1))
|
|
||||||
done
|
|
||||||
unset PORT && unset i
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
print_mr_ip_list(){
|
|
||||||
i=1
|
|
||||||
for ip in "${mr_ip_list[@]}"; do
|
|
||||||
echo -e " ${cyan}● Instance $i:${default} $ip"
|
|
||||||
i=$((i + 1))
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
### introduced due to
|
|
||||||
### https://github.com/Arksine/moonraker/issues/349
|
|
||||||
### https://github.com/Arksine/moonraker/pull/346
|
|
||||||
moonraker_polkit(){
|
|
||||||
SYSTEMDDIR="/etc/systemd/system"
|
|
||||||
MOONRAKER_SERVICES=$(find "$SYSTEMDDIR" -regextype posix-extended -regex "$SYSTEMDDIR/moonraker(-[^0])?[0-9]*.service")
|
|
||||||
for service in $MOONRAKER_SERVICES; do
|
|
||||||
HAS_SUPP="$( grep -cm1 "SupplementaryGroups=moonraker-admin" "$service" || true )"
|
|
||||||
if [ "$HAS_SUPP" -eq 0 ]; then
|
|
||||||
status_msg "Adding moonraker-admin supplementary group to $service ..."
|
|
||||||
sudo sed -i "/^Type=simple$/a SupplementaryGroups=moonraker-admin" "$service" \
|
|
||||||
&& ok_msg "Adding moonraker-admin supplementary group successfull!"
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
### execute moonrakers policykit-rules script
|
|
||||||
"${HOME}"/moonraker/scripts/set-policykit-rules.sh
|
|
||||||
sudo systemctl daemon-reload
|
|
||||||
}
|
|
||||||
506
scripts/moonraker.sh
Normal file
506
scripts/moonraker.sh
Normal file
@@ -0,0 +1,506 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
#=======================================================================#
|
||||||
|
# Copyright (C) 2020 - 2022 Dominik Willner <th33xitus@gmail.com> #
|
||||||
|
# #
|
||||||
|
# This file is part of KIAUH - Klipper Installation And Update Helper #
|
||||||
|
# https://github.com/th33xitus/kiauh #
|
||||||
|
# #
|
||||||
|
# This file may be distributed under the terms of the GNU GPLv3 license #
|
||||||
|
#=======================================================================#
|
||||||
|
|
||||||
|
set -e
|
||||||
|
|
||||||
|
### global variables
|
||||||
|
SYSTEMD="/etc/systemd/system"
|
||||||
|
INITD="/etc/init.d"
|
||||||
|
ETCDEF="/etc/default"
|
||||||
|
MOONRAKER_ENV="${HOME}/moonraker-env"
|
||||||
|
MOONRAKER_DIR="${HOME}/moonraker"
|
||||||
|
MOONRAKER_REPO="https://github.com/Arksine/moonraker.git"
|
||||||
|
|
||||||
|
#===================================================#
|
||||||
|
#================ INSTALL MOONRAKER ================#
|
||||||
|
#===================================================#
|
||||||
|
|
||||||
|
function system_check_moonraker(){
|
||||||
|
local major minor
|
||||||
|
### python 3 check
|
||||||
|
status_msg "Your Python 3 version is: $(python3 --version)"
|
||||||
|
major=$(python3 --version | cut -d" " -f2 | cut -d"." -f1)
|
||||||
|
minor=$(python3 --version | cut -d"." -f2)
|
||||||
|
if [ "${major}" -ge 3 ] && [ "${minor}" -ge 7 ]; then
|
||||||
|
echo "true"
|
||||||
|
else
|
||||||
|
echo "false"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function moonraker_systemd() {
|
||||||
|
local services
|
||||||
|
services=$(find "${SYSTEMD}" -maxdepth 1 -regextype posix-extended -regex "${SYSTEMD}/moonraker(-[^0])?[0-9]*.service")
|
||||||
|
echo "${services}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function moonraker_setup_dialog(){
|
||||||
|
status_msg "Initializing Moonraker installation ..."
|
||||||
|
|
||||||
|
### return early if moonraker already exists
|
||||||
|
if [ -n "$(moonraker_systemd)" ]; then
|
||||||
|
ERROR_MSG="At least one Moonraker service is already installed:"
|
||||||
|
for service in $(moonraker_systemd); do
|
||||||
|
ERROR_MSG="${ERROR_MSG}\n ➔ ${service}"
|
||||||
|
done
|
||||||
|
export ERROR_MSG
|
||||||
|
print_error && return
|
||||||
|
fi
|
||||||
|
|
||||||
|
### return early if python version check fails
|
||||||
|
if [ "$(system_check_moonraker)" == "false" ]; then
|
||||||
|
ERROR_MSG="Versioncheck failed! Python 3.7 or newer required!\n"
|
||||||
|
ERROR_MSG="${ERROR_MSG} Please upgrade Python."
|
||||||
|
export ERROR_MSG
|
||||||
|
print_error && return
|
||||||
|
fi
|
||||||
|
|
||||||
|
top_border
|
||||||
|
if [ -f "${INITD}/klipper" ] || [ -f "${SYSTEMD}/klipper.service" ]; then
|
||||||
|
printf "|${green}%-55s${default}|\n" " 1 Klipper instance was found!"
|
||||||
|
elif [ "$(klipper_systemd | wc -w)" -gt 1 ]; then
|
||||||
|
printf "|${green}%-55s${default}|\n" " $(klipper_systemd | wc -w) Klipper instances were found!"
|
||||||
|
else
|
||||||
|
echo -e "| ${yellow}INFO: No existing Klipper installation found!${default} |"
|
||||||
|
fi
|
||||||
|
echo -e "| Usually you need one Moonraker instance per Klipper |"
|
||||||
|
echo -e "| instance. Though you can install as many as you wish. |"
|
||||||
|
bottom_border
|
||||||
|
|
||||||
|
local count
|
||||||
|
while [[ ! (${count} =~ ^[1-9]+((0)+)?$) ]]; do
|
||||||
|
read -p "${cyan}###### Number of Moonraker instances to set up:${default} " count
|
||||||
|
if [[ ! (${count} =~ ^[1-9]+((0)+)?$) ]]; then
|
||||||
|
error_msg "Invalid Input!\n"
|
||||||
|
else
|
||||||
|
echo
|
||||||
|
read -p "${cyan}###### Install ${count} instance(s)? (Y/n):${default} " yn
|
||||||
|
case "${yn}" in
|
||||||
|
Y|y|Yes|yes|"")
|
||||||
|
select_msg "Yes"
|
||||||
|
status_msg "Installing ${count} Moonraker instance(s) ... \n"
|
||||||
|
moonraker_setup "${count}"
|
||||||
|
break;;
|
||||||
|
N|n|No|no)
|
||||||
|
select_msg"No"
|
||||||
|
error_msg "Exiting Moonraker setup ...\n"
|
||||||
|
break;;
|
||||||
|
*)
|
||||||
|
invalid_option && print_error
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
function install_moonraker_packages(){
|
||||||
|
local packages
|
||||||
|
local install_script="${HOME}/moonraker/scripts/install-moonraker.sh"
|
||||||
|
|
||||||
|
### read PKGLIST from official install script
|
||||||
|
status_msg "Reading dependencies..."
|
||||||
|
# shellcheck disable=SC2016
|
||||||
|
packages="$(grep "PKGLIST=" "${install_script}" | cut -d'"' -f2 | sed 's/\${PKGLIST}//g' | tr -d '\n')"
|
||||||
|
|
||||||
|
echo "${cyan}${packages}${white}" | tr '[:space:]' '\n'
|
||||||
|
read -r -a packages <<< "${packages}"
|
||||||
|
|
||||||
|
### Update system package info
|
||||||
|
status_msg "Updating lists of packages..."
|
||||||
|
sudo apt-get update --allow-releaseinfo-change
|
||||||
|
|
||||||
|
### Install required packages
|
||||||
|
status_msg "Installing packages..."
|
||||||
|
sudo apt-get install --yes "${packages[@]}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function create_moonraker_virtualenv(){
|
||||||
|
status_msg "Installing python virtual environment..."
|
||||||
|
### always create a clean virtualenv
|
||||||
|
[ -d "${MOONRAKER_ENV}" ] && rm -rf "${MOONRAKER_ENV}"
|
||||||
|
virtualenv -p /usr/bin/python3 "${MOONRAKER_ENV}"
|
||||||
|
"${MOONRAKER_ENV}"/bin/pip install -r "${MOONRAKER_DIR}/scripts/moonraker-requirements.txt"
|
||||||
|
}
|
||||||
|
|
||||||
|
function moonraker_setup(){
|
||||||
|
local instances=${1}
|
||||||
|
### checking dependencies
|
||||||
|
dep=(wget curl unzip dfu-util virtualenv)
|
||||||
|
### additional required dependencies on armbian
|
||||||
|
dep+=(libjpeg-dev zlib1g-dev)
|
||||||
|
dependency_check "${dep[@]}"
|
||||||
|
|
||||||
|
### step 1: clone moonraker
|
||||||
|
status_msg "Downloading Moonraker ..."
|
||||||
|
### force remove existing moonraker dir and clone into fresh moonraker dir
|
||||||
|
[ -d "${MOONRAKER_DIR}" ] && rm -rf "${MOONRAKER_DIR}"
|
||||||
|
cd "${HOME}" && git clone "${MOONRAKER_REPO}"
|
||||||
|
|
||||||
|
### step 2: install moonraker dependencies and create python virtualenv
|
||||||
|
status_msg "Installing dependencies ..."
|
||||||
|
install_moonraker_packages
|
||||||
|
create_moonraker_virtualenv
|
||||||
|
|
||||||
|
### step 3: create moonraker.conf
|
||||||
|
create_moonraker_conf "${instances}"
|
||||||
|
|
||||||
|
### step 4: create moonraker instances
|
||||||
|
create_moonraker_service "${instances}"
|
||||||
|
|
||||||
|
### step 5: create polkit rules for moonraker
|
||||||
|
moonraker_polkit
|
||||||
|
|
||||||
|
### step 6: enable and start all instances
|
||||||
|
do_action_service "enable" "moonraker"
|
||||||
|
do_action_service "start" "moonraker"
|
||||||
|
|
||||||
|
### confirm message
|
||||||
|
if [[ ${instances} -eq 1 ]]; then
|
||||||
|
CONFIRM_MSG="Moonraker has been set up!"
|
||||||
|
elif [[ ${instances} -gt 1 ]]; then
|
||||||
|
CONFIRM_MSG="${instances} Moonraker instances have been set up!"
|
||||||
|
fi
|
||||||
|
export CONFIRM_MSG
|
||||||
|
print_confirm
|
||||||
|
|
||||||
|
print_mr_ip_list "${mr_ip_list}"
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
function write_moonraker_service(){
|
||||||
|
local i=${1} cfg_dir=${2} cfg=${3} log=${4} service=${5}
|
||||||
|
local service_template="${SRCDIR}/kiauh/resources/moonraker.service"
|
||||||
|
|
||||||
|
### replace all placeholders
|
||||||
|
if [ ! -f "${service}" ]; then
|
||||||
|
status_msg "Creating Moonraker Service ${i} ..."
|
||||||
|
sudo cp "${service_template}" "${service}"
|
||||||
|
|
||||||
|
[ -z "${i}" ] && sudo sed -i "s|instance %INST% ||" "${service}"
|
||||||
|
[ -n "${i}" ] && sudo sed -i "s|%INST%|${i}|" "${service}"
|
||||||
|
sudo sed -i "s|%USER%|${USER}|; s|%ENV%|${MOONRAKER_ENV}|; s|%DIR%|${MOONRAKER_DIR}|" "${service}"
|
||||||
|
sudo sed -i "s|%CFG%|${cfg}|; s|%LOG%|${log}|" "${service}"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function create_moonraker_service(){
|
||||||
|
local instances=${1}
|
||||||
|
if [ "${instances}" -eq 1 ]; then
|
||||||
|
local i=""
|
||||||
|
local cfg_dir="${KLIPPER_CONFIG}"
|
||||||
|
local cfg="${cfg_dir}/moonraker.conf"
|
||||||
|
local log="${HOME}/klipper_logs/moonraker.log"
|
||||||
|
local service="${SYSTEMD}/moonraker.service"
|
||||||
|
### write single instance service
|
||||||
|
write_moonraker_service "${i}" "${cfg_dir}" "${cfg}" "${log}" "${service}"
|
||||||
|
ok_msg "Single Moonraker instance created!"
|
||||||
|
elif [ "${instances}" -gt 1 ]; then
|
||||||
|
local i=1
|
||||||
|
while [ "${i}" -le "${instances}" ]; do
|
||||||
|
local cfg_dir="${KLIPPER_CONFIG}/printer_${i}"
|
||||||
|
local cfg="${cfg_dir}/moonraker.conf"
|
||||||
|
local log="${HOME}/klipper_logs/moonraker-${i}.log"
|
||||||
|
local service="${SYSTEMD}/moonraker-${i}.service"
|
||||||
|
### write multi instance service
|
||||||
|
write_moonraker_service "${i}" "${cfg_dir}" "${cfg}" "${log}" "${service}"
|
||||||
|
ok_msg "Moonraker instance #${i} created!"
|
||||||
|
i=$((i+1))
|
||||||
|
done && unset i
|
||||||
|
### enable mainsails remoteMode if mainsail is found
|
||||||
|
if [ -d "${MAINSAIL_DIR}" ]; then
|
||||||
|
status_msg "Mainsail installation found!"
|
||||||
|
status_msg "Enabling Mainsail remoteMode ..."
|
||||||
|
enable_mainsail_remotemode
|
||||||
|
ok_msg "Mainsails remoteMode enabled!"
|
||||||
|
fi
|
||||||
|
else
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function write_moonraker_conf(){
|
||||||
|
local cfg_dir=${1} cfg=${2} port=${3} log=${4} db=${5} uds=${6} lan=${7}
|
||||||
|
local conf_template="${SRCDIR}/kiauh/resources/moonraker.conf"
|
||||||
|
[ ! -d "${cfg_dir}" ] && mkdir -p "${cfg_dir}"
|
||||||
|
|
||||||
|
if [ ! -f "${cfg}" ]; then
|
||||||
|
status_msg "Creating moonraker.conf in ${cfg_dir} ..."
|
||||||
|
cp "${conf_template}" "${cfg}"
|
||||||
|
sed -i "s|%USER%|${USER}|g" "${cfg}"
|
||||||
|
sed -i "s|%CFG%|${cfg_dir}|; s|%PORT%|${port}|; s|%LOG%|${log}|; s|%DB%|${db}|; s|%UDS%|${uds}|" "${cfg}"
|
||||||
|
# if host ip is not in the default ip ranges replace placeholder,
|
||||||
|
# otherwise remove placeholder from config
|
||||||
|
if ! grep -q "${lan}" "${cfg}"; then
|
||||||
|
sed -i "s|%LAN%|${lan}|" "${cfg}"
|
||||||
|
else
|
||||||
|
sed -i "/%LAN%/d" "${cfg}"
|
||||||
|
fi
|
||||||
|
ok_msg "moonraker.conf created!"
|
||||||
|
else
|
||||||
|
status_msg "File '${cfg_dir}/moonraker.conf' already exists!\nSkipping..."
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function create_moonraker_conf(){
|
||||||
|
local instances=${1}
|
||||||
|
local log="${HOME}/klipper_logs"
|
||||||
|
local mr_ip_list=()
|
||||||
|
local ip lan
|
||||||
|
|
||||||
|
ip=$(hostname -I | cut -d" " -f1)
|
||||||
|
lan="$(hostname -I | cut -d" " -f1 | cut -d"." -f1-2).0.0/16"
|
||||||
|
|
||||||
|
if [ "${instances}" -eq 1 ]; then
|
||||||
|
local cfg_dir="${KLIPPER_CONFIG}"
|
||||||
|
local cfg="${cfg_dir}/moonraker.conf"
|
||||||
|
local port=7125
|
||||||
|
local db="${HOME}/.moonraker_database"
|
||||||
|
local uds="/tmp/klippy_uds"
|
||||||
|
### write single instance config
|
||||||
|
write_moonraker_conf "${cfg_dir}" "${cfg}" "${port}" "${log}" "${db}" "${uds}" "${lan}"
|
||||||
|
mr_ip_list+=("${ip}:${port}")
|
||||||
|
elif [ "${instances}" -gt 1 ]; then
|
||||||
|
local i=1
|
||||||
|
while [ "${i}" -le "${instances}" ]; do
|
||||||
|
local cfg_dir="${KLIPPER_CONFIG}/printer_${i}"
|
||||||
|
local cfg="${cfg_dir}/moonraker.conf"
|
||||||
|
local port=7125
|
||||||
|
local db="${HOME}/.moonraker_database_${i}"
|
||||||
|
local uds="/tmp/klippy_uds-${i}"
|
||||||
|
### write multi instance config
|
||||||
|
write_moonraker_conf "${cfg_dir}" "${cfg}" "${port}" "${log}" "${db}" "${uds}" "${lan}"
|
||||||
|
mr_ip_list+=("${ip}:${port}")
|
||||||
|
port=$((port+1))
|
||||||
|
i=$((i+1))
|
||||||
|
done && unset port i
|
||||||
|
else
|
||||||
|
return 1
|
||||||
|
fi
|
||||||
|
export mr_ip_list
|
||||||
|
}
|
||||||
|
|
||||||
|
function print_mr_ip_list(){
|
||||||
|
local ips=${1}
|
||||||
|
local i=0
|
||||||
|
for ip in "${ips[@]}"; do
|
||||||
|
echo -e " ${cyan}● Instance $((i + 1)):${white} ${ip}"
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
|
### introduced due to
|
||||||
|
### https://github.com/Arksine/moonraker/issues/349
|
||||||
|
### https://github.com/Arksine/moonraker/pull/346
|
||||||
|
function moonraker_polkit(){
|
||||||
|
local has_sup
|
||||||
|
### check for required SupplementaryGroups entry in service files
|
||||||
|
### write it to the service if it doesn't exist
|
||||||
|
for service in $(moonraker_systemd); do
|
||||||
|
has_sup="$(grep "SupplementaryGroups=moonraker-admin" "${service}")"
|
||||||
|
if [ -z "${has_sup}" ]; then
|
||||||
|
status_msg "Adding moonraker-admin supplementary group to ${service} ..."
|
||||||
|
sudo sed -i "/^Type=simple$/a SupplementaryGroups=moonraker-admin" "${service}"
|
||||||
|
ok_msg "Adding moonraker-admin supplementary group successfull!"
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
[ -z "${has_sup}" ] && echo "reloading services!!!" && sudo systemctl daemon-reload
|
||||||
|
### execute moonrakers policykit-rules script
|
||||||
|
/bin/bash "${HOME}/moonraker/scripts/set-policykit-rules.sh"
|
||||||
|
}
|
||||||
|
|
||||||
|
#==================================================#
|
||||||
|
#================ REMOVE MOONRAKER ================#
|
||||||
|
#==================================================#
|
||||||
|
|
||||||
|
function remove_moonraker_sysvinit() {
|
||||||
|
[ ! -e "${INITD}/moonraker" ] && return
|
||||||
|
status_msg "Removing Moonraker SysVinit service ..."
|
||||||
|
sudo systemctl stop moonraker
|
||||||
|
sudo update-rc.d -f moonraker remove
|
||||||
|
sudo rm -f "${INITD}/moonraker" "${ETCDEF}/moonraker"
|
||||||
|
ok_msg "Moonraker SysVinit service removed!"
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_moonraker_systemd() {
|
||||||
|
[ -z "$(moonraker_systemd)" ] && return
|
||||||
|
status_msg "Removing Moonraker Systemd Services ..."
|
||||||
|
local files
|
||||||
|
for service in $(moonraker_systemd | cut -d"/" -f5)
|
||||||
|
do
|
||||||
|
status_msg "Removing ${service} ..."
|
||||||
|
sudo systemctl stop "${service}"
|
||||||
|
sudo systemctl disable "${service}"
|
||||||
|
sudo rm -f "${SYSTEMD}/${service}"
|
||||||
|
ok_msg "Done!"
|
||||||
|
done
|
||||||
|
### reloading units
|
||||||
|
sudo systemctl daemon-reload
|
||||||
|
sudo systemctl reset-failed
|
||||||
|
ok_msg "Moonraker Services removed!"
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_moonraker_logs() {
|
||||||
|
local files
|
||||||
|
files=$(find "${HOME}/klipper_logs" -maxdepth 1 -regextype posix-extended -regex "${HOME}/klipper_logs/moonraker(-[^0])?[0-9]*\.log(.*)?")
|
||||||
|
if [ -n "${files}" ]; then
|
||||||
|
for file in ${files}; do
|
||||||
|
status_msg "Removing ${file} ..."
|
||||||
|
rm -f "${file}"
|
||||||
|
ok_msg "${file} removed!"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_moonraker_api_key() {
|
||||||
|
### remove legacy api key
|
||||||
|
if [ -e "${HOME}/.klippy_api_key" ]; then
|
||||||
|
status_msg "Removing legacy API Key ..."
|
||||||
|
rm "${HOME}/.klippy_api_key"
|
||||||
|
ok_msg "Done!"
|
||||||
|
fi
|
||||||
|
### remove api key
|
||||||
|
if [ -e "${HOME}/.moonraker_api_key" ]; then
|
||||||
|
status_msg "Removing API Key ..."
|
||||||
|
rm "${HOME}/.moonraker_api_key"
|
||||||
|
ok_msg "Done!"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_moonraker_dir() {
|
||||||
|
[ ! -d "${MOONRAKER_DIR}" ] && return
|
||||||
|
status_msg "Removing Moonraker directory ..."
|
||||||
|
rm -rf "${MOONRAKER_DIR}"
|
||||||
|
ok_msg "Directory removed!"
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_moonraker_env() {
|
||||||
|
[ ! -d "${MOONRAKER_ENV}" ] && return
|
||||||
|
status_msg "Removing moonraker-env directory ..."
|
||||||
|
rm -rf "${MOONRAKER_ENV}"
|
||||||
|
ok_msg "Directory removed!"
|
||||||
|
}
|
||||||
|
|
||||||
|
function remove_moonraker_polkit() {
|
||||||
|
status_msg "Removing all Moonraker PolicyKit rules ..."
|
||||||
|
/bin/bash "${HOME}/moonraker/scripts/set-policykit-rules.sh" --clear
|
||||||
|
ok_msg "Done!"
|
||||||
|
}
|
||||||
|
|
||||||
|
#TODO this is technically not moonraker but rather webinterface related configs, so this should be refactored.
|
||||||
|
function remove_moonraker_nginx() {
|
||||||
|
if [[ -e "${NGINX_CONFD}/upstreams.conf" || -e "${NGINX_CONFD}/common_vars.conf" ]]; then
|
||||||
|
status_msg "Removing Moonraker NGINX configuration ..."
|
||||||
|
sudo rm -f "${NGINX_CONFD}/upstreams.conf" "${NGINX_CONFD}/common_vars.conf"
|
||||||
|
ok_msg "Moonraker NGINX configuration removed!"
|
||||||
|
fi
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function remove_moonraker(){
|
||||||
|
remove_moonraker_sysvinit
|
||||||
|
remove_moonraker_systemd
|
||||||
|
remove_moonraker_logs
|
||||||
|
remove_moonraker_api_key
|
||||||
|
remove_moonraker_dir
|
||||||
|
remove_moonraker_env
|
||||||
|
remove_moonraker_polkit
|
||||||
|
remove_moonraker_nginx
|
||||||
|
|
||||||
|
confirm="Moonraker was successfully removed!"
|
||||||
|
print_confirm "${confirm}" && return
|
||||||
|
}
|
||||||
|
|
||||||
|
#==================================================#
|
||||||
|
#================ UPDATE MOONRAKER ================#
|
||||||
|
#==================================================#
|
||||||
|
|
||||||
|
function update_moonraker(){
|
||||||
|
do_action_service "stop" "moonraker"
|
||||||
|
if [ ! -d "${MOONRAKER_DIR}" ]; then
|
||||||
|
cd "${HOME}" && git clone "${MOONRAKER_REPO}"
|
||||||
|
else
|
||||||
|
bb4u "moonraker"
|
||||||
|
status_msg "Updating Moonraker ..."
|
||||||
|
cd "${MOONRAKER_DIR}" && git pull
|
||||||
|
### read PKGLIST and install possible new dependencies
|
||||||
|
install_moonraker_packages
|
||||||
|
### install possible new python dependencies
|
||||||
|
"${MOONRAKER_ENV}"/bin/pip install -r "${MOONRAKER_DIR}/scripts/moonraker-requirements.txt"
|
||||||
|
fi
|
||||||
|
### required due to https://github.com/Arksine/moonraker/issues/349
|
||||||
|
moonraker_polkit
|
||||||
|
|
||||||
|
update_log_paths "moonraker"
|
||||||
|
ok_msg "Update complete!"
|
||||||
|
do_action_service "restart" "moonraker"
|
||||||
|
}
|
||||||
|
|
||||||
|
#==================================================#
|
||||||
|
#================ MOONRAKER STATUS ================#
|
||||||
|
#==================================================#
|
||||||
|
|
||||||
|
function get_moonraker_status(){
|
||||||
|
local sf_count status
|
||||||
|
sf_count="$(moonraker_systemd | wc -w)"
|
||||||
|
|
||||||
|
### remove the "SERVICE" entry from the data array if a moonraker service is installed
|
||||||
|
local data_arr=(SERVICE "${MOONRAKER_DIR}" "${MOONRAKER_ENV}")
|
||||||
|
[ "${sf_count}" -gt 0 ] && unset "data_arr[0]"
|
||||||
|
|
||||||
|
### count+1 for each found data-item from array
|
||||||
|
local filecount=0
|
||||||
|
for data in "${data_arr[@]}"; do
|
||||||
|
[ -e "${data}" ] && filecount=$(("${filecount}" + 1))
|
||||||
|
done
|
||||||
|
|
||||||
|
if [ "${filecount}" == "${#data_arr[*]}" ]; then
|
||||||
|
status="$(printf "${green}Installed: %-5s${white}" "${sf_count}")"
|
||||||
|
elif [ "${filecount}" == 0 ]; then
|
||||||
|
status="${red}Not installed!${white} "
|
||||||
|
else
|
||||||
|
status="${yellow}Incomplete!${white} "
|
||||||
|
fi
|
||||||
|
echo "${status}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_local_moonraker_commit(){
|
||||||
|
if [ -d "${MOONRAKER_DIR}" ] && [ -d "${MOONRAKER_DIR}"/.git ]; then
|
||||||
|
cd "${MOONRAKER_DIR}"
|
||||||
|
commit="$(git describe HEAD --always --tags | cut -d "-" -f 1,2)"
|
||||||
|
else
|
||||||
|
commit="${NONE}"
|
||||||
|
fi
|
||||||
|
echo "${commit}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function get_remote_moonraker_commit(){
|
||||||
|
if [ -d "${MOONRAKER_DIR}" ] && [ -d "${MOONRAKER_DIR}"/.git ]; then
|
||||||
|
cd "${MOONRAKER_DIR}"
|
||||||
|
git fetch origin -q
|
||||||
|
commit=$(git describe origin/master --always --tags | cut -d "-" -f 1,2)
|
||||||
|
else
|
||||||
|
commit="${NONE}"
|
||||||
|
fi
|
||||||
|
echo "${commit}"
|
||||||
|
}
|
||||||
|
|
||||||
|
function compare_moonraker_versions(){
|
||||||
|
unset MOONRAKER_UPDATE_AVAIL
|
||||||
|
if [ "$(get_local_moonraker_commit)" != "$(get_remote_moonraker_commit)" ]; then
|
||||||
|
LOCAL_COMMIT="${yellow}$(printf "%-12s" "$(get_local_moonraker_commit)")${white}"
|
||||||
|
REMOTE_COMMIT="${green}$(printf "%-12s" "$(get_remotemoonrakerr_commit)")${white}"
|
||||||
|
# add klipper to the update all array for the update all function in the updater
|
||||||
|
MOONRAKER_UPDATE_AVAIL="true" && update_arr+=(update_moonraker)
|
||||||
|
else
|
||||||
|
LOCAL_COMMIT="${green}$(printf "%-12s" "$(get_remote_moonraker_commit)")${white}"
|
||||||
|
REMOTE_COMMIT="${green}$(printf "%-12s" "$(get_remote_moonraker_commit)")${white}"
|
||||||
|
KLIPPER_UPDATE_AVAIL="false"
|
||||||
|
fi
|
||||||
|
}
|
||||||
@@ -1,79 +1,6 @@
|
|||||||
### base variables
|
### base variables
|
||||||
SYSTEMDDIR="/etc/systemd/system"
|
SYSTEMDDIR="/etc/systemd/system"
|
||||||
|
|
||||||
remove_moonraker(){
|
|
||||||
shopt -s extglob # enable extended globbing
|
|
||||||
### remove "legacy" moonraker init.d service
|
|
||||||
if [ -f /etc/init.d/moonraker ]; then
|
|
||||||
status_msg "Removing Moonraker Service ..."
|
|
||||||
sudo systemctl stop moonraker
|
|
||||||
sudo update-rc.d -f moonraker remove
|
|
||||||
sudo rm -f /etc/init.d/moonraker
|
|
||||||
sudo rm -f /etc/default/moonraker
|
|
||||||
ok_msg "Moonraker Service removed!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### remove all moonraker services
|
|
||||||
FILE="$SYSTEMDDIR/moonraker?(-*([0-9])).service"
|
|
||||||
if ls $FILE 2>/dev/null 1>&2; then
|
|
||||||
status_msg "Removing Moonraker Services ..."
|
|
||||||
for service in $(ls $FILE | cut -d"/" -f5)
|
|
||||||
do
|
|
||||||
status_msg "Removing $service ..."
|
|
||||||
sudo systemctl stop $service
|
|
||||||
sudo systemctl disable $service
|
|
||||||
sudo rm -f $SYSTEMDDIR/$service
|
|
||||||
ok_msg "Done!"
|
|
||||||
done
|
|
||||||
### reloading units
|
|
||||||
sudo systemctl daemon-reload
|
|
||||||
sudo systemctl reset-failed
|
|
||||||
ok_msg "Moonraker Service removed!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### remove all logfiles
|
|
||||||
FILE="${HOME}/klipper_logs/moonraker?(-*([0-9])).log"
|
|
||||||
if ls $FILE 2>/dev/null 1>&2; then
|
|
||||||
for log in $(ls $FILE); do
|
|
||||||
status_msg "Removing $log ..."
|
|
||||||
rm -f $log
|
|
||||||
ok_msg "$log removed!"
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
### remove moonraker nginx config
|
|
||||||
if [[ -e $NGINX_CONFD/upstreams.conf || -e $NGINX_CONFD/common_vars.conf ]]; then
|
|
||||||
status_msg "Removing Moonraker NGINX configuration ..."
|
|
||||||
sudo rm -f $NGINX_CONFD/upstreams.conf $NGINX_CONFD/common_vars.conf && ok_msg "Moonraker NGINX configuration removed!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### remove legacy api key
|
|
||||||
if [ -e ${HOME}/.klippy_api_key ]; then
|
|
||||||
status_msg "Removing legacy API Key ..." && rm ${HOME}/.klippy_api_key && ok_msg "Done!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### remove api key
|
|
||||||
if [ -e ${HOME}/.moonraker_api_key ]; then
|
|
||||||
status_msg "Removing API Key ..." && rm ${HOME}/.moonraker_api_key && ok_msg "Done!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
### removing moonraker and moonraker-env folder
|
|
||||||
if [ -d $MOONRAKER_DIR ]; then
|
|
||||||
status_msg "Removing Moonraker directory ..."
|
|
||||||
rm -rf $MOONRAKER_DIR && ok_msg "Directory removed!"
|
|
||||||
fi
|
|
||||||
if [ -d $MOONRAKER_ENV ]; then
|
|
||||||
status_msg "Removing moonraker-env directory ..."
|
|
||||||
rm -rf $MOONRAKER_ENV && ok_msg "Directory removed!"
|
|
||||||
fi
|
|
||||||
|
|
||||||
CONFIRM_MSG=" Moonraker was successfully removed!"
|
|
||||||
shopt -u extglob # disable extended globbing
|
|
||||||
}
|
|
||||||
|
|
||||||
#############################################################
|
|
||||||
#############################################################
|
|
||||||
|
|
||||||
remove_dwc2(){
|
remove_dwc2(){
|
||||||
### remove "legacy" init.d service
|
### remove "legacy" init.d service
|
||||||
if [ -e /etc/init.d/dwc ]; then
|
if [ -e /etc/init.d/dwc ]; then
|
||||||
|
|||||||
@@ -54,38 +54,6 @@ dwc2_status(){
|
|||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
moonraker_status(){
|
|
||||||
mrcount=0
|
|
||||||
moonraker_data=(
|
|
||||||
SERVICE
|
|
||||||
$MOONRAKER_DIR
|
|
||||||
$MOONRAKER_ENV_DIR
|
|
||||||
)
|
|
||||||
|
|
||||||
### count amount of moonraker service files in /etc/systemd/system
|
|
||||||
SERVICE_FILE_COUNT=$(ls /etc/systemd/system | grep -E "^moonraker(\-[[:digit:]]+)?\.service$" | wc -l)
|
|
||||||
|
|
||||||
### remove the "SERVICE" entry from the moonraker_data array if a moonraker service is installed
|
|
||||||
[ $SERVICE_FILE_COUNT -gt 0 ] && unset moonraker_data[0]
|
|
||||||
|
|
||||||
### count+1 for each found data-item from array
|
|
||||||
for mrd in "${moonraker_data[@]}"
|
|
||||||
do
|
|
||||||
if [ -e $mrd ]; then
|
|
||||||
mrcount=$(expr $mrcount + 1)
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
### display status
|
|
||||||
if [ "$mrcount" == "${#moonraker_data[*]}" ]; then
|
|
||||||
MOONRAKER_STATUS="$(printf "${green}Installed: %-5s${default}" $SERVICE_FILE_COUNT)"
|
|
||||||
elif [ "$mrcount" == 0 ]; then
|
|
||||||
MOONRAKER_STATUS="${red}Not installed!${default} "
|
|
||||||
else
|
|
||||||
MOONRAKER_STATUS="${yellow}Incomplete!${default} "
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
mainsail_status(){
|
mainsail_status(){
|
||||||
mcount=0
|
mcount=0
|
||||||
mainsail_data=(
|
mainsail_data=(
|
||||||
@@ -294,33 +262,6 @@ compare_dwc2_versions(){
|
|||||||
#############################################################
|
#############################################################
|
||||||
#############################################################
|
#############################################################
|
||||||
|
|
||||||
read_moonraker_versions(){
|
|
||||||
if [ -d $MOONRAKER_DIR ] && [ -d $MOONRAKER_DIR/.git ]; then
|
|
||||||
cd $MOONRAKER_DIR
|
|
||||||
git fetch origin master -q
|
|
||||||
LOCAL_MOONRAKER_COMMIT=$(git describe HEAD --always --tags | cut -d "-" -f 1,2)
|
|
||||||
REMOTE_MOONRAKER_COMMIT=$(git describe origin/master --always --tags | cut -d "-" -f 1,2)
|
|
||||||
else
|
|
||||||
LOCAL_MOONRAKER_COMMIT=$NONE
|
|
||||||
REMOTE_MOONRAKER_COMMIT=$NONE
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
compare_moonraker_versions(){
|
|
||||||
unset MOONRAKER_UPDATE_AVAIL
|
|
||||||
read_moonraker_versions
|
|
||||||
if [ "$LOCAL_MOONRAKER_COMMIT" != "$REMOTE_MOONRAKER_COMMIT" ]; then
|
|
||||||
LOCAL_MOONRAKER_COMMIT="${yellow}$(printf "%-12s" "$LOCAL_MOONRAKER_COMMIT")${default}"
|
|
||||||
REMOTE_MOONRAKER_COMMIT="${green}$(printf "%-12s" "$REMOTE_MOONRAKER_COMMIT")${default}"
|
|
||||||
# add moonraker to the update all array for the update all function in the updater
|
|
||||||
MOONRAKER_UPDATE_AVAIL="true" && update_arr+=(update_moonraker)
|
|
||||||
else
|
|
||||||
LOCAL_MOONRAKER_COMMIT="${green}$(printf "%-12s" "$LOCAL_MOONRAKER_COMMIT")${default}"
|
|
||||||
REMOTE_MOONRAKER_COMMIT="${green}$(printf "%-12s" "$REMOTE_MOONRAKER_COMMIT")${default}"
|
|
||||||
MOONRAKER_UPDATE_AVAIL="false"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
read_local_mainsail_version(){
|
read_local_mainsail_version(){
|
||||||
unset MAINSAIL_VER_FOUND
|
unset MAINSAIL_VER_FOUND
|
||||||
if [ -e $MAINSAIL_DIR/.version ]; then
|
if [ -e $MAINSAIL_DIR/.version ]; then
|
||||||
|
|||||||
@@ -6,7 +6,7 @@ main_ui(){
|
|||||||
echo -e "| 0) [Upload Log] | Klipper: $(get_klipper_status)|"
|
echo -e "| 0) [Upload Log] | Klipper: $(get_klipper_status)|"
|
||||||
echo -e "| | |"
|
echo -e "| | |"
|
||||||
echo -e "| 1) [Install] |--------------------------------|"
|
echo -e "| 1) [Install] |--------------------------------|"
|
||||||
echo -e "| 2) [Update] | Moonraker: $MOONRAKER_STATUS|"
|
echo -e "| 2) [Update] | Moonraker: $(get_moonraker_status)|"
|
||||||
echo -e "| 3) [Remove] | |"
|
echo -e "| 3) [Remove] | |"
|
||||||
echo -e "| 4) [Advanced] | Mainsail: $MAINSAIL_STATUS|"
|
echo -e "| 4) [Advanced] | Mainsail: $MAINSAIL_STATUS|"
|
||||||
echo -e "| 5) [Backup] | Fluidd: $FLUIDD_STATUS|"
|
echo -e "| 5) [Backup] | Fluidd: $FLUIDD_STATUS|"
|
||||||
@@ -48,7 +48,7 @@ main_menu(){
|
|||||||
#check install status
|
#check install status
|
||||||
print_kiauh_version
|
print_kiauh_version
|
||||||
# klipper_status
|
# klipper_status
|
||||||
moonraker_status
|
# moonraker_status
|
||||||
dwc2_status
|
dwc2_status
|
||||||
fluidd_status
|
fluidd_status
|
||||||
mainsail_status
|
mainsail_status
|
||||||
|
|||||||
@@ -251,26 +251,6 @@ update_fluidd(){
|
|||||||
symlink_webui_nginx_log "fluidd"
|
symlink_webui_nginx_log "fluidd"
|
||||||
}
|
}
|
||||||
|
|
||||||
update_moonraker(){
|
|
||||||
do_action_service "stop" "moonraker"
|
|
||||||
bb4u "moonraker"
|
|
||||||
status_msg "Updating Moonraker ..."
|
|
||||||
### pull latest files from github
|
|
||||||
cd "$MOONRAKER_DIR" && git pull
|
|
||||||
### read PKGLIST and install possible new dependencies
|
|
||||||
install_moonraker_packages
|
|
||||||
### install possible new python dependencies
|
|
||||||
MR_REQ_TXT="$MOONRAKER_DIR/scripts/moonraker-requirements.txt"
|
|
||||||
"$MOONRAKER_ENV"/bin/pip install -r "$MR_REQ_TXT"
|
|
||||||
update_log_paths "moonraker"
|
|
||||||
|
|
||||||
### required due to https://github.com/Arksine/moonraker/issues/349
|
|
||||||
moonraker_polkit
|
|
||||||
|
|
||||||
ok_msg "Update complete!"
|
|
||||||
do_action_service "restart" "moonraker"
|
|
||||||
}
|
|
||||||
|
|
||||||
update_klipperscreen(){
|
update_klipperscreen(){
|
||||||
stop_klipperscreen
|
stop_klipperscreen
|
||||||
cd $KLIPPERSCREEN_DIR
|
cd $KLIPPERSCREEN_DIR
|
||||||
|
|||||||
Reference in New Issue
Block a user