nixpkgs/pkgs/os-specific/linux/sysdig/default.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

150 lines
4.4 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
2023-03-20 09:01:39 +00:00
, yaml-cpp, nlohmann_json, re2, zstd
}:
2021-12-16 11:32:14 +00:00
let
# Compare with https://github.com/draios/sysdig/blob/dev/cmake/modules/falcosecurity-libs.cmake
2023-08-09 05:59:56 +00:00
libsRev = "59fb313475b82f842e9e9bbc1e0e629428c0a4cf";
libsSha256 = "sha256-IjzLbCOpB6EgPDgkGIyg1dNxHfYgU10OLgXrDOPmoTs=";
2022-05-14 04:58:07 +00:00
# Compare with https://github.com/falcosecurity/libs/blob/master/cmake/modules/valijson.cmake#L17
valijson = fetchFromGitHub {
owner = "tristanpenman";
repo = "valijson";
rev = "v0.6";
sha256 = "sha256-ZD19Q2MxMQd3yEKbY90GFCrerie5/jzgO8do4JQDoKM=";
};
# https://github.com/draios/sysdig/blob/0.31.5/cmake/modules/driver.cmake
2022-12-12 16:06:05 +00:00
driver = fetchFromGitHub {
owner = "falcosecurity";
repo = "libs";
2023-08-09 05:59:56 +00:00
rev = libsRev;
sha256 = libsSha256;
};
2022-12-12 16:06:05 +00:00
2021-12-16 11:32:14 +00:00
in
stdenv.mkDerivation rec {
pname = "sysdig";
2023-08-09 05:59:56 +00:00
version = "0.33.1";
2017-05-08 17:59:39 +00:00
src = fetchFromGitHub {
owner = "draios";
repo = "sysdig";
rev = version;
2023-08-09 05:59:56 +00:00
sha256 = "sha256-qcJ9EcePrsKic+wgsck+pTrRdQic0xhzguH4EYVP0gk=";
};
2023-08-09 05:59:56 +00:00
patches = [
# https://github.com/draios/sysdig/pull/2024
(fetchpatch {
url = "https://github.com/draios/sysdig/commit/d9515aad2be660b2ba7ec8c0b4fb2467a10434af.patch";
sha256 = "sha256-3m+Rn8BZS8U8QTBDJ6x7kQbH6BE3HKgt1iNnRjPEr8k=";
})
];
2021-12-16 11:32:14 +00:00
nativeBuildInputs = [ cmake perl installShellFiles pkg-config ];
buildInputs = [
2022-05-14 04:58:07 +00:00
luajit
ncurses
libb64
openssl
curl
jq
gcc
elfutils
tbb
2022-12-12 16:06:05 +00:00
libb64
re2
2022-05-14 04:58:07 +00:00
protobuf
grpc
yaml-cpp
2022-05-14 04:58:07 +00:00
jsoncpp
nlohmann_json
2023-03-20 09:01:39 +00:00
zstd
] ++ lib.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
2022-12-12 16:06:05 +00:00
cp -r ${driver} driver-src
chmod -R +w driver-src
cmakeFlagsArray+=(
"-DFALCOSECURITY_LIBS_SOURCE_DIR=$(pwd)/libs"
"-DVALIJSON_INCLUDE=${valijson}/include"
"-DDRIVER_SOURCE_DIR=$(pwd)/driver-src/driver"
)
2021-12-16 11:32:14 +00:00
'';
cmakeFlags = [
2015-12-12 20:25:17 +00:00
"-DUSE_BUNDLED_DEPS=OFF"
"-DSYSDIG_VERSION=${version}"
2022-12-12 16:06:05 +00:00
"-DUSE_BUNDLED_B64=OFF"
"-DUSE_BUNDLED_TBB=OFF"
"-DUSE_BUNDLED_RE2=OFF"
2019-12-19 09:49:37 +00:00
"-DCREATE_TEST_TARGETS=OFF"
] ++ lib.optional (kernel == null) "-DBUILD_DRIVER=OFF";
2023-06-10 06:13:32 +00:00
env.NIX_CFLAGS_COMPILE =
# needed since luajit-2.1.0-beta3
"-DluaL_reg=luaL_Reg -DluaL_getn(L,i)=((int)lua_objlen(L,i)) " +
# fix compiler warnings been treated as errors
"-Wno-error";
2014-05-06 20:54:41 +00:00
preConfigure = ''
2022-05-14 04:58:07 +00:00
if ! grep -q "${libsRev}" cmake/modules/falcosecurity-libs.cmake; then
echo "falcosecurity-libs checksum needs to be updated!"
exit 1
fi
2023-03-20 09:01:39 +00:00
cmakeFlagsArray+=(-DCMAKE_EXE_LINKER_FLAGS="-ltbb -lcurl -lzstd -labsl_synchronization")
'' + lib.optionalString (kernel != null) ''
2021-12-16 11:32:14 +00:00
export INSTALL_MOD_PATH="$out"
2014-05-06 20:54:41 +00: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
''
+ lib.optionalString (kernel != null) ''
make install_driver
kernel_dev=${kernel.dev}
kernel_dev=''${kernel_dev#${builtins.storeDir}/}
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
for i in $out/lib/modules/${kernel.modDirVersion}/{extra,updates}/scap.ko.xz; do
if test -f "$i"; then
xz -d $i
sed -i "s#$kernel_dev#................................#g" ''${i%.xz}
xz -9 ''${i%.xz}
fi
done
fi
'';
meta = with lib; {
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 10:19:50 +00: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 16:53:00 +00:00
downloadPage = "https://github.com/draios/sysdig/releases";
};
}