├── .gitmodules ├── CHANGES ├── CHANGES.ru ├── LICENSE ├── README ├── auto ├── cc │ ├── acc │ ├── bcc │ ├── ccc │ ├── clang │ ├── conf │ ├── gcc │ ├── icc │ ├── msvc │ ├── name │ ├── owc │ └── sunc ├── define ├── endianness ├── feature ├── have ├── have_headers ├── headers ├── include ├── init ├── install ├── lib │ ├── conf │ ├── geoip │ │ └── conf │ ├── google-perftools │ │ └── conf │ ├── libatomic │ │ ├── conf │ │ └── make │ ├── libgd │ │ └── conf │ ├── libxslt │ │ └── conf │ ├── make │ ├── openssl │ │ ├── conf │ │ ├── make │ │ ├── makefile.bcc │ │ └── makefile.msvc │ ├── pcre │ │ ├── conf │ │ ├── make │ │ ├── makefile.bcc │ │ ├── makefile.msvc │ │ └── makefile.owc │ ├── perl │ │ ├── conf │ │ └── make │ └── zlib │ │ ├── conf │ │ ├── make │ │ ├── makefile.bcc │ │ ├── makefile.msvc │ │ └── makefile.owc ├── make ├── module ├── modules ├── nohave ├── options ├── os │ ├── conf │ ├── darwin │ ├── freebsd │ ├── linux │ ├── solaris │ └── win32 ├── sources ├── stubs ├── summary ├── threads ├── types │ ├── sizeof │ ├── typedef │ ├── uintptr_t │ └── value └── unix ├── conf ├── fastcgi.conf ├── fastcgi_params ├── koi-utf ├── koi-win ├── mime.types ├── nginx.conf ├── scgi_params ├── uwsgi_params └── win-utf ├── configure ├── contrib ├── README ├── geo2nginx.pl ├── unicode2nginx │ ├── koi-utf │ ├── unicode-to-nginx.pl │ └── win-utf └── vim │ ├── ftdetect │ └── nginx.vim │ ├── ftplugin │ └── nginx.vim │ ├── indent │ └── nginx.vim │ └── syntax │ └── nginx.vim ├── debian ├── Dockerfile.amd64 ├── Dockerfile.i386 ├── README.Packaging ├── autoscripts │ ├── postinst-nginx │ ├── postrm-nginx │ └── prerm-nginx ├── changelog ├── compat ├── conf │ ├── fastcgi.conf │ ├── fastcgi_params │ ├── koi-utf │ ├── koi-win │ ├── mime.types │ ├── naxsi.rules │ ├── naxsi_core.rules │ ├── nginx.conf │ ├── proxy_params │ ├── scgi_params │ ├── sites-available │ │ └── default │ ├── snippets │ │ ├── fastcgi-php.conf │ │ └── snakeoil.conf │ ├── uwsgi_params │ └── win-utf ├── control ├── copyright ├── dh_nginx ├── gbp.conf ├── help │ ├── docs │ │ ├── fcgiwrap │ │ ├── php │ │ ├── support-irc │ │ └── upstream │ └── examples │ │ ├── drupal │ │ ├── http │ │ ├── mail │ │ ├── mailman │ │ ├── nginx.conf │ │ ├── nginx_modsite │ │ ├── virtual_hosts │ │ └── wordpress ├── libnginx-mod-http-auth-pam.nginx ├── libnginx-mod-http-geoip.nginx ├── libnginx-mod-http-image-filter.nginx ├── libnginx-mod-http-lua.nginx ├── libnginx-mod-http-ndk.nginx ├── libnginx-mod-http-perl.install ├── libnginx-mod-http-perl.lintian-overrides ├── libnginx-mod-http-perl.nginx ├── libnginx-mod-http-xslt-filter.nginx ├── libnginx-mod-mail.nginx ├── libnginx-mod-stream.nginx ├── libnginx-mod.conf │ ├── mod-http-auth-pam.conf │ ├── mod-http-geoip.conf │ ├── mod-http-image-filter.conf │ ├── mod-http-lua.conf │ ├── mod-http-ndk.conf │ ├── mod-http-perl.conf │ ├── mod-http-xslt-filter.conf │ ├── mod-mail.conf │ └── mod-stream.conf ├── libnginx-mod.nginx.skeleton ├── modules │ ├── README.Modules-versions │ └── nginx-auth-pam │ │ ├── ChangeLog │ │ ├── LICENSE │ │ ├── README.md │ │ ├── VERSION │ │ ├── config │ │ └── ngx_http_auth_pam_module.c ├── nginx-common.NEWS ├── nginx-common.README.Debian ├── nginx-common.config ├── nginx-common.dirs ├── nginx-common.install ├── nginx-common.links ├── nginx-common.lintian-overrides ├── nginx-common.manpages ├── nginx-common.nginx.default ├── nginx-common.nginx.init ├── nginx-common.nginx.logrotate ├── nginx-common.nginx.service ├── nginx-common.nginx.upstart ├── nginx-common.postinst ├── nginx-common.postrm ├── nginx-common.preinst ├── nginx-common.templates ├── nginx-doc.docs ├── nginx-doc.examples ├── nginx-extras.install ├── nginx-extras.lintian-overrides ├── nginx-extras.manpages ├── nginx-extras.postinst ├── nginx-extras.prerm ├── nginx-full.dirs ├── nginx-full.install ├── nginx-full.lintian-overrides ├── nginx-full.manpages ├── nginx-full.postinst ├── nginx-full.prerm ├── nginx-light.dirs ├── nginx-light.install ├── nginx-light.lintian-overrides ├── nginx-light.manpages ├── nginx-light.postinst ├── nginx-light.prerm ├── ngx-conf │ ├── README.rst │ ├── ngx-conf │ └── ngx-conf.1 ├── patches │ ├── 0002-Make-sure-signature-stays-the-same-in-all-nginx-buil.patch │ ├── perl-use-dpkg-buildflags.patch │ └── series ├── po │ ├── POTFILES.in │ └── templates.pot ├── rules ├── source │ ├── format │ └── include-binaries ├── tests │ ├── control │ ├── extras-module-deps │ ├── extras-simple │ ├── full-module-deps │ ├── full-simple │ ├── light-module-deps │ └── light-simple ├── ufw │ └── nginx ├── upstream │ └── signing-key.asc ├── vim │ └── nginx.yaml └── watch ├── html ├── 50x.html └── index.html ├── man └── nginx.8 └── src ├── core ├── nginx.c ├── nginx.h ├── ngx_array.c ├── ngx_array.h ├── ngx_buf.c ├── ngx_buf.h ├── ngx_conf_file.c ├── ngx_conf_file.h ├── ngx_config.h ├── ngx_connection.c ├── ngx_connection.h ├── ngx_core.h ├── ngx_cpuinfo.c ├── ngx_crc.h ├── ngx_crc32.c ├── ngx_crc32.h ├── ngx_crypt.c ├── ngx_crypt.h ├── ngx_cycle.c ├── ngx_cycle.h ├── ngx_file.c ├── ngx_file.h ├── ngx_hash.c ├── ngx_hash.h ├── ngx_inet.c ├── ngx_inet.h ├── ngx_list.c ├── ngx_list.h ├── ngx_log.c ├── ngx_log.h ├── ngx_md5.c ├── ngx_md5.h ├── ngx_module.c ├── ngx_module.h ├── ngx_murmurhash.c ├── ngx_murmurhash.h ├── ngx_open_file_cache.c ├── ngx_open_file_cache.h ├── ngx_output_chain.c ├── ngx_palloc.c ├── ngx_palloc.h ├── ngx_parse.c ├── ngx_parse.h ├── ngx_parse_time.c ├── ngx_parse_time.h ├── ngx_proxy_protocol.c ├── ngx_proxy_protocol.h ├── ngx_queue.c ├── ngx_queue.h ├── ngx_radix_tree.c ├── ngx_radix_tree.h ├── ngx_rbtree.c ├── ngx_rbtree.h ├── ngx_regex.c ├── ngx_regex.h ├── ngx_resolver.c ├── ngx_resolver.h ├── ngx_rwlock.c ├── ngx_rwlock.h ├── ngx_sha1.c ├── ngx_sha1.h ├── ngx_shmtx.c ├── ngx_shmtx.h ├── ngx_slab.c ├── ngx_slab.h ├── ngx_spinlock.c ├── ngx_string.c ├── ngx_string.h ├── ngx_syslog.c ├── ngx_syslog.h ├── ngx_thread_pool.c ├── ngx_thread_pool.h ├── ngx_times.c └── ngx_times.h ├── event ├── modules │ ├── ngx_devpoll_module.c │ ├── ngx_epoll_module.c │ ├── ngx_eventport_module.c │ ├── ngx_kqueue_module.c │ ├── ngx_poll_module.c │ ├── ngx_select_module.c │ └── ngx_win32_select_module.c ├── ngx_event.c ├── ngx_event.h ├── ngx_event_accept.c ├── ngx_event_connect.c ├── ngx_event_connect.h ├── ngx_event_openssl.c ├── ngx_event_openssl.h ├── ngx_event_openssl_stapling.c ├── ngx_event_pipe.c ├── ngx_event_pipe.h ├── ngx_event_posted.c ├── ngx_event_posted.h ├── ngx_event_timer.c └── ngx_event_timer.h ├── http ├── modules │ ├── ngx_http_access_module.c │ ├── ngx_http_addition_filter_module.c │ ├── ngx_http_auth_basic_module.c │ ├── ngx_http_auth_request_module.c │ ├── ngx_http_autoindex_module.c │ ├── ngx_http_browser_module.c │ ├── ngx_http_charset_filter_module.c │ ├── ngx_http_chunked_filter_module.c │ ├── ngx_http_dav_module.c │ ├── ngx_http_degradation_module.c │ ├── ngx_http_empty_gif_module.c │ ├── ngx_http_fastcgi_module.c │ ├── ngx_http_flv_module.c │ ├── ngx_http_geo_module.c │ ├── ngx_http_geoip_module.c │ ├── ngx_http_grpc_module.c │ ├── ngx_http_gunzip_filter_module.c │ ├── ngx_http_gzip_filter_module.c │ ├── ngx_http_gzip_static_module.c │ ├── ngx_http_headers_filter_module.c │ ├── ngx_http_image_filter_module.c │ ├── ngx_http_index_module.c │ ├── ngx_http_limit_conn_module.c │ ├── ngx_http_limit_req_module.c │ ├── ngx_http_log_module.c │ ├── ngx_http_map_module.c │ ├── ngx_http_memcached_module.c │ ├── ngx_http_mirror_module.c │ ├── ngx_http_mp4_module.c │ ├── ngx_http_not_modified_filter_module.c │ ├── ngx_http_proxy_module.c │ ├── ngx_http_random_index_module.c │ ├── ngx_http_range_filter_module.c │ ├── ngx_http_realip_module.c │ ├── ngx_http_referer_module.c │ ├── ngx_http_rewrite_module.c │ ├── ngx_http_scgi_module.c │ ├── ngx_http_secure_link_module.c │ ├── ngx_http_slice_filter_module.c │ ├── ngx_http_split_clients_module.c │ ├── ngx_http_ssi_filter_module.c │ ├── ngx_http_ssi_filter_module.h │ ├── ngx_http_ssl_module.c │ ├── ngx_http_ssl_module.h │ ├── ngx_http_static_module.c │ ├── ngx_http_stub_status_module.c │ ├── ngx_http_sub_filter_module.c │ ├── ngx_http_try_files_module.c │ ├── ngx_http_upstream_hash_module.c │ ├── ngx_http_upstream_ip_hash_module.c │ ├── ngx_http_upstream_keepalive_module.c │ ├── ngx_http_upstream_least_conn_module.c │ ├── ngx_http_upstream_zone_module.c │ ├── ngx_http_userid_filter_module.c │ ├── ngx_http_uwsgi_module.c │ ├── ngx_http_xslt_filter_module.c │ └── perl │ │ ├── Makefile.PL │ │ ├── nginx.pm │ │ ├── nginx.xs │ │ ├── ngx_http_perl_module.c │ │ ├── ngx_http_perl_module.h │ │ └── typemap ├── ngx_http.c ├── ngx_http.h ├── ngx_http_cache.h ├── ngx_http_config.h ├── ngx_http_copy_filter_module.c ├── ngx_http_core_module.c ├── ngx_http_core_module.h ├── ngx_http_file_cache.c ├── ngx_http_header_filter_module.c ├── ngx_http_parse.c ├── ngx_http_postpone_filter_module.c ├── ngx_http_request.c ├── ngx_http_request.h ├── ngx_http_request_body.c ├── ngx_http_script.c ├── ngx_http_script.h ├── ngx_http_special_response.c ├── ngx_http_upstream.c ├── ngx_http_upstream.h ├── ngx_http_upstream_round_robin.c ├── ngx_http_upstream_round_robin.h ├── ngx_http_variables.c ├── ngx_http_variables.h ├── ngx_http_write_filter_module.c └── v2 │ ├── ngx_http_v2.c │ ├── ngx_http_v2.h │ ├── ngx_http_v2_encode.c │ ├── ngx_http_v2_filter_module.c │ ├── ngx_http_v2_huff_decode.c │ ├── ngx_http_v2_huff_encode.c │ ├── ngx_http_v2_module.c │ ├── ngx_http_v2_module.h │ └── ngx_http_v2_table.c ├── mail ├── ngx_mail.c ├── ngx_mail.h ├── ngx_mail_auth_http_module.c ├── ngx_mail_core_module.c ├── ngx_mail_handler.c ├── ngx_mail_imap_handler.c ├── ngx_mail_imap_module.c ├── ngx_mail_imap_module.h ├── ngx_mail_parse.c ├── ngx_mail_pop3_handler.c ├── ngx_mail_pop3_module.c ├── ngx_mail_pop3_module.h ├── ngx_mail_proxy_module.c ├── ngx_mail_smtp_handler.c ├── ngx_mail_smtp_module.c ├── ngx_mail_smtp_module.h ├── ngx_mail_ssl_module.c └── ngx_mail_ssl_module.h ├── misc ├── ngx_cpp_test_module.cpp └── ngx_google_perftools_module.c ├── os └── unix │ ├── ngx_alloc.c │ ├── ngx_alloc.h │ ├── ngx_atomic.h │ ├── ngx_channel.c │ ├── ngx_channel.h │ ├── ngx_daemon.c │ ├── ngx_darwin.h │ ├── ngx_darwin_config.h │ ├── ngx_darwin_init.c │ ├── ngx_darwin_sendfile_chain.c │ ├── ngx_dlopen.c │ ├── ngx_dlopen.h │ ├── ngx_errno.c │ ├── ngx_errno.h │ ├── ngx_file_aio_read.c │ ├── ngx_files.c │ ├── ngx_files.h │ ├── ngx_freebsd.h │ ├── ngx_freebsd_config.h │ ├── ngx_freebsd_init.c │ ├── ngx_freebsd_sendfile_chain.c │ ├── ngx_gcc_atomic_amd64.h │ ├── ngx_gcc_atomic_ppc.h │ ├── ngx_gcc_atomic_sparc64.h │ ├── ngx_gcc_atomic_x86.h │ ├── ngx_linux.h │ ├── ngx_linux_aio_read.c │ ├── ngx_linux_config.h │ ├── ngx_linux_init.c │ ├── ngx_linux_sendfile_chain.c │ ├── ngx_os.h │ ├── ngx_posix_config.h │ ├── ngx_posix_init.c │ ├── ngx_process.c │ ├── ngx_process.h │ ├── ngx_process_cycle.c │ ├── ngx_process_cycle.h │ ├── ngx_readv_chain.c │ ├── ngx_recv.c │ ├── ngx_send.c │ ├── ngx_setaffinity.c │ ├── ngx_setaffinity.h │ ├── ngx_setproctitle.c │ ├── ngx_setproctitle.h │ ├── ngx_shmem.c │ ├── ngx_shmem.h │ ├── ngx_socket.c │ ├── ngx_socket.h │ ├── ngx_solaris.h │ ├── ngx_solaris_config.h │ ├── ngx_solaris_init.c │ ├── ngx_solaris_sendfilev_chain.c │ ├── ngx_sunpro_amd64.il │ ├── ngx_sunpro_atomic_sparc64.h │ ├── ngx_sunpro_sparc64.il │ ├── ngx_sunpro_x86.il │ ├── ngx_thread.h │ ├── ngx_thread_cond.c │ ├── ngx_thread_id.c │ ├── ngx_thread_mutex.c │ ├── ngx_time.c │ ├── ngx_time.h │ ├── ngx_udp_recv.c │ ├── ngx_udp_send.c │ ├── ngx_udp_sendmsg_chain.c │ ├── ngx_user.c │ ├── ngx_user.h │ └── ngx_writev_chain.c └── stream ├── ngx_stream.c ├── ngx_stream.h ├── ngx_stream_access_module.c ├── ngx_stream_core_module.c ├── ngx_stream_geo_module.c ├── ngx_stream_geoip_module.c ├── ngx_stream_handler.c ├── ngx_stream_limit_conn_module.c ├── ngx_stream_log_module.c ├── ngx_stream_map_module.c ├── ngx_stream_proxy_module.c ├── ngx_stream_realip_module.c ├── ngx_stream_return_module.c ├── ngx_stream_script.c ├── ngx_stream_script.h ├── ngx_stream_split_clients_module.c ├── ngx_stream_ssl_module.c ├── ngx_stream_ssl_module.h ├── ngx_stream_ssl_preread_module.c ├── ngx_stream_upstream.c ├── ngx_stream_upstream.h ├── ngx_stream_upstream_hash_module.c ├── ngx_stream_upstream_least_conn_module.c ├── ngx_stream_upstream_round_robin.c ├── ngx_stream_upstream_round_robin.h ├── ngx_stream_upstream_zone_module.c ├── ngx_stream_variables.c ├── ngx_stream_variables.h └── ngx_stream_write_filter_module.c /.gitmodules: -------------------------------------------------------------------------------- 1 | [submodule "debian/modules/nginx-cache-purge"] 2 | path = debian/modules/nginx-cache-purge 3 | url = git://github.com/FRiCKLE/ngx_cache_purge.git 4 | [submodule "debian/modules/headers-more-nginx-module"] 5 | path = debian/modules/headers-more-nginx-module 6 | url = git://github.com/agentzh/headers-more-nginx-module.git 7 | [submodule "debian/modules/nginx-development-kit"] 8 | path = debian/modules/nginx-development-kit 9 | url = git://github.com/simpl/ngx_devel_kit.git 10 | [submodule "debian/modules/nginx-echo"] 11 | path = debian/modules/nginx-echo 12 | url = git://github.com/agentzh/echo-nginx-module.git 13 | [submodule "debian/modules/nginx-lua"] 14 | path = debian/modules/nginx-lua 15 | url = git://github.com/chaoslawful/lua-nginx-module.git 16 | [submodule "debian/modules/nginx-upload-progress"] 17 | path = debian/modules/nginx-upload-progress 18 | url = git://github.com/masterzen/nginx-upload-progress-module.git 19 | [submodule "debian/modules/nginx-push-stream-module"] 20 | path = debian/modules/nginx-push-stream-module 21 | url = git://github.com/wandenberg/nginx-push-stream-module.git 22 | [submodule "debian/modules/nginx-dav-ext-module"] 23 | path = debian/modules/nginx-dav-ext-module 24 | url = git://github.com/arut/nginx-dav-ext-module.git 25 | [submodule "debian/modules/ngx_http_substitutions_filter_module"] 26 | path = debian/modules/ngx_http_substitutions_filter_module 27 | url = git://github.com/yaoweibin/ngx_http_substitutions_filter_module.git 28 | [submodule "debian/modules/ngx-fancyindex"] 29 | path = debian/modules/ngx-fancyindex 30 | url = git://github.com/aperezdc/ngx-fancyindex.git 31 | [submodule "debian/modules/ngx_pagespeed"] 32 | path = debian/modules/ngx_pagespeed 33 | url = git://github.com/pagespeed/ngx_pagespeed.git 34 | [submodule "debian/modules/nginx-auth-ldap"] 35 | path = debian/modules/nginx-auth-ldap 36 | url = git://github.com/kvspb/nginx-auth-ldap.git 37 | [submodule "debian/modules/naxsi"] 38 | path = debian/modules/naxsi 39 | url = git://github.com/nbs-system/naxsi.git 40 | [submodule "debian/modules/nginx-rtmp-module"] 41 | path = debian/modules/nginx-rtmp-module 42 | url = git://github.com/arut/nginx-rtmp-module.git 43 | [submodule "debian/modules/nginx-upstream-fair"] 44 | path = debian/modules/nginx-upstream-fair 45 | url = git://github.com/itoffshore/nginx-upstream-fair.git 46 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | /* 2 | * Copyright (C) 2002-2018 Igor Sysoev 3 | * Copyright (C) 2011-2018 Nginx, Inc. 4 | * All rights reserved. 5 | * 6 | * Redistribution and use in source and binary forms, with or without 7 | * modification, are permitted provided that the following conditions 8 | * are met: 9 | * 1. Redistributions of source code must retain the above copyright 10 | * notice, this list of conditions and the following disclaimer. 11 | * 2. Redistributions in binary form must reproduce the above copyright 12 | * notice, this list of conditions and the following disclaimer in the 13 | * documentation and/or other materials provided with the distribution. 14 | * 15 | * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND 16 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 17 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 18 | * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE 19 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 20 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 21 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 22 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 23 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 24 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 25 | * SUCH DAMAGE. 26 | */ 27 | -------------------------------------------------------------------------------- /README: -------------------------------------------------------------------------------- 1 | 2 | Documentation is available at http://nginx.org 3 | 4 | -------------------------------------------------------------------------------- /auto/cc/acc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | # aCC: HP ANSI C++ B3910B A.03.55.02 7 | 8 | # C89 mode 9 | 10 | CFLAGS="$CFLAGS -Ae" 11 | CC_TEST_FLAGS="-Ae" 12 | 13 | PCRE_OPT="$PCRE_OPT -Ae" 14 | ZLIB_OPT="$ZLIB_OPT -Ae" 15 | -------------------------------------------------------------------------------- /auto/cc/bcc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | # Borland C++ 5.5 7 | 8 | # optimizations 9 | 10 | # maximize speed 11 | CFLAGS="$CFLAGS -O2" 12 | 13 | case $CPU in 14 | pentium) 15 | # optimize for Pentium and Athlon 16 | CPU_OPT="-5" 17 | ;; 18 | 19 | pentiumpro) 20 | # optimize for Pentium Pro, Pentium II and Pentium III 21 | CPU_OPT="-6" 22 | ;; 23 | esac 24 | 25 | # __stdcall 26 | #CPU_OPT="$CPU_OPT -ps" 27 | # __fastcall 28 | #CPU_OPT="$CPU_OPT -pr" 29 | 30 | CFLAGS="$CFLAGS $CPU_OPT" 31 | 32 | # multithreaded 33 | CFLAGS="$CFLAGS -tWM" 34 | 35 | # stop on warning 36 | CFLAGS="$CFLAGS -w!" 37 | 38 | # disable logo 39 | CFLAGS="$CFLAGS -q" 40 | 41 | 42 | # precompiled headers 43 | CORE_DEPS="$CORE_DEPS $NGX_OBJS/ngx_config.csm" 44 | NGX_PCH="$NGX_OBJS/ngx_config.csm" 45 | NGX_BUILD_PCH="-H=$NGX_OBJS/ngx_config.csm" 46 | NGX_USE_PCH="-Hu -H=$NGX_OBJS/ngx_config.csm" 47 | 48 | 49 | # Win32 GUI mode application 50 | #LINK="\$(CC) -laa" 51 | 52 | 53 | # the resource file 54 | NGX_RES="$NGX_OBJS/nginx.res" 55 | NGX_RCC="brcc32 -fo$NGX_OBJS/nginx.res \$(CORE_INCS) $NGX_WIN32_RC" 56 | # the pragma allows to link the resource file using bcc32 and 57 | # to avoid the direct ilink32 calling and the c0w32.obj's WinMain/main problem 58 | NGX_PRAGMA="#pragma resource \"$NGX_OBJS/nginx.res\"" 59 | 60 | 61 | ngx_include_opt="-I" 62 | ngx_objout="-o" 63 | ngx_binout="-e" 64 | ngx_objext="obj" 65 | 66 | ngx_long_start='@&&| 67 | ' 68 | ngx_long_end='|' 69 | 70 | ngx_regex_dirsep='\\' 71 | ngx_dirsep="\\" 72 | -------------------------------------------------------------------------------- /auto/cc/ccc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | # Compaq C V6.5-207 7 | 8 | ngx_include_opt="-I" 9 | 10 | # warnings 11 | 12 | CFLAGS="$CFLAGS -msg_enable level6 -msg_fatal level6" 13 | 14 | CFLAGS="$CFLAGS -msg_disable unknownmacro" 15 | CFLAGS="$CFLAGS -msg_disable unusedincl" 16 | CFLAGS="$CFLAGS -msg_disable unnecincl" 17 | CFLAGS="$CFLAGS -msg_disable nestincl" 18 | CFLAGS="$CFLAGS -msg_disable strctpadding" 19 | CFLAGS="$CFLAGS -msg_disable ansialiascast" 20 | CFLAGS="$CFLAGS -msg_disable inlinestoclsmod" 21 | CFLAGS="$CFLAGS -msg_disable cxxkeyword" 22 | CFLAGS="$CFLAGS -msg_disable longlongsufx" 23 | CFLAGS="$CFLAGS -msg_disable valuepres" 24 | 25 | # STUB 26 | CFLAGS="$CFLAGS -msg_disable truncintcast" 27 | CFLAGS="$CFLAGS -msg_disable trunclongcast" 28 | 29 | CFLAGS="$CFLAGS -msg_disable truncintasn" 30 | CFLAGS="$CFLAGS -msg_disable trunclongint" 31 | CFLAGS="$CFLAGS -msg_disable intconcastsgn" 32 | CFLAGS="$CFLAGS -msg_disable intconstsign" 33 | CFLAGS="$CFLAGS -msg_disable switchlong" 34 | CFLAGS="$CFLAGS -msg_disable subscrbounds2" 35 | 36 | CFLAGS="$CFLAGS -msg_disable hexoctunsign" 37 | 38 | CFLAGS="$CFLAGS -msg_disable ignorecallval" 39 | CFLAGS="$CFLAGS -msg_disable nonstandcast" 40 | CFLAGS="$CFLAGS -msg_disable embedcomment" 41 | CFLAGS="$CFLAGS -msg_disable unreachcode" 42 | CFLAGS="$CFLAGS -msg_disable questcompare2" 43 | CFLAGS="$CFLAGS -msg_disable unusedtop" 44 | CFLAGS="$CFLAGS -msg_disable unrefdecl" 45 | 46 | CFLAGS="$CFLAGS -msg_disable bitnotint" 47 | -------------------------------------------------------------------------------- /auto/cc/clang: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Nginx, Inc. 3 | 4 | 5 | # clang 6 | 7 | 8 | NGX_CLANG_VER=`$CC -v 2>&1 | grep 'version' 2>&1 \ 9 | | sed -e 's/^.* version \(.*\)/\1/'` 10 | 11 | echo " + clang version: $NGX_CLANG_VER" 12 | 13 | have=NGX_COMPILER value="\"clang $NGX_CLANG_VER\"" . auto/define 14 | 15 | 16 | CC_TEST_FLAGS="-pipe" 17 | 18 | 19 | # optimizations 20 | 21 | #NGX_CLANG_OPT="-O2" 22 | #NGX_CLANG_OPT="-Oz" 23 | NGX_CLANG_OPT="-O" 24 | 25 | case $CPU in 26 | pentium) 27 | # optimize for Pentium 28 | CPU_OPT="-march=pentium" 29 | NGX_CPU_CACHE_LINE=32 30 | ;; 31 | 32 | pentiumpro | pentium3) 33 | # optimize for Pentium Pro, Pentium II and Pentium III 34 | CPU_OPT="-march=pentiumpro" 35 | NGX_CPU_CACHE_LINE=32 36 | ;; 37 | 38 | pentium4) 39 | # optimize for Pentium 4 40 | CPU_OPT="-march=pentium4" 41 | NGX_CPU_CACHE_LINE=128 42 | ;; 43 | 44 | athlon) 45 | # optimize for Athlon 46 | CPU_OPT="-march=athlon" 47 | NGX_CPU_CACHE_LINE=64 48 | ;; 49 | 50 | opteron) 51 | # optimize for Opteron 52 | CPU_OPT="-march=opteron" 53 | NGX_CPU_CACHE_LINE=64 54 | ;; 55 | 56 | esac 57 | 58 | CC_AUX_FLAGS="$CC_AUX_FLAGS $CPU_OPT" 59 | 60 | 61 | CFLAGS="$CFLAGS -pipe $CPU_OPT" 62 | 63 | if [ ".$PCRE_OPT" = "." ]; then 64 | PCRE_OPT="-O2 -pipe $CPU_OPT" 65 | else 66 | PCRE_OPT="$PCRE_OPT -pipe" 67 | fi 68 | 69 | if [ ".$ZLIB_OPT" = "." ]; then 70 | ZLIB_OPT="-O2 -pipe $CPU_OPT" 71 | else 72 | ZLIB_OPT="$ZLIB_OPT -pipe" 73 | fi 74 | 75 | 76 | # warnings 77 | 78 | CFLAGS="$CFLAGS $NGX_CLANG_OPT -Wall -Wextra -Wpointer-arith" 79 | CFLAGS="$CFLAGS -Wconditional-uninitialized" 80 | #CFLAGS="$CFLAGS -Wmissing-prototypes" 81 | 82 | # we have a lot of unused function arguments 83 | CFLAGS="$CFLAGS -Wno-unused-parameter" 84 | 85 | # deprecated system OpenSSL library on OS X 86 | if [ "$NGX_SYSTEM" = "Darwin" ]; then 87 | CFLAGS="$CFLAGS -Wno-deprecated-declarations" 88 | fi 89 | 90 | # stop on warning 91 | CFLAGS="$CFLAGS -Werror" 92 | 93 | # debug 94 | CFLAGS="$CFLAGS -g" 95 | 96 | if [ ".$CPP" = "." ]; then 97 | CPP="$CC -E" 98 | fi 99 | -------------------------------------------------------------------------------- /auto/cc/name: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | if [ "$NGX_PLATFORM" != win32 ]; then 7 | 8 | ngx_feature="C compiler" 9 | ngx_feature_name= 10 | ngx_feature_run=yes 11 | ngx_feature_incs= 12 | ngx_feature_path= 13 | ngx_feature_libs= 14 | ngx_feature_test= 15 | . auto/feature 16 | 17 | if [ $ngx_found = no ]; then 18 | echo 19 | echo $0: error: C compiler $CC is not found 20 | echo 21 | exit 1 22 | fi 23 | 24 | fi 25 | 26 | 27 | if [ "$CC" = cl ]; then 28 | NGX_CC_NAME=msvc 29 | echo " + using Microsoft Visual C++ compiler" 30 | 31 | elif [ "$CC" = wcl386 ]; then 32 | NGX_CC_NAME=owc 33 | echo " + using Open Watcom C compiler" 34 | 35 | elif [ "$CC" = bcc32 ]; then 36 | NGX_CC_NAME=bcc 37 | echo " + using Borland C++ compiler" 38 | 39 | elif `$CC -V 2>&1 | grep '^Intel(R) C' >/dev/null 2>&1`; then 40 | NGX_CC_NAME=icc 41 | echo " + using Intel C++ compiler" 42 | 43 | elif `$CC -v 2>&1 | grep 'gcc version' >/dev/null 2>&1`; then 44 | NGX_CC_NAME=gcc 45 | echo " + using GNU C compiler" 46 | 47 | elif `$CC -v 2>&1 | grep 'clang version' >/dev/null 2>&1`; then 48 | NGX_CC_NAME=clang 49 | echo " + using Clang C compiler" 50 | 51 | elif `$CC -v 2>&1 | grep 'LLVM version' >/dev/null 2>&1`; then 52 | NGX_CC_NAME=clang 53 | echo " + using Clang C compiler" 54 | 55 | elif `$CC -V 2>&1 | grep 'Sun C' >/dev/null 2>&1`; then 56 | NGX_CC_NAME=sunc 57 | echo " + using Sun C compiler" 58 | 59 | elif `$CC -V 2>&1 | grep '^Compaq C' >/dev/null 2>&1`; then 60 | NGX_CC_NAME=ccc 61 | echo " + using Compaq C compiler" 62 | 63 | elif `$CC -V 2>&1 | grep '^aCC: ' >/dev/null 2>&1`; then 64 | NGX_CC_NAME=acc 65 | echo " + using HP aC++ compiler" 66 | 67 | else 68 | NGX_CC_NAME=unknown 69 | 70 | fi 71 | -------------------------------------------------------------------------------- /auto/define: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | cat << END >> $NGX_AUTO_CONFIG_H 7 | 8 | #ifndef $have 9 | #define $have $value 10 | #endif 11 | 12 | END 13 | -------------------------------------------------------------------------------- /auto/endianness: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | echo $ngx_n "checking for system byte ordering ...$ngx_c" 7 | 8 | cat << END >> $NGX_AUTOCONF_ERR 9 | 10 | ---------------------------------------- 11 | checking for system byte ordering 12 | 13 | END 14 | 15 | 16 | cat << END > $NGX_AUTOTEST.c 17 | 18 | int main(void) { 19 | int i = 0x11223344; 20 | char *p; 21 | 22 | p = (char *) &i; 23 | if (*p == 0x44) return 0; 24 | return 1; 25 | } 26 | 27 | END 28 | 29 | ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ 30 | -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT $ngx_feature_libs" 31 | 32 | eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" 33 | 34 | if [ -x $NGX_AUTOTEST ]; then 35 | if $NGX_AUTOTEST >/dev/null 2>&1; then 36 | echo " little endian" 37 | have=NGX_HAVE_LITTLE_ENDIAN . auto/have 38 | else 39 | echo " big endian" 40 | fi 41 | 42 | rm -rf $NGX_AUTOTEST* 43 | 44 | else 45 | rm -rf $NGX_AUTOTEST* 46 | 47 | echo 48 | echo "$0: error: cannot detect system byte ordering" 49 | exit 1 50 | fi 51 | -------------------------------------------------------------------------------- /auto/have: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | cat << END >> $NGX_AUTO_CONFIG_H 7 | 8 | #ifndef $have 9 | #define $have 1 10 | #endif 11 | 12 | END 13 | -------------------------------------------------------------------------------- /auto/have_headers: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | cat << END >> $NGX_AUTO_HEADERS_H 7 | 8 | #ifndef $have 9 | #define $have 1 10 | #endif 11 | 12 | END 13 | -------------------------------------------------------------------------------- /auto/headers: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | ngx_include="unistd.h"; . auto/include 7 | ngx_include="inttypes.h"; . auto/include 8 | ngx_include="limits.h"; . auto/include 9 | ngx_include="sys/filio.h"; . auto/include 10 | ngx_include="sys/param.h"; . auto/include 11 | ngx_include="sys/mount.h"; . auto/include 12 | ngx_include="sys/statvfs.h"; . auto/include 13 | ngx_include="crypt.h"; . auto/include 14 | -------------------------------------------------------------------------------- /auto/include: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | echo $ngx_n "checking for $ngx_include ...$ngx_c" 7 | 8 | cat << END >> $NGX_AUTOCONF_ERR 9 | 10 | ---------------------------------------- 11 | checking for $ngx_include 12 | 13 | END 14 | 15 | 16 | ngx_found=no 17 | 18 | cat << END > $NGX_AUTOTEST.c 19 | 20 | $NGX_INCLUDE_SYS_PARAM_H 21 | #include <$ngx_include> 22 | 23 | int main(void) { 24 | return 0; 25 | } 26 | 27 | END 28 | 29 | 30 | ngx_test="$CC -o $NGX_AUTOTEST $NGX_AUTOTEST.c" 31 | 32 | eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" 33 | 34 | if [ -x $NGX_AUTOTEST ]; then 35 | 36 | ngx_found=yes 37 | 38 | echo " found" 39 | 40 | ngx_name=`echo $ngx_include \ 41 | | tr abcdefghijklmnopqrstuvwxyz/. ABCDEFGHIJKLMNOPQRSTUVWXYZ__` 42 | 43 | 44 | have=NGX_HAVE_$ngx_name . auto/have_headers 45 | 46 | eval "NGX_INCLUDE_$ngx_name='#include <$ngx_include>'" 47 | 48 | else 49 | echo " not found" 50 | 51 | echo "----------" >> $NGX_AUTOCONF_ERR 52 | cat $NGX_AUTOTEST.c >> $NGX_AUTOCONF_ERR 53 | echo "----------" >> $NGX_AUTOCONF_ERR 54 | echo $ngx_test >> $NGX_AUTOCONF_ERR 55 | echo "----------" >> $NGX_AUTOCONF_ERR 56 | fi 57 | 58 | rm -rf $NGX_AUTOTEST* 59 | -------------------------------------------------------------------------------- /auto/init: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | NGX_MAKEFILE=$NGX_OBJS/Makefile 7 | NGX_MODULES_C=$NGX_OBJS/ngx_modules.c 8 | 9 | NGX_AUTO_HEADERS_H=$NGX_OBJS/ngx_auto_headers.h 10 | NGX_AUTO_CONFIG_H=$NGX_OBJS/ngx_auto_config.h 11 | 12 | NGX_AUTOTEST=$NGX_OBJS/autotest 13 | NGX_AUTOCONF_ERR=$NGX_OBJS/autoconf.err 14 | 15 | # STUBs 16 | NGX_ERR=$NGX_OBJS/autoconf.err 17 | MAKEFILE=$NGX_OBJS/Makefile 18 | 19 | 20 | NGX_PCH= 21 | NGX_USE_PCH= 22 | 23 | 24 | # check the echo's "-n" option and "\c" capability 25 | 26 | if echo "test\c" | grep c >/dev/null; then 27 | 28 | if echo -n test | grep n >/dev/null; then 29 | ngx_n= 30 | ngx_c= 31 | 32 | else 33 | ngx_n=-n 34 | ngx_c= 35 | fi 36 | 37 | else 38 | ngx_n= 39 | ngx_c='\c' 40 | fi 41 | 42 | 43 | # create Makefile 44 | 45 | cat << END > Makefile 46 | 47 | default: build 48 | 49 | clean: 50 | rm -rf Makefile $NGX_OBJS 51 | END 52 | -------------------------------------------------------------------------------- /auto/lib/conf: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | if [ $USE_PCRE = YES -o $PCRE != NONE ]; then 7 | . auto/lib/pcre/conf 8 | 9 | else 10 | if [ $USE_PCRE = DISABLED -a $HTTP = YES -a $HTTP_REWRITE = YES ]; then 11 | 12 | cat << END 13 | 14 | $0: error: the HTTP rewrite module requires the PCRE library. 15 | You can either disable the module by using --without-http_rewrite_module 16 | option or you have to enable the PCRE support. 17 | 18 | END 19 | exit 1 20 | fi 21 | fi 22 | 23 | 24 | if [ $USE_OPENSSL = YES ]; then 25 | . auto/lib/openssl/conf 26 | fi 27 | 28 | if [ $USE_ZLIB = YES ]; then 29 | . auto/lib/zlib/conf 30 | fi 31 | 32 | if [ $USE_LIBXSLT != NO ]; then 33 | . auto/lib/libxslt/conf 34 | fi 35 | 36 | if [ $USE_LIBGD != NO ]; then 37 | . auto/lib/libgd/conf 38 | fi 39 | 40 | if [ $USE_PERL != NO ]; then 41 | . auto/lib/perl/conf 42 | fi 43 | 44 | if [ $USE_GEOIP != NO ]; then 45 | . auto/lib/geoip/conf 46 | fi 47 | 48 | if [ $NGX_GOOGLE_PERFTOOLS = YES ]; then 49 | . auto/lib/google-perftools/conf 50 | fi 51 | 52 | if [ $NGX_LIBATOMIC != NO ]; then 53 | . auto/lib/libatomic/conf 54 | fi 55 | -------------------------------------------------------------------------------- /auto/lib/google-perftools/conf: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | ngx_feature="Google perftools" 7 | ngx_feature_name= 8 | ngx_feature_run=no 9 | ngx_feature_incs= 10 | ngx_feature_path= 11 | ngx_feature_libs="-lprofiler" 12 | ngx_feature_test="ProfilerStop()" 13 | . auto/feature 14 | 15 | 16 | if [ $ngx_found = no ]; then 17 | 18 | # FreeBSD port 19 | 20 | ngx_feature="Google perftools in /usr/local/" 21 | 22 | if [ $NGX_RPATH = YES ]; then 23 | ngx_feature_libs="-R/usr/local/lib -L/usr/local/lib -lprofiler" 24 | else 25 | ngx_feature_libs="-L/usr/local/lib -lprofiler" 26 | fi 27 | 28 | . auto/feature 29 | fi 30 | 31 | 32 | if [ $ngx_found = no ]; then 33 | 34 | # MacPorts 35 | 36 | ngx_feature="Google perftools in /opt/local/" 37 | 38 | if [ $NGX_RPATH = YES ]; then 39 | ngx_feature_libs="-R/opt/local/lib -L/opt/local/lib -lprofiler" 40 | else 41 | ngx_feature_libs="-L/opt/local/lib -lprofiler" 42 | fi 43 | 44 | . auto/feature 45 | fi 46 | 47 | 48 | if [ $ngx_found = yes ]; then 49 | CORE_LIBS="$CORE_LIBS $ngx_feature_libs" 50 | 51 | else 52 | 53 | cat << END 54 | 55 | $0: error: the Google perftools module requires the Google perftools 56 | library. You can either do not enable the module or install the library. 57 | 58 | END 59 | 60 | exit 1 61 | fi 62 | -------------------------------------------------------------------------------- /auto/lib/libatomic/conf: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | if [ $NGX_LIBATOMIC != YES ]; then 7 | 8 | have=NGX_HAVE_LIBATOMIC . auto/have 9 | CORE_INCS="$CORE_INCS $NGX_LIBATOMIC/src" 10 | LINK_DEPS="$LINK_DEPS $NGX_LIBATOMIC/src/libatomic_ops.a" 11 | CORE_LIBS="$CORE_LIBS $NGX_LIBATOMIC/src/libatomic_ops.a" 12 | 13 | else 14 | 15 | ngx_feature="atomic_ops library" 16 | ngx_feature_name=NGX_HAVE_LIBATOMIC 17 | ngx_feature_run=yes 18 | ngx_feature_incs="#define AO_REQUIRE_CAS 19 | #include " 20 | ngx_feature_path= 21 | ngx_feature_libs="-latomic_ops" 22 | ngx_feature_test="long n = 0; 23 | if (!AO_compare_and_swap(&n, 0, 1)) 24 | return 1; 25 | if (AO_fetch_and_add(&n, 1) != 1) 26 | return 1; 27 | if (n != 2) 28 | return 1; 29 | AO_nop();" 30 | . auto/feature 31 | 32 | if [ $ngx_found = yes ]; then 33 | CORE_LIBS="$CORE_LIBS $ngx_feature_libs" 34 | else 35 | 36 | cat << END 37 | 38 | $0: error: libatomic_ops library was not found. 39 | 40 | END 41 | exit 1 42 | fi 43 | fi 44 | -------------------------------------------------------------------------------- /auto/lib/libatomic/make: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | cat << END >> $NGX_MAKEFILE 7 | 8 | $NGX_LIBATOMIC/src/libatomic_ops.a: $NGX_LIBATOMIC/Makefile 9 | cd $NGX_LIBATOMIC && \$(MAKE) 10 | 11 | $NGX_LIBATOMIC/Makefile: $NGX_MAKEFILE 12 | cd $NGX_LIBATOMIC \\ 13 | && if [ -f Makefile ]; then \$(MAKE) distclean; fi \\ 14 | && ./configure 15 | 16 | END 17 | -------------------------------------------------------------------------------- /auto/lib/libgd/conf: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | ngx_feature="GD library" 7 | ngx_feature_name= 8 | ngx_feature_run=no 9 | ngx_feature_incs="#include " 10 | ngx_feature_path= 11 | ngx_feature_libs="-lgd" 12 | ngx_feature_test="gdImagePtr img = gdImageCreateFromGifPtr(1, NULL);" 13 | . auto/feature 14 | 15 | 16 | if [ $ngx_found = no ]; then 17 | 18 | # FreeBSD port 19 | 20 | ngx_feature="GD library in /usr/local/" 21 | ngx_feature_path="/usr/local/include" 22 | 23 | if [ $NGX_RPATH = YES ]; then 24 | ngx_feature_libs="-R/usr/local/lib -L/usr/local/lib -lgd" 25 | else 26 | ngx_feature_libs="-L/usr/local/lib -lgd" 27 | fi 28 | 29 | . auto/feature 30 | fi 31 | 32 | 33 | if [ $ngx_found = no ]; then 34 | 35 | # NetBSD port 36 | 37 | ngx_feature="GD library in /usr/pkg/" 38 | ngx_feature_path="/usr/pkg/include" 39 | 40 | if [ $NGX_RPATH = YES ]; then 41 | ngx_feature_libs="-R/usr/pkg/lib -L/usr/pkg/lib -lgd" 42 | else 43 | ngx_feature_libs="-L/usr/pkg/lib -lgd" 44 | fi 45 | 46 | . auto/feature 47 | fi 48 | 49 | 50 | if [ $ngx_found = no ]; then 51 | 52 | # MacPorts 53 | 54 | ngx_feature="GD library in /opt/local/" 55 | ngx_feature_path="/opt/local/include" 56 | 57 | if [ $NGX_RPATH = YES ]; then 58 | ngx_feature_libs="-R/opt/local/lib -L/opt/local/lib -lgd" 59 | else 60 | ngx_feature_libs="-L/opt/local/lib -lgd" 61 | fi 62 | 63 | . auto/feature 64 | fi 65 | 66 | 67 | if [ $ngx_found = yes ]; then 68 | 69 | CORE_INCS="$CORE_INCS $ngx_feature_path" 70 | 71 | if [ $USE_LIBGD = YES ]; then 72 | CORE_LIBS="$CORE_LIBS $ngx_feature_libs" 73 | fi 74 | 75 | NGX_LIB_LIBGD=$ngx_feature_libs 76 | 77 | ngx_feature="GD WebP support" 78 | ngx_feature_name="NGX_HAVE_GD_WEBP" 79 | ngx_feature_test="gdImagePtr img = gdImageCreateFromWebpPtr(1, NULL);" 80 | . auto/feature 81 | 82 | else 83 | 84 | cat << END 85 | 86 | $0: error: the HTTP image filter module requires the GD library. 87 | You can either do not enable the module or install the libraries. 88 | 89 | END 90 | 91 | exit 1 92 | 93 | fi 94 | -------------------------------------------------------------------------------- /auto/lib/make: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | if [ $PCRE != NONE -a $PCRE != NO -a $PCRE != YES ]; then 7 | . auto/lib/pcre/make 8 | fi 9 | 10 | if [ $OPENSSL != NONE -a $OPENSSL != NO -a $OPENSSL != YES ]; then 11 | . auto/lib/openssl/make 12 | fi 13 | 14 | if [ $ZLIB != NONE -a $ZLIB != NO -a $ZLIB != YES ]; then 15 | . auto/lib/zlib/make 16 | fi 17 | 18 | if [ $NGX_LIBATOMIC != NO -a $NGX_LIBATOMIC != YES ]; then 19 | . auto/lib/libatomic/make 20 | fi 21 | 22 | if [ $USE_PERL != NO ]; then 23 | . auto/lib/perl/make 24 | fi 25 | -------------------------------------------------------------------------------- /auto/lib/openssl/make: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | case "$CC" in 7 | 8 | cl) 9 | 10 | cat << END >> $NGX_MAKEFILE 11 | 12 | $OPENSSL/openssl/include/openssl/ssl.h: $NGX_MAKEFILE 13 | \$(MAKE) -f auto/lib/openssl/makefile.msvc \ 14 | OPENSSL="$OPENSSL" OPENSSL_OPT="$OPENSSL_OPT" 15 | 16 | END 17 | 18 | ;; 19 | 20 | bcc32) 21 | 22 | ngx_opt=`echo "-DOPENSSL=\"$OPENSSL\" -DOPENSSL_OPT=\"$OPENSSL_OPT\"" \ 23 | | sed -e "s/\//$ngx_regex_dirsep/g"` 24 | 25 | cat << END >> $NGX_MAKEFILE 26 | 27 | `echo "$OPENSSL\\openssl\\lib\\libeay32.lib: \ 28 | $OPENSSL\\openssl\\include\\openssl\\ssl.h" \ 29 | | sed -e "s/\//$ngx_regex_dirsep/g"` 30 | 31 | `echo "$OPENSSL\\openssl\\lib\\ssleay32.lib: \ 32 | $OPENSSL\\openssl\\include\\openssl\\ssl.h" \ 33 | | sed -e "s/\//$ngx_regex_dirsep/g"` 34 | 35 | `echo "$OPENSSL\\openssl\\include\\openssl\\ssl.h: $NGX_MAKEFILE" \ 36 | | sed -e "s/\//$ngx_regex_dirsep/g"` 37 | \$(MAKE) -f auto/lib/openssl/makefile.bcc $ngx_opt 38 | 39 | END 40 | 41 | ;; 42 | 43 | *) 44 | case $OPENSSL in 45 | /*) ngx_prefix="$OPENSSL/.openssl" ;; 46 | *) ngx_prefix="$PWD/$OPENSSL/.openssl" ;; 47 | esac 48 | 49 | cat << END >> $NGX_MAKEFILE 50 | 51 | $OPENSSL/.openssl/include/openssl/ssl.h: $NGX_MAKEFILE 52 | cd $OPENSSL \\ 53 | && if [ -f Makefile ]; then \$(MAKE) clean; fi \\ 54 | && ./config --prefix=$ngx_prefix no-shared no-threads $OPENSSL_OPT \\ 55 | && \$(MAKE) \\ 56 | && \$(MAKE) install_sw LIBDIR=lib 57 | 58 | END 59 | 60 | ;; 61 | 62 | esac 63 | -------------------------------------------------------------------------------- /auto/lib/openssl/makefile.bcc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | all: 7 | cd $(OPENSSL) 8 | 9 | perl Configure BC-32 no-shared --prefix=openssl $(OPENSSL_OPT) 10 | 11 | ms\do_nasm 12 | 13 | $(MAKE) -f ms\bcb.mak 14 | $(MAKE) -f ms\bcb.mak install 15 | 16 | # Borland's make does not expand "[ch]" in 17 | # copy "inc32\openssl\*.[ch]" "openssl\include\openssl" 18 | copy inc32\openssl\*.h openssl\include\openssl 19 | -------------------------------------------------------------------------------- /auto/lib/openssl/makefile.msvc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | all: 7 | cd $(OPENSSL) 8 | 9 | perl Configure VC-WIN32 no-shared \ 10 | --prefix="%cd%/openssl" \ 11 | --openssldir="%cd%/openssl/ssl" \ 12 | $(OPENSSL_OPT) 13 | 14 | if exist ms\do_ms.bat ( \ 15 | ms\do_ms \ 16 | && $(MAKE) -f ms\nt.mak \ 17 | && $(MAKE) -f ms\nt.mak install \ 18 | ) else ( \ 19 | $(MAKE) \ 20 | && $(MAKE) install_sw \ 21 | ) 22 | -------------------------------------------------------------------------------- /auto/lib/pcre/make: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | case "$NGX_CC_NAME" in 7 | 8 | msvc) 9 | ngx_makefile=makefile.msvc 10 | ngx_opt="CPU_OPT=\"$CPU_OPT\" LIBC=$LIBC" 11 | ngx_pcre="PCRE=\"$PCRE\"" 12 | ;; 13 | 14 | owc) 15 | ngx_makefile=makefile.owc 16 | ngx_opt="CPU_OPT=\"$CPU_OPT\"" 17 | ngx_pcre=`echo PCRE=\"$PCRE\" | sed -e "s/\//$ngx_regex_dirsep/g"` 18 | ;; 19 | 20 | bcc) 21 | ngx_makefile=makefile.bcc 22 | ngx_opt="-DCPU_OPT=\"$CPU_OPT\"" 23 | ngx_pcre=`echo \-DPCRE=\"$PCRE\" | sed -e "s/\//$ngx_regex_dirsep/g"` 24 | ;; 25 | 26 | *) 27 | ngx_makefile= 28 | ;; 29 | 30 | esac 31 | 32 | 33 | if [ -n "$ngx_makefile" ]; then 34 | 35 | cat << END >> $NGX_MAKEFILE 36 | 37 | `echo "$PCRE/pcre.lib: $PCRE/pcre.h $NGX_MAKEFILE" \ 38 | | sed -e "s/\//$ngx_regex_dirsep/g"` 39 | \$(MAKE) -f auto/lib/pcre/$ngx_makefile $ngx_pcre $ngx_opt 40 | 41 | `echo "$PCRE/pcre.h:" | sed -e "s/\//$ngx_regex_dirsep/g"` 42 | \$(MAKE) -f auto/lib/pcre/$ngx_makefile $ngx_pcre pcre.h 43 | 44 | END 45 | 46 | else 47 | 48 | cat << END >> $NGX_MAKEFILE 49 | 50 | $PCRE/pcre.h: $PCRE/Makefile 51 | 52 | $PCRE/Makefile: $NGX_MAKEFILE 53 | cd $PCRE \\ 54 | && if [ -f Makefile ]; then \$(MAKE) distclean; fi \\ 55 | && CC="\$(CC)" CFLAGS="$PCRE_OPT" \\ 56 | ./configure --disable-shared $PCRE_CONF_OPT 57 | 58 | $PCRE/.libs/libpcre.a: $PCRE/Makefile 59 | cd $PCRE \\ 60 | && \$(MAKE) libpcre.la 61 | 62 | END 63 | 64 | fi 65 | -------------------------------------------------------------------------------- /auto/lib/pcre/makefile.bcc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | CFLAGS = -q -O2 -tWM -w-8004 $(CPU_OPT) 7 | PCREFLAGS = -DHAVE_CONFIG_H -DPCRE_STATIC -DPOSIX_MALLOC_THRESHOLD=10 \ 8 | -DSUPPORT_PCRE8 -DHAVE_MEMMOVE 9 | 10 | 11 | pcre.lib: 12 | cd $(PCRE) 13 | 14 | bcc32 -c $(CFLAGS) -I. $(PCREFLAGS) pcre_*.c 15 | 16 | copy /y nul pcre.lst 17 | for %n in (*.obj) do @echo +%n ^^& >> pcre.lst 18 | echo + >> pcre.lst 19 | 20 | tlib pcre.lib @pcre.lst 21 | 22 | pcre.h: 23 | cd $(PCRE) 24 | 25 | copy /y pcre.h.generic pcre.h 26 | copy /y config.h.generic config.h 27 | copy /y pcre_chartables.c.dist pcre_chartables.c 28 | -------------------------------------------------------------------------------- /auto/lib/pcre/makefile.msvc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | CFLAGS = -O2 -Ob1 -Oi -Gs $(LIBC) $(CPU_OPT) 7 | PCREFLAGS = -DHAVE_CONFIG_H -DPCRE_STATIC -DPOSIX_MALLOC_THRESHOLD=10 \ 8 | -DSUPPORT_PCRE8 -DHAVE_MEMMOVE 9 | 10 | 11 | pcre.lib: 12 | cd $(PCRE) 13 | 14 | cl -nologo -c $(CFLAGS) -I . $(PCREFLAGS) pcre_*.c 15 | 16 | link -lib -out:pcre.lib -verbose:lib pcre_*.obj 17 | 18 | pcre.h: 19 | cd $(PCRE) 20 | 21 | copy /y pcre.h.generic pcre.h 22 | copy /y config.h.generic config.h 23 | copy /y pcre_chartables.c.dist pcre_chartables.c 24 | -------------------------------------------------------------------------------- /auto/lib/pcre/makefile.owc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | CFLAGS = -c -zq -bt=nt -ot -op -oi -oe -s -bm $(CPU_OPT) 7 | PCREFLAGS = -DHAVE_CONFIG_H -DPCRE_STATIC -DPOSIX_MALLOC_THRESHOLD=10 & 8 | -DSUPPORT_PCRE8 -DHAVE_MEMMOVE 9 | 10 | 11 | pcre.lib: 12 | cd $(PCRE) 13 | 14 | wcl386 $(CFLAGS) -i=. $(PCREFLAGS) pcre_*.c 15 | 16 | dir /b *.obj > pcre.lst 17 | 18 | wlib -n pcre.lib @pcre.lst 19 | 20 | pcre.h: 21 | cd $(PCRE) 22 | 23 | copy /y pcre.h.generic pcre.h 24 | copy /y config.h.generic config.h 25 | copy /y pcre_chartables.c.dist pcre_chartables.c 26 | -------------------------------------------------------------------------------- /auto/lib/perl/make: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | cat << END >> $NGX_MAKEFILE 7 | 8 | $NGX_OBJS/src/http/modules/perl/ngx_http_perl_module.o: \\ 9 | $NGX_OBJS/$ngx_perl_module 10 | 11 | $NGX_OBJS/$ngx_perl_module: \\ 12 | \$(CORE_DEPS) \$(HTTP_DEPS) \\ 13 | src/http/modules/perl/ngx_http_perl_module.h \\ 14 | $NGX_OBJS/src/http/modules/perl/Makefile 15 | cd $NGX_OBJS/src/http/modules/perl && \$(MAKE) 16 | 17 | rm -rf $NGX_OBJS/install_perl 18 | 19 | 20 | $NGX_OBJS/src/http/modules/perl/Makefile: \\ 21 | $NGX_AUTO_CONFIG_H \\ 22 | src/core/nginx.h \\ 23 | src/http/modules/perl/Makefile.PL \\ 24 | src/http/modules/perl/nginx.pm \\ 25 | src/http/modules/perl/nginx.xs \\ 26 | src/http/modules/perl/typemap 27 | grep 'define NGINX_VERSION' src/core/nginx.h \\ 28 | | sed -e 's/^.*"\(.*\)".*/\1/' > \\ 29 | $NGX_OBJS/src/http/modules/perl/version 30 | sed "s/%%VERSION%%/\`cat $NGX_OBJS/src/http/modules/perl/version\`/" \\ 31 | src/http/modules/perl/nginx.pm > \\ 32 | $NGX_OBJS/src/http/modules/perl/nginx.pm 33 | cp -p src/http/modules/perl/nginx.xs $NGX_OBJS/src/http/modules/perl/ 34 | cp -p src/http/modules/perl/typemap $NGX_OBJS/src/http/modules/perl/ 35 | cp -p src/http/modules/perl/Makefile.PL $NGX_OBJS/src/http/modules/perl/ 36 | 37 | cd $NGX_OBJS/src/http/modules/perl \\ 38 | && NGX_PM_CFLAGS="\$(NGX_PM_CFLAGS) -g $NGX_CC_OPT" \\ 39 | NGX_PM_LDFLAGS="$NGX_LD_OPT \$(NGX_PM_LDFLAGS)" \\ 40 | NGX_INCS="$CORE_INCS $NGX_OBJS $HTTP_INCS" \\ 41 | NGX_DEPS="\$(CORE_DEPS) \$(HTTP_DEPS)" \\ 42 | $NGX_PERL Makefile.PL \\ 43 | LIB=$NGX_PERL_MODULES \\ 44 | INSTALLSITEMAN3DIR=$NGX_PERL_MODULES_MAN 45 | 46 | END 47 | -------------------------------------------------------------------------------- /auto/lib/zlib/makefile.bcc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | CFLAGS = -q -O2 -tWM -w-8004 -w-8012 $(CPU_OPT) 7 | 8 | zlib.lib: 9 | cd $(ZLIB) 10 | 11 | bcc32 -c $(CFLAGS) adler32.c crc32.c deflate.c \ 12 | trees.c zutil.c compress.c \ 13 | inflate.c inffast.c inftrees.c 14 | 15 | tlib zlib.lib +adler32.obj +crc32.obj +deflate.obj \ 16 | +trees.obj +zutil.obj +compress.obj \ 17 | +inflate.obj +inffast.obj +inftrees.obj 18 | -------------------------------------------------------------------------------- /auto/lib/zlib/makefile.msvc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | CFLAGS = -nologo -O2 -Ob1 -Oi -Gs $(LIBC) $(CPU_OPT) 7 | 8 | zlib.lib: 9 | cd $(ZLIB) 10 | 11 | cl -c $(CFLAGS) adler32.c crc32.c deflate.c \ 12 | trees.c zutil.c compress.c \ 13 | inflate.c inffast.c inftrees.c 14 | 15 | link -lib -out:zlib.lib adler32.obj crc32.obj deflate.obj \ 16 | trees.obj zutil.obj compress.obj \ 17 | inflate.obj inffast.obj inftrees.obj 18 | -------------------------------------------------------------------------------- /auto/lib/zlib/makefile.owc: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | CFLAGS = -zq -bt=nt -ot -op -oi -oe -s -bm $(CPU_OPT) 7 | 8 | zlib.lib: 9 | cd $(ZLIB) 10 | 11 | wcl386 -c $(CFLAGS) adler32.c crc32.c deflate.c trees.c zutil.c & 12 | compress.c inflate.c inffast.c inftrees.c 13 | wlib -n zlib.lib adler32.obj crc32.obj deflate.obj trees.obj & 14 | zutil.obj compress.obj inflate.obj inffast.obj inftrees.obj 15 | -------------------------------------------------------------------------------- /auto/nohave: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | cat << END >> $NGX_AUTO_CONFIG_H 7 | 8 | #ifndef $have 9 | #define $have 0 10 | #endif 11 | 12 | END 13 | -------------------------------------------------------------------------------- /auto/os/solaris: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | have=NGX_SOLARIS . auto/have_headers 7 | 8 | CORE_INCS="$UNIX_INCS" 9 | CORE_DEPS="$UNIX_DEPS $SOLARIS_DEPS" 10 | CORE_SRCS="$UNIX_SRCS $SOLARIS_SRCS " 11 | CORE_LIBS="$CORE_LIBS -lsocket -lnsl" 12 | 13 | NGX_RPATH=YES 14 | 15 | # Solaris's make does not support a blank line between target and rules 16 | ngx_spacer= 17 | 18 | CC_AUX_FLAGS="$CC_AUX_FLAGS -D_FILE_OFFSET_BITS=64 -lsocket -lnsl" 19 | 20 | 21 | if [ $ZLIB_ASM != NO ]; then 22 | echo "$0: error: the --with-zlib-asm=CPU option is not supported" 23 | echo "on that platform" 24 | echo 25 | 26 | exit 1 27 | fi 28 | 29 | 30 | ngx_feature="sendfilev()" 31 | ngx_feature_name="NGX_HAVE_SENDFILE" 32 | ngx_feature_run=no 33 | ngx_feature_incs="#include " 34 | ngx_feature_path= 35 | ngx_feature_libs="-lsendfile" 36 | ngx_feature_test="int fd = 1; sendfilevec_t vec[1]; 37 | size_t sent; ssize_t n; 38 | n = sendfilev(fd, vec, 1, &sent); 39 | if (n == -1) return 1" 40 | . auto/feature 41 | 42 | 43 | if [ $ngx_found = yes ]; then 44 | CORE_SRCS="$CORE_SRCS $SOLARIS_SENDFILEV_SRCS" 45 | CORE_LIBS="$CORE_LIBS -lsendfile" 46 | fi 47 | 48 | 49 | ngx_feature="event ports" 50 | ngx_feature_name="NGX_HAVE_EVENTPORT" 51 | ngx_feature_run=no 52 | ngx_feature_incs="#include " 53 | ngx_feature_path= 54 | ngx_feature_libs= 55 | ngx_feature_test="(void) port_create()" 56 | . auto/feature 57 | 58 | if [ $ngx_found = yes ]; then 59 | CORE_SRCS="$CORE_SRCS $EVENTPORT_SRCS" 60 | EVENT_MODULES="$EVENT_MODULES $EVENTPORT_MODULE" 61 | fi 62 | -------------------------------------------------------------------------------- /auto/os/win32: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | have=NGX_WIN32 . auto/have_headers 7 | 8 | CORE_INCS="$WIN32_INCS" 9 | CORE_DEPS="$WIN32_DEPS" 10 | CORE_SRCS="$WIN32_SRCS $IOCP_SRCS" 11 | OS_CONFIG="$WIN32_CONFIG" 12 | NGX_ICONS="$NGX_WIN32_ICONS" 13 | SELECT_SRCS=$WIN32_SELECT_SRCS 14 | 15 | ngx_pic_opt= 16 | ngx_binext=".exe" 17 | 18 | case "$NGX_CC_NAME" in 19 | 20 | gcc) 21 | CORE_LIBS="$CORE_LIBS -ladvapi32 -lws2_32" 22 | MAIN_LINK="$MAIN_LINK -Wl,--export-all-symbols" 23 | MAIN_LINK="$MAIN_LINK -Wl,--out-implib=$NGX_OBJS/libnginx.a" 24 | MODULE_LINK="-shared -L $NGX_OBJS -lnginx" 25 | ;; 26 | 27 | *) 28 | CORE_LIBS="$CORE_LIBS advapi32.lib ws2_32.lib" 29 | ;; 30 | 31 | esac 32 | 33 | EVENT_MODULES="$EVENT_MODULES $IOCP_MODULE" 34 | EVENT_FOUND=YES 35 | 36 | if [ $EVENT_SELECT = NO ]; then 37 | CORE_SRCS="$CORE_SRCS $SELECT_SRCS" 38 | EVENT_MODULES="$EVENT_MODULES $SELECT_MODULE" 39 | fi 40 | 41 | have=NGX_HAVE_INET6 . auto/have 42 | 43 | have=NGX_HAVE_IOCP . auto/have 44 | -------------------------------------------------------------------------------- /auto/stubs: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | have=NGX_SUPPRESS_WARN . auto/have 7 | 8 | have=NGX_SMP . auto/have 9 | -------------------------------------------------------------------------------- /auto/summary: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | echo 7 | echo "Configuration summary" 8 | 9 | 10 | if [ $USE_THREADS = YES ]; then 11 | echo " + using threads" 12 | fi 13 | 14 | if [ $USE_PCRE = DISABLED ]; then 15 | echo " + PCRE library is disabled" 16 | 17 | else 18 | case $PCRE in 19 | YES) echo " + using system PCRE library" ;; 20 | NONE) echo " + PCRE library is not used" ;; 21 | *) echo " + using PCRE library: $PCRE" ;; 22 | esac 23 | fi 24 | 25 | case $OPENSSL in 26 | YES) echo " + using system OpenSSL library" ;; 27 | NONE) echo " + OpenSSL library is not used" ;; 28 | *) echo " + using OpenSSL library: $OPENSSL" ;; 29 | esac 30 | 31 | case $ZLIB in 32 | YES) echo " + using system zlib library" ;; 33 | NONE) echo " + zlib library is not used" ;; 34 | *) echo " + using zlib library: $ZLIB" ;; 35 | esac 36 | 37 | case $NGX_LIBATOMIC in 38 | YES) echo " + using system libatomic_ops library" ;; 39 | NO) ;; # not used 40 | *) echo " + using libatomic_ops library: $NGX_LIBATOMIC" ;; 41 | esac 42 | 43 | echo 44 | 45 | 46 | cat << END 47 | nginx path prefix: "$NGX_PREFIX" 48 | nginx binary file: "$NGX_SBIN_PATH" 49 | nginx modules path: "$NGX_MODULES_PATH" 50 | nginx configuration prefix: "$NGX_CONF_PREFIX" 51 | nginx configuration file: "$NGX_CONF_PATH" 52 | nginx pid file: "$NGX_PID_PATH" 53 | END 54 | 55 | if test -n "$NGX_ERROR_LOG_PATH"; then 56 | echo " nginx error log file: \"$NGX_ERROR_LOG_PATH\"" 57 | else 58 | echo " nginx logs errors to stderr" 59 | fi 60 | 61 | cat << END 62 | nginx http access log file: "$NGX_HTTP_LOG_PATH" 63 | nginx http client request body temporary files: "$NGX_HTTP_CLIENT_TEMP_PATH" 64 | END 65 | 66 | if [ $HTTP_PROXY = YES ]; then 67 | echo " nginx http proxy temporary files: \"$NGX_HTTP_PROXY_TEMP_PATH\"" 68 | fi 69 | 70 | if [ $HTTP_FASTCGI = YES ]; then 71 | echo " nginx http fastcgi temporary files: \"$NGX_HTTP_FASTCGI_TEMP_PATH\"" 72 | fi 73 | 74 | if [ $HTTP_UWSGI = YES ]; then 75 | echo " nginx http uwsgi temporary files: \"$NGX_HTTP_UWSGI_TEMP_PATH\"" 76 | fi 77 | 78 | if [ $HTTP_SCGI = YES ]; then 79 | echo " nginx http scgi temporary files: \"$NGX_HTTP_SCGI_TEMP_PATH\"" 80 | fi 81 | 82 | echo "$NGX_POST_CONF_MSG" 83 | -------------------------------------------------------------------------------- /auto/threads: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Nginx, Inc. 3 | 4 | 5 | if [ $USE_THREADS = YES ]; then 6 | 7 | if [ "$NGX_PLATFORM" = win32 ]; then 8 | cat << END 9 | 10 | $0: --with-threads is not supported on Windows 11 | 12 | END 13 | exit 1 14 | fi 15 | 16 | have=NGX_THREADS . auto/have 17 | CORE_DEPS="$CORE_DEPS $THREAD_POOL_DEPS" 18 | CORE_SRCS="$CORE_SRCS $THREAD_POOL_SRCS" 19 | CORE_LIBS="$CORE_LIBS -lpthread" 20 | NGX_LIBPTHREAD="-lpthread" 21 | fi 22 | -------------------------------------------------------------------------------- /auto/types/sizeof: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | echo $ngx_n "checking for $ngx_type size ...$ngx_c" 7 | 8 | cat << END >> $NGX_AUTOCONF_ERR 9 | 10 | ---------------------------------------- 11 | checking for $ngx_type size 12 | 13 | END 14 | 15 | ngx_size= 16 | 17 | cat << END > $NGX_AUTOTEST.c 18 | 19 | #include 20 | #include 21 | $NGX_INCLUDE_UNISTD_H 22 | #include 23 | #include 24 | #include 25 | $NGX_INCLUDE_INTTYPES_H 26 | $NGX_INCLUDE_AUTO_CONFIG_H 27 | 28 | int main(void) { 29 | printf("%d", (int) sizeof($ngx_type)); 30 | return 0; 31 | } 32 | 33 | END 34 | 35 | 36 | ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ 37 | -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT $ngx_feature_libs" 38 | 39 | eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" 40 | 41 | 42 | if [ -x $NGX_AUTOTEST ]; then 43 | ngx_size=`$NGX_AUTOTEST` 44 | echo " $ngx_size bytes" 45 | fi 46 | 47 | 48 | case $ngx_size in 49 | 4) 50 | ngx_max_value=2147483647 51 | ngx_max_len='(sizeof("-2147483648") - 1)' 52 | ;; 53 | 54 | 8) 55 | ngx_max_value=9223372036854775807LL 56 | ngx_max_len='(sizeof("-9223372036854775808") - 1)' 57 | ;; 58 | 59 | *) 60 | echo 61 | echo "$0: error: can not detect $ngx_type size" 62 | 63 | echo "----------" >> $NGX_AUTOCONF_ERR 64 | cat $NGX_AUTOTEST.c >> $NGX_AUTOCONF_ERR 65 | echo "----------" >> $NGX_AUTOCONF_ERR 66 | echo $ngx_test >> $NGX_AUTOCONF_ERR 67 | echo "----------" >> $NGX_AUTOCONF_ERR 68 | 69 | rm -rf $NGX_AUTOTEST* 70 | 71 | exit 1 72 | esac 73 | 74 | 75 | rm -rf $NGX_AUTOTEST* 76 | 77 | -------------------------------------------------------------------------------- /auto/types/typedef: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | echo $ngx_n "checking for $ngx_type ...$ngx_c" 7 | 8 | cat << END >> $NGX_AUTOCONF_ERR 9 | 10 | ---------------------------------------- 11 | checking for $ngx_type 12 | 13 | END 14 | 15 | ngx_found=no 16 | 17 | for ngx_try in $ngx_type $ngx_types 18 | do 19 | 20 | cat << END > $NGX_AUTOTEST.c 21 | 22 | #include 23 | #include 24 | #include 25 | #include 26 | #include 27 | #include 28 | $NGX_INCLUDE_INTTYPES_H 29 | 30 | int main(void) { 31 | $ngx_try i = 0; 32 | return (int) i; 33 | } 34 | 35 | END 36 | 37 | ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ 38 | -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT $ngx_feature_libs" 39 | 40 | eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" 41 | 42 | if [ -x $NGX_AUTOTEST ]; then 43 | if [ $ngx_try = $ngx_type ]; then 44 | echo " found" 45 | ngx_found=yes 46 | else 47 | echo ", $ngx_try used" 48 | ngx_found=$ngx_try 49 | fi 50 | fi 51 | 52 | if [ $ngx_found = no ]; then 53 | if [ $ngx_try = $ngx_type ]; then 54 | echo $ngx_n " $ngx_try not found$ngx_c" 55 | else 56 | echo $ngx_n ", $ngx_try not found$ngx_c" 57 | fi 58 | 59 | echo "----------" >> $NGX_AUTOCONF_ERR 60 | cat $NGX_AUTOTEST.c >> $NGX_AUTOCONF_ERR 61 | echo "----------" >> $NGX_AUTOCONF_ERR 62 | echo $ngx_test >> $NGX_AUTOCONF_ERR 63 | echo "----------" >> $NGX_AUTOCONF_ERR 64 | fi 65 | 66 | rm -rf $NGX_AUTOTEST* 67 | 68 | if [ $ngx_found != no ]; then 69 | break 70 | fi 71 | done 72 | 73 | if [ $ngx_found = no ]; then 74 | echo 75 | echo "$0: error: can not define $ngx_type" 76 | 77 | exit 1 78 | fi 79 | 80 | if [ $ngx_found != yes ]; then 81 | echo "typedef $ngx_found $ngx_type;" >> $NGX_AUTO_CONFIG_H 82 | fi 83 | -------------------------------------------------------------------------------- /auto/types/uintptr_t: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | echo $ngx_n "checking for uintptr_t ...$ngx_c" 7 | 8 | cat << END >> $NGX_AUTOCONF_ERR 9 | 10 | ---------------------------------------- 11 | checking for uintptr_t 12 | 13 | END 14 | 15 | found=no 16 | 17 | cat << END > $NGX_AUTOTEST.c 18 | 19 | #include 20 | $NGX_INCLUDE_INTTYPES_H 21 | 22 | int main(void) { 23 | uintptr_t i = 0; 24 | return (int) i; 25 | } 26 | 27 | END 28 | 29 | ngx_test="$CC $CC_TEST_FLAGS $CC_AUX_FLAGS \ 30 | -o $NGX_AUTOTEST $NGX_AUTOTEST.c $NGX_LD_OPT" 31 | 32 | eval "$ngx_test >> $NGX_AUTOCONF_ERR 2>&1" 33 | 34 | if [ -x $NGX_AUTOTEST ]; then 35 | echo " uintptr_t found" 36 | found=yes 37 | else 38 | echo $ngx_n " uintptr_t not found" $ngx_c 39 | fi 40 | 41 | rm -rf $NGX_AUTOTEST* 42 | 43 | 44 | if [ $found = no ]; then 45 | found="uint`expr 8 \* $ngx_ptr_size`_t" 46 | echo ", $found used" 47 | 48 | echo "typedef $found uintptr_t;" >> $NGX_AUTO_CONFIG_H 49 | echo "typedef $found intptr_t;" | sed -e 's/u//g' >> $NGX_AUTO_CONFIG_H 50 | fi 51 | -------------------------------------------------------------------------------- /auto/types/value: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | 6 | cat << END >> $NGX_AUTO_CONFIG_H 7 | 8 | #ifndef $ngx_param 9 | #define $ngx_param $ngx_value 10 | #endif 11 | 12 | END 13 | -------------------------------------------------------------------------------- /conf/fastcgi.conf: -------------------------------------------------------------------------------- 1 | 2 | fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 3 | fastcgi_param QUERY_STRING $query_string; 4 | fastcgi_param REQUEST_METHOD $request_method; 5 | fastcgi_param CONTENT_TYPE $content_type; 6 | fastcgi_param CONTENT_LENGTH $content_length; 7 | 8 | fastcgi_param SCRIPT_NAME $fastcgi_script_name; 9 | fastcgi_param REQUEST_URI $request_uri; 10 | fastcgi_param DOCUMENT_URI $document_uri; 11 | fastcgi_param DOCUMENT_ROOT $document_root; 12 | fastcgi_param SERVER_PROTOCOL $server_protocol; 13 | fastcgi_param REQUEST_SCHEME $scheme; 14 | fastcgi_param HTTPS $https if_not_empty; 15 | 16 | fastcgi_param GATEWAY_INTERFACE CGI/1.1; 17 | fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; 18 | 19 | fastcgi_param REMOTE_ADDR $remote_addr; 20 | fastcgi_param REMOTE_PORT $remote_port; 21 | fastcgi_param SERVER_ADDR $server_addr; 22 | fastcgi_param SERVER_PORT $server_port; 23 | fastcgi_param SERVER_NAME $server_name; 24 | 25 | # PHP only, required if PHP was built with --enable-force-cgi-redirect 26 | fastcgi_param REDIRECT_STATUS 200; 27 | -------------------------------------------------------------------------------- /conf/fastcgi_params: -------------------------------------------------------------------------------- 1 | 2 | fastcgi_param QUERY_STRING $query_string; 3 | fastcgi_param REQUEST_METHOD $request_method; 4 | fastcgi_param CONTENT_TYPE $content_type; 5 | fastcgi_param CONTENT_LENGTH $content_length; 6 | 7 | fastcgi_param SCRIPT_NAME $fastcgi_script_name; 8 | fastcgi_param REQUEST_URI $request_uri; 9 | fastcgi_param DOCUMENT_URI $document_uri; 10 | fastcgi_param DOCUMENT_ROOT $document_root; 11 | fastcgi_param SERVER_PROTOCOL $server_protocol; 12 | fastcgi_param REQUEST_SCHEME $scheme; 13 | fastcgi_param HTTPS $https if_not_empty; 14 | 15 | fastcgi_param GATEWAY_INTERFACE CGI/1.1; 16 | fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; 17 | 18 | fastcgi_param REMOTE_ADDR $remote_addr; 19 | fastcgi_param REMOTE_PORT $remote_port; 20 | fastcgi_param SERVER_ADDR $server_addr; 21 | fastcgi_param SERVER_PORT $server_port; 22 | fastcgi_param SERVER_NAME $server_name; 23 | 24 | # PHP only, required if PHP was built with --enable-force-cgi-redirect 25 | fastcgi_param REDIRECT_STATUS 200; 26 | -------------------------------------------------------------------------------- /conf/scgi_params: -------------------------------------------------------------------------------- 1 | 2 | scgi_param REQUEST_METHOD $request_method; 3 | scgi_param REQUEST_URI $request_uri; 4 | scgi_param QUERY_STRING $query_string; 5 | scgi_param CONTENT_TYPE $content_type; 6 | 7 | scgi_param DOCUMENT_URI $document_uri; 8 | scgi_param DOCUMENT_ROOT $document_root; 9 | scgi_param SCGI 1; 10 | scgi_param SERVER_PROTOCOL $server_protocol; 11 | scgi_param REQUEST_SCHEME $scheme; 12 | scgi_param HTTPS $https if_not_empty; 13 | 14 | scgi_param REMOTE_ADDR $remote_addr; 15 | scgi_param REMOTE_PORT $remote_port; 16 | scgi_param SERVER_PORT $server_port; 17 | scgi_param SERVER_NAME $server_name; 18 | -------------------------------------------------------------------------------- /conf/uwsgi_params: -------------------------------------------------------------------------------- 1 | 2 | uwsgi_param QUERY_STRING $query_string; 3 | uwsgi_param REQUEST_METHOD $request_method; 4 | uwsgi_param CONTENT_TYPE $content_type; 5 | uwsgi_param CONTENT_LENGTH $content_length; 6 | 7 | uwsgi_param REQUEST_URI $request_uri; 8 | uwsgi_param PATH_INFO $document_uri; 9 | uwsgi_param DOCUMENT_ROOT $document_root; 10 | uwsgi_param SERVER_PROTOCOL $server_protocol; 11 | uwsgi_param REQUEST_SCHEME $scheme; 12 | uwsgi_param HTTPS $https if_not_empty; 13 | 14 | uwsgi_param REMOTE_ADDR $remote_addr; 15 | uwsgi_param REMOTE_PORT $remote_port; 16 | uwsgi_param SERVER_PORT $server_port; 17 | uwsgi_param SERVER_NAME $server_name; 18 | -------------------------------------------------------------------------------- /contrib/README: -------------------------------------------------------------------------------- 1 | 2 | geo2nginx.pl by Andrei Nigmatulin 3 | 4 | The perl script to convert CSV geoip database ( free download 5 | at http://www.maxmind.com/app/geoip_country ) to format, suitable 6 | for use by the ngx_http_geo_module. 7 | 8 | 9 | unicode2nginx by Maxim Dounin 10 | 11 | The perl script to convert unicode mappings ( available 12 | at http://www.unicode.org/Public/MAPPINGS/ ) to the nginx 13 | configuration file format. 14 | Two generated full maps for windows-1251 and koi8-r. 15 | 16 | 17 | vim by Evan Miller 18 | 19 | Syntax highlighting of nginx configuration for vim, to be 20 | placed into ~/.vim/. 21 | 22 | -------------------------------------------------------------------------------- /contrib/geo2nginx.pl: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | # (c) Andrei Nigmatulin, 2005 4 | # 5 | # this script provided "as is", without any warranties. use it at your own risk. 6 | # 7 | # special thanx to Andrew Sitnikov for perl port 8 | # 9 | # this script converts CSV geoip database (free download at http://www.maxmind.com/app/geoip_country) 10 | # to format, suitable for use with nginx_http_geo module (http://sysoev.ru/nginx) 11 | # 12 | # for example, line with ip range 13 | # 14 | # "62.16.68.0","62.16.127.255","1041253376","1041268735","RU","Russian Federation" 15 | # 16 | # will be converted to four subnetworks: 17 | # 18 | # 62.16.68.0/22 RU; 19 | # 62.16.72.0/21 RU; 20 | # 62.16.80.0/20 RU; 21 | # 62.16.96.0/19 RU; 22 | 23 | 24 | use warnings; 25 | use strict; 26 | 27 | while( ){ 28 | if (/"[^"]+","[^"]+","([^"]+)","([^"]+)","([^"]+)"/){ 29 | print_subnets($1, $2, $3); 30 | } 31 | } 32 | 33 | sub print_subnets { 34 | my ($a1, $a2, $c) = @_; 35 | my $l; 36 | while ($a1 <= $a2) { 37 | for ($l = 0; ($a1 & (1 << $l)) == 0 && ($a1 + ((1 << ($l + 1)) - 1)) <= $a2; $l++){}; 38 | print long2ip($a1) . "/" . (32 - $l) . " " . $c . ";\n"; 39 | $a1 += (1 << $l); 40 | } 41 | } 42 | 43 | sub long2ip { 44 | my $ip = shift; 45 | 46 | my $str = 0; 47 | 48 | $str = ($ip & 255); 49 | 50 | $ip >>= 8; 51 | $str = ($ip & 255).".$str"; 52 | 53 | $ip >>= 8; 54 | $str = ($ip & 255).".$str"; 55 | 56 | $ip >>= 8; 57 | $str = ($ip & 255).".$str"; 58 | } 59 | -------------------------------------------------------------------------------- /contrib/unicode2nginx/unicode-to-nginx.pl: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | # Convert unicode mappings to nginx configuration file format. 4 | 5 | # You may find useful mappings in various places, including 6 | # unicode.org official site: 7 | # 8 | # http://www.unicode.org/Public/MAPPINGS/VENDORS/MICSFT/WINDOWS/CP1251.TXT 9 | # http://www.unicode.org/Public/MAPPINGS/VENDORS/MISC/KOI8-R.TXT 10 | 11 | # Needs perl 5.6 or later. 12 | 13 | # Written by Maxim Dounin, mdounin@mdounin.ru 14 | 15 | ############################################################################### 16 | 17 | require 5.006; 18 | 19 | while (<>) { 20 | # Skip comments and empty lines 21 | 22 | next if /^#/; 23 | next if /^\s*$/; 24 | chomp; 25 | 26 | # Convert mappings 27 | 28 | if (/^\s*0x(..)\s*0x(....)\s*(#.*)/) { 29 | # Mapping "#" 30 | my $cs_code = $1; 31 | my $un_code = $2; 32 | my $un_name = $3; 33 | 34 | # Produce UTF-8 sequence from character code; 35 | 36 | my $un_utf8 = join('', 37 | map { sprintf("%02X", $_) } 38 | unpack("U0C*", pack("U", hex($un_code))) 39 | ); 40 | 41 | print " $cs_code $un_utf8 ; $un_name\n"; 42 | 43 | } else { 44 | warn "Unrecognized line: '$_'"; 45 | } 46 | } 47 | 48 | ############################################################################### 49 | -------------------------------------------------------------------------------- /contrib/vim/ftdetect/nginx.vim: -------------------------------------------------------------------------------- 1 | au BufRead,BufNewFile *.nginx set ft=nginx 2 | au BufRead,BufNewFile */etc/nginx/* set ft=nginx 3 | au BufRead,BufNewFile */usr/local/nginx/conf/* set ft=nginx 4 | au BufRead,BufNewFile nginx.conf set ft=nginx 5 | -------------------------------------------------------------------------------- /contrib/vim/ftplugin/nginx.vim: -------------------------------------------------------------------------------- 1 | setlocal commentstring=#\ %s 2 | -------------------------------------------------------------------------------- /contrib/vim/indent/nginx.vim: -------------------------------------------------------------------------------- 1 | if exists("b:did_indent") 2 | finish 3 | endif 4 | let b:did_indent = 1 5 | 6 | setlocal indentexpr= 7 | 8 | " cindent actually works for nginx' simple file structure 9 | setlocal cindent 10 | " Just make sure that the comments are not reset as defs would be. 11 | setlocal cinkeys-=0# 12 | -------------------------------------------------------------------------------- /debian/Dockerfile.amd64: -------------------------------------------------------------------------------- 1 | # Usage: 2 | # docker build --pull -t build-jessie-amd64 -f debian/Dockerfile.amd64 . 3 | # docker run build-jessie-amd64 4 | # ID=$(docker ps -l -q) 5 | # docker cp $ID:/usr/src ~/Downloads/ 6 | # docker rm $ID 7 | 8 | FROM debian:jessie 9 | 10 | RUN export DEBIAN_FRONTEND noninteractive \ 11 | && apt-get update \ 12 | && apt-get dist-upgrade -y \ 13 | && apt-get install -y build-essential devscripts equivs libwww-perl 14 | 15 | ADD debian/control /root/ 16 | RUN mk-build-deps --install --tool 'apt-get -y' --remove /root/control && rm -f /root/control 17 | 18 | ADD . /usr/src/builddir 19 | WORKDIR /usr/src/builddir 20 | RUN find debian/ -name '\.git*' -exec rm -rf {} \; &>/dev/null \ 21 | && rm -r debian/modules/nginx-upload-progress/test/ \ 22 | && rm -r debian/modules/nginx-rtmp-module/test/ \ 23 | && uscan --download-current-version 24 | 25 | RUN dpkg-buildpackage 26 | 27 | RUN apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* /usr/src/builddir 28 | -------------------------------------------------------------------------------- /debian/Dockerfile.i386: -------------------------------------------------------------------------------- 1 | # Usage: 2 | # docker build --pull -t build-jessie-i386 -f debian/Dockerfile.i386 . 3 | # docker run build-jessie-i386 4 | # ID=$(docker ps -l -q) 5 | # docker cp $ID:/usr/src ~/Downloads/ 6 | # docker rm $ID 7 | 8 | FROM i386/debian:jessie 9 | 10 | RUN export DEBIAN_FRONTEND noninteractive \ 11 | && apt-get update \ 12 | && apt-get dist-upgrade -y \ 13 | && apt-get install -y build-essential devscripts equivs libwww-perl 14 | 15 | ADD debian/control /root/ 16 | RUN mk-build-deps --install --tool 'apt-get -y' --remove /root/control && rm -f /root/control 17 | 18 | ADD . /usr/src/builddir 19 | WORKDIR /usr/src/builddir 20 | RUN find debian/ -name '\.git*' -exec rm -rf {} \; &>/dev/null \ 21 | && rm -r debian/modules/nginx-upload-progress/test/ \ 22 | && rm -r debian/modules/nginx-rtmp-module/test/ \ 23 | && uscan --download-current-version 24 | 25 | RUN setarch linux32 dpkg-buildpackage 26 | 27 | RUN apt-get clean && rm -rf /var/lib/apt/lists/* /tmp/* /var/tmp/* /usr/src/builddir 28 | -------------------------------------------------------------------------------- /debian/autoscripts/postinst-nginx: -------------------------------------------------------------------------------- 1 | for confpair in #NAMES# ; do 2 | from=$(echo $confpair | cut -d: -f1) 3 | to=$(echo $confpair | cut -d: -f2) 4 | 5 | # Symlink on fresh installations 6 | if [ -z "$2" ]; then 7 | ln -sf /usr/share/nginx/modules-available/$from \ 8 | /etc/nginx/modules-enabled/$to 9 | fi 10 | done 11 | 12 | if [ -s /run/nginx.pid ]; then 13 | nginx -s reload 14 | fi 15 | -------------------------------------------------------------------------------- /debian/autoscripts/postrm-nginx: -------------------------------------------------------------------------------- 1 | if [ "$1" = "purge" ] ; then 2 | for confpair in #NAMES# ; do 3 | from=$(echo $confpair | cut -d: -f1) 4 | to=$(echo $confpair | cut -d: -f2) 5 | 6 | if [ -e /etc/nginx/modules-enabled/$to ]; then 7 | rm /etc/nginx/modules-enabled/$to 8 | fi 9 | done 10 | 11 | if [ -s /run/nginx.pid ]; then 12 | nginx -s reload 13 | fi 14 | fi 15 | -------------------------------------------------------------------------------- /debian/autoscripts/prerm-nginx: -------------------------------------------------------------------------------- 1 | if [ "$1" = "remove" ] || [ "$1" = "deconfigure" ] ; then 2 | for confpair in #NAMES# ; do 3 | from=$(echo $confpair | cut -d: -f1) 4 | to=$(echo $confpair | cut -d: -f2) 5 | 6 | if [ -e /etc/nginx/modules-enabled/$to ]; then 7 | rm /etc/nginx/modules-enabled/$to 8 | fi 9 | done 10 | 11 | if [ -s /run/nginx.pid ]; then 12 | nginx -s reload 13 | fi 14 | fi 15 | -------------------------------------------------------------------------------- /debian/compat: -------------------------------------------------------------------------------- 1 | 9 2 | -------------------------------------------------------------------------------- /debian/conf/fastcgi.conf: -------------------------------------------------------------------------------- 1 | 2 | fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 3 | fastcgi_param QUERY_STRING $query_string; 4 | fastcgi_param REQUEST_METHOD $request_method; 5 | fastcgi_param CONTENT_TYPE $content_type; 6 | fastcgi_param CONTENT_LENGTH $content_length; 7 | 8 | fastcgi_param SCRIPT_NAME $fastcgi_script_name; 9 | fastcgi_param REQUEST_URI $request_uri; 10 | fastcgi_param DOCUMENT_URI $document_uri; 11 | fastcgi_param DOCUMENT_ROOT $document_root; 12 | fastcgi_param SERVER_PROTOCOL $server_protocol; 13 | fastcgi_param REQUEST_SCHEME $scheme; 14 | fastcgi_param HTTPS $https if_not_empty; 15 | 16 | fastcgi_param GATEWAY_INTERFACE CGI/1.1; 17 | fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; 18 | 19 | fastcgi_param REMOTE_ADDR $remote_addr; 20 | fastcgi_param REMOTE_PORT $remote_port; 21 | fastcgi_param SERVER_ADDR $server_addr; 22 | fastcgi_param SERVER_PORT $server_port; 23 | fastcgi_param SERVER_NAME $server_name; 24 | 25 | # PHP only, required if PHP was built with --enable-force-cgi-redirect 26 | fastcgi_param REDIRECT_STATUS 200; 27 | -------------------------------------------------------------------------------- /debian/conf/fastcgi_params: -------------------------------------------------------------------------------- 1 | 2 | fastcgi_param QUERY_STRING $query_string; 3 | fastcgi_param REQUEST_METHOD $request_method; 4 | fastcgi_param CONTENT_TYPE $content_type; 5 | fastcgi_param CONTENT_LENGTH $content_length; 6 | 7 | fastcgi_param SCRIPT_NAME $fastcgi_script_name; 8 | fastcgi_param REQUEST_URI $request_uri; 9 | fastcgi_param DOCUMENT_URI $document_uri; 10 | fastcgi_param DOCUMENT_ROOT $document_root; 11 | fastcgi_param SERVER_PROTOCOL $server_protocol; 12 | fastcgi_param REQUEST_SCHEME $scheme; 13 | fastcgi_param HTTPS $https if_not_empty; 14 | 15 | fastcgi_param GATEWAY_INTERFACE CGI/1.1; 16 | fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; 17 | 18 | fastcgi_param REMOTE_ADDR $remote_addr; 19 | fastcgi_param REMOTE_PORT $remote_port; 20 | fastcgi_param SERVER_ADDR $server_addr; 21 | fastcgi_param SERVER_PORT $server_port; 22 | fastcgi_param SERVER_NAME $server_name; 23 | 24 | # PHP only, required if PHP was built with --enable-force-cgi-redirect 25 | fastcgi_param REDIRECT_STATUS 200; 26 | -------------------------------------------------------------------------------- /debian/conf/naxsi.rules: -------------------------------------------------------------------------------- 1 | # Sample rules file for default vhost. 2 | 3 | LearningMode; 4 | SecRulesEnabled; 5 | DeniedUrl "/50x.html"; 6 | 7 | ## check rules 8 | CheckRule "$SQL >= 8" BLOCK; 9 | CheckRule "$RFI >= 8" BLOCK; 10 | CheckRule "$TRAVERSAL >= 4" BLOCK; 11 | CheckRule "$EVADE >= 4" BLOCK; 12 | CheckRule "$XSS >= 8" BLOCK; 13 | -------------------------------------------------------------------------------- /debian/conf/nginx.conf: -------------------------------------------------------------------------------- 1 | user www-data; 2 | worker_processes auto; 3 | pid /run/nginx.pid; 4 | include /etc/nginx/modules-enabled/*.conf; 5 | 6 | events { 7 | worker_connections 768; 8 | # multi_accept on; 9 | } 10 | 11 | http { 12 | 13 | ## 14 | # Basic Settings 15 | ## 16 | 17 | sendfile on; 18 | tcp_nopush on; 19 | tcp_nodelay on; 20 | keepalive_timeout 65; 21 | types_hash_max_size 2048; 22 | # server_tokens off; 23 | 24 | # server_names_hash_bucket_size 64; 25 | # server_name_in_redirect off; 26 | 27 | include /etc/nginx/mime.types; 28 | default_type application/octet-stream; 29 | 30 | ## 31 | # SSL Settings 32 | ## 33 | 34 | ssl_protocols TLSv1 TLSv1.1 TLSv1.2; # Dropping SSLv3, ref: POODLE 35 | ssl_prefer_server_ciphers on; 36 | 37 | ## 38 | # Logging Settings 39 | ## 40 | 41 | access_log /var/log/nginx/access.log; 42 | error_log /var/log/nginx/error.log; 43 | 44 | ## 45 | # Gzip Settings 46 | ## 47 | 48 | gzip on; 49 | gzip_disable "msie6"; 50 | 51 | # gzip_vary on; 52 | # gzip_proxied any; 53 | # gzip_comp_level 6; 54 | # gzip_buffers 16 8k; 55 | # gzip_http_version 1.1; 56 | # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; 57 | 58 | ## 59 | # nginx-naxsi config 60 | ## 61 | # Uncomment it if you installed nginx-naxsi 62 | ## 63 | 64 | #include /etc/nginx/naxsi_core.rules; 65 | 66 | ## 67 | # Virtual Host Configs 68 | ## 69 | 70 | include /etc/nginx/conf.d/*.conf; 71 | include /etc/nginx/sites-enabled/*; 72 | } 73 | 74 | 75 | #mail { 76 | # # See sample authentication script at: 77 | # # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript 78 | # 79 | # # auth_http localhost/auth.php; 80 | # # pop3_capabilities "TOP" "USER"; 81 | # # imap_capabilities "IMAP4rev1" "UIDPLUS"; 82 | # 83 | # server { 84 | # listen localhost:110; 85 | # protocol pop3; 86 | # proxy on; 87 | # } 88 | # 89 | # server { 90 | # listen localhost:143; 91 | # protocol imap; 92 | # proxy on; 93 | # } 94 | #} 95 | -------------------------------------------------------------------------------- /debian/conf/proxy_params: -------------------------------------------------------------------------------- 1 | proxy_set_header Host $http_host; 2 | proxy_set_header X-Real-IP $remote_addr; 3 | proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; 4 | proxy_set_header X-Forwarded-Proto $scheme; 5 | -------------------------------------------------------------------------------- /debian/conf/scgi_params: -------------------------------------------------------------------------------- 1 | 2 | scgi_param REQUEST_METHOD $request_method; 3 | scgi_param REQUEST_URI $request_uri; 4 | scgi_param QUERY_STRING $query_string; 5 | scgi_param CONTENT_TYPE $content_type; 6 | 7 | scgi_param DOCUMENT_URI $document_uri; 8 | scgi_param DOCUMENT_ROOT $document_root; 9 | scgi_param SCGI 1; 10 | scgi_param SERVER_PROTOCOL $server_protocol; 11 | scgi_param REQUEST_SCHEME $scheme; 12 | scgi_param HTTPS $https if_not_empty; 13 | 14 | scgi_param REMOTE_ADDR $remote_addr; 15 | scgi_param REMOTE_PORT $remote_port; 16 | scgi_param SERVER_PORT $server_port; 17 | scgi_param SERVER_NAME $server_name; 18 | -------------------------------------------------------------------------------- /debian/conf/snippets/fastcgi-php.conf: -------------------------------------------------------------------------------- 1 | # regex to split $uri to $fastcgi_script_name and $fastcgi_path 2 | fastcgi_split_path_info ^(.+\.php)(/.+)$; 3 | 4 | # Check that the PHP script exists before passing it 5 | try_files $fastcgi_script_name =404; 6 | 7 | # Bypass the fact that try_files resets $fastcgi_path_info 8 | # see: http://trac.nginx.org/nginx/ticket/321 9 | set $path_info $fastcgi_path_info; 10 | fastcgi_param PATH_INFO $path_info; 11 | 12 | fastcgi_index index.php; 13 | include fastcgi.conf; 14 | -------------------------------------------------------------------------------- /debian/conf/snippets/snakeoil.conf: -------------------------------------------------------------------------------- 1 | # Self signed certificates generated by the ssl-cert package 2 | # Don't use them in a production server! 3 | 4 | ssl_certificate /etc/ssl/certs/ssl-cert-snakeoil.pem; 5 | ssl_certificate_key /etc/ssl/private/ssl-cert-snakeoil.key; 6 | -------------------------------------------------------------------------------- /debian/conf/uwsgi_params: -------------------------------------------------------------------------------- 1 | 2 | uwsgi_param QUERY_STRING $query_string; 3 | uwsgi_param REQUEST_METHOD $request_method; 4 | uwsgi_param CONTENT_TYPE $content_type; 5 | uwsgi_param CONTENT_LENGTH $content_length; 6 | 7 | uwsgi_param REQUEST_URI $request_uri; 8 | uwsgi_param PATH_INFO $document_uri; 9 | uwsgi_param DOCUMENT_ROOT $document_root; 10 | uwsgi_param SERVER_PROTOCOL $server_protocol; 11 | uwsgi_param REQUEST_SCHEME $scheme; 12 | uwsgi_param HTTPS $https if_not_empty; 13 | 14 | uwsgi_param REMOTE_ADDR $remote_addr; 15 | uwsgi_param REMOTE_PORT $remote_port; 16 | uwsgi_param SERVER_PORT $server_port; 17 | uwsgi_param SERVER_NAME $server_name; 18 | -------------------------------------------------------------------------------- /debian/gbp.conf: -------------------------------------------------------------------------------- 1 | [DEFAULT] 2 | debian-branch = jessie 3 | debian-tag = dotdeb/jessie-%(version)s 4 | upstream-branch = upstream 5 | upstream-tag = upstream/%(version)s 6 | pristine-tar = False 7 | 8 | [dch] 9 | meta = 1 10 | -------------------------------------------------------------------------------- /debian/help/docs/fcgiwrap: -------------------------------------------------------------------------------- 1 | ## 2 | # File: 3 | # fcgiwrap 4 | # Description: 5 | # The fcgiwrap tool allows a user to quickly and painlessly setup a socket 6 | # to handle CGI requests. This is useful for Python, Perl, etc. 7 | ## 8 | 9 | The easy way: 10 | apt-get install fcgiwrap 11 | 12 | The less-easy way: 13 | If your distribution does not provide it, the Nginx wiki describes the steps. 14 | http://wiki.nginx.org/Fcgiwrap 15 | -------------------------------------------------------------------------------- /debian/help/docs/support-irc: -------------------------------------------------------------------------------- 1 | ## 2 | # File: 3 | # support-irc 4 | # Description: 5 | # This file explains how to get support on IRC. 6 | ## 7 | 8 | Nginx has a moderately active IRC channel on Freenode. 9 | 10 | You can get there by: 11 | * Client 12 | Using an IRC Client and pointing it to: 13 | #nginx on irc.freenode.net 14 | * Browser 15 | Opening a web browser and pointing it to: 16 | http://webchat.freenode.net?channels=nginx 17 | 18 | Common sense is expected to be followed: 19 | * Code of Conduct 20 | http://www.ubuntu.com/community/conduct 21 | * IRC Etiquette 22 | http://www.ircbeginner.com/ircinfo/etiquette.html 23 | * Patience 24 | If somebody doesn't answer you right away, then wait. 25 | Even active IRC users have to run off sometimes. 26 | 27 | If you need more help with IRC The Linux Documentation Project has more information: 28 | http://tldp.org/HOWTO/IRC/beginners.html 29 | -------------------------------------------------------------------------------- /debian/help/docs/upstream: -------------------------------------------------------------------------------- 1 | ## 2 | # File: 3 | # upstream 4 | # Description: 5 | # This file describes how to use upstream blocks. 6 | ## 7 | 8 | An upstream block allows you to set a list of upstream locations for both 9 | proxy_pass and fastcgi_pass directives. 10 | 11 | Examples of upstream blocks: 12 | 13 | # PHP listening on the same server 14 | upstream php { 15 | # ip_hash ensures the same backend is used for client reconnects. 16 | ip_hash; 17 | # This assumes we have multiple PHP listeners on different known ports. 18 | server 127.0.0.1:9000; 19 | server 127.0.0.1:9001; 20 | server 127.0.0.1:9002; 21 | server 127.0.0.1:9003; 22 | # In addition to listening on ports, we can listen to unix sockets. 23 | server unix:/tmp/php-cgi.socket; 24 | } 25 | 26 | # Multiple backend Apache instances on separate servers 27 | upstream apache { 28 | # Adding a weight alters the chance the upstream server will be used. 29 | server apache1.domain.com weight 5; 30 | server apache2.domain.com; 31 | server apache3.domain.com; 32 | # Adding 'down' keeps the upstream from being used. Useful for downtime management. 33 | server apache4.domain.com down; 34 | server apache5.domain.com; 35 | } 36 | 37 | Using an upstream location: 38 | 39 | # Passing PHP to upstream 40 | location ~ \.php$ { 41 | fastcgi_split_path_info ^(.+\.php)(/.+)$; 42 | include fastcgi_params; 43 | fastcgi_pass php; 44 | } 45 | 46 | # Passing all requests for /cgi-bin/* to Apache upstreams. 47 | location /cgi-bin { 48 | proxy_pass apache; 49 | } 50 | 51 | For more information see http://wiki.nginx.org/HttpUpstreamModule 52 | -------------------------------------------------------------------------------- /debian/help/examples/http: -------------------------------------------------------------------------------- 1 | ## 2 | # File: 3 | # http 4 | # Description: 5 | # This file is meant to deliver a basic understanding of the http block. 6 | ## 7 | 8 | # All web configuration should be inside of the http block. 9 | # Most settings here are pretty self explanatory. 10 | # See http://wiki.nginx.org/HttpCoreModule for details. 11 | http { 12 | 13 | ## 14 | # Basic Settings 15 | ## 16 | 17 | sendfile on; 18 | tcp_nopush on; 19 | tcp_nodelay on; 20 | keepalive_timeout 65; 21 | # server_tokens off; 22 | 23 | # server_names_hash_bucket_size 64; 24 | # server_name_in_redirect off; 25 | 26 | include /etc/nginx/mime.types; 27 | default_type application/octet-stream; 28 | 29 | ## 30 | # Logging Settings 31 | ## 32 | 33 | access_log /var/log/nginx/access.log; 34 | error_log /var/log/nginx/error.log; 35 | 36 | ## 37 | # Gzip Settings 38 | ## 39 | 40 | gzip on; 41 | gzip_disable "msie6"; 42 | 43 | # gzip_vary on; 44 | # gzip_proxied any; 45 | # gzip_comp_level 6; 46 | # gzip_buffers 16 8k; 47 | # gzip_http_version 1.1; 48 | # gzip_types text/plain text/css application/json application/javascript text/xml application/xml application/xml+rss text/javascript; 49 | 50 | ## 51 | # Virtual Host Configs 52 | # These lines will include: 53 | # any files in /etc/nginx/sites-enabled/ 54 | # and any in /etc/nginx/conf.d/ ending with .conf 55 | ## 56 | 57 | include /etc/nginx/conf.d/*.conf; 58 | include /etc/nginx/sites-enabled/*; 59 | } 60 | -------------------------------------------------------------------------------- /debian/help/examples/mail: -------------------------------------------------------------------------------- 1 | ## 2 | # File: 3 | # mail 4 | # Description: 5 | # Provides a basic example of a mail proxy. 6 | ## 7 | 8 | # All mail proxy configuration should be inside of the mail block. 9 | # Most settings here are pretty self explanatory. 10 | # See http://wiki.nginx.org/MailCoreModule 11 | mail { 12 | # See sample authentication script at: 13 | # http://wiki.nginx.org/ImapAuthenticateWithApachePhpScript 14 | 15 | # auth_http localhost/auth.php; 16 | # pop3_capabilities "TOP" "USER"; 17 | # imap_capabilities "IMAP4rev1" "UIDPLUS"; 18 | 19 | server { 20 | listen localhost:110; 21 | protocol pop3; 22 | proxy on; 23 | } 24 | 25 | server { 26 | listen localhost:143; 27 | protocol imap; 28 | proxy on; 29 | } 30 | } 31 | -------------------------------------------------------------------------------- /debian/help/examples/mailman: -------------------------------------------------------------------------------- 1 | ## 2 | # File: 3 | # mailman 4 | # Description: 5 | # This file explains how to install MailMan and offers a nearly drop-in 6 | # model if MailMan was installed from Debian/Ubuntu repositories. 7 | ## 8 | 9 | server { 10 | 11 | # This is the URI of your website. You can specify multiple sites to be 12 | # served by the same Drupal installation. 13 | server_name lists.DOMAIN.TLD; 14 | 15 | # This is the default MailMan root directory. 16 | root /usr/lib/cgi-bin; 17 | 18 | # If the request is exactly the server_name, then we need to redirect 19 | # the browser to the listinfo page. Notice the = for an exact match. 20 | location = / { 21 | rewrite ^ /mailman/listinfo permanent; 22 | } 23 | 24 | # Any requests need to be rewritten to /mailman/. 25 | # This happens only if no other location block matches. 26 | location / { 27 | rewrite ^ /mailman$uri; 28 | } 29 | 30 | # If /mailmain/ was part of the request, then we need to let python 31 | # handle the request. 32 | location /mailman/ { 33 | fastcgi_split_path_info (^/mailman/[^/]*)(.*)$; 34 | include fastcgi_params; 35 | fastcgi_param GATEWAY_INTERFACE CGI/1.1; 36 | fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 37 | fastcgi_param PATH_INFO $fastcgi_path_info; 38 | fastcgi_param PATH_TRANSLATED $document_root$fastcgi_path_info; 39 | # fcgiwrap was used to create this socket. 40 | # See /usr/share/doc/nginx-doc/fcgiwrap 41 | fastcgi_pass unix:/tmp/cgi.socket; 42 | } 43 | 44 | # If a request was made for an image, we need to change the directory 45 | # that is beeing looked at. Nothing else is needed because the images 46 | # are static content. 47 | location /images/mailman { 48 | alias /var/lib/mailman/icons; 49 | } 50 | 51 | # If a request for /pipermail was made, we are still only dealing with 52 | # static content. The archives are at a different location and we need 53 | # to point at it. Because these are public, there's no issue in letting 54 | # them be browsed; autoindex is turned on to allow browsing. 55 | location /pipermail { 56 | alias /var/lib/mailman/archives/public; 57 | autoindex on; 58 | } 59 | } 60 | -------------------------------------------------------------------------------- /debian/help/examples/nginx.conf: -------------------------------------------------------------------------------- 1 | ## 2 | # File: 3 | # nginx.conf 4 | # Description: 5 | # Provides a very basic description of the use of nginx.conf. 6 | ## 7 | 8 | # For more options with more detailed descriptions: 9 | # See http://wiki.nginx.org/CoreModule 10 | 11 | # Sets user/group of worker processes. If group is not specified, group is assumed 12 | # to be the same as user. Syntax: user user [group] 13 | user www-data; 14 | 15 | # nginx has the ability to use more than one worker process 16 | worker_processes 4; 17 | 18 | # The pid-file. It can be used for the kill-command to send signals to nginx. 19 | # Example: To reload the config: kill -HUP `cat /var/log/nginx.pid` 20 | pid /var/run/nginx.pid; 21 | 22 | # See http://wiki.nginx.org/HttpEventsModule 23 | events { 24 | worker_connections 1024; 25 | # multi_accept on; 26 | } 27 | 28 | # See /usr/share/doc/nginx/examples/http 29 | http { 30 | } 31 | 32 | # See /usr/share/doc/nginx/examples/mail 33 | mail { 34 | } 35 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-auth-pam.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-geoip.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-image-filter.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-lua.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-ndk.nginx: -------------------------------------------------------------------------------- 1 | mod debian/build-extras/objs/ndk_http_module.so 2 | mod debian/libnginx-mod.conf/mod-http-ndk.conf 10 3 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-perl.install: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use Config; 4 | 5 | my $vendorarch = substr($Config{vendorarch}, 1); 6 | print "debian/build-extras/objs/src/http/modules/perl/blib/arch/auto/nginx/* $vendorarch/auto/nginx\n"; 7 | print "debian/build-extras/objs/src/http/modules/perl/blib/lib/nginx.pm $vendorarch\n"; 8 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-perl.lintian-overrides: -------------------------------------------------------------------------------- 1 | libnginx-mod-http-perl: wrong-section-according-to-package-name libnginx-mod-http-perl => perl 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-perl.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod-http-xslt-filter.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod-mail.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod-stream.nginx: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-http-auth-pam.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_http_auth_pam_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-http-geoip.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_http_geoip_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-http-image-filter.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_http_image_filter_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-http-lua.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_http_lua_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-http-ndk.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ndk_http_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-http-perl.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_http_perl_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-http-xslt-filter.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_http_xslt_filter_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-mail.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_mail_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.conf/mod-stream.conf: -------------------------------------------------------------------------------- 1 | load_module modules/ngx_stream_module.so; 2 | -------------------------------------------------------------------------------- /debian/libnginx-mod.nginx.skeleton: -------------------------------------------------------------------------------- 1 | #!/usr/bin/perl -w 2 | 3 | use File::Basename; 4 | 5 | # Guess module name 6 | $module = basename($0, '.nginx'); 7 | $module =~ s/^libnginx-mod-//; 8 | 9 | $modulepath = $module; 10 | $modulepath =~ s/-/_/g; 11 | 12 | print "mod debian/build-extras/objs/ngx_${modulepath}_module.so\n"; 13 | print "mod debian/libnginx-mod.conf/mod-${module}.conf\n"; 14 | -------------------------------------------------------------------------------- /debian/modules/README.Modules-versions: -------------------------------------------------------------------------------- 1 | README for Modules versions 2 | --------------------------- 3 | 4 | This file lists third party modules built with nginx in Debian, homepage and 5 | version and that are not git submodules. 6 | 7 | nginx-auth-pam 8 | Homepage: https://github.com/stogh/ngx_http_auth_pam_module 9 | Version: 1.5.1 10 | -------------------------------------------------------------------------------- /debian/modules/nginx-auth-pam/ChangeLog: -------------------------------------------------------------------------------- 1 | 2016-04-06 sto@iti.es 2 | 3 | * Version 1.5.1. 4 | * Fix building alongside other modules in nginx 1.9.11+ (patch provided by 5 | Graham Edgecombe ) 6 | 7 | 2016-03-23 sto@iti.es 8 | 9 | * Version 1.5. 10 | * Added support to build module dynamically (patch provided by Sjir 11 | Bagmeijer ). 12 | * Log PAM error and info messages to nginx log files (patch provided by 13 | André Caron ). 14 | 15 | 2015-02-04 sto@iti.es 16 | 17 | * Version 1.4. 18 | * Cleanup PAM responses on error, the module was not doing it, causing 19 | memory leaks (thanks to Michael Koziarski for the report). 20 | 21 | 2013-09-17 sto@iti.es 22 | 23 | * Version 1.3. 24 | * Added support to export HOST and REQUEST variables to the PAM ENVIRONMENT. 25 | Thanks to Ruben Jenster for the initial patch, his version is available 26 | from https://github.com/r10r/ngx_http_auth_pam_module; my version uses his 27 | implementation but only if the user sets the ``pam_auth_set_pam_env`` 28 | flag. 29 | * Fixed bug from http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=+721702 30 | (ngx_module_t commands array should end with a ngx_null_command); the bug 31 | was already fixed on the PAM_ENV patch, but I forgot about it until I went 32 | back to my svn repository to add the debian patch... better latter than 33 | never... ;) 34 | 35 | 2010-11-15 sto@iti.upv.es 36 | 37 | * Version 1.2. 38 | * Fixed possible memory leak when authentication fails, pam_end has to 39 | be called to free memory (thanks to Neil Chintomby). 40 | 41 | 2009-01-26 sto@iti.upv.es 42 | 43 | * Version 1.1. 44 | * Fixed ngx_log_debugX calls, no we use the correct X value on each 45 | call. 46 | 47 | 2008-09-17 sto@iti.upv.es 48 | 49 | * Initial version (1.0). 50 | -------------------------------------------------------------------------------- /debian/modules/nginx-auth-pam/LICENSE: -------------------------------------------------------------------------------- 1 | /* 2 | * Copyright (C) 2008-2016 Sergio Talens Oliag 3 | * 4 | * Redistribution and use in source and binary forms, with or without 5 | * modification, are permitted provided that the following conditions 6 | * are met: 7 | * 1. Redistributions of source code must retain the above copyright 8 | * notice, this list of conditions and the following disclaimer. 9 | * 2. Redistributions in binary form must reproduce the above copyright 10 | * notice, this list of conditions and the following disclaimer in the 11 | * documentation and/or other materials provided with the distribution. 12 | * 13 | * THIS SOFTWARE IS PROVIDED BY AUTHOR AND CONTRIBUTORS ``AS IS'' AND 14 | * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 15 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 16 | * ARE DISCLAIMED. IN NO EVENT SHALL AUTHOR OR CONTRIBUTORS BE LIABLE 17 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 18 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 19 | * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 20 | * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 21 | * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 22 | * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 23 | * SUCH DAMAGE. 24 | * 25 | */ 26 | -------------------------------------------------------------------------------- /debian/modules/nginx-auth-pam/VERSION: -------------------------------------------------------------------------------- 1 | 1.5 2 | -------------------------------------------------------------------------------- /debian/modules/nginx-auth-pam/config: -------------------------------------------------------------------------------- 1 | ngx_addon_name=ngx_http_auth_pam_module 2 | 3 | if test -n "$ngx_module_link"; then 4 | ngx_module_type=HTTP 5 | ngx_module_name=ngx_http_auth_pam_module 6 | ngx_module_incs= 7 | ngx_module_deps= 8 | ngx_module_srcs="$ngx_addon_dir/ngx_http_auth_pam_module.c" 9 | ngx_module_libs="-lpam" 10 | 11 | . auto/module 12 | else 13 | HTTP_MODULES="$HTTP_MODULES ngx_http_auth_pam_module" 14 | NGX_ADDON_SRCS="$NGX_ADDON_SRCS $ngx_addon_dir/ngx_http_auth_pam_module.c" 15 | CORE_LIBS="$CORE_LIBS -lpam" 16 | fi -------------------------------------------------------------------------------- /debian/nginx-common.README.Debian: -------------------------------------------------------------------------------- 1 | Noteworthy Changes Wheezy => Jessie 2 | =================================== 3 | 4 | * Disabled SSLv3 by default 5 | 6 | After POODLE we followed suit and disabled SSLv3 by default. 7 | 8 | * /var/log/nginx permissions 9 | 10 | /var/log/nginx/ is now not readable by default (www-data:adm 750), 11 | If you depend on that you can add a manual override with dpkg-statoverride. 12 | 13 | * New upgrade & rotate initscript commands 14 | 15 | You can now upgrade the nginx binary on the fly with /etc/init.d/nginx upgrade 16 | (Read more on http://nginx.org/en/docs/control.html#upgrade) 17 | 18 | * Synced configuration files are with upstream 19 | 20 | Unfortunately that might break existing configuration for some users, especially 21 | fastcgi scripts. /usr/share/doc/nginx-common/NEWS.Debian.gz contains some 22 | more information about the changes made. 23 | 24 | * Changed document root to /var/www/html 25 | 26 | The default document root has now changed to /var/www/html/. 27 | 28 | * Added a snippets directory 29 | 30 | A /etc/nginx/snippets has been added, it contains common configuration 31 | stangas. For now we ship a snakeoil.conf (self-signed ssl) and a simple 32 | fastcgi-php.conf. 33 | 34 | * Switched to graceful stop 35 | 36 | Both systemd and the initscript's stop function try to graceful stop 37 | nginx (SIGQUIT) before stopping it fast (SIGTERM). That allows nginx to 38 | serve connected clients before shutting down. 39 | 40 | * Dropped nginx-naxsi 41 | 42 | Packaging naxsi was not trivial and, unfortunately, none of the 43 | maintainers uses it. That's the reason nginx-naxsi was not in a good 44 | shape and we are not feeling comfortable to release and support it. 45 | 46 | -------------------------------------------------------------------------------- /debian/nginx-common.config: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | 3 | set -e 4 | 5 | . /usr/share/debconf/confmodule 6 | 7 | logdir="/var/log/nginx" 8 | 9 | log_symlinks_check() { 10 | # Skip new installations 11 | [ -z "$1" ] && return 12 | 13 | # Skip unaffected installations 14 | dpkg --compare-versions "$1" lt-nl "1.10.2-2~dotdeb+8.2" || return 0 15 | 16 | # Check for unsecure symlinks 17 | linked_logfiles="` find "$logdir" -type l -user www-data -name '*.log' `" 18 | 19 | # Skip if nothing is found 20 | [ -z "$linked_logfiles" ] && return 21 | 22 | db_subst nginx/log-symlinks logfiles $linked_logfiles 23 | db_input high nginx/log-symlinks || true 24 | db_go || true 25 | } 26 | 27 | case "$1" in 28 | configure|reconfigure) 29 | log_symlinks_check "$2" 30 | ;; 31 | *) 32 | ;; 33 | esac 34 | 35 | # vim: set ts=4 sts=4 sw=4 et sta ai : 36 | 37 | -------------------------------------------------------------------------------- /debian/nginx-common.dirs: -------------------------------------------------------------------------------- 1 | etc/nginx 2 | etc/nginx/sites-available 3 | etc/nginx/sites-enabled 4 | etc/nginx/modules-available 5 | etc/nginx/modules-enabled 6 | etc/nginx/conf.d 7 | etc/ufw/applications.d 8 | usr/share/nginx 9 | usr/share/vim/addons 10 | usr/share/vim/registry 11 | var/log/nginx 12 | var/lib/nginx 13 | var/www/html 14 | -------------------------------------------------------------------------------- /debian/nginx-common.install: -------------------------------------------------------------------------------- 1 | debian/conf/* etc/nginx 2 | debian/ufw/nginx etc/ufw/applications.d 3 | html/index.html usr/share/nginx/html/ 4 | debian/vim/nginx.yaml usr/share/vim/registry 5 | contrib/vim/* usr/share/vim/addons 6 | debian/ngx-conf/ngx-conf usr/sbin 7 | -------------------------------------------------------------------------------- /debian/nginx-common.links: -------------------------------------------------------------------------------- 1 | usr/lib/nginx/modules usr/share/nginx/modules 2 | -------------------------------------------------------------------------------- /debian/nginx-common.lintian-overrides: -------------------------------------------------------------------------------- 1 | # /var/www/html is the default document root 2 | nginx-common: dir-or-file-in-var-www var/www/html/ 3 | -------------------------------------------------------------------------------- /debian/nginx-common.manpages: -------------------------------------------------------------------------------- 1 | debian/ngx-conf/ngx-conf.1 2 | -------------------------------------------------------------------------------- /debian/nginx-common.nginx.default: -------------------------------------------------------------------------------- 1 | # Note: You may want to look at the following page before setting the ULIMIT. 2 | # http://wiki.nginx.org/CoreModule#worker_rlimit_nofile 3 | # Set the ulimit variable if you need defaults to change. 4 | # Example: ULIMIT="-n 4096" 5 | #ULIMIT="-n 4096" 6 | 7 | # Define the stop schedule for nginx 8 | # see the start-stop-daemon --retry documentation for more information 9 | # 10 | #STOP_SCHEDULE="QUIT/5/TERM/5/KILL/5" 11 | -------------------------------------------------------------------------------- /debian/nginx-common.nginx.logrotate: -------------------------------------------------------------------------------- 1 | /var/log/nginx/*.log { 2 | daily 3 | missingok 4 | rotate 14 5 | compress 6 | delaycompress 7 | notifempty 8 | create 0640 www-data adm 9 | sharedscripts 10 | prerotate 11 | if [ -d /etc/logrotate.d/httpd-prerotate ]; then \ 12 | run-parts /etc/logrotate.d/httpd-prerotate; \ 13 | fi \ 14 | endscript 15 | postrotate 16 | invoke-rc.d nginx rotate >/dev/null 2>&1 17 | endscript 18 | } 19 | -------------------------------------------------------------------------------- /debian/nginx-common.nginx.service: -------------------------------------------------------------------------------- 1 | # Stop dance for nginx 2 | # ======================= 3 | # 4 | # ExecStop sends SIGSTOP (graceful stop) to the nginx process. 5 | # If, after 5s (--retry QUIT/5) nginx is still running, systemd takes control 6 | # and sends SIGTERM (fast shutdown) to the main process. 7 | # After another 5s (TimeoutStopSec=5), and if nginx is alive, systemd sends 8 | # SIGKILL to all the remaining processes in the process group (KillMode=mixed). 9 | # 10 | # nginx signals reference doc: 11 | # http://nginx.org/en/docs/control.html 12 | # 13 | [Unit] 14 | Description=A high performance web server and a reverse proxy server 15 | Documentation=man:nginx(8) 16 | After=network.target 17 | 18 | [Service] 19 | Type=forking 20 | PIDFile=/run/nginx.pid 21 | ExecStartPre=/usr/sbin/nginx -t -q -g 'daemon on; master_process on;' 22 | ExecStart=/usr/sbin/nginx -g 'daemon on; master_process on;' 23 | ExecReload=/usr/sbin/nginx -g 'daemon on; master_process on;' -s reload 24 | ExecStop=-/sbin/start-stop-daemon --quiet --stop --retry QUIT/5 --pidfile /run/nginx.pid 25 | TimeoutStopSec=5 26 | KillMode=mixed 27 | 28 | [Install] 29 | WantedBy=multi-user.target 30 | -------------------------------------------------------------------------------- /debian/nginx-common.nginx.upstart: -------------------------------------------------------------------------------- 1 | description "nginx - small, powerful, scalable web/proxy server" 2 | 3 | start on filesystem and static-network-up 4 | stop on runlevel [016] 5 | 6 | expect fork 7 | respawn 8 | 9 | pre-start script 10 | [ -x /usr/sbin/nginx ] || { stop; exit 0; } 11 | /usr/sbin/nginx -q -t -g 'daemon on; master_process on;' || { stop; exit 0; } 12 | end script 13 | 14 | exec /usr/sbin/nginx -g 'daemon on; master_process on;' 15 | 16 | pre-stop exec /usr/sbin/nginx -s quit 17 | -------------------------------------------------------------------------------- /debian/nginx-common.postinst: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | . /usr/share/debconf/confmodule 5 | 6 | # Handle naxsi removal 7 | dpkg-maintscript-helper rm_conffile \ 8 | /etc/nginx/naxsi-ui.conf.1.4.1 1.6.2-2~ -- "$@" 9 | dpkg-maintscript-helper rm_conffile \ 10 | /etc/nginx/naxsi-ui.conf 1.6.2-2~ -- "$@" 11 | 12 | case "$1" in 13 | configure) 14 | logdir="/var/log/nginx" 15 | 16 | # Allow local admin to override 17 | if ! dpkg-statoverride --list "$logdir" >/dev/null; then 18 | chown root:adm $logdir 19 | chmod 0755 $logdir 20 | fi 21 | 22 | # Secure default logfiles on fresh installations 23 | if [ -z "$2" ]; then 24 | access_log="$logdir/access.log" 25 | error_log="$logdir/error.log" 26 | 27 | if [ ! -e "$access_log" ]; then 28 | touch "$access_log" 29 | chmod 640 "$access_log" 30 | chown www-data:adm "$access_log" 31 | fi 32 | 33 | if [ ! -e "$error_log" ]; then 34 | touch "$error_log" 35 | chmod 640 "$error_log" 36 | chown www-data:adm "$error_log" 37 | fi 38 | fi 39 | 40 | # If a symlink doesn't exist and can be created, then create it. 41 | if [ -z $2 ] && [ ! -e /etc/nginx/sites-enabled/default ] && 42 | [ -d /etc/nginx/sites-enabled ] && [ -d /etc/nginx/sites-available ]; then 43 | ln -s /etc/nginx/sites-available/default /etc/nginx/sites-enabled/default 44 | fi 45 | 46 | # Create a default index page when not already present. 47 | if [ ! -e /var/www/html/index.nginx-debian.html ]; then 48 | cp /usr/share/nginx/html/index.html /var/www/html/index.nginx-debian.html 49 | fi 50 | 51 | ;; 52 | 53 | abort-upgrade|abort-remove|abort-deconfigure) 54 | ;; 55 | 56 | *) 57 | echo "postinst called with unknown argument \`$1'" >&2 58 | exit 1 59 | ;; 60 | esac 61 | 62 | #DEBHELPER# 63 | 64 | exit 0 65 | -------------------------------------------------------------------------------- /debian/nginx-common.postrm: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | # Handle naxsi removal 5 | dpkg-maintscript-helper rm_conffile \ 6 | /etc/nginx/naxsi-ui.conf.1.4.1 1.6.2-2~ -- "$@" 7 | dpkg-maintscript-helper rm_conffile \ 8 | /etc/nginx/naxsi-ui.conf 1.6.2-2~ -- "$@" 9 | 10 | case "$1" in 11 | purge) 12 | rm -rf /var/lib/nginx /var/log/nginx /etc/nginx 13 | ;; 14 | 15 | upgrade|remove|failed-upgrade|abort-install|abort-upgrade|disappear) 16 | ;; 17 | 18 | *) 19 | echo "postrm called with unknown argument \`$1'" >&2 20 | exit 1 21 | ;; 22 | esac 23 | 24 | #DEBHELPER# 25 | 26 | exit 0 27 | -------------------------------------------------------------------------------- /debian/nginx-common.preinst: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | # Handle naxsi removal 5 | dpkg-maintscript-helper rm_conffile \ 6 | /etc/nginx/naxsi-ui.conf.1.4.1 1.6.2-2~ -- "$@" 7 | dpkg-maintscript-helper rm_conffile \ 8 | /etc/nginx/naxsi-ui.conf 1.6.2-2~ -- "$@" 9 | 10 | case "$1" in 11 | install) 12 | # If we are doing a fresh install, then these files are no longer needed. 13 | # They were around for a very short time and are best simply removed. 14 | rm -f /etc/logrotate.d/nginx-full 15 | rm -f /etc/logrotate.d/nginx-light 16 | rm -f /etc/logrotate.d/nginx-extras 17 | rm -f /etc/logrotate.d/nginx-common 18 | ;; 19 | 20 | upgrade) 21 | # If this is an upgrade, then they might have the UFW profile in the wrong spot. 22 | if [ -d /etc/ufw/applications.d/nginx ]; then 23 | rm -f /etc/ufw/applications.d/nginx/ufw.profile 24 | rmdir /etc/ufw/applications.d/nginx 25 | fi 26 | rm -f /etc/logrotate.d/nginx-full 27 | rm -f /etc/logrotate.d/nginx-light 28 | rm -f /etc/logrotate.d/nginx-extras 29 | rm -f /etc/logrotate.d/nginx-common 30 | ;; 31 | 32 | abort-upgrade) 33 | ;; 34 | 35 | *) 36 | echo "preinst called with unknown argument \`$1'" >&2 37 | exit 1 38 | ;; 39 | esac 40 | 41 | #DEBHELPER# 42 | 43 | exit 0 44 | -------------------------------------------------------------------------------- /debian/nginx-common.templates: -------------------------------------------------------------------------------- 1 | Template: nginx/log-symlinks 2 | Type: note 3 | _Description: Possible insecure nginx log files 4 | The following log files under /var/log/nginx directory are symlinks 5 | owned by www-data: 6 | . 7 | ${logfiles} 8 | . 9 | Since nginx 1.4.4-4 /var/log/nginx was owned by www-data. As a result 10 | www-data could symlink log files to sensitive locations, which in turn 11 | could lead to privilege escalation attacks. Although /var/log/nginx 12 | permissions are now fixed it is possible that such insecure links 13 | already exist. So, please make sure to check the above locations. 14 | -------------------------------------------------------------------------------- /debian/nginx-doc.docs: -------------------------------------------------------------------------------- 1 | README 2 | debian/help/docs/* 3 | -------------------------------------------------------------------------------- /debian/nginx-doc.examples: -------------------------------------------------------------------------------- 1 | debian/help/examples/* 2 | -------------------------------------------------------------------------------- /debian/nginx-extras.install: -------------------------------------------------------------------------------- 1 | debian/build-extras/objs/nginx usr/sbin 2 | -------------------------------------------------------------------------------- /debian/nginx-extras.lintian-overrides: -------------------------------------------------------------------------------- 1 | nginx-extras: spelling-error-in-binary usr/sbin/nginx tEH the 2 | -------------------------------------------------------------------------------- /debian/nginx-extras.manpages: -------------------------------------------------------------------------------- 1 | debian/build-extras/objs/nginx.8 2 | -------------------------------------------------------------------------------- /debian/nginx-extras.postinst: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | case "$1" in 5 | abort-upgrade|abort-remove|abort-deconfigure|configure) 6 | ;; 7 | 8 | *) 9 | echo "postinst called with unknown argument \`$1'" >&2 10 | exit 1 11 | ;; 12 | esac 13 | 14 | if [ -x /etc/init.d/nginx ]; then 15 | if [ -f /run/nginx.pid ] && pidof /usr/sbin/nginx >/dev/null; then 16 | NGX_PID=`cat /run/nginx.pid` 17 | if kill -s USR2 $NGX_PID 2>/dev/null; then 18 | while [ ! -s /run/nginx.pid.oldbin ] || [ ! -s /run/nginx.pid ]; do 19 | cnt=`expr $cnt + 1` 20 | if [ $cnt -gt 10 ]; then 21 | kill -s KILL $NGX_PID 22 | invoke-rc.d nginx start 23 | exit 0 24 | fi 25 | sleep 1 26 | done 27 | NGX_OLD_PID=`cat /run/nginx.pid.oldbin` 28 | kill -s QUIT $NGX_OLD_PID 29 | fi 30 | else 31 | invoke-rc.d nginx start || exit $? 32 | fi 33 | fi 34 | 35 | #DEBHELPER# 36 | 37 | exit 0 38 | -------------------------------------------------------------------------------- /debian/nginx-extras.prerm: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | case "$1" in 5 | remove|remove-in-favour|deconfigure|deconfigure-in-favour) 6 | if [ -x /etc/init.d/nginx ]; then 7 | invoke-rc.d nginx stop || exit $? 8 | fi 9 | ;; 10 | 11 | upgrade|failed-upgrade) 12 | ;; 13 | 14 | *) 15 | echo "prerm called with unknown argument \`$1'" >&2 16 | exit 1 17 | ;; 18 | esac 19 | 20 | #DEBHELPER# 21 | 22 | exit 0 23 | -------------------------------------------------------------------------------- /debian/nginx-full.dirs: -------------------------------------------------------------------------------- 1 | usr/sbin 2 | -------------------------------------------------------------------------------- /debian/nginx-full.install: -------------------------------------------------------------------------------- 1 | debian/build-full/objs/nginx usr/sbin 2 | -------------------------------------------------------------------------------- /debian/nginx-full.lintian-overrides: -------------------------------------------------------------------------------- 1 | nginx-full: spelling-error-in-binary usr/sbin/nginx tEH the 2 | -------------------------------------------------------------------------------- /debian/nginx-full.manpages: -------------------------------------------------------------------------------- 1 | debian/build-full/objs/nginx.8 2 | -------------------------------------------------------------------------------- /debian/nginx-full.postinst: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | case "$1" in 5 | abort-upgrade|abort-remove|abort-deconfigure|configure) 6 | ;; 7 | 8 | *) 9 | echo "postinst called with unknown argument \`$1'" >&2 10 | exit 1 11 | ;; 12 | esac 13 | 14 | if [ -x /etc/init.d/nginx ]; then 15 | if [ -f /run/nginx.pid ] && pidof /usr/sbin/nginx >/dev/null; then 16 | NGX_PID=`cat /run/nginx.pid` 17 | if kill -s USR2 $NGX_PID 2>/dev/null; then 18 | while [ ! -s /run/nginx.pid.oldbin ] || [ ! -s /run/nginx.pid ]; do 19 | cnt=`expr $cnt + 1` 20 | if [ $cnt -gt 10 ]; then 21 | kill -s KILL $NGX_PID 22 | invoke-rc.d nginx start 23 | exit 0 24 | fi 25 | sleep 1 26 | done 27 | NGX_OLD_PID=`cat /run/nginx.pid.oldbin` 28 | kill -s QUIT $NGX_OLD_PID 29 | fi 30 | else 31 | invoke-rc.d nginx start || exit $? 32 | fi 33 | fi 34 | 35 | #DEBHELPER# 36 | 37 | exit 0 38 | -------------------------------------------------------------------------------- /debian/nginx-full.prerm: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | case "$1" in 5 | remove|remove-in-favour|deconfigure|deconfigure-in-favour) 6 | if [ -x /etc/init.d/nginx ]; then 7 | invoke-rc.d nginx stop || exit $? 8 | fi 9 | ;; 10 | 11 | upgrade|failed-upgrade) 12 | ;; 13 | 14 | *) 15 | echo "prerm called with unknown argument \`$1'" >&2 16 | exit 1 17 | ;; 18 | esac 19 | 20 | #DEBHELPER# 21 | 22 | exit 0 23 | -------------------------------------------------------------------------------- /debian/nginx-light.dirs: -------------------------------------------------------------------------------- 1 | usr/sbin 2 | -------------------------------------------------------------------------------- /debian/nginx-light.install: -------------------------------------------------------------------------------- 1 | debian/build-light/objs/nginx usr/sbin 2 | -------------------------------------------------------------------------------- /debian/nginx-light.lintian-overrides: -------------------------------------------------------------------------------- 1 | nginx-light: spelling-error-in-binary usr/sbin/nginx tEH the 2 | -------------------------------------------------------------------------------- /debian/nginx-light.manpages: -------------------------------------------------------------------------------- 1 | debian/build-light/objs/nginx.8 2 | -------------------------------------------------------------------------------- /debian/nginx-light.postinst: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | case "$1" in 5 | abort-upgrade|abort-remove|abort-deconfigure|configure) 6 | ;; 7 | 8 | *) 9 | echo "postinst called with unknown argument \`$1'" >&2 10 | exit 1 11 | ;; 12 | esac 13 | 14 | if [ -x /etc/init.d/nginx ]; then 15 | if [ -f /run/nginx.pid ] && pidof /usr/sbin/nginx >/dev/null; then 16 | NGX_PID=`cat /run/nginx.pid` 17 | if kill -s USR2 $NGX_PID 2>/dev/null; then 18 | while [ ! -s /run/nginx.pid.oldbin ] || [ ! -s /run/nginx.pid ]; do 19 | cnt=`expr $cnt + 1` 20 | if [ $cnt -gt 10 ]; then 21 | kill -s KILL $NGX_PID 22 | invoke-rc.d nginx start 23 | exit 0 24 | fi 25 | sleep 1 26 | done 27 | NGX_OLD_PID=`cat /run/nginx.pid.oldbin` 28 | kill -s QUIT $NGX_OLD_PID 29 | fi 30 | else 31 | invoke-rc.d nginx start || exit $? 32 | fi 33 | fi 34 | 35 | #DEBHELPER# 36 | 37 | exit 0 38 | -------------------------------------------------------------------------------- /debian/nginx-light.prerm: -------------------------------------------------------------------------------- 1 | #!/bin/sh 2 | set -e 3 | 4 | case "$1" in 5 | remove|remove-in-favour|deconfigure|deconfigure-in-favour) 6 | if [ -x /etc/init.d/nginx ]; then 7 | invoke-rc.d nginx stop || exit $? 8 | fi 9 | ;; 10 | 11 | upgrade|failed-upgrade) 12 | ;; 13 | 14 | *) 15 | echo "prerm called with unknown argument \`$1'" >&2 16 | exit 1 17 | ;; 18 | esac 19 | 20 | #DEBHELPER# 21 | 22 | exit 0 23 | -------------------------------------------------------------------------------- /debian/patches/0002-Make-sure-signature-stays-the-same-in-all-nginx-buil.patch: -------------------------------------------------------------------------------- 1 | From: Christos Trochalakis 2 | Date: Wed, 30 Mar 2016 09:47:11 +0300 3 | Subject: Make sure signature stays the same in all nginx builds 4 | 5 | NGX_HTTP_HEADERS is part of nginx signature. When a dyn 6 | modules is loaded the signature of the module is compared 7 | to the one of the nginx binary. 8 | 9 | dyn modules are build from nginx-full, so in order to make 10 | them loadable in other flavors we need to make sure all the 11 | binaries share the same signature. 12 | --- 13 | configure | 4 ++++ 14 | 1 file changed, 4 insertions(+) 15 | 16 | Index: Local/configure 17 | =================================================================== 18 | --- Local.orig/configure 19 | +++ Local/configure 20 | @@ -58,6 +58,10 @@ if [ "$NGX_PLATFORM" != win32 ]; then 21 | . auto/unix 22 | fi 23 | 24 | +# Debian 25 | +# Make sure signature stays the same on all nginx flavors 26 | +have=NGX_HTTP_HEADERS . auto/have 27 | + 28 | . auto/threads 29 | . auto/modules 30 | . auto/lib/conf 31 | -------------------------------------------------------------------------------- /debian/patches/perl-use-dpkg-buildflags.patch: -------------------------------------------------------------------------------- 1 | Description: Use linker flags from environment for perl (dpkg-buildflags). 2 | Necessary for hardening flags. 3 | Author: Christos Trochalakis 4 | Index: Local/src/http/modules/perl/Makefile.PL 5 | =================================================================== 6 | --- Local.orig/src/http/modules/perl/Makefile.PL 7 | +++ Local/src/http/modules/perl/Makefile.PL 8 | @@ -3,6 +3,7 @@ 9 | # Copyright (C) Nginx, Inc. 10 | 11 | use 5.006001; 12 | +use Config; 13 | use ExtUtils::MakeMaker; 14 | 15 | WriteMakefile( 16 | @@ -14,6 +15,9 @@ WriteMakefile( 17 | AUTHOR => 'Igor Sysoev', 18 | 19 | CCFLAGS => "$ENV{NGX_PM_CFLAGS}", 20 | + # Pass link hardening flags 21 | + # $Config{lddlflags} is the default 22 | + LDDLFLAGS => "$Config{lddlflags} $ENV{DEBIAN_NGINX_PERL_LDFLAGS}", 23 | OPTIMIZE => '-O', 24 | 25 | LDDLFLAGS => "$ENV{NGX_PM_LDFLAGS}", 26 | -------------------------------------------------------------------------------- /debian/patches/series: -------------------------------------------------------------------------------- 1 | perl-use-dpkg-buildflags.patch 2 | 0002-Make-sure-signature-stays-the-same-in-all-nginx-buil.patch 3 | -------------------------------------------------------------------------------- /debian/po/POTFILES.in: -------------------------------------------------------------------------------- 1 | [type: gettext/rfc822deb] nginx-common.templates 2 | -------------------------------------------------------------------------------- /debian/po/templates.pot: -------------------------------------------------------------------------------- 1 | # Nginx debconf translations 2 | # Copyright (C) 2016 Christos Trochalakis 3 | # This file is distributed under the same license as the nginx package. 4 | # Chrirtos Trochalakis , 2016. 5 | # 6 | #, fuzzy 7 | msgid "" 8 | msgstr "" 9 | "Project-Id-Version: nginx\n" 10 | "Report-Msgid-Bugs-To: nginx@packages.debian.org\n" 11 | "POT-Creation-Date: 2016-10-04 20:03+0300\n" 12 | "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" 13 | "Last-Translator: FULL NAME \n" 14 | "Language-Team: LANGUAGE \n" 15 | "Language: \n" 16 | "MIME-Version: 1.0\n" 17 | "Content-Type: text/plain; charset=CHARSET\n" 18 | "Content-Transfer-Encoding: 8bit\n" 19 | 20 | #. Type: note 21 | #. Description 22 | #: ../nginx-common.templates:1001 23 | msgid "Possible insecure nginx log files" 24 | msgstr "" 25 | 26 | #. Type: note 27 | #. Description 28 | #: ../nginx-common.templates:1001 29 | msgid "" 30 | "The following log files under /var/log/nginx directory are symlinks owned by " 31 | "www-data:" 32 | msgstr "" 33 | 34 | #. Type: note 35 | #. Description 36 | #: ../nginx-common.templates:1001 37 | msgid "${logfiles}" 38 | msgstr "" 39 | 40 | #. Type: note 41 | #. Description 42 | #: ../nginx-common.templates:1001 43 | msgid "" 44 | "Since nginx 1.4.4-4 /var/log/nginx was owned by www-data. As a result www-" 45 | "data could symlink log files to sensitive locations, which in turn could " 46 | "lead to privilege escalation attacks. Although /var/log/nginx permissions " 47 | "are now fixed it is possible that such insecure links already exist. So, " 48 | "please make sure to check the above locations." 49 | msgstr "" 50 | -------------------------------------------------------------------------------- /debian/source/format: -------------------------------------------------------------------------------- 1 | 3.0 (quilt) 2 | -------------------------------------------------------------------------------- /debian/source/include-binaries: -------------------------------------------------------------------------------- 1 | debian/modules/nginx-upload-progress/test/100 2 | debian/modules/naxsi/t/fuzz/med-post-non-ascii 3 | debian/modules/naxsi/t/fuzz/mini-unknown-CT-post 4 | -------------------------------------------------------------------------------- /debian/tests/control: -------------------------------------------------------------------------------- 1 | Tests: light-simple 2 | Restrictions: allow-stderr isolation-container 3 | Depends: nginx-light, curl 4 | 5 | Tests: full-simple 6 | Restrictions: allow-stderr isolation-container 7 | Depends: nginx-full, curl 8 | 9 | Tests: extras-simple 10 | Restrictions: allow-stderr isolation-container 11 | Depends: nginx-extras, curl 12 | 13 | Tests: full-module-deps 14 | Restrictions: allow-stderr isolation-container 15 | Depends: nginx-full, curl, libnginx-mod-http-auth-pam, libnginx-mod-http-geoip, libnginx-mod-http-image-filter, libnginx-mod-http-lua, libnginx-mod-http-perl, libnginx-mod-http-xslt-filter, libnginx-mod-mail, libnginx-mod-stream 16 | 17 | Tests: light-module-deps 18 | Restrictions: allow-stderr isolation-container 19 | Depends: nginx-light, curl, libnginx-mod-http-auth-pam, libnginx-mod-http-geoip, libnginx-mod-http-image-filter, libnginx-mod-http-lua, libnginx-mod-http-perl, libnginx-mod-http-xslt-filter, libnginx-mod-mail, libnginx-mod-stream 20 | 21 | Tests: extras-module-deps 22 | Restrictions: allow-stderr isolation-container 23 | Depends: nginx-extras, curl, libnginx-mod-http-auth-pam, libnginx-mod-http-geoip, libnginx-mod-http-image-filter, libnginx-mod-http-lua, libnginx-mod-http-perl, libnginx-mod-http-xslt-filter, libnginx-mod-mail, libnginx-mod-stream 24 | -------------------------------------------------------------------------------- /debian/tests/extras-module-deps: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | curl --silent --fail -o /dev/null -w "response_code: %{http_code}\n" http://127.0.0.1/ 4 | -------------------------------------------------------------------------------- /debian/tests/extras-simple: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | curl --silent --fail -o /dev/null -w "response_code: %{http_code}\n" http://127.0.0.1/ 4 | -------------------------------------------------------------------------------- /debian/tests/full-module-deps: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | curl --silent --fail -o /dev/null -w "response_code: %{http_code}\n" http://127.0.0.1/ 4 | -------------------------------------------------------------------------------- /debian/tests/full-simple: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | curl --silent --fail -o /dev/null -w "response_code: %{http_code}\n" http://127.0.0.1/ 4 | -------------------------------------------------------------------------------- /debian/tests/light-module-deps: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | curl --silent --fail -o /dev/null -w "response_code: %{http_code}\n" http://127.0.0.1/ 4 | -------------------------------------------------------------------------------- /debian/tests/light-simple: -------------------------------------------------------------------------------- 1 | #!/bin/bash 2 | 3 | curl --silent --fail -o /dev/null -w "response_code: %{http_code}\n" http://127.0.0.1/ 4 | -------------------------------------------------------------------------------- /debian/ufw/nginx: -------------------------------------------------------------------------------- 1 | [Nginx HTTP] 2 | title=Web Server (Nginx, HTTP) 3 | description=Small, but very powerful and efficient web server 4 | ports=80/tcp 5 | 6 | [Nginx HTTPS] 7 | title=Web Server (Nginx, HTTPS) 8 | description=Small, but very powerful and efficient web server 9 | ports=443/tcp 10 | 11 | [Nginx Full] 12 | title=Web Server (Nginx, HTTP + HTTPS) 13 | description=Small, but very powerful and efficient web server 14 | ports=80,443/tcp 15 | -------------------------------------------------------------------------------- /debian/upstream/signing-key.asc: -------------------------------------------------------------------------------- 1 | -----BEGIN PGP PUBLIC KEY BLOCK----- 2 | 3 | mQENBE7SKu8BCADQo6x4ZQfAcPlJMLmL8zBEBUS6GyKMMMDtrTh3Yaq481HB54oR 4 | 0cpKL05Ff9upjrIzLD5TJUCzYYM9GQOhguDUP8+ZU9JpSz3yO2TvH7WBbUZ8FADf 5 | hblmmUBLNgOWgLo3W+FYhl3mz1GFS2Fvid6Tfn02L8CBAj7jxbjL1Qj/OA/WmLLc 6 | m6BMTqI7IBlYW2vyIOIHasISGiAwZfp0ucMeXXvTtt14LGa8qXVcFnJTdwbf03AS 7 | ljhYrQnKnpl3VpDAoQt8C68YCwjaNJW59hKqWB+XeIJ9CW98+EOAxLAFszSyGanp 8 | rCqPd0numj9TIddjcRkTA/ZbmCWK+xjpVBGXABEBAAG0IU1heGltIERvdW5pbiA8 9 | bWRvdW5pbkBtZG91bmluLnJ1PohGBBARAgAGBQJO01Y/AAoJEOzw6QssFyCDVyQA 10 | n3qwTZlcZgyyzWu9Cs8gJ0CXREaSAJ92QjGLT9DijTcbB+q9OS/nl16Z/IhGBBAR 11 | AgAGBQJO02JDAAoJEKk3YTmlJMU+P64AnjCKEXFelSVMtgefJk3+vpyt3QX1AKCH 12 | 9M3MbTWPeDUL+MpULlfdyfvjj4heBBARCAAGBQJRCTwgAAoJEFGFCWhsfl6CzF0B 13 | AJsQ3DJbtGcZ+0VIcM2a06RRQfBvIHqm1A/1WSYmObLGAP90lxWlNjSugvUUlqTk 14 | YEEgRTGozgixSyMWGJrNwqgMYokBOAQTAQIAIgUCTtIq7wIbAwYLCQgHAwIGFQgC 15 | CQoLBBYCAwECHgECF4AACgkQUgqZk6HAUvj+iwf/b4FS6zVzJ5T0v1vcQGD4ZzXe 16 | D5xMC4BJW414wVMU15rfX7aCdtoCYBNiApPxEd7SwiyxWRhRA9bikUq87JEgmnyV 17 | 0iYbHZvCvc1jOkx4WR7E45t1Mi29KBoPaFXA9X5adZkYcOQLDxa2Z8m6LGXnlF6N 18 | tJkxQ8APrjZsdrbDvo3HxU9muPcq49ydzhgwfLwpUs11LYkwB0An9WRPuv3jporZ 19 | /XgI6RfPMZ5NIx+FRRCjn6DnfHboY9rNF6NzrOReJRBhXCi6I+KkHHEnMoyg8XET 20 | 9lVkfHTOl81aIZqrAloX3/00TkYWyM2zO9oYpOg6eUFCX/Lw4MJZsTcT5EKVxLkB 21 | DQRO0irvAQgA0LjCc8S6oZzjiap2MjRNhRFA5BYjXZRZBdKF2VP74avt2/RELq8G 22 | W0n7JWmKn6vvrXabEGLyfkCngAhTq9tJ/K7LPx/bmlO5+jboO/1inH2BTtLiHjAX 23 | vicXZk3oaZt2Sotx5mMI3yzpFQRVqZXsi0LpUTPJEh3oS8IdYRjslQh1A7P5hfCZ 24 | wtzwb/hKm8upODe/ITUMuXeWfLuQj/uEU6wMzmfMHb+jlYMWtb+v98aJa2FODeKP 25 | mWCXLa7bliXp1SSeBOEfIgEAmjM6QGlDx5sZhr2Ss2xSPRdZ8DqD7oiRVzmstX1Y 26 | oxEzC0yXfaefC7SgM0nMnaTvYEOYJ9CH3wARAQABiQEfBBgBAgAJBQJO0irvAhsM 27 | AAoJEFIKmZOhwFL4844H/jo8icCcS6eOWvnen7lg0FcCo1fIm4wW3tEmkQdchSHE 28 | CJDq7pgTloN65pwB5tBoT47cyYNZA9eTfJVgRc74q5cexKOYrMC3KuAqWbwqXhkV 29 | s0nkWxnOIidTHSXvBZfDFA4Idwte94Thrzf8Pn8UESudTiqrWoCBXk2UyVsl03gJ 30 | blSJAeJGYPPeo+Yj6m63OWe2+/S2VTgmbPS/RObn0Aeg7yuff0n5+ytEt2KL51gO 31 | QE2uIxTCawHr12PsllPkbqPk/PagIttfEJqn9b0CrqPC3HREePb2aMJ/Ctw/76CO 32 | wn0mtXeIXLCTvBmznXfaMKllsqbsy2nCJ2P2uJjOntw= 33 | =ISka 34 | -----END PGP PUBLIC KEY BLOCK----- 35 | -------------------------------------------------------------------------------- /debian/vim/nginx.yaml: -------------------------------------------------------------------------------- 1 | addon: nginx 2 | description: "allow syntax highlighting for Nginx configuration files" 3 | files: 4 | - ftdetect/nginx.vim 5 | - indent/nginx.vim 6 | - syntax/nginx.vim 7 | -------------------------------------------------------------------------------- /debian/watch: -------------------------------------------------------------------------------- 1 | version=3 2 | opts=pgpsigurlmangle=s/$/.asc/ \ 3 | http://nginx.org/download/nginx-(\d\.1[02468]\.\d+)\.tar\.gz 4 | -------------------------------------------------------------------------------- /html/50x.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | Error 5 | 12 | 13 | 14 |

An error occurred.

15 |

Sorry, the page you are looking for is currently unavailable.
16 | Please try again later.

17 |

If you are the system administrator of this resource then you should check 18 | the error log for details.

19 |

Faithfully yours, nginx.

20 | 21 | 22 | -------------------------------------------------------------------------------- /html/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | Welcome to nginx! 5 | 12 | 13 | 14 |

Welcome to nginx!

15 |

If you see this page, the nginx web server is successfully installed and 16 | working. Further configuration is required.

17 | 18 |

For online documentation and support please refer to 19 | nginx.org.
20 | Commercial support is available at 21 | nginx.com.

22 | 23 |

Thank you for using nginx.

24 | 25 | 26 | -------------------------------------------------------------------------------- /src/core/nginx.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGINX_H_INCLUDED_ 9 | #define _NGINX_H_INCLUDED_ 10 | 11 | 12 | #define nginx_version 1014002 13 | #define NGINX_VERSION "1.14.2" 14 | #define NGINX_VER "nginx/" NGINX_VERSION 15 | 16 | #ifdef NGX_BUILD 17 | #define NGINX_VER_BUILD NGINX_VER " (" NGX_BUILD ")" 18 | #else 19 | #define NGINX_VER_BUILD NGINX_VER 20 | #endif 21 | 22 | #define NGINX_VAR "NGINX" 23 | #define NGX_OLDPID_EXT ".oldbin" 24 | 25 | 26 | #endif /* _NGINX_H_INCLUDED_ */ 27 | -------------------------------------------------------------------------------- /src/core/ngx_array.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_ARRAY_H_INCLUDED_ 9 | #define _NGX_ARRAY_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct { 17 | void *elts; 18 | ngx_uint_t nelts; 19 | size_t size; 20 | ngx_uint_t nalloc; 21 | ngx_pool_t *pool; 22 | } ngx_array_t; 23 | 24 | 25 | ngx_array_t *ngx_array_create(ngx_pool_t *p, ngx_uint_t n, size_t size); 26 | void ngx_array_destroy(ngx_array_t *a); 27 | void *ngx_array_push(ngx_array_t *a); 28 | void *ngx_array_push_n(ngx_array_t *a, ngx_uint_t n); 29 | 30 | 31 | static ngx_inline ngx_int_t 32 | ngx_array_init(ngx_array_t *array, ngx_pool_t *pool, ngx_uint_t n, size_t size) 33 | { 34 | /* 35 | * set "array->nelts" before "array->elts", otherwise MSVC thinks 36 | * that "array->nelts" may be used without having been initialized 37 | */ 38 | 39 | array->nelts = 0; 40 | array->size = size; 41 | array->nalloc = n; 42 | array->pool = pool; 43 | 44 | array->elts = ngx_palloc(pool, n * size); 45 | if (array->elts == NULL) { 46 | return NGX_ERROR; 47 | } 48 | 49 | return NGX_OK; 50 | } 51 | 52 | 53 | #endif /* _NGX_ARRAY_H_INCLUDED_ */ 54 | -------------------------------------------------------------------------------- /src/core/ngx_crc.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_CRC_H_INCLUDED_ 9 | #define _NGX_CRC_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | /* 32-bit crc16 */ 17 | 18 | static ngx_inline uint32_t 19 | ngx_crc(u_char *data, size_t len) 20 | { 21 | uint32_t sum; 22 | 23 | for (sum = 0; len; len--) { 24 | 25 | /* 26 | * gcc 2.95.2 x86 and icc 7.1.006 compile 27 | * that operator into the single "rol" opcode, 28 | * msvc 6.0sp2 compiles it into four opcodes. 29 | */ 30 | sum = sum >> 1 | sum << 31; 31 | 32 | sum += *data++; 33 | } 34 | 35 | return sum; 36 | } 37 | 38 | 39 | #endif /* _NGX_CRC_H_INCLUDED_ */ 40 | -------------------------------------------------------------------------------- /src/core/ngx_crc32.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_CRC32_H_INCLUDED_ 9 | #define _NGX_CRC32_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | extern uint32_t *ngx_crc32_table_short; 17 | extern uint32_t ngx_crc32_table256[]; 18 | 19 | 20 | static ngx_inline uint32_t 21 | ngx_crc32_short(u_char *p, size_t len) 22 | { 23 | u_char c; 24 | uint32_t crc; 25 | 26 | crc = 0xffffffff; 27 | 28 | while (len--) { 29 | c = *p++; 30 | crc = ngx_crc32_table_short[(crc ^ (c & 0xf)) & 0xf] ^ (crc >> 4); 31 | crc = ngx_crc32_table_short[(crc ^ (c >> 4)) & 0xf] ^ (crc >> 4); 32 | } 33 | 34 | return crc ^ 0xffffffff; 35 | } 36 | 37 | 38 | static ngx_inline uint32_t 39 | ngx_crc32_long(u_char *p, size_t len) 40 | { 41 | uint32_t crc; 42 | 43 | crc = 0xffffffff; 44 | 45 | while (len--) { 46 | crc = ngx_crc32_table256[(crc ^ *p++) & 0xff] ^ (crc >> 8); 47 | } 48 | 49 | return crc ^ 0xffffffff; 50 | } 51 | 52 | 53 | #define ngx_crc32_init(crc) \ 54 | crc = 0xffffffff 55 | 56 | 57 | static ngx_inline void 58 | ngx_crc32_update(uint32_t *crc, u_char *p, size_t len) 59 | { 60 | uint32_t c; 61 | 62 | c = *crc; 63 | 64 | while (len--) { 65 | c = ngx_crc32_table256[(c ^ *p++) & 0xff] ^ (c >> 8); 66 | } 67 | 68 | *crc = c; 69 | } 70 | 71 | 72 | #define ngx_crc32_final(crc) \ 73 | crc ^= 0xffffffff 74 | 75 | 76 | ngx_int_t ngx_crc32_table_init(void); 77 | 78 | 79 | #endif /* _NGX_CRC32_H_INCLUDED_ */ 80 | -------------------------------------------------------------------------------- /src/core/ngx_crypt.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_CRYPT_H_INCLUDED_ 9 | #define _NGX_CRYPT_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | ngx_int_t ngx_crypt(ngx_pool_t *pool, u_char *key, u_char *salt, 17 | u_char **encrypted); 18 | 19 | 20 | #endif /* _NGX_CRYPT_H_INCLUDED_ */ 21 | -------------------------------------------------------------------------------- /src/core/ngx_list.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | ngx_list_t * 13 | ngx_list_create(ngx_pool_t *pool, ngx_uint_t n, size_t size) 14 | { 15 | ngx_list_t *list; 16 | 17 | list = ngx_palloc(pool, sizeof(ngx_list_t)); 18 | if (list == NULL) { 19 | return NULL; 20 | } 21 | 22 | if (ngx_list_init(list, pool, n, size) != NGX_OK) { 23 | return NULL; 24 | } 25 | 26 | return list; 27 | } 28 | 29 | 30 | void * 31 | ngx_list_push(ngx_list_t *l) 32 | { 33 | void *elt; 34 | ngx_list_part_t *last; 35 | 36 | last = l->last; 37 | 38 | if (last->nelts == l->nalloc) { 39 | 40 | /* the last part is full, allocate a new list part */ 41 | 42 | last = ngx_palloc(l->pool, sizeof(ngx_list_part_t)); 43 | if (last == NULL) { 44 | return NULL; 45 | } 46 | 47 | last->elts = ngx_palloc(l->pool, l->nalloc * l->size); 48 | if (last->elts == NULL) { 49 | return NULL; 50 | } 51 | 52 | last->nelts = 0; 53 | last->next = NULL; 54 | 55 | l->last->next = last; 56 | l->last = last; 57 | } 58 | 59 | elt = (char *) last->elts + l->size * last->nelts; 60 | last->nelts++; 61 | 62 | return elt; 63 | } 64 | -------------------------------------------------------------------------------- /src/core/ngx_list.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_LIST_H_INCLUDED_ 9 | #define _NGX_LIST_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct ngx_list_part_s ngx_list_part_t; 17 | 18 | struct ngx_list_part_s { 19 | void *elts; 20 | ngx_uint_t nelts; 21 | ngx_list_part_t *next; 22 | }; 23 | 24 | 25 | typedef struct { 26 | ngx_list_part_t *last; 27 | ngx_list_part_t part; 28 | size_t size; 29 | ngx_uint_t nalloc; 30 | ngx_pool_t *pool; 31 | } ngx_list_t; 32 | 33 | 34 | ngx_list_t *ngx_list_create(ngx_pool_t *pool, ngx_uint_t n, size_t size); 35 | 36 | static ngx_inline ngx_int_t 37 | ngx_list_init(ngx_list_t *list, ngx_pool_t *pool, ngx_uint_t n, size_t size) 38 | { 39 | list->part.elts = ngx_palloc(pool, n * size); 40 | if (list->part.elts == NULL) { 41 | return NGX_ERROR; 42 | } 43 | 44 | list->part.nelts = 0; 45 | list->part.next = NULL; 46 | list->last = &list->part; 47 | list->size = size; 48 | list->nalloc = n; 49 | list->pool = pool; 50 | 51 | return NGX_OK; 52 | } 53 | 54 | 55 | /* 56 | * 57 | * the iteration through the list: 58 | * 59 | * part = &list.part; 60 | * data = part->elts; 61 | * 62 | * for (i = 0 ;; i++) { 63 | * 64 | * if (i >= part->nelts) { 65 | * if (part->next == NULL) { 66 | * break; 67 | * } 68 | * 69 | * part = part->next; 70 | * data = part->elts; 71 | * i = 0; 72 | * } 73 | * 74 | * ... data[i] ... 75 | * 76 | * } 77 | */ 78 | 79 | 80 | void *ngx_list_push(ngx_list_t *list); 81 | 82 | 83 | #endif /* _NGX_LIST_H_INCLUDED_ */ 84 | -------------------------------------------------------------------------------- /src/core/ngx_md5.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_MD5_H_INCLUDED_ 9 | #define _NGX_MD5_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct { 17 | uint64_t bytes; 18 | uint32_t a, b, c, d; 19 | u_char buffer[64]; 20 | } ngx_md5_t; 21 | 22 | 23 | void ngx_md5_init(ngx_md5_t *ctx); 24 | void ngx_md5_update(ngx_md5_t *ctx, const void *data, size_t size); 25 | void ngx_md5_final(u_char result[16], ngx_md5_t *ctx); 26 | 27 | 28 | #endif /* _NGX_MD5_H_INCLUDED_ */ 29 | -------------------------------------------------------------------------------- /src/core/ngx_murmurhash.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Austin Appleby 4 | */ 5 | 6 | 7 | #include 8 | #include 9 | 10 | 11 | uint32_t 12 | ngx_murmur_hash2(u_char *data, size_t len) 13 | { 14 | uint32_t h, k; 15 | 16 | h = 0 ^ len; 17 | 18 | while (len >= 4) { 19 | k = data[0]; 20 | k |= data[1] << 8; 21 | k |= data[2] << 16; 22 | k |= data[3] << 24; 23 | 24 | k *= 0x5bd1e995; 25 | k ^= k >> 24; 26 | k *= 0x5bd1e995; 27 | 28 | h *= 0x5bd1e995; 29 | h ^= k; 30 | 31 | data += 4; 32 | len -= 4; 33 | } 34 | 35 | switch (len) { 36 | case 3: 37 | h ^= data[2] << 16; 38 | /* fall through */ 39 | case 2: 40 | h ^= data[1] << 8; 41 | /* fall through */ 42 | case 1: 43 | h ^= data[0]; 44 | h *= 0x5bd1e995; 45 | } 46 | 47 | h ^= h >> 13; 48 | h *= 0x5bd1e995; 49 | h ^= h >> 15; 50 | 51 | return h; 52 | } 53 | -------------------------------------------------------------------------------- /src/core/ngx_murmurhash.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_MURMURHASH_H_INCLUDED_ 9 | #define _NGX_MURMURHASH_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | uint32_t ngx_murmur_hash2(u_char *data, size_t len); 17 | 18 | 19 | #endif /* _NGX_MURMURHASH_H_INCLUDED_ */ 20 | -------------------------------------------------------------------------------- /src/core/ngx_parse.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_PARSE_H_INCLUDED_ 9 | #define _NGX_PARSE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | ssize_t ngx_parse_size(ngx_str_t *line); 17 | off_t ngx_parse_offset(ngx_str_t *line); 18 | ngx_int_t ngx_parse_time(ngx_str_t *line, ngx_uint_t is_sec); 19 | 20 | 21 | #endif /* _NGX_PARSE_H_INCLUDED_ */ 22 | -------------------------------------------------------------------------------- /src/core/ngx_parse_time.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_PARSE_TIME_H_INCLUDED_ 9 | #define _NGX_PARSE_TIME_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | time_t ngx_parse_http_time(u_char *value, size_t len); 17 | 18 | /* compatibility */ 19 | #define ngx_http_parse_time(value, len) ngx_parse_http_time(value, len) 20 | 21 | 22 | #endif /* _NGX_PARSE_TIME_H_INCLUDED_ */ 23 | -------------------------------------------------------------------------------- /src/core/ngx_proxy_protocol.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Roman Arutyunyan 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_PROXY_PROTOCOL_H_INCLUDED_ 9 | #define _NGX_PROXY_PROTOCOL_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | #define NGX_PROXY_PROTOCOL_MAX_HEADER 107 17 | 18 | 19 | u_char *ngx_proxy_protocol_read(ngx_connection_t *c, u_char *buf, 20 | u_char *last); 21 | u_char *ngx_proxy_protocol_write(ngx_connection_t *c, u_char *buf, 22 | u_char *last); 23 | 24 | 25 | #endif /* _NGX_PROXY_PROTOCOL_H_INCLUDED_ */ 26 | -------------------------------------------------------------------------------- /src/core/ngx_queue.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | /* 13 | * find the middle queue element if the queue has odd number of elements 14 | * or the first element of the queue's second part otherwise 15 | */ 16 | 17 | ngx_queue_t * 18 | ngx_queue_middle(ngx_queue_t *queue) 19 | { 20 | ngx_queue_t *middle, *next; 21 | 22 | middle = ngx_queue_head(queue); 23 | 24 | if (middle == ngx_queue_last(queue)) { 25 | return middle; 26 | } 27 | 28 | next = ngx_queue_head(queue); 29 | 30 | for ( ;; ) { 31 | middle = ngx_queue_next(middle); 32 | 33 | next = ngx_queue_next(next); 34 | 35 | if (next == ngx_queue_last(queue)) { 36 | return middle; 37 | } 38 | 39 | next = ngx_queue_next(next); 40 | 41 | if (next == ngx_queue_last(queue)) { 42 | return middle; 43 | } 44 | } 45 | } 46 | 47 | 48 | /* the stable insertion sort */ 49 | 50 | void 51 | ngx_queue_sort(ngx_queue_t *queue, 52 | ngx_int_t (*cmp)(const ngx_queue_t *, const ngx_queue_t *)) 53 | { 54 | ngx_queue_t *q, *prev, *next; 55 | 56 | q = ngx_queue_head(queue); 57 | 58 | if (q == ngx_queue_last(queue)) { 59 | return; 60 | } 61 | 62 | for (q = ngx_queue_next(q); q != ngx_queue_sentinel(queue); q = next) { 63 | 64 | prev = ngx_queue_prev(q); 65 | next = ngx_queue_next(q); 66 | 67 | ngx_queue_remove(q); 68 | 69 | do { 70 | if (cmp(prev, q) <= 0) { 71 | break; 72 | } 73 | 74 | prev = ngx_queue_prev(prev); 75 | 76 | } while (prev != ngx_queue_sentinel(queue)); 77 | 78 | ngx_queue_insert_after(prev, q); 79 | } 80 | } 81 | -------------------------------------------------------------------------------- /src/core/ngx_radix_tree.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_RADIX_TREE_H_INCLUDED_ 9 | #define _NGX_RADIX_TREE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | #define NGX_RADIX_NO_VALUE (uintptr_t) -1 17 | 18 | typedef struct ngx_radix_node_s ngx_radix_node_t; 19 | 20 | struct ngx_radix_node_s { 21 | ngx_radix_node_t *right; 22 | ngx_radix_node_t *left; 23 | ngx_radix_node_t *parent; 24 | uintptr_t value; 25 | }; 26 | 27 | 28 | typedef struct { 29 | ngx_radix_node_t *root; 30 | ngx_pool_t *pool; 31 | ngx_radix_node_t *free; 32 | char *start; 33 | size_t size; 34 | } ngx_radix_tree_t; 35 | 36 | 37 | ngx_radix_tree_t *ngx_radix_tree_create(ngx_pool_t *pool, 38 | ngx_int_t preallocate); 39 | 40 | ngx_int_t ngx_radix32tree_insert(ngx_radix_tree_t *tree, 41 | uint32_t key, uint32_t mask, uintptr_t value); 42 | ngx_int_t ngx_radix32tree_delete(ngx_radix_tree_t *tree, 43 | uint32_t key, uint32_t mask); 44 | uintptr_t ngx_radix32tree_find(ngx_radix_tree_t *tree, uint32_t key); 45 | 46 | #if (NGX_HAVE_INET6) 47 | ngx_int_t ngx_radix128tree_insert(ngx_radix_tree_t *tree, 48 | u_char *key, u_char *mask, uintptr_t value); 49 | ngx_int_t ngx_radix128tree_delete(ngx_radix_tree_t *tree, 50 | u_char *key, u_char *mask); 51 | uintptr_t ngx_radix128tree_find(ngx_radix_tree_t *tree, u_char *key); 52 | #endif 53 | 54 | 55 | #endif /* _NGX_RADIX_TREE_H_INCLUDED_ */ 56 | -------------------------------------------------------------------------------- /src/core/ngx_regex.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_REGEX_H_INCLUDED_ 9 | #define _NGX_REGEX_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | #include 16 | 17 | 18 | #define NGX_REGEX_NO_MATCHED PCRE_ERROR_NOMATCH /* -1 */ 19 | 20 | #define NGX_REGEX_CASELESS PCRE_CASELESS 21 | 22 | 23 | typedef struct { 24 | pcre *code; 25 | pcre_extra *extra; 26 | } ngx_regex_t; 27 | 28 | 29 | typedef struct { 30 | ngx_str_t pattern; 31 | ngx_pool_t *pool; 32 | ngx_int_t options; 33 | 34 | ngx_regex_t *regex; 35 | int captures; 36 | int named_captures; 37 | int name_size; 38 | u_char *names; 39 | ngx_str_t err; 40 | } ngx_regex_compile_t; 41 | 42 | 43 | typedef struct { 44 | ngx_regex_t *regex; 45 | u_char *name; 46 | } ngx_regex_elt_t; 47 | 48 | 49 | void ngx_regex_init(void); 50 | ngx_int_t ngx_regex_compile(ngx_regex_compile_t *rc); 51 | 52 | #define ngx_regex_exec(re, s, captures, size) \ 53 | pcre_exec(re->code, re->extra, (const char *) (s)->data, (s)->len, 0, 0, \ 54 | captures, size) 55 | #define ngx_regex_exec_n "pcre_exec()" 56 | 57 | ngx_int_t ngx_regex_exec_array(ngx_array_t *a, ngx_str_t *s, ngx_log_t *log); 58 | 59 | 60 | #endif /* _NGX_REGEX_H_INCLUDED_ */ 61 | -------------------------------------------------------------------------------- /src/core/ngx_rwlock.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Ruslan Ermilov 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_RWLOCK_H_INCLUDED_ 9 | #define _NGX_RWLOCK_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | void ngx_rwlock_wlock(ngx_atomic_t *lock); 17 | void ngx_rwlock_rlock(ngx_atomic_t *lock); 18 | void ngx_rwlock_unlock(ngx_atomic_t *lock); 19 | void ngx_rwlock_downgrade(ngx_atomic_t *lock); 20 | 21 | 22 | #endif /* _NGX_RWLOCK_H_INCLUDED_ */ 23 | -------------------------------------------------------------------------------- /src/core/ngx_sha1.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_SHA1_H_INCLUDED_ 9 | #define _NGX_SHA1_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct { 17 | uint64_t bytes; 18 | uint32_t a, b, c, d, e, f; 19 | u_char buffer[64]; 20 | } ngx_sha1_t; 21 | 22 | 23 | void ngx_sha1_init(ngx_sha1_t *ctx); 24 | void ngx_sha1_update(ngx_sha1_t *ctx, const void *data, size_t size); 25 | void ngx_sha1_final(u_char result[20], ngx_sha1_t *ctx); 26 | 27 | 28 | #endif /* _NGX_SHA1_H_INCLUDED_ */ 29 | -------------------------------------------------------------------------------- /src/core/ngx_shmtx.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_SHMTX_H_INCLUDED_ 9 | #define _NGX_SHMTX_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct { 17 | ngx_atomic_t lock; 18 | #if (NGX_HAVE_POSIX_SEM) 19 | ngx_atomic_t wait; 20 | #endif 21 | } ngx_shmtx_sh_t; 22 | 23 | 24 | typedef struct { 25 | #if (NGX_HAVE_ATOMIC_OPS) 26 | ngx_atomic_t *lock; 27 | #if (NGX_HAVE_POSIX_SEM) 28 | ngx_atomic_t *wait; 29 | ngx_uint_t semaphore; 30 | sem_t sem; 31 | #endif 32 | #else 33 | ngx_fd_t fd; 34 | u_char *name; 35 | #endif 36 | ngx_uint_t spin; 37 | } ngx_shmtx_t; 38 | 39 | 40 | ngx_int_t ngx_shmtx_create(ngx_shmtx_t *mtx, ngx_shmtx_sh_t *addr, 41 | u_char *name); 42 | void ngx_shmtx_destroy(ngx_shmtx_t *mtx); 43 | ngx_uint_t ngx_shmtx_trylock(ngx_shmtx_t *mtx); 44 | void ngx_shmtx_lock(ngx_shmtx_t *mtx); 45 | void ngx_shmtx_unlock(ngx_shmtx_t *mtx); 46 | ngx_uint_t ngx_shmtx_force_unlock(ngx_shmtx_t *mtx, ngx_pid_t pid); 47 | 48 | 49 | #endif /* _NGX_SHMTX_H_INCLUDED_ */ 50 | -------------------------------------------------------------------------------- /src/core/ngx_slab.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_SLAB_H_INCLUDED_ 9 | #define _NGX_SLAB_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct ngx_slab_page_s ngx_slab_page_t; 17 | 18 | struct ngx_slab_page_s { 19 | uintptr_t slab; 20 | ngx_slab_page_t *next; 21 | uintptr_t prev; 22 | }; 23 | 24 | 25 | typedef struct { 26 | ngx_uint_t total; 27 | ngx_uint_t used; 28 | 29 | ngx_uint_t reqs; 30 | ngx_uint_t fails; 31 | } ngx_slab_stat_t; 32 | 33 | 34 | typedef struct { 35 | ngx_shmtx_sh_t lock; 36 | 37 | size_t min_size; 38 | size_t min_shift; 39 | 40 | ngx_slab_page_t *pages; 41 | ngx_slab_page_t *last; 42 | ngx_slab_page_t free; 43 | 44 | ngx_slab_stat_t *stats; 45 | ngx_uint_t pfree; 46 | 47 | u_char *start; 48 | u_char *end; 49 | 50 | ngx_shmtx_t mutex; 51 | 52 | u_char *log_ctx; 53 | u_char zero; 54 | 55 | unsigned log_nomem:1; 56 | 57 | void *data; 58 | void *addr; 59 | } ngx_slab_pool_t; 60 | 61 | 62 | void ngx_slab_sizes_init(void); 63 | void ngx_slab_init(ngx_slab_pool_t *pool); 64 | void *ngx_slab_alloc(ngx_slab_pool_t *pool, size_t size); 65 | void *ngx_slab_alloc_locked(ngx_slab_pool_t *pool, size_t size); 66 | void *ngx_slab_calloc(ngx_slab_pool_t *pool, size_t size); 67 | void *ngx_slab_calloc_locked(ngx_slab_pool_t *pool, size_t size); 68 | void ngx_slab_free(ngx_slab_pool_t *pool, void *p); 69 | void ngx_slab_free_locked(ngx_slab_pool_t *pool, void *p); 70 | 71 | 72 | #endif /* _NGX_SLAB_H_INCLUDED_ */ 73 | -------------------------------------------------------------------------------- /src/core/ngx_spinlock.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | void 13 | ngx_spinlock(ngx_atomic_t *lock, ngx_atomic_int_t value, ngx_uint_t spin) 14 | { 15 | 16 | #if (NGX_HAVE_ATOMIC_OPS) 17 | 18 | ngx_uint_t i, n; 19 | 20 | for ( ;; ) { 21 | 22 | if (*lock == 0 && ngx_atomic_cmp_set(lock, 0, value)) { 23 | return; 24 | } 25 | 26 | if (ngx_ncpu > 1) { 27 | 28 | for (n = 1; n < spin; n <<= 1) { 29 | 30 | for (i = 0; i < n; i++) { 31 | ngx_cpu_pause(); 32 | } 33 | 34 | if (*lock == 0 && ngx_atomic_cmp_set(lock, 0, value)) { 35 | return; 36 | } 37 | } 38 | } 39 | 40 | ngx_sched_yield(); 41 | } 42 | 43 | #else 44 | 45 | #if (NGX_THREADS) 46 | 47 | #error ngx_spinlock() or ngx_atomic_cmp_set() are not defined ! 48 | 49 | #endif 50 | 51 | #endif 52 | 53 | } 54 | -------------------------------------------------------------------------------- /src/core/ngx_syslog.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Nginx, Inc. 4 | */ 5 | 6 | 7 | #ifndef _NGX_SYSLOG_H_INCLUDED_ 8 | #define _NGX_SYSLOG_H_INCLUDED_ 9 | 10 | 11 | typedef struct { 12 | ngx_pool_t *pool; 13 | ngx_uint_t facility; 14 | ngx_uint_t severity; 15 | ngx_str_t tag; 16 | 17 | ngx_addr_t server; 18 | ngx_connection_t conn; 19 | unsigned busy:1; 20 | unsigned nohostname:1; 21 | } ngx_syslog_peer_t; 22 | 23 | 24 | char *ngx_syslog_process_conf(ngx_conf_t *cf, ngx_syslog_peer_t *peer); 25 | u_char *ngx_syslog_add_header(ngx_syslog_peer_t *peer, u_char *buf); 26 | void ngx_syslog_writer(ngx_log_t *log, ngx_uint_t level, u_char *buf, 27 | size_t len); 28 | ssize_t ngx_syslog_send(ngx_syslog_peer_t *peer, u_char *buf, size_t len); 29 | 30 | 31 | #endif /* _NGX_SYSLOG_H_INCLUDED_ */ 32 | -------------------------------------------------------------------------------- /src/core/ngx_thread_pool.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Nginx, Inc. 4 | * Copyright (C) Valentin V. Bartenev 5 | */ 6 | 7 | 8 | #ifndef _NGX_THREAD_POOL_H_INCLUDED_ 9 | #define _NGX_THREAD_POOL_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | struct ngx_thread_task_s { 18 | ngx_thread_task_t *next; 19 | ngx_uint_t id; 20 | void *ctx; 21 | void (*handler)(void *data, ngx_log_t *log); 22 | ngx_event_t event; 23 | }; 24 | 25 | 26 | typedef struct ngx_thread_pool_s ngx_thread_pool_t; 27 | 28 | 29 | ngx_thread_pool_t *ngx_thread_pool_add(ngx_conf_t *cf, ngx_str_t *name); 30 | ngx_thread_pool_t *ngx_thread_pool_get(ngx_cycle_t *cycle, ngx_str_t *name); 31 | 32 | ngx_thread_task_t *ngx_thread_task_alloc(ngx_pool_t *pool, size_t size); 33 | ngx_int_t ngx_thread_task_post(ngx_thread_pool_t *tp, ngx_thread_task_t *task); 34 | 35 | 36 | #endif /* _NGX_THREAD_POOL_H_INCLUDED_ */ 37 | -------------------------------------------------------------------------------- /src/core/ngx_times.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_TIMES_H_INCLUDED_ 9 | #define _NGX_TIMES_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct { 17 | time_t sec; 18 | ngx_uint_t msec; 19 | ngx_int_t gmtoff; 20 | } ngx_time_t; 21 | 22 | 23 | void ngx_time_init(void); 24 | void ngx_time_update(void); 25 | void ngx_time_sigsafe_update(void); 26 | u_char *ngx_http_time(u_char *buf, time_t t); 27 | u_char *ngx_http_cookie_time(u_char *buf, time_t t); 28 | void ngx_gmtime(time_t t, ngx_tm_t *tp); 29 | 30 | time_t ngx_next_time(time_t when); 31 | #define ngx_next_time_n "mktime()" 32 | 33 | 34 | extern volatile ngx_time_t *ngx_cached_time; 35 | 36 | #define ngx_time() ngx_cached_time->sec 37 | #define ngx_timeofday() (ngx_time_t *) ngx_cached_time 38 | 39 | extern volatile ngx_str_t ngx_cached_err_log_time; 40 | extern volatile ngx_str_t ngx_cached_http_time; 41 | extern volatile ngx_str_t ngx_cached_http_log_time; 42 | extern volatile ngx_str_t ngx_cached_http_log_iso8601; 43 | extern volatile ngx_str_t ngx_cached_syslog_time; 44 | 45 | /* 46 | * milliseconds elapsed since epoch and truncated to ngx_msec_t, 47 | * used in event timers 48 | */ 49 | extern volatile ngx_msec_t ngx_current_msec; 50 | 51 | 52 | #endif /* _NGX_TIMES_H_INCLUDED_ */ 53 | -------------------------------------------------------------------------------- /src/event/ngx_event_posted.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | #include 11 | 12 | 13 | ngx_queue_t ngx_posted_accept_events; 14 | ngx_queue_t ngx_posted_events; 15 | 16 | 17 | void 18 | ngx_event_process_posted(ngx_cycle_t *cycle, ngx_queue_t *posted) 19 | { 20 | ngx_queue_t *q; 21 | ngx_event_t *ev; 22 | 23 | while (!ngx_queue_empty(posted)) { 24 | 25 | q = ngx_queue_head(posted); 26 | ev = ngx_queue_data(q, ngx_event_t, queue); 27 | 28 | ngx_log_debug1(NGX_LOG_DEBUG_EVENT, cycle->log, 0, 29 | "posted event %p", ev); 30 | 31 | ngx_delete_posted_event(ev); 32 | 33 | ev->handler(ev); 34 | } 35 | } 36 | -------------------------------------------------------------------------------- /src/event/ngx_event_posted.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_EVENT_POSTED_H_INCLUDED_ 9 | #define _NGX_EVENT_POSTED_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | #define ngx_post_event(ev, q) \ 18 | \ 19 | if (!(ev)->posted) { \ 20 | (ev)->posted = 1; \ 21 | ngx_queue_insert_tail(q, &(ev)->queue); \ 22 | \ 23 | ngx_log_debug1(NGX_LOG_DEBUG_CORE, (ev)->log, 0, "post event %p", ev);\ 24 | \ 25 | } else { \ 26 | ngx_log_debug1(NGX_LOG_DEBUG_CORE, (ev)->log, 0, \ 27 | "update posted event %p", ev); \ 28 | } 29 | 30 | 31 | #define ngx_delete_posted_event(ev) \ 32 | \ 33 | (ev)->posted = 0; \ 34 | ngx_queue_remove(&(ev)->queue); \ 35 | \ 36 | ngx_log_debug1(NGX_LOG_DEBUG_CORE, (ev)->log, 0, \ 37 | "delete posted event %p", ev); 38 | 39 | 40 | 41 | void ngx_event_process_posted(ngx_cycle_t *cycle, ngx_queue_t *posted); 42 | 43 | 44 | extern ngx_queue_t ngx_posted_accept_events; 45 | extern ngx_queue_t ngx_posted_events; 46 | 47 | 48 | #endif /* _NGX_EVENT_POSTED_H_INCLUDED_ */ 49 | -------------------------------------------------------------------------------- /src/http/modules/ngx_http_ssl_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_HTTP_SSL_H_INCLUDED_ 9 | #define _NGX_HTTP_SSL_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | typedef struct { 18 | ngx_flag_t enable; 19 | 20 | ngx_ssl_t ssl; 21 | 22 | ngx_flag_t prefer_server_ciphers; 23 | 24 | ngx_uint_t protocols; 25 | 26 | ngx_uint_t verify; 27 | ngx_uint_t verify_depth; 28 | 29 | size_t buffer_size; 30 | 31 | ssize_t builtin_session_cache; 32 | 33 | time_t session_timeout; 34 | 35 | ngx_array_t *certificates; 36 | ngx_array_t *certificate_keys; 37 | 38 | ngx_str_t dhparam; 39 | ngx_str_t ecdh_curve; 40 | ngx_str_t client_certificate; 41 | ngx_str_t trusted_certificate; 42 | ngx_str_t crl; 43 | 44 | ngx_str_t ciphers; 45 | 46 | ngx_array_t *passwords; 47 | 48 | ngx_shm_zone_t *shm_zone; 49 | 50 | ngx_flag_t session_tickets; 51 | ngx_array_t *session_ticket_keys; 52 | 53 | ngx_flag_t stapling; 54 | ngx_flag_t stapling_verify; 55 | ngx_str_t stapling_file; 56 | ngx_str_t stapling_responder; 57 | 58 | u_char *file; 59 | ngx_uint_t line; 60 | } ngx_http_ssl_srv_conf_t; 61 | 62 | 63 | extern ngx_module_t ngx_http_ssl_module; 64 | 65 | 66 | #endif /* _NGX_HTTP_SSL_H_INCLUDED_ */ 67 | -------------------------------------------------------------------------------- /src/http/modules/perl/Makefile.PL: -------------------------------------------------------------------------------- 1 | 2 | # Copyright (C) Igor Sysoev 3 | # Copyright (C) Nginx, Inc. 4 | 5 | use 5.006001; 6 | use ExtUtils::MakeMaker; 7 | 8 | WriteMakefile( 9 | NAME => 'nginx', 10 | VERSION_FROM => 'nginx.pm', # finds $VERSION 11 | PREREQ_PM => {}, # e.g., Module::Name => 1.1 12 | 13 | ABSTRACT_FROM => 'nginx.pm', # retrieve abstract from module 14 | AUTHOR => 'Igor Sysoev', 15 | 16 | CCFLAGS => "$ENV{NGX_PM_CFLAGS}", 17 | OPTIMIZE => '-O', 18 | 19 | LDDLFLAGS => "$ENV{NGX_PM_LDFLAGS}", 20 | 21 | INC => join(" ", map { 22 | m#^/# ? "-I $_" : "-I ../../../../../$_" 23 | } (split /\s+/, $ENV{NGX_INCS})), 24 | 25 | depend => { 26 | 'nginx.c' => join(" ", map { 27 | m#^/# ? $_ : "../../../../../$_" 28 | } (split(/\s+/, $ENV{NGX_DEPS}), 29 | "src/http/modules/perl/ngx_http_perl_module.h")) 30 | }, 31 | 32 | PM => { 33 | 'nginx.pm' => '$(INST_LIBDIR)/nginx.pm' 34 | } 35 | ); 36 | -------------------------------------------------------------------------------- /src/http/modules/perl/ngx_http_perl_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_HTTP_PERL_MODULE_H_INCLUDED_ 9 | #define _NGX_HTTP_PERL_MODULE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | #include 16 | 17 | #include 18 | #include 19 | 20 | 21 | typedef ngx_http_request_t *nginx; 22 | 23 | typedef struct { 24 | ngx_str_t filename; 25 | ngx_str_t redirect_uri; 26 | ngx_str_t redirect_args; 27 | 28 | SV *next; 29 | 30 | ngx_uint_t done; /* unsigned done:1; */ 31 | 32 | ngx_array_t *variables; /* array of ngx_http_perl_var_t */ 33 | 34 | #if (NGX_HTTP_SSI) 35 | ngx_http_ssi_ctx_t *ssi; 36 | #endif 37 | } ngx_http_perl_ctx_t; 38 | 39 | 40 | typedef struct { 41 | ngx_uint_t hash; 42 | ngx_str_t name; 43 | ngx_str_t value; 44 | } ngx_http_perl_var_t; 45 | 46 | 47 | extern ngx_module_t ngx_http_perl_module; 48 | 49 | 50 | /* 51 | * workaround for "unused variable `Perl___notused'" warning 52 | * when building with perl 5.6.1 53 | */ 54 | #ifndef PERL_IMPLICIT_CONTEXT 55 | #undef dTHXa 56 | #define dTHXa(a) 57 | #endif 58 | 59 | 60 | extern void boot_DynaLoader(pTHX_ CV* cv); 61 | 62 | 63 | void ngx_http_perl_handle_request(ngx_http_request_t *r); 64 | void ngx_http_perl_sleep_handler(ngx_http_request_t *r); 65 | 66 | 67 | #endif /* _NGX_HTTP_PERL_MODULE_H_INCLUDED_ */ 68 | -------------------------------------------------------------------------------- /src/http/modules/perl/typemap: -------------------------------------------------------------------------------- 1 | TYPEMAP 2 | 3 | nginx T_PTROBJ 4 | -------------------------------------------------------------------------------- /src/http/v2/ngx_http_v2_encode.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Nginx, Inc. 4 | * Copyright (C) Valentin V. Bartenev 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | #include 11 | 12 | 13 | static u_char *ngx_http_v2_write_int(u_char *pos, ngx_uint_t prefix, 14 | ngx_uint_t value); 15 | 16 | 17 | u_char * 18 | ngx_http_v2_string_encode(u_char *dst, u_char *src, size_t len, u_char *tmp, 19 | ngx_uint_t lower) 20 | { 21 | size_t hlen; 22 | 23 | hlen = ngx_http_v2_huff_encode(src, len, tmp, lower); 24 | 25 | if (hlen > 0) { 26 | *dst = NGX_HTTP_V2_ENCODE_HUFF; 27 | dst = ngx_http_v2_write_int(dst, ngx_http_v2_prefix(7), hlen); 28 | return ngx_cpymem(dst, tmp, hlen); 29 | } 30 | 31 | *dst = NGX_HTTP_V2_ENCODE_RAW; 32 | dst = ngx_http_v2_write_int(dst, ngx_http_v2_prefix(7), len); 33 | 34 | if (lower) { 35 | ngx_strlow(dst, src, len); 36 | return dst + len; 37 | } 38 | 39 | return ngx_cpymem(dst, src, len); 40 | } 41 | 42 | 43 | static u_char * 44 | ngx_http_v2_write_int(u_char *pos, ngx_uint_t prefix, ngx_uint_t value) 45 | { 46 | if (value < prefix) { 47 | *pos++ |= value; 48 | return pos; 49 | } 50 | 51 | *pos++ |= prefix; 52 | value -= prefix; 53 | 54 | while (value >= 128) { 55 | *pos++ = value % 128 + 128; 56 | value /= 128; 57 | } 58 | 59 | *pos++ = (u_char) value; 60 | 61 | return pos; 62 | } 63 | -------------------------------------------------------------------------------- /src/http/v2/ngx_http_v2_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Nginx, Inc. 4 | * Copyright (C) Valentin V. Bartenev 5 | */ 6 | 7 | 8 | #ifndef _NGX_HTTP_V2_MODULE_H_INCLUDED_ 9 | #define _NGX_HTTP_V2_MODULE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | typedef struct { 18 | size_t recv_buffer_size; 19 | u_char *recv_buffer; 20 | } ngx_http_v2_main_conf_t; 21 | 22 | 23 | typedef struct { 24 | size_t pool_size; 25 | ngx_uint_t concurrent_streams; 26 | ngx_uint_t concurrent_pushes; 27 | ngx_uint_t max_requests; 28 | size_t max_field_size; 29 | size_t max_header_size; 30 | size_t preread_size; 31 | ngx_uint_t streams_index_mask; 32 | ngx_msec_t recv_timeout; 33 | ngx_msec_t idle_timeout; 34 | } ngx_http_v2_srv_conf_t; 35 | 36 | 37 | typedef struct { 38 | size_t chunk_size; 39 | 40 | ngx_flag_t push_preload; 41 | 42 | ngx_flag_t push; 43 | ngx_array_t *pushes; 44 | } ngx_http_v2_loc_conf_t; 45 | 46 | 47 | extern ngx_module_t ngx_http_v2_module; 48 | 49 | 50 | #endif /* _NGX_HTTP_V2_MODULE_H_INCLUDED_ */ 51 | -------------------------------------------------------------------------------- /src/mail/ngx_mail_imap_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_MAIL_IMAP_MODULE_H_INCLUDED_ 9 | #define _NGX_MAIL_IMAP_MODULE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | typedef struct { 18 | size_t client_buffer_size; 19 | 20 | ngx_str_t capability; 21 | ngx_str_t starttls_capability; 22 | ngx_str_t starttls_only_capability; 23 | 24 | ngx_uint_t auth_methods; 25 | 26 | ngx_array_t capabilities; 27 | } ngx_mail_imap_srv_conf_t; 28 | 29 | 30 | void ngx_mail_imap_init_session(ngx_mail_session_t *s, ngx_connection_t *c); 31 | void ngx_mail_imap_init_protocol(ngx_event_t *rev); 32 | void ngx_mail_imap_auth_state(ngx_event_t *rev); 33 | ngx_int_t ngx_mail_imap_parse_command(ngx_mail_session_t *s); 34 | 35 | 36 | extern ngx_module_t ngx_mail_imap_module; 37 | 38 | 39 | #endif /* _NGX_MAIL_IMAP_MODULE_H_INCLUDED_ */ 40 | -------------------------------------------------------------------------------- /src/mail/ngx_mail_pop3_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_MAIL_POP3_MODULE_H_INCLUDED_ 9 | #define _NGX_MAIL_POP3_MODULE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | typedef struct { 18 | ngx_str_t capability; 19 | ngx_str_t starttls_capability; 20 | ngx_str_t starttls_only_capability; 21 | ngx_str_t auth_capability; 22 | 23 | ngx_uint_t auth_methods; 24 | 25 | ngx_array_t capabilities; 26 | } ngx_mail_pop3_srv_conf_t; 27 | 28 | 29 | void ngx_mail_pop3_init_session(ngx_mail_session_t *s, ngx_connection_t *c); 30 | void ngx_mail_pop3_init_protocol(ngx_event_t *rev); 31 | void ngx_mail_pop3_auth_state(ngx_event_t *rev); 32 | ngx_int_t ngx_mail_pop3_parse_command(ngx_mail_session_t *s); 33 | 34 | 35 | extern ngx_module_t ngx_mail_pop3_module; 36 | 37 | 38 | #endif /* _NGX_MAIL_POP3_MODULE_H_INCLUDED_ */ 39 | -------------------------------------------------------------------------------- /src/mail/ngx_mail_smtp_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_MAIL_SMTP_MODULE_H_INCLUDED_ 9 | #define _NGX_MAIL_SMTP_MODULE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | #include 16 | 17 | 18 | typedef struct { 19 | ngx_msec_t greeting_delay; 20 | 21 | size_t client_buffer_size; 22 | 23 | ngx_str_t capability; 24 | ngx_str_t starttls_capability; 25 | ngx_str_t starttls_only_capability; 26 | 27 | ngx_str_t server_name; 28 | ngx_str_t greeting; 29 | 30 | ngx_uint_t auth_methods; 31 | 32 | ngx_array_t capabilities; 33 | } ngx_mail_smtp_srv_conf_t; 34 | 35 | 36 | void ngx_mail_smtp_init_session(ngx_mail_session_t *s, ngx_connection_t *c); 37 | void ngx_mail_smtp_init_protocol(ngx_event_t *rev); 38 | void ngx_mail_smtp_auth_state(ngx_event_t *rev); 39 | ngx_int_t ngx_mail_smtp_parse_command(ngx_mail_session_t *s); 40 | 41 | 42 | extern ngx_module_t ngx_mail_smtp_module; 43 | 44 | 45 | #endif /* _NGX_MAIL_SMTP_MODULE_H_INCLUDED_ */ 46 | -------------------------------------------------------------------------------- /src/mail/ngx_mail_ssl_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_MAIL_SSL_H_INCLUDED_ 9 | #define _NGX_MAIL_SSL_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | #define NGX_MAIL_STARTTLS_OFF 0 18 | #define NGX_MAIL_STARTTLS_ON 1 19 | #define NGX_MAIL_STARTTLS_ONLY 2 20 | 21 | 22 | typedef struct { 23 | ngx_flag_t enable; 24 | ngx_flag_t prefer_server_ciphers; 25 | 26 | ngx_ssl_t ssl; 27 | 28 | ngx_uint_t starttls; 29 | ngx_uint_t protocols; 30 | 31 | ngx_uint_t verify; 32 | ngx_uint_t verify_depth; 33 | 34 | ssize_t builtin_session_cache; 35 | 36 | time_t session_timeout; 37 | 38 | ngx_array_t *certificates; 39 | ngx_array_t *certificate_keys; 40 | 41 | ngx_str_t dhparam; 42 | ngx_str_t ecdh_curve; 43 | ngx_str_t client_certificate; 44 | ngx_str_t trusted_certificate; 45 | ngx_str_t crl; 46 | 47 | ngx_str_t ciphers; 48 | 49 | ngx_array_t *passwords; 50 | 51 | ngx_shm_zone_t *shm_zone; 52 | 53 | ngx_flag_t session_tickets; 54 | ngx_array_t *session_ticket_keys; 55 | 56 | u_char *file; 57 | ngx_uint_t line; 58 | } ngx_mail_ssl_conf_t; 59 | 60 | 61 | extern ngx_module_t ngx_mail_ssl_module; 62 | 63 | 64 | #endif /* _NGX_MAIL_SSL_H_INCLUDED_ */ 65 | -------------------------------------------------------------------------------- /src/misc/ngx_cpp_test_module.cpp: -------------------------------------------------------------------------------- 1 | 2 | // stub module to test header files' C++ compatibility 3 | 4 | extern "C" { 5 | #include 6 | #include 7 | #include 8 | #include 9 | #include 10 | 11 | #include 12 | 13 | #include 14 | #include 15 | #include 16 | #include 17 | } 18 | 19 | // nginx header files should go before other, because they define 64-bit off_t 20 | // #include 21 | 22 | 23 | void ngx_cpp_test_handler(void *data); 24 | 25 | void 26 | ngx_cpp_test_handler(void *data) 27 | { 28 | return; 29 | } 30 | -------------------------------------------------------------------------------- /src/os/unix/ngx_alloc.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | ngx_uint_t ngx_pagesize; 13 | ngx_uint_t ngx_pagesize_shift; 14 | ngx_uint_t ngx_cacheline_size; 15 | 16 | 17 | void * 18 | ngx_alloc(size_t size, ngx_log_t *log) 19 | { 20 | void *p; 21 | 22 | p = malloc(size); 23 | if (p == NULL) { 24 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, 25 | "malloc(%uz) failed", size); 26 | } 27 | 28 | ngx_log_debug2(NGX_LOG_DEBUG_ALLOC, log, 0, "malloc: %p:%uz", p, size); 29 | 30 | return p; 31 | } 32 | 33 | 34 | void * 35 | ngx_calloc(size_t size, ngx_log_t *log) 36 | { 37 | void *p; 38 | 39 | p = ngx_alloc(size, log); 40 | 41 | if (p) { 42 | ngx_memzero(p, size); 43 | } 44 | 45 | return p; 46 | } 47 | 48 | 49 | #if (NGX_HAVE_POSIX_MEMALIGN) 50 | 51 | void * 52 | ngx_memalign(size_t alignment, size_t size, ngx_log_t *log) 53 | { 54 | void *p; 55 | int err; 56 | 57 | err = posix_memalign(&p, alignment, size); 58 | 59 | if (err) { 60 | ngx_log_error(NGX_LOG_EMERG, log, err, 61 | "posix_memalign(%uz, %uz) failed", alignment, size); 62 | p = NULL; 63 | } 64 | 65 | ngx_log_debug3(NGX_LOG_DEBUG_ALLOC, log, 0, 66 | "posix_memalign: %p:%uz @%uz", p, size, alignment); 67 | 68 | return p; 69 | } 70 | 71 | #elif (NGX_HAVE_MEMALIGN) 72 | 73 | void * 74 | ngx_memalign(size_t alignment, size_t size, ngx_log_t *log) 75 | { 76 | void *p; 77 | 78 | p = memalign(alignment, size); 79 | if (p == NULL) { 80 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, 81 | "memalign(%uz, %uz) failed", alignment, size); 82 | } 83 | 84 | ngx_log_debug3(NGX_LOG_DEBUG_ALLOC, log, 0, 85 | "memalign: %p:%uz @%uz", p, size, alignment); 86 | 87 | return p; 88 | } 89 | 90 | #endif 91 | -------------------------------------------------------------------------------- /src/os/unix/ngx_alloc.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_ALLOC_H_INCLUDED_ 9 | #define _NGX_ALLOC_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | void *ngx_alloc(size_t size, ngx_log_t *log); 17 | void *ngx_calloc(size_t size, ngx_log_t *log); 18 | 19 | #define ngx_free free 20 | 21 | 22 | /* 23 | * Linux has memalign() or posix_memalign() 24 | * Solaris has memalign() 25 | * FreeBSD 7.0 has posix_memalign(), besides, early version's malloc() 26 | * aligns allocations bigger than page size at the page boundary 27 | */ 28 | 29 | #if (NGX_HAVE_POSIX_MEMALIGN || NGX_HAVE_MEMALIGN) 30 | 31 | void *ngx_memalign(size_t alignment, size_t size, ngx_log_t *log); 32 | 33 | #else 34 | 35 | #define ngx_memalign(alignment, size, log) ngx_alloc(size, log) 36 | 37 | #endif 38 | 39 | 40 | extern ngx_uint_t ngx_pagesize; 41 | extern ngx_uint_t ngx_pagesize_shift; 42 | extern ngx_uint_t ngx_cacheline_size; 43 | 44 | 45 | #endif /* _NGX_ALLOC_H_INCLUDED_ */ 46 | -------------------------------------------------------------------------------- /src/os/unix/ngx_channel.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_CHANNEL_H_INCLUDED_ 9 | #define _NGX_CHANNEL_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | typedef struct { 18 | ngx_uint_t command; 19 | ngx_pid_t pid; 20 | ngx_int_t slot; 21 | ngx_fd_t fd; 22 | } ngx_channel_t; 23 | 24 | 25 | ngx_int_t ngx_write_channel(ngx_socket_t s, ngx_channel_t *ch, size_t size, 26 | ngx_log_t *log); 27 | ngx_int_t ngx_read_channel(ngx_socket_t s, ngx_channel_t *ch, size_t size, 28 | ngx_log_t *log); 29 | ngx_int_t ngx_add_channel_event(ngx_cycle_t *cycle, ngx_fd_t fd, 30 | ngx_int_t event, ngx_event_handler_pt handler); 31 | void ngx_close_channel(ngx_fd_t *fd, ngx_log_t *log); 32 | 33 | 34 | #endif /* _NGX_CHANNEL_H_INCLUDED_ */ 35 | -------------------------------------------------------------------------------- /src/os/unix/ngx_daemon.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | ngx_int_t 13 | ngx_daemon(ngx_log_t *log) 14 | { 15 | int fd; 16 | 17 | switch (fork()) { 18 | case -1: 19 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "fork() failed"); 20 | return NGX_ERROR; 21 | 22 | case 0: 23 | break; 24 | 25 | default: 26 | exit(0); 27 | } 28 | 29 | ngx_parent = ngx_pid; 30 | ngx_pid = ngx_getpid(); 31 | 32 | if (setsid() == -1) { 33 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "setsid() failed"); 34 | return NGX_ERROR; 35 | } 36 | 37 | umask(0); 38 | 39 | fd = open("/dev/null", O_RDWR); 40 | if (fd == -1) { 41 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, 42 | "open(\"/dev/null\") failed"); 43 | return NGX_ERROR; 44 | } 45 | 46 | if (dup2(fd, STDIN_FILENO) == -1) { 47 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "dup2(STDIN) failed"); 48 | return NGX_ERROR; 49 | } 50 | 51 | if (dup2(fd, STDOUT_FILENO) == -1) { 52 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "dup2(STDOUT) failed"); 53 | return NGX_ERROR; 54 | } 55 | 56 | #if 0 57 | if (dup2(fd, STDERR_FILENO) == -1) { 58 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "dup2(STDERR) failed"); 59 | return NGX_ERROR; 60 | } 61 | #endif 62 | 63 | if (fd > STDERR_FILENO) { 64 | if (close(fd) == -1) { 65 | ngx_log_error(NGX_LOG_EMERG, log, ngx_errno, "close() failed"); 66 | return NGX_ERROR; 67 | } 68 | } 69 | 70 | return NGX_OK; 71 | } 72 | -------------------------------------------------------------------------------- /src/os/unix/ngx_darwin.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_DARWIN_H_INCLUDED_ 9 | #define _NGX_DARWIN_H_INCLUDED_ 10 | 11 | 12 | void ngx_debug_init(void); 13 | ngx_chain_t *ngx_darwin_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in, 14 | off_t limit); 15 | 16 | extern int ngx_darwin_kern_osreldate; 17 | extern int ngx_darwin_hw_ncpu; 18 | extern u_long ngx_darwin_net_inet_tcp_sendspace; 19 | 20 | extern ngx_uint_t ngx_debug_malloc; 21 | 22 | 23 | #endif /* _NGX_DARWIN_H_INCLUDED_ */ 24 | -------------------------------------------------------------------------------- /src/os/unix/ngx_darwin_config.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_DARWIN_CONFIG_H_INCLUDED_ 9 | #define _NGX_DARWIN_CONFIG_H_INCLUDED_ 10 | 11 | 12 | #define __APPLE_USE_RFC_3542 /* IPV6_PKTINFO */ 13 | 14 | 15 | #include 16 | #include 17 | #include 18 | #include 19 | #include 20 | #include /* offsetof() */ 21 | #include 22 | #include 23 | #include 24 | #include 25 | #include 26 | #include 27 | #include 28 | #include 29 | #include 30 | #include 31 | #include /* statfs() */ 32 | 33 | #include /* FIONBIO */ 34 | #include 35 | #include 36 | #include 37 | #include 38 | 39 | #include 40 | #include 41 | #include 42 | #include 43 | 44 | #include 45 | #include 46 | #include /* TCP_NODELAY */ 47 | #include 48 | #include 49 | #include 50 | 51 | #include 52 | #include 53 | 54 | #include 55 | 56 | 57 | #ifndef IOV_MAX 58 | #define IOV_MAX 64 59 | #endif 60 | 61 | 62 | #include 63 | 64 | 65 | #if (NGX_HAVE_POSIX_SEM) 66 | #include 67 | #endif 68 | 69 | 70 | #if (NGX_HAVE_POLL) 71 | #include 72 | #endif 73 | 74 | 75 | #if (NGX_HAVE_KQUEUE) 76 | #include 77 | #endif 78 | 79 | 80 | #define NGX_LISTEN_BACKLOG -1 81 | 82 | 83 | #ifndef NGX_HAVE_INHERITED_NONBLOCK 84 | #define NGX_HAVE_INHERITED_NONBLOCK 1 85 | #endif 86 | 87 | 88 | #ifndef NGX_HAVE_CASELESS_FILESYSTEM 89 | #define NGX_HAVE_CASELESS_FILESYSTEM 1 90 | #endif 91 | 92 | 93 | #define NGX_HAVE_OS_SPECIFIC_INIT 1 94 | #define NGX_HAVE_DEBUG_MALLOC 1 95 | 96 | 97 | extern char **environ; 98 | 99 | 100 | #endif /* _NGX_DARWIN_CONFIG_H_INCLUDED_ */ 101 | -------------------------------------------------------------------------------- /src/os/unix/ngx_dlopen.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Maxim Dounin 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | #if (NGX_HAVE_DLOPEN) 13 | 14 | char * 15 | ngx_dlerror(void) 16 | { 17 | char *err; 18 | 19 | err = (char *) dlerror(); 20 | 21 | if (err == NULL) { 22 | return ""; 23 | } 24 | 25 | return err; 26 | } 27 | 28 | #endif 29 | -------------------------------------------------------------------------------- /src/os/unix/ngx_dlopen.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Maxim Dounin 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_DLOPEN_H_INCLUDED_ 9 | #define _NGX_DLOPEN_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | #define ngx_dlopen(path) dlopen((char *) path, RTLD_NOW | RTLD_GLOBAL) 17 | #define ngx_dlopen_n "dlopen()" 18 | 19 | #define ngx_dlsym(handle, symbol) dlsym(handle, symbol) 20 | #define ngx_dlsym_n "dlsym()" 21 | 22 | #define ngx_dlclose(handle) dlclose(handle) 23 | #define ngx_dlclose_n "dlclose()" 24 | 25 | 26 | #if (NGX_HAVE_DLOPEN) 27 | char *ngx_dlerror(void); 28 | #endif 29 | 30 | 31 | #endif /* _NGX_DLOPEN_H_INCLUDED_ */ 32 | -------------------------------------------------------------------------------- /src/os/unix/ngx_errno.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | /* 13 | * The strerror() messages are copied because: 14 | * 15 | * 1) strerror() and strerror_r() functions are not Async-Signal-Safe, 16 | * therefore, they cannot be used in signal handlers; 17 | * 18 | * 2) a direct sys_errlist[] array may be used instead of these functions, 19 | * but Linux linker warns about its usage: 20 | * 21 | * warning: `sys_errlist' is deprecated; use `strerror' or `strerror_r' instead 22 | * warning: `sys_nerr' is deprecated; use `strerror' or `strerror_r' instead 23 | * 24 | * causing false bug reports. 25 | */ 26 | 27 | 28 | static ngx_str_t *ngx_sys_errlist; 29 | static ngx_str_t ngx_unknown_error = ngx_string("Unknown error"); 30 | 31 | 32 | u_char * 33 | ngx_strerror(ngx_err_t err, u_char *errstr, size_t size) 34 | { 35 | ngx_str_t *msg; 36 | 37 | msg = ((ngx_uint_t) err < NGX_SYS_NERR) ? &ngx_sys_errlist[err]: 38 | &ngx_unknown_error; 39 | size = ngx_min(size, msg->len); 40 | 41 | return ngx_cpymem(errstr, msg->data, size); 42 | } 43 | 44 | 45 | ngx_int_t 46 | ngx_strerror_init(void) 47 | { 48 | char *msg; 49 | u_char *p; 50 | size_t len; 51 | ngx_err_t err; 52 | 53 | /* 54 | * ngx_strerror() is not ready to work at this stage, therefore, 55 | * malloc() is used and possible errors are logged using strerror(). 56 | */ 57 | 58 | len = NGX_SYS_NERR * sizeof(ngx_str_t); 59 | 60 | ngx_sys_errlist = malloc(len); 61 | if (ngx_sys_errlist == NULL) { 62 | goto failed; 63 | } 64 | 65 | for (err = 0; err < NGX_SYS_NERR; err++) { 66 | msg = strerror(err); 67 | len = ngx_strlen(msg); 68 | 69 | p = malloc(len); 70 | if (p == NULL) { 71 | goto failed; 72 | } 73 | 74 | ngx_memcpy(p, msg, len); 75 | ngx_sys_errlist[err].len = len; 76 | ngx_sys_errlist[err].data = p; 77 | } 78 | 79 | return NGX_OK; 80 | 81 | failed: 82 | 83 | err = errno; 84 | ngx_log_stderr(0, "malloc(%uz) failed (%d: %s)", len, err, strerror(err)); 85 | 86 | return NGX_ERROR; 87 | } 88 | -------------------------------------------------------------------------------- /src/os/unix/ngx_freebsd.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_FREEBSD_H_INCLUDED_ 9 | #define _NGX_FREEBSD_H_INCLUDED_ 10 | 11 | 12 | void ngx_debug_init(void); 13 | ngx_chain_t *ngx_freebsd_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in, 14 | off_t limit); 15 | 16 | extern int ngx_freebsd_kern_osreldate; 17 | extern int ngx_freebsd_hw_ncpu; 18 | extern u_long ngx_freebsd_net_inet_tcp_sendspace; 19 | 20 | extern ngx_uint_t ngx_freebsd_sendfile_nbytes_bug; 21 | extern ngx_uint_t ngx_freebsd_use_tcp_nopush; 22 | extern ngx_uint_t ngx_debug_malloc; 23 | 24 | 25 | #endif /* _NGX_FREEBSD_H_INCLUDED_ */ 26 | -------------------------------------------------------------------------------- /src/os/unix/ngx_gcc_atomic_amd64.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #if (NGX_SMP) 9 | #define NGX_SMP_LOCK "lock;" 10 | #else 11 | #define NGX_SMP_LOCK 12 | #endif 13 | 14 | 15 | /* 16 | * "cmpxchgq r, [m]": 17 | * 18 | * if (rax == [m]) { 19 | * zf = 1; 20 | * [m] = r; 21 | * } else { 22 | * zf = 0; 23 | * rax = [m]; 24 | * } 25 | * 26 | * 27 | * The "r" is any register, %rax (%r0) - %r16. 28 | * The "=a" and "a" are the %rax register. 29 | * Although we can return result in any register, we use "a" because it is 30 | * used in cmpxchgq anyway. The result is actually in %al but not in $rax, 31 | * however as the code is inlined gcc can test %al as well as %rax. 32 | * 33 | * The "cc" means that flags were changed. 34 | */ 35 | 36 | static ngx_inline ngx_atomic_uint_t 37 | ngx_atomic_cmp_set(ngx_atomic_t *lock, ngx_atomic_uint_t old, 38 | ngx_atomic_uint_t set) 39 | { 40 | u_char res; 41 | 42 | __asm__ volatile ( 43 | 44 | NGX_SMP_LOCK 45 | " cmpxchgq %3, %1; " 46 | " sete %0; " 47 | 48 | : "=a" (res) : "m" (*lock), "a" (old), "r" (set) : "cc", "memory"); 49 | 50 | return res; 51 | } 52 | 53 | 54 | /* 55 | * "xaddq r, [m]": 56 | * 57 | * temp = [m]; 58 | * [m] += r; 59 | * r = temp; 60 | * 61 | * 62 | * The "+r" is any register, %rax (%r0) - %r16. 63 | * The "cc" means that flags were changed. 64 | */ 65 | 66 | static ngx_inline ngx_atomic_int_t 67 | ngx_atomic_fetch_add(ngx_atomic_t *value, ngx_atomic_int_t add) 68 | { 69 | __asm__ volatile ( 70 | 71 | NGX_SMP_LOCK 72 | " xaddq %0, %1; " 73 | 74 | : "+r" (add) : "m" (*value) : "cc", "memory"); 75 | 76 | return add; 77 | } 78 | 79 | 80 | #define ngx_memory_barrier() __asm__ volatile ("" ::: "memory") 81 | 82 | #define ngx_cpu_pause() __asm__ ("pause") 83 | -------------------------------------------------------------------------------- /src/os/unix/ngx_gcc_atomic_sparc64.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | /* 9 | * "casa [r1] 0x80, r2, r0" and 10 | * "casxa [r1] 0x80, r2, r0" do the following: 11 | * 12 | * if ([r1] == r2) { 13 | * swap(r0, [r1]); 14 | * } else { 15 | * r0 = [r1]; 16 | * } 17 | * 18 | * so "r0 == r2" means that the operation was successful. 19 | * 20 | * 21 | * The "r" means the general register. 22 | * The "+r" means the general register used for both input and output. 23 | */ 24 | 25 | 26 | #if (NGX_PTR_SIZE == 4) 27 | #define NGX_CASA "casa" 28 | #else 29 | #define NGX_CASA "casxa" 30 | #endif 31 | 32 | 33 | static ngx_inline ngx_atomic_uint_t 34 | ngx_atomic_cmp_set(ngx_atomic_t *lock, ngx_atomic_uint_t old, 35 | ngx_atomic_uint_t set) 36 | { 37 | __asm__ volatile ( 38 | 39 | NGX_CASA " [%1] 0x80, %2, %0" 40 | 41 | : "+r" (set) : "r" (lock), "r" (old) : "memory"); 42 | 43 | return (set == old); 44 | } 45 | 46 | 47 | static ngx_inline ngx_atomic_int_t 48 | ngx_atomic_fetch_add(ngx_atomic_t *value, ngx_atomic_int_t add) 49 | { 50 | ngx_atomic_uint_t old, res; 51 | 52 | old = *value; 53 | 54 | for ( ;; ) { 55 | 56 | res = old + add; 57 | 58 | __asm__ volatile ( 59 | 60 | NGX_CASA " [%1] 0x80, %2, %0" 61 | 62 | : "+r" (res) : "r" (value), "r" (old) : "memory"); 63 | 64 | if (res == old) { 65 | return res; 66 | } 67 | 68 | old = res; 69 | } 70 | } 71 | 72 | 73 | #if (NGX_SMP) 74 | #define ngx_memory_barrier() \ 75 | __asm__ volatile ( \ 76 | "membar #LoadLoad | #LoadStore | #StoreStore | #StoreLoad" \ 77 | ::: "memory") 78 | #else 79 | #define ngx_memory_barrier() __asm__ volatile ("" ::: "memory") 80 | #endif 81 | 82 | #define ngx_cpu_pause() 83 | -------------------------------------------------------------------------------- /src/os/unix/ngx_linux.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_LINUX_H_INCLUDED_ 9 | #define _NGX_LINUX_H_INCLUDED_ 10 | 11 | 12 | ngx_chain_t *ngx_linux_sendfile_chain(ngx_connection_t *c, ngx_chain_t *in, 13 | off_t limit); 14 | 15 | 16 | #endif /* _NGX_LINUX_H_INCLUDED_ */ 17 | -------------------------------------------------------------------------------- /src/os/unix/ngx_linux_init.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | u_char ngx_linux_kern_ostype[50]; 13 | u_char ngx_linux_kern_osrelease[50]; 14 | 15 | 16 | static ngx_os_io_t ngx_linux_io = { 17 | ngx_unix_recv, 18 | ngx_readv_chain, 19 | ngx_udp_unix_recv, 20 | ngx_unix_send, 21 | ngx_udp_unix_send, 22 | ngx_udp_unix_sendmsg_chain, 23 | #if (NGX_HAVE_SENDFILE) 24 | ngx_linux_sendfile_chain, 25 | NGX_IO_SENDFILE 26 | #else 27 | ngx_writev_chain, 28 | 0 29 | #endif 30 | }; 31 | 32 | 33 | ngx_int_t 34 | ngx_os_specific_init(ngx_log_t *log) 35 | { 36 | struct utsname u; 37 | 38 | if (uname(&u) == -1) { 39 | ngx_log_error(NGX_LOG_ALERT, log, ngx_errno, "uname() failed"); 40 | return NGX_ERROR; 41 | } 42 | 43 | (void) ngx_cpystrn(ngx_linux_kern_ostype, (u_char *) u.sysname, 44 | sizeof(ngx_linux_kern_ostype)); 45 | 46 | (void) ngx_cpystrn(ngx_linux_kern_osrelease, (u_char *) u.release, 47 | sizeof(ngx_linux_kern_osrelease)); 48 | 49 | ngx_os_io = ngx_linux_io; 50 | 51 | return NGX_OK; 52 | } 53 | 54 | 55 | void 56 | ngx_os_specific_status(ngx_log_t *log) 57 | { 58 | ngx_log_error(NGX_LOG_NOTICE, log, 0, "OS: %s %s", 59 | ngx_linux_kern_ostype, ngx_linux_kern_osrelease); 60 | } 61 | -------------------------------------------------------------------------------- /src/os/unix/ngx_process.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_PROCESS_H_INCLUDED_ 9 | #define _NGX_PROCESS_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef pid_t ngx_pid_t; 17 | 18 | #define NGX_INVALID_PID -1 19 | 20 | typedef void (*ngx_spawn_proc_pt) (ngx_cycle_t *cycle, void *data); 21 | 22 | typedef struct { 23 | ngx_pid_t pid; 24 | int status; 25 | ngx_socket_t channel[2]; 26 | 27 | ngx_spawn_proc_pt proc; 28 | void *data; 29 | char *name; 30 | 31 | unsigned respawn:1; 32 | unsigned just_spawn:1; 33 | unsigned detached:1; 34 | unsigned exiting:1; 35 | unsigned exited:1; 36 | } ngx_process_t; 37 | 38 | 39 | typedef struct { 40 | char *path; 41 | char *name; 42 | char *const *argv; 43 | char *const *envp; 44 | } ngx_exec_ctx_t; 45 | 46 | 47 | #define NGX_MAX_PROCESSES 1024 48 | 49 | #define NGX_PROCESS_NORESPAWN -1 50 | #define NGX_PROCESS_JUST_SPAWN -2 51 | #define NGX_PROCESS_RESPAWN -3 52 | #define NGX_PROCESS_JUST_RESPAWN -4 53 | #define NGX_PROCESS_DETACHED -5 54 | 55 | 56 | #define ngx_getpid getpid 57 | #define ngx_getppid getppid 58 | 59 | #ifndef ngx_log_pid 60 | #define ngx_log_pid ngx_pid 61 | #endif 62 | 63 | 64 | ngx_pid_t ngx_spawn_process(ngx_cycle_t *cycle, 65 | ngx_spawn_proc_pt proc, void *data, char *name, ngx_int_t respawn); 66 | ngx_pid_t ngx_execute(ngx_cycle_t *cycle, ngx_exec_ctx_t *ctx); 67 | ngx_int_t ngx_init_signals(ngx_log_t *log); 68 | void ngx_debug_point(void); 69 | 70 | 71 | #if (NGX_HAVE_SCHED_YIELD) 72 | #define ngx_sched_yield() sched_yield() 73 | #else 74 | #define ngx_sched_yield() usleep(1) 75 | #endif 76 | 77 | 78 | extern int ngx_argc; 79 | extern char **ngx_argv; 80 | extern char **ngx_os_argv; 81 | 82 | extern ngx_pid_t ngx_pid; 83 | extern ngx_pid_t ngx_parent; 84 | extern ngx_socket_t ngx_channel; 85 | extern ngx_int_t ngx_process_slot; 86 | extern ngx_int_t ngx_last_process; 87 | extern ngx_process_t ngx_processes[NGX_MAX_PROCESSES]; 88 | 89 | 90 | #endif /* _NGX_PROCESS_H_INCLUDED_ */ 91 | -------------------------------------------------------------------------------- /src/os/unix/ngx_process_cycle.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_PROCESS_CYCLE_H_INCLUDED_ 9 | #define _NGX_PROCESS_CYCLE_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | #define NGX_CMD_OPEN_CHANNEL 1 17 | #define NGX_CMD_CLOSE_CHANNEL 2 18 | #define NGX_CMD_QUIT 3 19 | #define NGX_CMD_TERMINATE 4 20 | #define NGX_CMD_REOPEN 5 21 | 22 | 23 | #define NGX_PROCESS_SINGLE 0 24 | #define NGX_PROCESS_MASTER 1 25 | #define NGX_PROCESS_SIGNALLER 2 26 | #define NGX_PROCESS_WORKER 3 27 | #define NGX_PROCESS_HELPER 4 28 | 29 | 30 | typedef struct { 31 | ngx_event_handler_pt handler; 32 | char *name; 33 | ngx_msec_t delay; 34 | } ngx_cache_manager_ctx_t; 35 | 36 | 37 | void ngx_master_process_cycle(ngx_cycle_t *cycle); 38 | void ngx_single_process_cycle(ngx_cycle_t *cycle); 39 | 40 | 41 | extern ngx_uint_t ngx_process; 42 | extern ngx_uint_t ngx_worker; 43 | extern ngx_pid_t ngx_pid; 44 | extern ngx_pid_t ngx_new_binary; 45 | extern ngx_uint_t ngx_inherited; 46 | extern ngx_uint_t ngx_daemonized; 47 | extern ngx_uint_t ngx_exiting; 48 | 49 | extern sig_atomic_t ngx_reap; 50 | extern sig_atomic_t ngx_sigio; 51 | extern sig_atomic_t ngx_sigalrm; 52 | extern sig_atomic_t ngx_quit; 53 | extern sig_atomic_t ngx_debug_quit; 54 | extern sig_atomic_t ngx_terminate; 55 | extern sig_atomic_t ngx_noaccept; 56 | extern sig_atomic_t ngx_reconfigure; 57 | extern sig_atomic_t ngx_reopen; 58 | extern sig_atomic_t ngx_change_binary; 59 | 60 | 61 | #endif /* _NGX_PROCESS_CYCLE_H_INCLUDED_ */ 62 | -------------------------------------------------------------------------------- /src/os/unix/ngx_send.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | #include 11 | 12 | 13 | ssize_t 14 | ngx_unix_send(ngx_connection_t *c, u_char *buf, size_t size) 15 | { 16 | ssize_t n; 17 | ngx_err_t err; 18 | ngx_event_t *wev; 19 | 20 | wev = c->write; 21 | 22 | #if (NGX_HAVE_KQUEUE) 23 | 24 | if ((ngx_event_flags & NGX_USE_KQUEUE_EVENT) && wev->pending_eof) { 25 | (void) ngx_connection_error(c, wev->kq_errno, 26 | "kevent() reported about an closed connection"); 27 | wev->error = 1; 28 | return NGX_ERROR; 29 | } 30 | 31 | #endif 32 | 33 | for ( ;; ) { 34 | n = send(c->fd, buf, size, 0); 35 | 36 | ngx_log_debug3(NGX_LOG_DEBUG_EVENT, c->log, 0, 37 | "send: fd:%d %z of %uz", c->fd, n, size); 38 | 39 | if (n > 0) { 40 | if (n < (ssize_t) size) { 41 | wev->ready = 0; 42 | } 43 | 44 | c->sent += n; 45 | 46 | return n; 47 | } 48 | 49 | err = ngx_socket_errno; 50 | 51 | if (n == 0) { 52 | ngx_log_error(NGX_LOG_ALERT, c->log, err, "send() returned zero"); 53 | wev->ready = 0; 54 | return n; 55 | } 56 | 57 | if (err == NGX_EAGAIN || err == NGX_EINTR) { 58 | wev->ready = 0; 59 | 60 | ngx_log_debug0(NGX_LOG_DEBUG_EVENT, c->log, err, 61 | "send() not ready"); 62 | 63 | if (err == NGX_EAGAIN) { 64 | return NGX_AGAIN; 65 | } 66 | 67 | } else { 68 | wev->error = 1; 69 | (void) ngx_connection_error(c, err, "send() failed"); 70 | return NGX_ERROR; 71 | } 72 | } 73 | } 74 | -------------------------------------------------------------------------------- /src/os/unix/ngx_setaffinity.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Nginx, Inc. 4 | */ 5 | 6 | 7 | #include 8 | #include 9 | 10 | 11 | #if (NGX_HAVE_CPUSET_SETAFFINITY) 12 | 13 | void 14 | ngx_setaffinity(ngx_cpuset_t *cpu_affinity, ngx_log_t *log) 15 | { 16 | ngx_uint_t i; 17 | 18 | for (i = 0; i < CPU_SETSIZE; i++) { 19 | if (CPU_ISSET(i, cpu_affinity)) { 20 | ngx_log_error(NGX_LOG_NOTICE, log, 0, 21 | "cpuset_setaffinity(): using cpu #%ui", i); 22 | } 23 | } 24 | 25 | if (cpuset_setaffinity(CPU_LEVEL_WHICH, CPU_WHICH_PID, -1, 26 | sizeof(cpuset_t), cpu_affinity) == -1) 27 | { 28 | ngx_log_error(NGX_LOG_ALERT, log, ngx_errno, 29 | "cpuset_setaffinity() failed"); 30 | } 31 | } 32 | 33 | #elif (NGX_HAVE_SCHED_SETAFFINITY) 34 | 35 | void 36 | ngx_setaffinity(ngx_cpuset_t *cpu_affinity, ngx_log_t *log) 37 | { 38 | ngx_uint_t i; 39 | 40 | for (i = 0; i < CPU_SETSIZE; i++) { 41 | if (CPU_ISSET(i, cpu_affinity)) { 42 | ngx_log_error(NGX_LOG_NOTICE, log, 0, 43 | "sched_setaffinity(): using cpu #%ui", i); 44 | } 45 | } 46 | 47 | if (sched_setaffinity(0, sizeof(cpu_set_t), cpu_affinity) == -1) { 48 | ngx_log_error(NGX_LOG_ALERT, log, ngx_errno, 49 | "sched_setaffinity() failed"); 50 | } 51 | } 52 | 53 | #endif 54 | -------------------------------------------------------------------------------- /src/os/unix/ngx_setaffinity.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Nginx, Inc. 4 | */ 5 | 6 | #ifndef _NGX_SETAFFINITY_H_INCLUDED_ 7 | #define _NGX_SETAFFINITY_H_INCLUDED_ 8 | 9 | 10 | #if (NGX_HAVE_SCHED_SETAFFINITY || NGX_HAVE_CPUSET_SETAFFINITY) 11 | 12 | #define NGX_HAVE_CPU_AFFINITY 1 13 | 14 | #if (NGX_HAVE_SCHED_SETAFFINITY) 15 | 16 | typedef cpu_set_t ngx_cpuset_t; 17 | 18 | #elif (NGX_HAVE_CPUSET_SETAFFINITY) 19 | 20 | #include 21 | 22 | typedef cpuset_t ngx_cpuset_t; 23 | 24 | #endif 25 | 26 | void ngx_setaffinity(ngx_cpuset_t *cpu_affinity, ngx_log_t *log); 27 | 28 | #else 29 | 30 | #define ngx_setaffinity(cpu_affinity, log) 31 | 32 | typedef uint64_t ngx_cpuset_t; 33 | 34 | #endif 35 | 36 | 37 | #endif /* _NGX_SETAFFINITY_H_INCLUDED_ */ 38 | -------------------------------------------------------------------------------- /src/os/unix/ngx_setproctitle.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_SETPROCTITLE_H_INCLUDED_ 9 | #define _NGX_SETPROCTITLE_H_INCLUDED_ 10 | 11 | 12 | #if (NGX_HAVE_SETPROCTITLE) 13 | 14 | /* FreeBSD, NetBSD, OpenBSD */ 15 | 16 | #define ngx_init_setproctitle(log) NGX_OK 17 | #define ngx_setproctitle(title) setproctitle("%s", title) 18 | 19 | 20 | #else /* !NGX_HAVE_SETPROCTITLE */ 21 | 22 | #if !defined NGX_SETPROCTITLE_USES_ENV 23 | 24 | #if (NGX_SOLARIS) 25 | 26 | #define NGX_SETPROCTITLE_USES_ENV 1 27 | #define NGX_SETPROCTITLE_PAD ' ' 28 | 29 | ngx_int_t ngx_init_setproctitle(ngx_log_t *log); 30 | void ngx_setproctitle(char *title); 31 | 32 | #elif (NGX_LINUX) || (NGX_DARWIN) 33 | 34 | #define NGX_SETPROCTITLE_USES_ENV 1 35 | #define NGX_SETPROCTITLE_PAD '\0' 36 | 37 | ngx_int_t ngx_init_setproctitle(ngx_log_t *log); 38 | void ngx_setproctitle(char *title); 39 | 40 | #else 41 | 42 | #define ngx_init_setproctitle(log) NGX_OK 43 | #define ngx_setproctitle(title) 44 | 45 | #endif /* OSes */ 46 | 47 | #endif /* NGX_SETPROCTITLE_USES_ENV */ 48 | 49 | #endif /* NGX_HAVE_SETPROCTITLE */ 50 | 51 | 52 | #endif /* _NGX_SETPROCTITLE_H_INCLUDED_ */ 53 | -------------------------------------------------------------------------------- /src/os/unix/ngx_shmem.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_SHMEM_H_INCLUDED_ 9 | #define _NGX_SHMEM_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef struct { 17 | u_char *addr; 18 | size_t size; 19 | ngx_str_t name; 20 | ngx_log_t *log; 21 | ngx_uint_t exists; /* unsigned exists:1; */ 22 | } ngx_shm_t; 23 | 24 | 25 | ngx_int_t ngx_shm_alloc(ngx_shm_t *shm); 26 | void ngx_shm_free(ngx_shm_t *shm); 27 | 28 | 29 | #endif /* _NGX_SHMEM_H_INCLUDED_ */ 30 | -------------------------------------------------------------------------------- /src/os/unix/ngx_socket.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | /* 13 | * ioctl(FIONBIO) sets a non-blocking mode with the single syscall 14 | * while fcntl(F_SETFL, O_NONBLOCK) needs to learn the current state 15 | * using fcntl(F_GETFL). 16 | * 17 | * ioctl() and fcntl() are syscalls at least in FreeBSD 2.x, Linux 2.2 18 | * and Solaris 7. 19 | * 20 | * ioctl() in Linux 2.4 and 2.6 uses BKL, however, fcntl(F_SETFL) uses it too. 21 | */ 22 | 23 | 24 | #if (NGX_HAVE_FIONBIO) 25 | 26 | int 27 | ngx_nonblocking(ngx_socket_t s) 28 | { 29 | int nb; 30 | 31 | nb = 1; 32 | 33 | return ioctl(s, FIONBIO, &nb); 34 | } 35 | 36 | 37 | int 38 | ngx_blocking(ngx_socket_t s) 39 | { 40 | int nb; 41 | 42 | nb = 0; 43 | 44 | return ioctl(s, FIONBIO, &nb); 45 | } 46 | 47 | #endif 48 | 49 | 50 | #if (NGX_FREEBSD) 51 | 52 | int 53 | ngx_tcp_nopush(ngx_socket_t s) 54 | { 55 | int tcp_nopush; 56 | 57 | tcp_nopush = 1; 58 | 59 | return setsockopt(s, IPPROTO_TCP, TCP_NOPUSH, 60 | (const void *) &tcp_nopush, sizeof(int)); 61 | } 62 | 63 | 64 | int 65 | ngx_tcp_push(ngx_socket_t s) 66 | { 67 | int tcp_nopush; 68 | 69 | tcp_nopush = 0; 70 | 71 | return setsockopt(s, IPPROTO_TCP, TCP_NOPUSH, 72 | (const void *) &tcp_nopush, sizeof(int)); 73 | } 74 | 75 | #elif (NGX_LINUX) 76 | 77 | 78 | int 79 | ngx_tcp_nopush(ngx_socket_t s) 80 | { 81 | int cork; 82 | 83 | cork = 1; 84 | 85 | return setsockopt(s, IPPROTO_TCP, TCP_CORK, 86 | (const void *) &cork, sizeof(int)); 87 | } 88 | 89 | 90 | int 91 | ngx_tcp_push(ngx_socket_t s) 92 | { 93 | int cork; 94 | 95 | cork = 0; 96 | 97 | return setsockopt(s, IPPROTO_TCP, TCP_CORK, 98 | (const void *) &cork, sizeof(int)); 99 | } 100 | 101 | #else 102 | 103 | int 104 | ngx_tcp_nopush(ngx_socket_t s) 105 | { 106 | return 0; 107 | } 108 | 109 | 110 | int 111 | ngx_tcp_push(ngx_socket_t s) 112 | { 113 | return 0; 114 | } 115 | 116 | #endif 117 | -------------------------------------------------------------------------------- /src/os/unix/ngx_socket.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_SOCKET_H_INCLUDED_ 9 | #define _NGX_SOCKET_H_INCLUDED_ 10 | 11 | 12 | #include 13 | 14 | 15 | #define NGX_WRITE_SHUTDOWN SHUT_WR 16 | 17 | typedef int ngx_socket_t; 18 | 19 | #define ngx_socket socket 20 | #define ngx_socket_n "socket()" 21 | 22 | 23 | #if (NGX_HAVE_FIONBIO) 24 | 25 | int ngx_nonblocking(ngx_socket_t s); 26 | int ngx_blocking(ngx_socket_t s); 27 | 28 | #define ngx_nonblocking_n "ioctl(FIONBIO)" 29 | #define ngx_blocking_n "ioctl(!FIONBIO)" 30 | 31 | #else 32 | 33 | #define ngx_nonblocking(s) fcntl(s, F_SETFL, fcntl(s, F_GETFL) | O_NONBLOCK) 34 | #define ngx_nonblocking_n "fcntl(O_NONBLOCK)" 35 | 36 | #define ngx_blocking(s) fcntl(s, F_SETFL, fcntl(s, F_GETFL) & ~O_NONBLOCK) 37 | #define ngx_blocking_n "fcntl(!O_NONBLOCK)" 38 | 39 | #endif 40 | 41 | int ngx_tcp_nopush(ngx_socket_t s); 42 | int ngx_tcp_push(ngx_socket_t s); 43 | 44 | #if (NGX_LINUX) 45 | 46 | #define ngx_tcp_nopush_n "setsockopt(TCP_CORK)" 47 | #define ngx_tcp_push_n "setsockopt(!TCP_CORK)" 48 | 49 | #else 50 | 51 | #define ngx_tcp_nopush_n "setsockopt(TCP_NOPUSH)" 52 | #define ngx_tcp_push_n "setsockopt(!TCP_NOPUSH)" 53 | 54 | #endif 55 | 56 | 57 | #define ngx_shutdown_socket shutdown 58 | #define ngx_shutdown_socket_n "shutdown()" 59 | 60 | #define ngx_close_socket close 61 | #define ngx_close_socket_n "close() socket" 62 | 63 | 64 | #endif /* _NGX_SOCKET_H_INCLUDED_ */ 65 | -------------------------------------------------------------------------------- /src/os/unix/ngx_solaris.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_SOLARIS_H_INCLUDED_ 9 | #define _NGX_SOLARIS_H_INCLUDED_ 10 | 11 | 12 | ngx_chain_t *ngx_solaris_sendfilev_chain(ngx_connection_t *c, ngx_chain_t *in, 13 | off_t limit); 14 | 15 | 16 | #endif /* _NGX_SOLARIS_H_INCLUDED_ */ 17 | -------------------------------------------------------------------------------- /src/os/unix/ngx_solaris_init.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | char ngx_solaris_sysname[20]; 13 | char ngx_solaris_release[10]; 14 | char ngx_solaris_version[50]; 15 | 16 | 17 | static ngx_os_io_t ngx_solaris_io = { 18 | ngx_unix_recv, 19 | ngx_readv_chain, 20 | ngx_udp_unix_recv, 21 | ngx_unix_send, 22 | ngx_udp_unix_send, 23 | ngx_udp_unix_sendmsg_chain, 24 | #if (NGX_HAVE_SENDFILE) 25 | ngx_solaris_sendfilev_chain, 26 | NGX_IO_SENDFILE 27 | #else 28 | ngx_writev_chain, 29 | 0 30 | #endif 31 | }; 32 | 33 | 34 | ngx_int_t 35 | ngx_os_specific_init(ngx_log_t *log) 36 | { 37 | if (sysinfo(SI_SYSNAME, ngx_solaris_sysname, sizeof(ngx_solaris_sysname)) 38 | == -1) 39 | { 40 | ngx_log_error(NGX_LOG_ALERT, log, ngx_errno, 41 | "sysinfo(SI_SYSNAME) failed"); 42 | return NGX_ERROR; 43 | } 44 | 45 | if (sysinfo(SI_RELEASE, ngx_solaris_release, sizeof(ngx_solaris_release)) 46 | == -1) 47 | { 48 | ngx_log_error(NGX_LOG_ALERT, log, ngx_errno, 49 | "sysinfo(SI_RELEASE) failed"); 50 | return NGX_ERROR; 51 | } 52 | 53 | if (sysinfo(SI_VERSION, ngx_solaris_version, sizeof(ngx_solaris_version)) 54 | == -1) 55 | { 56 | ngx_log_error(NGX_LOG_ALERT, log, ngx_errno, 57 | "sysinfo(SI_SYSNAME) failed"); 58 | return NGX_ERROR; 59 | } 60 | 61 | 62 | ngx_os_io = ngx_solaris_io; 63 | 64 | return NGX_OK; 65 | } 66 | 67 | 68 | void 69 | ngx_os_specific_status(ngx_log_t *log) 70 | { 71 | 72 | ngx_log_error(NGX_LOG_NOTICE, log, 0, "OS: %s %s", 73 | ngx_solaris_sysname, ngx_solaris_release); 74 | 75 | ngx_log_error(NGX_LOG_NOTICE, log, 0, "version: %s", 76 | ngx_solaris_version); 77 | } 78 | -------------------------------------------------------------------------------- /src/os/unix/ngx_sunpro_amd64.il: -------------------------------------------------------------------------------- 1 | / 2 | / Copyright (C) Igor Sysoev 3 | / Copyright (C) Nginx, Inc. 4 | / 5 | 6 | / ngx_atomic_uint_t ngx_atomic_cmp_set(ngx_atomic_t *lock, 7 | / ngx_atomic_uint_t old, ngx_atomic_uint_t set); 8 | / 9 | / the arguments are passed in %rdi, %rsi, %rdx 10 | / the result is returned in the %rax 11 | 12 | .inline ngx_atomic_cmp_set,0 13 | movq %rsi, %rax 14 | lock 15 | cmpxchgq %rdx, (%rdi) 16 | setz %al 17 | movzbq %al, %rax 18 | .end 19 | 20 | 21 | / ngx_atomic_int_t ngx_atomic_fetch_add(ngx_atomic_t *value, 22 | / ngx_atomic_int_t add); 23 | / 24 | / the arguments are passed in %rdi, %rsi 25 | / the result is returned in the %rax 26 | 27 | .inline ngx_atomic_fetch_add,0 28 | movq %rsi, %rax 29 | lock 30 | xaddq %rax, (%rdi) 31 | .end 32 | 33 | 34 | / ngx_cpu_pause() 35 | / 36 | / the "rep; nop" is used instead of "pause" to avoid the "[ PAUSE ]" hardware 37 | / capability added by linker because Solaris/amd64 does not know about it: 38 | / 39 | / ld.so.1: nginx: fatal: hardware capability unsupported: 0x2000 [ PAUSE ] 40 | 41 | .inline ngx_cpu_pause,0 42 | rep; nop 43 | .end 44 | -------------------------------------------------------------------------------- /src/os/unix/ngx_sunpro_atomic_sparc64.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #if (NGX_PTR_SIZE == 4) 9 | #define NGX_CASA ngx_casa 10 | #else 11 | #define NGX_CASA ngx_casxa 12 | #endif 13 | 14 | 15 | ngx_atomic_uint_t 16 | ngx_casa(ngx_atomic_uint_t set, ngx_atomic_uint_t old, ngx_atomic_t *lock); 17 | 18 | ngx_atomic_uint_t 19 | ngx_casxa(ngx_atomic_uint_t set, ngx_atomic_uint_t old, ngx_atomic_t *lock); 20 | 21 | /* the code in src/os/unix/ngx_sunpro_sparc64.il */ 22 | 23 | 24 | static ngx_inline ngx_atomic_uint_t 25 | ngx_atomic_cmp_set(ngx_atomic_t *lock, ngx_atomic_uint_t old, 26 | ngx_atomic_uint_t set) 27 | { 28 | set = NGX_CASA(set, old, lock); 29 | 30 | return (set == old); 31 | } 32 | 33 | 34 | static ngx_inline ngx_atomic_int_t 35 | ngx_atomic_fetch_add(ngx_atomic_t *value, ngx_atomic_int_t add) 36 | { 37 | ngx_atomic_uint_t old, res; 38 | 39 | old = *value; 40 | 41 | for ( ;; ) { 42 | 43 | res = old + add; 44 | 45 | res = NGX_CASA(res, old, value); 46 | 47 | if (res == old) { 48 | return res; 49 | } 50 | 51 | old = res; 52 | } 53 | } 54 | 55 | 56 | #define ngx_memory_barrier() \ 57 | __asm (".volatile"); \ 58 | __asm ("membar #LoadLoad | #LoadStore | #StoreStore | #StoreLoad"); \ 59 | __asm (".nonvolatile") 60 | 61 | #define ngx_cpu_pause() 62 | -------------------------------------------------------------------------------- /src/os/unix/ngx_sunpro_sparc64.il: -------------------------------------------------------------------------------- 1 | / 2 | / Copyright (C) Igor Sysoev 3 | / Copyright (C) Nginx, Inc. 4 | / 5 | 6 | 7 | / "casa [%o2] 0x80, %o1, %o0" and 8 | / "casxa [%o2] 0x80, %o1, %o0" do the following: 9 | / 10 | / if ([%o2] == %o1) { 11 | / swap(%o0, [%o2]); 12 | / } else { 13 | / %o0 = [%o2]; 14 | / } 15 | 16 | 17 | / ngx_atomic_uint_t ngx_casa(ngx_atomic_uint_t set, ngx_atomic_uint_t old, 18 | / ngx_atomic_t *lock); 19 | / 20 | / the arguments are passed in the %o0, %o1, %o2 21 | / the result is returned in the %o0 22 | 23 | .inline ngx_casa,0 24 | casa [%o2] 0x80, %o1, %o0 25 | .end 26 | 27 | 28 | / ngx_atomic_uint_t ngx_casxa(ngx_atomic_uint_t set, ngx_atomic_uint_t old, 29 | / ngx_atomic_t *lock); 30 | / 31 | / the arguments are passed in the %o0, %o1, %o2 32 | / the result is returned in the %o0 33 | 34 | .inline ngx_casxa,0 35 | casxa [%o2] 0x80, %o1, %o0 36 | .end 37 | -------------------------------------------------------------------------------- /src/os/unix/ngx_sunpro_x86.il: -------------------------------------------------------------------------------- 1 | / 2 | / Copyright (C) Igor Sysoev 3 | / Copyright (C) Nginx, Inc. 4 | / 5 | 6 | / ngx_atomic_uint_t ngx_atomic_cmp_set(ngx_atomic_t *lock, 7 | / ngx_atomic_uint_t old, ngx_atomic_uint_t set); 8 | / 9 | / the arguments are passed on stack (%esp), 4(%esp), 8(%esp) 10 | 11 | .inline ngx_atomic_cmp_set,0 12 | movl (%esp), %ecx 13 | movl 4(%esp), %eax 14 | movl 8(%esp), %edx 15 | lock 16 | cmpxchgl %edx, (%ecx) 17 | setz %al 18 | movzbl %al, %eax 19 | .end 20 | 21 | 22 | / ngx_atomic_int_t ngx_atomic_fetch_add(ngx_atomic_t *value, 23 | / ngx_atomic_int_t add); 24 | / 25 | / the arguments are passed on stack (%esp), 4(%esp) 26 | 27 | .inline ngx_atomic_fetch_add,0 28 | movl (%esp), %ecx 29 | movl 4(%esp), %eax 30 | lock 31 | xaddl %eax, (%ecx) 32 | .end 33 | 34 | 35 | / ngx_cpu_pause() 36 | / 37 | / the "rep; nop" is used instead of "pause" to avoid the "[ PAUSE ]" hardware 38 | / capability added by linker because Solaris/i386 does not know about it: 39 | / 40 | / ld.so.1: nginx: fatal: hardware capability unsupported: 0x2000 [ PAUSE ] 41 | 42 | .inline ngx_cpu_pause,0 43 | rep; nop 44 | .end 45 | -------------------------------------------------------------------------------- /src/os/unix/ngx_thread.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_THREAD_H_INCLUDED_ 9 | #define _NGX_THREAD_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | #if (NGX_THREADS) 16 | 17 | #include 18 | 19 | 20 | typedef pthread_mutex_t ngx_thread_mutex_t; 21 | 22 | ngx_int_t ngx_thread_mutex_create(ngx_thread_mutex_t *mtx, ngx_log_t *log); 23 | ngx_int_t ngx_thread_mutex_destroy(ngx_thread_mutex_t *mtx, ngx_log_t *log); 24 | ngx_int_t ngx_thread_mutex_lock(ngx_thread_mutex_t *mtx, ngx_log_t *log); 25 | ngx_int_t ngx_thread_mutex_unlock(ngx_thread_mutex_t *mtx, ngx_log_t *log); 26 | 27 | 28 | typedef pthread_cond_t ngx_thread_cond_t; 29 | 30 | ngx_int_t ngx_thread_cond_create(ngx_thread_cond_t *cond, ngx_log_t *log); 31 | ngx_int_t ngx_thread_cond_destroy(ngx_thread_cond_t *cond, ngx_log_t *log); 32 | ngx_int_t ngx_thread_cond_signal(ngx_thread_cond_t *cond, ngx_log_t *log); 33 | ngx_int_t ngx_thread_cond_wait(ngx_thread_cond_t *cond, ngx_thread_mutex_t *mtx, 34 | ngx_log_t *log); 35 | 36 | 37 | #if (NGX_LINUX) 38 | 39 | typedef pid_t ngx_tid_t; 40 | #define NGX_TID_T_FMT "%P" 41 | 42 | #elif (NGX_FREEBSD) 43 | 44 | typedef uint32_t ngx_tid_t; 45 | #define NGX_TID_T_FMT "%uD" 46 | 47 | #elif (NGX_DARWIN) 48 | 49 | typedef uint64_t ngx_tid_t; 50 | #define NGX_TID_T_FMT "%uA" 51 | 52 | #else 53 | 54 | typedef uint64_t ngx_tid_t; 55 | #define NGX_TID_T_FMT "%uA" 56 | 57 | #endif 58 | 59 | ngx_tid_t ngx_thread_tid(void); 60 | 61 | #define ngx_log_tid ngx_thread_tid() 62 | 63 | #else 64 | 65 | #define ngx_log_tid 0 66 | #define NGX_TID_T_FMT "%d" 67 | 68 | #endif 69 | 70 | 71 | #endif /* _NGX_THREAD_H_INCLUDED_ */ 72 | -------------------------------------------------------------------------------- /src/os/unix/ngx_thread_cond.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | ngx_int_t 13 | ngx_thread_cond_create(ngx_thread_cond_t *cond, ngx_log_t *log) 14 | { 15 | ngx_err_t err; 16 | 17 | err = pthread_cond_init(cond, NULL); 18 | if (err == 0) { 19 | return NGX_OK; 20 | } 21 | 22 | ngx_log_error(NGX_LOG_EMERG, log, err, "pthread_cond_init() failed"); 23 | return NGX_ERROR; 24 | } 25 | 26 | 27 | ngx_int_t 28 | ngx_thread_cond_destroy(ngx_thread_cond_t *cond, ngx_log_t *log) 29 | { 30 | ngx_err_t err; 31 | 32 | err = pthread_cond_destroy(cond); 33 | if (err == 0) { 34 | return NGX_OK; 35 | } 36 | 37 | ngx_log_error(NGX_LOG_EMERG, log, err, "pthread_cond_destroy() failed"); 38 | return NGX_ERROR; 39 | } 40 | 41 | 42 | ngx_int_t 43 | ngx_thread_cond_signal(ngx_thread_cond_t *cond, ngx_log_t *log) 44 | { 45 | ngx_err_t err; 46 | 47 | err = pthread_cond_signal(cond); 48 | if (err == 0) { 49 | return NGX_OK; 50 | } 51 | 52 | ngx_log_error(NGX_LOG_EMERG, log, err, "pthread_cond_signal() failed"); 53 | return NGX_ERROR; 54 | } 55 | 56 | 57 | ngx_int_t 58 | ngx_thread_cond_wait(ngx_thread_cond_t *cond, ngx_thread_mutex_t *mtx, 59 | ngx_log_t *log) 60 | { 61 | ngx_err_t err; 62 | 63 | err = pthread_cond_wait(cond, mtx); 64 | 65 | #if 0 66 | ngx_time_update(); 67 | #endif 68 | 69 | if (err == 0) { 70 | return NGX_OK; 71 | } 72 | 73 | ngx_log_error(NGX_LOG_ALERT, log, err, "pthread_cond_wait() failed"); 74 | 75 | return NGX_ERROR; 76 | } 77 | -------------------------------------------------------------------------------- /src/os/unix/ngx_thread_id.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | #include 11 | 12 | 13 | #if (NGX_LINUX) 14 | 15 | /* 16 | * Linux thread id is a pid of thread created by clone(2), 17 | * glibc does not provide a wrapper for gettid(). 18 | */ 19 | 20 | ngx_tid_t 21 | ngx_thread_tid(void) 22 | { 23 | return syscall(SYS_gettid); 24 | } 25 | 26 | #elif (NGX_FREEBSD) && (__FreeBSD_version >= 900031) 27 | 28 | #include 29 | 30 | ngx_tid_t 31 | ngx_thread_tid(void) 32 | { 33 | return pthread_getthreadid_np(); 34 | } 35 | 36 | #elif (NGX_DARWIN) 37 | 38 | /* 39 | * MacOSX thread has two thread ids: 40 | * 41 | * 1) MacOSX 10.6 (Snow Leoprad) has pthread_threadid_np() returning 42 | * an uint64_t value, which is obtained using the __thread_selfid() 43 | * syscall. It is a number above 300,000. 44 | */ 45 | 46 | ngx_tid_t 47 | ngx_thread_tid(void) 48 | { 49 | uint64_t tid; 50 | 51 | (void) pthread_threadid_np(NULL, &tid); 52 | return tid; 53 | } 54 | 55 | /* 56 | * 2) Kernel thread mach_port_t returned by pthread_mach_thread_np(). 57 | * It is a number in range 100-100,000. 58 | * 59 | * return pthread_mach_thread_np(pthread_self()); 60 | */ 61 | 62 | #else 63 | 64 | ngx_tid_t 65 | ngx_thread_tid(void) 66 | { 67 | return (uint64_t) (uintptr_t) pthread_self(); 68 | } 69 | 70 | #endif 71 | -------------------------------------------------------------------------------- /src/os/unix/ngx_time.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | /* 13 | * FreeBSD does not test /etc/localtime change, however, we can workaround it 14 | * by calling tzset() with TZ and then without TZ to update timezone. 15 | * The trick should work since FreeBSD 2.1.0. 16 | * 17 | * Linux does not test /etc/localtime change in localtime(), 18 | * but may stat("/etc/localtime") several times in every strftime(), 19 | * therefore we use it to update timezone. 20 | * 21 | * Solaris does not test /etc/TIMEZONE change too and no workaround available. 22 | */ 23 | 24 | void 25 | ngx_timezone_update(void) 26 | { 27 | #if (NGX_FREEBSD) 28 | 29 | if (getenv("TZ")) { 30 | return; 31 | } 32 | 33 | putenv("TZ=UTC"); 34 | 35 | tzset(); 36 | 37 | unsetenv("TZ"); 38 | 39 | tzset(); 40 | 41 | #elif (NGX_LINUX) 42 | time_t s; 43 | struct tm *t; 44 | char buf[4]; 45 | 46 | s = time(0); 47 | 48 | t = localtime(&s); 49 | 50 | strftime(buf, 4, "%H", t); 51 | 52 | #endif 53 | } 54 | 55 | 56 | void 57 | ngx_localtime(time_t s, ngx_tm_t *tm) 58 | { 59 | #if (NGX_HAVE_LOCALTIME_R) 60 | (void) localtime_r(&s, tm); 61 | 62 | #else 63 | ngx_tm_t *t; 64 | 65 | t = localtime(&s); 66 | *tm = *t; 67 | 68 | #endif 69 | 70 | tm->ngx_tm_mon++; 71 | tm->ngx_tm_year += 1900; 72 | } 73 | 74 | 75 | void 76 | ngx_libc_localtime(time_t s, struct tm *tm) 77 | { 78 | #if (NGX_HAVE_LOCALTIME_R) 79 | (void) localtime_r(&s, tm); 80 | 81 | #else 82 | struct tm *t; 83 | 84 | t = localtime(&s); 85 | *tm = *t; 86 | 87 | #endif 88 | } 89 | 90 | 91 | void 92 | ngx_libc_gmtime(time_t s, struct tm *tm) 93 | { 94 | #if (NGX_HAVE_LOCALTIME_R) 95 | (void) gmtime_r(&s, tm); 96 | 97 | #else 98 | struct tm *t; 99 | 100 | t = gmtime(&s); 101 | *tm = *t; 102 | 103 | #endif 104 | } 105 | -------------------------------------------------------------------------------- /src/os/unix/ngx_time.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_TIME_H_INCLUDED_ 9 | #define _NGX_TIME_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef ngx_rbtree_key_t ngx_msec_t; 17 | typedef ngx_rbtree_key_int_t ngx_msec_int_t; 18 | 19 | typedef struct tm ngx_tm_t; 20 | 21 | #define ngx_tm_sec tm_sec 22 | #define ngx_tm_min tm_min 23 | #define ngx_tm_hour tm_hour 24 | #define ngx_tm_mday tm_mday 25 | #define ngx_tm_mon tm_mon 26 | #define ngx_tm_year tm_year 27 | #define ngx_tm_wday tm_wday 28 | #define ngx_tm_isdst tm_isdst 29 | 30 | #define ngx_tm_sec_t int 31 | #define ngx_tm_min_t int 32 | #define ngx_tm_hour_t int 33 | #define ngx_tm_mday_t int 34 | #define ngx_tm_mon_t int 35 | #define ngx_tm_year_t int 36 | #define ngx_tm_wday_t int 37 | 38 | 39 | #if (NGX_HAVE_GMTOFF) 40 | #define ngx_tm_gmtoff tm_gmtoff 41 | #define ngx_tm_zone tm_zone 42 | #endif 43 | 44 | 45 | #if (NGX_SOLARIS) 46 | 47 | #define ngx_timezone(isdst) (- (isdst ? altzone : timezone) / 60) 48 | 49 | #else 50 | 51 | #define ngx_timezone(isdst) (- (isdst ? timezone + 3600 : timezone) / 60) 52 | 53 | #endif 54 | 55 | 56 | void ngx_timezone_update(void); 57 | void ngx_localtime(time_t s, ngx_tm_t *tm); 58 | void ngx_libc_localtime(time_t s, struct tm *tm); 59 | void ngx_libc_gmtime(time_t s, struct tm *tm); 60 | 61 | #define ngx_gettimeofday(tp) (void) gettimeofday(tp, NULL); 62 | #define ngx_msleep(ms) (void) usleep(ms * 1000) 63 | #define ngx_sleep(s) (void) sleep(s) 64 | 65 | 66 | #endif /* _NGX_TIME_H_INCLUDED_ */ 67 | -------------------------------------------------------------------------------- /src/os/unix/ngx_udp_recv.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | #include 11 | 12 | 13 | ssize_t 14 | ngx_udp_unix_recv(ngx_connection_t *c, u_char *buf, size_t size) 15 | { 16 | ssize_t n; 17 | ngx_err_t err; 18 | ngx_event_t *rev; 19 | 20 | rev = c->read; 21 | 22 | do { 23 | n = recv(c->fd, buf, size, 0); 24 | 25 | ngx_log_debug3(NGX_LOG_DEBUG_EVENT, c->log, 0, 26 | "recv: fd:%d %z of %uz", c->fd, n, size); 27 | 28 | if (n >= 0) { 29 | 30 | #if (NGX_HAVE_KQUEUE) 31 | 32 | if (ngx_event_flags & NGX_USE_KQUEUE_EVENT) { 33 | rev->available -= n; 34 | 35 | /* 36 | * rev->available may be negative here because some additional 37 | * bytes may be received between kevent() and recv() 38 | */ 39 | 40 | if (rev->available <= 0) { 41 | rev->ready = 0; 42 | rev->available = 0; 43 | } 44 | } 45 | 46 | #endif 47 | 48 | return n; 49 | } 50 | 51 | err = ngx_socket_errno; 52 | 53 | if (err == NGX_EAGAIN || err == NGX_EINTR) { 54 | ngx_log_debug0(NGX_LOG_DEBUG_EVENT, c->log, err, 55 | "recv() not ready"); 56 | n = NGX_AGAIN; 57 | 58 | } else { 59 | n = ngx_connection_error(c, err, "recv() failed"); 60 | break; 61 | } 62 | 63 | } while (err == NGX_EINTR); 64 | 65 | rev->ready = 0; 66 | 67 | if (n == NGX_ERROR) { 68 | rev->error = 1; 69 | } 70 | 71 | return n; 72 | } 73 | -------------------------------------------------------------------------------- /src/os/unix/ngx_udp_send.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | #include 11 | 12 | 13 | ssize_t 14 | ngx_udp_unix_send(ngx_connection_t *c, u_char *buf, size_t size) 15 | { 16 | ssize_t n; 17 | ngx_err_t err; 18 | ngx_event_t *wev; 19 | 20 | wev = c->write; 21 | 22 | for ( ;; ) { 23 | n = sendto(c->fd, buf, size, 0, c->sockaddr, c->socklen); 24 | 25 | ngx_log_debug4(NGX_LOG_DEBUG_EVENT, c->log, 0, 26 | "sendto: fd:%d %z of %uz to \"%V\"", 27 | c->fd, n, size, &c->addr_text); 28 | 29 | if (n >= 0) { 30 | if ((size_t) n != size) { 31 | wev->error = 1; 32 | (void) ngx_connection_error(c, 0, "sendto() incomplete"); 33 | return NGX_ERROR; 34 | } 35 | 36 | c->sent += n; 37 | 38 | return n; 39 | } 40 | 41 | err = ngx_socket_errno; 42 | 43 | if (err == NGX_EAGAIN) { 44 | wev->ready = 0; 45 | ngx_log_debug0(NGX_LOG_DEBUG_EVENT, c->log, NGX_EAGAIN, 46 | "sendto() not ready"); 47 | return NGX_AGAIN; 48 | } 49 | 50 | if (err != NGX_EINTR) { 51 | wev->error = 1; 52 | (void) ngx_connection_error(c, err, "sendto() failed"); 53 | return NGX_ERROR; 54 | } 55 | } 56 | } 57 | -------------------------------------------------------------------------------- /src/os/unix/ngx_user.c: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #include 9 | #include 10 | 11 | 12 | #if (NGX_CRYPT) 13 | 14 | #if (NGX_HAVE_GNU_CRYPT_R) 15 | 16 | ngx_int_t 17 | ngx_libc_crypt(ngx_pool_t *pool, u_char *key, u_char *salt, u_char **encrypted) 18 | { 19 | char *value; 20 | size_t len; 21 | struct crypt_data cd; 22 | 23 | cd.initialized = 0; 24 | 25 | value = crypt_r((char *) key, (char *) salt, &cd); 26 | 27 | if (value) { 28 | len = ngx_strlen(value) + 1; 29 | 30 | *encrypted = ngx_pnalloc(pool, len); 31 | if (*encrypted == NULL) { 32 | return NGX_ERROR; 33 | } 34 | 35 | ngx_memcpy(*encrypted, value, len); 36 | return NGX_OK; 37 | } 38 | 39 | ngx_log_error(NGX_LOG_CRIT, pool->log, ngx_errno, "crypt_r() failed"); 40 | 41 | return NGX_ERROR; 42 | } 43 | 44 | #else 45 | 46 | ngx_int_t 47 | ngx_libc_crypt(ngx_pool_t *pool, u_char *key, u_char *salt, u_char **encrypted) 48 | { 49 | char *value; 50 | size_t len; 51 | ngx_err_t err; 52 | 53 | value = crypt((char *) key, (char *) salt); 54 | 55 | if (value) { 56 | len = ngx_strlen(value) + 1; 57 | 58 | *encrypted = ngx_pnalloc(pool, len); 59 | if (*encrypted == NULL) { 60 | return NGX_ERROR; 61 | } 62 | 63 | ngx_memcpy(*encrypted, value, len); 64 | return NGX_OK; 65 | } 66 | 67 | err = ngx_errno; 68 | 69 | ngx_log_error(NGX_LOG_CRIT, pool->log, err, "crypt() failed"); 70 | 71 | return NGX_ERROR; 72 | } 73 | 74 | #endif 75 | 76 | #endif /* NGX_CRYPT */ 77 | -------------------------------------------------------------------------------- /src/os/unix/ngx_user.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_USER_H_INCLUDED_ 9 | #define _NGX_USER_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | 15 | 16 | typedef uid_t ngx_uid_t; 17 | typedef gid_t ngx_gid_t; 18 | 19 | 20 | ngx_int_t ngx_libc_crypt(ngx_pool_t *pool, u_char *key, u_char *salt, 21 | u_char **encrypted); 22 | 23 | 24 | #endif /* _NGX_USER_H_INCLUDED_ */ 25 | -------------------------------------------------------------------------------- /src/stream/ngx_stream_ssl_module.h: -------------------------------------------------------------------------------- 1 | 2 | /* 3 | * Copyright (C) Igor Sysoev 4 | * Copyright (C) Nginx, Inc. 5 | */ 6 | 7 | 8 | #ifndef _NGX_STREAM_SSL_H_INCLUDED_ 9 | #define _NGX_STREAM_SSL_H_INCLUDED_ 10 | 11 | 12 | #include 13 | #include 14 | #include 15 | 16 | 17 | typedef struct { 18 | ngx_msec_t handshake_timeout; 19 | 20 | ngx_flag_t prefer_server_ciphers; 21 | 22 | ngx_ssl_t ssl; 23 | 24 | ngx_uint_t protocols; 25 | 26 | ngx_uint_t verify; 27 | ngx_uint_t verify_depth; 28 | 29 | ssize_t builtin_session_cache; 30 | 31 | time_t session_timeout; 32 | 33 | ngx_array_t *certificates; 34 | ngx_array_t *certificate_keys; 35 | 36 | ngx_str_t dhparam; 37 | ngx_str_t ecdh_curve; 38 | ngx_str_t client_certificate; 39 | ngx_str_t trusted_certificate; 40 | ngx_str_t crl; 41 | 42 | ngx_str_t ciphers; 43 | 44 | ngx_array_t *passwords; 45 | 46 | ngx_shm_zone_t *shm_zone; 47 | 48 | ngx_flag_t session_tickets; 49 | ngx_array_t *session_ticket_keys; 50 | } ngx_stream_ssl_conf_t; 51 | 52 | 53 | extern ngx_module_t ngx_stream_ssl_module; 54 | 55 | 56 | #endif /* _NGX_STREAM_SSL_H_INCLUDED_ */ 57 | --------------------------------------------------------------------------------