diff options
Diffstat (limited to 'infra/libkookie/nixpkgs/pkgs/servers/computing/storm/default.nix')
-rw-r--r-- | infra/libkookie/nixpkgs/pkgs/servers/computing/storm/default.nix | 69 |
1 files changed, 69 insertions, 0 deletions
diff --git a/infra/libkookie/nixpkgs/pkgs/servers/computing/storm/default.nix b/infra/libkookie/nixpkgs/pkgs/servers/computing/storm/default.nix new file mode 100644 index 000000000000..541e9f6e11b5 --- /dev/null +++ b/infra/libkookie/nixpkgs/pkgs/servers/computing/storm/default.nix @@ -0,0 +1,69 @@ +{ stdenv, lib, fetchurl, zip, unzip +, jdk, python +, confFile ? "" +, extraLibraryPaths ? [] +, extraJars ? [] +}: + +stdenv.mkDerivation rec { + pname = "apache-storm"; + version = "2.2.0"; + name = "${pname}-${version}"; + + src = fetchurl { + url = "mirror://apache/storm/${name}/${name}.tar.gz"; + sha256 = "0xc6lfilfkkjyds59b6c770gj21v9srzpln31c9qb3ls6hzic8gn"; + }; + + buildInputs = [ zip unzip ]; + + installPhase = '' + mkdir -p $out/share/${name} + mv public $out/docs + mv examples $out/share/${name}/. + + mv external extlib* lib $out/. + mv conf bin $out/. + mv log4j2 $out/conf/. + ''; + + fixupPhase = '' + # Fix python reference + sed -i \ + -e '19iPYTHON=${python}/bin/python' \ + -e 's|#!/usr/bin/.*python|#!${python}/bin/python|' \ + $out/bin/storm + sed -i \ + -e 's|#!/usr/bin/.*python|#!${python}/bin/python|' \ + -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 + + # Default jdk location + sed -i -e 's|#.*export JAVA_HOME=.*|export JAVA_HOME="${jdk.home}"|' \ + $out/conf/storm-env.sh + ls -lh $out/lib + unzip $out/lib/storm-client-${version}.jar defaults.yaml; + zip -d $out/lib/storm-client-${version}.jar defaults.yaml; + sed -i \ + -e 's|java.library.path: .*|java.library.path: "${lib.concatStringsSep ":" extraLibraryPaths}"|' \ + -e 's|storm.log4j2.conf.dir: .*|storm.log4j2.conf.dir: "conf/log4j2"|' \ + defaults.yaml + ${if confFile != "" then ''cat ${confFile} >> defaults.yaml'' else ""} + mv defaults.yaml $out/conf; + + # Link to extra jars + cd $out/lib; + ${lib.concatMapStrings (jar: "ln -s ${jar};\n") extraJars} + ''; + + dontStrip = true; + + meta = with stdenv.lib; { + homepage = "http://storm.apache.org"; + description = "Distributed realtime computation system"; + license = licenses.asl20; + maintainers = with maintainers; [ edwtjo vizanto ]; + platforms = with platforms; unix; + }; +} |