Files
nixpkgs/pkgs/by-name/te/tetragon/package.nix
Dark Steveneq 646b892680
Some checks failed
Periodic Merges (6h) / master → staging-nixos (push) Failing after 12m50s
Periodic Merges (6h) / master → staging-next (push) Failing after 12m54s
Periodic Merges (24h) / merge-base(master,staging) → haskell-updates (push) Failing after 11m54s
Periodic Merges (6h) / staging-next → staging (push) Failing after 12m13s
Periodic Merges (24h) / staging-next-25.05 → staging-25.05 (push) Failing after 13m24s
Periodic Merges (24h) / release-25.05 → staging-next-25.05 (push) Failing after 14m28s
push sheeet
2025-10-09 14:15:47 +02:00

85 lines
1.9 KiB
Nix

{
lib,
stdenv,
fetchFromGitHub,
pkg-config,
go,
llvm,
clang,
bash,
writableTmpDirAsHomeHook,
gitMinimal,
}:
stdenv.mkDerivation (finalAttrs: {
pname = "tetragon";
version = "1.5.0";
src = fetchFromGitHub {
owner = "cilium";
repo = "tetragon";
tag = "v${finalAttrs.version}";
hash = "sha256-riuSByvMpbukA+pwbzecnyUvZGtPR6lLEA1s2oBnI+A=";
};
nativeBuildInputs = [
writableTmpDirAsHomeHook
gitMinimal
];
buildInputs = [
clang
go
llvm
pkg-config
];
env = {
LOCAL_CLANG = 1;
LOCAL_CLANG_FORMAT = 1;
NIX_CFLAGS_COMPILE = "-fno-stack-protector -Qunused-arguments";
};
buildPhase = ''
runHook preBuild
make tetragon
make tetragon-operator
make tetra
make tetragon-bpf
runHook postBuild
'';
# For BPF compilation
hardeningDisable = [ "zerocallusedregs" ];
postPatch = ''
substituteInPlace bpf/Makefile.defs --replace-fail '/bin/bash' '${lib.getExe bash}'
substituteInPlace pkg/defaults/defaults.go --replace-fail '/var/lib/tetragon/' $out/lib/tetragon/bpf/
'';
installPhase = ''
runHook preInstall
mkdir -p $out/lib/tetragon $out/lib/tetragon/tetragon.tp.d/
sed -i "s+/usr/local/+$out/+g" install/linux-tarball/usr/local/lib/tetragon/tetragon.conf.d/bpf-lib
cp -n -r install/linux-tarball/usr/local/lib/tetragon/tetragon.conf.d/ $out/lib/tetragon/
cp -n -r ./bpf/objs $out/lib/tetragon/bpf
install -m755 -D ./tetra $out/bin/tetra
install -m755 -D ./tetragon $out/bin/tetragon
runHook postInstall
'';
meta = {
description = "Real-time, eBPF-based Security Observability and Runtime Enforcement tool";
homepage = "https://github.com/cilium/tetragon";
license = lib.licenses.asl20;
mainProgram = "tetragon";
maintainers = with lib.maintainers; [ gangaram ];
platforms = lib.platforms.linux;
sourceProvenance = with lib.sourceTypes; [ fromSource ];
};
})