Remove features
All checks were successful
/ check (push) Successful in 1m21s

This commit is contained in:
Oliver Davies 2025-05-03 16:50:27 +01:00
parent 54954d6223
commit 54b43e4203
58 changed files with 224 additions and 242 deletions

View file

@ -3,7 +3,6 @@
{ {
imports = [ ../common ]; imports = [ ../common ];
features = {
cli = { cli = {
direnv.enable = true; direnv.enable = true;
fzf.enable = true; fzf.enable = true;
@ -28,7 +27,7 @@
repos = extraConfig.XDG_REPOS_DIR; repos = extraConfig.XDG_REPOS_DIR;
in in
options.features.cli.tmux-sessionizer.directories.default options.cli.tmux-sessionizer.directories.default
++ [ ++ [
repos repos
"${repos}/*" "${repos}/*"
@ -43,7 +42,6 @@
neovim.enable = true; neovim.enable = true;
phpactor.enable = true; phpactor.enable = true;
}; };
};
xdg.configFile."pam-gnupg".text = '' xdg.configFile."pam-gnupg".text = ''
C0D940F9A390F286FCAAE8439D501171E39D0A47 C0D940F9A390F286FCAAE8439D501171E39D0A47

View file

@ -1,7 +1,6 @@
{ {
imports = [ ../common ]; imports = [ ../common ];
features = {
cli.zsh.enable = true; cli.zsh.enable = true;
desktop.media = { desktop.media = {
@ -9,5 +8,4 @@
makemkv.enable = true; makemkv.enable = true;
mpv.enable = true; mpv.enable = true;
}; };
};
} }

View file

@ -1,11 +1,9 @@
{ {
imports = [ ../common ]; imports = [ ../common ];
features = {
cli = { cli = {
fzf.enable = true; fzf.enable = true;
starship.enable = true; starship.enable = true;
zsh.enable = true; zsh.enable = true;
}; };
};
} }

View file

@ -3,7 +3,6 @@
{ {
imports = [ ../common ]; imports = [ ../common ];
features = {
cli = { cli = {
bluetuith.enable = true; bluetuith.enable = true;
direnv.enable = true; direnv.enable = true;
@ -30,7 +29,7 @@
repos = extraConfig.XDG_REPOS_DIR; repos = extraConfig.XDG_REPOS_DIR;
in in
options.features.cli.tmux-sessionizer.directories.default options.cli.tmux-sessionizer.directories.default
++ [ ++ [
repos repos
"${repos}/*" "${repos}/*"
@ -66,7 +65,6 @@
mpv.enable = true; mpv.enable = true;
}; };
}; };
};
programs.dev-commit = { programs.dev-commit = {
enable = true; enable = true;

View file

@ -7,12 +7,10 @@
./modules/wiki.nix ./modules/wiki.nix
]; ];
features = {
cli = { cli = {
docker.enable = true; docker.enable = true;
password-store.enable = true; password-store.enable = true;
}; };
};
wsl = { wsl = {
enable = true; enable = true;

View file

@ -11,14 +11,12 @@
../../users/eric.nix ../../users/eric.nix
]; ];
features = {
core = { core = {
bluetooth.enable = true; bluetooth.enable = true;
zram.enable = true; zram.enable = true;
}; };
desktop.media.makemkv.enable = true; desktop.media.makemkv.enable = true;
};
# Bootloader. # Bootloader.
boot = { boot = {

View file

@ -16,11 +16,9 @@
../../users/opdavies.nix ../../users/opdavies.nix
]; ];
features = {
core.openssh.enable = true; core.openssh.enable = true;
cli.podman.enable = true; cli.podman.enable = true;
desktop.dconf.enable = true; desktop.dconf.enable = true;
};
services.logind.lidSwitchExternalPower = "ignore"; services.logind.lidSwitchExternalPower = "ignore";

View file

@ -3,7 +3,7 @@
postgresqlBackup.enable = true; postgresqlBackup.enable = true;
}; };
features.homelab = { homelab = {
enable = true; enable = true;
domain = "oliverdavies.uk"; domain = "oliverdavies.uk";

View file

@ -4,11 +4,11 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
service = "audiobookshelf"; service = "audiobookshelf";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
url = mkOption { url = mkOption {

View file

@ -10,10 +10,10 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
service = "tubearchivist"; service = "tubearchivist";
homelab = config.features.homelab; homelab = config.homelab;
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
port = mkOption { port = mkOption {

View file

@ -3,7 +3,7 @@
with lib; with lib;
{ {
options.features.homelab = { options.homelab = {
enable = mkEnableOption "Enable homelab services and configuration"; enable = mkEnableOption "Enable homelab services and configuration";
domain = mkOption { domain = mkOption {

View file

@ -4,11 +4,11 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
service = "forgejo"; service = "forgejo";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
url = mkOption { url = mkOption {

View file

@ -9,11 +9,11 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
service = "immich"; service = "immich";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
url = mkOption { url = mkOption {

View file

@ -4,11 +4,11 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
service = "jellyfin"; service = "jellyfin";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
url = mkOption { url = mkOption {

View file

@ -4,11 +4,11 @@ with lib;
let let
cfg = homelab.services.paperless; cfg = homelab.services.paperless;
homelab = config.features.homelab; homelab = config.homelab;
service = "paperless"; service = "paperless";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
url = mkOption { url = mkOption {

View file

@ -9,12 +9,12 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
opts = options.services.${service}; opts = options.services.${service};
service = "homepage-dashboard"; service = "homepage-dashboard";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
port = mkOption { port = mkOption {

View file

@ -3,7 +3,7 @@
with lib; with lib;
let let
homelab = config.features.homelab.services; homelab = config.homelab.services;
homepageCategories = [ homepageCategories = [
"Media" "Media"

View file

@ -4,11 +4,11 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
service = "uptime-kuma"; service = "uptime-kuma";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
url = mkOption { url = mkOption {

View file

@ -9,11 +9,11 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
service = "vaultwarden"; service = "vaultwarden";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
url = mkOption { url = mkOption {

View file

@ -12,7 +12,6 @@
../../users/opdavies.nix ../../users/opdavies.nix
]; ];
features = {
cli.password-store = { cli.password-store = {
enable = true; enable = true;
@ -39,7 +38,6 @@
st.enable = true; st.enable = true;
thunar.enable = true; thunar.enable = true;
}; };
};
boot = { boot = {
loader = { loader = {

View file

@ -14,14 +14,12 @@
../../users/opdavies.nix ../../users/opdavies.nix
]; ];
features = {
core = { core = {
bluetooth.enable = true; bluetooth.enable = true;
zram.enable = true; zram.enable = true;
}; };
desktop.dconf.enable = true; desktop.dconf.enable = true;
};
boot = { boot = {
loader = { loader = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.redshift; cfg = config.redshift;
in in
{ {
options.features.redshift.enable = mkEnableOption "Enable redshift"; options.redshift.enable = mkEnableOption "Enable redshift";
config = mkIf cfg.enable { config = mkIf cfg.enable {
location = { location = {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.cli.bluetuith; cfg = config.cli.bluetuith;
in in
{ {
options.features.cli.bluetuith.enable = mkEnableOption "Enable bluetuith"; options.cli.bluetuith.enable = mkEnableOption "Enable bluetuith";
config = mkIf cfg.enable { config = mkIf cfg.enable {
home.packages = with pkgs; [ home.packages = with pkgs; [

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.cli.direnv; cfg = config.cli.direnv;
in in
{ {
options.features.cli.direnv.enable = mkEnableOption "Enable direnv"; options.cli.direnv.enable = mkEnableOption "Enable direnv";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.direnv = { programs.direnv = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.cli.fzf; cfg = config.cli.fzf;
in in
{ {
options.features.cli.fzf.enable = mkEnableOption "Enable fzf"; options.cli.fzf.enable = mkEnableOption "Enable fzf";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.fzf = { programs.fzf = {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.cli.git; cfg = config.cli.git;
in in
{ {
options.features.cli.git = { options.cli.git = {
enable = mkEnableOption "Enable git"; enable = mkEnableOption "Enable git";
user = mkOption { user = mkOption {

View file

@ -3,12 +3,12 @@
with lib; with lib;
let let
cfg = config.features.cli.node; cfg = config.cli.node;
inherit (config.xdg) configHome dataHome stateHome; inherit (config.xdg) configHome dataHome stateHome;
in in
{ {
options.features.cli.node.enable = mkEnableOption "Enable node"; options.cli.node.enable = mkEnableOption "Enable node";
config = mkIf cfg.enable { config = mkIf cfg.enable {
xdg.configFile."${config.home.sessionVariables.NPM_CONFIG_USERCONFIG}".text = '' xdg.configFile."${config.home.sessionVariables.NPM_CONFIG_USERCONFIG}".text = ''

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.cli.notes; cfg = config.cli.notes;
in in
{ {
options.features.cli.notes.enable = mkEnableOption "Enable notes"; options.cli.notes.enable = mkEnableOption "Enable notes";
config = mkIf cfg.enable { config = mkIf cfg.enable {
xdg = { xdg = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.cli.ranger; cfg = config.cli.ranger;
in in
{ {
options.features.cli.ranger.enable = mkEnableOption "Enable ranger"; options.cli.ranger.enable = mkEnableOption "Enable ranger";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.ranger.enable = true; programs.ranger.enable = true;

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.cli.starship; cfg = config.cli.starship;
in in
{ {
options.features.cli.starship.enable = mkEnableOption "Enable starship"; options.cli.starship.enable = mkEnableOption "Enable starship";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.starship = programs.starship =

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.cli.tmux-sessionizer; cfg = config.cli.tmux-sessionizer;
in in
{ {
options.features.cli.tmux-sessionizer = { options.cli.tmux-sessionizer = {
enable = mkEnableOption "Enable tmux-sessionizer"; enable = mkEnableOption "Enable tmux-sessionizer";
directories = mkOption { directories = mkOption {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.cli.tmux; cfg = config.cli.tmux;
in in
{ {
options.features.cli.tmux.enable = mkEnableOption "Enable tmux"; options.cli.tmux.enable = mkEnableOption "Enable tmux";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.tmux = { programs.tmux = {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.cli.zsh; cfg = config.cli.zsh;
in in
{ {
options.features.cli.zsh.enable = mkEnableOption "Enable zsh"; options.cli.zsh.enable = mkEnableOption "Enable zsh";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.zsh = { programs.zsh = {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.coding.neovim; cfg = config.coding.neovim;
in in
{ {
options.features.coding.neovim.enable = mkEnableOption "Enable neovim"; options.coding.neovim.enable = mkEnableOption "Enable neovim";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.neovim = programs.neovim =

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.coding.phpactor; cfg = config.coding.phpactor;
in in
{ {
options.features.coding.phpactor.enable = lib.mkEnableOption "Enable phpactor"; options.coding.phpactor.enable = lib.mkEnableOption "Enable phpactor";
config = mkIf cfg.enable { config = mkIf cfg.enable {
home.packages = with pkgs; [ home.packages = with pkgs; [

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.browsers.firefox; cfg = config.desktop.browsers.firefox;
in in
{ {
options.features.desktop.browsers.firefox = { options.desktop.browsers.firefox = {
enable = mkEnableOption "Enable firefox"; enable = mkEnableOption "Enable firefox";
homepageUrl = mkOption { homepageUrl = mkOption {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.browsers.qutebrowser; cfg = config.desktop.browsers.qutebrowser;
in in
{ {
options.features.desktop.browsers.qutebrowser.enable = options.desktop.browsers.qutebrowser.enable =
mkEnableOption "Enable qutebrowser"; mkEnableOption "Enable qutebrowser";
config = mkIf cfg.enable { config = mkIf cfg.enable {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.flameshot; cfg = config.desktop.flameshot;
in in
{ {
options.features.desktop.flameshot.enable = mkEnableOption "Enable flameshot"; options.desktop.flameshot.enable = mkEnableOption "Enable flameshot";
config = mkIf cfg.enable { config = mkIf cfg.enable {
services.flameshot = { services.flameshot = {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.gtk; cfg = config.desktop.gtk;
in in
{ {
options.features.desktop.gtk.enable = mkEnableOption "Enable gtk"; options.desktop.gtk.enable = mkEnableOption "Enable gtk";
config = mkIf cfg.enable { config = mkIf cfg.enable {
gtk = with pkgs; { gtk = with pkgs; {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.media.handbrake; cfg = config.desktop.media.handbrake;
in in
{ {
options.features.desktop.media.handbrake.enable = mkEnableOption "Enable handbrake"; options.desktop.media.handbrake.enable = mkEnableOption "Enable handbrake";
config = mkIf cfg.enable { config = mkIf cfg.enable {
home.packages = with pkgs; [ home.packages = with pkgs; [

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.media.makemkv; cfg = config.desktop.media.makemkv;
in in
{ {
options.features.desktop.media.makemkv.enable = mkEnableOption "Enable makemkv"; options.desktop.media.makemkv.enable = mkEnableOption "Enable makemkv";
config = mkIf cfg.enable { config = mkIf cfg.enable {
home.packages = with pkgs; [ home.packages = with pkgs; [

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.media.mpv; cfg = config.desktop.media.mpv;
in in
{ {
options.features.desktop.media.mpv.enable = mkEnableOption "Enable mpv"; options.desktop.media.mpv.enable = mkEnableOption "Enable mpv";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.mpv = { programs.mpv = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.cli.docker; cfg = config.cli.docker;
in in
{ {
options.features.cli.docker.enable = mkEnableOption "Enable docker"; options.cli.docker.enable = mkEnableOption "Enable docker";
config = mkIf cfg.enable { config = mkIf cfg.enable {
virtualisation = { virtualisation = {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.cli.password-store; cfg = config.cli.password-store;
in in
{ {
options.features.cli.password-store = { options.cli.password-store = {
enable = mkEnableOption "Enable pass"; enable = mkEnableOption "Enable pass";
extensions = mkOption { extensions = mkOption {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.cli.podman; cfg = config.cli.podman;
in in
{ {
options.features.cli.podman.enable = mkEnableOption "Enable podman"; options.cli.podman.enable = mkEnableOption "Enable podman";
config = mkIf cfg.enable { config = mkIf cfg.enable {
virtualisation = { virtualisation = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.core.bluetooth; cfg = config.core.bluetooth;
in in
{ {
options.features.core.bluetooth.enable = mkEnableOption "Enable bluetooth"; options.core.bluetooth.enable = mkEnableOption "Enable bluetooth";
config = mkIf cfg.enable { config = mkIf cfg.enable {
hardware.bluetooth.enable = true; hardware.bluetooth.enable = true;

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.core.openssh; cfg = config.core.openssh;
in in
{ {
options.features.core.openssh.enable = mkEnableOption "Enable openssh"; options.core.openssh.enable = mkEnableOption "Enable openssh";
config = mkIf cfg.enable { config = mkIf cfg.enable {
services.openssh = { services.openssh = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.core.pipewire; cfg = config.core.pipewire;
in in
{ {
options.features.core.pipewire.enable = mkEnableOption "Enable pipewire"; options.core.pipewire.enable = mkEnableOption "Enable pipewire";
config = mkIf cfg.enable { config = mkIf cfg.enable {
services.pipewire = { services.pipewire = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.core.xbanish; cfg = config.core.xbanish;
in in
{ {
options.features.core.xbanish.enable = mkEnableOption "Enable xbanish"; options.core.xbanish.enable = mkEnableOption "Enable xbanish";
config = mkIf cfg.enable { config = mkIf cfg.enable {
services.xbanish.enable = true; services.xbanish.enable = true;

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.core.zram; cfg = config.core.zram;
in in
{ {
options.features.core.zram.enable = mkEnableOption "Enable zram"; options.core.zram.enable = mkEnableOption "Enable zram";
config = mkIf cfg.enable { config = mkIf cfg.enable {
zramSwap = { zramSwap = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.dconf; cfg = config.desktop.dconf;
in in
{ {
options.features.desktop.dconf.enable = mkEnableOption "Enable dconf"; options.desktop.dconf.enable = mkEnableOption "Enable dconf";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.dconf.enable = true; programs.dconf.enable = true;

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.dwm; cfg = config.desktop.dwm;
in in
{ {
options.features.desktop.dwm.enable = mkEnableOption "Enable dwm"; options.desktop.dwm.enable = mkEnableOption "Enable dwm";
config = mkIf cfg.enable { config = mkIf cfg.enable {
services = { services = {

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.fonts; cfg = config.desktop.fonts;
in in
{ {
options.features.desktop.fonts.enable = mkEnableOption "Enable fonts"; options.desktop.fonts.enable = mkEnableOption "Enable fonts";
config = mkIf cfg.enable { config = mkIf cfg.enable {
fonts = { fonts = {

View file

@ -3,10 +3,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.media.makemkv; cfg = config.desktop.media.makemkv;
in in
{ {
options.features.desktop.media.makemkv.enable = mkEnableOption "Enable makemkv"; options.desktop.media.makemkv.enable = mkEnableOption "Enable makemkv";
config = mkIf cfg.enable { config = mkIf cfg.enable {
boot.kernelModules = [ "sg" ]; boot.kernelModules = [ "sg" ];

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.st; cfg = config.desktop.st;
in in
{ {
options.features.desktop.st.enable = mkEnableOption "Enable st"; options.desktop.st.enable = mkEnableOption "Enable st";
config = mkIf cfg.enable { config = mkIf cfg.enable {
environment.systemPackages = with pkgs; [ environment.systemPackages = with pkgs; [

View file

@ -8,10 +8,10 @@
with lib; with lib;
let let
cfg = config.features.desktop.thunar; cfg = config.desktop.thunar;
in in
{ {
options.features.desktop.thunar.enable = mkEnableOption "Enable thunar"; options.desktop.thunar.enable = mkEnableOption "Enable thunar";
config = mkIf cfg.enable { config = mkIf cfg.enable {
programs.thunar = { programs.thunar = {

View file

@ -10,11 +10,11 @@ with lib;
let let
cfg = homelab.services.${service}; cfg = homelab.services.${service};
homelab = config.features.homelab; homelab = config.homelab;
service = "gitea-actions-runner"; service = "gitea-actions-runner";
in in
{ {
options.features.homelab.services.${service} = { options.homelab.services.${service} = {
enable = mkEnableOption "Enable ${service}"; enable = mkEnableOption "Enable ${service}";
}; };

View file

@ -18,8 +18,8 @@ with lib;
"networkmanager" "networkmanager"
"wheel" "wheel"
] ]
++ optional config.features.cli.docker.enable "docker" ++ optional config.cli.docker.enable "docker"
++ optional config.features.cli.podman.enable "podman"; ++ optional config.cli.podman.enable "podman";
packages = with pkgs; [ packages = with pkgs; [
qrencode qrencode