85 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Nix
		
	
	
	
	
	
{
 | 
						|
  lib,
 | 
						|
  stdenv,
 | 
						|
  fetchFromGitHub,
 | 
						|
  pkg-config,
 | 
						|
  go,
 | 
						|
  llvm_16,
 | 
						|
  clang_16,
 | 
						|
  bash,
 | 
						|
  writableTmpDirAsHomeHook,
 | 
						|
  gitMinimal,
 | 
						|
}:
 | 
						|
 | 
						|
stdenv.mkDerivation (finalAttrs: {
 | 
						|
  pname = "tetragon";
 | 
						|
  version = "1.4.0";
 | 
						|
 | 
						|
  src = fetchFromGitHub {
 | 
						|
    owner = "cilium";
 | 
						|
    repo = "tetragon";
 | 
						|
    tag = "v${finalAttrs.version}";
 | 
						|
    hash = "sha256-HOVQdKUIBLq9/2hTokZKvLZOgRQu5/lAwYy1yQa1bus=";
 | 
						|
  };
 | 
						|
 | 
						|
  nativeBuildInputs = [
 | 
						|
    writableTmpDirAsHomeHook
 | 
						|
    gitMinimal
 | 
						|
  ];
 | 
						|
 | 
						|
  buildInputs = [
 | 
						|
    clang_16
 | 
						|
    go
 | 
						|
    llvm_16
 | 
						|
    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 ];
 | 
						|
  };
 | 
						|
})
 |