Compare commits

...

3 commits

Author SHA1 Message Date
0c0245a8b4
fix: use quad9 as DNS
private DNS inside of the tailnet breaks the connection occasionally
2024-12-19 12:58:20 +01:00
599a549540
chore: make use of ts injection 2024-12-19 12:57:41 +01:00
78e63a2044
feat: add beets 2024-12-19 12:57:31 +01:00
6 changed files with 109 additions and 18 deletions

85
home/terminal/beets.nix Normal file
View file

@ -0,0 +1,85 @@
{ pkgs, lib, ... }:
let
inherit (lib) concatStringsSep listToAttrs;
plugins = [
"convert"
"chroma"
"inline"
"fish"
"fetchart"
"lastgenre"
"scrub"
"duplicates"
"info"
"missing"
"unimported"
"badfiles"
];
in
{
config = {
programs.beets = {
package = pkgs.beets.override {
pluginOverrides = listToAttrs (
map (name: {
value.enable = true;
inherit name;
}) plugins
);
};
settings = {
plugins = concatStringsSep " " plugins;
per_disc_numbering = "yes";
asciify_paths = true;
convert = {
auto = "yes";
format = "flac";
never_convert_lossy_files = "yes";
};
fetchart = {
auto = true;
cover_format = "jpg";
maxwidth = 500;
minwidth = 500;
enforce_ratio = true;
high_resolution = true;
};
duplicates = {
count = true;
};
lastgenre = {
auto = "yes";
count = 5;
separator = ";";
};
replace = {
"[\\\\/]" = "_";
"^\\." = "_";
"[\\x00-\\x1f]" = "_";
"\\.$" = "_";
"\\s+$" = "";
"^\\s+" = "";
"^-" = "_";
};
import = {
incremental = "yes";
bell = "yes";
languages = "en";
};
item_fields = {
disc_and_track = "u'%02i.%02i' % (disc, track) if disctotal > 1 else u'%02i' % (track)";
primary_albumartist = # python
''
if albumartist.lower().strip().startswith(albumartists[0].lower().strip()):
return albumartists[0]
else:
return None
'';
};
paths = {
default = "%ifdef{primary_albumartist, $primary_albumartist, $albumartist}/$album%aunique{}/$disc_and_track - $artist - $title";
};
};
};
};
}

View file

@ -6,5 +6,6 @@
./fish ./fish
./btop.nix ./btop.nix
./hyfetch.nix ./hyfetch.nix
./beets.nix
]; ];
} }

View file

@ -9,23 +9,27 @@ in
clip = "wl-copy"; clip = "wl-copy";
}; };
functions = { functions = {
gitignore = "curl -sL https://www.gitignore.io/api/$argv"; gitignore = # fish
mv-bad-creation-date = '' "curl -sL https://www.gitignore.io/api/$argv";
${getExe' pkgs.exiftool "exiftool"} -if 'not $CreateDate' -p '$FileName' "$PWD/$argv[1]" | xargs -I {} mv -i "$PWD/$argv[1]/{}" "$argv[2]" mv-bad-creation-date = # fish
''; ''
rename-images = '' ${getExe' pkgs.exiftool "exiftool"} -if 'not $CreateDate' -p '$FileName' "$PWD/$argv[1]" | xargs -I {} mv -i "$PWD/$argv[1]/{}" "$argv[2]"
set -f input "$PWD/$argv[1]" '';
rename-images = # fish
''
set -f input "$PWD/$argv[1]"
if not test -d $input if not test -d $input
echo "input is not a directory" echo "input is not a directory"
else else
${getExe' pkgs.exiftool "exiftool"} -if '$CreateDate' -p '$FileName' "$input" | xargs -I {} jhead -n%Y-%m-%d-%H%M%S "$input/{}" ${getExe' pkgs.exiftool "exiftool"} -if '$CreateDate' -p '$FileName' "$input" | xargs -I {} jhead -n%Y-%m-%d-%H%M%S "$input/{}"
end end
''; '';
fish_prompt = builtins.readFile ./fish_prompt.fish; fish_prompt = builtins.readFile ./fish_prompt.fish;
revert = '' revert = # fish
env --chdir $HOME/.nixconf sudo nixos-rebuild switch --flake .#$(hostname) --rollback ''
''; env --chdir $HOME/.nixconf sudo nixos-rebuild switch --flake .#$(hostname) --rollback
'';
}; };
}; };
} }

View file

@ -82,7 +82,7 @@
sway.enable = true; sway.enable = true;
hyprland.enable = true; hyprland.enable = true;
pulseview.enable = true; pulseview.enable = true;
steam.enable = true;
gnupg.agent = { gnupg.agent = {
enable = true; enable = true;
enableSSHSupport = true; enableSSHSupport = true;

View file

@ -30,7 +30,7 @@
enable = true; enable = true;
nix-direnv.enable = true; nix-direnv.enable = true;
}; };
beets.enable = true;
waybar.enable = true; waybar.enable = true;
rofi.enable = true; rofi.enable = true;
vscode.enable = true; vscode.enable = true;

View file

@ -6,7 +6,8 @@
base_domain = "ts"; base_domain = "ts";
nameservers.global = [ nameservers.global = [
"100.64.0.4" #"100.64.0.4"
"9.9.9.9"
]; ];
extra_records = extra_records =