2023-06-21 01:08:53 +00:00
|
|
|
self: { lib, config, pkgs, ... }: with lib; let
|
|
|
|
relativePath = path: assert types.path.check path;
|
2023-06-26 05:59:15 +00:00
|
|
|
with builtins; strings.removePrefix (toString self) (toString path);
|
2023-06-21 01:08:53 +00:00
|
|
|
|
|
|
|
impurityGroupEnabled = group: let
|
|
|
|
impurityGroups = strings.splitString " " (builtins.getEnv "IMPURITY_GROUPS");
|
|
|
|
in group == "" || builtins.elem group impurityGroups;
|
|
|
|
|
|
|
|
impurePath = let
|
|
|
|
impurePathEnv = builtins.getEnv "IMPURITY_PATH";
|
|
|
|
in if impurePathEnv == ""
|
|
|
|
then throw "impurity.enable is true but IMPURITY_PATH is not set"
|
2023-06-26 05:59:15 +00:00
|
|
|
else impurePathEnv;
|
|
|
|
|
|
|
|
createImpurePath = path: let
|
|
|
|
relative = (relativePath path);
|
|
|
|
full = impurePath + relative;
|
|
|
|
in pkgs.runCommand "impurity-${relative}" {} "ln -s ${full} $out";
|
2023-06-21 01:08:53 +00:00
|
|
|
|
|
|
|
in {
|
|
|
|
options.impurity.enable = mkOption {
|
|
|
|
type = types.bool;
|
|
|
|
default = false;
|
|
|
|
description = "Enable impure symlinks";
|
|
|
|
};
|
|
|
|
|
|
|
|
config._module.args.impurity = rec {
|
|
|
|
groupedLink = groupspec: path:
|
|
|
|
assert types.path.check path; let
|
|
|
|
groups =
|
|
|
|
if groupspec == null
|
|
|
|
then [ "" ]
|
|
|
|
else if (types.listOf types.string).check groupspec
|
|
|
|
then groupspec
|
|
|
|
else assert types.string.check groupspec;
|
|
|
|
strings.splitString " " groupspec;
|
|
|
|
in if config.impurity.enable && lists.any (group: impurityGroupEnabled group) groups
|
|
|
|
then createImpurePath path
|
|
|
|
else path;
|
|
|
|
|
|
|
|
link = path: groupedLink null path;
|
|
|
|
};
|
|
|
|
}
|