forked from mirrors/nixpkgs
Merge pull request #188273 from cab404/klipper-mutable-config
klipper: additional config options
This commit is contained in:
commit
3814271800
|
@ -35,6 +35,30 @@ in
|
||||||
description = lib.mdDoc "Path of the API socket to create.";
|
description = lib.mdDoc "Path of the API socket to create.";
|
||||||
};
|
};
|
||||||
|
|
||||||
|
mutableConfig = mkOption {
|
||||||
|
type = types.bool;
|
||||||
|
default = false;
|
||||||
|
example = true;
|
||||||
|
description = lib.mdDoc ''
|
||||||
|
Whether to copy the config to a mutable directory instead of using the one directly from the nix store.
|
||||||
|
This will only copy the config if the file at `services.klipper.mutableConfigPath` doesn't exist.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
mutableConfigFolder = mkOption {
|
||||||
|
type = types.path;
|
||||||
|
default = "/var/lib/klipper";
|
||||||
|
description = lib.mdDoc "Path to mutable Klipper config file.";
|
||||||
|
};
|
||||||
|
|
||||||
|
configFile = mkOption {
|
||||||
|
type = types.nullOr types.path;
|
||||||
|
default = null;
|
||||||
|
description = lib.mdDoc ''
|
||||||
|
Path to default Klipper config.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
octoprintIntegration = mkOption {
|
octoprintIntegration = mkOption {
|
||||||
type = types.bool;
|
type = types.bool;
|
||||||
default = false;
|
default = false;
|
||||||
|
@ -62,8 +86,8 @@ in
|
||||||
};
|
};
|
||||||
|
|
||||||
settings = mkOption {
|
settings = mkOption {
|
||||||
type = format.type;
|
type = types.nullOr format.type;
|
||||||
default = { };
|
default = null;
|
||||||
description = lib.mdDoc ''
|
description = lib.mdDoc ''
|
||||||
Configuration for Klipper. See the [documentation](https://www.klipper3d.org/Overview.html#configuration-and-tuning-guides)
|
Configuration for Klipper. See the [documentation](https://www.klipper3d.org/Overview.html#configuration-and-tuning-guides)
|
||||||
for supported values.
|
for supported values.
|
||||||
|
@ -80,6 +104,10 @@ in
|
||||||
building of firmware and addition of klipper-flash tools for manual flashing.
|
building of firmware and addition of klipper-flash tools for manual flashing.
|
||||||
This will add `klipper-flash-$mcu` scripts to your environment which can be called to flash the firmware.
|
This will add `klipper-flash-$mcu` scripts to your environment which can be called to flash the firmware.
|
||||||
'');
|
'');
|
||||||
|
serial = mkOption {
|
||||||
|
type = types.nullOr path;
|
||||||
|
description = lib.mdDoc "Path to serial port this printer is connected to. Leave `null` to derive it from `service.klipper.settings`.";
|
||||||
|
};
|
||||||
configFile = mkOption {
|
configFile = mkOption {
|
||||||
type = path;
|
type = path;
|
||||||
description = lib.mdDoc "Path to firmware config which is generated using `klipper-genconf`";
|
description = lib.mdDoc "Path to firmware config which is generated using `klipper-genconf`";
|
||||||
|
@ -95,19 +123,25 @@ in
|
||||||
assertions = [
|
assertions = [
|
||||||
{
|
{
|
||||||
assertion = cfg.octoprintIntegration -> config.services.octoprint.enable;
|
assertion = cfg.octoprintIntegration -> config.services.octoprint.enable;
|
||||||
message = "Option klipper.octoprintIntegration requires Octoprint to be enabled on this system. Please enable services.octoprint to use it.";
|
message = "Option services.klipper.octoprintIntegration requires Octoprint to be enabled on this system. Please enable services.octoprint to use it.";
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
assertion = cfg.user != null -> cfg.group != null;
|
assertion = cfg.user != null -> cfg.group != null;
|
||||||
message = "Option klipper.group is not set when a user is specified.";
|
message = "Option services.klipper.group is not set when services.klipper.user is specified.";
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
assertion = foldl (a: b: a && b) true (mapAttrsToList (mcu: _: mcu != null -> (hasAttrByPath [ "${mcu}" "serial" ] cfg.settings)) cfg.firmwares);
|
assertion = cfg.settings != null -> foldl (a: b: a && b) true (mapAttrsToList (mcu: _: mcu != null -> (hasAttrByPath [ "${mcu}" "serial" ] cfg.settings)) cfg.firmwares);
|
||||||
message = "Option klipper.settings.$mcu.serial must be set when klipper.firmware.$mcu is specified";
|
message = "Option services.klipper.settings.$mcu.serial must be set when settings.klipper.firmware.$mcu is specified";
|
||||||
|
}
|
||||||
|
{
|
||||||
|
assertion = (cfg.configFile != null) != (cfg.settings != null);
|
||||||
|
message = "You need to either specify services.klipper.settings or services.klipper.defaultConfig.";
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
environment.etc."klipper.cfg".source = format.generate "klipper.cfg" cfg.settings;
|
environment.etc = mkIf (!cfg.mutableConfig) {
|
||||||
|
"klipper.cfg".source = if cfg.settings != null then format.generate "klipper.cfg" cfg.settings else cfg.configFile;
|
||||||
|
};
|
||||||
|
|
||||||
services.klipper = mkIf cfg.octoprintIntegration {
|
services.klipper = mkIf cfg.octoprintIntegration {
|
||||||
user = config.services.octoprint.user;
|
user = config.services.octoprint.user;
|
||||||
|
@ -118,15 +152,34 @@ in
|
||||||
let
|
let
|
||||||
klippyArgs = "--input-tty=${cfg.inputTTY}"
|
klippyArgs = "--input-tty=${cfg.inputTTY}"
|
||||||
+ optionalString (cfg.apiSocket != null) " --api-server=${cfg.apiSocket}";
|
+ optionalString (cfg.apiSocket != null) " --api-server=${cfg.apiSocket}";
|
||||||
|
printerConfigPath =
|
||||||
|
if cfg.mutableConfig
|
||||||
|
then cfg.mutableConfigFolder + "/printer.cfg"
|
||||||
|
else "/etc/klipper.cfg";
|
||||||
|
printerConfigFile =
|
||||||
|
if cfg.settings != null
|
||||||
|
then format.generate "klipper.cfg" cfg.settings
|
||||||
|
else cfg.configFile;
|
||||||
in
|
in
|
||||||
{
|
{
|
||||||
description = "Klipper 3D Printer Firmware";
|
description = "Klipper 3D Printer Firmware";
|
||||||
wantedBy = [ "multi-user.target" ];
|
wantedBy = [ "multi-user.target" ];
|
||||||
after = [ "network.target" ];
|
after = [ "network.target" ];
|
||||||
|
preStart = ''
|
||||||
|
mkdir -p ${cfg.mutableConfigFolder}
|
||||||
|
${lib.optionalString (cfg.mutableConfig) ''
|
||||||
|
[ -e ${printerConfigPath} ] || {
|
||||||
|
cp ${printerConfigFile} ${printerConfigPath}
|
||||||
|
chmod +w ${printerConfigPath}
|
||||||
|
}
|
||||||
|
''}
|
||||||
|
mkdir -p ${cfg.mutableConfigFolder}/gcodes
|
||||||
|
'';
|
||||||
|
|
||||||
serviceConfig = {
|
serviceConfig = {
|
||||||
ExecStart = "${cfg.package}/lib/klipper/klippy.py ${klippyArgs} /etc/klipper.cfg";
|
ExecStart = "${cfg.package}/lib/klipper/klippy.py ${klippyArgs} ${printerConfigPath}";
|
||||||
RuntimeDirectory = "klipper";
|
RuntimeDirectory = "klipper";
|
||||||
|
StateDirectory = "klipper";
|
||||||
SupplementaryGroups = [ "dialout" ];
|
SupplementaryGroups = [ "dialout" ];
|
||||||
WorkingDirectory = "${cfg.package}/lib";
|
WorkingDirectory = "${cfg.package}/lib";
|
||||||
OOMScoreAdjust = "-999";
|
OOMScoreAdjust = "-999";
|
||||||
|
@ -134,6 +187,7 @@ in
|
||||||
CPUSchedulingPriority = 99;
|
CPUSchedulingPriority = 99;
|
||||||
IOSchedulingClass = "realtime";
|
IOSchedulingClass = "realtime";
|
||||||
IOSchedulingPriority = 0;
|
IOSchedulingPriority = 0;
|
||||||
|
UMask = "0002";
|
||||||
} // (if cfg.user != null then {
|
} // (if cfg.user != null then {
|
||||||
Group = cfg.group;
|
Group = cfg.group;
|
||||||
User = cfg.user;
|
User = cfg.user;
|
||||||
|
@ -146,8 +200,9 @@ in
|
||||||
environment.systemPackages =
|
environment.systemPackages =
|
||||||
with pkgs;
|
with pkgs;
|
||||||
let
|
let
|
||||||
|
default = a: b: if a != null then a else b;
|
||||||
firmwares = filterAttrs (n: v: v!= null) (mapAttrs
|
firmwares = filterAttrs (n: v: v!= null) (mapAttrs
|
||||||
(mcu: { enable, configFile }: if enable then pkgs.klipper-firmware.override {
|
(mcu: { enable, configFile, serial }: if enable then pkgs.klipper-firmware.override {
|
||||||
mcu = lib.strings.sanitizeDerivationName mcu;
|
mcu = lib.strings.sanitizeDerivationName mcu;
|
||||||
firmwareConfig = configFile;
|
firmwareConfig = configFile;
|
||||||
} else null)
|
} else null)
|
||||||
|
@ -156,11 +211,14 @@ in
|
||||||
(mcu: firmware: pkgs.klipper-flash.override {
|
(mcu: firmware: pkgs.klipper-flash.override {
|
||||||
mcu = lib.strings.sanitizeDerivationName mcu;
|
mcu = lib.strings.sanitizeDerivationName mcu;
|
||||||
klipper-firmware = firmware;
|
klipper-firmware = firmware;
|
||||||
flashDevice = cfg.settings."${mcu}".serial;
|
flashDevice = default cfg.firmwares."${mcu}".serial cfg.settings."${mcu}".serial;
|
||||||
firmwareConfig = cfg.firmwares."${mcu}".configFile;
|
firmwareConfig = cfg.firmwares."${mcu}".configFile;
|
||||||
})
|
})
|
||||||
firmwares;
|
firmwares;
|
||||||
in
|
in
|
||||||
[ klipper-genconf ] ++ firmwareFlasher ++ attrValues firmwares;
|
[ klipper-genconf ] ++ firmwareFlasher ++ attrValues firmwares;
|
||||||
};
|
};
|
||||||
|
meta.maintainers = [
|
||||||
|
maintainers.cab404
|
||||||
|
];
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue