class Cassandra < Formula desc "Eventually consistent, distributed key-value store" homepage "https://cassandra.apache.org" url "https://www.apache.org/dyn/closer.lua/cassandra/3.5/apache-cassandra-3.5-bin.tar.gz" mirror "https://archive.apache.org/dist/cassandra/3.5/apache-cassandra-3.5-bin.tar.gz" sha256 "b575990dfa53567bc67407318330f9406750f4543a9d385b0fce326eb430bf4f" bottle do sha256 "1ee1f606696f6210ca500e52e87c8c84ae604912cf9b8408b99783b31e5e82d8" => :el_capitan sha256 "107f947e10105c61bfec68e3fbd32487cb1c69c26aaad34d33396c3d40fe936b" => :yosemite sha256 "674a7b2969039a671e75551f4a70c86a02b0d18889366ac345d730c141c03b7c" => :mavericks end depends_on :python if MacOS.version <= :snow_leopard # Only Yosemite has new enough setuptools for successful compile of the below deps. resource "setuptools" do url "https://pypi.python.org/packages/source/s/setuptools/setuptools-12.0.5.tar.gz" sha256 "bda326cad34921060a45004b0dd81f828d471695346e303f4ca53b8ba6f4547f" end resource "thrift" do url "https://pypi.python.org/packages/source/t/thrift/thrift-0.9.2.tar.gz" sha256 "08f665e4b033c9d2d0b6174d869273104362c80e77ee4c01054a74141e378afa" end resource "futures" do url "https://pypi.python.org/packages/source/f/futures/futures-2.2.0.tar.gz" sha256 "151c057173474a3a40f897165951c0e33ad04f37de65b6de547ddef107fd0ed3" end resource "six" do url "https://pypi.python.org/packages/source/s/six/six-1.9.0.tar.gz" sha256 "e24052411fc4fbd1f672635537c3fc2330d9481b18c0317695b46259512c91d5" end resource "cql" do url "https://pypi.python.org/packages/source/c/cql/cql-1.4.0.tar.gz" sha256 "7857c16d8aab7b736ab677d1016ef8513dedb64097214ad3a50a6c550cb7d6e0" end resource "cassandra-driver" do url "https://pypi.python.org/packages/source/c/cassandra-driver/cassandra-driver-3.0.0.tar.gz" sha256 "b84e3a0716564f1f6a0deba120308d801f0232010d9c2df90579de293e59fa78" end def install (var+"lib/cassandra").mkpath (var+"log/cassandra").mkpath pypath = libexec/"vendor/lib/python2.7/site-packages" ENV.prepend_create_path "PYTHONPATH", pypath %w[setuptools thrift futures six cql cassandra-driver].each do |r| resource(r).stage do system "python", *Language::Python.setup_install_args(libexec/"vendor") end end inreplace "conf/cassandra.yaml", "/var/lib/cassandra", "#{var}/lib/cassandra" inreplace "conf/cassandra-env.sh", "/lib/", "/" inreplace "bin/cassandra", "-Dcassandra.logdir\=$CASSANDRA_HOME/logs", "-Dcassandra.logdir\=#{var}/log/cassandra" inreplace "bin/cassandra.in.sh" do |s| s.gsub! "CASSANDRA_HOME=\"`dirname \"$0\"`/..\"", "CASSANDRA_HOME=\"#{libexec}\"" # Store configs in etc, outside of keg s.gsub! "CASSANDRA_CONF=\"$CASSANDRA_HOME/conf\"", "CASSANDRA_CONF=\"#{etc}/cassandra\"" # Jars installed to prefix, no longer in a lib folder s.gsub! "\"$CASSANDRA_HOME\"/lib/*.jar", "\"$CASSANDRA_HOME\"/*.jar" # The jammm Java agent is not in a lib/ subdir either: s.gsub! "JAVA_AGENT=\"$JAVA_AGENT -javaagent:$CASSANDRA_HOME/lib/jamm-", "JAVA_AGENT=\"$JAVA_AGENT -javaagent:$CASSANDRA_HOME/jamm-" # Storage path s.gsub! "cassandra_storagedir\=\"$CASSANDRA_HOME/data\"", "cassandra_storagedir\=\"#{var}/lib/cassandra\"" end rm Dir["bin/*.bat", "bin/*.ps1"] # This breaks on `brew uninstall cassandra && brew install cassandra` # https://github.com/Homebrew/homebrew/pull/38309 (etc+"cassandra").install Dir["conf/*"] libexec.install Dir["*.txt", "{bin,interface,javadoc,pylib,lib/licenses}"] libexec.install Dir["lib/*.jar"] share.install [libexec+"bin/cassandra.in.sh", libexec+"bin/stop-server"] inreplace Dir["#{libexec}/bin/cassandra*", "#{libexec}/bin/debug-cql", "#{libexec}/bin/nodetool", "#{libexec}/bin/sstable*"], %r{`dirname "?\$0"?`/cassandra.in.sh}, "#{share}/cassandra.in.sh" # Make sure tools are installed rm Dir[buildpath/"tools/bin/*.bat"] # Delete before install to avoid copying useless files (libexec/"tools").install Dir[buildpath/"tools/lib/*.jar"] # Tools use different cassandra.in.sh and should be changed differently mv buildpath/"tools/bin/cassandra.in.sh", buildpath/"tools/bin/cassandra-tools.in.sh" inreplace buildpath/"tools/bin/cassandra-tools.in.sh" do |s| # Tools have slightly different path to CASSANDRA_HOME s.gsub! "CASSANDRA_HOME=\"`dirname $0`/../..\"", "CASSANDRA_HOME=\"#{libexec}\"" # Store configs in etc, outside of keg s.gsub! "CASSANDRA_CONF=\"$CASSANDRA_HOME/conf\"", "CASSANDRA_CONF=\"#{etc}/cassandra\"" # Core Jars installed to prefix, no longer in a lib folder s.gsub! "\"$CASSANDRA_HOME\"/lib/*.jar", "\"$CASSANDRA_HOME\"/*.jar" # Tools Jars are under tools folder s.gsub! "\"$CASSANDRA_HOME\"/tools/lib/*.jar", "\"$CASSANDRA_HOME\"/tools/*.jar" # Storage path s.gsub! "cassandra_storagedir\=\"$CASSANDRA_HOME/data\"", "cassandra_storagedir\=\"#{var}/lib/cassandra\"" end share.install [buildpath/"tools/bin/cassandra-tools.in.sh"] # Update tools script files inreplace Dir[buildpath/"tools/bin/*"], "`dirname \"$0\"`/cassandra.in.sh", "#{share}/cassandra-tools.in.sh" # Make sure tools are available bin.install Dir[buildpath/"tools/bin/*"] bin.write_exec_script Dir["#{libexec}/bin/*"] rm bin/"cqlsh" # Remove existing exec script (bin/"cqlsh").write_env_script libexec/"bin/cqlsh", :PYTHONPATH => pypath end plist_options :manual => "cassandra start" def plist; <<-EOS.undent KeepAlive Label #{plist_name} ProgramArguments #{opt_bin}/cassandra -f RunAtLoad WorkingDirectory #{var}/lib/cassandra EOS end test do system "#{bin}/cassandra", "-v" system "#{bin}/cassandra-stressd", "-v" system "#{bin}/sstablesplit", "-h" system "#{bin}/nodetool", "help" end end