class Cassandra < Formula desc "Eventually consistent, distributed key-value store" homepage "https://cassandra.apache.org" url "https://www.apache.org/dyn/closer.lua?path=cassandra/3.11.8/apache-cassandra-3.11.8-bin.tar.gz" mirror "https://archive.apache.org/dist/cassandra/3.11.8/apache-cassandra-3.11.8-bin.tar.gz" sha256 "3d04e4b79c3f264cb491e1bc5127ec465102b55005a6c8f4af8548b32e74bf50" license "Apache-2.0" livecheck do url :stable end bottle do cellar :any_skip_relocation sha256 "10ab8a8b38c1fa1cc534f2600dcac773588bb5d65d913fedc1012e46f4e952c7" => :catalina sha256 "844b20c9363081279243d537f2b1f16dbc6d6d4c8aec9e0ff0d33a3f6a89bfa6" => :mojave sha256 "fa549ffa600c249ae8ab011927afa45924e6fbd6dc2fe640667d260a55037375" => :high_sierra end depends_on "cython" => :build depends_on :macos # Due to Python 2 (https://issues.apache.org/jira/browse/CASSANDRA-10190) # Only >=Yosemite has new enough setuptools for successful compile of the below deps. # Python 2 needs setuptools < 45.0.0 (https://github.com/pypa/setuptools/issues/2094) resource "setuptools" do url "https://files.pythonhosted.org/packages/b2/40/4e00501c204b457f10fe410da0c97537214b2265247bc9a5bc6edd55b9e4/setuptools-44.1.1.zip" sha256 "c67aa55db532a0dadc4d2e20ba9961cbd3ccc84d544e9029699822542b5a476b" end resource "futures" do url "https://files.pythonhosted.org/packages/47/04/5fc6c74ad114032cd2c544c575bffc17582295e9cd6a851d6026ab4b2c00/futures-3.3.0.tar.gz" sha256 "7e033af76a5e35f58e56da7a91e687706faf4e7bdfb2cbc3f2cca6b9bcda9794" end resource "six" do url "https://files.pythonhosted.org/packages/6b/34/415834bfdafca3c5f451532e8a8d9ba89a21c9743a0c59fbd0205c7f9426/six-1.15.0.tar.gz" sha256 "30639c035cdb23534cd4aa2dd52c3bf48f06e5f4a941509c8bafd8ce11080259" end # thrift==0.9.3 resource "thrift" do url "https://files.pythonhosted.org/packages/ae/58/35e3f0cd290039ff862c2c9d8ae8a76896665d70343d833bdc2f748b8e55/thrift-0.9.3.tar.gz" sha256 "dfbc3d3bd19d396718dab05abaf46d93ae8005e2df798ef02e32793cd963877e" 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/cd/22/7bf65cfd5d60f3c916ed57c88705803fac30928696f2a300d9ee3751b390/cassandra-driver-3.24.0.tar.gz" sha256 "83ec8d9a5827ee44bb1c0601a63696a8a9086beaf0151c8255556299246081bd" 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_LOG_DIR", "-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 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") output = shell_output("#{bin}/cqlsh localhost 2>&1", 1) assert_match "Connection error", output end end