aboutsummaryrefslogtreecommitdiff
path: root/modules/system/worldWritableDirs.nix
diff options
context:
space:
mode:
authorIgor Pashev <pashev.igor@gmail.com>2016-09-29 13:51:44 +0300
committerIgor Pashev <pashev.igor@gmail.com>2016-09-29 13:51:44 +0300
commit62f28d30a069135f9c48678507203958adfc334f (patch)
tree7f38af0c8d3f445ee8cc50906a639baec7011127 /modules/system/worldWritableDirs.nix
parent1af9e6589bdd18e6ba7eeabf073aa7d710020cdd (diff)
downloadnixsap-62f28d30a069135f9c48678507203958adfc334f.tar.gz
Moved everything into ./modules
Diffstat (limited to 'modules/system/worldWritableDirs.nix')
-rw-r--r--modules/system/worldWritableDirs.nix25
1 files changed, 25 insertions, 0 deletions
diff --git a/modules/system/worldWritableDirs.nix b/modules/system/worldWritableDirs.nix
new file mode 100644
index 0000000..9899696
--- /dev/null
+++ b/modules/system/worldWritableDirs.nix
@@ -0,0 +1,25 @@
+{ config, pkgs, lib, ... }:
+let
+ dirs = config.nixsap.system.worldWritableDirs;
+
+in {
+ options.nixsap.system.worldWritableDirs = lib.mkOption {
+ type = lib.types.listOf lib.types.path;
+ description = "These dirs will be chmod'ed 1777";
+ default = [ "/tmp" "/var/tmp" ];
+ };
+
+ config = lib.mkIf (dirs != []) {
+ systemd.services.chmod1777 = {
+ description = "Make some dirs world-writable";
+ unitConfig.RequiresMountsFor = dirs;
+ before = [ "local-fs.target" ];
+ wantedBy = [ "local-fs.target" ];
+ serviceConfig = {
+ ExecStart = "${pkgs.coreutils}/bin/chmod -c 1777 ${lib.concatStringsSep " " dirs}";
+ Type = "oneshot";
+ RemainAfterExit = true;
+ };
+ };
+ };
+}