summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorMichael Hoang <Enzime@users.noreply.github.com>2024-10-25 13:01:10 +1100
committerGitHub <noreply@github.com>2024-10-25 13:01:10 +1100
commit8c675759e94b243c45ac9c080c7af286da9a08c6 (patch)
tree8c5703c4f9c0cf4aeb877e7e3b9eb8c1aef6979a /modules
parent04193f188e4144d7047f83ad1de81d6034d175cd (diff)
parentf737259769ef4722ed956bcaaab67509b96c23cc (diff)
Merge pull request #813 from PhilipBorgesen/power-related-options
Power related options (sleep, wake-on-lan, restart after power failure, ...)
Diffstat (limited to 'modules')
-rw-r--r--modules/module-list.nix2
-rw-r--r--modules/networking/default.nix16
-rw-r--r--modules/power/default.nix47
-rw-r--r--modules/power/sleep.nix80
-rw-r--r--modules/system/activation-scripts.nix1
5 files changed, 146 insertions, 0 deletions
diff --git a/modules/module-list.nix b/modules/module-list.nix
index 6604eb9..effdff7 100644
--- a/modules/module-list.nix
+++ b/modules/module-list.nix
@@ -51,6 +51,8 @@
./environment
./fonts
./launchd
+ ./power
+ ./power/sleep.nix
./services/activate-system
./services/aerospace
./services/autossh.nix
diff --git a/modules/networking/default.nix b/modules/networking/default.nix
index 099c705..b53a9e4 100644
--- a/modules/networking/default.nix
+++ b/modules/networking/default.nix
@@ -9,6 +9,8 @@ let
emptyList = lst: if lst != [] then lst else ["empty"];
+ onOff = cond: if cond then "on" else "off";
+
setNetworkServices = optionalString (cfg.knownNetworkServices != []) ''
networkservices=$(networksetup -listallnetworkservices)
${concatMapStringsSep "\n" (srv: ''
@@ -93,6 +95,16 @@ in
default = [];
description = "The list of search paths used when resolving domain names.";
};
+
+ networking.wakeOnLan.enable = mkOption {
+ type = types.nullOr types.bool;
+ default = null;
+ description = ''
+ Enable Wake-on-LAN for the device.
+
+ Battery powered devices may require being connected to power.
+ '';
+ };
};
config = {
@@ -116,6 +128,10 @@ in
''}
${setNetworkServices}
+
+ ${optionalString (cfg.wakeOnLan.enable != null) ''
+ systemsetup -setWakeOnNetworkAccess '${onOff cfg.wakeOnLan.enable}' &> /dev/null
+ ''}
'';
};
diff --git a/modules/power/default.nix b/modules/power/default.nix
new file mode 100644
index 0000000..a99905f
--- /dev/null
+++ b/modules/power/default.nix
@@ -0,0 +1,47 @@
+{ config, lib, ... }:
+
+let
+ cfg = config.power;
+
+ types = lib.types;
+
+ onOff = cond: if cond then "on" else "off";
+in
+
+{
+ options = {
+ power.restartAfterPowerFailure = lib.mkOption {
+ type = types.nullOr types.bool;
+ default = null;
+ description = ''
+ Whether to restart the computer after a power failure.
+ '';
+ };
+
+ power.restartAfterFreeze = lib.mkOption {
+ type = types.nullOr types.bool;
+ default = null;
+ description = ''
+ Whether to restart the computer after a system freeze.
+ '';
+ };
+ };
+
+ config = {
+
+ system.activationScripts.power.text = ''
+ echo "configuring power..." >&2
+
+ ${lib.optionalString (cfg.restartAfterPowerFailure != null) ''
+ systemsetup -setRestartPowerFailure \
+ '${onOff cfg.restartAfterPowerFailure}' &> /dev/null
+ ''}
+
+ ${lib.optionalString (cfg.restartAfterFreeze != null) ''
+ systemsetup -setRestartFreeze \
+ '${onOff cfg.restartAfterFreeze}' &> /dev/null
+ ''}
+ '';
+
+ };
+}
diff --git a/modules/power/sleep.nix b/modules/power/sleep.nix
new file mode 100644
index 0000000..ab5862c
--- /dev/null
+++ b/modules/power/sleep.nix
@@ -0,0 +1,80 @@
+{ config, lib, ... }:
+
+let
+ cfg = config.power.sleep;
+
+ types = lib.types;
+
+ onOff = cond: if cond then "on" else "off";
+in
+
+{
+ options = {
+ power.sleep.computer = lib.mkOption {
+ type = types.nullOr (types.either types.ints.positive (types.enum ["never"]));
+ default = null;
+ example = "never";
+ description = ''
+ Amount of idle time (in minutes) until the computer sleeps.
+
+ `"never"` disables computer sleeping.
+
+ The system might not be considered idle before connected displays sleep, as
+ per the `power.sleep.display` option.
+ '';
+ };
+
+ power.sleep.display = lib.mkOption {
+ type = types.nullOr (types.either types.ints.positive (types.enum ["never"]));
+ default = null;
+ example = "never";
+ description = ''
+ Amount of idle time (in minutes) until displays sleep.
+
+ `"never"` disables display sleeping.
+ '';
+ };
+
+ power.sleep.harddisk = lib.mkOption {
+ type = types.nullOr (types.either types.ints.positive (types.enum ["never"]));
+ default = null;
+ example = "never";
+ description = ''
+ Amount of idle time (in minutes) until hard disks sleep.
+
+ `"never"` disables hard disk sleeping.
+ '';
+ };
+
+ power.sleep.allowSleepByPowerButton = lib.mkOption {
+ type = types.nullOr types.bool;
+ default = null;
+ description = ''
+ Whether the power button can sleep the computer.
+ '';
+ };
+ };
+
+ config = {
+
+ system.activationScripts.power.text = lib.mkAfter ''
+ ${lib.optionalString (cfg.computer != null) ''
+ systemsetup -setComputerSleep '${toString cfg.computer}' &> /dev/null
+ ''}
+
+ ${lib.optionalString (cfg.display != null) ''
+ systemsetup -setDisplaySleep '${toString cfg.display}' &> /dev/null
+ ''}
+
+ ${lib.optionalString (cfg.harddisk != null) ''
+ systemsetup -setHardDiskSleep '${toString cfg.harddisk}' &> /dev/null
+ ''}
+
+ ${lib.optionalString (cfg.allowSleepByPowerButton != null) ''
+ systemsetup -setAllowPowerButtonToSleepComputer \
+ '${onOff cfg.allowSleepByPowerButton}' &> /dev/null
+ ''}
+ '';
+
+ };
+}
diff --git a/modules/system/activation-scripts.nix b/modules/system/activation-scripts.nix
index 8325199..da8eb5c 100644
--- a/modules/system/activation-scripts.nix
+++ b/modules/system/activation-scripts.nix
@@ -67,6 +67,7 @@ in
${cfg.activationScripts.nix-daemon.text}
${cfg.activationScripts.time.text}
${cfg.activationScripts.networking.text}
+ ${cfg.activationScripts.power.text}
${cfg.activationScripts.keyboard.text}
${cfg.activationScripts.fonts.text}
${cfg.activationScripts.nvram.text}