summary refs log tree commit diff
path: root/nixos/modules/services/continuous-integration/jenkins/default.nix
diff options
context:
space:
mode:
authorCorey O'Connor <coreyoconnor@gmail.com>2014-03-06 10:06:53 -0800
committerCorey O'Connor <coreyoconnor@gmail.com>2014-03-13 13:01:50 -0700
commit40de28afca0faa6673948bf99f444faad1d1a2d4 (patch)
tree0a7c874fde8a886f43de82b28c4cf0a924607696 /nixos/modules/services/continuous-integration/jenkins/default.nix
parent4b6e67f6c43c49dd2cb950c152d22cf59b5364a6 (diff)
downloadnixpkgs-40de28afca0faa6673948bf99f444faad1d1a2d4.tar
nixpkgs-40de28afca0faa6673948bf99f444faad1d1a2d4.tar.gz
nixpkgs-40de28afca0faa6673948bf99f444faad1d1a2d4.tar.bz2
nixpkgs-40de28afca0faa6673948bf99f444faad1d1a2d4.tar.lz
nixpkgs-40de28afca0faa6673948bf99f444faad1d1a2d4.tar.xz
nixpkgs-40de28afca0faa6673948bf99f444faad1d1a2d4.tar.zst
nixpkgs-40de28afca0faa6673948bf99f444faad1d1a2d4.zip
remove users.jenkins config start on slave config.
Uses standard NixOS user config merging.
Work in progress: The slave config does not actually start the slave agent. This just configures a
jenkins user if required. Bare minimum to enable a nice jenkins SSH slave.
Diffstat (limited to 'nixos/modules/services/continuous-integration/jenkins/default.nix')
-rw-r--r--nixos/modules/services/continuous-integration/jenkins/default.nix31
1 files changed, 26 insertions, 5 deletions
diff --git a/nixos/modules/services/continuous-integration/jenkins/default.nix b/nixos/modules/services/continuous-integration/jenkins/default.nix
index 6e3f6abbb87..c3dc59a9fbd 100644
--- a/nixos/modules/services/continuous-integration/jenkins/default.nix
+++ b/nixos/modules/services/continuous-integration/jenkins/default.nix
@@ -2,7 +2,6 @@
 with pkgs.lib;
 let
   cfg = config.services.jenkins;
-  userCfg = config.users.jenkins;
 in {
   options = {
     services.jenkins = {
@@ -18,15 +17,24 @@ in {
         default = "jenkins";
         type = with types; string;
         description = ''
-          User the jenkins server should execute under. Defaults to the "jenkins" user.
+          User the jenkins server should execute under.
+        '';
+      };
+
+      group = mkOption {
+        default = "jenkins";
+        type = with types; string;
+        description = ''
+          User the jenkins server should execute under.
         '';
       };
 
       home = mkOption {
-        default = userCfg.home;
+        default = "/var/lib/jenkins";
         type = with types; string;
         description = ''
-          The path to use as JENKINS_HOME. Defaults to the home of the "jenkins" user.
+          The path to use as JENKINS_HOME. If the default user "jenkins" is configured then
+          this is the home of the "jenkins" user.
         '';
       };
 
@@ -58,7 +66,20 @@ in {
   };
 
   config = mkIf cfg.enable {
-    users.jenkins.enable = true;
+    users.extraGroups = optional (cfg.group == "jenkins") {
+      name = "jenkins";
+      gid = config.ids.gids.jenkins;
+    };
+
+    users.extraUsers = optional (cfg.user == "jenkins") {
+      name = "jenkins";
+      description = "jenkins user";
+      createHome = true;
+      home = cfg.home;
+      group = cfg.group;
+      useDefaultShell = true;
+      uid = config.ids.uids.jenkins;
+    };
 
     systemd.services.jenkins = {
       description = "Jenkins Continuous Integration Server";