AMule: create the user only if the user option is null, don't pollute the system profile with useless packages.

svn path=/nixos/trunk/; revision=23928
This commit is contained in:
Evgeny Egorochkin 2010-09-26 02:04:06 +00:00
parent d8c72719aa
commit 3bca96e1bd
1 changed files with 7 additions and 8 deletions

View File

@ -4,6 +4,7 @@ with pkgs.lib;
let let
cfg = config.services.amule; cfg = config.services.amule;
user = if cfg.user != null then cfg.user else "amule";
in in
{ {
@ -22,14 +23,14 @@ in
}; };
dataDir = mkOption { dataDir = mkOption {
default = ''/home/${cfg.user}/''; default = ''/home/${user}/'';
description = '' description = ''
The directory holding configuration, incoming and temporary files. The directory holding configuration, incoming and temporary files.
''; '';
}; };
user = mkOption { user = mkOption {
default = "amule"; default = null;
description = '' description = ''
The user the AMule daemon should run as. The user the AMule daemon should run as.
''; '';
@ -44,10 +45,10 @@ in
config = mkIf cfg.enable { config = mkIf cfg.enable {
users.extraUsers = singleton users.extraUsers = mkIf (cfg.user == null) [
{ name = cfg.user; { name = cfg.user;
description = "AMule daemon"; description = "AMule daemon";
}; } ];
jobs.amuled = jobs.amuled =
{ description = "AMule daemon"; { description = "AMule daemon";
@ -56,17 +57,15 @@ in
preStart = '' preStart = ''
mkdir -p ${cfg.dataDir} mkdir -p ${cfg.dataDir}
chown ${cfg.user} ${cfg.dataDir} chown ${user} ${cfg.dataDir}
''; '';
exec = '' exec = ''
${pkgs.su}/bin/su -s ${pkgs.stdenv.shell} ${cfg.user} \ ${pkgs.su}/bin/su -s ${pkgs.stdenv.shell} ${user} \
-c 'HOME="${cfg.dataDir}" ${pkgs.amuleDaemon}/bin/amuled' -c 'HOME="${cfg.dataDir}" ${pkgs.amuleDaemon}/bin/amuled'
''; '';
}; };
environment.systemPackages = [ pkgs.amuleDaemon ];
}; };
} }