cfg/flake.nix
2025-12-30 20:58:52 +01:00

127 lines
3 KiB
Nix

{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
nixpkgs_25-05.url = "github:NixOS/nixpkgs/nixos-25.05";
nixos-hardware.url = "github:NixOS/nixos-hardware/master";
colmena = {
url = "github:zhaofengli/colmena";
inputs.nixpkgs.follows = "nixpkgs";
inputs.flake-utils.follows = "flake-utils";
};
home-manager = {
url = "github:nix-community/home-manager";
inputs.nixpkgs.follows = "nixpkgs";
};
flake-utils.url = "github:numtide/flake-utils";
agenix = {
url = "github:ryantm/agenix";
inputs.nixpkgs.follows = "nixpkgs";
inputs.darwin.follows = "";
};
vscode-extensions = {
url = "github:nix-community/nix-vscode-extensions";
inputs.nixpkgs.follows = "nixpkgs";
};
disko = {
url = "github:nix-community/disko/latest";
inputs.nixpkgs.follows = "nixpkgs";
};
lanzaboote = {
url = "github:nix-community/lanzaboote/v0.4.3";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs =
{
self,
agenix,
colmena,
disko,
flake-utils,
home-manager,
lanzaboote,
nixos-hardware,
nixpkgs_25-05,
nixpkgs,
vscode-extensions,
}@inputs:
let
inherit (nixpkgs) lib;
var = import ./var { inherit lib; };
lib' = import ./lib.nix { inherit lib var; };
pkgs_25-05 = import nixpkgs_25-05 { system = "x86_64-linux"; };
specialArgs = rec {
inherit
inputs
lib'
pkgs_25-05
var
;
secrets = lib'.walk-dir ./secrets;
};
mkDesktop =
host:
nixpkgs.lib.nixosSystem {
system = "x86_64-linux";
specialArgs = specialArgs // {
inherit host;
};
modules = [
(./host + "/${host}")
./home
./mod
];
};
in
{
nixosConfigurations = {
# if you add a host, make sure to add it to var/default.nix as well
"solo" = mkDesktop "solo";
"c2" = mkDesktop "c2";
"fw" = mkDesktop "fw";
};
colmenaHive = colmena.lib.makeHive {
meta = {
nixpkgs = import nixpkgs {
system = "x86_64-linux";
};
inherit specialArgs;
};
"roam" = {
deployment = {
targetHost = "185.163.117.158";
buildOnTarget = true;
};
imports = [
./host/roam
./mod
];
};
};
}
// flake-utils.lib.eachDefaultSystem (
system:
let
pkgs = import nixpkgs { inherit system; };
in
{
devShells = import ./devshells { inherit pkgs; } // {
default = pkgs.mkShell {
buildInputs = [
colmena.packages.${system}.colmena
agenix.packages.${system}.default
pkgs.openssl
pkgs.jq
pkgs.syncthing
];
};
};
formatter = pkgs.nixfmt-tree;
}
);
}