config/flake.nix

60 lines
1.4 KiB
Nix
Raw Normal View History

2024-11-17 20:28:14 +01:00
{
description = "Homelab configuration";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-unstable";
2024-11-22 18:05:37 +01:00
impermanence.url = "github:nix-community/impermanence";
2024-12-26 19:41:49 +01:00
# Sops-nix, a secrets manager
sops-nix.url = "github:Mic92/sops-nix";
sops-nix.inputs.nixpkgs.follows = "nixpkgs";
2024-11-17 20:28:14 +01:00
};
outputs =
{ self, nixpkgs, ... }@inputs:
let
outputs = self.outputs;
utils = import ./utils.nix;
2024-12-26 17:22:00 +01:00
homelabConfig = import ./config.nix;
roles = import ./roles { inherit utils; };
hosts = import ./hosts.nix {
inherit homelabConfig roles;
lib = nixpkgs.lib;
};
pkgs = nixpkgs.legacyPackages.x86_64-linux;
2024-11-17 20:28:14 +01:00
in
{
devShells.x86_64-linux.default = pkgs.mkShell {
buildInputs = [ pkgs.colmena ];
};
colmena =
{
meta = {
nixpkgs = import nixpkgs {
system = "x86_64-linux";
};
specialArgs = {
inherit
inputs
outputs
hosts
;
};
};
}
// (nixpkgs.lib.mapAttrs (
2025-02-04 02:15:57 +01:00
_: value:
(utils.mkSystem {
hostConfig = value;
})
) hosts);
nixosConfigurations = {
template = nixpkgs.lib.nixosSystem {
specialArgs = { inherit inputs; };
modules = [ ./systems/template/configuration.nix ];
2025-02-04 02:15:57 +01:00
};
};
2024-11-17 20:28:14 +01:00
};
}