185 lines
5.6 KiB
Ruby
185 lines
5.6 KiB
Ruby
class Nginx < Formula
|
|
desc "HTTP(S) server and reverse proxy, and IMAP/POP3 proxy server"
|
|
homepage "https://nginx.org/"
|
|
# Use "mainline" releases only (odd minor version number), not "stable"
|
|
# See https://www.nginx.com/blog/nginx-1-12-1-13-released/ for why
|
|
url "https://nginx.org/download/nginx-1.23.3.tar.gz"
|
|
sha256 "75cb5787dbb9fae18b14810f91cc4343f64ce4c24e27302136fb52498042ba54"
|
|
license "BSD-2-Clause"
|
|
head "https://hg.nginx.org/nginx/", using: :hg
|
|
|
|
livecheck do
|
|
url :homepage
|
|
regex(%r{nginx[._-]v?(\d+(?:\.\d+)+)</a>\nmainline version}i)
|
|
end
|
|
|
|
bottle do
|
|
sha256 arm64_ventura: "fd95ddcaeabfc3a38523a72000f4738730d3163e565a9693ba40422f5a929149"
|
|
sha256 arm64_monterey: "1a5ca9ef1443da42401e35d41ac58d81a874f94449c76aa69fd3ec2d0e775bcc"
|
|
sha256 arm64_big_sur: "d508ffc8165c81413d84046a47bfd95a8ec40d5709a423429c33a9f81b538380"
|
|
sha256 ventura: "8de46606c7c3a4fda4d93f723af91831793028c23fe2d9e24e2a06bb8fdea61d"
|
|
sha256 monterey: "2abd6923892bea21c46f5b70d18051a25560af9196a9b0963faac05f5dff17c9"
|
|
sha256 big_sur: "540376a9e7c7dbef24a9f66025cf2030b143eabef0bed82fb15595aa410620d2"
|
|
sha256 x86_64_linux: "e0528d587c273db0546ecc75552deca4436ca4ad2774f210a7089fb3942056ea"
|
|
end
|
|
|
|
depends_on "openssl@1.1"
|
|
depends_on "pcre2"
|
|
|
|
uses_from_macos "xz" => :build
|
|
uses_from_macos "libxcrypt"
|
|
|
|
def install
|
|
# keep clean copy of source for compiling dynamic modules e.g. passenger
|
|
(pkgshare/"src").mkpath
|
|
system "tar", "-cJf", (pkgshare/"src/src.tar.xz"), "."
|
|
|
|
# Changes default port to 8080
|
|
inreplace "conf/nginx.conf" do |s|
|
|
s.gsub! "listen 80;", "listen 8080;"
|
|
s.gsub! " #}\n\n}", " #}\n include servers/*;\n}"
|
|
end
|
|
|
|
openssl = Formula["openssl@1.1"]
|
|
pcre = Formula["pcre2"]
|
|
|
|
cc_opt = "-I#{pcre.opt_include} -I#{openssl.opt_include}"
|
|
ld_opt = "-L#{pcre.opt_lib} -L#{openssl.opt_lib}"
|
|
|
|
args = %W[
|
|
--prefix=#{prefix}
|
|
--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-compat
|
|
--with-debug
|
|
--with-http_addition_module
|
|
--with-http_auth_request_module
|
|
--with-http_dav_module
|
|
--with-http_degradation_module
|
|
--with-http_flv_module
|
|
--with-http_gunzip_module
|
|
--with-http_gzip_static_module
|
|
--with-http_mp4_module
|
|
--with-http_random_index_module
|
|
--with-http_realip_module
|
|
--with-http_secure_link_module
|
|
--with-http_slice_module
|
|
--with-http_ssl_module
|
|
--with-http_stub_status_module
|
|
--with-http_sub_module
|
|
--with-http_v2_module
|
|
--with-ipv6
|
|
--with-mail
|
|
--with-mail_ssl_module
|
|
--with-pcre
|
|
--with-pcre-jit
|
|
--with-stream
|
|
--with-stream_realip_module
|
|
--with-stream_ssl_module
|
|
--with-stream_ssl_preread_module
|
|
]
|
|
|
|
(pkgshare/"src/configure_args.txt").write args.join("\n")
|
|
|
|
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
|
|
end
|
|
|
|
def post_install
|
|
(etc/"nginx/servers").mkpath
|
|
(var/"run/nginx").mkpath
|
|
|
|
# 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
|
|
sbin.install_symlink bin/"nginx" if rack.subdirs.any? { |d| d.join("sbin").directory? }
|
|
end
|
|
|
|
def caveats
|
|
<<~EOS
|
|
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
|
|
end
|
|
|
|
service do
|
|
if OS.linux?
|
|
run [opt_bin/"nginx", "-g", "'daemon off;'"]
|
|
else
|
|
run [opt_bin/"nginx", "-g", "daemon off;"]
|
|
end
|
|
keep_alive false
|
|
working_dir HOMEBREW_PREFIX
|
|
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
|