class Openvpn < Formula desc "SSL/TLS VPN implementing OSI layer 2 or 3 secure network extension" homepage "https://openvpn.net/index.php/download/community-downloads.html" url "https://swupdate.openvpn.org/community/releases/openvpn-2.4.3.tar.xz" mirror "https://build.openvpn.net/downloads/releases/openvpn-2.4.3.tar.xz" sha256 "15e15fc97f189b52aee7c90ec8355aa77469c773125110b4c2f089abecde36fb" bottle do sha256 "a478c5ce934a56cbb39869c4b2c5c007e4b3b62a1e5731adb20ddb84347bddd7" => :high_sierra sha256 "1fd1b64c45e92591247c3cb073577d6a161c9e19118c067a2b965833c4b5b448" => :sierra sha256 "ab58d314e44570b921e95141cf37e7d95deae15e4d026b2212d1f85acac1d32b" => :el_capitan sha256 "c3c014805479617d3c0cb4ab80c875929b27fee96501ad323031a0f2d344ec0d" => :yosemite end # Requires tuntap for < 10.10 depends_on :macos => :yosemite depends_on "pkg-config" => :build depends_on "lzo" depends_on "openssl" resource "pkcs11-helper" do url "https://github.com/OpenSC/pkcs11-helper/releases/download/pkcs11-helper-1.22/pkcs11-helper-1.22.tar.bz2" sha256 "fbc15f5ffd5af0200ff2f756cb4388494e0fb00b4f2b186712dce6c48484a942" end def install vendor = buildpath/"brew_vendor" resource("pkcs11-helper").stage do system "./configure", "--disable-debug", "--disable-dependency-tracking", "--prefix=#{vendor}/pkcs11-helper", "--disable-threading", "--disable-slotevent", "--disable-shared" system "make", "install" end ENV.prepend_path "PKG_CONFIG_PATH", vendor/"pkcs11-helper/lib/pkgconfig" system "./configure", "--disable-debug", "--disable-dependency-tracking", "--disable-silent-rules", "--with-crypto-library=openssl", "--enable-pkcs11", "--prefix=#{prefix}" system "make", "install" # Install OpenVPN's new contrib helper allowing the use of # macOS keychain certificates with OpenVPN. cd "contrib/keychain-mcd" do system "make" sbin.install "keychain-mcd" man8.install "keychain-mcd.8" end inreplace "sample/sample-config-files/openvpn-startup.sh", "/etc/openvpn", "#{etc}/openvpn" (doc/"samples").install Dir["sample/sample-*"] (etc/"openvpn").install doc/"samples/sample-config-files/client.conf" (etc/"openvpn").install doc/"samples/sample-config-files/server.conf" # We don't use PolarSSL, so this file is unnecessary & somewhat confusing. rm doc/"README.polarssl" end def post_install (var/"run/openvpn").mkpath end plist_options :startup => true def plist; <<-EOS.undent Label #{plist_name} ProgramArguments #{opt_sbin}/openvpn --config #{etc}/openvpn/openvpn.conf OnDemand RunAtLoad TimeOut 90 WatchPaths #{etc}/openvpn WorkingDirectory #{etc}/openvpn EOS end test do system sbin/"openvpn", "--show-ciphers" end end