Quassel: Create quassel user only if cfg.user is left empty to avoid messing up existing users.
This solution is still suboptimal but others are even worse. svn path=/nixos/trunk/; revision=23927
This commit is contained in:
parent
26417566c4
commit
d8c72719aa
@ -5,6 +5,7 @@ with pkgs.lib;
|
|||||||
let
|
let
|
||||||
quassel = pkgs.quasselDaemon;
|
quassel = pkgs.quasselDaemon;
|
||||||
cfg = config.services.quassel;
|
cfg = config.services.quassel;
|
||||||
|
user = if cfg.user != null then cfg.user else "quassel";
|
||||||
in
|
in
|
||||||
|
|
||||||
{
|
{
|
||||||
@ -39,16 +40,16 @@ in
|
|||||||
};
|
};
|
||||||
|
|
||||||
dataDir = mkOption {
|
dataDir = mkOption {
|
||||||
default = ''/home/${cfg.user}/.config/quassel-irc.org'';
|
default = ''/home/${user}/.config/quassel-irc.org'';
|
||||||
description = ''
|
description = ''
|
||||||
The directory holding configuration files, the SQlite database and the SSL Cert.
|
The directory holding configuration files, the SQlite database and the SSL Cert.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
user = mkOption {
|
user = mkOption {
|
||||||
default = "quassel";
|
default = null;
|
||||||
description = ''
|
description = ''
|
||||||
The user the Quassel daemon should run as.
|
The existing user the Quassel daemon should run as. If left empty, a default "quassel" user will be created.
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -61,10 +62,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 = "Quassel IRC client daemon";
|
description = "Quassel IRC client daemon";
|
||||||
};
|
}];
|
||||||
|
|
||||||
|
|
||||||
jobs.quassel =
|
jobs.quassel =
|
||||||
@ -74,11 +75,11 @@ 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 '${quassel}/bin/quasselcore --listen=${cfg.interface}\
|
-c '${quassel}/bin/quasselcore --listen=${cfg.interface}\
|
||||||
--port=${toString cfg.portNumber} --configdir=${cfg.dataDir}'
|
--port=${toString cfg.portNumber} --configdir=${cfg.dataDir}'
|
||||||
'';
|
'';
|
||||||
|
Loading…
x
Reference in New Issue
Block a user