3
0
Fork 0
forked from mirrors/nixpkgs
nixpkgs/pkgs/os-specific/linux/sysdig/default.nix

89 lines
3 KiB
Nix
Raw Normal View History

2021-12-16 11:32:14 +00:00
{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, kernel, installShellFiles, pkg-config
, luajit, ncurses, perl, jsoncpp, libb64, openssl, curl, jq, gcc, elfutils, tbb, protobuf, grpc
}:
2021-01-15 14:45:37 +00:00
with lib;
2021-12-16 11:32:14 +00:00
let
# Compare with https://github.com/draios/sysdig/blob/dev/cmake/modules/falcosecurity-libs.cmake
2021-12-16 11:32:14 +00:00
libsRev = "2160111cd088aea9ae2235d3385ecb0b1ab6623c";
libsSha256 = "sha256-TOuxXtrxujyAjzAtlX3/eCfM16mwxnmZ6Wg44SG0dTs=";
in
stdenv.mkDerivation rec {
pname = "sysdig";
2021-12-16 11:32:14 +00:00
version = "0.28.0";
2017-05-08 18:59:39 +01:00
src = fetchFromGitHub {
owner = "draios";
repo = "sysdig";
rev = version;
2021-12-16 11:32:14 +00:00
sha256 = "sha256-oE3vCmOw+gcmvGqj7Xk5injpNC/YThckJMNg5XRFhME=";
};
2021-12-16 11:32:14 +00:00
nativeBuildInputs = [ cmake perl installShellFiles pkg-config ];
buildInputs = [
luajit ncurses jsoncpp libb64 openssl curl jq gcc elfutils tbb protobuf grpc
] ++ optionals (kernel != null) kernel.moduleBuildDependencies;
hardeningDisable = [ "pic" ];
2021-12-16 11:32:14 +00:00
postUnpack = ''
cp -r ${fetchFromGitHub {
owner = "falcosecurity";
repo = "libs";
rev = libsRev;
sha256 = libsSha256;
}} libs
chmod -R +w libs
cmakeFlagsArray+=("-DFALCOSECURITY_LIBS_SOURCE_DIR=$(pwd)/libs")
'';
cmakeFlags = [
2015-12-12 20:25:17 +00:00
"-DUSE_BUNDLED_DEPS=OFF"
"-DSYSDIG_VERSION=${version}"
2019-12-19 09:49:37 +00:00
"-DCREATE_TEST_TARGETS=OFF"
2014-05-12 21:08:45 +01:00
] ++ optional (kernel == null) "-DBUILD_DRIVER=OFF";
# needed since luajit-2.1.0-beta3
2019-10-30 02:23:29 +00:00
NIX_CFLAGS_COMPILE = "-DluaL_reg=luaL_Reg -DluaL_getn(L,i)=((int)lua_objlen(L,i))";
2014-05-06 21:54:41 +01:00
preConfigure = ''
2021-09-12 09:49:06 +01:00
cmakeFlagsArray+=(-DCMAKE_EXE_LINKER_FLAGS="-ltbb -lcurl -labsl_synchronization")
'' + optionalString (kernel != null) ''
2021-12-16 11:32:14 +00:00
export INSTALL_MOD_PATH="$out"
2014-05-06 21:54:41 +01:00
export KERNELDIR="${kernel.dev}/lib/modules/${kernel.modDirVersion}/build"
'';
postInstall =
''
# Fix the bash completion location
installShellCompletion --bash $out/etc/bash_completion.d/sysdig
rm $out/etc/bash_completion.d/sysdig
rmdir $out/etc/bash_completion.d
rmdir $out/etc
''
+ optionalString (kernel != null) ''
make install_driver
kernel_dev=${kernel.dev}
kernel_dev=''${kernel_dev#/nix/store/}
kernel_dev=''${kernel_dev%%-linux*dev*}
2021-12-16 11:32:14 +00:00
if test -f "$out/lib/modules/${kernel.modDirVersion}/extra/scap.ko"; then
sed -i "s#$kernel_dev#................................#g" $out/lib/modules/${kernel.modDirVersion}/extra/scap.ko
else
2021-12-16 11:32:14 +00:00
xz -d $out/lib/modules/${kernel.modDirVersion}/extra/scap.ko.xz
sed -i "s#$kernel_dev#................................#g" $out/lib/modules/${kernel.modDirVersion}/extra/scap.ko
xz $out/lib/modules/${kernel.modDirVersion}/extra/scap.ko
fi
'';
2017-05-08 18:59:39 +01:00
meta = {
description = "A tracepoint-based system tracing tool for Linux (with clients for other OSes)";
license = with licenses; [ asl20 gpl2 mit ];
maintainers = [maintainers.raskin];
2018-08-10 11:19:50 +01:00
platforms = ["x86_64-linux"] ++ platforms.darwin;
2018-12-29 23:53:59 +00:00
broken = kernel != null && versionOlder kernel.version "4.14";
homepage = "https://sysdig.com/opensource/";
2014-08-03 17:53:00 +01:00
downloadPage = "https://github.com/draios/sysdig/releases";
};
}