diff options
author | Corey O'Connor <coreyoconnor@gmail.com> | 2014-03-06 10:06:53 -0800 |
---|---|---|
committer | Corey O'Connor <coreyoconnor@gmail.com> | 2014-03-13 13:01:50 -0700 |
commit | 40de28afca0faa6673948bf99f444faad1d1a2d4 (patch) | |
tree | 0a7c874fde8a886f43de82b28c4cf0a924607696 /nixos/modules/services/continuous-integration/jenkins/default.nix | |
parent | 4b6e67f6c43c49dd2cb950c152d22cf59b5364a6 (diff) | |
download | nixpkgs-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.nix | 31 |
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"; |