# This document describes Moonraker's full configuration. As this file references configuration for both Klipper (`printer.cfg`) and Moonraker (`moonraker.conf`), each example contains a commment indicating which configuration file is being refrenenced. A basic [sample configuration](./moonraker.conf) in the `docs` directory. ## `[server]` The `[server]` section provides essential configuration for Moonraker and its core components. This section is requrired. ```ini # moonraker.conf [server] host: 0.0.0.0 # The host address in which to bind the HTTP server. Default is to bind # to all interfaces port: 7125 # The port the HTTP server will listen on. Default is 7125 klippy_uds_address: /tmp/klippy_uds # The address of Unix Domain Socket used to communicate with Klippy. Default # is /tmp/klippy_uds max_upload_size: 1024 # The maximum size allowed for a file upload (in MiB). Default is 1024 MiB. enable_debug_logging: False # When set to True Moonraker will log in verbose mode. During this stage # of development the default is False. config_path: # The path to a directory where configuration files are located. This # directory may contain Klipper config files (printer.cfg) or Moonraker # config files (moonraker.conf). Clients may also write their own config # files to this directory. Note that this may not be the system root # (ie: "/") and moonraker must have read and write access permissions # for this directory. database_path: ~/.moonraker_database # The path to the folder that stores Moonraker's lmdb database files. # It is NOT recommended to place this file in a location that is served by # Moonraker (such as the "config_path" or the location where gcode # files are stored). If the folder does not exist an attempt will be made # to create it. The default is ~/.moonraker_database. log_path: # An optional path to a directory where log files are located. Users may # configure various applications to store logs here and Moonraker will serve # them at "/server/files/logs/*". The default is no log paths. enable_database_debug: False # For developer use only. End users should leave this option set to False. temperature_store_size: 1200 # The maximum number of temperature values to store for each sensor. Note # that this value also applies to the "target", "power", and "fan_speed" # if the sensor reports them. The default is 1200, which is enough to # store approximately 20 minutes of data at one value per second. gcode_store_size: 1000 # The maximum number "gcode lines" to store. The default is 1000. ``` ## `[authorization]` The `[authorization]` section provides configuration for Moonraker's authorization module. ```ini # moonraker.conf [authorization] login_timeout: # The time, in days, after which a user is forced to re-enter their # credentials to log in. This period begins when a logged out user # first logs in. Successive logins without logging out will not # renew the timeout. The default is 90 days. trusted_clients: 192.168.1.30 192.168.1.0/24 my-printer.lan # A list of newline separated ip addresses, ip ranges, or fully qualified # domain names that are trusted. Trusted clients are given full access to # the API. Both IPv4 and IPv6 addresses and ranges are supported. Ranges # must be expressed in CIDR notation (see http://ip.sb/cidr for more info). # For example, an entry of 192.168.1.0/24 will authorize IPs in the range of # 192.168.1.1 - 192.168.1.254. Note that when specifying IPv4 ranges the # last segment of the ip address must be 0. The default is no clients are # trusted. cors_domains: http://klipper-printer.local http://second-printer.local:7125 # Enables CORS for the specified domains. One may specify * if they wish # to allow all domains, however this should be an option reserved for # client developers and not used in production. A * can also be used # to specify a wildcard that matches several domains. For example: # *.local # http://*.my-domain.com # *.my-domain.com:* # Are all valid entries. However, a wildcard may not be specified in # the top level domain: # http://my-printer.* # The above example will be rejected. # When CORS is enabled by adding an entry to this option, all origins # matching the "trusted_clients" option will have CORS headers set as # well. If this option is not specified then CORS is disabled. force_logins: False # When set to True a user login is required for authorization if at least # one user has been created, overriding the "trusted_clients" configuration. # If no users have been created then trusted client checks will apply. # The default is False. ``` ## `[octoprint_compat]` Enables partial support of Octoprint API is implemented with the purpose of allowing uploading of sliced prints to a moonraker instance. Currently we support Slic3r derivatives and Cura with Cura-Octoprint. ```ini # moonraker.conf [octoprint_compat] ``` ## `[history]` Enables print history tracking. ```ini # moonraker.conf [history] ``` ## `[paneldue]` Enables PanelDue display support. The PanelDue should be connected to the host machine, either via the machine's UART GPIOs or through a USB-TTL converter. Currently PanelDue Firmware Version 1.24 is supported. Other releases may not behave correctly. ```ini # moonraker.conf [paneldue] serial: # The serial port in which the PanelDue is connected. This parameter # must be provided. baud: 57600 # The baud rate to connect at. The default is 57600 baud. machine_name: Klipper # An optional unique machine name which displays on the PanelDue's # Header. The default is "Klipper". macros: LOAD_FILAMENT UNLOAD_FILAMENT PANELDUE_BEEP FREQUENCY=500 DURATION=1 # A list of newline separated "macros" that are displayed in the # PanelDue's "macros" tab. These can be gcode macros or simple # gcodes. A macro may contain parameters. The default is no # macros will be displayed by the PanelDue. confirmed_macros: RESTART FIRMWARE_RESTART # Like the "macros" option, this list is added to the macros tab. # When one of these macros is excuted the PanelDue will prompt # the user with a confirmation dialog. The default is to include # RESTART and FIRMWARE_RESTART. ``` Most options above are self explanatory. The "macros" option can be used to specify commands (either built in or gcode_macros) that will show up in the PanelDue's "macro" menu. Note that buzzing the piezo requires the following gcode_macro in `printer.cfg`: ```ini # printer.cfg [gcode_macro PANELDUE_BEEP] # Beep frequency default_parameter_FREQUENCY: 300 # Beep duration in seconds default_parameter_DURATION: 1. gcode: {action_call_remote_method("paneldue_beep", frequency=FREQUENCY|int, duration=DURATION|float)} ``` ## `[power]` Enables device power control. Currently GPIO (relays), TPLink Smartplug, and Tasmota (via http) devices, HomeAssistant switch are supported. ```ini # moonraker.conf [power device_name] type: gpio # The type of device. Can be either gpio, tplink_smartplug, tasmota # shelly, homeseer, homeassistant, or loxonev1. # This parameter must be provided. off_when_shutdown: False # If set to True the device will be powered off when Klipper enters # the "shutdown" state. This option applies to all device types. # The default is False. locked_while_printing: False # If True, locks the device so that the power cannot be changed while the # printer is printing. This is useful to avert an accidental shutdown to # the printer's power. The default is False. restart_klipper_when_powered: False # If set to True, Moonraker will issue a "FIRMWARE_RESTART" to Klipper # after the device has been powered on. The default is False, thus no # attempt to made to restart Klipper after power on. restart_delay: 1. # If "restart_klipper_when_powered" is set, this option specifies the amount # of time (in seconds) to delay the restart. Default is 1 second. pin: gpiochip0/gpio26 # The pin to use for GPIO devices. The chip is optional, if left out # then the module will default to gpiochip0. If one wishes to invert # the signal, a "!" may be prefixed to the pin. Valid examples: # gpiochip0/gpio26 # gpio26 # !gpiochip0/gpio26 # !gpio26 # This parameter must be provided for "gpio" type devices initial_state: off # The initial state for GPIO type devices. May be on or # off. When moonraker starts the device will be set to this # state. Default is off. address: port: # The above options are used for "tplink_smartplug" devices. The # address should be a valid ip or hostname for the tplink device. # The port should be the port the device is configured to use. # "Power Strips" can be controlled by including the socket index # in the ip address. For example, to control socket index 1: # 192.168.1.127/1 # The address must be provided. The port defaults to 9999. address: password: output_id: timer: # The above options are used for "tasmota" devices. The # address should be a valid ip or hostname for the tasmota device. # Provide a password if configured in Tasmota (default is empty). # Provided an output_id (relay id) if the Tasmota device supports # more than one (default is 1). # If your single-relay Tasmota device switches on/off successfully, # but fails to report its state, ensure that 'SetOption26' is set in # Tasmota. address: user: password: output_id: timer: # The above options are used for "shelly" devices. The # address should be a valid ip or hostname for the Shelly device. # Provide a user and password if configured in Shelly (default is empty). # If password is set but user is empty the default user "admin" will be used # Provided an output_id (relay id) if the Shelly device supports # more than one (default is 0). When timer option is used to delay the turn # off make sure to set the state to "on" in action call_remote_method. # So we send a command to turn it on for x sec when its already on then # it turns off. address: device: user: password: # The above options are used for "homeseer" devices. The # address should be a valid ip or hostname for the homeseer controller. # "device" should be the ID of the device to control. # To find out the ID, in the HomeSeer UI, click on the device you want to # control (Make sure to click the sub-device that actually has On/Off # buttons). And then go to the "status/graphics" tab and it should list # "ID" in the "advanced information" section. # Provide a user and password with access to "device control" # and at least the specific device you want to control address: port: device: token: # The above options are used for "homeassistant" devices. The # address should be a valid ip or hostname for the homeassistant controller. # "device" should be the ID of the switch to control. address: user: password: output_id: # The above options are used for "loxone smart home miniserver v1 " devices. # The address should be a valid ip or hostname for the loxone miniserver v1 # device. All entries must be configured in advance in the loxone config. # Provide a user and password configured in loxone config. # The output_id is the name of a programmed output, virtual input or virtual # output in the loxone config his output_id (name) may only be used once in # the loxone config ``` Below are some potential examples: ```ini # moonraker.conf [power printer] type: gpio pin: gpio26 off_when_shutdown: True initial_state: off [power printer_led] type: gpio pin: !gpiochip0/gpio16 initial_state: off [power light_strip] type: gpio pin: gpiochip0/gpio17 initial_state: on [power wifi_switch] type: tplink_smartplug address: 192.168.1.123 [power tasmota_plug] type: tasmota address: 192.168.1.124 password: password1 [power shelly_plug] type: shelly address: 192.168.1.125 user: user2 password: password2 [power homeassistant_switch] type: homeassistant address: 192.168.1.126 port: 8123 device: switch.1234567890abcdefghij token: home-assistant-very-long-token ``` It is possible to toggle device power from the Klippy host, this can be done with a gcode_macro, such as: ```ini # printer.cfg [gcode_macro POWER_OFF_PRINTER] gcode: {action_call_remote_method("set_device_power", device="printer", state="off")} ``` The `POWER_OFF_PRINTER` gcode can be run to turn off the "printer" device. This could be used in conjunction with Klipper's idle timeout to turn the printer off when idle with a configuration similar to that of below: ```ini # printer.cfg [delayed_gcode delayed_printer_off] initial_duration: 0. gcode: {% if printer.idle_timeout.state == "Idle" %} POWER_OFF_PRINTER {% endif %} [idle_timeout] gcode: TURN_OFF_MOTORS TURN_OFF_HEATERS UPDATE_DELAYED_GCODE ID=delayed_printer_off DURATION=60 ``` ## `[update_manager]` This enables moonraker's update manager. Note that updates can only be performed on pristine git repos. Repos that have been modified on disk or cloned from unofficial sources are not supported. ```ini # moonraker.conf [update_manager] enable_repo_debug: False # When set to True moonraker will bypass repo validation and allow # updates from unofficial remotes and/or branches. Updates on # detached repos are also allowed. This option is intended for # developers and should not be used on production machines. The # default is False. enable_auto_refresh: False # When set to True Moonraker will attempt to fetch status about # available updates roughly every 24 hours, between 12am-4am. # When set to False Moonraker will only fetch update state on startup # and clients will need to request that Moonraker updates state. The # default is False. distro: debian # The disto in which moonraker has been installed. Currently the # update manager only supports "debian", which encompasses all of # its derivatives. The default is debain. ``` ### Client Configuration This allows client programs such as Fluidd, KlipperScreen, and Mainsail to be updated in addition to klipper, moonraker, and the system os. Repos that have been modified or cloned from unofficial sources are not supported. There are two types of update manager clients and each will be detailed separately. The first one is targeted towards releases that do not need a service restart such as Fluidd/Mainsail. ```ini # moonraker.conf [update_manager client client_name] type: web repo: # This is the GitHub repo of the client, in the format of user/client. # For example, this could be set to cadriel/fluidd to update Fluidd or # meteyou/mainsail to update Mainsail. This parameter must be provided. path: # The path to the client's files on disk. This parameter must be provided. persistent_files: # A list of newline separated file names that should persist between # updates. This is useful for static configuration files, or perhaps # themes. The default is no persistent files. ``` This second example is for git repositories that have a service that need updating. ```ini # moonraker.conf # service_name must be the name of the systemd service [update_manager client service_name] type: git_repo path: # The absolute path to the client's files on disk. This parameter must be provided. # Example: # path: ~/service_name origin: # The full GitHub URL of the "origin" remote for the repository. This can # be be viewed by navigating to your repository and running: # git remote -v # This parameter must be provided. primary_branch: # The name of the primary branch used for release code on this repo. This # option allows clients to specify 'main', or their own unique name, as # the branch used for repo validity checks. The default is master. env: # The path to the client's virtual environment executable on disk. For # example, Moonraker's venv is located at ~/moonraker-env/bin/python. # The default is no env, which disables updating python packages. requirements: # This is the location in the repository to the client's virtual environment # requirements file. This location is relative to the root of the repository. # This parameter must be provided if the "env" option is set, otherwise it # should be omitted. install_script: # The file location, relative to the repository, for the installation script. # The update manager parses this file for "system" packages that need updating. # The default is no install script, which disables system package updates enable_node_updates: # When set to True, Moonraker will asssume that this repo relies upon node # and will attempt to execute "npm ci --only=prod" when it detects a change # to package-lock.json. Note that if your project does not have a # package-lock.json in its root directory then the plugin will fail to load. # Default is False. ```