flakelight/builtinModules/propagationModule.nix

48 lines
1.8 KiB
Nix
Raw Permalink Normal View History

# flakelight -- Framework for simplifying flake setup
# Copyright (C) 2023 Archit Gupta <archit@accelbread.com>
# SPDX-License-Identifier: MIT
# This provides a module that can be added to module systems nested inside of
# flakelight, for example NixOS or home-manager configurations.
{ lib, config, flakelight, moduleArgs, inputs, outputs, ... }:
let
inherit (lib) mapAttrs mkOption optional optionalAttrs;
2024-01-14 21:59:39 +01:00
inherit (flakelight) selectAttr;
inherit (flakelight.types) module;
flakeConfig = config;
in
{
options.propagationModule = mkOption { type = module; internal = true; };
config.propagationModule =
{ lib, pkgs, options, config, ... }:
2024-01-14 21:59:39 +01:00
let inherit (pkgs.stdenv.hostPlatform) system; in {
config = (optionalAttrs (options ? nixpkgs) {
nixpkgs = (optionalAttrs (options ? nixpkgs.overlays) {
# Forward overlays to NixOS/home-manager configurations
overlays = lib.mkOrder 10
(flakeConfig.withOverlays ++ [ flakeConfig.packageOverlay ]);
})
// (optionalAttrs (options ? nixpkgs.config) {
# Forward nixpkgs.config to NixOS/home-manager configurations
inherit (flakeConfig.nixpkgs) config;
});
})
// (optionalAttrs (options ? home-manager.sharedModules) {
# Propagate module to home-manager when using its nixos module
home-manager.sharedModules =
optional (! config.home-manager.useGlobalPkgs)
[ flakeConfig.propagationModule ];
})
// {
# Give access to flakelight module args under `flake` arg.
# Also include inputs'/outputs' which depend on `pkgs`.
_module.args.flake = {
2024-01-14 21:59:39 +01:00
inputs' = mapAttrs (_: selectAttr system) inputs;
outputs' = selectAttr system outputs;
} // moduleArgs;
};
};
}