2021-04-28 23:22:39 -07:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, fetchurl
|
|
|
|
, python
|
|
|
|
, makeWrapper
|
|
|
|
, gawk
|
|
|
|
, bash
|
|
|
|
, getopt
|
|
|
|
, procps
|
|
|
|
, which
|
|
|
|
, jre
|
|
|
|
, coreutils
|
|
|
|
, nixosTests
|
|
|
|
# generation is the attribute version suffix such as 3_11 in pkgs.cassandra_3_11
|
2020-12-09 04:01:56 -08:00
|
|
|
, generation
|
2021-04-28 23:22:39 -07:00
|
|
|
, version
|
|
|
|
, sha256
|
|
|
|
, extraMeta ? { }
|
2020-12-09 04:01:56 -08:00
|
|
|
, ...
|
2016-07-22 12:34:43 -07:00
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
2021-01-14 23:07:56 -08:00
|
|
|
libPath = lib.makeLibraryPath [ stdenv.cc.cc ];
|
2021-04-28 23:39:35 -07:00
|
|
|
binPath = lib.makeBinPath [
|
2016-10-06 12:45:11 -07:00
|
|
|
bash
|
|
|
|
getopt
|
|
|
|
gawk
|
|
|
|
which
|
|
|
|
jre
|
2018-03-25 21:01:31 -07:00
|
|
|
procps
|
2021-04-28 23:22:39 -07:00
|
|
|
];
|
2016-07-22 12:34:43 -07:00
|
|
|
in
|
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2019-08-15 05:41:18 -07:00
|
|
|
pname = "cassandra";
|
2017-11-07 05:11:56 -08:00
|
|
|
inherit version;
|
2016-07-22 12:34:43 -07:00
|
|
|
|
|
|
|
src = fetchurl {
|
|
|
|
inherit sha256;
|
2019-08-15 05:41:18 -07:00
|
|
|
url = "mirror://apache/cassandra/${version}/apache-${pname}-${version}-bin.tar.gz";
|
2016-07-22 12:34:43 -07:00
|
|
|
};
|
|
|
|
|
2019-04-08 21:31:55 -07:00
|
|
|
nativeBuildInputs = [ makeWrapper coreutils ];
|
2016-07-22 12:34:43 -07:00
|
|
|
|
|
|
|
installPhase = ''
|
2021-02-18 03:17:30 -08:00
|
|
|
runHook preInstall
|
|
|
|
|
2016-07-22 12:34:43 -07:00
|
|
|
mkdir $out
|
|
|
|
mv * $out
|
2017-08-16 06:22:27 -07:00
|
|
|
|
|
|
|
# Clean up documentation.
|
2019-08-15 05:41:18 -07:00
|
|
|
mkdir -p $out/share/doc/${pname}-${version}
|
2017-08-16 06:22:27 -07:00
|
|
|
mv $out/CHANGES.txt \
|
|
|
|
$out/LICENSE.txt \
|
|
|
|
$out/NEWS.txt \
|
|
|
|
$out/NOTICE.txt \
|
|
|
|
$out/javadoc \
|
2019-08-15 05:41:18 -07:00
|
|
|
$out/share/doc/${pname}-${version}
|
2017-08-16 06:22:27 -07:00
|
|
|
|
|
|
|
if [[ -d $out/doc ]]; then
|
2019-08-15 05:41:18 -07:00
|
|
|
mv "$out/doc/"* $out/share/doc/${pname}-${version}
|
2017-08-16 06:22:27 -07:00
|
|
|
rmdir $out/doc
|
|
|
|
fi
|
|
|
|
|
2019-04-07 06:53:57 -07:00
|
|
|
|
|
|
|
for cmd in bin/cassandra \
|
|
|
|
bin/nodetool \
|
|
|
|
bin/sstablekeys \
|
|
|
|
bin/sstableloader \
|
|
|
|
bin/sstablescrub \
|
|
|
|
bin/sstableupgrade \
|
|
|
|
bin/sstableutil \
|
2019-04-08 21:31:55 -07:00
|
|
|
bin/sstableverify; do
|
|
|
|
# Check if file exists because some don't exist across all versions
|
|
|
|
if [ -f $out/$cmd ]; then
|
|
|
|
wrapProgram $out/bin/$(basename "$cmd") \
|
|
|
|
--suffix-each LD_LIBRARY_PATH : ${libPath} \
|
|
|
|
--prefix PATH : ${binPath} \
|
|
|
|
--set JAVA_HOME ${jre}
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
for cmd in tools/bin/cassandra-stress \
|
2019-04-07 06:53:57 -07:00
|
|
|
tools/bin/cassandra-stressd \
|
|
|
|
tools/bin/sstabledump \
|
|
|
|
tools/bin/sstableexpiredblockers \
|
|
|
|
tools/bin/sstablelevelreset \
|
|
|
|
tools/bin/sstablemetadata \
|
|
|
|
tools/bin/sstableofflinerelevel \
|
|
|
|
tools/bin/sstablerepairedset \
|
|
|
|
tools/bin/sstablesplit \
|
|
|
|
tools/bin/token-generator; do
|
2019-04-08 21:31:55 -07:00
|
|
|
# Check if file exists because some don't exist across all versions
|
2016-07-22 12:34:43 -07:00
|
|
|
if [ -f $out/$cmd ]; then
|
2019-04-08 21:31:55 -07:00
|
|
|
makeWrapper $out/$cmd $out/bin/$(basename "$cmd") \
|
2016-07-22 12:34:43 -07:00
|
|
|
--suffix-each LD_LIBRARY_PATH : ${libPath} \
|
|
|
|
--prefix PATH : ${binPath} \
|
|
|
|
--set JAVA_HOME ${jre}
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
|
|
|
wrapProgram $out/bin/cqlsh --prefix PATH : ${python}/bin
|
2021-02-18 03:17:30 -08:00
|
|
|
|
|
|
|
runHook postInstall
|
2021-04-28 23:22:39 -07:00
|
|
|
'';
|
2016-07-22 12:34:43 -07:00
|
|
|
|
2020-12-09 04:01:56 -08:00
|
|
|
passthru = {
|
|
|
|
tests =
|
|
|
|
let
|
|
|
|
test = nixosTests."cassandra_${generation}";
|
2021-04-28 23:22:39 -07:00
|
|
|
in
|
|
|
|
{
|
2020-12-09 04:01:56 -08:00
|
|
|
nixos =
|
|
|
|
assert test.testPackage.version == version;
|
|
|
|
test;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2021-01-10 23:54:33 -08:00
|
|
|
meta = with lib; {
|
2020-03-31 18:11:51 -07:00
|
|
|
homepage = "http://cassandra.apache.org/";
|
2016-07-22 12:34:43 -07:00
|
|
|
description = "A massively scalable open source NoSQL database";
|
2016-10-06 12:45:11 -07:00
|
|
|
platforms = platforms.unix;
|
2016-07-22 12:34:43 -07:00
|
|
|
license = licenses.asl20;
|
2020-12-14 06:37:46 -08:00
|
|
|
maintainers = [ maintainers.roberth ];
|
2021-02-18 02:44:25 -08:00
|
|
|
} // extraMeta;
|
2016-07-22 12:34:43 -07:00
|
|
|
}
|