nginxtra 1.0.15.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (363) hide show
  1. data/VERSION +1 -0
  2. data/bin/nginxtra +5 -0
  3. data/lib/nginxtra.rb +12 -0
  4. data/lib/nginxtra/action.rb +36 -0
  5. data/lib/nginxtra/actions/compile.rb +60 -0
  6. data/lib/nginxtra/actions/install.rb +99 -0
  7. data/lib/nginxtra/actions/reload.rb +14 -0
  8. data/lib/nginxtra/actions/restart.rb +15 -0
  9. data/lib/nginxtra/actions/start.rb +53 -0
  10. data/lib/nginxtra/actions/status.rb +31 -0
  11. data/lib/nginxtra/actions/stop.rb +14 -0
  12. data/lib/nginxtra/cli.rb +77 -0
  13. data/lib/nginxtra/config.rb +339 -0
  14. data/lib/nginxtra/error.rb +13 -0
  15. data/lib/nginxtra/status.rb +57 -0
  16. data/src/nginx/CHANGES +5630 -0
  17. data/src/nginx/CHANGES.ru +5716 -0
  18. data/src/nginx/LICENSE +25 -0
  19. data/src/nginx/README +3 -0
  20. data/src/nginx/auto/cc/acc +15 -0
  21. data/src/nginx/auto/cc/bcc +72 -0
  22. data/src/nginx/auto/cc/ccc +46 -0
  23. data/src/nginx/auto/cc/conf +189 -0
  24. data/src/nginx/auto/cc/gcc +183 -0
  25. data/src/nginx/auto/cc/icc +121 -0
  26. data/src/nginx/auto/cc/msvc +138 -0
  27. data/src/nginx/auto/cc/name +101 -0
  28. data/src/nginx/auto/cc/owc +104 -0
  29. data/src/nginx/auto/cc/sunc +158 -0
  30. data/src/nginx/auto/define +12 -0
  31. data/src/nginx/auto/endianess +45 -0
  32. data/src/nginx/auto/feature +123 -0
  33. data/src/nginx/auto/have +12 -0
  34. data/src/nginx/auto/have_headers +12 -0
  35. data/src/nginx/auto/headers +13 -0
  36. data/src/nginx/auto/include +61 -0
  37. data/src/nginx/auto/init +51 -0
  38. data/src/nginx/auto/install +184 -0
  39. data/src/nginx/auto/lib/conf +83 -0
  40. data/src/nginx/auto/lib/geoip/conf +79 -0
  41. data/src/nginx/auto/lib/google-perftools/conf +45 -0
  42. data/src/nginx/auto/lib/libatomic/conf +43 -0
  43. data/src/nginx/auto/lib/libatomic/make +14 -0
  44. data/src/nginx/auto/lib/libgd/conf +83 -0
  45. data/src/nginx/auto/lib/libxslt/conf +156 -0
  46. data/src/nginx/auto/lib/make +32 -0
  47. data/src/nginx/auto/lib/md5/conf +103 -0
  48. data/src/nginx/auto/lib/md5/make +96 -0
  49. data/src/nginx/auto/lib/md5/makefile.bcc +22 -0
  50. data/src/nginx/auto/lib/md5/makefile.msvc +22 -0
  51. data/src/nginx/auto/lib/md5/makefile.owc +11 -0
  52. data/src/nginx/auto/lib/openssl/conf +74 -0
  53. data/src/nginx/auto/lib/openssl/make +67 -0
  54. data/src/nginx/auto/lib/openssl/makefile.bcc +18 -0
  55. data/src/nginx/auto/lib/openssl/makefile.msvc +14 -0
  56. data/src/nginx/auto/lib/pcre/conf +180 -0
  57. data/src/nginx/auto/lib/pcre/make +64 -0
  58. data/src/nginx/auto/lib/pcre/makefile.bcc +26 -0
  59. data/src/nginx/auto/lib/pcre/makefile.msvc +22 -0
  60. data/src/nginx/auto/lib/pcre/makefile.owc +24 -0
  61. data/src/nginx/auto/lib/perl/conf +60 -0
  62. data/src/nginx/auto/lib/perl/make +36 -0
  63. data/src/nginx/auto/lib/sha1/conf +79 -0
  64. data/src/nginx/auto/lib/sha1/make +96 -0
  65. data/src/nginx/auto/lib/sha1/makefile.bcc +22 -0
  66. data/src/nginx/auto/lib/sha1/makefile.msvc +22 -0
  67. data/src/nginx/auto/lib/sha1/makefile.owc +11 -0
  68. data/src/nginx/auto/lib/test +40 -0
  69. data/src/nginx/auto/lib/zlib/conf +76 -0
  70. data/src/nginx/auto/lib/zlib/make +114 -0
  71. data/src/nginx/auto/lib/zlib/makefile.bcc +15 -0
  72. data/src/nginx/auto/lib/zlib/makefile.msvc +14 -0
  73. data/src/nginx/auto/lib/zlib/makefile.owc +14 -0
  74. data/src/nginx/auto/lib/zlib/patch.zlib.h +10 -0
  75. data/src/nginx/auto/make +417 -0
  76. data/src/nginx/auto/modules +479 -0
  77. data/src/nginx/auto/nohave +12 -0
  78. data/src/nginx/auto/options +490 -0
  79. data/src/nginx/auto/os/conf +105 -0
  80. data/src/nginx/auto/os/darwin +116 -0
  81. data/src/nginx/auto/os/freebsd +136 -0
  82. data/src/nginx/auto/os/linux +152 -0
  83. data/src/nginx/auto/os/solaris +60 -0
  84. data/src/nginx/auto/os/win32 +29 -0
  85. data/src/nginx/auto/sources +518 -0
  86. data/src/nginx/auto/stubs +8 -0
  87. data/src/nginx/auto/summary +114 -0
  88. data/src/nginx/auto/types/sizeof +83 -0
  89. data/src/nginx/auto/types/typedef +77 -0
  90. data/src/nginx/auto/types/uintptr_t +42 -0
  91. data/src/nginx/auto/types/value +12 -0
  92. data/src/nginx/auto/unix +719 -0
  93. data/src/nginx/conf/fastcgi.conf +24 -0
  94. data/src/nginx/conf/fastcgi_params +23 -0
  95. data/src/nginx/conf/koi-utf +109 -0
  96. data/src/nginx/conf/koi-win +103 -0
  97. data/src/nginx/conf/mime.types +80 -0
  98. data/src/nginx/conf/nginx.conf +118 -0
  99. data/src/nginx/conf/scgi_params +15 -0
  100. data/src/nginx/conf/uwsgi_params +15 -0
  101. data/src/nginx/conf/win-utf +126 -0
  102. data/src/nginx/configure +108 -0
  103. data/src/nginx/contrib/README +15 -0
  104. data/src/nginx/contrib/geo2nginx.pl +58 -0
  105. data/src/nginx/contrib/unicode2nginx/koi-utf +131 -0
  106. data/src/nginx/contrib/unicode2nginx/unicode-to-nginx.pl +45 -0
  107. data/src/nginx/contrib/unicode2nginx/win-utf +130 -0
  108. data/src/nginx/html/50x.html +18 -0
  109. data/src/nginx/html/index.html +8 -0
  110. data/src/nginx/man/nginx.8 +202 -0
  111. data/src/nginx/src/core/nginx.c +1333 -0
  112. data/src/nginx/src/core/nginx.h +20 -0
  113. data/src/nginx/src/core/ngx_array.c +147 -0
  114. data/src/nginx/src/core/ngx_array.h +53 -0
  115. data/src/nginx/src/core/ngx_buf.c +218 -0
  116. data/src/nginx/src/core/ngx_buf.h +162 -0
  117. data/src/nginx/src/core/ngx_conf_file.c +1506 -0
  118. data/src/nginx/src/core/ngx_conf_file.h +348 -0
  119. data/src/nginx/src/core/ngx_config.h +134 -0
  120. data/src/nginx/src/core/ngx_connection.c +1074 -0
  121. data/src/nginx/src/core/ngx_connection.h +195 -0
  122. data/src/nginx/src/core/ngx_core.h +95 -0
  123. data/src/nginx/src/core/ngx_cpuinfo.c +139 -0
  124. data/src/nginx/src/core/ngx_crc.h +39 -0
  125. data/src/nginx/src/core/ngx_crc32.c +129 -0
  126. data/src/nginx/src/core/ngx_crc32.h +79 -0
  127. data/src/nginx/src/core/ngx_crypt.c +238 -0
  128. data/src/nginx/src/core/ngx_crypt.h +20 -0
  129. data/src/nginx/src/core/ngx_cycle.c +1379 -0
  130. data/src/nginx/src/core/ngx_cycle.h +142 -0
  131. data/src/nginx/src/core/ngx_file.c +993 -0
  132. data/src/nginx/src/core/ngx_file.h +151 -0
  133. data/src/nginx/src/core/ngx_hash.c +976 -0
  134. data/src/nginx/src/core/ngx_hash.h +122 -0
  135. data/src/nginx/src/core/ngx_inet.c +1008 -0
  136. data/src/nginx/src/core/ngx_inet.h +120 -0
  137. data/src/nginx/src/core/ngx_list.c +71 -0
  138. data/src/nginx/src/core/ngx_list.h +83 -0
  139. data/src/nginx/src/core/ngx_log.c +459 -0
  140. data/src/nginx/src/core/ngx_log.h +250 -0
  141. data/src/nginx/src/core/ngx_md5.c +289 -0
  142. data/src/nginx/src/core/ngx_md5.h +60 -0
  143. data/src/nginx/src/core/ngx_murmurhash.c +50 -0
  144. data/src/nginx/src/core/ngx_murmurhash.h +19 -0
  145. data/src/nginx/src/core/ngx_open_file_cache.c +882 -0
  146. data/src/nginx/src/core/ngx_open_file_cache.h +119 -0
  147. data/src/nginx/src/core/ngx_output_chain.c +673 -0
  148. data/src/nginx/src/core/ngx_palloc.c +433 -0
  149. data/src/nginx/src/core/ngx_palloc.h +95 -0
  150. data/src/nginx/src/core/ngx_parse.c +249 -0
  151. data/src/nginx/src/core/ngx_parse.h +24 -0
  152. data/src/nginx/src/core/ngx_queue.c +80 -0
  153. data/src/nginx/src/core/ngx_queue.h +112 -0
  154. data/src/nginx/src/core/ngx_radix_tree.c +291 -0
  155. data/src/nginx/src/core/ngx_radix_tree.h +46 -0
  156. data/src/nginx/src/core/ngx_rbtree.c +383 -0
  157. data/src/nginx/src/core/ngx_rbtree.h +84 -0
  158. data/src/nginx/src/core/ngx_regex.c +206 -0
  159. data/src/nginx/src/core/ngx_regex.h +56 -0
  160. data/src/nginx/src/core/ngx_resolver.c +2201 -0
  161. data/src/nginx/src/core/ngx_resolver.h +149 -0
  162. data/src/nginx/src/core/ngx_sha1.h +31 -0
  163. data/src/nginx/src/core/ngx_shmtx.c +284 -0
  164. data/src/nginx/src/core/ngx_shmtx.h +38 -0
  165. data/src/nginx/src/core/ngx_slab.c +701 -0
  166. data/src/nginx/src/core/ngx_slab.h +54 -0
  167. data/src/nginx/src/core/ngx_spinlock.c +53 -0
  168. data/src/nginx/src/core/ngx_string.c +1837 -0
  169. data/src/nginx/src/core/ngx_string.h +231 -0
  170. data/src/nginx/src/core/ngx_times.c +407 -0
  171. data/src/nginx/src/core/ngx_times.h +51 -0
  172. data/src/nginx/src/event/modules/ngx_aio_module.c +171 -0
  173. data/src/nginx/src/event/modules/ngx_devpoll_module.c +569 -0
  174. data/src/nginx/src/event/modules/ngx_epoll_module.c +833 -0
  175. data/src/nginx/src/event/modules/ngx_eventport_module.c +602 -0
  176. data/src/nginx/src/event/modules/ngx_kqueue_module.c +785 -0
  177. data/src/nginx/src/event/modules/ngx_poll_module.c +443 -0
  178. data/src/nginx/src/event/modules/ngx_rtsig_module.c +735 -0
  179. data/src/nginx/src/event/modules/ngx_select_module.c +435 -0
  180. data/src/nginx/src/event/modules/ngx_win32_select_module.c +400 -0
  181. data/src/nginx/src/event/ngx_event.c +1275 -0
  182. data/src/nginx/src/event/ngx_event.h +573 -0
  183. data/src/nginx/src/event/ngx_event_accept.c +428 -0
  184. data/src/nginx/src/event/ngx_event_busy_lock.c +286 -0
  185. data/src/nginx/src/event/ngx_event_busy_lock.h +65 -0
  186. data/src/nginx/src/event/ngx_event_connect.c +258 -0
  187. data/src/nginx/src/event/ngx_event_connect.h +76 -0
  188. data/src/nginx/src/event/ngx_event_mutex.c +70 -0
  189. data/src/nginx/src/event/ngx_event_openssl.c +2382 -0
  190. data/src/nginx/src/event/ngx_event_openssl.h +162 -0
  191. data/src/nginx/src/event/ngx_event_pipe.c +996 -0
  192. data/src/nginx/src/event/ngx_event_pipe.h +95 -0
  193. data/src/nginx/src/event/ngx_event_posted.c +173 -0
  194. data/src/nginx/src/event/ngx_event_posted.h +75 -0
  195. data/src/nginx/src/event/ngx_event_timer.c +159 -0
  196. data/src/nginx/src/event/ngx_event_timer.h +102 -0
  197. data/src/nginx/src/http/modules/ngx_http_access_module.c +384 -0
  198. data/src/nginx/src/http/modules/ngx_http_addition_filter_module.c +250 -0
  199. data/src/nginx/src/http/modules/ngx_http_auth_basic_module.c +478 -0
  200. data/src/nginx/src/http/modules/ngx_http_autoindex_module.c +701 -0
  201. data/src/nginx/src/http/modules/ngx_http_browser_module.c +713 -0
  202. data/src/nginx/src/http/modules/ngx_http_charset_filter_module.c +1681 -0
  203. data/src/nginx/src/http/modules/ngx_http_chunked_filter_module.c +242 -0
  204. data/src/nginx/src/http/modules/ngx_http_dav_module.c +1141 -0
  205. data/src/nginx/src/http/modules/ngx_http_degradation_module.c +243 -0
  206. data/src/nginx/src/http/modules/ngx_http_empty_gif_module.c +140 -0
  207. data/src/nginx/src/http/modules/ngx_http_fastcgi_module.c +2916 -0
  208. data/src/nginx/src/http/modules/ngx_http_flv_module.c +254 -0
  209. data/src/nginx/src/http/modules/ngx_http_geo_module.c +1441 -0
  210. data/src/nginx/src/http/modules/ngx_http_geoip_module.c +671 -0
  211. data/src/nginx/src/http/modules/ngx_http_gzip_filter_module.c +1206 -0
  212. data/src/nginx/src/http/modules/ngx_http_gzip_static_module.c +299 -0
  213. data/src/nginx/src/http/modules/ngx_http_headers_filter_module.c +616 -0
  214. data/src/nginx/src/http/modules/ngx_http_image_filter_module.c +1489 -0
  215. data/src/nginx/src/http/modules/ngx_http_index_module.c +516 -0
  216. data/src/nginx/src/http/modules/ngx_http_limit_req_module.c +809 -0
  217. data/src/nginx/src/http/modules/ngx_http_limit_zone_module.c +553 -0
  218. data/src/nginx/src/http/modules/ngx_http_log_module.c +1357 -0
  219. data/src/nginx/src/http/modules/ngx_http_map_module.c +575 -0
  220. data/src/nginx/src/http/modules/ngx_http_memcached_module.c +624 -0
  221. data/src/nginx/src/http/modules/ngx_http_mp4_module.c +3000 -0
  222. data/src/nginx/src/http/modules/ngx_http_not_modified_filter_module.c +143 -0
  223. data/src/nginx/src/http/modules/ngx_http_proxy_module.c +2831 -0
  224. data/src/nginx/src/http/modules/ngx_http_random_index_module.c +317 -0
  225. data/src/nginx/src/http/modules/ngx_http_range_filter_module.c +855 -0
  226. data/src/nginx/src/http/modules/ngx_http_realip_module.c +476 -0
  227. data/src/nginx/src/http/modules/ngx_http_referer_module.c +613 -0
  228. data/src/nginx/src/http/modules/ngx_http_rewrite_module.c +1019 -0
  229. data/src/nginx/src/http/modules/ngx_http_scgi_module.c +1714 -0
  230. data/src/nginx/src/http/modules/ngx_http_secure_link_module.c +355 -0
  231. data/src/nginx/src/http/modules/ngx_http_split_clients_module.c +242 -0
  232. data/src/nginx/src/http/modules/ngx_http_ssi_filter_module.c +2913 -0
  233. data/src/nginx/src/http/modules/ngx_http_ssi_filter_module.h +114 -0
  234. data/src/nginx/src/http/modules/ngx_http_ssl_module.c +652 -0
  235. data/src/nginx/src/http/modules/ngx_http_ssl_module.h +52 -0
  236. data/src/nginx/src/http/modules/ngx_http_static_module.c +278 -0
  237. data/src/nginx/src/http/modules/ngx_http_stub_status_module.c +144 -0
  238. data/src/nginx/src/http/modules/ngx_http_sub_filter_module.c +716 -0
  239. data/src/nginx/src/http/modules/ngx_http_upstream_ip_hash_module.c +237 -0
  240. data/src/nginx/src/http/modules/ngx_http_userid_filter_module.c +846 -0
  241. data/src/nginx/src/http/modules/ngx_http_uwsgi_module.c +1774 -0
  242. data/src/nginx/src/http/modules/ngx_http_xslt_filter_module.c +984 -0
  243. data/src/nginx/src/http/modules/perl/Makefile.PL +42 -0
  244. data/src/nginx/src/http/modules/perl/nginx.pm +137 -0
  245. data/src/nginx/src/http/modules/perl/nginx.xs +986 -0
  246. data/src/nginx/src/http/modules/perl/ngx_http_perl_module.c +1076 -0
  247. data/src/nginx/src/http/modules/perl/ngx_http_perl_module.h +67 -0
  248. data/src/nginx/src/http/modules/perl/typemap +3 -0
  249. data/src/nginx/src/http/ngx_http.c +2073 -0
  250. data/src/nginx/src/http/ngx_http.h +160 -0
  251. data/src/nginx/src/http/ngx_http_busy_lock.c +307 -0
  252. data/src/nginx/src/http/ngx_http_busy_lock.h +54 -0
  253. data/src/nginx/src/http/ngx_http_cache.h +148 -0
  254. data/src/nginx/src/http/ngx_http_config.h +75 -0
  255. data/src/nginx/src/http/ngx_http_copy_filter_module.c +300 -0
  256. data/src/nginx/src/http/ngx_http_core_module.c +4736 -0
  257. data/src/nginx/src/http/ngx_http_core_module.h +541 -0
  258. data/src/nginx/src/http/ngx_http_file_cache.c +1715 -0
  259. data/src/nginx/src/http/ngx_http_header_filter_module.c +623 -0
  260. data/src/nginx/src/http/ngx_http_parse.c +1734 -0
  261. data/src/nginx/src/http/ngx_http_parse_time.c +276 -0
  262. data/src/nginx/src/http/ngx_http_postpone_filter_module.c +178 -0
  263. data/src/nginx/src/http/ngx_http_request.c +3181 -0
  264. data/src/nginx/src/http/ngx_http_request.h +573 -0
  265. data/src/nginx/src/http/ngx_http_request_body.c +644 -0
  266. data/src/nginx/src/http/ngx_http_script.c +1752 -0
  267. data/src/nginx/src/http/ngx_http_script.h +257 -0
  268. data/src/nginx/src/http/ngx_http_special_response.c +789 -0
  269. data/src/nginx/src/http/ngx_http_upstream.c +4555 -0
  270. data/src/nginx/src/http/ngx_http_upstream.h +350 -0
  271. data/src/nginx/src/http/ngx_http_upstream_round_robin.c +791 -0
  272. data/src/nginx/src/http/ngx_http_upstream_round_robin.h +85 -0
  273. data/src/nginx/src/http/ngx_http_variables.c +2053 -0
  274. data/src/nginx/src/http/ngx_http_variables.h +115 -0
  275. data/src/nginx/src/http/ngx_http_write_filter_module.c +315 -0
  276. data/src/nginx/src/mail/ngx_mail.c +542 -0
  277. data/src/nginx/src/mail/ngx_mail.h +407 -0
  278. data/src/nginx/src/mail/ngx_mail_auth_http_module.c +1452 -0
  279. data/src/nginx/src/mail/ngx_mail_core_module.c +553 -0
  280. data/src/nginx/src/mail/ngx_mail_handler.c +773 -0
  281. data/src/nginx/src/mail/ngx_mail_imap_handler.c +457 -0
  282. data/src/nginx/src/mail/ngx_mail_imap_module.c +253 -0
  283. data/src/nginx/src/mail/ngx_mail_imap_module.h +39 -0
  284. data/src/nginx/src/mail/ngx_mail_parse.c +885 -0
  285. data/src/nginx/src/mail/ngx_mail_pop3_handler.c +500 -0
  286. data/src/nginx/src/mail/ngx_mail_pop3_module.c +264 -0
  287. data/src/nginx/src/mail/ngx_mail_pop3_module.h +38 -0
  288. data/src/nginx/src/mail/ngx_mail_proxy_module.c +1089 -0
  289. data/src/nginx/src/mail/ngx_mail_smtp_handler.c +872 -0
  290. data/src/nginx/src/mail/ngx_mail_smtp_module.c +308 -0
  291. data/src/nginx/src/mail/ngx_mail_smtp_module.h +45 -0
  292. data/src/nginx/src/mail/ngx_mail_ssl_module.c +491 -0
  293. data/src/nginx/src/mail/ngx_mail_ssl_module.h +52 -0
  294. data/src/nginx/src/misc/ngx_cpp_test_module.cpp +27 -0
  295. data/src/nginx/src/misc/ngx_google_perftools_module.c +126 -0
  296. data/src/nginx/src/os/unix/ngx_aio_read.c +109 -0
  297. data/src/nginx/src/os/unix/ngx_aio_read_chain.c +78 -0
  298. data/src/nginx/src/os/unix/ngx_aio_write.c +109 -0
  299. data/src/nginx/src/os/unix/ngx_aio_write_chain.c +100 -0
  300. data/src/nginx/src/os/unix/ngx_alloc.c +90 -0
  301. data/src/nginx/src/os/unix/ngx_alloc.h +45 -0
  302. data/src/nginx/src/os/unix/ngx_atomic.h +311 -0
  303. data/src/nginx/src/os/unix/ngx_channel.c +258 -0
  304. data/src/nginx/src/os/unix/ngx_channel.h +34 -0
  305. data/src/nginx/src/os/unix/ngx_daemon.c +69 -0
  306. data/src/nginx/src/os/unix/ngx_darwin.h +20 -0
  307. data/src/nginx/src/os/unix/ngx_darwin_config.h +96 -0
  308. data/src/nginx/src/os/unix/ngx_darwin_init.c +166 -0
  309. data/src/nginx/src/os/unix/ngx_darwin_sendfile_chain.c +366 -0
  310. data/src/nginx/src/os/unix/ngx_errno.c +87 -0
  311. data/src/nginx/src/os/unix/ngx_errno.h +68 -0
  312. data/src/nginx/src/os/unix/ngx_file_aio_read.c +208 -0
  313. data/src/nginx/src/os/unix/ngx_files.c +566 -0
  314. data/src/nginx/src/os/unix/ngx_files.h +343 -0
  315. data/src/nginx/src/os/unix/ngx_freebsd.h +24 -0
  316. data/src/nginx/src/os/unix/ngx_freebsd_config.h +119 -0
  317. data/src/nginx/src/os/unix/ngx_freebsd_init.c +259 -0
  318. data/src/nginx/src/os/unix/ngx_freebsd_rfork_thread.c +756 -0
  319. data/src/nginx/src/os/unix/ngx_freebsd_rfork_thread.h +122 -0
  320. data/src/nginx/src/os/unix/ngx_freebsd_sendfile_chain.c +436 -0
  321. data/src/nginx/src/os/unix/ngx_gcc_atomic_amd64.h +82 -0
  322. data/src/nginx/src/os/unix/ngx_gcc_atomic_ppc.h +155 -0
  323. data/src/nginx/src/os/unix/ngx_gcc_atomic_sparc64.h +82 -0
  324. data/src/nginx/src/os/unix/ngx_gcc_atomic_x86.h +127 -0
  325. data/src/nginx/src/os/unix/ngx_linux.h +18 -0
  326. data/src/nginx/src/os/unix/ngx_linux_aio_read.c +137 -0
  327. data/src/nginx/src/os/unix/ngx_linux_config.h +117 -0
  328. data/src/nginx/src/os/unix/ngx_linux_init.c +91 -0
  329. data/src/nginx/src/os/unix/ngx_linux_sendfile_chain.c +378 -0
  330. data/src/nginx/src/os/unix/ngx_os.h +84 -0
  331. data/src/nginx/src/os/unix/ngx_posix_config.h +153 -0
  332. data/src/nginx/src/os/unix/ngx_posix_init.c +124 -0
  333. data/src/nginx/src/os/unix/ngx_process.c +590 -0
  334. data/src/nginx/src/os/unix/ngx_process.h +87 -0
  335. data/src/nginx/src/os/unix/ngx_process_cycle.c +1390 -0
  336. data/src/nginx/src/os/unix/ngx_process_cycle.h +61 -0
  337. data/src/nginx/src/os/unix/ngx_pthread_thread.c +278 -0
  338. data/src/nginx/src/os/unix/ngx_readv_chain.c +258 -0
  339. data/src/nginx/src/os/unix/ngx_recv.c +180 -0
  340. data/src/nginx/src/os/unix/ngx_send.c +73 -0
  341. data/src/nginx/src/os/unix/ngx_setproctitle.c +135 -0
  342. data/src/nginx/src/os/unix/ngx_setproctitle.h +52 -0
  343. data/src/nginx/src/os/unix/ngx_shmem.c +126 -0
  344. data/src/nginx/src/os/unix/ngx_shmem.h +29 -0
  345. data/src/nginx/src/os/unix/ngx_socket.c +116 -0
  346. data/src/nginx/src/os/unix/ngx_socket.h +64 -0
  347. data/src/nginx/src/os/unix/ngx_solaris.h +16 -0
  348. data/src/nginx/src/os/unix/ngx_solaris_config.h +107 -0
  349. data/src/nginx/src/os/unix/ngx_solaris_init.c +75 -0
  350. data/src/nginx/src/os/unix/ngx_solaris_sendfilev_chain.c +251 -0
  351. data/src/nginx/src/os/unix/ngx_sunpro_amd64.il +43 -0
  352. data/src/nginx/src/os/unix/ngx_sunpro_atomic_sparc64.h +61 -0
  353. data/src/nginx/src/os/unix/ngx_sunpro_sparc64.il +36 -0
  354. data/src/nginx/src/os/unix/ngx_sunpro_x86.il +44 -0
  355. data/src/nginx/src/os/unix/ngx_thread.h +128 -0
  356. data/src/nginx/src/os/unix/ngx_time.c +104 -0
  357. data/src/nginx/src/os/unix/ngx_time.h +66 -0
  358. data/src/nginx/src/os/unix/ngx_udp_recv.c +115 -0
  359. data/src/nginx/src/os/unix/ngx_user.c +109 -0
  360. data/src/nginx/src/os/unix/ngx_user.h +24 -0
  361. data/src/nginx/src/os/unix/ngx_writev_chain.c +181 -0
  362. data/src/nginx/src/os/unix/rfork_thread.S +73 -0
  363. metadata +419 -0
@@ -0,0 +1,120 @@
1
+
2
+ /*
3
+ * Copyright (C) Igor Sysoev
4
+ * Copyright (C) Nginx, Inc.
5
+ */
6
+
7
+
8
+ #ifndef _NGX_INET_H_INCLUDED_
9
+ #define _NGX_INET_H_INCLUDED_
10
+
11
+
12
+ #include <ngx_config.h>
13
+ #include <ngx_core.h>
14
+
15
+
16
+ /*
17
+ * TODO: autoconfigure NGX_SOCKADDRLEN and NGX_SOCKADDR_STRLEN as
18
+ * sizeof(struct sockaddr_storage)
19
+ * sizeof(struct sockaddr_un)
20
+ * sizeof(struct sockaddr_in6)
21
+ * sizeof(struct sockaddr_in)
22
+ */
23
+
24
+ #define NGX_INET_ADDRSTRLEN (sizeof("255.255.255.255") - 1)
25
+ #define NGX_INET6_ADDRSTRLEN \
26
+ (sizeof("ffff:ffff:ffff:ffff:ffff:ffff:255.255.255.255") - 1)
27
+ #define NGX_UNIX_ADDRSTRLEN \
28
+ (sizeof(struct sockaddr_un) - offsetof(struct sockaddr_un, sun_path))
29
+
30
+ #if (NGX_HAVE_UNIX_DOMAIN)
31
+ #define NGX_SOCKADDR_STRLEN (sizeof("unix:") - 1 + NGX_UNIX_ADDRSTRLEN)
32
+ #else
33
+ #define NGX_SOCKADDR_STRLEN (NGX_INET6_ADDRSTRLEN + sizeof(":65535") - 1)
34
+ #endif
35
+
36
+ #if (NGX_HAVE_UNIX_DOMAIN)
37
+ #define NGX_SOCKADDRLEN sizeof(struct sockaddr_un)
38
+ #else
39
+ #define NGX_SOCKADDRLEN 512
40
+ #endif
41
+
42
+
43
+ typedef struct {
44
+ in_addr_t addr;
45
+ in_addr_t mask;
46
+ } ngx_in_cidr_t;
47
+
48
+
49
+ #if (NGX_HAVE_INET6)
50
+
51
+ typedef struct {
52
+ struct in6_addr addr;
53
+ struct in6_addr mask;
54
+ } ngx_in6_cidr_t;
55
+
56
+ #endif
57
+
58
+
59
+ typedef struct {
60
+ ngx_uint_t family;
61
+ union {
62
+ ngx_in_cidr_t in;
63
+ #if (NGX_HAVE_INET6)
64
+ ngx_in6_cidr_t in6;
65
+ #endif
66
+ } u;
67
+ } ngx_cidr_t;
68
+
69
+
70
+ typedef struct {
71
+ struct sockaddr *sockaddr;
72
+ socklen_t socklen;
73
+ ngx_str_t name;
74
+ } ngx_addr_t;
75
+
76
+
77
+ typedef struct {
78
+ ngx_str_t url;
79
+ ngx_str_t host;
80
+ ngx_str_t port_text;
81
+ ngx_str_t uri;
82
+
83
+ in_port_t port;
84
+ in_port_t default_port;
85
+ int family;
86
+
87
+ unsigned listen:1;
88
+ unsigned uri_part:1;
89
+ unsigned no_resolve:1;
90
+ unsigned one_addr:1;
91
+
92
+ unsigned no_port:1;
93
+ unsigned wildcard:1;
94
+
95
+ socklen_t socklen;
96
+ u_char sockaddr[NGX_SOCKADDRLEN];
97
+
98
+ ngx_addr_t *addrs;
99
+ ngx_uint_t naddrs;
100
+
101
+ char *err;
102
+ } ngx_url_t;
103
+
104
+
105
+ in_addr_t ngx_inet_addr(u_char *text, size_t len);
106
+ #if (NGX_HAVE_INET6)
107
+ ngx_int_t ngx_inet6_addr(u_char *p, size_t len, u_char *addr);
108
+ size_t ngx_inet6_ntop(u_char *p, u_char *text, size_t len);
109
+ #endif
110
+ size_t ngx_sock_ntop(struct sockaddr *sa, u_char *text, size_t len,
111
+ ngx_uint_t port);
112
+ size_t ngx_inet_ntop(int family, void *addr, u_char *text, size_t len);
113
+ ngx_int_t ngx_ptocidr(ngx_str_t *text, ngx_cidr_t *cidr);
114
+ ngx_int_t ngx_parse_addr(ngx_pool_t *pool, ngx_addr_t *addr, u_char *text,
115
+ size_t len);
116
+ ngx_int_t ngx_parse_url(ngx_pool_t *pool, ngx_url_t *u);
117
+ ngx_int_t ngx_inet_resolve_host(ngx_pool_t *pool, ngx_url_t *u);
118
+
119
+
120
+ #endif /* _NGX_INET_H_INCLUDED_ */
@@ -0,0 +1,71 @@
1
+
2
+ /*
3
+ * Copyright (C) Igor Sysoev
4
+ * Copyright (C) Nginx, Inc.
5
+ */
6
+
7
+
8
+ #include <ngx_config.h>
9
+ #include <ngx_core.h>
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
+ list->part.elts = ngx_palloc(pool, n * size);
23
+ if (list->part.elts == NULL) {
24
+ return NULL;
25
+ }
26
+
27
+ list->part.nelts = 0;
28
+ list->part.next = NULL;
29
+ list->last = &list->part;
30
+ list->size = size;
31
+ list->nalloc = n;
32
+ list->pool = pool;
33
+
34
+ return list;
35
+ }
36
+
37
+
38
+ void *
39
+ ngx_list_push(ngx_list_t *l)
40
+ {
41
+ void *elt;
42
+ ngx_list_part_t *last;
43
+
44
+ last = l->last;
45
+
46
+ if (last->nelts == l->nalloc) {
47
+
48
+ /* the last part is full, allocate a new list part */
49
+
50
+ last = ngx_palloc(l->pool, sizeof(ngx_list_part_t));
51
+ if (last == NULL) {
52
+ return NULL;
53
+ }
54
+
55
+ last->elts = ngx_palloc(l->pool, l->nalloc * l->size);
56
+ if (last->elts == NULL) {
57
+ return NULL;
58
+ }
59
+
60
+ last->nelts = 0;
61
+ last->next = NULL;
62
+
63
+ l->last->next = last;
64
+ l->last = last;
65
+ }
66
+
67
+ elt = (char *) last->elts + l->size * last->nelts;
68
+ last->nelts++;
69
+
70
+ return elt;
71
+ }
@@ -0,0 +1,83 @@
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 <ngx_config.h>
13
+ #include <ngx_core.h>
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_ */
@@ -0,0 +1,459 @@
1
+
2
+ /*
3
+ * Copyright (C) Igor Sysoev
4
+ * Copyright (C) Nginx, Inc.
5
+ */
6
+
7
+
8
+ #include <ngx_config.h>
9
+ #include <ngx_core.h>
10
+
11
+
12
+ static char *ngx_error_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf);
13
+
14
+
15
+ static ngx_command_t ngx_errlog_commands[] = {
16
+
17
+ {ngx_string("error_log"),
18
+ NGX_MAIN_CONF|NGX_CONF_1MORE,
19
+ ngx_error_log,
20
+ 0,
21
+ 0,
22
+ NULL},
23
+
24
+ ngx_null_command
25
+ };
26
+
27
+
28
+ static ngx_core_module_t ngx_errlog_module_ctx = {
29
+ ngx_string("errlog"),
30
+ NULL,
31
+ NULL
32
+ };
33
+
34
+
35
+ ngx_module_t ngx_errlog_module = {
36
+ NGX_MODULE_V1,
37
+ &ngx_errlog_module_ctx, /* module context */
38
+ ngx_errlog_commands, /* module directives */
39
+ NGX_CORE_MODULE, /* module type */
40
+ NULL, /* init master */
41
+ NULL, /* init module */
42
+ NULL, /* init process */
43
+ NULL, /* init thread */
44
+ NULL, /* exit thread */
45
+ NULL, /* exit process */
46
+ NULL, /* exit master */
47
+ NGX_MODULE_V1_PADDING
48
+ };
49
+
50
+
51
+ static ngx_log_t ngx_log;
52
+ static ngx_open_file_t ngx_log_file;
53
+ ngx_uint_t ngx_use_stderr = 1;
54
+
55
+
56
+ static ngx_str_t err_levels[] = {
57
+ ngx_null_string,
58
+ ngx_string("emerg"),
59
+ ngx_string("alert"),
60
+ ngx_string("crit"),
61
+ ngx_string("error"),
62
+ ngx_string("warn"),
63
+ ngx_string("notice"),
64
+ ngx_string("info"),
65
+ ngx_string("debug")
66
+ };
67
+
68
+ static const char *debug_levels[] = {
69
+ "debug_core", "debug_alloc", "debug_mutex", "debug_event",
70
+ "debug_http", "debug_mail", "debug_mysql"
71
+ };
72
+
73
+
74
+ #if (NGX_HAVE_VARIADIC_MACROS)
75
+
76
+ void
77
+ ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
78
+ const char *fmt, ...)
79
+
80
+ #else
81
+
82
+ void
83
+ ngx_log_error_core(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
84
+ const char *fmt, va_list args)
85
+
86
+ #endif
87
+ {
88
+ #if (NGX_HAVE_VARIADIC_MACROS)
89
+ va_list args;
90
+ #endif
91
+ u_char *p, *last, *msg;
92
+ u_char errstr[NGX_MAX_ERROR_STR];
93
+
94
+ if (log->file->fd == NGX_INVALID_FILE) {
95
+ return;
96
+ }
97
+
98
+ last = errstr + NGX_MAX_ERROR_STR;
99
+
100
+ ngx_memcpy(errstr, ngx_cached_err_log_time.data,
101
+ ngx_cached_err_log_time.len);
102
+
103
+ p = errstr + ngx_cached_err_log_time.len;
104
+
105
+ p = ngx_slprintf(p, last, " [%V] ", &err_levels[level]);
106
+
107
+ /* pid#tid */
108
+ p = ngx_slprintf(p, last, "%P#" NGX_TID_T_FMT ": ",
109
+ ngx_log_pid, ngx_log_tid);
110
+
111
+ if (log->connection) {
112
+ p = ngx_slprintf(p, last, "*%uA ", log->connection);
113
+ }
114
+
115
+ msg = p;
116
+
117
+ #if (NGX_HAVE_VARIADIC_MACROS)
118
+
119
+ va_start(args, fmt);
120
+ p = ngx_vslprintf(p, last, fmt, args);
121
+ va_end(args);
122
+
123
+ #else
124
+
125
+ p = ngx_vslprintf(p, last, fmt, args);
126
+
127
+ #endif
128
+
129
+ if (err) {
130
+ p = ngx_log_errno(p, last, err);
131
+ }
132
+
133
+ if (level != NGX_LOG_DEBUG && log->handler) {
134
+ p = log->handler(log, p, last - p);
135
+ }
136
+
137
+ if (p > last - NGX_LINEFEED_SIZE) {
138
+ p = last - NGX_LINEFEED_SIZE;
139
+ }
140
+
141
+ ngx_linefeed(p);
142
+
143
+ (void) ngx_write_fd(log->file->fd, errstr, p - errstr);
144
+
145
+ if (!ngx_use_stderr
146
+ || level > NGX_LOG_WARN
147
+ || log->file->fd == ngx_stderr)
148
+ {
149
+ return;
150
+ }
151
+
152
+ msg -= (7 + err_levels[level].len + 3);
153
+
154
+ (void) ngx_sprintf(msg, "nginx: [%V] ", &err_levels[level]);
155
+
156
+ (void) ngx_write_console(ngx_stderr, msg, p - msg);
157
+ }
158
+
159
+
160
+ #if !(NGX_HAVE_VARIADIC_MACROS)
161
+
162
+ void ngx_cdecl
163
+ ngx_log_error(ngx_uint_t level, ngx_log_t *log, ngx_err_t err,
164
+ const char *fmt, ...)
165
+ {
166
+ va_list args;
167
+
168
+ if (log->log_level >= level) {
169
+ va_start(args, fmt);
170
+ ngx_log_error_core(level, log, err, fmt, args);
171
+ va_end(args);
172
+ }
173
+ }
174
+
175
+
176
+ void ngx_cdecl
177
+ ngx_log_debug_core(ngx_log_t *log, ngx_err_t err, const char *fmt, ...)
178
+ {
179
+ va_list args;
180
+
181
+ va_start(args, fmt);
182
+ ngx_log_error_core(NGX_LOG_DEBUG, log, err, fmt, args);
183
+ va_end(args);
184
+ }
185
+
186
+ #endif
187
+
188
+
189
+ void ngx_cdecl
190
+ ngx_log_abort(ngx_err_t err, const char *fmt, ...)
191
+ {
192
+ u_char *p;
193
+ va_list args;
194
+ u_char errstr[NGX_MAX_CONF_ERRSTR];
195
+
196
+ va_start(args, fmt);
197
+ p = ngx_vsnprintf(errstr, sizeof(errstr) - 1, fmt, args);
198
+ va_end(args);
199
+
200
+ ngx_log_error(NGX_LOG_ALERT, ngx_cycle->log, err,
201
+ "%*s", p - errstr, errstr);
202
+ }
203
+
204
+
205
+ void ngx_cdecl
206
+ ngx_log_stderr(ngx_err_t err, const char *fmt, ...)
207
+ {
208
+ u_char *p, *last;
209
+ va_list args;
210
+ u_char errstr[NGX_MAX_ERROR_STR];
211
+
212
+ last = errstr + NGX_MAX_ERROR_STR;
213
+ p = errstr + 7;
214
+
215
+ ngx_memcpy(errstr, "nginx: ", 7);
216
+
217
+ va_start(args, fmt);
218
+ p = ngx_vslprintf(p, last, fmt, args);
219
+ va_end(args);
220
+
221
+ if (err) {
222
+ p = ngx_log_errno(p, last, err);
223
+ }
224
+
225
+ if (p > last - NGX_LINEFEED_SIZE) {
226
+ p = last - NGX_LINEFEED_SIZE;
227
+ }
228
+
229
+ ngx_linefeed(p);
230
+
231
+ (void) ngx_write_console(ngx_stderr, errstr, p - errstr);
232
+ }
233
+
234
+
235
+ u_char *
236
+ ngx_log_errno(u_char *buf, u_char *last, ngx_err_t err)
237
+ {
238
+ if (buf > last - 50) {
239
+
240
+ /* leave a space for an error code */
241
+
242
+ buf = last - 50;
243
+ *buf++ = '.';
244
+ *buf++ = '.';
245
+ *buf++ = '.';
246
+ }
247
+
248
+ #if (NGX_WIN32)
249
+ buf = ngx_slprintf(buf, last, ((unsigned) err < 0x80000000)
250
+ ? " (%d: " : " (%Xd: ", err);
251
+ #else
252
+ buf = ngx_slprintf(buf, last, " (%d: ", err);
253
+ #endif
254
+
255
+ buf = ngx_strerror(err, buf, last - buf);
256
+
257
+ if (buf < last) {
258
+ *buf++ = ')';
259
+ }
260
+
261
+ return buf;
262
+ }
263
+
264
+
265
+ ngx_log_t *
266
+ ngx_log_init(u_char *prefix)
267
+ {
268
+ u_char *p, *name;
269
+ size_t nlen, plen;
270
+
271
+ ngx_log.file = &ngx_log_file;
272
+ ngx_log.log_level = NGX_LOG_NOTICE;
273
+
274
+ name = (u_char *) NGX_ERROR_LOG_PATH;
275
+
276
+ /*
277
+ * we use ngx_strlen() here since BCC warns about
278
+ * condition is always false and unreachable code
279
+ */
280
+
281
+ nlen = ngx_strlen(name);
282
+
283
+ if (nlen == 0) {
284
+ ngx_log_file.fd = ngx_stderr;
285
+ return &ngx_log;
286
+ }
287
+
288
+ p = NULL;
289
+
290
+ #if (NGX_WIN32)
291
+ if (name[1] != ':') {
292
+ #else
293
+ if (name[0] != '/') {
294
+ #endif
295
+
296
+ if (prefix) {
297
+ plen = ngx_strlen(prefix);
298
+
299
+ } else {
300
+ #ifdef NGX_PREFIX
301
+ prefix = (u_char *) NGX_PREFIX;
302
+ plen = ngx_strlen(prefix);
303
+ #else
304
+ plen = 0;
305
+ #endif
306
+ }
307
+
308
+ if (plen) {
309
+ name = malloc(plen + nlen + 2);
310
+ if (name == NULL) {
311
+ return NULL;
312
+ }
313
+
314
+ p = ngx_cpymem(name, prefix, plen);
315
+
316
+ if (!ngx_path_separator(*(p - 1))) {
317
+ *p++ = '/';
318
+ }
319
+
320
+ ngx_cpystrn(p, (u_char *) NGX_ERROR_LOG_PATH, nlen + 1);
321
+
322
+ p = name;
323
+ }
324
+ }
325
+
326
+ ngx_log_file.fd = ngx_open_file(name, NGX_FILE_APPEND,
327
+ NGX_FILE_CREATE_OR_OPEN,
328
+ NGX_FILE_DEFAULT_ACCESS);
329
+
330
+ if (ngx_log_file.fd == NGX_INVALID_FILE) {
331
+ ngx_log_stderr(ngx_errno,
332
+ "[alert] could not open error log file: "
333
+ ngx_open_file_n " \"%s\" failed", name);
334
+ #if (NGX_WIN32)
335
+ ngx_event_log(ngx_errno,
336
+ "could not open error log file: "
337
+ ngx_open_file_n " \"%s\" failed", name);
338
+ #endif
339
+
340
+ ngx_log_file.fd = ngx_stderr;
341
+ }
342
+
343
+ if (p) {
344
+ ngx_free(p);
345
+ }
346
+
347
+ return &ngx_log;
348
+ }
349
+
350
+
351
+ ngx_log_t *
352
+ ngx_log_create(ngx_cycle_t *cycle, ngx_str_t *name)
353
+ {
354
+ ngx_log_t *log;
355
+
356
+ log = ngx_pcalloc(cycle->pool, sizeof(ngx_log_t));
357
+ if (log == NULL) {
358
+ return NULL;
359
+ }
360
+
361
+ log->file = ngx_conf_open_file(cycle, name);
362
+ if (log->file == NULL) {
363
+ return NULL;
364
+ }
365
+
366
+ return log;
367
+ }
368
+
369
+
370
+ char *
371
+ ngx_log_set_levels(ngx_conf_t *cf, ngx_log_t *log)
372
+ {
373
+ ngx_uint_t i, n, d, found;
374
+ ngx_str_t *value;
375
+
376
+ value = cf->args->elts;
377
+
378
+ for (i = 2; i < cf->args->nelts; i++) {
379
+ found = 0;
380
+
381
+ for (n = 1; n <= NGX_LOG_DEBUG; n++) {
382
+ if (ngx_strcmp(value[i].data, err_levels[n].data) == 0) {
383
+
384
+ if (log->log_level != 0) {
385
+ ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
386
+ "duplicate log level \"%V\"",
387
+ &value[i]);
388
+ return NGX_CONF_ERROR;
389
+ }
390
+
391
+ log->log_level = n;
392
+ found = 1;
393
+ break;
394
+ }
395
+ }
396
+
397
+ for (n = 0, d = NGX_LOG_DEBUG_FIRST; d <= NGX_LOG_DEBUG_LAST; d <<= 1) {
398
+ if (ngx_strcmp(value[i].data, debug_levels[n++]) == 0) {
399
+ if (log->log_level & ~NGX_LOG_DEBUG_ALL) {
400
+ ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
401
+ "invalid log level \"%V\"",
402
+ &value[i]);
403
+ return NGX_CONF_ERROR;
404
+ }
405
+
406
+ log->log_level |= d;
407
+ found = 1;
408
+ break;
409
+ }
410
+ }
411
+
412
+
413
+ if (!found) {
414
+ ngx_conf_log_error(NGX_LOG_EMERG, cf, 0,
415
+ "invalid log level \"%V\"", &value[i]);
416
+ return NGX_CONF_ERROR;
417
+ }
418
+ }
419
+
420
+ if (log->log_level == NGX_LOG_DEBUG) {
421
+ log->log_level = NGX_LOG_DEBUG_ALL;
422
+ }
423
+
424
+ return NGX_CONF_OK;
425
+ }
426
+
427
+
428
+ static char *
429
+ ngx_error_log(ngx_conf_t *cf, ngx_command_t *cmd, void *conf)
430
+ {
431
+ ngx_str_t *value, name;
432
+
433
+ if (cf->cycle->new_log.file) {
434
+ return "is duplicate";
435
+ }
436
+
437
+ value = cf->args->elts;
438
+
439
+ if (ngx_strcmp(value[1].data, "stderr") == 0) {
440
+ ngx_str_null(&name);
441
+
442
+ } else {
443
+ name = value[1];
444
+ }
445
+
446
+ cf->cycle->new_log.file = ngx_conf_open_file(cf->cycle, &name);
447
+ if (cf->cycle->new_log.file == NULL) {
448
+ return NULL;
449
+ }
450
+
451
+ if (cf->args->nelts == 2) {
452
+ cf->cycle->new_log.log_level = NGX_LOG_ERR;
453
+ return NGX_CONF_OK;
454
+ }
455
+
456
+ cf->cycle->new_log.log_level = 0;
457
+
458
+ return ngx_log_set_levels(cf, &cf->cycle->new_log);
459
+ }