class Auditbeat < Formula desc "Lightweight Shipper for Audit Data" homepage "https://www.elastic.co/products/beats/auditbeat" url "https://github.com/elastic/beats/archive/v6.2.2.tar.gz" sha256 "0866c3e26fcbd55f191e746b3bf925b450badd13fb72ea9f712481559932c878" head "https://github.com/elastic/beats.git" bottle do cellar :any_skip_relocation sha256 "c7b1b6b0dead6a93667afad4248b304fb1ebbe771c85091becac2a6a9fa6e085" => :high_sierra sha256 "4ab4c67dac14be0bc3a6d5462cf4f26556f8ae1c459a7ccea99c864d05d2b6c9" => :sierra sha256 "9a04e10ba3192814b34b1a72aa5cc4259d4836108e8aa522b949a26653ec7139" => :el_capitan end depends_on "go" => :build # Patch required to build against go 1.10. # May be removed once upstream beats project fully supports go 1.10. patch do url "https://raw.githubusercontent.com/Homebrew/formula-patches/1ddc0e6/auditbeat/go1.10.diff" sha256 "cf0988ba5ff5cc8bd7502671f08ea282b19720be42bea2aaf5c236b29a01a24f" end resource "virtualenv" do url "https://files.pythonhosted.org/packages/d4/0c/9840c08189e030873387a73b90ada981885010dd9aea134d6de30cd24cb8/virtualenv-15.1.0.tar.gz" sha256 "02f8102c2436bb03b3ee6dede1919d1dac8a427541652e5ec95171ec8adbc93a" end def install ENV["GOPATH"] = buildpath (buildpath/"src/github.com/elastic/beats").install buildpath.children ENV.prepend_create_path "PYTHONPATH", buildpath/"vendor/lib/python2.7/site-packages" resource("virtualenv").stage do system "python", *Language::Python.setup_install_args(buildpath/"vendor") end ENV.prepend_path "PATH", buildpath/"vendor/bin" cd "src/github.com/elastic/beats/auditbeat" do # prevent downloading binary wheels inreplace "../libbeat/scripts/Makefile", "pip install", "pip install --no-binary :all" system "make" system "make", "DEV_OS=darwin", "update" (libexec/"bin").install "auditbeat" libexec.install "_meta/kibana" (etc/"auditbeat").install Dir["auditbeat*.yml"] prefix.install_metafiles end (bin/"auditbeat").write <<~EOS #!/bin/sh exec #{libexec}/bin/auditbeat \ -path.config #{etc}/auditbeat \ -path.data #{var}/lib/auditbeat \ -path.home #{libexec} \ -path.logs #{var}/log/auditbeat \ "$@" EOS end def post_install (var/"lib/auditbeat").mkpath (var/"log/auditbeat").mkpath end plist_options :manual => "auditbeat" def plist; <<~EOS Label #{plist_name} Program #{opt_bin}/auditbeat RunAtLoad EOS end test do (testpath/"files").mkpath (testpath/"config/auditbeat.yml").write <<~EOS auditbeat.modules: - module: file_integrity paths: - #{testpath}/files output.file: path: "#{testpath}/auditbeat" filename: auditbeat EOS pid = fork do exec "#{bin}/auditbeat", "-path.config", testpath/"config", "-path.data", testpath/"data" end sleep 5 begin touch testpath/"files/touch" sleep 30 s = IO.readlines(testpath/"auditbeat/auditbeat").last(1)[0] assert_match "\"action\":\[\"created\"\]", s realdirpath = File.realdirpath(testpath) assert_match "\"path\":\"#{realdirpath}/files/touch\"", s ensure Process.kill "SIGINT", pid Process.wait pid end end end