diff options
author | sinanmohd <sinan@sinanmohd.com> | 2024-08-30 11:57:06 +0530 |
---|---|---|
committer | sinanmohd <sinan@sinanmohd.com> | 2024-08-30 11:57:06 +0530 |
commit | c75ab728a38ede1540a83aad307fefdb23fbabba (patch) | |
tree | d5f74edc06f68e40662675968324918289210366 | |
parent | d1ed412ae63e847f1e1460dc7777c4f8d1bf23bc (diff) |
home/wayland/swayidle: suspend idle system on battery
-rw-r--r-- | home/wayland/modules/sway/swayidle.nix | 51 |
1 files changed, 48 insertions, 3 deletions
diff --git a/home/wayland/modules/sway/swayidle.nix b/home/wayland/modules/sway/swayidle.nix index 1aa16c5..abb3a10 100644 --- a/home/wayland/modules/sway/swayidle.nix +++ b/home/wayland/modules/sway/swayidle.nix @@ -2,14 +2,51 @@ swaylock = lib.getExe config.programs.swaylock.package; brightnessctl = lib.getExe pkgs.brightnessctl; swaymsg = "${pkgs.sway}/bin/swaymsg"; + + minute = 60; # seconds + suspend_timeout = minute * 60; + suspend_on_battery = pkgs.writeShellApplication { + name = "suspend_on_battery"; + runtimeInputs = with pkgs; [ gnugrep systemd sudo coreutils ]; + text = let + sudo = "/run/wrappers/bin/sudo"; + in '' + is_discharging() { + grep -qFx \ + 'POWER_SUPPLY_STATUS=Discharging' \ + /sys/class/power_supply/*/uevent + } + + was_charging=false + while true; do + if is_discharging; then + if [ $was_charging = true ]; then + sleep ${builtins.toString suspend_timeout} + fi + + if is_discharging; then + ${sudo} systemctl suspend-then-hibernate + fi + fi + + was_charging=true + sleep 10 + done + ''; + }; in { + systemd.user.services.suspend_on_battery = { + Unit.Description = "Suspend on battery"; + Service.ExecStart = lib.getExe suspend_on_battery; + }; + services.swayidle = { enable = true; systemdTarget = "sway-session.target"; timeouts = [ { - timeout = 250; + timeout = minute * 4; command = "${brightnessctl} --save; " + "${brightnessctl} set 10%-"; @@ -17,12 +54,12 @@ in { } { - timeout = 300; + timeout = minute * 5; command = swaylock; } { - timeout = 600; + timeout = minute * 10; command = "${swaymsg} --type command 'output * dpms off'; " + "${brightnessctl} -c leds -d platform::kbd_backlight --save; " @@ -31,6 +68,14 @@ in { "${brightnessctl} -c leds -d platform::kbd_backlight --restore; " + "${swaymsg} --type command 'output * dpms on'"; } + + { + timeout = suspend_timeout; + command = + "${pkgs.systemd}/bin/systemctl --user start suspend_on_battery"; + resumeCommand = + "${pkgs.systemd}/bin/systemctl --user stop suspend_on_battery"; + } ]; }; } |