2018-07-21 01:44:44 +01:00
|
|
|
{ stdenv, lib, fetchurl, zip, unzip
|
2022-01-11 23:40:02 +00:00
|
|
|
, jdk, python2
|
2020-06-22 14:36:39 +01:00
|
|
|
, confFile ? ""
|
|
|
|
, extraLibraryPaths ? []
|
|
|
|
, extraJars ? []
|
|
|
|
}:
|
2013-02-07 14:32:10 +00:00
|
|
|
|
2016-07-13 05:45:33 +01:00
|
|
|
stdenv.mkDerivation rec {
|
2020-06-22 14:36:39 +01:00
|
|
|
pname = "apache-storm";
|
2021-11-28 11:17:23 +00:00
|
|
|
version = "2.3.0";
|
2020-06-22 14:36:39 +01:00
|
|
|
name = "${pname}-${version}";
|
|
|
|
|
2013-02-07 14:32:10 +00:00
|
|
|
src = fetchurl {
|
2020-06-22 14:36:39 +01:00
|
|
|
url = "mirror://apache/storm/${name}/${name}.tar.gz";
|
2021-11-28 11:17:23 +00:00
|
|
|
sha256 = "sha256-ScIlWyZjPG/ZY5nFIDOeRZ/NopoOfm0Mh3XO/P9sNjY=";
|
2013-02-07 14:32:10 +00:00
|
|
|
};
|
|
|
|
|
2021-02-20 21:01:53 +00:00
|
|
|
nativeBuildInputs = [ zip unzip ];
|
2013-02-07 14:32:10 +00:00
|
|
|
|
|
|
|
installPhase = ''
|
2016-07-13 05:45:33 +01:00
|
|
|
mkdir -p $out/share/${name}
|
|
|
|
mv public $out/docs
|
|
|
|
mv examples $out/share/${name}/.
|
2013-02-07 14:32:10 +00:00
|
|
|
|
2018-04-12 22:35:24 +01:00
|
|
|
mv external extlib* lib $out/.
|
2016-07-13 05:45:33 +01:00
|
|
|
mv conf bin $out/.
|
|
|
|
mv log4j2 $out/conf/.
|
|
|
|
'';
|
2013-09-10 15:05:47 +01:00
|
|
|
|
2016-07-13 05:45:33 +01:00
|
|
|
fixupPhase = ''
|
|
|
|
# Fix python reference
|
|
|
|
sed -i \
|
2022-01-11 23:40:02 +00:00
|
|
|
-e '19iPYTHON=${python2}/bin/python' \
|
|
|
|
-e 's|#!/usr/bin/.*python|#!${python2}/bin/python|' \
|
2016-07-13 05:45:33 +01:00
|
|
|
$out/bin/storm
|
|
|
|
sed -i \
|
2022-01-11 23:40:02 +00:00
|
|
|
-e 's|#!/usr/bin/.*python|#!${python2}/bin/python|' \
|
2016-07-13 05:45:33 +01:00
|
|
|
-e "s|STORM_CONF_DIR = .*|STORM_CONF_DIR = os.getenv('STORM_CONF_DIR','$out/conf')|" \
|
|
|
|
-e 's|STORM_LOG4J2_CONF_DIR =.*|STORM_LOG4J2_CONF_DIR = os.path.join(STORM_CONF_DIR, "log4j2")|' \
|
|
|
|
$out/bin/storm.py
|
2020-06-22 14:36:39 +01:00
|
|
|
|
2016-07-13 05:45:33 +01:00
|
|
|
# Default jdk location
|
|
|
|
sed -i -e 's|#.*export JAVA_HOME=.*|export JAVA_HOME="${jdk.home}"|' \
|
|
|
|
$out/conf/storm-env.sh
|
2020-06-22 14:36:39 +01:00
|
|
|
ls -lh $out/lib
|
|
|
|
unzip $out/lib/storm-client-${version}.jar defaults.yaml;
|
|
|
|
zip -d $out/lib/storm-client-${version}.jar defaults.yaml;
|
2016-07-13 05:45:33 +01:00
|
|
|
sed -i \
|
2020-06-22 14:36:39 +01:00
|
|
|
-e 's|java.library.path: .*|java.library.path: "${lib.concatStringsSep ":" extraLibraryPaths}"|' \
|
2016-07-13 05:45:33 +01:00
|
|
|
-e 's|storm.log4j2.conf.dir: .*|storm.log4j2.conf.dir: "conf/log4j2"|' \
|
|
|
|
defaults.yaml
|
2021-01-24 09:19:10 +00:00
|
|
|
${if confFile != "" then "cat ${confFile} >> defaults.yaml" else ""}
|
2016-07-13 05:45:33 +01:00
|
|
|
mv defaults.yaml $out/conf;
|
2013-02-14 08:58:49 +00:00
|
|
|
|
2020-06-22 14:36:39 +01:00
|
|
|
# Link to extra jars
|
2016-07-13 05:45:33 +01:00
|
|
|
cd $out/lib;
|
2013-02-14 08:58:49 +00:00
|
|
|
${lib.concatMapStrings (jar: "ln -s ${jar};\n") extraJars}
|
2013-02-07 14:32:10 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
dontStrip = true;
|
|
|
|
|
2021-01-11 07:54:33 +00:00
|
|
|
meta = with lib; {
|
2021-12-29 15:02:51 +00:00
|
|
|
homepage = "https://storm.apache.org/";
|
2013-10-06 10:49:53 +01:00
|
|
|
description = "Distributed realtime computation system";
|
2016-07-13 05:45:33 +01:00
|
|
|
license = licenses.asl20;
|
|
|
|
maintainers = with maintainers; [ edwtjo vizanto ];
|
2016-08-02 18:50:55 +01:00
|
|
|
platforms = with platforms; unix;
|
2013-02-07 14:32:10 +00:00
|
|
|
};
|
|
|
|
}
|