about summary refs log tree commit diff
path: root/nixpkgs/pkgs/by-name/te/tetragon/package.nix
blob: cbb940da53e42f103d471db0ec76645234be4ca9 (plain) (blame)
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
{ lib
, stdenv
, fetchFromGitHub
, pkg-config
, go
, llvm_16
, clang_16
, bash
}:

stdenv.mkDerivation (finalAttrs: {
  pname = "tetragon";
  version = "0.11.0";

  src = fetchFromGitHub {
    owner = "cilium";
    repo = "tetragon";
    rev = "refs/tags/v${finalAttrs.version}";
    sha256 = "sha256-KOR5MMRnhrlcMPqRjzjSJXvitiZQ8/tlxEnBiQG2x/Q=";
  };

  buildInputs = [
    clang_16
    go
    llvm_16
    pkg-config
  ];

  env.NIX_CFLAGS_COMPILE = "-fno-stack-protector -Qunused-arguments";

  buildPhase = ''
    runHook preBuild
    export HOME=$TMP
    export LOCAL_CLANG=1
    export LOCAL_CLANG_FORMAT=1
    make tetragon
    make tetragon-operator
    make tetra
    make tetragon-bpf
    runHook postBuild
  '';

  postPatch = ''
    substituteInPlace bpf/Makefile --replace '/bin/bash' '${lib.getExe bash}'
    substituteInPlace pkg/defaults/defaults.go --replace '/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 = with lib; {
    description      = "Real-time, eBPF-based Security Observability and Runtime Enforcement tool";
    homepage         = "https://github.com/cilium/tetragon";
    license          = licenses.asl20;
    mainProgram      = "tetragon";
    maintainers      = with maintainers; [ gangaram ];
    platforms        = platforms.linux;
    sourceProvenance = with sourceTypes; [ fromSource ];
  };
})