homebrew-core/Formula/tcpdump.rb

50 lines
2.1 KiB
Ruby

class Tcpdump < Formula
desc "Command-line packet analyzer"
homepage "https://www.tcpdump.org/"
url "https://www.tcpdump.org/release/tcpdump-4.99.1.tar.gz"
sha256 "79b36985fb2703146618d87c4acde3e068b91c553fb93f021a337f175fd10ebe"
license "BSD-3-Clause"
head "https://github.com/the-tcpdump-group/tcpdump.git", branch: "master"
livecheck do
url "https://www.tcpdump.org/release/"
regex(/href=.*?tcpdump[._-]v?(\d+(?:\.\d+)+)\.t/i)
end
bottle do
sha256 cellar: :any, arm64_monterey: "9e3d14677a6e3ef5802768c70981432012e4b66ae4510f0941ffaf17704b6e79"
sha256 cellar: :any, arm64_big_sur: "76240f2c1366e4ff70ec2a7a4faecdd8a39b57ba4641a88a01850e773a408964"
sha256 cellar: :any, monterey: "0ed877b6b1f8c00f36a1dd57433d0c4d14de5ed043dfa8539b31344b15543608"
sha256 cellar: :any, big_sur: "f13d5873a6d26314c930711e8565ce1265ac127a8470952aadda54232bbc9e8f"
sha256 cellar: :any, catalina: "4238eca3a7436080167e6b83054e10e14774cc77368d0e84e6e6914d34bf7290"
sha256 cellar: :any, mojave: "c919c1dde35897ff9bb40f367e4f286808ca6eeaf31ae99c279dfb779e9f4785"
sha256 cellar: :any_skip_relocation, x86_64_linux: "2a216492e1ced7cd3cf58ab6abccd5cccaa3b316e1096d6367aaf927e07bf4ac"
end
depends_on "libpcap"
depends_on "openssl@1.1"
def install
system "./configure", "--prefix=#{prefix}",
"--disable-smb",
"--disable-universal"
system "make", "install"
end
test do
output = shell_output("#{bin}/tcpdump --help 2>&1")
assert_match "tcpdump version #{version}", output
assert_match "libpcap version #{Formula["libpcap"].version}", output
assert_match "OpenSSL #{Formula["openssl@1.1"].version}", output
match = "tcpdump: (cannot open BPF device) /dev/bpf0: Operation not permitted"
on_linux do
match = <<~EOS
tcpdump: eth0: You don't have permission to capture on that device
(socket: Operation not permitted)
EOS
end
assert_match match, shell_output("#{bin}/tcpdump ipv6 2>&1", 1)
end
end