2020-12-29 11:16:27 +01:00
|
|
|
|
{
|
2022-08-28 15:27:18 -04:00
|
|
|
|
description = "Kubernetes management with nix";
|
2020-12-29 11:16:27 +01:00
|
|
|
|
|
2021-04-03 21:57:02 -07:00
|
|
|
|
inputs = {
|
2022-04-02 13:18:09 -07:00
|
|
|
|
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
|
2022-08-13 00:09:36 -04:00
|
|
|
|
flake-utils = {
|
|
|
|
|
|
url = "github:numtide/flake-utils";
|
|
|
|
|
|
inputs.nixpkgs.follows = "nixpkgs";
|
|
|
|
|
|
};
|
2022-08-14 21:48:45 -04:00
|
|
|
|
flake-compat = {
|
|
|
|
|
|
url = "github:edolstra/flake-compat";
|
|
|
|
|
|
flake = false;
|
|
|
|
|
|
};
|
2021-04-03 21:57:02 -07:00
|
|
|
|
};
|
2020-12-29 11:16:27 +01:00
|
|
|
|
|
2022-04-02 12:40:35 -07:00
|
|
|
|
outputs = {
|
|
|
|
|
|
self,
|
|
|
|
|
|
nixpkgs,
|
2022-04-02 13:18:09 -07:00
|
|
|
|
...
|
|
|
|
|
|
} @ inputs:
|
2022-04-02 14:42:22 -07:00
|
|
|
|
(inputs.flake-utils.lib.eachSystem ["x86_64-linux"] (
|
2022-04-02 14:41:57 -07:00
|
|
|
|
#inputs.flake-utils.lib.eachDefaultSystem (
|
2022-04-02 12:40:35 -07:00
|
|
|
|
system: let
|
2022-04-02 13:32:40 -07:00
|
|
|
|
pkgs = import inputs.nixpkgs {
|
|
|
|
|
|
overlays = [
|
|
|
|
|
|
self.overlays.default
|
|
|
|
|
|
];
|
|
|
|
|
|
config.allowUnsupportedSystem = true;
|
|
|
|
|
|
inherit system;
|
|
|
|
|
|
};
|
2021-05-28 19:25:48 -05:00
|
|
|
|
|
2022-04-02 13:43:57 -07:00
|
|
|
|
inherit (pkgs) lib;
|
2021-05-28 20:26:17 -05:00
|
|
|
|
|
|
|
|
|
|
kubenix = {
|
2022-04-02 12:40:35 -07:00
|
|
|
|
lib = import ./lib {inherit lib pkgs;};
|
2021-05-28 20:26:17 -05:00
|
|
|
|
evalModules = self.evalModules.${system};
|
2022-04-02 13:18:09 -07:00
|
|
|
|
modules = self.nixosModules.kubenix;
|
2021-05-28 20:26:17 -05:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
# evalModules with same interface as lib.evalModules and kubenix as
|
|
|
|
|
|
# special argument
|
2022-04-02 12:40:35 -07:00
|
|
|
|
evalModules = attrs @ {
|
|
|
|
|
|
module ? null,
|
|
|
|
|
|
modules ? [module],
|
|
|
|
|
|
...
|
|
|
|
|
|
}: let
|
2022-04-02 13:41:07 -07:00
|
|
|
|
lib' = lib.extend (lib: _self: import ./lib/upstreamables.nix {inherit lib pkgs;});
|
2022-04-02 12:40:35 -07:00
|
|
|
|
attrs' = builtins.removeAttrs attrs ["module"];
|
|
|
|
|
|
in
|
2021-05-28 20:26:17 -05:00
|
|
|
|
lib'.evalModules (lib.recursiveUpdate
|
|
|
|
|
|
{
|
2022-04-02 13:28:07 -07:00
|
|
|
|
modules =
|
|
|
|
|
|
modules
|
|
|
|
|
|
++ [
|
|
|
|
|
|
{
|
2022-04-02 16:12:17 -07:00
|
|
|
|
config._module.args = {
|
2022-04-02 13:28:07 -07:00
|
|
|
|
inherit pkgs;
|
|
|
|
|
|
name = "default";
|
|
|
|
|
|
};
|
|
|
|
|
|
}
|
|
|
|
|
|
];
|
2022-08-11 23:41:33 -04:00
|
|
|
|
specialArgs = {
|
|
|
|
|
|
inherit kubenix;
|
|
|
|
|
|
inherit pkgs;
|
|
|
|
|
|
};
|
2021-05-28 20:26:17 -05:00
|
|
|
|
}
|
|
|
|
|
|
attrs');
|
2022-04-02 12:40:35 -07:00
|
|
|
|
in {
|
2022-04-02 14:41:57 -07:00
|
|
|
|
inherit evalModules pkgs;
|
2021-05-28 20:26:17 -05:00
|
|
|
|
|
2022-08-13 00:09:36 -04:00
|
|
|
|
devShells.default = pkgs.mkShell {
|
|
|
|
|
|
buildInputs = with pkgs; [
|
|
|
|
|
|
# formatters
|
|
|
|
|
|
alejandra
|
|
|
|
|
|
black
|
|
|
|
|
|
nodePackages.prettier
|
|
|
|
|
|
nodePackages.prettier-plugin-toml
|
|
|
|
|
|
shfmt
|
|
|
|
|
|
treefmt
|
|
|
|
|
|
|
|
|
|
|
|
# extra tools
|
|
|
|
|
|
dive
|
|
|
|
|
|
fd
|
|
|
|
|
|
k9s
|
|
|
|
|
|
kube3d
|
|
|
|
|
|
kubie
|
2022-08-28 15:22:43 -04:00
|
|
|
|
hugo
|
2022-08-13 00:09:36 -04:00
|
|
|
|
];
|
2022-08-13 00:34:44 -04:00
|
|
|
|
packages = [
|
|
|
|
|
|
(pkgs.writeShellScriptBin "evalnix" ''
|
|
|
|
|
|
# check nix parsing
|
|
|
|
|
|
fd --extension nix --exec nix-instantiate --parse --quiet {} >/dev/null
|
|
|
|
|
|
'')
|
|
|
|
|
|
];
|
2022-08-13 00:09:36 -04:00
|
|
|
|
# KUBECONFIG = "kubeconfig.json";
|
2022-08-13 01:06:30 -04:00
|
|
|
|
shellHook = ''
|
|
|
|
|
|
export NODE_PATH="${pkgs.nodePackages.prettier-plugin-toml}/lib/node_modules:$NODE_PATH"
|
|
|
|
|
|
'';
|
2022-08-13 00:09:36 -04:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
formatter = pkgs.treefmt;
|
2021-05-28 19:25:48 -05:00
|
|
|
|
|
2022-08-28 02:20:49 -04:00
|
|
|
|
apps = {
|
2022-08-28 15:22:43 -04:00
|
|
|
|
docs = inputs.flake-utils.lib.mkApp {
|
|
|
|
|
|
drv = pkgs.writeShellScriptBin "gen-docs" ''
|
|
|
|
|
|
set -eo pipefail
|
|
|
|
|
|
|
|
|
|
|
|
# generate json object of module options
|
|
|
|
|
|
nix build '.#docs' -o ./docs/data/options.json
|
|
|
|
|
|
|
|
|
|
|
|
# remove all old module pages
|
2022-08-29 02:12:38 -04:00
|
|
|
|
rm ./docs/content/modules/[!_]?*.md || true
|
2022-08-28 15:22:43 -04:00
|
|
|
|
|
|
|
|
|
|
# create a page for each module in hugo
|
|
|
|
|
|
for mod in ${builtins.toString (builtins.attrNames self.nixosModules.kubenix)}; do
|
|
|
|
|
|
[[ $mod == "base" ]] && mod=kubenix
|
|
|
|
|
|
[[ $mod == "k8s" ]] && mod=kubernetes
|
|
|
|
|
|
[[ $mod == "submodule"* ]] && continue
|
|
|
|
|
|
echo " {{< options >}}" > ./docs/content/modules/$mod.md
|
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
|
|
# build the site
|
|
|
|
|
|
cd docs && ${pkgs.hugo}/bin/hugo $@
|
|
|
|
|
|
'';
|
|
|
|
|
|
};
|
2022-08-28 02:20:49 -04:00
|
|
|
|
generate = inputs.flake-utils.lib.mkApp {
|
|
|
|
|
|
drv = pkgs.writeShellScriptBin "gen-modules" ''
|
|
|
|
|
|
set -eo pipefail
|
|
|
|
|
|
|
|
|
|
|
|
nix build '.#generate-k8s'
|
|
|
|
|
|
cp ./result/* ./modules/generated/
|
|
|
|
|
|
|
|
|
|
|
|
rm result
|
|
|
|
|
|
'';
|
|
|
|
|
|
};
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2022-08-12 09:44:00 -04:00
|
|
|
|
packages =
|
2022-08-13 00:09:36 -04:00
|
|
|
|
inputs.flake-utils.lib.flattenTree
|
|
|
|
|
|
{
|
2022-08-12 09:44:00 -04:00
|
|
|
|
inherit (pkgs) kubernetes kubectl;
|
|
|
|
|
|
}
|
|
|
|
|
|
// {
|
|
|
|
|
|
cli = pkgs.callPackage ./pkgs/kubenix.nix {};
|
|
|
|
|
|
default = self.packages.${system}.cli;
|
2022-08-28 15:22:43 -04:00
|
|
|
|
docs = import ./docs {
|
|
|
|
|
|
inherit pkgs;
|
|
|
|
|
|
options =
|
|
|
|
|
|
(self.evalModules.${system} {
|
|
|
|
|
|
modules =
|
|
|
|
|
|
builtins.attrValues (builtins.removeAttrs
|
|
|
|
|
|
# the submodules module currently doesn't evaluate:
|
|
|
|
|
|
# error: No module found ‹name›/latest
|
|
|
|
|
|
# not sure how important that documentation is a this time
|
|
|
|
|
|
self.nixosModules.kubenix ["submodule" "submodules"]);
|
|
|
|
|
|
})
|
|
|
|
|
|
.options;
|
|
|
|
|
|
};
|
2022-08-15 00:29:27 -04:00
|
|
|
|
}
|
2022-08-28 15:22:43 -04:00
|
|
|
|
// import ./jobs {
|
|
|
|
|
|
inherit pkgs;
|
|
|
|
|
|
};
|
2021-05-28 19:25:48 -05:00
|
|
|
|
|
2021-05-28 20:26:17 -05:00
|
|
|
|
checks = let
|
|
|
|
|
|
wasSuccess = suite:
|
2022-04-02 13:43:57 -07:00
|
|
|
|
if suite.success
|
2021-05-28 20:26:17 -05:00
|
|
|
|
then pkgs.runCommandNoCC "testing-suite-config-assertions-for-${suite.name}-succeeded" {} "echo success > $out"
|
|
|
|
|
|
else pkgs.runCommandNoCC "testing-suite-config-assertions-for-${suite.name}-failed" {} "exit 1";
|
2022-08-29 02:04:47 -04:00
|
|
|
|
examples = import ./docs/content/examples;
|
2022-04-02 14:07:05 -07:00
|
|
|
|
mkK8STests = attrs:
|
|
|
|
|
|
(import ./tests {inherit evalModules;})
|
2022-04-02 14:42:22 -07:00
|
|
|
|
({registry = "docker.io/gatehub";} // attrs);
|
2022-08-13 21:39:56 -04:00
|
|
|
|
in
|
|
|
|
|
|
{
|
|
|
|
|
|
# TODO: access "success" derivation with nice testing utils for nice output
|
2022-08-29 02:04:47 -04:00
|
|
|
|
testing = wasSuccess examples.testing.config.testing;
|
2022-08-13 21:39:56 -04:00
|
|
|
|
}
|
2022-08-28 15:22:43 -04:00
|
|
|
|
// builtins.listToAttrs (builtins.map
|
|
|
|
|
|
(v: {
|
2022-08-13 21:39:56 -04:00
|
|
|
|
name = "test-k8s-${builtins.replaceStrings ["."] ["_"] v}";
|
|
|
|
|
|
value = wasSuccess (mkK8STests {k8sVersion = v;});
|
|
|
|
|
|
})
|
|
|
|
|
|
(import ./versions.nix).versions);
|
2021-05-28 19:25:48 -05:00
|
|
|
|
}
|
|
|
|
|
|
))
|
2022-04-02 12:40:35 -07:00
|
|
|
|
// {
|
2022-04-02 13:18:09 -07:00
|
|
|
|
nixosModules.kubenix = import ./modules;
|
2022-04-02 13:41:07 -07:00
|
|
|
|
overlays.default = _final: prev: {
|
2021-05-28 20:26:17 -05:00
|
|
|
|
kubenix.evalModules = self.evalModules.${prev.system};
|
2021-04-03 21:57:02 -07:00
|
|
|
|
};
|
|
|
|
|
|
};
|
2020-12-29 11:16:27 +01:00
|
|
|
|
}
|