Created
June 19, 2013 18:47
-
-
Save mranallo/5816843 to your computer and use it in GitHub Desktop.
nginx + upload module + spdy
This file contains 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.1.tar.gz' | |
sha1 '9c72838973572323535dae10f4e412d671b27a7e' | |
devel do | |
url 'http://nginx.org/download/nginx-1.5.1.tar.gz' | |
sha1 'bd5a5e7dba39a4aa166918112367589f165ce5bc' | |
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-upload', 'Compile support for upload module (http://www.grid.net.ru/nginx/upload.en.html) and upload progress' | |
depends_on 'pcre' | |
# 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' | |
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", | |
"--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-upload' | |
`mkdir /tmp/nginx_upload; mkdir /tmp/nginx_upload-progress` | |
`cd /tmp/ && wget http://www.grid.net.ru/nginx/download/nginx_upload_module-2.2.0.tar.gz` | |
`tar xzf /tmp/nginx_upload_module-2.2.0.tar.gz --directory /tmp/nginx_upload --strip 1` | |
`cd /tmp/nginx_upload && wget http://portage.perestoroniny.ru/www-servers/nginx/files/nginx-1.3.9_upload_module.patch` | |
`cd /tmp/nginx_upload && patch ngx_http_upload_module.c nginx-1.3.9_upload_module.patch` | |
`cd /tmp/ && wget http://github.com/downloads/masterzen/nginx-upload-progress-module/nginx_uploadprogress_module-0.9.0.tar.gz` | |
`tar xzf /tmp/nginx_uploadprogress_module-0.9.0.tar.gz --directory /tmp/nginx_upload-progress --strip 1` | |
args << "--add-module=/tmp/nginx_upload" | |
args << "--add-module=/tmp/nginx_upload-progress" | |
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 caveats; <<-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 | |
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