466f3b0665
We have an upstream signed binary available! Big big love to Mattias for this. This PR converts all the existing tuntap dependencies into binary-friendly tuntap dependencies, and adds a tuntap dependency to requirements to look for the kexts. Closes Homebrew/homebrew#33894. Signed-off-by: Mike McQuaid <mike@mikemcquaid.com>
84 lines
2.6 KiB
Ruby
84 lines
2.6 KiB
Ruby
require "formula"
|
|
|
|
class Openvpn < Formula
|
|
homepage "https://openvpn.net/index.php/download/community-downloads.html"
|
|
url "http://build.openvpn.net/downloads/releases/openvpn-2.3.4.tar.gz"
|
|
mirror "http://swupdate.openvpn.org/community/releases/openvpn-2.3.4.tar.gz"
|
|
sha256 "af506d5f48568fa8d2f2435cb3fad35f9a9a8f263999ea6df3ba296960cec85a"
|
|
revision 1
|
|
|
|
bottle do
|
|
sha1 "126ac2407abc24948fb125fe5f40fee7f5730f57" => :mavericks
|
|
sha1 "89914a561787f2d78bf2b0121c19f275ca11fade" => :mountain_lion
|
|
sha1 "3b9d94774429fbaada9b2e1cead67ea425481e5b" => :lion
|
|
end
|
|
|
|
depends_on "lzo"
|
|
depends_on :tuntap
|
|
depends_on "openssl"
|
|
|
|
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
|
|
|
|
system "./configure", "--disable-debug",
|
|
"--disable-dependency-tracking",
|
|
"--prefix=#{prefix}",
|
|
"--enable-password-save"
|
|
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
|
|
end
|
|
|
|
def caveats; <<-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.
|
|
|
|
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
|
|
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
|
|
end
|