Last active
December 22, 2015 11:28
-
-
Save flazz/6465372 to your computer and use it in GitHub Desktop.
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
location /lua { | |
default_type 'text/plain'; | |
content_by_lua 'ngx.print("lua!!!")'; | |
} |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
require 'formula' | |
class Nginx < Formula | |
homepage 'http://nginx.org/' | |
url 'http://nginx.org/download/nginx-1.4.2.tar.gz' | |
sha1 '8f006dc773840b6624a137a584ff8850d5155e3f' | |
devel do | |
url 'http://nginx.org/download/nginx-1.5.3.tar.gz' | |
sha1 '88f4548e46c25d32f08681c0aba39b86b84ec3a3' | |
end | |
head 'http://hg.nginx.org/nginx/', :using => :hg | |
env :userpaths | |
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' | |
option 'with-luajit', 'Compile LUA scripting support' | |
depends_on 'pcre' | |
depends_on 'passenger' => :optional | |
# SPDY needs openssl >= 1.0.1 for NPN; see: | |
# https://tools.ietf.org/agenda/82/slides/tls-3.pdf | |
# http://www.openssl.org/news/changelog.html | |
depends_on 'openssl' if build.with? 'spdy' | |
if build.with? 'luajit' | |
depends_on 'luajit' | |
depends_on 'ngx_devel_kit' | |
depends_on 'lua-nginx-module' | |
ENV['LUAJIT_LIB'] = `pkg-config --libs-only-L luajit`.strip.sub '-L', '' | |
ENV['LUAJIT_INC'] = `pkg-config --cflags-only-I luajit`.strip.sub '-I', '' | |
end | |
skip_clean 'logs' | |
# Changes default port to 8080 | |
def patches | |
DATA | |
end | |
def passenger_config_args | |
passenger_root = `passenger-config --root`.chomp | |
if File.directory?(passenger_root) | |
return "--add-module=#{passenger_root}/ext/nginx" | |
end | |
puts "Unable to install nginx with passenger support. The passenger" | |
puts "gem must be installed and passenger-config must be in your path" | |
puts "in order to continue." | |
exit | |
end | |
def install | |
cc_opt = "-I#{HOMEBREW_PREFIX}/include" | |
ld_opt = "-L#{HOMEBREW_PREFIX}/lib" | |
if build.with? 'spdy' | |
openssl_path = Formula.factory("openssl").opt_prefix | |
cc_opt += " -I#{openssl_path}/include" | |
ld_opt += " -L#{openssl_path}/lib" | |
end | |
args = ["--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" | |
] | |
args << passenger_config_args if build.include? 'with-passenger' | |
args << "--with-http_dav_module" if build.include? 'with-webdav' | |
args << "--with-debug" if build.include? 'with-debug' | |
args << "--with-http_spdy_module" if build.include? 'with-spdy' | |
args << "--with-http_gunzip_module" if build.include? 'with-gunzip' | |
if build.include? 'with-luajit' | |
args << "--add-module=#{ `brew --prefix ngx_devel_kit`.chomp }" | |
args << "--add-module=#{ `brew --prefix lua-nginx-module`.chomp }" | |
end | |
if build.head? | |
system "./auto/configure", *args | |
else | |
system "./configure", *args | |
end | |
system "make" | |
system "make install" | |
man8.install "objs/nginx.8" | |
(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. | |
prefix.cd do | |
dst = HOMEBREW_PREFIX/"var/www" | |
if not dst.exist? | |
dst.dirname.mkpath | |
mv "html", dst | |
else | |
rm_rf "html" | |
dst.mkpath | |
end | |
Pathname.new("#{prefix}/html").make_relative_symlink(dst) | |
end | |
# 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 (HOMEBREW_CELLAR/'nginx').subdirs.any?{|d| (d/:sbin).directory? } | |
sbin.mkpath | |
sbin.cd do | |
(sbin/'nginx').make_relative_symlink(bin/'nginx') | |
end | |
end | |
end | |
def passenger_caveats; <<-EOS.undent | |
To activate Phusion Passenger, add this to #{etc}/nginx/nginx.conf: | |
passenger_root #{HOMEBREW_PREFIX}/opt/passenger | |
passenger_ruby /usr/bin/ruby | |
EOS | |
end | |
def caveats | |
s = <<-EOS.undent | |
Docroot is: #{HOMEBREW_PREFIX}/var/www | |
The default port has been set to 8080 so that nginx can run without sudo. | |
If you want to host pages on your local machine to the wider network you | |
can change the port to 80 in: #{HOMEBREW_PREFIX}/etc/nginx/nginx.conf | |
You will then need to run nginx as root: `sudo nginx`. | |
EOS | |
s << passenger_caveats if build.include? 'with-passenger' | |
s | |
end | |
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_prefix}/bin/nginx</string> | |
<string>-g</string> | |
<string>daemon off;</string> | |
</array> | |
<key>WorkingDirectory</key> | |
<string>#{HOMEBREW_PREFIX}</string> | |
</dict> | |
</plist> | |
EOS | |
end | |
end | |
__END__ | |
--- a/conf/nginx.conf | |
+++ b/conf/nginx.conf | |
@@ -33,7 +33,7 @@ | |
#gzip on; | |
server { | |
- listen 80; | |
+ listen 8080; | |
server_name localhost; | |
#charset koi8-r; |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment