From 5060262b79a74dd7b35d6a5c2c3fd02bae1ccecc Mon Sep 17 00:00:00 2001 From: Rodney Lorrimar Date: Sun, 30 May 2021 12:40:58 +1000 Subject: [PATCH] services/emacs: Prevent deletion of socket file When running a socket-activated emacs service, we don't want emacs to remove the socket file after exiting, because then subsequent invocations of `emacsclient` won't be able to use the socket to start emacs.service again. --- modules/services/emacs.nix | 10 +++++++++- tests/modules/services/emacs/emacs-socket-27.nix | 2 +- tests/modules/services/emacs/emacs-socket-28.nix | 2 +- .../modules/services/emacs/emacs-socket-emacs.service | 2 ++ 4 files changed, 13 insertions(+), 3 deletions(-) diff --git a/modules/services/emacs.nix b/modules/services/emacs.nix index b8ca9f02..96c86ee7 100644 --- a/modules/services/emacs.nix +++ b/modules/services/emacs.nix @@ -35,7 +35,8 @@ let # Match the default socket path for the Emacs version so emacsclient continues # to work without wrapping it. - socketPath = "%t/emacs/server"; + socketDir = "%t/emacs"; + socketPath = "${socketDir}/server"; in { meta.maintainers = [ maintainers.tadfisher ]; @@ -112,6 +113,13 @@ in { SuccessExitStatus = 15; Restart = "on-failure"; + } // optionalAttrs (cfg.socketActivation.enable) { + # Use read-only directory permissions to prevent emacs from + # deleting systemd's socket file before exiting. + ExecStartPost = + "${pkgs.coreutils}/bin/chmod --changes -w ${socketDir}"; + ExecStopPost = + "${pkgs.coreutils}/bin/chmod --changes +w ${socketDir}"; }; } // optionalAttrs (!cfg.socketActivation.enable) { Install = { WantedBy = [ "default.target" ]; }; diff --git a/tests/modules/services/emacs/emacs-socket-27.nix b/tests/modules/services/emacs/emacs-socket-27.nix index 22619937..0fd1be1b 100644 --- a/tests/modules/services/emacs/emacs-socket-27.nix +++ b/tests/modules/services/emacs/emacs-socket-27.nix @@ -31,7 +31,7 @@ in { assertFileContent home-files/.config/systemd/user/emacs.service \ ${ pkgs.substituteAll { - inherit (pkgs) runtimeShell; + inherit (pkgs) runtimeShell coreutils; src = ./emacs-socket-emacs.service; } } diff --git a/tests/modules/services/emacs/emacs-socket-28.nix b/tests/modules/services/emacs/emacs-socket-28.nix index f04d93cb..d2c04239 100644 --- a/tests/modules/services/emacs/emacs-socket-28.nix +++ b/tests/modules/services/emacs/emacs-socket-28.nix @@ -31,7 +31,7 @@ in { assertFileContent home-files/.config/systemd/user/emacs.service \ ${ pkgs.substituteAll { - inherit (pkgs) runtimeShell; + inherit (pkgs) runtimeShell coreutils; src = ./emacs-socket-emacs.service; } } diff --git a/tests/modules/services/emacs/emacs-socket-emacs.service b/tests/modules/services/emacs/emacs-socket-emacs.service index 52d446cf..a3687ead 100644 --- a/tests/modules/services/emacs/emacs-socket-emacs.service +++ b/tests/modules/services/emacs/emacs-socket-emacs.service @@ -1,5 +1,7 @@ [Service] ExecStart=@runtimeShell@ -l -c "@emacs@/bin/emacs --fg-daemon='%t/emacs/server'" +ExecStartPost=@coreutils@/bin/chmod --changes -w %t/emacs +ExecStopPost=@coreutils@/bin/chmod --changes +w %t/emacs Restart=on-failure SuccessExitStatus=15 Type=notify