class Openssh < Formula desc "OpenBSD freely-licensed SSH connectivity tools" homepage "https://www.openssh.com/" url "https://ftp.openbsd.org/pub/OpenBSD/OpenSSH/portable/openssh-8.0p1.tar.gz" mirror "https://mirror.vdms.io/pub/OpenBSD/OpenSSH/portable/openssh-8.0p1.tar.gz" version "8.0p1" sha256 "bd943879e69498e8031eb6b7f44d08cdc37d59a7ab689aa0b437320c3481fd68" revision 2 bottle do sha256 "37ea71baac410e3a1f2e3b2ea67965f756c5352005ca425904ae49a1b0bb7aeb" => :catalina sha256 "0b7cd9be11683b47e0274c9409f0378c8d24b2c5e668a45f84f9f79d5e115e4e" => :mojave sha256 "039f3ec0c77a782856680181e0cb34733bfe3b1cede8b24e6194bd1696c457b7" => :high_sierra sha256 "a5d5795b777a608d13905fc443b5c526f1a0b3368e6e1d5f98fa7380ef26e701" => :sierra end # Please don't resubmit the keychain patch option. It will never be accepted. # https://github.com/Homebrew/homebrew-dupes/pull/482#issuecomment-118994372 depends_on "pkg-config" => :build depends_on "ldns" depends_on "openssl@1.1" resource "com.openssh.sshd.sb" do url "https://opensource.apple.com/source/OpenSSH/OpenSSH-209.50.1/com.openssh.sshd.sb" sha256 "a273f86360ea5da3910cfa4c118be931d10904267605cdd4b2055ced3a829774" end # Both these patches are applied by Apple. patch do url "https://raw.githubusercontent.com/Homebrew/patches/1860b0a74/openssh/patch-sandbox-darwin.c-apple-sandbox-named-external.diff" sha256 "d886b98f99fd27e3157b02b5b57f3fb49f43fd33806195970d4567f12be66e71" end patch do url "https://raw.githubusercontent.com/Homebrew/patches/d8b2d8c2/openssh/patch-sshd.c-apple-sandbox-named-external.diff" sha256 "3505c58bf1e584c8af92d916fe5f3f1899a6b15cc64a00ddece1dc0874b2f78f" end def install ENV.append "CPPFLAGS", "-D__APPLE_SANDBOX_NAMED_EXTERNAL__" # Ensure sandbox profile prefix is correct. # We introduce this issue with patching, it's not an upstream bug. inreplace "sandbox-darwin.c", "@PREFIX@/share/openssh", etc/"ssh" args = %W[ --prefix=#{prefix} --sysconfdir=#{etc}/ssh --with-ldns --with-libedit --with-kerberos5 --with-pam --with-ssl-dir=#{Formula["openssl@1.1"].opt_prefix} ] system "./configure", *args system "make" ENV.deparallelize system "make", "install" # This was removed by upstream with very little announcement and has # potential to break scripts, so recreate it for now. # Debian have done the same thing. bin.install_symlink bin/"ssh" => "slogin" buildpath.install resource("com.openssh.sshd.sb") (etc/"ssh").install "com.openssh.sshd.sb" => "org.openssh.sshd.sb" end test do assert_match "OpenSSH_", shell_output("#{bin}/ssh -V 2>&1") begin pid = fork { exec sbin/"sshd", "-D", "-p", "8022" } sleep 2 assert_match "sshd", shell_output("lsof -i :8022") ensure Process.kill(9, pid) Process.wait(pid) end end end