infra/flake.nix

90 lines
2.1 KiB
Nix
Raw Normal View History

2024-10-13 15:16:39 -05:00
{
2024-10-13 15:26:29 -05:00
description = "computer systems infrastructure";
2024-10-13 15:16:39 -05:00
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-24.05";
flake-parts.url = "github:hercules-ci/flake-parts";
sops-nix.url = "github:Mic92/sops-nix";
sops-nix.inputs.nixpkgs.follows = "nixpkgs";
disko.url = "github:nix-community/disko";
disko.inputs.nixpkgs.follows = "nixpkgs";
deploy-rs.url = "github:serokell/deploy-rs";
deploy-rs.inputs.nixpkgs.follows = "nixpkgs";
impermanence.url = "github:nix-community/impermanence";
2024-12-13 16:47:09 -06:00
proxmox-nixos.url = "github:SaumonNet/proxmox-nixos";
2024-10-13 15:16:39 -05:00
min-rip.url = "git+ssh://git@git.min.rip/min/min.rip.git";
min-rip.flake = false;
breeze.url = "git+https://git.min.rip/min/breeze.git";
breeze.inputs.nixpkgs.follows = "nixpkgs";
};
2024-12-13 16:47:09 -06:00
nixConfig = {
extra-substituters = [
"https://cache.saumon.network/proxmox-nixos"
];
extra-trusted-public-keys = [
"proxmox-nixos:nveXDuVVhFDRFx8Dn19f1WDEaNRJjPrF2CPD2D+m1ys="
];
};
2024-10-13 15:16:39 -05:00
outputs = inputs @ {self, ...}:
inputs.flake-parts.lib.mkFlake {inherit inputs;} {
flake = let
hosts = import ./nixos/hosts {inherit inputs;};
in {
inherit (hosts) nixosConfigurations deploy;
};
systems = ["x86_64-linux"];
perSystem = {
system,
2024-10-15 16:02:42 -05:00
pkgs,
2024-10-13 15:16:39 -05:00
...
}: {
devShells.default = pkgs.mkShell {
2024-11-12 20:02:15 -06:00
KUSTOMIZE_PLUGIN_HOME = pkgs.buildEnv {
name = "kustomize-plugins";
paths = with pkgs; [
kustomize-sops
];
postBuild = ''
mv $out/lib/* $out
rm -r $out/lib
'';
pathsToLink = ["/lib"];
};
2024-10-13 15:16:39 -05:00
packages = with pkgs; [
sops
ssh-to-age
2024-10-15 16:02:42 -05:00
# not included: age, gpg, pcscd, scdaemon, etc.
2024-10-13 15:16:39 -05:00
deploy-rs
nixos-anywhere
argocd
kubectl
2024-11-12 20:02:15 -06:00
kustomize
2024-10-13 15:16:39 -05:00
kubernetes-helm
yamllint
nil
alejandra
statix
deadnix
];
};
};
};
}