mirror of
https://github.com/nix-community/home-manager.git
synced 2025-03-31 04:04:32 +00:00
nixos-module: Fix potential recursion error between home-manager users and nixos users configuration
Pushing users.users.<name>.packages from matching home-manager users leads to a circular dependency when one attribute set is calculated from the other. A configuration pull approach replaces the previous one to break up the circular dependency. This new approach allows more flexibility in configuring both option sets, including calculating from each other. EXAMPLE; ```nix {lib, /* custom arg */ flake, config, ...}: { home-manager.useUserPackages = true; home-manager.users = builtins.intersectAttrs (lib.filterAttrs (_: v: v.isNormalUser) config.users.users) (flake.outputs.homeModules.users); } ``` EXAMPLE; ```nix {lib, /* custom arg */ flake, config, ...}: { home-manager.useUserPackages = true; home-manager.users = { inherit (flake.outputs.homeModules.users) demo-user; }; users.users = lib.mapAttrs (_: _: { isNormalUser = true; }) (lib.filterAttrs (_: v: v.programs.git.enable) config.home-manager.users); } ``` fixes #594
This commit is contained in:
parent
63e77d09a1
commit
aec4ee4c1a
1 changed files with 7 additions and 3 deletions
|
@ -50,6 +50,13 @@ let
|
|||
};
|
||||
|
||||
in {
|
||||
options.users.users = mkOption {
|
||||
type = types.attrsOf (types.submodule ({ name, config, ... }: {
|
||||
config.packages = mkIf ((config.enable or true) && cfg.useUserPackages
|
||||
&& lib.hasAttr name cfg.users) [ cfg.users.${name}.home.path ];
|
||||
}));
|
||||
};
|
||||
|
||||
options.home-manager = {
|
||||
useUserPackages = mkEnableOption ''
|
||||
installation of user packages through the
|
||||
|
@ -104,10 +111,7 @@ in {
|
|||
};
|
||||
|
||||
config = (lib.mkMerge [
|
||||
# Fix potential recursion when configuring home-manager users based on values in users.users #594
|
||||
(mkIf (cfg.useUserPackages && cfg.users != { }) {
|
||||
users.users = (lib.mapAttrs
|
||||
(_username: usercfg: { packages = [ usercfg.home.path ]; }) cfg.users);
|
||||
environment.pathsToLink = [ "/etc/profile.d" ];
|
||||
})
|
||||
(mkIf (cfg.users != { }) {
|
||||
|
|
Loading…
Add table
Reference in a new issue