2021-12-16 11:32:14 +00:00
|
|
|
{ lib, stdenv, fetchFromGitHub, fetchpatch, cmake, kernel, installShellFiles, pkg-config
|
2021-03-16 12:26:01 +00:00
|
|
|
, 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
|
2018-11-22 21:31:38 +00:00
|
|
|
}:
|
2017-02-28 16:53:31 +00:00
|
|
|
|
2021-12-16 11:32:14 +00:00
|
|
|
let
|
2021-12-16 19:29:45 +00:00
|
|
|
# Compare with https://github.com/draios/sysdig/blob/dev/cmake/modules/falcosecurity-libs.cmake
|
2023-03-20 09:01:39 +00:00
|
|
|
libsRev = "0.10.5";
|
|
|
|
libsSha256 = "sha256-5a5ePcMHAlniJ8sU/5kKdRp5YkJ6tcr4h5Ru4Oc2kQY=";
|
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=";
|
|
|
|
};
|
|
|
|
|
2022-12-12 16:06:05 +00:00
|
|
|
driver = fetchFromGitHub {
|
|
|
|
owner = "falcosecurity";
|
|
|
|
repo = "libs";
|
2023-04-04 18:49:34 +00:00
|
|
|
rev = libsRev;
|
|
|
|
sha256 = libsSha256;
|
2023-02-23 03:43:02 +00:00
|
|
|
};
|
2022-12-12 16:06:05 +00:00
|
|
|
|
2021-12-16 11:32:14 +00:00
|
|
|
in
|
2017-02-28 16:53:31 +00:00
|
|
|
stdenv.mkDerivation rec {
|
2019-08-15 12:41:18 +00:00
|
|
|
pname = "sysdig";
|
2023-03-28 15:46:50 +00:00
|
|
|
version = "0.31.4";
|
2016-02-12 03:00:35 +00:00
|
|
|
|
2017-05-08 17:59:39 +00:00
|
|
|
src = fetchFromGitHub {
|
|
|
|
owner = "draios";
|
|
|
|
repo = "sysdig";
|
|
|
|
rev = version;
|
2023-03-28 15:46:50 +00:00
|
|
|
sha256 = "sha256-9WzvO17Q4fLwJNoDLk8xN8mqIcrBhcMyxfRhUXkQ5vI=";
|
2014-04-13 16:49:26 +00:00
|
|
|
};
|
2016-02-12 03:00:35 +00:00
|
|
|
|
2021-12-16 11:32:14 +00:00
|
|
|
nativeBuildInputs = [ cmake perl installShellFiles pkg-config ];
|
2014-04-13 16:49:26 +00:00
|
|
|
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
|
2023-01-29 14:44:19 +00:00
|
|
|
yaml-cpp
|
2022-05-14 04:58:07 +00:00
|
|
|
jsoncpp
|
|
|
|
nlohmann_json
|
2023-03-20 09:01:39 +00:00
|
|
|
zstd
|
2023-01-31 14:06:57 +00:00
|
|
|
] ++ lib.optionals (kernel != null) kernel.moduleBuildDependencies;
|
2016-02-12 03:00:35 +00:00
|
|
|
|
2016-02-26 17:38:15 +00:00
|
|
|
hardeningDisable = [ "pic" ];
|
2014-04-13 16:49:26 +00:00
|
|
|
|
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
|
|
|
'';
|
|
|
|
|
2014-04-13 16:49:26 +00:00
|
|
|
cmakeFlags = [
|
2015-12-12 20:25:17 +00:00
|
|
|
"-DUSE_BUNDLED_DEPS=OFF"
|
2016-07-25 12:47:13 +00:00
|
|
|
"-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"
|
2023-01-31 14:06:57 +00:00
|
|
|
] ++ lib.optional (kernel == null) "-DBUILD_DRIVER=OFF";
|
2016-02-12 03:00:35 +00:00
|
|
|
|
2017-05-02 11:47:36 +00:00
|
|
|
# needed since luajit-2.1.0-beta3
|
2023-02-19 19:23:32 +00:00
|
|
|
env.NIX_CFLAGS_COMPILE = "-DluaL_reg=luaL_Reg -DluaL_getn(L,i)=((int)lua_objlen(L,i))";
|
2017-05-02 11:47:36 +00:00
|
|
|
|
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")
|
2023-01-31 14:06:57 +00:00
|
|
|
'' + 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"
|
|
|
|
'';
|
2016-02-12 03:00:35 +00:00
|
|
|
|
2020-12-02 11:30:21 +00:00
|
|
|
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
|
|
|
|
''
|
2023-01-31 14:06:57 +00:00
|
|
|
+ lib.optionalString (kernel != null) ''
|
2020-12-02 11:30:21 +00:00
|
|
|
make install_driver
|
|
|
|
kernel_dev=${kernel.dev}
|
2023-03-23 17:34:04 +00:00
|
|
|
kernel_dev=''${kernel_dev#${builtins.storeDir}/}
|
2020-12-02 11:30:21 +00:00
|
|
|
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
|
2020-12-02 11:30:21 +00:00
|
|
|
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
|
2020-12-02 11:30:21 +00:00
|
|
|
fi
|
|
|
|
'';
|
|
|
|
|
2014-04-13 16:49:26 +00:00
|
|
|
|
2023-01-31 14:06:57 +00:00
|
|
|
meta = with lib; {
|
2016-02-12 03:00:35 +00:00
|
|
|
description = "A tracepoint-based system tracing tool for Linux (with clients for other OSes)";
|
2018-11-22 21:31:38 +00:00
|
|
|
license = with licenses; [ asl20 gpl2 mit ];
|
2014-05-09 07:06:56 +00:00
|
|
|
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";
|
2018-11-22 21:31:38 +00:00
|
|
|
homepage = "https://sysdig.com/opensource/";
|
2014-08-03 16:53:00 +00:00
|
|
|
downloadPage = "https://github.com/draios/sysdig/releases";
|
2014-04-13 16:49:26 +00:00
|
|
|
};
|
|
|
|
}
|