115 lines
3.1 KiB
Nix
115 lines
3.1 KiB
Nix
{
|
|
description = "sonja - nixos configs - custom packages - home manager";
|
|
|
|
inputs = {
|
|
lib-aggregate.url = "github:nix-community/lib-aggregate";
|
|
|
|
cmpkgs.url = "github:nixos/nixpkgs?ref=nixos-unstable";
|
|
nixpkgs-unstable.url = "github:nixos/nixpkgs?ref=nixpkgs-unstable";
|
|
|
|
home-manager = {
|
|
url = "github:nix-community/home-manager?ref=master";
|
|
inputs.nixpkgs.follows = "cmpkgs";
|
|
};
|
|
|
|
nixos-hardware.url = "github:NixOS/nixos-hardware";
|
|
|
|
sops-nix = {
|
|
url = "github:Mic92/sops-nix/master";
|
|
inputs.nixpkgs.follows = "cmpkgs";
|
|
};
|
|
|
|
disko = {
|
|
url = "github:nix-community/disko";
|
|
inputs.nixpkgs.follows = "cmpkgs";
|
|
};
|
|
};
|
|
|
|
outputs = inputs:
|
|
let
|
|
defaultSystems = [ "x86_64-linux" ];
|
|
|
|
lib = inputs.lib-aggregate.lib;
|
|
|
|
importPkgs = npkgs: extraCfg:
|
|
lib.genAttrs defaultSystems (system:
|
|
import npkgs {
|
|
inherit system;
|
|
config = { allowAliases = false; } // extraCfg;
|
|
}
|
|
);
|
|
|
|
pkgs = importPkgs inputs.cmpkgs { };
|
|
pkgsUnfree = importPkgs inputs.cmpkgs { allowUnfree = true; };
|
|
|
|
mkSystem = n: _v:
|
|
let
|
|
defaults = {
|
|
npkgs = inputs.cmpkgs;
|
|
path = ./hosts/${n}/configuration.nix;
|
|
extraModules = [ ];
|
|
};
|
|
v = defaults // _v;
|
|
in
|
|
v.npkgs.lib.nixosSystem {
|
|
modules = [
|
|
v.path
|
|
inputs.home-manager.nixosModules.home-manager
|
|
inputs.disko.nixosModules.disko
|
|
inputs.sops-nix.nixosModules.sops
|
|
] ++ v.extraModules;
|
|
specialArgs = { inherit inputs; };
|
|
};
|
|
|
|
mkIso = n: _v:
|
|
let
|
|
defaults = {
|
|
npkgs = inputs.cmpkgs;
|
|
path = ./hosts/${n}/configuration.nix;
|
|
};
|
|
v = defaults // _v;
|
|
in
|
|
v.npkgs.lib.nixosSystem {
|
|
modules = [ v.path ];
|
|
specialArgs = { inherit inputs; };
|
|
};
|
|
|
|
## Top-level nixos configs, keyed by system
|
|
nixosConfigsEx = {
|
|
"x86_64-linux" = {
|
|
coven = { };
|
|
# circle = { };
|
|
};
|
|
};
|
|
|
|
nixosConfigs = lib.foldl' (op: nul: nul // op) { } (lib.attrValues nixosConfigsEx);
|
|
nixosConfigurations = lib.mapAttrs (n: v: mkSystem n v) nixosConfigs // {
|
|
iso = mkIso "iso" { };
|
|
};
|
|
toplevels = lib.mapAttrs (_: v: v.config.system.build.toplevel) nixosConfigurations;
|
|
|
|
nixosModules = { };
|
|
overlays = { };
|
|
|
|
in
|
|
lib.recursiveUpdate
|
|
{
|
|
inherit nixosConfigs nixosConfigsEx nixosConfigurations toplevels;
|
|
inherit nixosModules overlays;
|
|
inherit pkgs pkgsUnfree;
|
|
}
|
|
(lib.flake-utils.eachSystem defaultSystems (system:
|
|
{
|
|
formatter = pkgs.${system}.nixfmt;
|
|
|
|
checks =
|
|
let
|
|
c_toplevels = lib.mapAttrs'
|
|
(n: v: lib.nameValuePair "toplevel-${n}" v.config.system.build.toplevel)
|
|
(lib.mapAttrs (n: v: mkSystem n v) nixosConfigsEx.${system});
|
|
in
|
|
c_toplevels;
|
|
}
|
|
));
|
|
}
|