2023-11-15 06:09:04 +00:00
|
|
|
{
|
2023-11-15 16:43:46 +00:00
|
|
|
description = "Kubernetes deployments flake";
|
2023-11-15 06:09:04 +00:00
|
|
|
|
|
|
|
inputs = {
|
|
|
|
# Base
|
|
|
|
nixpkgs.url = "github:NixOS/nixpkgs";
|
|
|
|
flake-utils.url = "github:numtide/flake-utils";
|
|
|
|
nix-kube-generators.url = "github:farcaller/nix-kube-generators";
|
|
|
|
nixhelm.url = "github:farcaller/nixhelm";
|
|
|
|
|
2023-11-17 05:29:37 +00:00
|
|
|
# Dev
|
2023-11-18 07:22:13 +00:00
|
|
|
devshell = {
|
|
|
|
url = "github:numtide/devshell";
|
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
};
|
2023-11-17 05:29:37 +00:00
|
|
|
|
2023-11-18 10:08:23 +00:00
|
|
|
# TODO: My whole homelab is a flake. It would be
|
|
|
|
# pretty wild to be able to import data from it.
|
2023-11-15 06:09:04 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
outputs = inputs @ {
|
|
|
|
self,
|
|
|
|
nixpkgs,
|
|
|
|
flake-utils,
|
|
|
|
nix-kube-generators,
|
|
|
|
nixhelm,
|
2023-11-17 05:29:37 +00:00
|
|
|
devshell,
|
2023-11-15 09:21:47 +00:00
|
|
|
}: let
|
2023-11-19 21:19:32 +00:00
|
|
|
rake = import ./lib/rake.nix;
|
2023-11-15 09:21:47 +00:00
|
|
|
in
|
|
|
|
{
|
2023-11-24 21:35:19 +00:00
|
|
|
# Services expected to provide custom APIs (e.g.: Gateway API,
|
|
|
|
# Istio, Longhorn) go in `./system`. All others in `./services`,
|
2023-11-24 20:17:59 +00:00
|
|
|
# including resources for the former dependent on other APIs.
|
2023-11-23 01:54:27 +00:00
|
|
|
# This prevents infinite recursion when gathering APIs.
|
2023-11-24 21:35:19 +00:00
|
|
|
systemServiceData = rake.leaves ./system;
|
|
|
|
serviceData = rake.leaves ./services;
|
2023-11-21 06:42:43 +00:00
|
|
|
|
2023-11-19 21:19:32 +00:00
|
|
|
repos = rake.leaves ./charts;
|
2023-11-21 05:46:44 +00:00
|
|
|
|
2023-11-19 21:19:32 +00:00
|
|
|
namespaces = rake.namespaces {
|
2023-11-24 21:35:19 +00:00
|
|
|
roots = [./system ./services];
|
2023-11-19 21:19:32 +00:00
|
|
|
extraMetadata = import ./namespaces.nix;
|
|
|
|
};
|
2023-11-15 09:21:47 +00:00
|
|
|
}
|
|
|
|
// flake-utils.lib.eachDefaultSystem (system: let
|
2023-11-17 05:29:37 +00:00
|
|
|
pkgs = import nixpkgs {
|
|
|
|
inherit system;
|
|
|
|
overlays = [devshell.overlays.default];
|
|
|
|
};
|
2023-11-22 04:58:13 +00:00
|
|
|
kubeVersion = pkgs.k3s.version;
|
2023-11-15 06:55:56 +00:00
|
|
|
kubelib = nix-kube-generators.lib {inherit pkgs;};
|
2023-11-19 19:35:35 +00:00
|
|
|
|
2023-11-23 01:54:27 +00:00
|
|
|
# When I move lib/eureka to a separate flake this'll look something like:
|
2023-11-22 04:44:47 +00:00
|
|
|
# lib = import ./lib {...} // {eureka = import ./eureka {...};}
|
2023-11-19 01:11:49 +00:00
|
|
|
lib = import ./lib {inherit charts kubelib pkgs;};
|
2023-11-19 19:35:35 +00:00
|
|
|
|
2023-11-23 18:22:34 +00:00
|
|
|
flakeBuilders = import ./lib/flake-builders.nix {inherit charts lib pkgs;};
|
2023-11-19 22:05:42 +00:00
|
|
|
|
2023-11-25 08:33:44 +00:00
|
|
|
charts =
|
|
|
|
pkgs.lib.attrsets.recursiveUpdate
|
|
|
|
(nixhelm.charts {inherit pkgs;})
|
|
|
|
(flakeBuilders.charts self.repos);
|
2023-11-21 06:42:43 +00:00
|
|
|
|
2023-11-24 21:35:19 +00:00
|
|
|
systemServices = flakeBuilders.services self.systemServiceData {
|
2023-11-22 04:58:13 +00:00
|
|
|
inherit kubeVersion;
|
|
|
|
apiVersions = [];
|
|
|
|
};
|
|
|
|
|
2023-11-21 07:31:11 +00:00
|
|
|
clusterData = {
|
2023-11-22 04:58:13 +00:00
|
|
|
inherit kubeVersion;
|
2023-11-21 07:31:11 +00:00
|
|
|
apiVersions =
|
|
|
|
pkgs.lib.lists.flatten
|
|
|
|
(map
|
|
|
|
(chartDrv: lib.gatherApis chartDrv.outPath)
|
2023-11-24 21:35:19 +00:00
|
|
|
(with pkgs.lib; attrsets.collect isDerivation systemServices));
|
2023-11-21 07:31:11 +00:00
|
|
|
};
|
2023-11-21 06:42:43 +00:00
|
|
|
|
2023-11-24 21:35:19 +00:00
|
|
|
services = flakeBuilders.services self.serviceData clusterData;
|
2023-11-23 18:22:34 +00:00
|
|
|
namespaces = flakeBuilders.namespaces self.namespaces;
|
2023-11-23 17:45:30 +00:00
|
|
|
|
2023-11-23 18:22:34 +00:00
|
|
|
paths = flakeBuilders.paths {
|
2023-11-24 21:35:19 +00:00
|
|
|
inherit services;
|
|
|
|
system = systemServices;
|
2023-11-23 17:45:30 +00:00
|
|
|
};
|
2023-11-15 06:09:04 +00:00
|
|
|
in {
|
|
|
|
packages = {
|
2023-11-27 06:19:36 +00:00
|
|
|
inherit charts lib;
|
2023-11-19 19:46:27 +00:00
|
|
|
|
|
|
|
# Useful for debugging; will go to own flake eventually.
|
2023-11-27 06:19:36 +00:00
|
|
|
inherit systemServices services namespaces;
|
2023-11-24 21:35:19 +00:00
|
|
|
inherit (self) serviceData;
|
2023-11-21 07:31:11 +00:00
|
|
|
inherit clusterData;
|
2023-11-23 17:45:30 +00:00
|
|
|
inherit paths;
|
2023-11-16 01:33:32 +00:00
|
|
|
|
2023-11-27 06:19:36 +00:00
|
|
|
# Each of the leaves of the `services` attrsets is a derivation
|
2023-11-23 18:22:34 +00:00
|
|
|
# (explained better in `lib/flake-builders.nix`).
|
2023-11-23 01:54:27 +00:00
|
|
|
# Here, they are gathered into one mega-derivation, with Kustomizations
|
|
|
|
# at each level for usage with `k apply -k $path`.
|
2023-11-19 22:23:50 +00:00
|
|
|
default = let
|
2023-11-27 06:19:36 +00:00
|
|
|
pname = "turboprop";
|
2023-11-19 22:23:50 +00:00
|
|
|
in
|
|
|
|
pkgs.stdenv.mkDerivation {
|
|
|
|
inherit pname;
|
|
|
|
version = "0.0.1";
|
2023-11-18 07:09:06 +00:00
|
|
|
|
2023-11-23 17:45:30 +00:00
|
|
|
derivation_paths = paths;
|
2023-11-19 22:23:50 +00:00
|
|
|
namespace_drv = namespaces;
|
2023-11-19 02:35:43 +00:00
|
|
|
|
2023-11-19 22:23:50 +00:00
|
|
|
src = builtins.path {
|
|
|
|
path = ./.;
|
|
|
|
name = pname;
|
|
|
|
};
|
2023-11-18 07:09:06 +00:00
|
|
|
|
2023-11-19 22:23:50 +00:00
|
|
|
buildInputs = with pkgs; [kustomize];
|
|
|
|
phases = ["installPhase"];
|
|
|
|
installPhase = builtins.readFile ./lib/output.sh;
|
|
|
|
};
|
2023-11-15 06:09:04 +00:00
|
|
|
};
|
2023-11-17 05:29:37 +00:00
|
|
|
devShell = pkgs.devshell.mkShell {
|
|
|
|
imports = [(pkgs.devshell.importTOML ./devshell.toml)];
|
2023-11-15 06:09:04 +00:00
|
|
|
};
|
|
|
|
formatter = pkgs.alejandra;
|
|
|
|
});
|
|
|
|
}
|