{ lib, stdenv, fetchFromGitHub, which, pcre2, zlib, ncurses, openssl, }: let version = "unstable-2023-08-09"; in stdenv.mkDerivation { pname = "ossec-agent"; inherit version; src = fetchFromGitHub { owner = "ossec"; repo = "ossec-hids"; rev = "c8a36b0af3d4ee5252855b90236407cbfb996eb2"; sha256 = "sha256-AZ8iubyhNHXGR/l+hA61ifNDUoan7AQ42l/uRTt5GmE="; }; # clear is used during the build process nativeBuildInputs = [ ncurses ]; buildInputs = [ which pcre2 zlib openssl ]; # patch to remove root manipulation, install phase which tries to add users to the system, and init phase which tries to modify the system to launch files patches = [ ./no-root.patch ]; # Workaround build failure on -fno-common toolchains like upstream # gcc-10. Otherwise build fails as: # ld: src/common/mgmt/pint-worker-external.po:(.data.rel.local+0x0): multiple definition of # `PINT_worker_external_impl'; src/common/mgmt/pint-mgmt.po:(.bss+0x20): first defined here env.NIX_CFLAGS_COMPILE = "-fcommon"; buildPhase = '' mkdir $out export USER_DIR="$out" # just to satisy the script ./install.sh <