-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathshell.nix
103 lines (94 loc) · 3.38 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
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
{ norust ? false, devrustup ? true, rust-profile ? "stable", io-engine ? "" }:
let
sources = import ./nix/sources.nix;
pkgs = import sources.nixpkgs {
overlays = [ (_: _: { inherit sources; }) (import ./nix/overlay.nix { }) ];
};
in
with pkgs;
let
norust_moth =
"You have requested an environment without rust, you should provide it! Hint: use rustup tool.";
devrustup_moth =
"You have requested an environment for rustup, you should provide it!";
io-engine-moth = "Using the following io-engine binary: ${io-engine}";
channel = import ./nix/lib/rust.nix { inherit sources; };
# python environment for tests/bdd
pytest_inputs = python3.withPackages
(ps: with ps; [ virtualenv grpcio grpcio-tools black ]);
rust_chan = channel.default_src;
rust = rust_chan.${rust-profile};
in
mkShell {
name = "control-plane-shell";
buildInputs = [
llvmPackages.bintools
clang
commitlint
cowsay
docker
etcd
fio
git
jq
llvmPackages.libclang
nixpkgs-fmt
nix
openapi-generator-cli
openssl
pkg-config
pre-commit
python3
utillinux
which
paperclip
pytest_inputs
] ++ pkgs.lib.optional (!norust) rust
++ pkgs.lib.optionals (system != "aarch64-darwin") [
e2fsprogs
xfsprogs_5_16
btrfs-progs
nvme-cli
# python3.9-pyopenssl-22.0.0 marked as broken but fixed on master..
tini
udev
lvm2
rdma-core
] ++ pkgs.lib.optional (system == "aarch64-darwin") darwin.apple_sdk.frameworks.Security;
LIBCLANG_PATH = "${llvmPackages.libclang.lib}/lib";
PROTOC = "${protobuf}/bin/protoc";
PROTOC_INCLUDE = "${protobuf}/include";
# variables used to easily create containers with docker files
ETCD_BIN = "${pkgs.etcd}/bin/etcd";
ETCDCTL_API = "3";
# using the nix rust toolchain
USE_NIX_RUST = "${toString (!norust)}";
# copy the rust toolchain to a writable directory, see: https://github.com/rust-lang/cargo/issues/10096
# the whole toolchain is copied to allow the src to be retrievable through "rustc --print sysroot"
RUST_TOOLCHAIN = ".rust-toolchain/${rust.version}";
RUST_TOOLCHAIN_NIX = "${rust}";
NODE_PATH = "${nodePackages."@commitlint/config-conventional"}/lib/node_modules";
shellHook = ''
./scripts/nix/git-submodule-init.sh
if [ -z "$CI" ] && [ "$IN_NIX_SHELL" == "impure" ]; then
echo
pre-commit install
pre-commit install --hook commit-msg
fi
${pkgs.lib.optionalString (norust) "cowsay ${norust_moth}"}
${pkgs.lib.optionalString (norust) "echo"}
rust_version="${rust.version}" rustup_channel="${lib.strings.concatMapStringsSep "-" (x: x) (lib.lists.drop 1 (lib.strings.splitString "-" rust.version))}" \
dev_rustup="${toString (devrustup)}" devrustup_moth="${devrustup_moth}" . ./scripts/rust/env-setup.sh
export WORKSPACE_ROOT=`pwd`
[ ! -z "${io-engine}" ] && cowsay "${io-engine-moth}"
[ ! -z "${io-engine}" ] && export IO_ENGINE_BIN="${io-engine-moth}"
export PATH="$PATH:$(pwd)/target/debug"
export SUDO=$(which sudo 2>/dev/null || echo /run/wrappers/bin/sudo)
DOCKER_CONFIG=~/.docker/config.json
if [ -f "$DOCKER_CONFIG" ]; then
DOCKER_TOKEN=$(cat ~/.docker/config.json | jq '.auths."https://index.docker.io/v1/".auth // empty' | tr -d '"' | base64 -d)
export DOCKER_USER=$(echo $DOCKER_TOKEN | cut -d':' -f1)
export DOCKER_PASS=$(echo $DOCKER_TOKEN | cut -d':' -f2)
fi
'';
}