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+)+)\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