117 lines
3.5 KiB
Ruby
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
|