feat: restructured snapcast
parent
36a64d5fdc
commit
42ad65fc34
|
@ -9,6 +9,7 @@
|
||||||
./hardware-configuration.nix
|
./hardware-configuration.nix
|
||||||
./file-systems.nix
|
./file-systems.nix
|
||||||
./home-manager.nix
|
./home-manager.nix
|
||||||
|
./snapcast.nix
|
||||||
outputs.nixosModules.common
|
outputs.nixosModules.common
|
||||||
outputs.nixosModules.desktop
|
outputs.nixosModules.desktop
|
||||||
];
|
];
|
||||||
|
|
|
@ -15,7 +15,9 @@
|
||||||
imports = [
|
imports = [
|
||||||
outputs.homeManagerModules.common
|
outputs.homeManagerModules.common
|
||||||
outputs.homeManagerModules.extra
|
outputs.homeManagerModules.extra
|
||||||
|
outputs.homeManagerModules.snapcast
|
||||||
];
|
];
|
||||||
|
snapclient.enable = true;
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,25 @@
|
||||||
|
{ config, pkgs, ... }:
|
||||||
|
|
||||||
|
{
|
||||||
|
services.snapserver = {
|
||||||
|
enable = true;
|
||||||
|
codec = "flac";
|
||||||
|
streams = {
|
||||||
|
pipewire = {
|
||||||
|
type = "pipe";
|
||||||
|
location = "/run/snapserver/pipewire";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
systemd.user.services.snapcast-sink = {
|
||||||
|
wantedBy = [ "pipewire.service" ];
|
||||||
|
after = [ "pipewire.service" ];
|
||||||
|
bindsTo = [ "pipewire.service" ];
|
||||||
|
path = with pkgs; [ gawk pulseaudio ];
|
||||||
|
script = ''
|
||||||
|
pactl load-module module-pipe-sink file=/run/snapserver/pipewire sink_name=Snapcast format=s16le rate=48000
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
|
@ -29,7 +29,7 @@
|
||||||
neovim = import ./neovim;
|
neovim = import ./neovim;
|
||||||
pass = import ./pass;
|
pass = import ./pass;
|
||||||
rss = import ./rss;
|
rss = import ./rss;
|
||||||
snapcast = import ./snapcast;
|
snapclient = import ./snapclient;
|
||||||
sound = import ./sound;
|
sound = import ./sound;
|
||||||
ssh = import ./ssh;
|
ssh = import ./ssh;
|
||||||
syncthing = import ./syncthing;
|
syncthing = import ./syncthing;
|
||||||
|
|
|
@ -20,7 +20,6 @@
|
||||||
../msg
|
../msg
|
||||||
../music
|
../music
|
||||||
../rss
|
../rss
|
||||||
../snapcast
|
|
||||||
../sound
|
../sound
|
||||||
../syncthing
|
../syncthing
|
||||||
../theming
|
../theming
|
||||||
|
|
|
@ -1,21 +0,0 @@
|
||||||
{ config, pkgs, ... }:
|
|
||||||
|
|
||||||
let snapserver_ip = "192.168.1.144";
|
|
||||||
in
|
|
||||||
{
|
|
||||||
home.packages = [ pkgs.snapcast ];
|
|
||||||
|
|
||||||
systemd.user.services.snapclient = {
|
|
||||||
Unit = {
|
|
||||||
After = [ "pipewire.service" ];
|
|
||||||
};
|
|
||||||
Service = {
|
|
||||||
Type = "simple";
|
|
||||||
ExecStart = "${pkgs.snapcast}/bin/snapclient --host ${snapserver_ip}";
|
|
||||||
};
|
|
||||||
Install = {
|
|
||||||
WantedBy = [ "pipewire.service" ];
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
|
@ -0,0 +1,33 @@
|
||||||
|
{ config, lib, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.snapclient;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options.snapclient = {
|
||||||
|
enable = lib.mkEnableOption "snapclient";
|
||||||
|
snapserver-host = lib.mkOption {
|
||||||
|
type = lib.types.str;
|
||||||
|
default = "localhost";
|
||||||
|
description = "host running snapserver to connect to";
|
||||||
|
};
|
||||||
|
package = lib.mkOption {
|
||||||
|
type = lib.types.package;
|
||||||
|
default = pkgs.snapcast;
|
||||||
|
defaultText = "pkgs.snapcast";
|
||||||
|
description = "package for snapcast";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
|
systemd.user.services.snapclient = {
|
||||||
|
Service = {
|
||||||
|
Type = "simple";
|
||||||
|
ExecStart = "${cfg.package}/bin/snapclient --host ${cfg.snapserver-host}";
|
||||||
|
};
|
||||||
|
Unit.After = [ "pipewire.service" ];
|
||||||
|
Install.WantedBy = [ "pipewire.service" ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue