beets: add mpdIntegration (#3755)

Allow configuration of mpdstats and mpdupdate plugins for Beets using
Home Manager.

Signed-off-by: Sefa Eyeoglu <contact@scrumplex.net>
This commit is contained in:
Sefa Eyeoglu 2023-05-11 14:03:54 +02:00 committed by GitHub
parent f714b17031
commit 622fa73725
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
12 changed files with 170 additions and 7 deletions

3
.github/CODEOWNERS vendored
View file

@ -84,7 +84,8 @@ Makefile @thiagokokada
/modules/programs/bat.nix @marsam /modules/programs/bat.nix @marsam
/modules/programs/beets.nix @rycee /modules/programs/beets.nix @rycee @Scrumplex
/tests/modules/programs/beets @Scrumplex
/modules/programs/bottom.nix @polykernel /modules/programs/bottom.nix @polykernel
/tests/modules/programs/bottom @polykernel /tests/modules/programs/bottom @polykernel

View file

@ -9,7 +9,7 @@ let
yamlFormat = pkgs.formats.yaml { }; yamlFormat = pkgs.formats.yaml { };
in { in {
meta.maintainers = [ maintainers.rycee ]; meta.maintainers = with maintainers; [ rycee Scrumplex ];
options = { options = {
programs.beets = { programs.beets = {
@ -48,13 +48,56 @@ in {
<filename>$XDG_CONFIG_HOME/beets/config.yaml</filename> <filename>$XDG_CONFIG_HOME/beets/config.yaml</filename>
''; '';
}; };
mpdIntegration = {
enableStats = mkEnableOption "mpdstats plugin and service";
enableUpdate = mkEnableOption "mpdupdate plugin";
host = mkOption {
type = types.str;
default = "localhost";
description = "Host mpdstats will connect to";
example = "10.0.0.42";
};
port = mkOption {
type = types.port;
default = config.services.mpd.network.port;
defaultText = literalExpression "config.services.mpd.network.port";
description = "Port mpdstats will connect to";
example = 6601;
};
};
}; };
}; };
config = mkIf cfg.enable { config = mkMerge [
home.packages = [ cfg.package ]; (mkIf cfg.enable {
home.packages = [ cfg.package ];
xdg.configFile."beets/config.yaml".source = xdg.configFile."beets/config.yaml".source =
yamlFormat.generate "beets-config" cfg.settings; yamlFormat.generate "beets-config" cfg.settings;
}; })
(mkIf (cfg.mpdIntegration.enableStats || cfg.mpdIntegration.enableUpdate) {
programs.beets.settings.mpd = {
host = cfg.mpdIntegration.host;
port = cfg.mpdIntegration.port;
};
})
(mkIf cfg.mpdIntegration.enableStats {
programs.beets.settings.plugins = [ "mpdstats" ];
})
(mkIf cfg.mpdIntegration.enableUpdate {
programs.beets.settings.plugins = [ "mpdupdate" ];
})
(mkIf (cfg.enable && cfg.mpdIntegration.enableStats) {
systemd.user.services."beets-mpdstats" = {
Unit = {
Description = "Beets MPDStats daemon";
After = optional config.services.mpd.enable "mpd.service";
Requires = optional config.services.mpd.enable "mpd.service";
};
Service.ExecStart = "${cfg.package}/bin/beet mpdstats";
Install.WantedBy = [ "default.target" ];
};
})
];
} }

View file

@ -152,6 +152,7 @@ import nmt {
./modules/misc/xsession ./modules/misc/xsession
./modules/programs/abook ./modules/programs/abook
./modules/programs/autorandr ./modules/programs/autorandr
./modules/programs/beets # One test relies on services.mpd
./modules/programs/borgmatic ./modules/programs/borgmatic
./modules/programs/firefox ./modules/programs/firefox
./modules/programs/foot ./modules/programs/foot

View file

@ -0,0 +1,5 @@
{
beets-mpdstats = ./mpdstats.nix;
beets-mpdstats-external = ./mpdstats-external.nix;
beets-mpdupdate = ./mpdupdate.nix;
}

View file

@ -0,0 +1,10 @@
[Install]
WantedBy=default.target
[Service]
ExecStart=@beets@/bin/beet mpdstats
[Unit]
After=mpd.service
Description=Beets MPDStats daemon
Requires=mpd.service

View file

@ -0,0 +1,5 @@
mpd:
host: localhost
port: 4242
plugins:
- mpdstats

View file

@ -0,0 +1,8 @@
[Install]
WantedBy=default.target
[Service]
ExecStart=@beets@/bin/beet mpdstats
[Unit]
Description=Beets MPDStats daemon

View file

@ -0,0 +1,5 @@
mpd:
host: 10.0.0.42
port: 6601
plugins:
- mpdstats

View file

@ -0,0 +1,29 @@
{ config, lib, pkgs, ... }:
{
config = {
home.stateVersion = "23.05";
programs.beets = {
enable = true;
package = config.lib.test.mkStubPackage { outPath = "@beets@"; };
mpdIntegration = {
enableStats = true;
host = "10.0.0.42";
port = 6601;
};
};
nmt.script = ''
assertFileExists home-files/.config/beets/config.yaml
assertFileContent \
home-files/.config/beets/config.yaml \
${./mpdstats-external-expected.yaml}
assertFileExists home-files/.config/systemd/user/beets-mpdstats.service
assertFileContent \
home-files/.config/systemd/user/beets-mpdstats.service \
${./mpdstats-external-expected.service}
'';
};
}

View file

@ -0,0 +1,31 @@
{ config, lib, pkgs, ... }:
{
config = {
home.stateVersion = "23.05";
services.mpd = {
enable = true;
musicDirectory = "/my/music/dir";
network.port = 4242;
};
programs.beets = {
enable = true;
package = config.lib.test.mkStubPackage { outPath = "@beets@"; };
mpdIntegration.enableStats = true;
};
nmt.script = ''
assertFileExists home-files/.config/beets/config.yaml
assertFileContent \
home-files/.config/beets/config.yaml \
${./mpdstats-expected.yaml}
assertFileExists home-files/.config/systemd/user/beets-mpdstats.service
assertFileContent \
home-files/.config/systemd/user/beets-mpdstats.service \
${./mpdstats-expected.service}
'';
};
}

View file

@ -0,0 +1,5 @@
mpd:
host: localhost
port: 6600
plugins:
- mpdupdate

View file

@ -0,0 +1,20 @@
{ config, lib, pkgs, ... }:
{
config = {
home.stateVersion = "23.05";
programs.beets = {
enable = true;
package = config.lib.test.mkStubPackage { outPath = "@beets@"; };
mpdIntegration.enableUpdate = true;
};
nmt.script = ''
assertFileExists home-files/.config/beets/config.yaml
assertFileContent \
home-files/.config/beets/config.yaml \
${./mpdupdate-expected.yaml}
'';
};
}