nix/flake.nix
2024-12-12 21:47:41 +01:00

135 lines
3.4 KiB
Nix

{
# Source of inspiration:
# - https://github.com/BonusPlay/sysconf/blob/master/flake.nix (agenix)
# - https://github.com/NixOS/infra/blob/master/build/flake.nix (agenix)
# - https://johns.codes/blog/organizing-system-configs-with-nixos (caddy)
# - https://nixos-and-flakes.thiscute.world/nixos-with-flakes/start-using-home-manager
# - https://forum.proxmox.com/threads/tutorial-unprivileged-lxcs-mount-cifs-shares.101795/ (Samba share)
description = "Pazpi's systems";
inputs = {
# NixOS related inputs
nixpkgs.url = "github:NixOS/nixpkgs/nixos-24.11";
nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixos-unstable";
nixos-hardware.url = "github:NixOS/nixos-hardware/master";
lix-module = {
url = "https://git.lix.systems/lix-project/nixos-module/archive/2.91.0.tar.gz";
inputs.nixpkgs.follows = "nixpkgs";
};
agenix = {
url = "github:ryantm/agenix";
inputs.nixpkgs.follows = "nixpkgs";
};
colmena = {
url = "github:zhaofengli/colmena";
inputs.nixpkgs.follows = "nixpkgs";
};
home-manager = {
url = "github:nix-community/home-manager/release-24.11";
inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs =
{
self,
nixpkgs,
nixpkgs-unstable,
nixos-hardware,
lix-module,
agenix,
colmena,
home-manager,
...
}@inputs:
let
system = "x86_64-linux";
pkgs = import nixpkgs { inherit system; };
lib = nixpkgs.lib;
in
{
# used with: `nix fmt`
formatter.${system} = pkgs.nixfmt-rfc-style;
nixosConfigurations = (import ./hosts inputs);
colmena =
lib.recursiveUpdate
(builtins.mapAttrs (k: v: { imports = v._module.args.modules; }) self.nixosConfigurations)
{
meta = {
nixpkgs = import nixpkgs {
system = "x86_64-linux";
overlays = [ ];
};
nodeNixpkgs = builtins.mapAttrs (_: v: v.pkgs) self.nixosConfigurations;
nodeSpecialArgs = builtins.mapAttrs (_: v: v._module.specialArgs) self.nixosConfigurations;
};
arr.deployment = {
targetHost = "192.168.1.189";
tags = [
"lxc"
"bacco"
];
};
caddy.deployment = {
targetHost = "192.168.1.150";
tags = [
"lxc"
"bacco"
];
};
metrics.deployment = {
targetHost = "192.168.1.152";
tags = [
"lxc"
"bacco"
];
};
nextcloud.deployment = {
targetHost = "192.168.1.153";
tags = [
"lxc"
"bacco"
];
};
# vaultwarden.deployment = {
# targetHost = "192.168.1.154";
# tags = [
# "lxc"
# "bacco"
# ];
# };
deadbeef.deployment = {
allowLocalDeployment = true;
targetHost = null;
tags = [ "local" ];
};
};
devShells.${system}.default = pkgs.mkShell {
buildInputs = with pkgs; [
agenix.packages.${system}.agenix
colmena.packages.${system}.colmena
];
};
};
}