Adds a new service module for shairport-sync. Tested with a local and remote pulseaudio server. Needs to be run as a user in the pulse group to access pulseaudio.wip/yesman
parent
069b1891d3
commit
6734127545
@ -0,0 +1,80 @@ |
||||
{ config, lib, pkgs, ... }: |
||||
|
||||
with lib; |
||||
|
||||
let |
||||
|
||||
cfg = config.services.shairport-sync; |
||||
|
||||
in |
||||
|
||||
{ |
||||
|
||||
###### interface |
||||
|
||||
options = { |
||||
|
||||
services.shairport-sync = { |
||||
|
||||
enable = mkOption { |
||||
default = false; |
||||
description = '' |
||||
Enable the shairport-sync daemon. |
||||
|
||||
Running with a local system-wide or remote pulseaudio server |
||||
is recommended. |
||||
''; |
||||
}; |
||||
|
||||
arguments = mkOption { |
||||
default = "-v -o pulse"; |
||||
description = '' |
||||
Arguments to pass to the daemon. Defaults to a local pulseaudio |
||||
server. |
||||
''; |
||||
}; |
||||
|
||||
user = mkOption { |
||||
default = "shairport"; |
||||
description = '' |
||||
User account name under which to run shairport-sync. The account |
||||
will be created. |
||||
''; |
||||
}; |
||||
|
||||
}; |
||||
|
||||
}; |
||||
|
||||
|
||||
###### implementation |
||||
|
||||
config = mkIf config.services.shairport-sync.enable { |
||||
|
||||
services.avahi.enable = true; |
||||
|
||||
users.extraUsers = singleton |
||||
{ name = cfg.user; |
||||
description = "Shairport user"; |
||||
isSystemUser = true; |
||||
createHome = true; |
||||
home = "/var/lib/shairport-sync"; |
||||
extraGroups = [ "audio" ] ++ optional config.hardware.pulseaudio.enable "pulse"; |
||||
}; |
||||
|
||||
systemd.services.shairport-sync = |
||||
{ |
||||
description = "shairport-sync"; |
||||
after = [ "network.target" "avahi-daemon.service" ]; |
||||
wantedBy = [ "multi-user.target" ]; |
||||
serviceConfig = { |
||||
User = cfg.user; |
||||
ExecStart = "${pkgs.shairport-sync}/bin/shairport-sync ${cfg.arguments}"; |
||||
}; |
||||
}; |
||||
|
||||
environment.systemPackages = [ pkgs.shairport-sync ]; |
||||
|
||||
}; |
||||
|
||||
} |
Loading…
Reference in new issue