forked from bank-vaults/vault-secrets-webhook
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathflake.nix
111 lines (88 loc) · 3.23 KB
/
flake.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
{
description = "A Kubernetes mutating webhook that makes direct secret injection into Pods possible";
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixpkgs-unstable";
nixpkgs-23-05.url = "github:NixOS/nixpkgs/release-23.05"; # TODO: remove once helm is fixed
flake-parts.url = "github:hercules-ci/flake-parts";
devenv.url = "github:cachix/devenv";
garden.url = "github:sagikazarmark/nix-garden";
};
outputs = inputs@{ flake-parts, ... }:
flake-parts.lib.mkFlake { inherit inputs; } {
imports = [
inputs.devenv.flakeModule
];
systems = [ "x86_64-linux" "x86_64-darwin" "aarch64-darwin" ];
perSystem = { config, self', inputs', pkgs, system, ... }: rec {
devenv.shells = {
default = {
languages = {
go.enable = true;
go.package = pkgs.go_1_21;
};
services = {
vault.enable = true;
};
pre-commit.hooks = {
nixpkgs-fmt.enable = true;
yamllint.enable = true;
hadolint.enable = true;
};
packages = with pkgs; [
gnumake
# golangci-lint
# TODO: remove once https://github.com/NixOS/nixpkgs/pull/254878 hits unstable
(golangci-lint.override (prev: {
buildGoModule = pkgs.buildGo121Module;
}))
kind
kubectl
kustomize
# kubernetes-helm
helm-docs
k3d
crc
yamllint
hadolint
] ++ [
inputs'.garden.packages.garden
inputs'.nixpkgs-23-05.legacyPackages.kubernetes-helm
self'.packages.licensei
];
env = {
GARDEN_DISABLE_ANALYTICS = "true";
KUBECONFIG = "${config.devenv.shells.default.env.DEVENV_STATE}/kube/config";
KIND_CLUSTER_NAME = "vault-secrets-webhook";
HELM_CACHE_HOME = "${config.devenv.shells.default.env.DEVENV_STATE}/helm/cache";
HELM_CONFIG_HOME = "${config.devenv.shells.default.env.DEVENV_STATE}/helm/config";
HELM_DATA_HOME = "${config.devenv.shells.default.env.DEVENV_STATE}/helm/data";
VAULT_TOKEN = "227e1cce-6bf7-30bb-2d2a-acc854318caf";
};
# https://github.com/cachix/devenv/issues/528#issuecomment-1556108767
containers = pkgs.lib.mkForce { };
};
ci = devenv.shells.default;
};
packages = {
# TODO: create flake in source repo
licensei = pkgs.buildGoModule rec {
pname = "licensei";
version = "0.8.0";
src = pkgs.fetchFromGitHub {
owner = "goph";
repo = "licensei";
rev = "v${version}";
sha256 = "sha256-Pvjmvfk0zkY2uSyLwAtzWNn5hqKImztkf8S6OhX8XoM=";
};
vendorSha256 = "sha256-ZIpZ2tPLHwfWiBywN00lPI1R7u7lseENIiybL3+9xG8=";
subPackages = [ "cmd/licensei" ];
ldflags = [
"-w"
"-s"
"-X main.version=v${version}"
];
};
};
};
};
}