homebrew-core/Formula/nginx.rb
Bas Hintemann 9ddc9e88d8 nginx: Fix passenger caveat after upstream change
The locations.ini file changed location in Homebrew/homebrew#44333, this corrects the nginx caveat to show the current path. Existing installations of nginx using passenger will fail to start passenger until this change in nginx.conf is made.

Closes Homebrew/homebrew#44465.

Signed-off-by: Dominyk Tiller <dominyktiller@gmail.com>
2015-09-30 19:49:44 +01:00

211 lines
6.8 KiB
Ruby

class Nginx < Formula
desc "HTTP(S) server and reverse proxy, and IMAP/POP3 proxy server"
homepage "http://nginx.org/"
url "http://nginx.org/download/nginx-1.8.0.tar.gz"
sha256 "23cca1239990c818d8f6da118320c4979aadf5386deda691b1b7c2c96b9df3d5"
head "http://hg.nginx.org/nginx/", :using => :hg
bottle do
revision 1
sha256 "e6bb9cc02def5205747dc20ffd7c24a3c0e34a7494355a9b0dade58dd8ce9dcf" => :el_capitan
sha256 "6df7b883f9214c5c0969559f6cc9ed56f9537263a1ef4882dae77b0b7af5a1df" => :yosemite
sha256 "68741910d6ee58f7ee1134c7b4c62dfd490ee337c9c0beb0d188edc418b0bd93" => :mavericks
sha256 "a622d0e1bfd55d8634520d72b41319da19828b9ab11063b6243d5b5f3d77ad08" => :mountain_lion
end
devel do
url "http://nginx.org/download/nginx-1.9.5.tar.gz"
sha256 "48e2787a6b245277e37cb7c5a31b1549a0bbacf288aa4731baacf9eaacdb481b"
end
env :userpaths
# Before submitting more options to this formula please check they aren't
# already in Homebrew/homebrew-nginx/nginx-full:
# https://github.com/Homebrew/homebrew-nginx/blob/master/nginx-full.rb
option "with-passenger", "Compile with support for Phusion Passenger module"
option "with-webdav", "Compile with support for WebDAV module"
option "with-debug", "Compile with support for debug log"
option "with-spdy", "Compile with support for SPDY module"
option "with-gunzip", "Compile with support for gunzip module"
depends_on "pcre"
depends_on "passenger" => :optional
depends_on "openssl" => :recommended
depends_on "libressl" => :optional
def install
# Changes default port to 8080
inreplace "conf/nginx.conf", "listen 80;", "listen 8080;"
inreplace "conf/nginx.conf", " #}\n\n}", " #}\n include servers/*;\n}"
pcre = Formula["pcre"]
openssl = Formula["openssl"]
libressl = Formula["libressl"]
if build.with? "libressl"
cc_opt = "-I#{pcre.include} -I#{libressl.include}"
ld_opt = "-L#{pcre.lib} -L#{libressl.lib}"
else
cc_opt = "-I#{pcre.include} -I#{openssl.include}"
ld_opt = "-L#{pcre.lib} -L#{openssl.lib}"
end
args = %W[
--prefix=#{prefix}
--with-http_ssl_module
--with-pcre
--with-ipv6
--sbin-path=#{bin}/nginx
--with-cc-opt=#{cc_opt}
--with-ld-opt=#{ld_opt}
--conf-path=#{etc}/nginx/nginx.conf
--pid-path=#{var}/run/nginx.pid
--lock-path=#{var}/run/nginx.lock
--http-client-body-temp-path=#{var}/run/nginx/client_body_temp
--http-proxy-temp-path=#{var}/run/nginx/proxy_temp
--http-fastcgi-temp-path=#{var}/run/nginx/fastcgi_temp
--http-uwsgi-temp-path=#{var}/run/nginx/uwsgi_temp
--http-scgi-temp-path=#{var}/run/nginx/scgi_temp
--http-log-path=#{var}/log/nginx/access.log
--error-log-path=#{var}/log/nginx/error.log
--with-http_gzip_static_module
]
if build.with? "passenger"
nginx_ext = `#{Formula["passenger"].opt_bin}/passenger-config --nginx-addon-dir`.chomp
args << "--add-module=#{nginx_ext}"
end
args << "--with-http_dav_module" if build.with? "webdav"
args << "--with-debug" if build.with? "debug"
args << "--with-http_gunzip_module" if build.with? "gunzip"
# This became "with-http_v2_module" in 1.9.5
# http://nginx.org/en/docs/http/ngx_http_spdy_module.html
# We handle devel/stable block variable options badly, so this installs
# the expected module rather than fatally bailing out of configure.
# The option should be deprecated to the new name when stable.
if build.devel? || build.head? && build.with?("spdy")
args << "--with-http_v2_module"
elsif build.with?("spdy")
args << "--with-http_spdy_module"
end
if build.head?
system "./auto/configure", *args
else
system "./configure", *args
end
system "make", "install"
if build.head?
man8.install "docs/man/nginx.8"
else
man8.install "man/nginx.8"
end
(etc/"nginx/servers").mkpath
(var/"run/nginx").mkpath
end
def post_install
# nginx's docroot is #{prefix}/html, this isn't useful, so we symlink it
# to #{HOMEBREW_PREFIX}/var/www. The reason we symlink instead of patching
# is so the user can redirect it easily to something else if they choose.
html = prefix/"html"
dst = var/"www"
if dst.exist?
html.rmtree
dst.mkpath
else
dst.dirname.mkpath
html.rename(dst)
end
prefix.install_symlink dst => "html"
# for most of this formula's life the binary has been placed in sbin
# and Homebrew used to suggest the user copy the plist for nginx to their
# ~/Library/LaunchAgents directory. So we need to have a symlink there
# for such cases
if rack.subdirs.any? { |d| d.join("sbin").directory? }
sbin.install_symlink bin/"nginx"
end
end
def passenger_caveats; <<-EOS.undent
To activate Phusion Passenger, add this to #{etc}/nginx/nginx.conf, inside the 'http' context:
passenger_root #{Formula["passenger"].opt_libexec}/src/ruby_supportlib/phusion_passenger/locations.ini;
passenger_ruby /usr/bin/ruby;
EOS
end
def caveats
s = <<-EOS.undent
Docroot is: #{var}/www
The default port has been set in #{etc}/nginx/nginx.conf to 8080 so that
nginx can run without sudo.
nginx will load all files in #{etc}/nginx/servers/.
EOS
s << "\n" << passenger_caveats if build.with? "passenger"
s
end
plist_options :manual => "nginx"
def plist; <<-EOS.undent
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//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>RunAtLoad</key>
<true/>
<key>KeepAlive</key>
<false/>
<key>ProgramArguments</key>
<array>
<string>#{opt_bin}/nginx</string>
<string>-g</string>
<string>daemon off;</string>
</array>
<key>WorkingDirectory</key>
<string>#{HOMEBREW_PREFIX}</string>
</dict>
</plist>
EOS
end
test do
(testpath/"nginx.conf").write <<-EOS
worker_processes 4;
error_log #{testpath}/error.log;
pid #{testpath}/nginx.pid;
events {
worker_connections 1024;
}
http {
client_body_temp_path #{testpath}/client_body_temp;
fastcgi_temp_path #{testpath}/fastcgi_temp;
proxy_temp_path #{testpath}/proxy_temp;
scgi_temp_path #{testpath}/scgi_temp;
uwsgi_temp_path #{testpath}/uwsgi_temp;
server {
listen 8080;
root #{testpath};
access_log #{testpath}/access.log;
error_log #{testpath}/error.log;
}
}
EOS
system "#{bin}/nginx", "-t", "-c", testpath/"nginx.conf"
end
end