nixos-servers/flake.nix

98 lines
2.7 KiB
Nix
Raw Normal View History

2023-11-05 17:43:32 +00:00
{
description = "NixOS definitions for our physical servers";
inputs = {
nixpkgs.url = "github:nixos/nixpkgs/nixos-23.11";
nixpkgs-unstable.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
2023-11-11 23:04:37 +00:00
deploy-rs.url = "github:serokell/deploy-rs";
disko = {
url = "github:nix-community/disko";
inputs.nixpkgs.follows = "nixpkgs";
};
agenix = {
url = "github:ryantm/agenix";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-01-07 19:24:12 +00:00
dns = {
url = "github:kirelagin/dns.nix";
inputs.nixpkgs.follows = "nixpkgs";
};
2024-01-17 20:28:15 +00:00
microvm = {
url = "github:astro/microvm.nix";
inputs.nixpkgs.follows = "nixpkgs";
};
2023-11-05 17:43:32 +00:00
};
outputs =
2024-02-11 13:56:20 +00:00
{ self, nixpkgs, deploy-rs, disko, agenix, nixpkgs-unstable, dns, microvm, ... }:
let
2024-02-26 22:08:12 +00:00
pkgs = nixpkgs.legacyPackages."x86_64-linux";
2024-01-23 20:36:29 +00:00
lib = pkgs.lib;
2024-02-26 22:08:12 +00:00
pkgs-unstable = nixpkgs-unstable.legacyPackages."x86_64-linux";
machines = import ./nixos/machines;
2024-01-28 10:48:13 +00:00
physicalMachines = lib.filterAttrs (n: v: v.type == "physical") machines;
mkNixosSystems = systemDef:
2024-01-28 12:57:36 +00:00
builtins.mapAttrs
(name: machine:
nixpkgs.lib.nixosSystem (systemDef name machine)
)
2024-01-28 10:48:13 +00:00
physicalMachines;
mkDeployNodes = nodeDef:
2024-01-28 12:57:36 +00:00
builtins.mapAttrs
(name: machine: nodeDef name machine)
2024-01-28 10:48:13 +00:00
physicalMachines;
2023-12-15 14:11:14 +00:00
in
{
2024-02-26 22:08:12 +00:00
devShells."x86_64-linux".default = pkgs.mkShell {
packages = with pkgs; [
libsecret
# TODO: using nixos-anywhere from nixos-unstable produces buffer overflow.
# Related to this issue: https://github.com/nix-community/nixos-anywhere/issues/242
# Should wait until this is merged in nixos-unstable.
# pkgs-unstable.nixos-anywhere
pkgs-unstable.deploy-rs
openssl
postgresql_15
opentofu
cdrtools
kubectl
ansible
];
};
2023-11-11 23:04:37 +00:00
2024-02-26 22:08:12 +00:00
formatter."x86_64-linux" = pkgs.nixfmt;
2023-11-11 23:04:37 +00:00
nixosConfigurations = mkNixosSystems (name: machine: {
2024-02-26 22:08:12 +00:00
system = machine.arch;
2024-02-11 13:56:20 +00:00
specialArgs = { inherit machines machine dns microvm disko agenix; };
2024-01-28 13:08:28 +00:00
modules = [
./nixos
{ networking.hostName = name; }
];
});
2023-11-11 23:04:37 +00:00
deploy = {
sshUser = "root";
user = "root";
nodes = mkDeployNodes (name: machine: {
hostname = self.nixosConfigurations.${name}.config.networking.fqdn;
2024-01-16 20:47:41 +00:00
profiles.system = {
2024-02-26 22:08:12 +00:00
remoteBuild = true;
path = deploy-rs.lib."aarch64-linux".activate.nixos
self.nixosConfigurations.${name};
};
});
2023-11-11 23:04:37 +00:00
};
checks = builtins.mapAttrs
2023-12-15 14:11:14 +00:00
(system: deployLib: deployLib.deployChecks self.deploy)
deploy-rs.lib;
2023-11-05 17:43:32 +00:00
};
}