homebrew-core/Formula/openvpn.rb

117 lines
3.5 KiB
Ruby

class Openvpn < Formula
desc "SSL 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.3.10.tar.gz"
mirror "http://build.openvpn.net/downloads/releases/openvpn-2.3.10.tar.gz"
sha256 "f8b0b5b92e35bbca1db1a7e6b49e04639e45634e9accd460459b40b2c99ec8f6"
bottle do
cellar :any
sha256 "0306a9f03cc1dfbb13e7f694cc1212b71d258f792077f1cc44d0b5f8d5ac14ac" => :el_capitan
sha256 "6a7849f46f06b0e090f489974cbb474751b14284a25f41b40d1cecd1430833c4" => :yosemite
sha256 "35e58ca6072dc8cb48fb9cfe85d9518f9b0530d4578f5f6ccf7d720cef7593da" => :mavericks
end
depends_on "lzo"
depends_on :tuntap if MacOS.version < :yosemite
depends_on "openssl"
depends_on "pkcs11-helper" => [:optional, "without-threading", "without-slotevent"]
if build.with? "pkcs11-helper"
depends_on "pkg-config" => :build
depends_on "autoconf" => :build
depends_on "automake" => :build
depends_on "libtool" => :build
end
def install
# pam_appl header is installed in a different location on Leopard
# and older; reported upstream https://community.openvpn.net/openvpn/ticket/326
if MacOS.version < :snow_leopard
inreplace Dir["src/plugins/auth-pam/{auth-pam,pamdl}.c"],
"security/pam_appl.h", "pam/pam_appl.h"
end
args = %W[
--disable-debug
--disable-dependency-tracking
--disable-silent-rules
--with-crypto-library=openssl
--prefix=#{prefix}
--enable-password-save
]
args << "--enable-pkcs11" if build.with? "pkcs11-helper"
system "./configure", *args
system "make", "install"
inreplace "sample/sample-config-files/openvpn-startup.sh",
"/etc/openvpn", "#{etc}/openvpn"
(doc/"sample").install Dir["sample/sample-*"]
(etc+"openvpn").mkpath
(var+"run/openvpn").mkpath
# We don't use PolarSSL, so this file is unnecessary and somewhat confusing.
rm "#{share}/doc/openvpn/README.polarssl"
end
def caveats
s = ""
if MacOS.version < :yosemite
s += <<-EOS.undent
If you have installed the Tuntap dependency as a source package you will
need to follow the instructions found in `brew info tuntap`. If you have
installed the binary Tuntap package, no further action is necessary.
EOS
end
s += <<-EOS.undent
For OpenVPN to work as a server, you will need to create configuration file
in #{etc}/openvpn, samples can be found in #{share}/doc/openvpn
EOS
s
end
plist_options :startup => true
def plist; <<-EOS.undent
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd";>
<plist version="1.0">
<dict>
<key>Label</key>
<string>#{plist_name}</string>
<key>ProgramArguments</key>
<array>
<string>#{opt_sbin}/openvpn</string>
<string>--config</string>
<string>#{etc}/openvpn/openvpn.conf</string>
</array>
<key>OnDemand</key>
<false/>
<key>RunAtLoad</key>
<true/>
<key>TimeOut</key>
<integer>90</integer>
<key>WatchPaths</key>
<array>
<string>#{etc}/openvpn</string>
</array>
<key>WorkingDirectory</key>
<string>#{etc}/openvpn</string>
</dict>
</plist>
EOS
end
test do
system "#{sbin}/openvpn", "--show-ciphers"
end
end