kubenix/flake.nix

145 lines
4.3 KiB
Nix
Raw Normal View History

2020-12-29 11:16:27 +01:00
{
description = "Kubernetes resource 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";
flake-utils = {
url = "github:numtide/flake-utils";
inputs.nixpkgs.follows = "nixpkgs";
};
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;
};
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";
};
}
];
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-04-02 12:40:35 -07:00
jobs = import ./jobs {inherit pkgs;};
2021-05-28 20:26:17 -05: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-13 00:34:44 -04:00
packages = [
(pkgs.writeShellScriptBin "evalnix" ''
# check nix parsing
fd --extension nix --exec nix-instantiate --parse --quiet {} >/dev/null
'')
];
# KUBECONFIG = "kubeconfig.json";
shellHook = ''
export NODE_PATH="${pkgs.nodePackages.prettier-plugin-toml}/lib/node_modules:$NODE_PATH"
'';
};
formatter = pkgs.treefmt;
2022-08-12 09:44:00 -04:00
packages =
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;
};
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-04-02 12:40:35 -07:00
mkExamples = attrs:
2022-08-11 23:07:20 -04:00
(import ./docs/examples {inherit evalModules;})
2022-04-02 14:42:22 -07:00
({registry = "docker.io/gatehub";} // attrs);
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);
in
{
# TODO: access "success" derivation with nice testing utils for nice output
nginx-example = wasSuccess (mkExamples {}).nginx-deployment.config.testing;
}
// builtins.listToAttrs (builtins.map (v: {
name = "test-k8s-${builtins.replaceStrings ["."] ["_"] v}";
value = wasSuccess (mkK8STests {k8sVersion = v;});
})
(import ./versions.nix).versions);
}
))
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-29 17:13:33 -05:00
# up to date versions of their nixpkgs equivalents
2022-04-02 13:18:09 -07:00
# kubernetes =
# prev.callPackage ./pkgs/applications/networking/cluster/kubernetes
# {};
# kubectl = prev.callPackage ./pkgs/applications/networking/cluster/kubectl {};
2021-04-03 21:57:02 -07:00
};
};
2020-12-29 11:16:27 +01:00
}