diff --git a/home/.config/swayidle/config b/home/.config/swayidle/config index 86f9c245..ab5ecc75 100644 --- a/home/.config/swayidle/config +++ b/home/.config/swayidle/config @@ -1,4 +1,2 @@ timeout 300 "hyprctl dispatch dpms off && dunstctl set-paused true" resume "hyprctl dispatch dpms on && dunstctl set-paused false" timeout 310 "loginctl lock-session" -before-sleep swaylock -fF -lock swaylock -fF diff --git a/home/.config/systemd/user/default.target.wants/systemd-lock-handler.service b/home/.config/systemd/user/default.target.wants/systemd-lock-handler.service new file mode 120000 index 00000000..b7c97202 --- /dev/null +++ b/home/.config/systemd/user/default.target.wants/systemd-lock-handler.service @@ -0,0 +1 @@ +/usr/lib/systemd/user/systemd-lock-handler.service \ No newline at end of file diff --git a/home/.config/systemd/user/lock.target.wants/systemd-lock-handler-swaylock.service b/home/.config/systemd/user/lock.target.wants/systemd-lock-handler-swaylock.service new file mode 120000 index 00000000..587607f8 --- /dev/null +++ b/home/.config/systemd/user/lock.target.wants/systemd-lock-handler-swaylock.service @@ -0,0 +1 @@ +/home/itsdrike/.config/systemd/user/systemd-lock-handler-swaylock.service \ No newline at end of file diff --git a/home/.config/systemd/user/systemd-lock-handler-swaylock.service b/home/.config/systemd/user/systemd-lock-handler-swaylock.service new file mode 100644 index 00000000..c5a21960 --- /dev/null +++ b/home/.config/systemd/user/systemd-lock-handler-swaylock.service @@ -0,0 +1,18 @@ +[Unit] +Description=Run Swaylock screenlocker on lock dbus event (using systemd-lock-handler) +# if swaylock exists cleanly, unlock this session +OnSuccess=unlock.target +# When lock.target is stopped, stop this too +PartOf=lock.target +# Delay lock.target until this service is ready +After=lock.target + +[Service] +# systemd will consider this service started when swaylock forks +# which swaylock will only do after it has locked the screen +Type=forking +ExecStart=/usr/bin/swaylock -fF +Restart=on-failure + +[Install] +WantedBy=lock.target