Convert `portmap' Upstart job to the "new" style.

svn path=/nixos/trunk/; revision=14232
This commit is contained in:
Ludovic Courtès 2009-02-24 19:17:25 +00:00
parent 9e29c72bd2
commit d1f57d6e1b
3 changed files with 64 additions and 48 deletions

View File

@ -967,18 +967,6 @@ in
}; };
portmap = {
enable = mkOption {
default = false;
description = ''
Whether to enable `portmap', an ONC RPC directory service
notably used by NFS and NIS, and which can be queried
using the rpcinfo(1) command.
'';
};
};
avahi = { avahi = {
enable = mkOption { enable = mkOption {
@ -3081,5 +3069,6 @@ root ALL=(ALL) SETENV: ALL
(import ../upstart-jobs/rogue.nix) (import ../upstart-jobs/rogue.nix)
(import ../upstart-jobs/guest-users.nix) (import ../upstart-jobs/guest-users.nix)
(import ../upstart-jobs/pulseaudio.nix) (import ../upstart-jobs/pulseaudio.nix)
(import ../upstart-jobs/portmap.nix)
]; ];
} }

View File

@ -220,12 +220,6 @@ let
servers = config.services.ntp.servers; servers = config.services.ntp.servers;
}) })
# portmap daemon.
++ optional config.services.portmap.enable
(import ../upstart-jobs/portmap.nix {
inherit (pkgs) makePortmap;
})
# Avahi daemon. # Avahi daemon.
++ optional config.services.avahi.enable ++ optional config.services.avahi.enable
(import ../upstart-jobs/avahi-daemon.nix { (import ../upstart-jobs/avahi-daemon.nix {

View File

@ -1,12 +1,40 @@
{ makePortmap }: {pkgs, config, ...}:
let uid = (import ../system/ids.nix).uids.portmap; ###### interface
let
inherit (pkgs.lib) mkOption mkIf;
inherit (pkgs) makePortmap;
uid = (import ../system/ids.nix).uids.portmap;
gid = (import ../system/ids.nix).gids.portmap; gid = (import ../system/ids.nix).gids.portmap;
in
{
name = "portmap";
users = [ options = {
services = {
portmap = {
enable = mkOption {
default = false;
description = ''
Whether to enable `portmap', an ONC RPC directory service
notably used by NFS and NIS, and which can be queried
using the rpcinfo(1) command.
'';
};
};
};
};
in
###### implementation
mkIf config.services.portmap.enable {
require = [
options
];
users = {
extraUsers = [
{ name = "portmap"; { name = "portmap";
inherit uid; inherit uid;
description = "portmap daemon user"; description = "portmap daemon user";
@ -14,16 +42,20 @@ in
} }
]; ];
groups = [ extraGroups = [
{ name = "portmap"; { name = "portmap";
inherit gid; inherit gid;
} }
]; ];
};
services = {
extraJobs = [{
name = "portmap";
job = job =
let portmap = makePortmap { daemonUID = uid; daemonGID = gid; }; let portmap = makePortmap { daemonUID = uid; daemonGID = gid; };
in in ''
''
description "ONC RPC portmap" description "ONC RPC portmap"
start on network-interfaces/started start on network-interfaces/started
@ -31,5 +63,6 @@ stop on network-interfaces/stop
respawn ${portmap}/sbin/portmap respawn ${portmap}/sbin/portmap
''; '';
}];
};
} }