passenger 4.0.59 → 4.0.60
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of passenger might be problematic. Click here for more details.
- checksums.yaml +8 -8
- checksums.yaml.gz.asc +7 -7
- data.tar.gz.asc +7 -7
- data/CHANGELOG +15 -0
- data/bin/passenger-install-apache2-module +2 -1
- data/bin/passenger-install-nginx-module +8 -2
- data/ext/apache2/Hooks.cpp +21 -2
- data/ext/apache2/MergeDirConfig.cpp +40 -40
- data/ext/common/ApplicationPool2/Group.h +14 -10
- data/ext/common/ApplicationPool2/Implementation.cpp +13 -7
- data/ext/common/ApplicationPool2/SmartSpawner.h +4 -1
- data/ext/common/Constants.h +1 -1
- data/ext/nginx/ContentHandler.c +17 -1
- data/lib/phusion_passenger.rb +4 -5
- data/lib/phusion_passenger/platform_info/depcheck_specs/libs.rb +4 -3
- data/lib/phusion_passenger/platform_info/openssl.rb +61 -0
- data/lib/phusion_passenger/standalone/runtime_installer.rb +27 -22
- data/packaging/debian/LICENSE.md +19 -0
- data/packaging/debian/README.md +320 -0
- data/packaging/debian/Vagrantfile +25 -0
- data/packaging/debian/build +210 -0
- data/packaging/debian/debian_specs/nginx/changelog +1989 -0
- data/packaging/debian/debian_specs/nginx/compat.erb +5 -0
- data/packaging/debian/debian_specs/nginx/conf/fastcgi.conf +25 -0
- data/packaging/debian/debian_specs/nginx/conf/fastcgi_params +24 -0
- data/packaging/debian/debian_specs/nginx/conf/koi-utf +109 -0
- data/packaging/debian/debian_specs/nginx/conf/koi-win +103 -0
- data/packaging/debian/debian_specs/nginx/conf/mime.types +89 -0
- data/packaging/debian/debian_specs/nginx/conf/nginx.conf.erb +97 -0
- data/packaging/debian/debian_specs/nginx/conf/proxy_params +4 -0
- data/packaging/debian/debian_specs/nginx/conf/scgi_params +16 -0
- data/packaging/debian/debian_specs/nginx/conf/sites-available/default.erb +93 -0
- data/packaging/debian/debian_specs/nginx/conf/snippets/fastcgi-php.conf +13 -0
- data/packaging/debian/debian_specs/nginx/conf/snippets/snakeoil.conf +5 -0
- data/packaging/debian/debian_specs/nginx/conf/uwsgi_params +16 -0
- data/packaging/debian/debian_specs/nginx/conf/win-utf +125 -0
- data/packaging/debian/debian_specs/nginx/control.erb +226 -0
- data/packaging/debian/debian_specs/nginx/copyright +196 -0
- data/packaging/debian/debian_specs/nginx/debian-full.lintian-overrides +1 -0
- data/packaging/debian/debian_specs/nginx/gbp.conf +2 -0
- data/packaging/debian/debian_specs/nginx/help/docs/fcgiwrap +14 -0
- data/packaging/debian/debian_specs/nginx/help/docs/php +119 -0
- data/packaging/debian/debian_specs/nginx/help/docs/support-irc +28 -0
- data/packaging/debian/debian_specs/nginx/help/docs/upstream +51 -0
- data/packaging/debian/debian_specs/nginx/help/examples/drupal +114 -0
- data/packaging/debian/debian_specs/nginx/help/examples/http +59 -0
- data/packaging/debian/debian_specs/nginx/help/examples/mail +30 -0
- data/packaging/debian/debian_specs/nginx/help/examples/mailman +59 -0
- data/packaging/debian/debian_specs/nginx/help/examples/nginx.conf +34 -0
- data/packaging/debian/debian_specs/nginx/help/examples/nginx_modsite +162 -0
- data/packaging/debian/debian_specs/nginx/help/examples/virtual_hosts +155 -0
- data/packaging/debian/debian_specs/nginx/help/examples/wordpress +74 -0
- data/packaging/debian/debian_specs/nginx/helpers.rb +41 -0
- data/packaging/debian/debian_specs/nginx/index-debian.html.in +32 -0
- data/packaging/debian/debian_specs/nginx/index-ubuntu.html.in +32 -0
- data/packaging/debian/debian_specs/nginx/index.html.erb +10 -0
- data/packaging/debian/debian_specs/nginx/modules/README.Modules-versions +65 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/README.markdown +510 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/config +5 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/doc/HttpHeadersMoreModule.wiki +395 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ddebug.h +119 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_filter_module.c +348 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_filter_module.h +80 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_headers_in.c +826 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_headers_in.h +26 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_headers_out.c +716 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_headers_out.h +26 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_util.c +380 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/src/ngx_http_headers_more_util.h +52 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/util/build.sh +32 -0
- data/packaging/debian/debian_specs/nginx/modules/headers-more-nginx-module/valgrind.suppress +215 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-auth-pam/ChangeLog +35 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-auth-pam/LICENSE +25 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-auth-pam/README.md +93 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-auth-pam/config +4 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-auth-pam/ngx_http_auth_pam_module.c +462 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-cache-purge/CHANGES +66 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-cache-purge/LICENSE +26 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-cache-purge/README.md +171 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-cache-purge/TODO.md +7 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-cache-purge/config +21 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-cache-purge/ngx_cache_purge_module.c +1803 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-dav-ext-module/README +29 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-dav-ext-module/config +9 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-dav-ext-module/ngx_http_dav_ext_module.c +824 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/README +139 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/README_AUTO_LIB +395 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/TODO +1 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/actions/array +10 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/actions/palloc +8 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/build +597 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/action_replacements +5 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/action_types +12 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/conf_args +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/conf_locs +25 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/conf_macros +35 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/contexts +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/header_files +3 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/headers +4 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/module_dependencies +5 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/modules_optional +15 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/data/prefixes +2 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/src/array.h +7 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/src/conf_cmd_basic.h +43 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/src/conf_merge.h +78 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/src/palloc.h +6 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/auto/text/autogen +12 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/config +49 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/docs/core/action_macros +63 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/docs/core/conf_cmds +62 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/docs/modules/set_var +124 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/docs/patches/more_logging_info +48 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/docs/upstream/list +45 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/examples/README +12 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/examples/http/set_var/config +4 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/examples/http/set_var/ngx_http_set_var_examples_module.c +136 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/ngx_auto_lib_core +797 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/notes/CHANGES +17 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/notes/LICENSE +24 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_array.h +113 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_conf_cmd_basic.h +2203 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_conf_cmd_extra.h +5423 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_conf_merge.h +227 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_config.c +72 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_config.h +98 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_includes.h +66 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/objs/ndk_palloc.h +112 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/patches/auto_config +16 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/patches/expose_rewrite_functions +291 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/patches/rewrite_phase_handler +19 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/hash/md5.h +117 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/hash/murmurhash2.c +77 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/hash/sha.h +200 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk.c +155 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk.h +58 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_buf.c +43 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_buf.h +5 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_complex_path.c +129 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_complex_path.h +30 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_complex_value.c +192 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_complex_value.h +21 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_conf_file.c +396 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_conf_file.h +44 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_debug.c +72 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_debug.h +171 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_encoding.c +57 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_encoding.h +12 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_hash.c +82 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_hash.h +45 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_http.c +138 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_http.h +3 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_http_headers.h +35 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_log.c +3 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_log.h +165 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_parse.h +67 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_path.c +583 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_path.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_process.c +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_process.h +12 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_regex.c +215 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_regex.h +7 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_rewrite.c +103 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_rewrite.h +26 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_set_var.c +602 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_set_var.h +44 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_string.c +434 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_string.h +37 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_string_util.h +14 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_upstream_list.c +205 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_upstream_list.h +27 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_uri.c +45 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-development-kit/src/ndk_uri.h +6 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/LICENSE +25 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/README.markdown +1850 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/config +5 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/doc/HttpEchoModule.wiki +1558 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ddebug.h +109 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_echo.c +344 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_echo.h +25 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_filter.c +282 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_filter.h +15 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_foreach.c +183 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_foreach.h +16 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_handler.c +429 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_handler.h +18 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_location.c +178 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_location.h +13 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_module.c +667 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_module.h +137 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_request_info.c +452 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_request_info.h +31 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_sleep.c +208 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_sleep.h +16 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_subrequest.c +788 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_subrequest.h +19 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_timer.c +96 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_timer.h +13 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_util.c +298 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_util.h +58 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_var.c +110 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/src/ngx_http_echo_var.h +9 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/util/build.sh +45 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/util/releng +8 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/util/wiki2pod.pl +131 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-echo/valgrind.suppress +38 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/LICENCE +24 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/README +206 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/changelog.txt +54 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/config +26 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/protocol.txt +191 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/ngx_http_push_defs.c +59 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/ngx_http_push_defs.h +73 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/ngx_http_push_module.c +783 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/ngx_http_push_module.h +31 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/ngx_http_push_module_setup.c +361 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/ngx_http_push_types.h +120 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/memory/store.c +1180 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/memory/store.h +1 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/ngx_http_push_module_ipc.c +146 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/ngx_http_push_module_ipc.h +5 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/ngx_http_push_store.h +51 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/ngx_rwlock.c +178 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/ngx_rwlock.h +5 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/rbtree_util.c +246 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-http-push/src/store/rbtree_util.h +9 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/Changes +51 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/README.markdown +6954 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/config +363 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/doc/HttpLuaModule.wiki +5898 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/dtrace/ngx_lua_provider.d +61 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/misc/recv-until-pm/Makefile +3 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/misc/recv-until-pm/lib/RecvUntil.pm +138 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/misc/recv-until-pm/t/sanity.t +140 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/api/ngx_http_lua_api.h +52 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ddebug.h +82 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_accessby.c +377 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_accessby.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_api.c +77 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_args.c +537 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_args.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_bodyfilterby.c +632 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_bodyfilterby.h +31 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_cache.c +296 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_cache.h +24 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_capturefilter.c +175 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_capturefilter.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_clfactory.c +887 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_clfactory.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_common.h +478 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_config.c +67 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_config.h +19 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_consts.c +148 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_consts.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_contentby.c +369 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_contentby.h +26 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_control.c +483 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_control.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_coroutine.c +379 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_coroutine.h +23 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_ctx.c +216 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_ctx.h +23 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_directive.c +1081 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_directive.h +56 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_exception.c +58 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_exception.h +33 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headerfilterby.c +302 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headerfilterby.h +29 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headers.c +1370 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headers.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headers_in.c +782 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headers_in.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headers_out.c +625 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_headers_out.h +23 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_initby.c +42 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_initby.h +23 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_initworkerby.c +320 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_initworkerby.h +25 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_log.c +300 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_log.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_logby.c +227 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_logby.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_misc.c +252 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_misc.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_module.c +924 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_ndk.c +184 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_ndk.h +21 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_output.c +794 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_output.h +28 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_pcrefix.c +106 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_pcrefix.h +23 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_phase.c +94 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_phase.h +13 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_probe.h +85 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_regex.c +2468 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_regex.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_req_body.c +1169 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_req_body.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_req_method.c +252 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_req_method.h +19 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_rewriteby.c +351 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_rewriteby.h +22 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_script.c +538 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_script.h +86 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_setby.c +216 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_setby.h +15 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_shdict.c +1844 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_shdict.h +52 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_sleep.c +191 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_sleep.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_socket_tcp.c +5314 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_socket_tcp.h +156 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_socket_udp.c +1624 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_socket_udp.h +56 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_string.c +704 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_string.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_subrequest.c +1741 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_subrequest.h +46 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_time.c +278 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_time.h +21 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_timer.c +661 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_timer.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_uri.c +110 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_uri.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_uthread.c +283 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_uthread.h +36 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_util.c +3972 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_util.h +423 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_variable.c +499 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_variable.h +20 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_worker.c +64 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/src/ngx_http_lua_worker.h +17 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/tapset/ngx_lua.stp +5 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/build.sh +39 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/build2.sh +55 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/fix-comments +27 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/gdbinit +415 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/ngx-links +62 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/reindex +64 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/releng +8 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/retab +8 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/revim +102 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/run_test.sh +10 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/util/update-readme.sh +4 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-lua/valgrind.suppress +144 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upload-progress/CHANGES +107 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upload-progress/LICENSE +25 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upload-progress/Makefile +8 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upload-progress/README +329 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upload-progress/config +3 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upload-progress/ngx_http_uploadprogress_module.c +1774 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upstream-fair/README +53 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upstream-fair/config +3 -0
- data/packaging/debian/debian_specs/nginx/modules/nginx-upstream-fair/ngx_http_upstream_fair_module.c +1356 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/CHANGELOG.md +37 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/HACKING.md +24 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/LICENSE +20 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/README.rst +182 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/config +8 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/nginx-0.6-support.patch +23 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/ngx_http_fancyindex_module.c +1305 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/template.awk +52 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/template.h +103 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx-fancyindex/template.html +102 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/CHANGES +37 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/README +141 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/config +3 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/doc/README.google_code_home_page.wiki +120 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/doc/README.html +199 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/doc/README.wiki +123 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/ngx_http_subs_filter_module.c +1298 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/README +275 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/AutoInstall.pm +820 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install.pm +470 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/AutoInstall.pm +82 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/Base.pm +83 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/Can.pm +81 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/Fetch.pm +93 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/Include.pm +34 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/Makefile.pm +415 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/Metadata.pm +716 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/TestBase.pm +29 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/Win32.pm +64 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Module/Install/WriteAll.pm +63 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Spiffy.pm +539 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Test/Base.pm +682 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Test/Base/Filter.pm +341 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Test/Builder.pm +1413 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Test/Builder/Module.pm +81 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/inc/Test/More.pm +735 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/lib/Test/Nginx.pm +315 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/lib/Test/Nginx/LWP.pm +524 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/lib/Test/Nginx/Socket.pm +1749 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/lib/Test/Nginx/Util.pm +874 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/t/subs.t +136 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/t/subs_capture.t +32 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/t/subs_fix_string.t +32 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/t/subs_regex.t +108 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/t/subs_types.t +59 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/test/test.sh +5 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/util/update-readme.sh +7 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/util/wiki2google_code_homepage.pl +29 -0
- data/packaging/debian/debian_specs/nginx/modules/ngx_http_substitutions_filter_module/util/wiki2pod.pl +129 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.NEWS +135 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.README.Debian +45 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.dirs.erb +32 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.install +3 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.lintian-overrides +2 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.manpages +1 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.nginx.default +10 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.nginx.init.erb +214 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.nginx.logrotate +18 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.nginx.service.erb +37 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.postinst.erb +66 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.postrm.erb +46 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.preinst +47 -0
- data/packaging/debian/debian_specs/nginx/nginx-common.prerm.erb +28 -0
- data/packaging/debian/debian_specs/nginx/nginx-doc.docs +2 -0
- data/packaging/debian/debian_specs/nginx/nginx-doc.examples +1 -0
- data/packaging/debian/debian_specs/nginx/nginx-extras.install.erb +17 -0
- data/packaging/debian/debian_specs/nginx/nginx-extras.lintian-overrides +1 -0
- data/packaging/debian/debian_specs/nginx/nginx-extras.postinst.erb +44 -0
- data/packaging/debian/debian_specs/nginx/nginx-extras.prerm +22 -0
- data/packaging/debian/debian_specs/nginx/nginx.1 +47 -0
- data/packaging/debian/debian_specs/nginx/patches/perl-use-dpkg-buildflags.patch +23 -0
- data/packaging/debian/debian_specs/nginx/patches/series +1 -0
- data/packaging/debian/debian_specs/nginx/rules.erb +185 -0
- data/packaging/debian/debian_specs/nginx/source/format +1 -0
- data/packaging/debian/debian_specs/nginx/tests/control +4 -0
- data/packaging/debian/debian_specs/nginx/ufw/nginx +14 -0
- data/packaging/debian/debian_specs/nginx/upstream/signing-key.asc +34 -0
- data/packaging/debian/debian_specs/nginx/watch +3 -0
- data/packaging/debian/debian_specs/passenger/README.Debian +12 -0
- data/packaging/debian/debian_specs/passenger/changelog +316 -0
- data/packaging/debian/debian_specs/passenger/compat +1 -0
- data/packaging/debian/debian_specs/passenger/control.erb +123 -0
- data/packaging/debian/debian_specs/passenger/copyright +385 -0
- data/packaging/debian/debian_specs/passenger/helpers.rb +24 -0
- data/packaging/debian/debian_specs/passenger/libapache2-mod-passenger.install +3 -0
- data/packaging/debian/debian_specs/passenger/libapache2-mod-passenger.postinst +36 -0
- data/packaging/debian/debian_specs/passenger/libapache2-mod-passenger.prerm +15 -0
- data/packaging/debian/debian_specs/passenger/locations.ini.erb +14 -0
- data/packaging/debian/debian_specs/passenger/passenger-dev.install.erb +3 -0
- data/packaging/debian/debian_specs/passenger/passenger-doc.install.erb +2 -0
- data/packaging/debian/debian_specs/passenger/passenger.conf +6 -0
- data/packaging/debian/debian_specs/passenger/passenger.docs +4 -0
- data/packaging/debian/debian_specs/passenger/passenger.install.erb +16 -0
- data/packaging/debian/debian_specs/passenger/passenger.load +3 -0
- data/packaging/debian/debian_specs/passenger/passenger.manpages +3 -0
- data/packaging/debian/debian_specs/passenger/passenger_free_ruby.c +29 -0
- data/packaging/debian/debian_specs/passenger/passenger_ruby_utils.c +54 -0
- data/packaging/debian/debian_specs/passenger/passenger_system_ruby.c.erb +37 -0
- data/packaging/debian/debian_specs/passenger/patches/series +0 -0
- data/packaging/debian/debian_specs/passenger/rules.erb +84 -0
- data/packaging/debian/debian_specs/passenger/source/format +1 -0
- data/packaging/debian/debian_specs/passenger_enterprise/README.Debian +12 -0
- data/packaging/debian/debian_specs/passenger_enterprise/changelog +316 -0
- data/packaging/debian/debian_specs/passenger_enterprise/compat +1 -0
- data/packaging/debian/debian_specs/passenger_enterprise/control.erb +123 -0
- data/packaging/debian/debian_specs/passenger_enterprise/copyright +385 -0
- data/packaging/debian/debian_specs/passenger_enterprise/helpers.rb +2 -0
- data/packaging/debian/debian_specs/passenger_enterprise/libapache2-mod-passenger-enterprise.install +3 -0
- data/packaging/debian/debian_specs/passenger_enterprise/libapache2-mod-passenger-enterprise.postinst +36 -0
- data/packaging/debian/debian_specs/passenger_enterprise/libapache2-mod-passenger-enterprise.prerm +15 -0
- data/packaging/debian/debian_specs/passenger_enterprise/locations.ini.erb +14 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger-enterprise-dev.install.erb +3 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger-enterprise-doc.install.erb +2 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger-enterprise.docs +4 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger-enterprise.install.erb +14 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger-enterprise.manpages +3 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger.conf +6 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger.load +3 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger_free_ruby.c.erb +1 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger_ruby_utils.c.erb +1 -0
- data/packaging/debian/debian_specs/passenger_enterprise/passenger_system_ruby.c.erb +1 -0
- data/packaging/debian/debian_specs/passenger_enterprise/patches/series +0 -0
- data/packaging/debian/debian_specs/passenger_enterprise/rules.erb +84 -0
- data/packaging/debian/debian_specs/passenger_enterprise/source/format +1 -0
- data/packaging/debian/docker_images/Makefile +38 -0
- data/packaging/debian/docker_images/buildbox/CONTAINER_VERSION.txt +0 -0
- data/packaging/debian/docker_images/buildbox/Dockerfile +3 -0
- data/packaging/debian/docker_images/buildbox/Gemfile +9 -0
- data/packaging/debian/docker_images/buildbox/Gemfile.lock +42 -0
- data/packaging/debian/docker_images/buildbox/install.sh +85 -0
- data/packaging/debian/docker_images/buildbox/pbuilderrc +4 -0
- data/packaging/debian/docker_images/buildbox/sudoers.conf +6 -0
- data/packaging/debian/docker_images/setup-buildbox-docker-image +7 -0
- data/packaging/debian/docker_images/setup-testbox-docker-image-debian-6 +7 -0
- data/packaging/debian/docker_images/setup-testbox-docker-image-debian-7 +7 -0
- data/packaging/debian/docker_images/setup-testbox-docker-image-debian-8 +7 -0
- data/packaging/debian/docker_images/setup-testbox-docker-image-ubuntu-12.04 +7 -0
- data/packaging/debian/docker_images/setup-testbox-docker-image-ubuntu-14.04 +7 -0
- data/packaging/debian/docker_images/setup-testbox-docker-image-ubuntu-15.04 +7 -0
- data/packaging/debian/docker_images/setup-testbox-docker-image-ubuntu-15.10 +7 -0
- data/packaging/debian/docker_images/testbox-debian-6/Dockerfile +3 -0
- data/packaging/debian/docker_images/testbox-debian-6/Gemfile +2 -0
- data/packaging/debian/docker_images/testbox-debian-6/Gemfile.lock +23 -0
- data/packaging/debian/docker_images/testbox-debian-6/argparse.py +2374 -0
- data/packaging/debian/docker_images/testbox-debian-6/install.sh +78 -0
- data/packaging/debian/docker_images/testbox-debian-7/Dockerfile +3 -0
- data/packaging/debian/docker_images/testbox-debian-7/Gemfile +2 -0
- data/packaging/debian/docker_images/testbox-debian-7/Gemfile.lock +23 -0
- data/packaging/debian/docker_images/testbox-debian-7/install.sh +71 -0
- data/packaging/debian/docker_images/testbox-debian-8/Dockerfile +3 -0
- data/packaging/debian/docker_images/testbox-debian-8/Gemfile +2 -0
- data/packaging/debian/docker_images/testbox-debian-8/Gemfile.lock +23 -0
- data/packaging/debian/docker_images/testbox-debian-8/install.sh +70 -0
- data/packaging/debian/docker_images/testbox-ubuntu-12.04/Dockerfile +3 -0
- data/packaging/debian/docker_images/testbox-ubuntu-12.04/Gemfile +2 -0
- data/packaging/debian/docker_images/testbox-ubuntu-12.04/Gemfile.lock +23 -0
- data/packaging/debian/docker_images/testbox-ubuntu-12.04/install.sh +69 -0
- data/packaging/debian/docker_images/testbox-ubuntu-14.04/Dockerfile +3 -0
- data/packaging/debian/docker_images/testbox-ubuntu-14.04/Gemfile +2 -0
- data/packaging/debian/docker_images/testbox-ubuntu-14.04/Gemfile.lock +23 -0
- data/packaging/debian/docker_images/testbox-ubuntu-14.04/install.sh +69 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.04/Dockerfile +3 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.04/Gemfile +2 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.04/Gemfile.lock +23 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.04/install.sh +69 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.10/Dockerfile +3 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.10/Gemfile +2 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.10/Gemfile.lock +23 -0
- data/packaging/debian/docker_images/testbox-ubuntu-15.10/install.sh +69 -0
- data/packaging/debian/internal/build/Rakefile +235 -0
- data/packaging/debian/internal/build/build-passenger-orig-tarball.sh +76 -0
- data/packaging/debian/internal/build/build-source-package.rb +121 -0
- data/packaging/debian/internal/build/download-nginx-orig-tarball.sh +17 -0
- data/packaging/debian/internal/build/rakefile_support.rb +96 -0
- data/packaging/debian/internal/build/setup-environment-essentials.sh +15 -0
- data/packaging/debian/internal/build/setup-environment.sh +29 -0
- data/packaging/debian/internal/lib/distro_info.rb +82 -0
- data/packaging/debian/internal/lib/distro_info.sh +303 -0
- data/packaging/debian/internal/lib/distro_info.sh.erb +65 -0
- data/packaging/debian/internal/lib/library.sh +83 -0
- data/packaging/debian/internal/lib/preprocessor.rb +173 -0
- data/packaging/debian/internal/lib/tracking.rb +95 -0
- data/packaging/debian/internal/lib/tracking_category.rb +45 -0
- data/packaging/debian/internal/lib/tracking_database.rb +132 -0
- data/packaging/debian/internal/lib/tracking_task.rb +148 -0
- data/packaging/debian/internal/lib/utils.rb +78 -0
- data/packaging/debian/internal/publish/Rakefile +97 -0
- data/packaging/debian/internal/publish/oss-binaries.phusionpassenger.com-fingerprint.txt +1 -0
- data/packaging/debian/internal/publish/packagecloud_fingerprint.txt +1 -0
- data/packaging/debian/internal/publish/passenger_website_fingerprint.txt +1 -0
- data/packaging/debian/internal/publish/preinit.sh +7 -0
- data/packaging/debian/internal/publish/rakefile_support.rb +183 -0
- data/packaging/debian/internal/scripts/gpg_noninteractive/gpg +11 -0
- data/packaging/debian/internal/scripts/initccache.sh +35 -0
- data/packaging/debian/internal/scripts/inituidgid.sh +19 -0
- data/packaging/debian/internal/scripts/my_init +340 -0
- data/packaging/debian/internal/scripts/pin_certificates +34 -0
- data/packaging/debian/internal/scripts/regen_distro_info_script.sh +3 -0
- data/packaging/debian/internal/scripts/setup-vagrant.sh +12 -0
- data/packaging/debian/internal/scripts/setuser +31 -0
- data/packaging/debian/internal/shell/initpbuilder.sh +3 -0
- data/packaging/debian/internal/shell/preinit.sh +28 -0
- data/packaging/debian/internal/shell/sudoers.conf +1 -0
- data/packaging/debian/internal/test/apache/apache-24.conf +5 -0
- data/packaging/debian/internal/test/apache/apache-pre-24.conf +4 -0
- data/packaging/debian/internal/test/apache/vhost.conf +17 -0
- data/packaging/debian/internal/test/misc/config.json +15 -0
- data/packaging/debian/internal/test/misc/hosts.conf +4 -0
- data/packaging/debian/internal/test/misc/init.sh +25 -0
- data/packaging/debian/internal/test/misc/nodejs_test_app.js +6 -0
- data/packaging/debian/internal/test/misc/python_test_app.py +3 -0
- data/packaging/debian/internal/test/misc/ruby_test_app.rb +5 -0
- data/packaging/debian/internal/test/misc/test_support.rb +61 -0
- data/packaging/debian/internal/test/nginx/vhost.conf +23 -0
- data/packaging/debian/internal/test/system_web_server_test.rb +126 -0
- data/packaging/debian/internal/test/test.sh +141 -0
- data/packaging/debian/jenkins/publish/clear_caches.rb +48 -0
- data/packaging/debian/jenkins/publish/publish.sh +69 -0
- data/packaging/debian/jenkins/test/test.sh +63 -0
- data/packaging/debian/passenger_apt_automation.sublime-project +14 -0
- data/packaging/debian/publish +172 -0
- data/packaging/debian/shell +116 -0
- data/packaging/debian/test +142 -0
- metadata +563 -3
- metadata.gz.asc +7 -7
- data/resources/oss-binaries.phusionpassenger.com.crt +0 -208
@@ -0,0 +1,46 @@
|
|
1
|
+
|
2
|
+
/*
|
3
|
+
* Copyright (C) Xiaozhe Wang (chaoslawful)
|
4
|
+
* Copyright (C) Yichun Zhang (agentzh)
|
5
|
+
*/
|
6
|
+
|
7
|
+
|
8
|
+
#ifndef _NGX_HTTP_LUA_SUBREQUEST_H_INCLUDED_
|
9
|
+
#define _NGX_HTTP_LUA_SUBREQUEST_H_INCLUDED_
|
10
|
+
|
11
|
+
|
12
|
+
#include "ngx_http_lua_common.h"
|
13
|
+
|
14
|
+
|
15
|
+
void ngx_http_lua_inject_subrequest_api(lua_State *L);
|
16
|
+
ngx_int_t ngx_http_lua_post_subrequest(ngx_http_request_t *r, void *data,
|
17
|
+
ngx_int_t rc);
|
18
|
+
|
19
|
+
|
20
|
+
extern ngx_str_t ngx_http_lua_get_method;
|
21
|
+
extern ngx_str_t ngx_http_lua_put_method;
|
22
|
+
extern ngx_str_t ngx_http_lua_post_method;
|
23
|
+
extern ngx_str_t ngx_http_lua_head_method;
|
24
|
+
extern ngx_str_t ngx_http_lua_delete_method;
|
25
|
+
extern ngx_str_t ngx_http_lua_options_method;
|
26
|
+
extern ngx_str_t ngx_http_lua_copy_method;
|
27
|
+
extern ngx_str_t ngx_http_lua_move_method;
|
28
|
+
extern ngx_str_t ngx_http_lua_lock_method;
|
29
|
+
extern ngx_str_t ngx_http_lua_mkcol_method;
|
30
|
+
extern ngx_str_t ngx_http_lua_propfind_method;
|
31
|
+
extern ngx_str_t ngx_http_lua_proppatch_method;
|
32
|
+
extern ngx_str_t ngx_http_lua_unlock_method;
|
33
|
+
extern ngx_str_t ngx_http_lua_patch_method;
|
34
|
+
extern ngx_str_t ngx_http_lua_trace_method;
|
35
|
+
|
36
|
+
|
37
|
+
typedef struct ngx_http_lua_post_subrequest_data_s {
|
38
|
+
ngx_http_lua_ctx_t *ctx;
|
39
|
+
ngx_http_lua_co_ctx_t *pr_co_ctx;
|
40
|
+
|
41
|
+
} ngx_http_lua_post_subrequest_data_t;
|
42
|
+
|
43
|
+
|
44
|
+
#endif /* _NGX_HTTP_LUA_SUBREQUEST_H_INCLUDED_ */
|
45
|
+
|
46
|
+
/* vi:set ft=c ts=4 sw=4 et fdm=marker: */
|
@@ -0,0 +1,278 @@
|
|
1
|
+
|
2
|
+
/*
|
3
|
+
* Copyright (C) Xiaozhe Wang (chaoslawful)
|
4
|
+
* Copyright (C) Yichun Zhang (agentzh)
|
5
|
+
*/
|
6
|
+
|
7
|
+
|
8
|
+
#ifndef DDEBUG
|
9
|
+
#define DDEBUG 0
|
10
|
+
#endif
|
11
|
+
#include "ddebug.h"
|
12
|
+
|
13
|
+
|
14
|
+
#include "ngx_http_lua_time.h"
|
15
|
+
#include "ngx_http_lua_util.h"
|
16
|
+
|
17
|
+
|
18
|
+
static int ngx_http_lua_ngx_today(lua_State *L);
|
19
|
+
static int ngx_http_lua_ngx_time(lua_State *L);
|
20
|
+
static int ngx_http_lua_ngx_now(lua_State *L);
|
21
|
+
static int ngx_http_lua_ngx_localtime(lua_State *L);
|
22
|
+
static int ngx_http_lua_ngx_utctime(lua_State *L);
|
23
|
+
static int ngx_http_lua_ngx_cookie_time(lua_State *L);
|
24
|
+
static int ngx_http_lua_ngx_http_time(lua_State *L);
|
25
|
+
static int ngx_http_lua_ngx_parse_http_time(lua_State *L);
|
26
|
+
static int ngx_http_lua_ngx_update_time(lua_State *L);
|
27
|
+
static int ngx_http_lua_ngx_req_start_time(lua_State *L);
|
28
|
+
|
29
|
+
|
30
|
+
static int
|
31
|
+
ngx_http_lua_ngx_today(lua_State *L)
|
32
|
+
{
|
33
|
+
time_t now;
|
34
|
+
ngx_tm_t tm;
|
35
|
+
u_char buf[sizeof("2010-11-19") - 1];
|
36
|
+
|
37
|
+
now = ngx_time();
|
38
|
+
ngx_gmtime(now + ngx_cached_time->gmtoff * 60, &tm);
|
39
|
+
|
40
|
+
ngx_sprintf(buf, "%04d-%02d-%02d", tm.ngx_tm_year, tm.ngx_tm_mon,
|
41
|
+
tm.ngx_tm_mday);
|
42
|
+
|
43
|
+
lua_pushlstring(L, (char *) buf, sizeof(buf));
|
44
|
+
|
45
|
+
return 1;
|
46
|
+
}
|
47
|
+
|
48
|
+
|
49
|
+
static int
|
50
|
+
ngx_http_lua_ngx_localtime(lua_State *L)
|
51
|
+
{
|
52
|
+
ngx_tm_t tm;
|
53
|
+
|
54
|
+
u_char buf[sizeof("2010-11-19 20:56:31") - 1];
|
55
|
+
|
56
|
+
ngx_gmtime(ngx_time() + ngx_cached_time->gmtoff * 60, &tm);
|
57
|
+
|
58
|
+
ngx_sprintf(buf, "%04d-%02d-%02d %02d:%02d:%02d", tm.ngx_tm_year,
|
59
|
+
tm.ngx_tm_mon, tm.ngx_tm_mday, tm.ngx_tm_hour, tm.ngx_tm_min,
|
60
|
+
tm.ngx_tm_sec);
|
61
|
+
|
62
|
+
lua_pushlstring(L, (char *) buf, sizeof(buf));
|
63
|
+
|
64
|
+
return 1;
|
65
|
+
}
|
66
|
+
|
67
|
+
|
68
|
+
static int
|
69
|
+
ngx_http_lua_ngx_time(lua_State *L)
|
70
|
+
{
|
71
|
+
lua_pushnumber(L, (lua_Number) ngx_time());
|
72
|
+
|
73
|
+
return 1;
|
74
|
+
}
|
75
|
+
|
76
|
+
|
77
|
+
static int
|
78
|
+
ngx_http_lua_ngx_now(lua_State *L)
|
79
|
+
{
|
80
|
+
ngx_time_t *tp;
|
81
|
+
|
82
|
+
tp = ngx_timeofday();
|
83
|
+
|
84
|
+
lua_pushnumber(L, (lua_Number) (tp->sec + tp->msec / 1000.0L));
|
85
|
+
|
86
|
+
return 1;
|
87
|
+
}
|
88
|
+
|
89
|
+
|
90
|
+
static int
|
91
|
+
ngx_http_lua_ngx_update_time(lua_State *L)
|
92
|
+
{
|
93
|
+
ngx_time_update();
|
94
|
+
return 0;
|
95
|
+
}
|
96
|
+
|
97
|
+
|
98
|
+
static int
|
99
|
+
ngx_http_lua_ngx_utctime(lua_State *L)
|
100
|
+
{
|
101
|
+
ngx_tm_t tm;
|
102
|
+
u_char buf[sizeof("2010-11-19 20:56:31") - 1];
|
103
|
+
|
104
|
+
ngx_gmtime(ngx_time(), &tm);
|
105
|
+
|
106
|
+
ngx_sprintf(buf, "%04d-%02d-%02d %02d:%02d:%02d", tm.ngx_tm_year,
|
107
|
+
tm.ngx_tm_mon, tm.ngx_tm_mday, tm.ngx_tm_hour, tm.ngx_tm_min,
|
108
|
+
tm.ngx_tm_sec);
|
109
|
+
|
110
|
+
lua_pushlstring(L, (char *) buf, sizeof(buf));
|
111
|
+
|
112
|
+
return 1;
|
113
|
+
}
|
114
|
+
|
115
|
+
|
116
|
+
static int
|
117
|
+
ngx_http_lua_ngx_cookie_time(lua_State *L)
|
118
|
+
{
|
119
|
+
time_t t;
|
120
|
+
u_char *p;
|
121
|
+
|
122
|
+
u_char buf[sizeof("Mon, 28 Sep 1970 06:00:00 GMT") - 1];
|
123
|
+
|
124
|
+
if (lua_gettop(L) != 1) {
|
125
|
+
return luaL_error(L, "expecting one argument");
|
126
|
+
}
|
127
|
+
|
128
|
+
t = (time_t) luaL_checknumber(L, 1);
|
129
|
+
|
130
|
+
p = buf;
|
131
|
+
p = ngx_http_cookie_time(p, t);
|
132
|
+
|
133
|
+
lua_pushlstring(L, (char *) buf, p - buf);
|
134
|
+
|
135
|
+
return 1;
|
136
|
+
}
|
137
|
+
|
138
|
+
|
139
|
+
static int
|
140
|
+
ngx_http_lua_ngx_http_time(lua_State *L)
|
141
|
+
{
|
142
|
+
time_t t;
|
143
|
+
u_char *p;
|
144
|
+
|
145
|
+
u_char buf[sizeof("Mon, 28 Sep 1970 06:00:00 GMT") - 1];
|
146
|
+
|
147
|
+
if (lua_gettop(L) != 1) {
|
148
|
+
return luaL_error(L, "expecting one argument");
|
149
|
+
}
|
150
|
+
|
151
|
+
t = (time_t) luaL_checknumber(L, 1);
|
152
|
+
|
153
|
+
p = buf;
|
154
|
+
p = ngx_http_time(p, t);
|
155
|
+
|
156
|
+
lua_pushlstring(L, (char *) buf, p - buf);
|
157
|
+
|
158
|
+
return 1;
|
159
|
+
}
|
160
|
+
|
161
|
+
|
162
|
+
static int
|
163
|
+
ngx_http_lua_ngx_parse_http_time(lua_State *L)
|
164
|
+
{
|
165
|
+
u_char *p;
|
166
|
+
size_t len;
|
167
|
+
time_t time;
|
168
|
+
|
169
|
+
if (lua_gettop(L) != 1) {
|
170
|
+
return luaL_error(L, "expecting one argument");
|
171
|
+
}
|
172
|
+
|
173
|
+
p = (u_char *) luaL_checklstring(L, 1, &len);
|
174
|
+
|
175
|
+
time = ngx_http_parse_time(p, len);
|
176
|
+
if (time == NGX_ERROR) {
|
177
|
+
lua_pushnil(L);
|
178
|
+
return 1;
|
179
|
+
}
|
180
|
+
|
181
|
+
lua_pushnumber(L, (lua_Number) time);
|
182
|
+
|
183
|
+
return 1;
|
184
|
+
}
|
185
|
+
|
186
|
+
|
187
|
+
static int
|
188
|
+
ngx_http_lua_ngx_req_start_time(lua_State *L)
|
189
|
+
{
|
190
|
+
ngx_http_request_t *r;
|
191
|
+
|
192
|
+
r = ngx_http_lua_get_req(L);
|
193
|
+
if (r == NULL) {
|
194
|
+
return luaL_error(L, "no request found");
|
195
|
+
}
|
196
|
+
|
197
|
+
lua_pushnumber(L, (lua_Number) (r->start_sec + r->start_msec / 1000.0L));
|
198
|
+
return 1;
|
199
|
+
}
|
200
|
+
|
201
|
+
|
202
|
+
void
|
203
|
+
ngx_http_lua_inject_time_api(lua_State *L)
|
204
|
+
{
|
205
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_utctime);
|
206
|
+
lua_setfield(L, -2, "utctime");
|
207
|
+
|
208
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_time);
|
209
|
+
lua_setfield(L, -2, "get_now_ts"); /* deprecated */
|
210
|
+
|
211
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_localtime);
|
212
|
+
lua_setfield(L, -2, "get_now"); /* deprecated */
|
213
|
+
|
214
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_localtime);
|
215
|
+
lua_setfield(L, -2, "localtime");
|
216
|
+
|
217
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_time);
|
218
|
+
lua_setfield(L, -2, "time");
|
219
|
+
|
220
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_now);
|
221
|
+
lua_setfield(L, -2, "now");
|
222
|
+
|
223
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_update_time);
|
224
|
+
lua_setfield(L, -2, "update_time");
|
225
|
+
|
226
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_today);
|
227
|
+
lua_setfield(L, -2, "get_today"); /* deprecated */
|
228
|
+
|
229
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_today);
|
230
|
+
lua_setfield(L, -2, "today");
|
231
|
+
|
232
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_cookie_time);
|
233
|
+
lua_setfield(L, -2, "cookie_time");
|
234
|
+
|
235
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_http_time);
|
236
|
+
lua_setfield(L, -2, "http_time");
|
237
|
+
|
238
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_parse_http_time);
|
239
|
+
lua_setfield(L, -2, "parse_http_time");
|
240
|
+
}
|
241
|
+
|
242
|
+
|
243
|
+
void
|
244
|
+
ngx_http_lua_inject_req_time_api(lua_State *L)
|
245
|
+
{
|
246
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_req_start_time);
|
247
|
+
lua_setfield(L, -2, "start_time");
|
248
|
+
}
|
249
|
+
|
250
|
+
|
251
|
+
#ifndef NGX_LUA_NO_FFI_API
|
252
|
+
double
|
253
|
+
ngx_http_lua_ffi_now(void)
|
254
|
+
{
|
255
|
+
ngx_time_t *tp;
|
256
|
+
|
257
|
+
tp = ngx_timeofday();
|
258
|
+
|
259
|
+
return tp->sec + tp->msec / 1000.0;
|
260
|
+
}
|
261
|
+
|
262
|
+
|
263
|
+
double
|
264
|
+
ngx_http_lua_ffi_req_start_time(ngx_http_request_t *r)
|
265
|
+
{
|
266
|
+
return r->start_sec + r->start_msec / 1000.0;
|
267
|
+
}
|
268
|
+
|
269
|
+
|
270
|
+
long
|
271
|
+
ngx_http_lua_ffi_time(void)
|
272
|
+
{
|
273
|
+
return (long) ngx_time();
|
274
|
+
}
|
275
|
+
#endif /* NGX_LUA_NO_FFI_API */
|
276
|
+
|
277
|
+
|
278
|
+
/* vi:set ft=c ts=4 sw=4 et fdm=marker: */
|
@@ -0,0 +1,21 @@
|
|
1
|
+
|
2
|
+
/*
|
3
|
+
* Copyright (C) Xiaozhe Wang (chaoslawful)
|
4
|
+
* Copyright (C) Yichun Zhang (agentzh)
|
5
|
+
*/
|
6
|
+
|
7
|
+
|
8
|
+
#ifndef _NGX_HTTP_LUA_TIME_H_INCLUDED_
|
9
|
+
#define _NGX_HTTP_LUA_TIME_H_INCLUDED_
|
10
|
+
|
11
|
+
|
12
|
+
#include "ngx_http_lua_common.h"
|
13
|
+
|
14
|
+
|
15
|
+
void ngx_http_lua_inject_time_api(lua_State *L);
|
16
|
+
void ngx_http_lua_inject_req_time_api(lua_State *L);
|
17
|
+
|
18
|
+
|
19
|
+
#endif /* _NGX_HTTP_LUA_TIME_H_INCLUDED_ */
|
20
|
+
|
21
|
+
/* vi:set ft=c ts=4 sw=4 et fdm=marker: */
|
@@ -0,0 +1,661 @@
|
|
1
|
+
|
2
|
+
/*
|
3
|
+
* Copyright (C) Yichun Zhang (agentzh)
|
4
|
+
*/
|
5
|
+
|
6
|
+
|
7
|
+
#ifndef DDEBUG
|
8
|
+
#define DDEBUG 0
|
9
|
+
#endif
|
10
|
+
#include "ddebug.h"
|
11
|
+
|
12
|
+
|
13
|
+
#include "ngx_http_lua_timer.h"
|
14
|
+
#include "ngx_http_lua_util.h"
|
15
|
+
#include "ngx_http_lua_contentby.h"
|
16
|
+
#include "ngx_http_lua_probe.h"
|
17
|
+
|
18
|
+
|
19
|
+
typedef struct {
|
20
|
+
void **main_conf;
|
21
|
+
void **srv_conf;
|
22
|
+
void **loc_conf;
|
23
|
+
|
24
|
+
/* event ident must be after 3 words (i.e. 3 pointers' size) as in
|
25
|
+
* ngx_connection_t. and we use the Lua coroutine reference number as
|
26
|
+
* the event ident */
|
27
|
+
int co_ref;
|
28
|
+
unsigned premature; /* :1 */
|
29
|
+
lua_State *co;
|
30
|
+
|
31
|
+
ngx_pool_t *pool;
|
32
|
+
|
33
|
+
ngx_listening_t *listening;
|
34
|
+
ngx_str_t client_addr_text;
|
35
|
+
|
36
|
+
ngx_http_lua_main_conf_t *lmcf;
|
37
|
+
ngx_http_lua_vm_state_t *vm_state;
|
38
|
+
|
39
|
+
} ngx_http_lua_timer_ctx_t;
|
40
|
+
|
41
|
+
|
42
|
+
static int ngx_http_lua_ngx_timer_at(lua_State *L);
|
43
|
+
static void ngx_http_lua_timer_handler(ngx_event_t *ev);
|
44
|
+
static u_char * ngx_http_lua_log_timer_error(ngx_log_t *log, u_char *buf,
|
45
|
+
size_t len);
|
46
|
+
static void ngx_http_lua_abort_pending_timers(ngx_event_t *ev);
|
47
|
+
|
48
|
+
|
49
|
+
void
|
50
|
+
ngx_http_lua_inject_timer_api(lua_State *L)
|
51
|
+
{
|
52
|
+
lua_createtable(L, 0 /* narr */, 1 /* nrec */); /* ngx.timer. */
|
53
|
+
|
54
|
+
lua_pushcfunction(L, ngx_http_lua_ngx_timer_at);
|
55
|
+
lua_setfield(L, -2, "at");
|
56
|
+
|
57
|
+
lua_setfield(L, -2, "timer");
|
58
|
+
}
|
59
|
+
|
60
|
+
|
61
|
+
static int
|
62
|
+
ngx_http_lua_ngx_timer_at(lua_State *L)
|
63
|
+
{
|
64
|
+
int nargs, co_ref;
|
65
|
+
u_char *p;
|
66
|
+
lua_State *vm; /* the main thread */
|
67
|
+
lua_State *co;
|
68
|
+
ngx_msec_t delay;
|
69
|
+
ngx_event_t *ev = NULL;
|
70
|
+
ngx_http_request_t *r;
|
71
|
+
ngx_connection_t *saved_c = NULL;
|
72
|
+
ngx_http_lua_ctx_t *ctx;
|
73
|
+
#if 0
|
74
|
+
ngx_http_connection_t *hc;
|
75
|
+
#endif
|
76
|
+
|
77
|
+
ngx_http_lua_timer_ctx_t *tctx = NULL;
|
78
|
+
ngx_http_lua_main_conf_t *lmcf;
|
79
|
+
#if 0
|
80
|
+
ngx_http_core_main_conf_t *cmcf;
|
81
|
+
#endif
|
82
|
+
|
83
|
+
nargs = lua_gettop(L);
|
84
|
+
if (nargs < 2) {
|
85
|
+
return luaL_error(L, "expecting at least 2 arguments but got %d",
|
86
|
+
nargs);
|
87
|
+
}
|
88
|
+
|
89
|
+
delay = (ngx_msec_t) (luaL_checknumber(L, 1) * 1000);
|
90
|
+
|
91
|
+
luaL_argcheck(L, lua_isfunction(L, 2) && !lua_iscfunction(L, 2), 2,
|
92
|
+
"Lua function expected");
|
93
|
+
|
94
|
+
r = ngx_http_lua_get_req(L);
|
95
|
+
if (r == NULL) {
|
96
|
+
return luaL_error(L, "no request");
|
97
|
+
}
|
98
|
+
|
99
|
+
ctx = ngx_http_get_module_ctx(r, ngx_http_lua_module);
|
100
|
+
|
101
|
+
if (ngx_exiting && delay > 0) {
|
102
|
+
lua_pushnil(L);
|
103
|
+
lua_pushliteral(L, "process exiting");
|
104
|
+
return 2;
|
105
|
+
}
|
106
|
+
|
107
|
+
lmcf = ngx_http_get_module_main_conf(r, ngx_http_lua_module);
|
108
|
+
|
109
|
+
if (lmcf->pending_timers >= lmcf->max_pending_timers) {
|
110
|
+
lua_pushnil(L);
|
111
|
+
lua_pushliteral(L, "too many pending timers");
|
112
|
+
return 2;
|
113
|
+
}
|
114
|
+
|
115
|
+
if (lmcf->watcher == NULL) {
|
116
|
+
/* create the watcher fake connection */
|
117
|
+
|
118
|
+
ngx_log_debug0(NGX_LOG_DEBUG_HTTP, ngx_cycle->log, 0,
|
119
|
+
"lua creating fake watcher connection");
|
120
|
+
|
121
|
+
if (ngx_cycle->files) {
|
122
|
+
saved_c = ngx_cycle->files[0];
|
123
|
+
}
|
124
|
+
|
125
|
+
lmcf->watcher = ngx_get_connection(0, ngx_cycle->log);
|
126
|
+
|
127
|
+
if (ngx_cycle->files) {
|
128
|
+
ngx_cycle->files[0] = saved_c;
|
129
|
+
}
|
130
|
+
|
131
|
+
if (lmcf->watcher == NULL) {
|
132
|
+
return luaL_error(L, "no memory");
|
133
|
+
}
|
134
|
+
|
135
|
+
/* to work around the -1 check in ngx_worker_process_cycle: */
|
136
|
+
lmcf->watcher->fd = (ngx_socket_t) -2;
|
137
|
+
|
138
|
+
lmcf->watcher->idle = 1;
|
139
|
+
lmcf->watcher->read->handler = ngx_http_lua_abort_pending_timers;
|
140
|
+
lmcf->watcher->data = lmcf;
|
141
|
+
}
|
142
|
+
|
143
|
+
vm = ngx_http_lua_get_lua_vm(r, ctx);
|
144
|
+
|
145
|
+
co = lua_newthread(vm);
|
146
|
+
|
147
|
+
/* L stack: time func [args] thread */
|
148
|
+
|
149
|
+
ngx_http_lua_probe_user_coroutine_create(r, L, co);
|
150
|
+
|
151
|
+
lua_createtable(co, 0, 0); /* the new globals table */
|
152
|
+
|
153
|
+
/* co stack: global_tb */
|
154
|
+
|
155
|
+
lua_createtable(co, 0, 1); /* the metatable */
|
156
|
+
ngx_http_lua_get_globals_table(co);
|
157
|
+
lua_setfield(co, -2, "__index");
|
158
|
+
lua_setmetatable(co, -2);
|
159
|
+
|
160
|
+
/* co stack: global_tb */
|
161
|
+
|
162
|
+
ngx_http_lua_set_globals_table(co);
|
163
|
+
|
164
|
+
/* co stack: <empty> */
|
165
|
+
|
166
|
+
dd("stack top: %d", lua_gettop(L));
|
167
|
+
|
168
|
+
lua_xmove(vm, L, 1); /* move coroutine from main thread to L */
|
169
|
+
|
170
|
+
/* L stack: time func [args] thread */
|
171
|
+
/* vm stack: empty */
|
172
|
+
|
173
|
+
lua_pushvalue(L, 2); /* copy entry function to top of L*/
|
174
|
+
|
175
|
+
/* L stack: time func [args] thread func */
|
176
|
+
|
177
|
+
lua_xmove(L, co, 1); /* move entry function from L to co */
|
178
|
+
|
179
|
+
/* L stack: time func [args] thread */
|
180
|
+
/* co stack: func */
|
181
|
+
|
182
|
+
ngx_http_lua_get_globals_table(co);
|
183
|
+
lua_setfenv(co, -2);
|
184
|
+
|
185
|
+
/* co stack: func */
|
186
|
+
|
187
|
+
lua_pushlightuserdata(L, &ngx_http_lua_coroutines_key);
|
188
|
+
lua_rawget(L, LUA_REGISTRYINDEX);
|
189
|
+
|
190
|
+
/* L stack: time func [args] thread corountines */
|
191
|
+
|
192
|
+
lua_pushvalue(L, -2);
|
193
|
+
|
194
|
+
/* L stack: time func [args] thread coroutines thread */
|
195
|
+
|
196
|
+
co_ref = luaL_ref(L, -2);
|
197
|
+
lua_pop(L, 1);
|
198
|
+
|
199
|
+
/* L stack: time func [args] thread */
|
200
|
+
|
201
|
+
if (nargs > 2) {
|
202
|
+
lua_pop(L, 1); /* L stack: time func [args] */
|
203
|
+
lua_xmove(L, co, nargs - 2); /* L stack: time func */
|
204
|
+
|
205
|
+
/* co stack: func [args] */
|
206
|
+
}
|
207
|
+
|
208
|
+
p = ngx_alloc(sizeof(ngx_event_t) + sizeof(ngx_http_lua_timer_ctx_t),
|
209
|
+
r->connection->log);
|
210
|
+
if (p == NULL) {
|
211
|
+
goto nomem;
|
212
|
+
}
|
213
|
+
|
214
|
+
ev = (ngx_event_t *) p;
|
215
|
+
|
216
|
+
ngx_memzero(ev, sizeof(ngx_event_t));
|
217
|
+
|
218
|
+
p += sizeof(ngx_event_t);
|
219
|
+
|
220
|
+
tctx = (ngx_http_lua_timer_ctx_t *) p;
|
221
|
+
|
222
|
+
tctx->premature = 0;
|
223
|
+
tctx->co_ref = co_ref;
|
224
|
+
tctx->co = co;
|
225
|
+
tctx->main_conf = r->main_conf;
|
226
|
+
tctx->srv_conf = r->srv_conf;
|
227
|
+
tctx->loc_conf = r->loc_conf;
|
228
|
+
tctx->lmcf = lmcf;
|
229
|
+
|
230
|
+
tctx->pool = ngx_create_pool(128, ngx_cycle->log);
|
231
|
+
if (tctx->pool == NULL) {
|
232
|
+
goto nomem;
|
233
|
+
}
|
234
|
+
|
235
|
+
if (r->connection) {
|
236
|
+
tctx->listening = r->connection->listening;
|
237
|
+
|
238
|
+
} else {
|
239
|
+
tctx->listening = NULL;
|
240
|
+
}
|
241
|
+
|
242
|
+
if (r->connection->addr_text.len) {
|
243
|
+
tctx->client_addr_text.data = ngx_palloc(tctx->pool,
|
244
|
+
r->connection->addr_text.len);
|
245
|
+
if (tctx->client_addr_text.data == NULL) {
|
246
|
+
goto nomem;
|
247
|
+
}
|
248
|
+
|
249
|
+
ngx_memcpy(tctx->client_addr_text.data, r->connection->addr_text.data,
|
250
|
+
r->connection->addr_text.len);
|
251
|
+
tctx->client_addr_text.len = r->connection->addr_text.len;
|
252
|
+
|
253
|
+
} else {
|
254
|
+
tctx->client_addr_text.len = 0;
|
255
|
+
tctx->client_addr_text.data = NULL;
|
256
|
+
}
|
257
|
+
|
258
|
+
if (ctx && ctx->vm_state) {
|
259
|
+
tctx->vm_state = ctx->vm_state;
|
260
|
+
tctx->vm_state->count++;
|
261
|
+
|
262
|
+
} else {
|
263
|
+
tctx->vm_state = NULL;
|
264
|
+
}
|
265
|
+
|
266
|
+
ev->handler = ngx_http_lua_timer_handler;
|
267
|
+
ev->data = tctx;
|
268
|
+
ev->log = ngx_cycle->log;
|
269
|
+
|
270
|
+
lmcf->pending_timers++;
|
271
|
+
|
272
|
+
ngx_add_timer(ev, delay);
|
273
|
+
|
274
|
+
lua_pushinteger(L, 1);
|
275
|
+
return 1;
|
276
|
+
|
277
|
+
nomem:
|
278
|
+
|
279
|
+
if (tctx && tctx->pool) {
|
280
|
+
ngx_destroy_pool(tctx->pool);
|
281
|
+
}
|
282
|
+
|
283
|
+
if (ev) {
|
284
|
+
ngx_free(ev);
|
285
|
+
}
|
286
|
+
|
287
|
+
lua_pushlightuserdata(L, &ngx_http_lua_coroutines_key);
|
288
|
+
lua_rawget(L, LUA_REGISTRYINDEX);
|
289
|
+
luaL_unref(L, -1, co_ref);
|
290
|
+
|
291
|
+
return luaL_error(L, "no memory");
|
292
|
+
}
|
293
|
+
|
294
|
+
|
295
|
+
static void
|
296
|
+
ngx_http_lua_timer_handler(ngx_event_t *ev)
|
297
|
+
{
|
298
|
+
int n;
|
299
|
+
lua_State *L;
|
300
|
+
ngx_int_t rc;
|
301
|
+
ngx_connection_t *c = NULL;
|
302
|
+
ngx_http_request_t *r = NULL;
|
303
|
+
ngx_http_lua_ctx_t *ctx;
|
304
|
+
ngx_http_cleanup_t *cln;
|
305
|
+
ngx_pool_cleanup_t *pcln;
|
306
|
+
|
307
|
+
ngx_http_lua_timer_ctx_t tctx;
|
308
|
+
ngx_http_lua_main_conf_t *lmcf;
|
309
|
+
ngx_http_core_loc_conf_t *clcf;
|
310
|
+
|
311
|
+
ngx_log_debug0(NGX_LOG_DEBUG_HTTP, ngx_cycle->log, 0,
|
312
|
+
"lua ngx.timer expired");
|
313
|
+
|
314
|
+
ngx_memcpy(&tctx, ev->data, sizeof(ngx_http_lua_timer_ctx_t));
|
315
|
+
ngx_free(ev);
|
316
|
+
ev = NULL;
|
317
|
+
|
318
|
+
lmcf = tctx.lmcf;
|
319
|
+
|
320
|
+
lmcf->pending_timers--;
|
321
|
+
|
322
|
+
if (lmcf->running_timers >= lmcf->max_running_timers) {
|
323
|
+
ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0,
|
324
|
+
"%i lua_max_running_timers are not enough",
|
325
|
+
lmcf->max_running_timers);
|
326
|
+
goto failed;
|
327
|
+
}
|
328
|
+
|
329
|
+
c = ngx_http_lua_create_fake_connection(tctx.pool);
|
330
|
+
if (c == NULL) {
|
331
|
+
goto failed;
|
332
|
+
}
|
333
|
+
|
334
|
+
c->log->handler = ngx_http_lua_log_timer_error;
|
335
|
+
c->log->data = c;
|
336
|
+
|
337
|
+
c->listening = tctx.listening;
|
338
|
+
c->addr_text = tctx.client_addr_text;
|
339
|
+
|
340
|
+
r = ngx_http_lua_create_fake_request(c);
|
341
|
+
if (r == NULL) {
|
342
|
+
goto failed;
|
343
|
+
}
|
344
|
+
|
345
|
+
r->main_conf = tctx.main_conf;
|
346
|
+
r->srv_conf = tctx.srv_conf;
|
347
|
+
r->loc_conf = tctx.loc_conf;
|
348
|
+
|
349
|
+
clcf = ngx_http_get_module_loc_conf(r, ngx_http_core_module);
|
350
|
+
|
351
|
+
#if defined(nginx_version) && nginx_version >= 1003014
|
352
|
+
|
353
|
+
ngx_http_set_connection_log(r->connection, clcf->error_log);
|
354
|
+
|
355
|
+
#else
|
356
|
+
|
357
|
+
c->log->file = clcf->error_log->file;
|
358
|
+
|
359
|
+
if (!(c->log->log_level & NGX_LOG_DEBUG_CONNECTION)) {
|
360
|
+
c->log->log_level = clcf->error_log->log_level;
|
361
|
+
}
|
362
|
+
|
363
|
+
#endif
|
364
|
+
|
365
|
+
dd("lmcf: %p", lmcf);
|
366
|
+
|
367
|
+
ctx = ngx_http_lua_create_ctx(r);
|
368
|
+
if (ctx == NULL) {
|
369
|
+
goto failed;
|
370
|
+
}
|
371
|
+
|
372
|
+
if (tctx.vm_state) {
|
373
|
+
ctx->vm_state = tctx.vm_state;
|
374
|
+
|
375
|
+
pcln = ngx_pool_cleanup_add(r->pool, 0);
|
376
|
+
if (pcln == NULL) {
|
377
|
+
goto failed;
|
378
|
+
}
|
379
|
+
|
380
|
+
pcln->handler = ngx_http_lua_cleanup_vm;
|
381
|
+
pcln->data = tctx.vm_state;
|
382
|
+
}
|
383
|
+
|
384
|
+
ctx->cur_co_ctx = &ctx->entry_co_ctx;
|
385
|
+
|
386
|
+
L = ngx_http_lua_get_lua_vm(r, ctx);
|
387
|
+
|
388
|
+
cln = ngx_http_cleanup_add(r, 0);
|
389
|
+
if (cln == NULL) {
|
390
|
+
goto failed;
|
391
|
+
}
|
392
|
+
|
393
|
+
cln->handler = ngx_http_lua_request_cleanup_handler;
|
394
|
+
cln->data = ctx;
|
395
|
+
ctx->cleanup = &cln->handler;
|
396
|
+
|
397
|
+
ctx->entered_content_phase = 1;
|
398
|
+
ctx->context = NGX_HTTP_LUA_CONTEXT_TIMER;
|
399
|
+
|
400
|
+
r->read_event_handler = ngx_http_block_reading;
|
401
|
+
|
402
|
+
ctx->cur_co_ctx->co_ref = tctx.co_ref;
|
403
|
+
ctx->cur_co_ctx->co = tctx.co;
|
404
|
+
ctx->cur_co_ctx->co_status = NGX_HTTP_LUA_CO_RUNNING;
|
405
|
+
|
406
|
+
dd("r connection: %p, log %p", r->connection, r->connection->log);
|
407
|
+
|
408
|
+
/* save the request in coroutine globals table */
|
409
|
+
ngx_http_lua_set_req(tctx.co, r);
|
410
|
+
|
411
|
+
lmcf->running_timers++;
|
412
|
+
|
413
|
+
lua_pushboolean(tctx.co, tctx.premature);
|
414
|
+
|
415
|
+
n = lua_gettop(tctx.co);
|
416
|
+
if (n > 2) {
|
417
|
+
lua_insert(tctx.co, 2);
|
418
|
+
}
|
419
|
+
|
420
|
+
#ifdef NGX_LUA_USE_ASSERT
|
421
|
+
ctx->cur_co_ctx->co_top = 1;
|
422
|
+
#endif
|
423
|
+
|
424
|
+
rc = ngx_http_lua_run_thread(L, r, ctx, n - 1);
|
425
|
+
|
426
|
+
dd("timer lua run thread: %d", (int) rc);
|
427
|
+
|
428
|
+
if (rc == NGX_ERROR || rc >= NGX_OK) {
|
429
|
+
/* do nothing */
|
430
|
+
|
431
|
+
} else if (rc == NGX_AGAIN) {
|
432
|
+
rc = ngx_http_lua_content_run_posted_threads(L, r, ctx, 0);
|
433
|
+
|
434
|
+
} else if (rc == NGX_DONE) {
|
435
|
+
rc = ngx_http_lua_content_run_posted_threads(L, r, ctx, 1);
|
436
|
+
|
437
|
+
} else {
|
438
|
+
rc = NGX_OK;
|
439
|
+
}
|
440
|
+
|
441
|
+
ngx_http_lua_finalize_request(r, rc);
|
442
|
+
return;
|
443
|
+
|
444
|
+
failed:
|
445
|
+
|
446
|
+
if (tctx.co_ref && tctx.co) {
|
447
|
+
lua_pushlightuserdata(tctx.co, &ngx_http_lua_coroutines_key);
|
448
|
+
lua_rawget(tctx.co, LUA_REGISTRYINDEX);
|
449
|
+
luaL_unref(tctx.co, -1, tctx.co_ref);
|
450
|
+
lua_settop(tctx.co, 0);
|
451
|
+
}
|
452
|
+
|
453
|
+
if (tctx.vm_state) {
|
454
|
+
ngx_http_lua_cleanup_vm(tctx.vm_state);
|
455
|
+
}
|
456
|
+
|
457
|
+
if (c) {
|
458
|
+
ngx_http_lua_close_fake_connection(c);
|
459
|
+
|
460
|
+
} else if (tctx.pool) {
|
461
|
+
ngx_destroy_pool(tctx.pool);
|
462
|
+
}
|
463
|
+
}
|
464
|
+
|
465
|
+
|
466
|
+
static u_char *
|
467
|
+
ngx_http_lua_log_timer_error(ngx_log_t *log, u_char *buf, size_t len)
|
468
|
+
{
|
469
|
+
u_char *p;
|
470
|
+
ngx_connection_t *c;
|
471
|
+
|
472
|
+
if (log->action) {
|
473
|
+
p = ngx_snprintf(buf, len, " while %s", log->action);
|
474
|
+
len -= p - buf;
|
475
|
+
buf = p;
|
476
|
+
}
|
477
|
+
|
478
|
+
c = log->data;
|
479
|
+
|
480
|
+
dd("ctx = %p", c);
|
481
|
+
|
482
|
+
p = ngx_snprintf(buf, len, ", context: ngx.timer");
|
483
|
+
len -= p - buf;
|
484
|
+
buf = p;
|
485
|
+
|
486
|
+
if (c->addr_text.len) {
|
487
|
+
p = ngx_snprintf(buf, len, ", client: %V", &c->addr_text);
|
488
|
+
len -= p - buf;
|
489
|
+
buf = p;
|
490
|
+
}
|
491
|
+
|
492
|
+
if (c && c->listening && c->listening->addr_text.len) {
|
493
|
+
p = ngx_snprintf(buf, len, ", server: %V", &c->listening->addr_text);
|
494
|
+
/* len -= p - buf; */
|
495
|
+
buf = p;
|
496
|
+
}
|
497
|
+
|
498
|
+
return buf;
|
499
|
+
}
|
500
|
+
|
501
|
+
|
502
|
+
static void
|
503
|
+
ngx_http_lua_abort_pending_timers(ngx_event_t *ev)
|
504
|
+
{
|
505
|
+
ngx_int_t i, n;
|
506
|
+
ngx_event_t **events;
|
507
|
+
ngx_connection_t *c, *saved_c = NULL;
|
508
|
+
ngx_rbtree_node_t *cur, *prev, *next, *sentinel, *temp;
|
509
|
+
ngx_http_lua_timer_ctx_t *tctx;
|
510
|
+
ngx_http_lua_main_conf_t *lmcf;
|
511
|
+
|
512
|
+
ngx_log_debug0(NGX_LOG_DEBUG_HTTP, ngx_cycle->log, 0,
|
513
|
+
"lua abort pending timers");
|
514
|
+
|
515
|
+
c = ev->data;
|
516
|
+
lmcf = c->data;
|
517
|
+
|
518
|
+
dd("lua connection fd: %d", (int) c->fd);
|
519
|
+
|
520
|
+
if (!c->close) {
|
521
|
+
return;
|
522
|
+
}
|
523
|
+
|
524
|
+
c->read->closed = 1;
|
525
|
+
c->write->closed = 1;
|
526
|
+
|
527
|
+
/* we temporarily use a valid fd (0) to make ngx_free_connection happy */
|
528
|
+
|
529
|
+
c->fd = 0;
|
530
|
+
|
531
|
+
if (ngx_cycle->files) {
|
532
|
+
saved_c = ngx_cycle->files[0];
|
533
|
+
}
|
534
|
+
|
535
|
+
ngx_free_connection(c);
|
536
|
+
|
537
|
+
c->fd = (ngx_socket_t) -1;
|
538
|
+
|
539
|
+
if (ngx_cycle->files) {
|
540
|
+
ngx_cycle->files[0] = saved_c;
|
541
|
+
}
|
542
|
+
|
543
|
+
if (lmcf->pending_timers == 0) {
|
544
|
+
return;
|
545
|
+
}
|
546
|
+
|
547
|
+
/* expire pending timers immediately */
|
548
|
+
|
549
|
+
sentinel = ngx_event_timer_rbtree.sentinel;
|
550
|
+
|
551
|
+
cur = ngx_event_timer_rbtree.root;
|
552
|
+
|
553
|
+
/* XXX nginx does not guarentee the parent of root is meaningful,
|
554
|
+
* so we temporarily override it to simplify tree traversal. */
|
555
|
+
temp = cur->parent;
|
556
|
+
cur->parent = NULL;
|
557
|
+
|
558
|
+
prev = NULL;
|
559
|
+
|
560
|
+
events = ngx_pcalloc(ngx_cycle->pool,
|
561
|
+
lmcf->pending_timers * sizeof(ngx_event_t));
|
562
|
+
if (events == NULL) {
|
563
|
+
return;
|
564
|
+
}
|
565
|
+
|
566
|
+
n = 0;
|
567
|
+
|
568
|
+
dd("root: %p, root parent: %p, sentinel: %p", cur, cur->parent, sentinel);
|
569
|
+
|
570
|
+
while (n < lmcf->pending_timers) {
|
571
|
+
if (cur == sentinel || cur == NULL) {
|
572
|
+
ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0,
|
573
|
+
"lua pending timer counter got out of sync: %i",
|
574
|
+
lmcf->pending_timers);
|
575
|
+
break;
|
576
|
+
}
|
577
|
+
|
578
|
+
dd("prev: %p, cur: %p, cur parent: %p, cur left: %p, cur right: %p",
|
579
|
+
prev, cur, cur->parent, cur->left, cur->right);
|
580
|
+
|
581
|
+
if (prev == cur->parent) {
|
582
|
+
/* neither of the children has been accessed yet */
|
583
|
+
|
584
|
+
next = cur->left;
|
585
|
+
if (next == sentinel) {
|
586
|
+
ev = (ngx_event_t *)
|
587
|
+
((char *) cur - offsetof(ngx_event_t, timer));
|
588
|
+
|
589
|
+
if (ev->handler == ngx_http_lua_timer_handler) {
|
590
|
+
dd("found node: %p", cur);
|
591
|
+
events[n++] = ev;
|
592
|
+
}
|
593
|
+
|
594
|
+
next = (cur->right != sentinel) ? cur->right : cur->parent;
|
595
|
+
}
|
596
|
+
|
597
|
+
} else if (prev == cur->left) {
|
598
|
+
/* just accessed the left child */
|
599
|
+
|
600
|
+
ev = (ngx_event_t *)
|
601
|
+
((char *) cur - offsetof(ngx_event_t, timer));
|
602
|
+
|
603
|
+
if (ev->handler == ngx_http_lua_timer_handler) {
|
604
|
+
dd("found node 2: %p", cur);
|
605
|
+
events[n++] = ev;
|
606
|
+
}
|
607
|
+
|
608
|
+
next = (cur->right != sentinel) ? cur->right : cur->parent;
|
609
|
+
|
610
|
+
} else if (prev == cur->right) {
|
611
|
+
/* already accessed both children */
|
612
|
+
next = cur->parent;
|
613
|
+
|
614
|
+
} else {
|
615
|
+
/* not reacheable */
|
616
|
+
next = NULL;
|
617
|
+
}
|
618
|
+
|
619
|
+
prev = cur;
|
620
|
+
cur = next;
|
621
|
+
}
|
622
|
+
|
623
|
+
/* restore the old tree root's parent */
|
624
|
+
ngx_event_timer_rbtree.root->parent = temp;
|
625
|
+
|
626
|
+
ngx_log_debug1(NGX_LOG_DEBUG_HTTP, ngx_cycle->log, 0,
|
627
|
+
"lua found %i pending timers to be aborted prematurely",
|
628
|
+
n);
|
629
|
+
|
630
|
+
for (i = 0; i < n; i++) {
|
631
|
+
ev = events[i];
|
632
|
+
|
633
|
+
ngx_rbtree_delete(&ngx_event_timer_rbtree, &ev->timer);
|
634
|
+
|
635
|
+
#if (NGX_DEBUG)
|
636
|
+
ev->timer.left = NULL;
|
637
|
+
ev->timer.right = NULL;
|
638
|
+
ev->timer.parent = NULL;
|
639
|
+
#endif
|
640
|
+
|
641
|
+
ev->timer_set = 0;
|
642
|
+
|
643
|
+
ev->timedout = 1;
|
644
|
+
|
645
|
+
tctx = ev->data;
|
646
|
+
tctx->premature = 1;
|
647
|
+
|
648
|
+
dd("calling timer handler prematurely");
|
649
|
+
ev->handler(ev);
|
650
|
+
}
|
651
|
+
|
652
|
+
#if 0
|
653
|
+
if (pending_timers) {
|
654
|
+
ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, 0,
|
655
|
+
"lua pending timer counter got out of sync: %i",
|
656
|
+
pending_timers);
|
657
|
+
}
|
658
|
+
#endif
|
659
|
+
}
|
660
|
+
|
661
|
+
/* vi:set ft=c ts=4 sw=4 et fdm=marker: */
|