class Cassandra < Formula desc "Eventually consistent, distributed key-value store" homepage "https://cassandra.apache.org" url "https://www.apache.org/dyn/closer.cgi?path=cassandra/3.11.0/apache-cassandra-3.11.0-bin.tar.gz" mirror "https://archive.apache.org/dist/cassandra/3.11.0/apache-cassandra-3.11.0-bin.tar.gz" sha256 "d597b99b402bd2cf925033519db9e58340acb893fd83d600d904ba4041d44fa7" bottle do cellar :any_skip_relocation sha256 "f304cf3030740ee48890139d4a5b6d71e1b57a02af5dbece3a9343aab8dbbdc9" => :high_sierra sha256 "007c79e7089c54d9f02fbae09680058f8b8ea812e93cc14eec0d159d459af985" => :sierra sha256 "cddd83cf00439208b7b87aa1985832ec230014a8d2ea89c0a2874c43befffaa8" => :el_capitan sha256 "cf55f9fea8c9182aca20821ea698951b0714a6a1fdcb0baac909a4b95e3efa52" => :yosemite end depends_on :python if MacOS.version <= :snow_leopard depends_on "cython" # Only >=Yosemite has new enough setuptools for successful compile of the below deps. resource "setuptools" do url "https://files.pythonhosted.org/packages/28/4f/889339f38da415e49cff15b21ab27becbf4c017c79fbfdeca663f5b33b36/setuptools-36.4.0.zip" sha256 "2758b0270fe8ceec42f336ee5b411e60dc8579febc27bb3ba9b794dc7f0239ae" end resource "futures" do url "https://files.pythonhosted.org/packages/cc/26/b61e3a4eb50653e8a7339d84eeaa46d1e93b92951978873c220ae64d0733/futures-3.1.1.tar.gz" sha256 "51ecb45f0add83c806c68e4b06106f90db260585b25ef2abfcda0bd95c0132fd" end resource "six" do url "https://files.pythonhosted.org/packages/b3/b2/238e2590826bfdd113244a40d9d3eb26918bd798fc187e2360a8367068db/six-1.10.0.tar.gz" sha256 "105f8d68616f8248e24bf0e9372ef04d3cc10104f1980f54d57b2ce73a5ad56a" end resource "thrift" do url "https://files.pythonhosted.org/packages/a3/ea/84a41e03f1ab14fb314c8bcf1c451090efa14c5cdfb9797d1079f502b54e/thrift-0.10.0.zip" sha256 "b7f6c09155321169af03f9fb20dc15a4a0c7481e7c334a5ba8f7f0d864633209" end resource "cql" do url "https://files.pythonhosted.org/packages/0b/15/523f6008d32f05dd3c6a2e7c2f21505f0a785b6dc8949cad325306858afc/cql-1.4.0.tar.gz" sha256 "7857c16d8aab7b736ab677d1016ef8513dedb64097214ad3a50a6c550cb7d6e0" end resource "cassandra-driver" do url "https://files.pythonhosted.org/packages/5a/96/a5b2458a0483d3cefdf13064d40119754c1552ea34b7f0e8c6e03e66eb0a/cassandra-driver-3.11.0.tar.gz" sha256 "643bed0fac08ee91630f0f35556bb62c3b4b007c20d4e6e8d349f769ea648150" 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 resources.each do |r| 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"] pkgshare.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}, "#{pkgshare}/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 pkgshare.install [buildpath/"tools/bin/cassandra-tools.in.sh"] # Update tools script files inreplace Dir[buildpath/"tools/bin/*"], "`dirname \"$0\"`/cassandra.in.sh", "#{pkgshare}/cassandra-tools.in.sh" # Make sure tools are available bin.install Dir[buildpath/"tools/bin/*"] bin.write_exec_script Dir["#{libexec}/bin/*"] rm %W[#{bin}/cqlsh #{bin}/cqlsh.py] # Remove existing exec scripts (bin/"cqlsh").write_env_script libexec/"bin/cqlsh", :PYTHONPATH => pypath (bin/"cqlsh.py").write_env_script libexec/"bin/cqlsh.py", :PYTHONPATH => pypath end plist_options :manual => "cassandra -f" def plist; <<-EOS.undent KeepAlive Label #{plist_name} ProgramArguments #{opt_bin}/cassandra -f RunAtLoad WorkingDirectory #{var}/lib/cassandra EOS end test do assert_match version.to_s, shell_output("#{bin}/cassandra -v") # This is enough to error out if env script is broken/insufficient. system bin/"cqlsh", "--version" end end