devos/hosts/default.nix

91 lines
2 KiB
Nix
Raw Normal View History

{ extern
, home
, lib
, nixos
, nixos-hardware
, override
, pkgs
, self
, system
, ...
}:
let
inherit (lib.flk) recImport nixosSystemExtended defaultImports;
2020-01-04 06:06:31 +01:00
inherit (builtins) attrValues removeAttrs;
2021-02-06 21:26:17 +01:00
suites = import ../suites { inherit lib; };
config = hostName:
2021-01-28 03:11:38 +01:00
nixosSystemExtended {
inherit system;
2021-02-05 07:42:46 +01:00
specialArgs = extern.specialArgs // { inherit suites; };
2020-12-31 21:42:49 +01:00
2020-07-31 06:17:28 +02:00
modules =
let
core = ../profiles/core;
2020-07-31 06:17:28 +02:00
2021-02-14 03:38:20 +01:00
modOverrides = { config, overrideModulesPath, ... }:
let
2021-02-14 03:38:20 +01:00
overrides = import ../overrides;
inherit (overrides) modules disabledModules;
in
{
disabledModules = modules ++ disabledModules;
imports = map
2021-02-14 03:38:20 +01:00
(path: "${overrideModulesPath}/${path}")
modules;
};
global = {
home-manager.useGlobalPkgs = true;
home-manager.useUserPackages = true;
2020-07-31 06:17:28 +02:00
hardware.enableRedistributableFirmware = lib.mkDefault true;
2020-07-31 06:17:28 +02:00
networking.hostName = hostName;
2020-08-04 08:11:08 +02:00
nix.nixPath = [
"nixpkgs=${nixos}"
"nixos-config=${self}/compat/nixos"
"home-manager=${home}"
];
nixpkgs = { inherit pkgs; };
nix.registry = {
devos.flake = self;
nixos.flake = nixos;
override.flake = override;
};
system.configurationRevision = lib.mkIf (self ? rev) self.rev;
};
2021-02-04 00:41:21 +01:00
local = {
require = [
(import "${toString ./.}/${hostName}.nix")
];
};
2020-07-31 06:17:28 +02:00
# Everything in `./modules/list.nix`.
flakeModules =
attrValues self.nixosModules;
2020-07-31 06:17:28 +02:00
in
2020-12-31 22:11:32 +01:00
flakeModules ++ [
core
global
local
modOverrides
] ++ extern.modules;
};
2020-01-04 06:06:31 +01:00
hosts = recImport {
dir = ./.;
_import = config;
};
2020-07-31 06:17:28 +02:00
in
hosts