1
0
Fork 0
mirror of https://github.com/nix-community/home-manager.git synced 2025-11-08 19:46:05 +01:00

dconf: Provide dconf package and dbus service file

With the dconf package and its dbus service file provided by 
home-manager, there is no need for it to be provided by the system.
This commit is contained in:
Rosario Pulella 2025-05-15 11:42:24 -04:00 committed by Austin Horstman
parent c310818dca
commit ff73544e4a

View file

@ -33,8 +33,7 @@ in
options = { options = {
dconf = { dconf = {
enable = lib.mkOption { enable = lib.mkEnableOption "dconf" // {
type = types.bool;
# While technically dconf on darwin could work, our activation step # While technically dconf on darwin could work, our activation step
# requires dbus, which only *lightly* supports Darwin in general, and # requires dbus, which only *lightly* supports Darwin in general, and
# not at all in the way it's packaged in nixpkgs. Because of this, we # not at all in the way it's packaged in nixpkgs. Because of this, we
@ -43,14 +42,6 @@ in
# re-enabled, unclear whether there's actual value in it though. # re-enabled, unclear whether there's actual value in it though.
default = !pkgs.stdenv.hostPlatform.isDarwin; default = !pkgs.stdenv.hostPlatform.isDarwin;
visible = false; visible = false;
description = ''
Whether to enable dconf settings.
Note, if you use NixOS then you must add
`programs.dconf.enable = true`
to your system configuration. Otherwise you will see a systemd error
message when your configuration is activated.
'';
}; };
settings = lib.mkOption { settings = lib.mkOption {
@ -85,70 +76,76 @@ in
}; };
}; };
config = lib.mkIf (cfg.enable && cfg.settings != { }) { config = lib.mkIf cfg.enable (
# Make sure the dconf directory exists. {
xdg.configFile."dconf/.keep".source = builtins.toFile "keep" ""; home.packages = [ pkgs.dconf ];
dbus.packages = [ pkgs.dconf ];
}
// lib.mkIf (cfg.settings != { }) {
# Make sure the dconf directory exists.
xdg.configFile."dconf/.keep".source = builtins.toFile "keep" "";
home.extraBuilderCommands = '' home.extraBuilderCommands = ''
mkdir -p $out/state/ mkdir -p $out/state/
ln -s ${stateDconfKeys} $out/state/${stateDconfKeys.name} ln -s ${stateDconfKeys} $out/state/${stateDconfKeys.name}
''; '';
home.activation.dconfSettings = lib.hm.dag.entryAfter [ "installPackages" ] ( home.activation.dconfSettings = lib.hm.dag.entryAfter [ "installPackages" ] (
let let
iniFile = pkgs.writeText "hm-dconf.ini" (toDconfIni cfg.settings); iniFile = pkgs.writeText "hm-dconf.ini" (toDconfIni cfg.settings);
statePath = "state/${stateDconfKeys.name}"; statePath = "state/${stateDconfKeys.name}";
cleanup = pkgs.writeShellScript "dconf-cleanup" '' cleanup = pkgs.writeShellScript "dconf-cleanup" ''
set -euo pipefail set -euo pipefail
${config.lib.bash.initHomeManagerLib} ${config.lib.bash.initHomeManagerLib}
PATH=${ PATH=${
lib.makeBinPath [ lib.makeBinPath [
pkgs.dconf pkgs.dconf
pkgs.jq pkgs.jq
] ]
}''${PATH:+:}$PATH }''${PATH:+:}$PATH
oldState="$1" oldState="$1"
newState="$2" newState="$2"
# Can't do cleanup if we don't know the old state. # Can't do cleanup if we don't know the old state.
if [[ ! -f $oldState ]]; then if [[ ! -f $oldState ]]; then
exit 0 exit 0
fi
# Reset all keys that are present in the old generation but not the new
# one.
jq -r -n \
--slurpfile old "$oldState" \
--slurpfile new "$newState" \
'($old[] - $new[])[]' \
| while read -r key; do
verboseEcho "Resetting dconf key \"$key\""
run $DCONF_DBUS_RUN_SESSION dconf reset "$key"
done
'';
in
''
if [[ -v DBUS_SESSION_BUS_ADDRESS ]]; then
export DCONF_DBUS_RUN_SESSION=""
else
export DCONF_DBUS_RUN_SESSION="${pkgs.dbus}/bin/dbus-run-session --dbus-daemon=${pkgs.dbus}/bin/dbus-daemon"
fi fi
# Reset all keys that are present in the old generation but not the new if [[ -v oldGenPath ]]; then
# one. ${cleanup} \
jq -r -n \ "$oldGenPath/${statePath}" \
--slurpfile old "$oldState" \ "$newGenPath/${statePath}"
--slurpfile new "$newState" \ fi
'($old[] - $new[])[]' \
| while read -r key; do
verboseEcho "Resetting dconf key \"$key\""
run $DCONF_DBUS_RUN_SESSION dconf reset "$key"
done
'';
in
''
if [[ -v DBUS_SESSION_BUS_ADDRESS ]]; then
export DCONF_DBUS_RUN_SESSION=""
else
export DCONF_DBUS_RUN_SESSION="${pkgs.dbus}/bin/dbus-run-session --dbus-daemon=${pkgs.dbus}/bin/dbus-daemon"
fi
if [[ -v oldGenPath ]]; then run $DCONF_DBUS_RUN_SESSION ${pkgs.dconf}/bin/dconf load / < ${iniFile}
${cleanup} \
"$oldGenPath/${statePath}" \
"$newGenPath/${statePath}"
fi
run $DCONF_DBUS_RUN_SESSION ${pkgs.dconf}/bin/dconf load / < ${iniFile} unset DCONF_DBUS_RUN_SESSION
''
unset DCONF_DBUS_RUN_SESSION );
'' }
); );
};
} }