refactor(moonraker): install/remove single instances

This commit is contained in:
coderus
2023-01-07 20:39:12 +01:00
parent 3071e1e037
commit 57e7b476fa

View File

@@ -103,14 +103,13 @@ function moonraker_setup_dialog() {
echo echo
while true; do while true; do
read -p "Select: " -i "0" -e moonraker_count read -p "Select: " moonraker_count
if [[ $moonraker_count =~ ^[0-9]+$ ]] && [[ $moonraker_count -le ${#klipper_available[@]} ]]; then if [[ $moonraker_count =~ ^[0-9]+$ ]] && [[ $moonraker_count -le ${#klipper_available[@]} ]]; then
break break
else else
error_msg "Invalid Input!" error_msg "Invalid Input!"
fi fi
done done
select_msg "${moonraker_count}"
if (( moonraker_count == 0 )); then if (( moonraker_count == 0 )); then
for service in "${klipper_available[@]}"; do for service in "${klipper_available[@]}"; do
user_input+=( "$(basename ${service})" ) user_input+=( "$(basename ${service})" )
@@ -132,6 +131,10 @@ function moonraker_setup_dialog() {
return 1 return 1
fi fi
for i in ${user_input[@]}; do
select_msg "${i}"
done
### confirm instance amount ### confirm instance amount
local yn local yn
while true; do while true; do
@@ -151,11 +154,6 @@ function moonraker_setup_dialog() {
esac esac
done done
### write existing klipper names into user_input array to use them as names for moonraker
for name in ${klipper_services}; do
user_input+=("$(basename ${name})")
done
(( moonraker_count > 0 )) && status_msg "Installing Moonraker for $(basename ${klipper_available[(( moonraker_count-1 ))]}) instance ..." (( moonraker_count > 0 )) && status_msg "Installing Moonraker for $(basename ${klipper_available[(( moonraker_count-1 ))]}) instance ..."
(( moonraker_count == 1 )) && status_msg "Installing Moonraker ..." (( moonraker_count == 1 )) && status_msg "Installing Moonraker ..."
moonraker_setup "${user_input[@]}" moonraker_setup "${user_input[@]}"
@@ -274,16 +272,14 @@ function clone_moonraker() {
function create_moonraker_conf() { function create_moonraker_conf() {
local names=("${@}") local names=("${@}")
local moonraker_count=${#names[@]} local moonraker_count=${#names[@]}
local port lan printer_data cfg_dir cfg uds local lan printer_data cfg_dir cfg uds
local port=$(get_moonraker_next_port)
port=7125
lan="$(hostname -I | cut -d" " -f1 | cut -d"." -f1-2).0.0/16" lan="$(hostname -I | cut -d" " -f1 | cut -d"." -f1-2).0.0/16"
local j=0 re="^[1-9][0-9]*$" for service in "${names[@]}"; do
for (( i=1; i <= moonraker_count; i++ )); do
### overwrite config folder if name is only a number ### overwrite config folder if name is only a number
printer_data=$(get_data_folder "${names[$j]}" "klipper") printer_data=$(get_data_folder "${service}" "klipper")
cfg_dir="${printer_data}/config" cfg_dir="${printer_data}/config"
cfg="${cfg_dir}/moonraker.conf" cfg="${cfg_dir}/moonraker.conf"
@@ -291,8 +287,7 @@ function create_moonraker_conf() {
### write multi instance config ### write multi instance config
write_moonraker_conf "${cfg_dir}" "${cfg}" "${port}" "${uds}" "${lan}" write_moonraker_conf "${cfg_dir}" "${cfg}" "${port}" "${uds}" "${lan}"
port=$(( port + 1 )) (( port=port+1 ))
j=$(( j + 1 ))
done && unset j done && unset j
} }
@@ -324,11 +319,9 @@ function configure_moonraker_service() {
local moonraker_count=${#names[@]} local moonraker_count=${#names[@]}
local printer_data cfg_dir service env_file instance_name service_name local printer_data cfg_dir service env_file instance_name service_name
local j=0 re="^[1-9][0-9]*$" for service in "${names[@]}"; do
printer_data=$(get_data_folder "${service}" "klipper")
for (( i=1; i <= moonraker_count; i++ )); do instance_name=$(get_instance_name "${service}")
printer_data=$(get_data_folder "${names[$j]}" "klipper")
instance_name=$(get_instance_name "${names[$j]}")
cfg_dir="${printer_data}/config" cfg_dir="${printer_data}/config"
if [[ "${instance_name}" == "klipper" ]]; then if [[ "${instance_name}" == "klipper" ]]; then
@@ -345,7 +338,6 @@ function configure_moonraker_service() {
### write multi instance service ### write multi instance service
write_moonraker_service "${service_name}" "${printer_data}" "${service}" "${env_file}" write_moonraker_service "${service_name}" "${printer_data}" "${service}" "${env_file}"
ok_msg "Moonraker instance '${service_name}' created!" ok_msg "Moonraker instance '${service_name}' created!"
j=$(( j + 1 ))
done && unset i done && unset i
### enable mainsails remoteMode if mainsail is found ### enable mainsails remoteMode if mainsail is found
@@ -382,19 +374,42 @@ function print_mr_ip_list() {
done && echo done && echo
} }
function get_moonraker_address() { function get_moonraker_next_port() {
local port=7125
local moonraker_services=$(moonraker_systemd) moonraker_ports=()
for service in ${moonraker_services}
do
service_name=$(basename ${service})
moonraker_ports+=( "$(get_moonraker_port ${service_name})" )
done
while true; do
if [[ ! " ${moonraker_ports[*]} " =~ " ${port} " ]]; then
break
fi
(( port=port+1 ))
done
echo "${port}"
}
function get_moonraker_port() {
local service=${1} local service=${1}
local printer_data=$(get_data_folder ${service} moonraker) local printer_data=$(get_data_folder ${service} moonraker)
local ip=$(hostname -I | cut -d" " -f1)
local port=$(grep "^port:" "${printer_data}/config/moonraker.conf" | cut -f 2 -d " ") local port=$(grep "^port:" "${printer_data}/config/moonraker.conf" | cut -f 2 -d " ")
echo "${port}"
}
function get_moonraker_address() {
local ip=$(hostname -I | cut -d" " -f1)
local port=$(get_moonraker_port ${1})
echo "${ip}:${port}" echo "${ip}:${port}"
} }
function print_moonraker_addresses() { function print_moonraker_addresses() {
local moonraker_services=$(moonraker_systemd) local service_name moonraker_services=$(moonraker_systemd)
for service in ${moonraker_services} for service in ${moonraker_services}
do do
echo " ${cyan}${service}:${white} $(get_moonraker_address ${service})" service_name=$(basename ${service})
echo " ${cyan}${service_name}:${white} $(get_moonraker_address ${service_name})"
done done
} }
@@ -459,11 +474,9 @@ function remove_moonraker_sysvinit() {
} }
function remove_moonraker_systemd() { function remove_moonraker_systemd() {
[[ -z $(moonraker_systemd) ]] && return
status_msg "Removing Moonraker Systemd Services ..." status_msg "Removing Moonraker Systemd Services ..."
for service in $(moonraker_systemd | cut -d"/" -f5); do for service in "${@}"; do
status_msg "Removing ${service} ..." status_msg "Removing ${service} ..."
sudo systemctl stop "${service}" sudo systemctl stop "${service}"
sudo systemctl disable "${service}" sudo systemctl disable "${service}"
@@ -478,29 +491,25 @@ function remove_moonraker_systemd() {
} }
function remove_moonraker_env_file() { function remove_moonraker_env_file() {
local files regex="\/home\/${USER}\/([A-Za-z0-9_]+)\/systemd\/moonraker\.env" local printer_data file
files=$(find "${HOME}" -maxdepth 3 -regextype posix-extended -regex "${regex}" | sort) for service in "${@}"; do
printer_data=$(get_data_folder ${service} moonraker)
if [[ -n ${files} ]]; then file="${HOME}/${printer_data}/systemd/moonraker.env"
for file in ${files}; do status_msg "Removing ${file} ..."
status_msg "Removing ${file} ..." rm -f "${file}"
rm -f "${file}" ok_msg "${file} removed!"
ok_msg "${file} removed!" done
done
fi
} }
function remove_moonraker_logs() { function remove_moonraker_logs() {
local files regex="\/home\/${USER}\/([A-Za-z0-9_]+)\/logs\/moonraker\.log.*" local printer_data file
files=$(find "${HOME}" -maxdepth 3 -regextype posix-extended -regex "${regex}" | sort) for service in "${@}"; do
printer_data=$(get_data_folder ${service} moonraker)
if [[ -n ${files} ]]; then file="${HOME}/${printer_data}/systemd/moonraker.log"*
for file in ${files}; do status_msg "Removing ${file} ..."
status_msg "Removing ${file} ..." rm -f "${file}"
rm -f "${file}" ok_msg "${file} removed!"
ok_msg "${file} removed!" done
done
fi
} }
function remove_legacy_moonraker_logs() { function remove_legacy_moonraker_logs() {
@@ -558,14 +567,79 @@ function remove_moonraker_polkit() {
function remove_moonraker() { function remove_moonraker() {
remove_moonraker_sysvinit remove_moonraker_sysvinit
remove_moonraker_systemd
remove_moonraker_env_file local moonraker_services=$(moonraker_systemd)
remove_moonraker_logs if [[ -z ${moonraker_services} ]]; then
print_error "Moonraker not installed, nothing to do!"
return
fi
local moonraker_services_count="$(moonraker_systemd | wc -w)"
if (( moonraker_services_count == 1 )); then
echo hi
else
echo "Select Moonraker service to remove:"
echo " 0. Remove all"
local i=1 moonraker_names=() service_name
for name in ${moonraker_services}; do
service_name=$(basename ${name})
echo " ${i}. ${service_name}"
moonraker_names+=( "${service_name}" )
(( i=i+1 ))
done
while true; do
read -p "Select: " moonraker_count
if [[ $moonraker_count =~ ^[0-9]+$ ]]; then
break
else
error_msg "Invalid Input!"
fi
done
local user_input=()
if (( moonraker_count == 0 )); then
user_input=( ${moonraker_names[@]} )
else
user_input=( "${moonraker_names[(( moonraker_count-1 ))]}" )
fi
for i in ${user_input[@]}; do
select_msg "${i}"
done
### confirm instance amount
local yn
while true; do
(( moonraker_count == 0 )) && local question="Remove all Moonraker instances?"
[[ ${#user_input[@]} == 1 ]] && local question="Remove Moonraker $(basename ${user_input[0]}) instance?"
read -p "${cyan}###### ${question} (Y/n):${white} " yn
case "${yn}" in
Y|y|Yes|yes|"")
select_msg "Yes"
break;;
N|n|No|no)
select_msg "No"
abort_msg "Exiting Moonraker setup ...\n"
return;;
*)
error_msg "Invalid Input!";;
esac
done
fi
remove_moonraker_systemd "${user_input[@]}"
remove_moonraker_env_file "${user_input[@]}"
remove_moonraker_logs "${user_input[@]}"
remove_legacy_moonraker_logs remove_legacy_moonraker_logs
remove_moonraker_api_key
remove_moonraker_polkit if (( ${moonraker_services_count} == 1 || ${moonraker_count} == 0 )); then
remove_moonraker_dir remove_moonraker_api_key
remove_moonraker_env remove_moonraker_polkit
remove_moonraker_dir
remove_moonraker_env
fi
print_confirm "Moonraker was successfully removed!" print_confirm "Moonraker was successfully removed!"
return return