nibylandia/flake.nix

150 lines
4.7 KiB
Nix
Raw Normal View History

2023-09-03 11:35:16 +00:00
{
description = "Nibylandia configurations";
inputs = {
2023-10-09 12:37:47 +00:00
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
2023-09-03 11:35:16 +00:00
home-manager.url = "github:nix-community/home-manager";
nix-colors.url = "github:misterio77/nix-colors";
nix-formatter-pack.url = "github:Gerschtli/nix-formatter-pack";
nix-index-database.url = "github:Mic92/nix-index-database";
deploy-rs.url = "github:serokell/deploy-rs";
2023-10-09 12:37:47 +00:00
microvm.url = "github:astro/microvm.nix";
colmena = {
url = "github:zhaofengli/colmena/main";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-09-03 11:35:16 +00:00
agenix = {
url = "github:ryantm/agenix";
inputs.darwin.follows = "";
};
lanzaboote = {
url = "github:nix-community/lanzaboote";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-10-14 21:24:33 +00:00
simple-nixos-mailserver = {
url = "gitlab:simple-nixos-mailserver/nixos-mailserver";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-09-03 11:35:16 +00:00
};
outputs = { self, nixpkgs, nix-formatter-pack, nix-index-database, deploy-rs
, agenix, lanzaboote, microvm, simple-nixos-mailserver, colmena, ...
}@inputs:
2023-10-08 23:21:05 +00:00
let
systems = [ "x86_64-linux" "aarch64-linux" ];
forAllSystems = nixpkgs.lib.genAttrs systems;
2023-10-08 23:21:05 +00:00
pkgsForDeploy =
forAllSystems (system: import nixpkgs { inherit system; });
deployPkgs = forAllSystems (system:
let pkgs = pkgsForDeploy.${system};
in import nixpkgs {
inherit system;
overlays = [
deploy-rs.overlay
(self: super: {
deploy-rs = {
inherit (pkgs) deploy-rs;
inherit (super.deploy-rs) lib;
};
})
];
});
inherit (nixpkgs) lib;
2023-09-03 11:35:16 +00:00
in {
formatter = forAllSystems (system:
nix-formatter-pack.lib.mkFormatter {
inherit nixpkgs system;
config = {
tools = {
deadnix = {
enable = true;
noLambdaPatternNames = true;
noLambdaArg = true;
};
statix.enable = true;
nixfmt.enable = true;
};
};
});
2023-10-14 21:24:33 +00:00
overlays = import ./overlays;
2023-10-19 22:11:57 +00:00
nixosModules = {
nibylandia-boot.imports = [ ./modules/boot.nix ];
2023-10-19 22:11:57 +00:00
nibylandia-secureboot.imports = [ ./modules/secureboot.nix ];
2023-10-19 22:11:57 +00:00
nibylandia-common.imports = [ ./modules/common.nix ];
2023-10-08 23:21:05 +00:00
2023-10-19 22:11:57 +00:00
nibylandia-graphical.imports = [ ./modules/graphical.nix ];
nibylandia-laptop.imports = [ ./modules/laptop.nix ];
nibylandia-gaming.imports = [ ./modules/gaming.nix ];
2023-10-14 21:24:33 +00:00
nibylandia-monitoring.imports = [ ./modules/monitoring.nix ];
2023-10-19 22:11:57 +00:00
nibylandia-ci-runners.imports = [ ./modules/ci-runners.nix ];
};
2023-10-19 22:11:57 +00:00
nixosConfigurations = {
2023-09-03 11:35:16 +00:00
scylla = nixpkgs.lib.nixosSystem {
system = "aarch64-linux";
2023-10-19 22:11:57 +00:00
modules = [ ./nixos/scylla ];
extraModules = [ inputs.colmena.nixosModules.deploymentOptions ];
2023-10-19 22:11:57 +00:00
specialArgs = { inherit inputs; };
};
khas = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
2023-10-19 22:11:57 +00:00
modules = [ ./nixos/khas ];
extraModules = [ inputs.colmena.nixosModules.deploymentOptions ];
2023-10-19 22:11:57 +00:00
specialArgs = { inherit inputs; };
2023-09-03 11:35:16 +00:00
};
2023-10-08 22:07:57 +00:00
microlith = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
2023-10-19 22:11:57 +00:00
modules = [ ./nixos/microlith ];
extraModules = [ inputs.colmena.nixosModules.deploymentOptions ];
2023-10-19 22:11:57 +00:00
specialArgs = { inherit inputs; };
2023-10-08 22:07:57 +00:00
};
2023-10-14 21:24:33 +00:00
zorigami = nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
2023-10-19 22:11:57 +00:00
modules = [ ./nixos/zorigami ];
extraModules = [ inputs.colmena.nixosModules.deploymentOptions ];
2023-10-19 22:11:57 +00:00
specialArgs = { inherit inputs; };
2023-10-14 21:24:33 +00:00
};
2023-09-03 11:35:16 +00:00
};
deploy.nodes = builtins.mapAttrs (name: value: {
2023-10-08 22:07:57 +00:00
fastConnection = false;
remoteBuild = true;
hostname = value.config.deployment.targetHost;
2023-10-08 22:07:57 +00:00
profiles.system = {
user = "root";
sshUser = "root";
path =
deployPkgs.${value.config.nixpkgs.system}.deploy-rs.lib.activate.nixos
value;
2023-10-08 22:07:57 +00:00
};
}) self.nixosConfigurations;
colmena = {
meta = {
nixpkgs = import inputs.nixpkgs { system = "x86_64-linux"; };
nodeNixpkgs =
builtins.mapAttrs (_: v: v.pkgs) self.nixosConfigurations;
nodeSpecialArgs = builtins.mapAttrs (_: v: v._module.specialArgs)
self.nixosConfigurations;
specialArgs.lib = lib;
2023-10-14 21:24:33 +00:00
};
} // builtins.mapAttrs (_: v: { imports = v._module.args.modules; })
self.nixosConfigurations;
2023-10-14 21:24:33 +00:00
2023-09-03 11:35:16 +00:00
checks = builtins.mapAttrs
(system: deployLib: deployLib.deployChecks self.deploy) deploy-rs.lib;
};
}