nixpkgs/pkgs/development/tools/misc/blackfire/default.nix

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

106 lines
3.4 KiB
Nix
Raw Normal View History

2020-10-03 22:36:47 +00:00
{ stdenv
, lib
, fetchurl
, dpkg
, writeShellScript
, curl
, jq
, common-updater-scripts
}:
stdenv.mkDerivation rec {
pname = "blackfire";
2023-04-22 03:59:40 +00:00
version = "2.15.0";
2020-10-03 22:36:47 +00:00
src = passthru.sources.${stdenv.hostPlatform.system} or (throw "Unsupported platform for blackfire: ${stdenv.hostPlatform.system}");
2020-10-03 22:36:47 +00:00
nativeBuildInputs = lib.optionals stdenv.isLinux [
dpkg
];
2020-10-03 22:36:47 +00:00
dontUnpack = true;
installPhase = ''
runHook preInstall
2022-04-21 19:27:18 +00:00
if ${ lib.boolToString stdenv.isLinux }
then
dpkg-deb -x $src $out
mv $out/usr/* $out
rmdir $out/usr
# Fix ExecStart path and replace deprecated directory creation method,
# use dynamic user.
substituteInPlace "$out/lib/systemd/system/blackfire-agent.service" \
--replace '/usr/' "$out/" \
--replace 'ExecStartPre=/bin/mkdir -p /var/run/blackfire' 'RuntimeDirectory=blackfire' \
--replace 'ExecStartPre=/bin/chown blackfire: /var/run/blackfire' "" \
--replace 'User=blackfire' 'DynamicUser=yes' \
--replace 'PermissionsStartOnly=true' ""
2020-10-03 22:36:47 +00:00
2022-04-21 19:27:18 +00:00
# Modernize socket path.
substituteInPlace "$out/etc/blackfire/agent" \
--replace '/var/run' '/run'
else
mkdir $out
2022-04-21 19:27:18 +00:00
tar -zxvf $src
mv etc $out
mv usr/* $out
fi
2020-10-03 22:36:47 +00:00
runHook postInstall
'';
passthru = {
sources = {
"x86_64-linux" = fetchurl {
url = "https://packages.blackfire.io/debian/pool/any/main/b/blackfire/blackfire_${version}_amd64.deb";
2023-04-22 03:59:40 +00:00
sha256 = "eKHP7yOy6hnHi0EomZhsGXWinNy4roQ9qRGn8tah6KI=";
};
"i686-linux" = fetchurl {
url = "https://packages.blackfire.io/debian/pool/any/main/b/blackfire/blackfire_${version}_i386.deb";
2023-04-22 03:59:40 +00:00
sha256 = "sCFVmGz850h9NKoVKUBV+93k913ihpfk+48buzsNOqw=";
};
"aarch64-linux" = fetchurl {
url = "https://packages.blackfire.io/debian/pool/any/main/b/blackfire/blackfire_${version}_arm64.deb";
2023-04-22 03:59:40 +00:00
sha256 = "V6adZVR82Z15fN//wuwHZK6C95hAxXPB9NuA0kx1qPA=";
};
"aarch64-darwin" = fetchurl {
url = "https://packages.blackfire.io/blackfire/${version}/blackfire-darwin_arm64.pkg.tar.gz";
2023-04-22 03:59:40 +00:00
sha256 = "X0sWPjmVAzJTKHUxVLbhWTdc7ryn2GkNMj9CuRgTb0I=";
};
"x86_64-darwin" = fetchurl {
url = "https://packages.blackfire.io/blackfire/${version}/blackfire-darwin_amd64.pkg.tar.gz";
2023-04-22 03:59:40 +00:00
sha256 = "FvoslunTPxmc2KqaxNSb0uK9fP4CV5HR39UDoW3zJfw=";
};
};
updateScript = writeShellScript "update-blackfire" ''
2022-04-21 19:27:18 +00:00
set -o errexit
2020-10-03 22:36:47 +00:00
export PATH="${lib.makeBinPath [ curl jq common-updater-scripts ]}"
2022-04-21 19:27:18 +00:00
NEW_VERSION=$(curl -s https://blackfire.io/api/v1/releases | jq .cli --raw-output)
if [[ "${version}" = "$NEW_VERSION" ]]; then
echo "The new version same as the old version."
exit 0
fi
for platform in ${lib.escapeShellArgs meta.platforms}; do
update-source-version "blackfire" "0" "${lib.fakeSha256}" --source-key="sources.$platform"
update-source-version "blackfire" "$NEW_VERSION" --source-key="sources.$platform"
2022-04-21 19:27:18 +00:00
done
2020-10-03 22:36:47 +00:00
'';
};
meta = with lib; {
description = "Blackfire Profiler agent and client";
homepage = "https://blackfire.io/";
sourceProvenance = with sourceTypes; [ binaryNativeCode ];
2020-10-03 22:36:47 +00:00
license = licenses.unfree;
maintainers = with maintainers; [ shyim ];
2022-09-13 09:32:23 +00:00
platforms = [ "x86_64-linux" "aarch64-linux" "i686-linux" "x86_64-darwin" "aarch64-darwin" ];
2020-10-03 22:36:47 +00:00
};
}