Merge pull request #16108 from pwetzel/squeezelite

Squeezelite package and service init

Changed files
+98
nixos
modules
pkgs
applications
audio
squeezelite
top-level
+2
nixos/modules/misc/ids.nix
···
nzbget = 245;
mosquitto = 246;
toxvpn = 247;
+
squeezelite = 248;
# When adding a uid, make sure it doesn't match an existing gid. And don't use uids above 399!
···
nzbget = 245;
mosquitto = 246;
#toxvpn = 247; # unused
+
#squeezelite = 248; #unused
# When adding a gid, make sure it doesn't match an existing
# uid. Users and groups with the same name should have equal
+1
nixos/modules/module-list.nix
···
./services/audio/liquidsoap.nix
./services/audio/mpd.nix
./services/audio/mopidy.nix
+
./services/audio/squeezelite.nix
./services/backup/almir.nix
./services/backup/bacula.nix
./services/backup/crashplan.nix
+67
nixos/modules/services/audio/squeezelite.nix
···
+
{ config, lib, pkgs, ... }:
+
+
with lib;
+
+
let
+
+
uid = config.ids.uids.squeezelite;
+
cfg = config.services.squeezelite;
+
+
in {
+
+
###### interface
+
+
options = {
+
+
services.squeezelite= {
+
+
enable = mkEnableOption "Squeezelite, a software Squeezebox emulator";
+
+
dataDir = mkOption {
+
default = "/var/lib/squeezelite";
+
type = types.str;
+
description = ''
+
The directory where Squeezelite stores its name file.
+
'';
+
};
+
+
extraArguments = mkOption {
+
default = "";
+
type = types.str;
+
description = ''
+
Additional command line arguments to pass to Squeezelite.
+
'';
+
};
+
+
};
+
+
};
+
+
+
###### implementation
+
+
config = mkIf cfg.enable {
+
+
systemd.services.squeezelite= {
+
wantedBy = [ "multi-user.target" ];
+
after = [ "network.target" "sound.target" ];
+
description = "Software Squeezebox emulator";
+
preStart = "mkdir -p ${cfg.dataDir} && chown -R squeezelite ${cfg.dataDir}";
+
serviceConfig = {
+
ExecStart = "${pkgs.squeezelite}/bin/squeezelite -N ${cfg.dataDir}/player-name ${cfg.extraArguments}";
+
User = "squeezelite";
+
PermissionsStartOnly = true;
+
};
+
};
+
+
users.extraUsers.squeezelite= {
+
inherit uid;
+
group = "nogroup";
+
extraGroups = [ "audio" ];
+
description = "Squeezelite user";
+
home = "${cfg.dataDir}";
+
};
+
+
};
+
+
}
+26
pkgs/applications/audio/squeezelite/default.nix
···
+
{ stdenv, fetchFromGitHub, alsaLib, faad2, flac, libmad, libvorbis, mpg123 }:
+
+
stdenv.mkDerivation {
+
name = "squeezelite-git-2016-05-27";
+
+
src = fetchFromGitHub {
+
owner = "ralph-irving";
+
repo = "squeezelite";
+
rev = "e37ed17fed9e11a7346cbe9f1e1deeccc051f42e";
+
sha256 = "15ihx2dbp4kr6k6r50g9q5npqad5zyv8nqf5cr37bhg964syvbdm";
+
};
+
+
buildInputs = [ alsaLib faad2 flac libmad libvorbis mpg123 ];
+
+
installPhase = ''
+
mkdir -p $out/bin
+
cp squeezelite $out/bin
+
'';
+
+
meta = with stdenv.lib; {
+
description = "Lightweight headless squeezebox client emulator";
+
homepage = https://github.com/ralph-irving/squeezelite;
+
license = licenses.gpl3;
+
platforms = platforms.linux;
+
};
+
}
+2
pkgs/top-level/all-packages.nix
···
apiKey = config.libspotify.apiKey or null;
+
squeezelite = callPackage ../applications/audio/squeezelite { };
+
ltunify = callPackage ../tools/misc/ltunify { };
src = callPackage ../applications/version-management/src/default.nix {