require 'formula' class Openvpn < Formula homepage 'http://openvpn.net/' url 'http://build.openvpn.net/downloads/releases/openvpn-2.3.1.tar.gz' mirror 'http://swupdate.openvpn.org/community/releases/openvpn-2.3.1.tar.gz' sha256 'bd2d7d85b39d4586bcdb74b36eb48d0ac4ab1e6812654c719b04826fdc70fb3c' depends_on 'lzo' def install # Build and install binary system "./configure", "--disable-debug", "--disable-dependency-tracking", "--prefix=#{prefix}", "--enable-password-save" system "make install" # Adjust sample file paths inreplace ["sample/sample-config-files/openvpn-startup.sh"] do |s| s.gsub! "/etc/openvpn", etc+'openvpn' end # Install sample files Dir['sample/sample-*'].each do |d| (share + 'doc/openvpn' + d).install Dir[d+'/*'] end # Create etc & var paths (etc + 'openvpn').mkpath (var + 'run/openvpn').mkpath end def caveats; <<-EOS.undent You may also wish to install tuntap: The TunTap project provides kernel extensions for Mac OS X that allow creation of virtual network interfaces. http://tuntaposx.sourceforge.net/ Because these are kernel extensions, there is no Homebrew formula for tuntap. 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 Label #{plist_name} ProgramArguments #{opt_prefix}/sbin/openvpn --config #{etc}/openvpn/openvpn.conf OnDemand RunAtLoad TimeOut 90 WatchPaths #{etc}/openvpn WorkingDirectory #{etc}/openvpn EOS end end