-
Notifications
You must be signed in to change notification settings - Fork 99
/
Copy pathshell.nix
51 lines (47 loc) · 1.11 KB
/
shell.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
let
sources = import ./nix/sources.nix;
pkgs = import sources.nixpkgs { };
in
pkgs.mkShell {
name = "lvm-shell";
buildInputs = with pkgs; [
chart-testing
git
go_1_19
golint
kubectl
kubernetes-helm
gnumake
minikube
semver-tool
yq-go
which
curl
cacert
util-linux
jq
lvm2_dmeventd
nixos-shell
] ++ pkgs.lib.optional (builtins.getEnv "IN_NIX_SHELL" == "pure") [ docker-client ];
PRE_COMMIT_ALLOW_NO_CONFIG = 1;
shellHook = ''
export GOPATH=$(pwd)/nix/.go
export GOCACHE=$(pwd)/nix/.go/cache
export TMPDIR=$(pwd)/nix/.tmp
export PATH=$GOPATH/bin:$PATH
mkdir -p "$TMPDIR"
if [ "$IN_NIX_SHELL" = "pure" ]; then
# working sudo within a pure nix-shell
for sudo in /run/wrappers/bin/sudo /usr/bin/sudo /usr/local/bin/sudo /sbin/sudo /bin/sudo; do
mkdir -p $(pwd)/nix/bins
ln -sf $sudo $(pwd)/nix/bins/sudo
export PATH=$(pwd)/nix/bins:$PATH
break
done
else
rm $(pwd)/nix/bins/sudo 2>/dev/null || :
rmdir $(pwd)/nix/bins 2>/dev/null || :
fi
make bootstrap
'';
}