install_moonraker(){ system_check_moonraker #ask user for customization get_user_selections_moonraker #disable/remove haproxy/lighttpd handle_haproxy_lighttpd #moonraker main installation moonraker_setup check_for_folder_moonraker #setup configs setup_printer_config_moonraker setup_moonraker_conf #execute customizations write_custom_trusted_clients symlinks_moonraker disable_octoprint #after install actions restart_moonraker restart_klipper #test_api } system_check_moonraker(){ status_msg "Initializing Moonraker installation ..." #check for existing printer.cfg and for the location locate_printer_cfg if [ -f $PRINTER_CFG ]; then PRINTER_CFG_FOUND="true" PRINTER_CFG_LOC=$PRINTER_CFG else PRINTER_CFG_FOUND="false" fi #check for existing klippy.log symlink in /klipper_config [ ! -e ${HOME}/klipper_config/klippy.log ] && KLIPPY_SL_FOUND="false" #check for existing moonraker.log symlink in /klipper_config [ ! -e ${HOME}/klipper_config/moonraker.log ] && MOONRAKER_SL_FOUND="false" #check for existing moonraker.conf if [ ! -f ${HOME}/moonraker.conf ]; then MOONRAKER_CONF_FOUND="false" else MOONRAKER_CONF_FOUND="true" fi #check if octoprint is installed if systemctl is-enabled octoprint.service -q 2>/dev/null; then unset OCTOPRINT_ENABLED OCTOPRINT_ENABLED="true" fi #check if haproxy is installed if [[ $(dpkg-query -f'${Status}' --show haproxy 2>/dev/null) = *\ installed ]]; then HAPROXY_FOUND="true" fi #check if lighttpd is installed if [[ $(dpkg-query -f'${Status}' --show lighttpd 2>/dev/null) = *\ installed ]]; then LIGHTTPD_FOUND="true" fi } get_user_selections_moonraker(){ #user selection for printer.cfg if [ "$PRINTER_CFG_FOUND" = "false" ]; then while true; do echo top_border echo -e "| ${red}WARNING! - No printer.cfg was found!${default} |" hr echo -e "| KIAUH can create a minimal printer.cfg with only the |" echo -e "| necessary Mainsail config entries if you wish. |" echo -e "| |" echo -e "| Please be aware, that this option will ${red}NOT${default} create a |" echo -e "| fully working printer.cfg for you! |" bottom_border read -p "${cyan}###### Create a default printer.cfg? (Y/n):${default} " yn case "$yn" in Y|y|Yes|yes|"") echo -e "###### > Yes" SEL_DEF_CFG="true" break;; N|n|No|no) echo -e "###### > No" SEL_DEF_CFG="false" break;; *) print_unkown_cmd print_msg && clear_msg;; esac done fi #user selection for moonraker.log symlink if [ "$KLIPPY_SL_FOUND" = "false" ]; then while true; do echo read -p "${cyan}###### Create klippy.log symlink? (y/N):${default} " yn case "$yn" in Y|y|Yes|yes) echo -e "###### > Yes" SEL_KLIPPYLOG_SL="true" break;; N|n|No|no|"") echo -e "###### > No" SEL_KLIPPYLOG_SL="false" break;; *) print_unkown_cmd print_msg && clear_msg;; esac done fi #user selection for moonraker.log symlink if [ "$MOONRAKER_SL_FOUND" = "false" ]; then while true; do echo read -p "${cyan}###### Create moonraker.log symlink? (y/N):${default} " yn case "$yn" in Y|y|Yes|yes) echo -e "###### > Yes" SEL_MRLOG_SL="true" break;; N|n|No|no|"") echo -e "###### > No" SEL_MRLOG_SL="false" break;; *) print_unkown_cmd print_msg && clear_msg;; esac done fi #ask user for more trusted clients while true; do echo top_border echo -e "| Apart from devices of your local network, you can add |" echo -e "| additional trusted clients to the moonraker.conf file |" bottom_border read -p "${cyan}###### Add additional trusted clients? (y/N):${default} " yn case "$yn" in Y|y|Yes|yes) echo -e "###### > Yes" ADD_TRUSTED_CLIENT="true" custom_trusted_clients break;; N|n|No|no|"") echo -e "###### > No" ADD_TRUSTED_CLIENT="false" break;; *) print_unkown_cmd print_msg && clear_msg;; esac done #ask user to disable octoprint when such installed service was found if [ "$OCTOPRINT_ENABLED" = "true" ]; then unset DISABLE_OPRINT while true; do echo warn_msg "OctoPrint service found!" echo -e "You might consider disabling the OctoPrint service," echo -e "since an active OctoPrint service may lead to unexpected" echo -e "behavior of the Mainsail Webinterface." read -p "${cyan}###### Do you want to disable OctoPrint now? (Y/n):${default} " yn case "$yn" in Y|y|Yes|yes|"") echo -e "###### > Yes" DISABLE_OPRINT="true" break;; N|n|No|no) echo -e "###### > No" DISABLE_OPRINT="false" break;; *) print_unkown_cmd print_msg && clear_msg;; esac done fi #notify user about haproxy or lighttpd services found and possible issues if [ "$HAPROXY_FOUND" = "true" ] || [ "$LIGHTTPD_FOUND" = "true" ]; then while true; do echo top_border echo -e "| ${red}Possibly disruptive/incompatible services found!${default} |" hr if [ "$HAPROXY_FOUND" = "true" ]; then echo -e "| ● haproxy |" fi if [ "$LIGHTTPD_FOUND" = "true" ]; then echo -e "| ● lighttpd |" fi hr echo -e "| Having those packages installed can lead to unwanted |" echo -e "| behaviour. It is recommend to remove those packages. |" echo -e "| |" echo -e "| 1) Remove packages (recommend) |" echo -e "| 2) Disable only (may cause issues) |" echo -e "| ${red}3) Skip this step (not recommended)${default} |" bottom_border read -p "${cyan}###### Please choose:${default} " action case "$action" in 1) echo -e "###### > Remove packages" if [ "$HAPROXY_FOUND" = "true" ]; then DISABLE_HAPROXY="false" REMOVE_HAPROXY="true" fi if [ "$LIGHTTPD_FOUND" = "true" ]; then DISABLE_LIGHTTPD="false" REMOVE_LIGHTTPD="true" fi break;; 2) echo -e "###### > Disable only" if [ "$HAPROXY_FOUND" = "true" ]; then DISABLE_HAPROXY="true" REMOVE_HAPROXY="false" fi if [ "$LIGHTTPD_FOUND" = "true" ]; then DISABLE_LIGHTTPD="true" REMOVE_LIGHTTPD="false" fi break;; 3) echo -e "###### > Skip" DISABLE_LIGHTTPD="false" REMOVE_LIGHTTPD="false" DISABLE_HAPROXY="false" REMOVE_HAPROXY="false" break;; *) print_unkown_cmd print_msg && clear_msg;; esac done fi status_msg "Installation will start now! Please wait ..." } ############################################################# ############################################################# moonraker_setup(){ dep=(wget curl unzip dfu-util nginx) dependency_check status_msg "Downloading Moonraker ..." cd ${HOME} && git clone $MOONRAKER_REPO ok_msg "Download complete!" status_msg "Installing Moonraker ..." $MOONRAKER_DIR/scripts/install-moonraker.sh #copy moonraker configuration for nginx to /etc/nginx/conf.d setup_moonraker_nginx_cfg #backup a possible existing printer.cfg at the old location #and before patching in the new location backup_printer_cfg patch_klipper_sysfile "moonraker" #re-run printer.cfg location function to read the new path for the printer.cfg locate_printer_cfg echo; ok_msg "Moonraker successfully installed!" } patch_klipper_sysfile(){ if [ -e $KLIPPER_SERVICE2 ]; then status_msg "Checking /etc/default/klipper for necessary entries ..." #patching new printer.cfg location to /etc/default/klipper if [ "$1" = "moonraker" ]; then if ! grep -q "/klipper_config/printer.cfg" $KLIPPER_SERVICE2; then status_msg "Patching new printer.cfg location to /etc/default/klipper ..." sudo sed -i "/KLIPPY_ARGS=/ s|$PRINTER_CFG|/home/${USER}/klipper_config/printer.cfg|" $KLIPPER_SERVICE2 ok_msg "New location is: '/home/${USER}/klipper_config/printer.cfg'" fi fi #patching new UDS argument to /etc/default/klipper if [ "$1" = "moonraker" ] || [ "$1" = "dwc2" ]; then if ! grep -q -- "-a /tmp/klippy_uds" $KLIPPER_SERVICE2; then status_msg "Patching unix domain socket to /etc/default/klipper ..." #append the new argument to /tmp/klippy.log argument sudo sed -i "/KLIPPY_ARGS/s/\.log/\.log -a \/tmp\/klippy_uds/" $KLIPPER_SERVICE2 ok_msg "Patching done!" fi fi fi if [ -e $KLIPPER_SERVICE3 ]; then status_msg "Checking /etc/systemd/system/klipper.service for necessary entries ..." #patching new printer.cfg location to /etc/systemd/system/klipper.service if [ "$1" = "moonraker" ]; then if ! grep -q "/klipper_config/printer.cfg" $KLIPPER_SERVICE3; then status_msg "Patching new printer.cfg location to /etc/systemd/system/klipper.service ..." sudo sed -i "/ExecStart=/ s|$PRINTER_CFG|/home/${USER}/klipper_config/printer.cfg|" $KLIPPER_SERVICE3 ok_msg "New location is: '/home/${USER}/klipper_config/printer.cfg'" #set variable if file got edited SERVICE_FILE_PATCHED="true" fi fi #patching new UDS argument to /etc/systemd/system/klipper.service if [ "$1" = "moonraker" ] || [ "$1" = "dwc2" ]; then if ! grep -q -- "-a /tmp/klippy_uds" $KLIPPER_SERVICE3; then status_msg "Patching unix domain socket to /etc/systemd/system/klipper.service ..." #append the new argument to /tmp/klippy.log argument sudo sed -i "/ExecStart/s/\.log/\.log -a \/tmp\/klippy_uds/" $KLIPPER_SERVICE3 ok_msg "Patching done!" #set variable if file got edited SERVICE_FILE_PATCHED="true" fi fi #reloading the units is only needed when the service file was patched. [ "$SERVICE_FILE_PATCHED" = "true" ] && status_msg "Reloading unit ..." && sudo systemctl daemon-reload fi ok_msg "Check complete!" echo } check_for_folder_moonraker(){ #check for / create sdcard folder if [ ! -d ${HOME}/sdcard ]; then status_msg "Creating sdcard directory ..." mkdir ${HOME}/sdcard ok_msg "sdcard directory created!" fi ##check for / create klipper_config folder if [ ! -d ${HOME}/klipper_config ]; then status_msg "Creating klipper_config directory ..." mkdir ${HOME}/klipper_config ok_msg "klipper_config directory created!" fi } ############################################################# ############################################################# setup_printer_config_moonraker(){ if [ "$PRINTER_CFG_FOUND" = "true" ]; then #copy printer.cfg to new location if there is no printer.cfg at the new location already if [ -f ${HOME}/printer.cfg ] && [ ! -f ${HOME}/klipper_config/printer.cfg ]; then status_msg "Copy printer.cfg to new location ..." cp ${HOME}/printer.cfg $PRINTER_CFG ok_msg "printer.cfg location: '$PRINTER_CFG'" ok_msg "Done!" fi #check printer.cfg for necessary moonraker entries read_printer_cfg "moonraker" && write_printer_cfg fi if [ "$SEL_DEF_CFG" = "true" ]; then status_msg "Creating minimal default printer.cfg ..." create_minimal_cfg ok_msg "printer.cfg location: '$PRINTER_CFG'" ok_msg "Done!" fi } setup_moonraker_conf(){ if [ "$MOONRAKER_CONF_FOUND" = "false" ]; then status_msg "Creating moonraker.conf ..." cp ${HOME}/kiauh/resources/moonraker.conf ${HOME} ok_msg "moonraker.conf created!" status_msg "Writing trusted clients to config ..." write_default_trusted_clients ok_msg "Trusted clients written!" fi #check for at least one trusted client in an already existing moonraker.conf #in no entry is found, write default trusted client if [ "$MOONRAKER_CONF_FOUND" = "true" ]; then if grep "trusted_clients:" ${HOME}/moonraker.conf -q; then TC_LINE=$(grep -n "trusted_clients:" ${HOME}/moonraker.conf | cut -d ":" -f1) FIRST_IP_LINE=$(expr $TC_LINE + 1) FIRST_IP=$(sed -n "$FIRST_IP_LINE"p ${HOME}/moonraker.conf | cut -d" " -f5) #if [[ ! $FIRST_IP =~ ([0-9].[0-9].[0-9].[0-9]) ]]; then if [ "$FIRST_IP" = "" ]; then status_msg "Writing trusted clients to config ..." backup_moonraker_conf && write_default_trusted_clients ok_msg "Trusted clients written!" fi fi fi } setup_moonraker_nginx_cfg(){ if [ ! -f $NGINX_CONFD/upstreams.conf ]; then sudo cp ${SRCDIR}/kiauh/resources/moonraker_nginx.cfg $NGINX_CONFD/upstreams.conf fi if [ ! -f $NGINX_CONFD/common_vars.conf ]; then sudo cp ${SRCDIR}/kiauh/resources/common_vars_nginx.cfg $NGINX_CONFD/common_vars.conf fi } ############################################################# ############################################################# write_default_trusted_clients(){ DEFAULT_IP=$(hostname -I) status_msg "Your devices current IP adress is:\n${cyan}● $DEFAULT_IP ${default}" #make IP of the device KIAUH is exectuted on as #default trusted client and expand the IP range from 0 - 255 DEFAULT_IP_RANGE="$(echo "$DEFAULT_IP" | cut -d"." -f1-3).0/24" status_msg "Writing the following IP range to moonraker.conf:\n${cyan}● $DEFAULT_IP_RANGE ${default}" #write the ip range in the first line below "trusted clients" #example: 192.168.1.0/24 sed -i "/trusted_clients\:/a \ \ \ \ $DEFAULT_IP_RANGE" ${HOME}/moonraker.conf ok_msg "IP range of ● $DEFAULT_IP_RANGE written to moonraker.conf!" } ############################################################# ############################################################# custom_trusted_clients(){ if [ "$ADD_TRUSTED_CLIENT" = "true" ]; then unset trusted_arr echo top_border echo -e "| You can now add additional trusted clients to your |" echo -e "| moonraker.conf file. Be warned, that there is no |" echo -e "| spellcheck to check for valid input. |" echo -e "| Make sure to type the IP correct! |" echo -e "| |" echo -e "| If you want to add IP ranges, you can type in e.g.: |" echo -e "| 192.168.1.0/24 |" echo -e "| This will add the IPs 192.168.1.1 to 192.168.1.254 |" echo -e "|-------------------------------------------------------|" echo -e "| You can add as many IPs / IP ranges as you want. |" echo -e "| When you are done type '${cyan}done${default}' to exit this dialoge. |" bottom_border while true; do read -p "${cyan}###### Enter IP and press ENTER:${default} " TRUSTED_IP case "$TRUSTED_IP" in done) echo echo -e "List of IPs to add:" for ip in ${trusted_arr[@]} do echo -e "${cyan}● $ip ${default}" done while true; do echo echo -e "Select 'Yes' to confirm, 'No' to start again" echo -e "or 'Q' to abort and skip." read -p "${cyan}###### Confirm writing (Y/n/q):${default} " yn case "$yn" in Y|y|Yes|yes|"") echo -e "###### > Yes" TUSTED_CLIENT_CONFIRM="true" break;; N|n|No|no) echo -e "###### > No" custom_trusted_clients break;; Q|q) unset trusted_arr echo -e "###### > Abort" echo -e "${red}Aborting ...${default}" break;; esac done break;; *) trusted_arr+=($TRUSTED_IP);; esac done fi } write_custom_trusted_clients(){ if [ "$TUSTED_CLIENT_CONFIRM" = "true" ]; then if [ "${#trusted_arr[@]}" != "0" ]; then for ip in ${trusted_arr[@]} do sed -i "/trusted_clients\:/a \ \ \ \ $ip" ${HOME}/moonraker.conf done ok_msg "Custom IPs written to moonraker.conf!" fi fi } symlinks_moonraker(){ #create a klippy.log/moonraker.log symlink in #klipper_config-dir just for convenience if [ "$SEL_KLIPPYLOG_SL" = "true" ] && [ ! -e ${HOME}/klipper_config/klippy.log ]; then status_msg "Creating klippy.log symlink ..." ln -s /tmp/klippy.log ${HOME}/klipper_config ok_msg "Symlink created!" fi if [ "$SEL_MRLOG_SL" = "true" ] && [ ! -e ${HOME}/klipper_config/moonraker.log ]; then status_msg "Creating moonraker.log symlink ..." ln -s /tmp/moonraker.log ${HOME}/klipper_config ok_msg "Symlink created!" fi } handle_haproxy_lighttpd(){ #handle haproxy if [ "$DISABLE_HAPROXY" = "true" ]; then if systemctl is-active haproxy -q; then status_msg "Stopping haproxy service ..." sudo /etc/init.d/haproxy stop && ok_msg "Service stopped!" fi sudo systemctl disable haproxy ok_msg "Haproxy service disabled!" else if [ "$REMOVE_HAPROXY" = "true" ]; then if systemctl is-active haproxy -q; then status_msg "Stopping haproxy service ..." sudo /etc/init.d/haproxy stop && ok_msg "Service stopped!" fi status_msg "Removing haproxy ..." sudo apt-get remove haproxy -y sudo update-rc.d -f haproxy remove ok_msg "Haproxy removed!" fi fi #handle lighttpd if [ "$DISABLE_LIGHTTPD" = "true" ]; then if systemctl is-active lighttpd -q; then status_msg "Stopping lighttpd service ..." sudo /etc/init.d/lighttpd stop && ok_msg "Service stopped!" fi sudo systemctl disable lighttpd ok_msg "Lighttpd service disabled!" else if [ "$REMOVE_LIGHTTPD" = "true" ]; then if systemctl is-active lighttpd -q; then status_msg "Stopping lighttpd service ..." sudo /etc/init.d/lighttpd stop && ok_msg "Service stopped!" fi status_msg "Removing lighttpd ..." sudo apt-get remove lighttpd -y sudo update-rc.d -f lighttpd remove ok_msg "Lighttpd removed!" fi fi }