Compare commits

..

2 commits

Author SHA1 Message Date
Antoine Martin c75979acef boreal: switch to pipewire 2021-05-26 00:33:52 +02:00
Antoine Martin 4d091d5aa6 services: add pipewire service 2021-05-26 00:33:15 +02:00
3 changed files with 71 additions and 7 deletions

View file

@ -74,6 +74,8 @@ in
]; ];
}; };
pipewire.enable = true;
wireguard = { wireguard = {
enable = false; enable = false;
iface = "wg"; iface = "wg";
@ -112,13 +114,6 @@ in
# TODO: remove when https://nixpk.gs/pr-tracker.html?pr=124237 reaches unstable # TODO: remove when https://nixpk.gs/pr-tracker.html?pr=124237 reaches unstable
nix.sandboxPaths = [ "/bin/sh=${pkgs.bash}/bin/sh" ]; nix.sandboxPaths = [ "/bin/sh=${pkgs.bash}/bin/sh" ];
sound.enable = true;
hardware.pulseaudio = {
enable = true;
extraModules = [ pkgs.pulseaudio-modules-bt ];
package = pkgs.pulseaudioFull;
};
hardware.bluetooth = { hardware.bluetooth = {
enable = true; enable = true;
powerOnBoot = true; powerOnBoot = true;

View file

@ -14,6 +14,7 @@
./monitoring.nix ./monitoring.nix
./nextcloud.nix ./nextcloud.nix
./nginx.nix ./nginx.nix
./pipewire.nix
./postgresql-backup.nix ./postgresql-backup.nix
./postgresql.nix ./postgresql.nix
./tgv.nix ./tgv.nix

68
services/pipewire.nix Normal file
View file

@ -0,0 +1,68 @@
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.my.services.pipewire;
my = config.my;
in
{
options.my.services.pipewire = {
enable = lib.mkEnableOption "Pipewire sound backend";
};
config = mkIf cfg.enable {
# from NixOS wiki, causes conflicts with pipewire
sound.enable = false;
# recommended for pipewire as well
security.rtkit.enable = true;
services.pipewire = {
enable = true;
alsa = {
enable = true;
support32Bit = true;
};
pulse.enable = true;
jack.enable = true;
media-session = {
enable = true;
config.bluez-monitor.rules = [
{
# Matches all cards
matches = [{ "device.name" = "~bluez_card.*"; }];
actions = {
"update-props" = {
"bluez5.reconnect-profiles" = [
"a2dp_sink"
"hfp_hf"
"hsp_hs"
];
# mSBC provides better audio + microphone
"bluez5.msbc-support" = true;
# SBC XQ provides better audio
"bluez5.sbc-xq-support" = true;
};
};
}
{
matches = [
# Matches all sources
{
"node.name" = "~bluez_input.*";
}
# Matches all outputs
{
"node.name" = "~bluez_output.*";
}
];
actions = {
"node.pause-on-idle" = false;
};
}
];
};
};
};
}