passenger 6.0.10 → 6.0.13

Sign up to get free protection for your applications and to get access to all the features.
Files changed (448) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG +84 -1
  3. data/CONTRIBUTORS +4 -0
  4. data/bin/passenger-install-nginx-module +2 -1
  5. data/build/common_library.rb +1 -1
  6. data/dev/copy_boost_headers +48 -16
  7. data/dev/index_cxx_dependencies.rb +1 -1
  8. data/dev/webpacketpp.patch +39 -0
  9. data/package.json +1 -1
  10. data/resources/mime.types +1 -0
  11. data/resources/templates/standalone/server.erb +1 -0
  12. data/src/agent/Core/ApplicationPool/Group/StateInspection.cpp +1 -0
  13. data/src/agent/Core/ApplicationPool/Options.h +5 -0
  14. data/src/agent/Core/Config.h +1 -1
  15. data/src/agent/Core/Controller/CheckoutSession.cpp +24 -13
  16. data/src/agent/Core/Controller/Config.h +5 -2
  17. data/src/agent/Core/Controller/InitRequest.cpp +2 -0
  18. data/src/agent/Core/Controller/InternalUtils.cpp +32 -6
  19. data/src/agent/Core/Controller.h +4 -1
  20. data/src/agent/Core/OptionParser.h +4 -0
  21. data/src/agent/Core/SpawningKit/Config/AutoGeneratedCode.h +7 -0
  22. data/src/agent/Core/SpawningKit/Config.h +13 -0
  23. data/src/agent/Core/SpawningKit/Handshake/Prepare.h +4 -0
  24. data/src/agent/Core/SpawningKit/Spawner.h +1 -0
  25. data/src/agent/SpawnEnvSetupper/SpawnEnvSetupperMain.cpp +4 -0
  26. data/src/agent/Watchdog/Config.h +1 -1
  27. data/src/apache2_module/ConfigGeneral/AutoGeneratedDefinitions.cpp +5 -0
  28. data/src/apache2_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.cpp +5 -0
  29. data/src/apache2_module/ConfigGeneral/AutoGeneratedSetterFuncs.cpp +18 -0
  30. data/src/apache2_module/DirConfig/AutoGeneratedCreateFunction.cpp +3 -0
  31. data/src/apache2_module/DirConfig/AutoGeneratedHeaderSerialization.cpp +3 -0
  32. data/src/apache2_module/DirConfig/AutoGeneratedManifestGeneration.cpp +11 -0
  33. data/src/apache2_module/DirConfig/AutoGeneratedMergeFunction.cpp +7 -0
  34. data/src/apache2_module/DirConfig/AutoGeneratedStruct.h +17 -0
  35. data/src/apache2_module/Hooks.cpp +1 -0
  36. data/src/cxx_supportlib/Constants.h +1 -1
  37. data/src/cxx_supportlib/IOTools/IOUtils.cpp +4 -4
  38. data/src/cxx_supportlib/vendor-modified/boost/align/align.hpp +19 -0
  39. data/src/cxx_supportlib/vendor-modified/boost/align/aligned_alloc.hpp +47 -0
  40. data/src/cxx_supportlib/vendor-modified/boost/align/alignment_of.hpp +54 -0
  41. data/src/cxx_supportlib/vendor-modified/boost/align/alignment_of_forward.hpp +20 -0
  42. data/src/cxx_supportlib/vendor-modified/boost/align/detail/align_cxx11.hpp +21 -0
  43. data/src/cxx_supportlib/vendor-modified/boost/align/detail/aligned_alloc.hpp +52 -0
  44. data/src/cxx_supportlib/vendor-modified/boost/align/detail/aligned_alloc_posix.hpp +41 -0
  45. data/src/cxx_supportlib/vendor-modified/boost/align/detail/alignment_of.hpp +31 -0
  46. data/src/cxx_supportlib/vendor-modified/boost/align/detail/alignment_of_cxx11.hpp +23 -0
  47. data/src/cxx_supportlib/vendor-modified/boost/align/detail/element_type.hpp +91 -0
  48. data/src/cxx_supportlib/vendor-modified/boost/align/detail/integral_constant.hpp +53 -0
  49. data/src/cxx_supportlib/vendor-modified/boost/align/detail/is_alignment.hpp +28 -0
  50. data/src/cxx_supportlib/vendor-modified/boost/align/detail/min_size.hpp +26 -0
  51. data/src/cxx_supportlib/vendor-modified/boost/asio/associated_allocator.hpp +53 -1
  52. data/src/cxx_supportlib/vendor-modified/boost/asio/associated_cancellation_slot.hpp +179 -0
  53. data/src/cxx_supportlib/vendor-modified/boost/asio/associated_executor.hpp +57 -1
  54. data/src/cxx_supportlib/vendor-modified/boost/asio/associator.hpp +37 -0
  55. data/src/cxx_supportlib/vendor-modified/boost/asio/async_result.hpp +789 -106
  56. data/src/cxx_supportlib/vendor-modified/boost/asio/awaitable.hpp +1 -1
  57. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_datagram_socket.hpp +80 -0
  58. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_deadline_timer.hpp +10 -0
  59. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_raw_socket.hpp +80 -0
  60. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_seq_packet_socket.hpp +30 -0
  61. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket.hpp +20 -0
  62. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket_acceptor.hpp +90 -0
  63. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_stream_socket.hpp +60 -0
  64. data/src/cxx_supportlib/vendor-modified/boost/asio/basic_waitable_timer.hpp +10 -0
  65. data/src/cxx_supportlib/vendor-modified/boost/asio/bind_cancellation_slot.hpp +723 -0
  66. data/src/cxx_supportlib/vendor-modified/boost/asio/bind_executor.hpp +191 -12
  67. data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_signal.hpp +361 -0
  68. data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_state.hpp +237 -0
  69. data/src/cxx_supportlib/vendor-modified/boost/asio/cancellation_type.hpp +176 -0
  70. data/src/cxx_supportlib/vendor-modified/boost/asio/co_spawn.hpp +30 -2
  71. data/src/cxx_supportlib/vendor-modified/boost/asio/connect.hpp +60 -0
  72. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/base_from_cancellation_state.hpp +165 -0
  73. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/bind_handler.hpp +209 -76
  74. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/config.hpp +149 -60
  75. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/deadline_timer_service.hpp +40 -0
  76. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/dev_poll_reactor.hpp +8 -4
  77. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/epoll_reactor.hpp +14 -4
  78. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/functional.hpp +6 -0
  79. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_alloc_helpers.hpp +14 -10
  80. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_type_requirements.hpp +21 -18
  81. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_work.hpp +30 -19
  82. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.hpp +8 -0
  83. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.ipp +14 -0
  84. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.hpp +20 -0
  85. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.ipp +30 -0
  86. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.hpp +20 -0
  87. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.ipp +29 -0
  88. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.hpp +24 -0
  89. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.ipp +19 -0
  90. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/strand_executor_service.hpp +3 -1
  91. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/timer_queue_ptime.ipp +6 -0
  92. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/kqueue_reactor.hpp +15 -5
  93. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/memory.hpp +60 -0
  94. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/pop_options.hpp +8 -0
  95. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/push_options.hpp +27 -0
  96. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_descriptor_service.hpp +93 -0
  97. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service.hpp +77 -0
  98. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service_base.hpp +111 -0
  99. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op.hpp +4 -0
  100. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op_queue.hpp +44 -0
  101. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/recycling_allocator.hpp +2 -1
  102. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolve_endpoint_op.hpp +2 -2
  103. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/select_reactor.hpp +14 -4
  104. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/thread_info_base.hpp +90 -24
  105. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue.hpp +30 -1
  106. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue_ptime.hpp +4 -0
  107. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/wait_op.hpp +5 -1
  108. data/src/cxx_supportlib/vendor-modified/boost/asio/detail/work_dispatcher.hpp +5 -2
  109. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/any_executor.hpp +12 -12
  110. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/bulk_execute.hpp +10 -8
  111. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/connect.hpp +8 -8
  112. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/execute.hpp +7 -7
  113. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/schedule.hpp +7 -7
  114. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_done.hpp +7 -7
  115. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_error.hpp +7 -7
  116. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/set_value.hpp +13 -13
  117. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/start.hpp +7 -7
  118. data/src/cxx_supportlib/vendor-modified/boost/asio/execution/submit.hpp +8 -8
  119. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/append.hpp +73 -0
  120. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/as_tuple.hpp +133 -0
  121. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/awaitable_operators.hpp +538 -0
  122. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/cancellation_condition.hpp +157 -0
  123. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/coro.hpp +1057 -0
  124. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/deferred.hpp +607 -0
  125. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/completion_handler_erasure.hpp +160 -0
  126. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/coro_promise_allocator.hpp +120 -0
  127. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/coro_traits.hpp +185 -0
  128. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/detail/partial_promise.hpp +181 -0
  129. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/append.hpp +219 -0
  130. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/as_single.hpp +14 -28
  131. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/as_tuple.hpp +248 -0
  132. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/deferred.hpp +106 -0
  133. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/parallel_group.hpp +434 -0
  134. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/prepend.hpp +219 -0
  135. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/impl/promise.hpp +100 -0
  136. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/parallel_group.hpp +217 -0
  137. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/prepend.hpp +73 -0
  138. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/promise.hpp +608 -0
  139. data/src/cxx_supportlib/vendor-modified/boost/asio/experimental/use_coro.hpp +284 -0
  140. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/awaitable.hpp +344 -20
  141. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_read_stream.hpp +23 -54
  142. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_write_stream.hpp +23 -54
  143. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/co_spawn.hpp +66 -18
  144. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/compose.hpp +55 -5
  145. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/connect.hpp +68 -80
  146. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/defer.hpp +8 -4
  147. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/dispatch.hpp +8 -4
  148. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/handler_alloc_hook.ipp +3 -2
  149. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/post.hpp +8 -4
  150. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read.hpp +98 -113
  151. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_at.hpp +71 -82
  152. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_until.hpp +210 -266
  153. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/redirect_error.hpp +248 -30
  154. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/spawn.hpp +11 -21
  155. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/use_awaitable.hpp +15 -3
  156. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write.hpp +71 -87
  157. data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write_at.hpp +46 -68
  158. data/src/cxx_supportlib/vendor-modified/boost/asio/io_context.hpp +4 -4
  159. data/src/cxx_supportlib/vendor-modified/boost/asio/local/detail/impl/endpoint.ipp +2 -7
  160. data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_descriptor.hpp +10 -0
  161. data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_stream_descriptor.hpp +23 -3
  162. data/src/cxx_supportlib/vendor-modified/boost/asio/prefer.hpp +21 -21
  163. data/src/cxx_supportlib/vendor-modified/boost/asio/query.hpp +9 -9
  164. data/src/cxx_supportlib/vendor-modified/boost/asio/read.hpp +88 -0
  165. data/src/cxx_supportlib/vendor-modified/boost/asio/read_at.hpp +44 -0
  166. data/src/cxx_supportlib/vendor-modified/boost/asio/read_until.hpp +132 -0
  167. data/src/cxx_supportlib/vendor-modified/boost/asio/require.hpp +21 -21
  168. data/src/cxx_supportlib/vendor-modified/boost/asio/require_concept.hpp +9 -9
  169. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/buffered_handshake_op.hpp +1 -1
  170. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/engine.hpp +5 -0
  171. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/handshake_op.hpp +1 -1
  172. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/impl/engine.ipp +14 -0
  173. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/io.hpp +36 -27
  174. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/read_op.hpp +1 -1
  175. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/shutdown_op.hpp +2 -2
  176. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/stream_core.hpp +37 -0
  177. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/write_op.hpp +1 -1
  178. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/context.ipp +14 -7
  179. data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream.hpp +73 -1
  180. data/src/cxx_supportlib/vendor-modified/boost/asio/system_executor.hpp +4 -4
  181. data/src/cxx_supportlib/vendor-modified/boost/asio/this_coro.hpp +235 -0
  182. data/src/cxx_supportlib/vendor-modified/boost/asio/thread_pool.hpp +4 -4
  183. data/src/cxx_supportlib/vendor-modified/boost/asio/use_awaitable.hpp +7 -10
  184. data/src/cxx_supportlib/vendor-modified/boost/asio/version.hpp +1 -1
  185. data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_random_access_handle.hpp +20 -0
  186. data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_stream_handle.hpp +20 -0
  187. data/src/cxx_supportlib/vendor-modified/boost/asio/write.hpp +88 -0
  188. data/src/cxx_supportlib/vendor-modified/boost/asio/write_at.hpp +44 -0
  189. data/src/cxx_supportlib/vendor-modified/boost/asio.hpp +6 -0
  190. data/src/cxx_supportlib/vendor-modified/boost/atomic/atomic_ref.hpp +14 -1
  191. data/src/cxx_supportlib/vendor-modified/boost/atomic/detail/config.hpp +17 -13
  192. data/src/cxx_supportlib/vendor-modified/boost/atomic/ipc_atomic_ref.hpp +14 -1
  193. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx03.hpp +2 -5
  194. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx11.hpp +2 -5
  195. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx14.hpp +2 -2
  196. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx17.hpp +2 -2
  197. data/src/cxx_supportlib/vendor-modified/boost/config/assert_cxx20.hpp +56 -0
  198. data/src/cxx_supportlib/vendor-modified/boost/config/auto_link.hpp +1 -5
  199. data/src/cxx_supportlib/vendor-modified/boost/config/compiler/common_edg.hpp +31 -11
  200. data/src/cxx_supportlib/vendor-modified/boost/config/detail/cxx_composite.hpp +20 -4
  201. data/src/cxx_supportlib/vendor-modified/boost/config/detail/select_platform_config.hpp +5 -0
  202. data/src/cxx_supportlib/vendor-modified/boost/config/detail/suffix.hpp +81 -0
  203. data/src/cxx_supportlib/vendor-modified/boost/config/platform/bsd.hpp +5 -8
  204. data/src/cxx_supportlib/vendor-modified/boost/config/platform/wasm.hpp +17 -0
  205. data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/dinkumware.hpp +26 -0
  206. data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libcpp.hpp +49 -0
  207. data/src/cxx_supportlib/vendor-modified/boost/config/stdlib/libstdcpp3.hpp +46 -4
  208. data/src/cxx_supportlib/vendor-modified/boost/container/adaptive_pool.hpp +2 -2
  209. data/src/cxx_supportlib/vendor-modified/boost/container/allocator.hpp +1 -1
  210. data/src/cxx_supportlib/vendor-modified/boost/container/detail/adaptive_node_pool.hpp +2 -2
  211. data/src/cxx_supportlib/vendor-modified/boost/container/detail/node_pool.hpp +2 -2
  212. data/src/cxx_supportlib/vendor-modified/boost/container/detail/std_fwd.hpp +3 -0
  213. data/src/cxx_supportlib/vendor-modified/boost/container/devector.hpp +2 -2
  214. data/src/cxx_supportlib/vendor-modified/boost/container/new_allocator.hpp +1 -1
  215. data/src/cxx_supportlib/vendor-modified/boost/container/node_allocator.hpp +1 -1
  216. data/src/cxx_supportlib/vendor-modified/boost/container/pmr/polymorphic_allocator.hpp +6 -6
  217. data/src/cxx_supportlib/vendor-modified/boost/container/static_vector.hpp +4 -4
  218. data/src/cxx_supportlib/vendor-modified/boost/container/throw_exception.hpp +45 -38
  219. data/src/cxx_supportlib/vendor-modified/boost/container/vector.hpp +24 -0
  220. data/src/cxx_supportlib/vendor-modified/boost/core/ignore_unused.hpp +32 -2
  221. data/src/cxx_supportlib/vendor-modified/boost/core/uncaught_exceptions.hpp +7 -7
  222. data/src/cxx_supportlib/vendor-modified/boost/date_time/compiler_config.hpp +0 -24
  223. data/src/cxx_supportlib/vendor-modified/boost/date_time/posix_time/time_parsers.hpp +4 -0
  224. data/src/cxx_supportlib/vendor-modified/boost/intrusive/any_hook.hpp +4 -4
  225. data/src/cxx_supportlib/vendor-modified/boost/intrusive/avl_set.hpp +83 -83
  226. data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree.hpp +43 -43
  227. data/src/cxx_supportlib/vendor-modified/boost/intrusive/avltree_algorithms.hpp +31 -31
  228. data/src/cxx_supportlib/vendor-modified/boost/intrusive/bs_set.hpp +85 -85
  229. data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree.hpp +68 -68
  230. data/src/cxx_supportlib/vendor-modified/boost/intrusive/bstree_algorithms.hpp +72 -62
  231. data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_list_algorithms.hpp +19 -20
  232. data/src/cxx_supportlib/vendor-modified/boost/intrusive/circular_slist_algorithms.hpp +19 -19
  233. data/src/cxx_supportlib/vendor-modified/boost/intrusive/derivation_value_traits.hpp +4 -4
  234. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/any_node_and_algorithms.hpp +2 -2
  235. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/bstree_algorithms_base.hpp +3 -3
  236. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/common_slist_algorithms.hpp +5 -5
  237. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/config_begin.hpp +1 -0
  238. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/generic_hook.hpp +8 -8
  239. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hash_combine.hpp +2 -4
  240. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/hashtable_node.hpp +1 -1
  241. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/math.hpp +2 -50
  242. data/src/cxx_supportlib/vendor-modified/boost/intrusive/detail/node_cloner_disposer.hpp +1 -1
  243. data/src/cxx_supportlib/vendor-modified/boost/intrusive/hashtable.hpp +71 -70
  244. data/src/cxx_supportlib/vendor-modified/boost/intrusive/linear_slist_algorithms.hpp +15 -14
  245. data/src/cxx_supportlib/vendor-modified/boost/intrusive/list.hpp +84 -82
  246. data/src/cxx_supportlib/vendor-modified/boost/intrusive/list_hook.hpp +10 -10
  247. data/src/cxx_supportlib/vendor-modified/boost/intrusive/member_value_traits.hpp +4 -4
  248. data/src/cxx_supportlib/vendor-modified/boost/intrusive/parent_from_member.hpp +2 -2
  249. data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_plus_bits.hpp +4 -4
  250. data/src/cxx_supportlib/vendor-modified/boost/intrusive/pointer_traits.hpp +18 -18
  251. data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree.hpp +43 -43
  252. data/src/cxx_supportlib/vendor-modified/boost/intrusive/rbtree_algorithms.hpp +26 -26
  253. data/src/cxx_supportlib/vendor-modified/boost/intrusive/set.hpp +85 -85
  254. data/src/cxx_supportlib/vendor-modified/boost/intrusive/set_hook.hpp +12 -12
  255. data/src/cxx_supportlib/vendor-modified/boost/intrusive/sg_set.hpp +93 -93
  256. data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree.hpp +51 -51
  257. data/src/cxx_supportlib/vendor-modified/boost/intrusive/sgtree_algorithms.hpp +24 -24
  258. data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist.hpp +104 -104
  259. data/src/cxx_supportlib/vendor-modified/boost/intrusive/slist_hook.hpp +8 -6
  260. data/src/cxx_supportlib/vendor-modified/boost/intrusive/splay_set.hpp +91 -91
  261. data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree.hpp +46 -46
  262. data/src/cxx_supportlib/vendor-modified/boost/intrusive/splaytree_algorithms.hpp +31 -31
  263. data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap.hpp +51 -51
  264. data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_algorithms.hpp +18 -18
  265. data/src/cxx_supportlib/vendor-modified/boost/intrusive/treap_set.hpp +97 -97
  266. data/src/cxx_supportlib/vendor-modified/boost/intrusive/trivial_value_traits.hpp +6 -4
  267. data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set.hpp +63 -63
  268. data/src/cxx_supportlib/vendor-modified/boost/intrusive/unordered_set_hook.hpp +15 -15
  269. data/src/cxx_supportlib/vendor-modified/boost/lexical_cast/detail/converter_numeric.hpp +4 -1
  270. data/src/cxx_supportlib/vendor-modified/boost/move/detail/config_begin.hpp +1 -0
  271. data/src/cxx_supportlib/vendor-modified/boost/move/detail/iterator_traits.hpp +1 -0
  272. data/src/cxx_supportlib/vendor-modified/boost/move/detail/nsec_clock.hpp +1 -1
  273. data/src/cxx_supportlib/vendor-modified/boost/operators.hpp +2 -0
  274. data/src/cxx_supportlib/vendor-modified/boost/regex/concepts.hpp +1 -1
  275. data/src/cxx_supportlib/vendor-modified/boost/regex/v4/basic_regex_parser.hpp +3 -0
  276. data/src/cxx_supportlib/vendor-modified/boost/regex/v4/unicode_iterator.hpp +112 -31
  277. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/basic_regex_parser.hpp +3 -0
  278. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/mem_block_cache.hpp +4 -8
  279. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/unicode_iterator.hpp +0 -2
  280. data/src/cxx_supportlib/vendor-modified/boost/regex/v5/w32_regex_traits.hpp +6 -2
  281. data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/shared_count.hpp +1 -1
  282. data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_counted_impl.hpp +22 -2
  283. data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/detail/sp_obsolete.hpp +32 -0
  284. data/src/cxx_supportlib/vendor-modified/boost/smart_ptr/shared_ptr.hpp +59 -1
  285. data/src/cxx_supportlib/vendor-modified/boost/system/detail/config.hpp +9 -11
  286. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_category.hpp +27 -21
  287. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_category_impl.hpp +34 -3
  288. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_code.hpp +378 -36
  289. data/src/cxx_supportlib/vendor-modified/boost/system/detail/error_condition.hpp +97 -21
  290. data/src/cxx_supportlib/vendor-modified/boost/system/detail/interop_category.hpp +107 -0
  291. data/src/cxx_supportlib/vendor-modified/boost/system/detail/is_same.hpp +33 -0
  292. data/src/cxx_supportlib/vendor-modified/boost/system/detail/snprintf.hpp +70 -0
  293. data/src/cxx_supportlib/vendor-modified/boost/system/detail/{to_std_category.hpp → std_category.hpp} +5 -55
  294. data/src/cxx_supportlib/vendor-modified/boost/system/detail/system_category_impl.hpp +2 -12
  295. data/src/cxx_supportlib/vendor-modified/boost/system/error_code.hpp +0 -33
  296. data/src/cxx_supportlib/vendor-modified/boost/utility/detail/result_of_variadic.hpp +190 -0
  297. data/src/cxx_supportlib/vendor-modified/boost/utility/result_of.hpp +20 -9
  298. data/src/cxx_supportlib/vendor-modified/boost/utility/string_view.hpp +3 -1
  299. data/src/cxx_supportlib/vendor-modified/boost/version.hpp +2 -2
  300. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/COPYING +0 -0
  301. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/changelog.md +0 -0
  302. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/readme.md +0 -0
  303. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/base64/base64.hpp +0 -0
  304. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/client.hpp +0 -0
  305. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/close.hpp +0 -0
  306. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/asio.hpp +0 -0
  307. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/asio_ssl.hpp +0 -0
  308. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/chrono.hpp +0 -0
  309. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/connection_hdl.hpp +0 -0
  310. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/cpp11.hpp +0 -0
  311. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/functional.hpp +2 -7
  312. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/md5.hpp +0 -0
  313. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/memory.hpp +0 -0
  314. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/network.hpp +0 -0
  315. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/platforms.hpp +0 -0
  316. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/random.hpp +0 -0
  317. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/regex.hpp +0 -0
  318. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/stdint.hpp +0 -0
  319. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/system_error.hpp +0 -0
  320. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/thread.hpp +0 -0
  321. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/time.hpp +0 -0
  322. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/common/type_traits.hpp +0 -0
  323. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/concurrency/basic.hpp +0 -0
  324. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/concurrency/none.hpp +0 -0
  325. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/asio.hpp +0 -0
  326. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/asio_client.hpp +0 -0
  327. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/asio_no_tls.hpp +0 -0
  328. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/asio_no_tls_client.hpp +0 -0
  329. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/boost_config.hpp +0 -0
  330. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/core.hpp +0 -0
  331. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/core_client.hpp +0 -0
  332. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/debug.hpp +0 -0
  333. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/debug_asio.hpp +0 -0
  334. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/debug_asio_no_tls.hpp +0 -0
  335. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/minimal_client.hpp +0 -0
  336. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/config/minimal_server.hpp +0 -0
  337. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/connection.hpp +0 -0
  338. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/connection_base.hpp +0 -0
  339. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/endpoint.hpp +0 -0
  340. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/endpoint_base.hpp +0 -0
  341. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/error.hpp +0 -0
  342. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/extensions/extension.hpp +0 -0
  343. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/extensions/permessage_deflate/disabled.hpp +0 -0
  344. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/extensions/permessage_deflate/enabled.hpp +0 -0
  345. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/frame.hpp +0 -0
  346. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/http/constants.hpp +0 -0
  347. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/http/impl/parser.hpp +0 -0
  348. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/http/impl/request.hpp +0 -0
  349. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/http/impl/response.hpp +0 -0
  350. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/http/parser.hpp +0 -0
  351. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/http/request.hpp +0 -0
  352. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/http/response.hpp +0 -0
  353. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/impl/connection_impl.hpp +0 -0
  354. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/impl/endpoint_impl.hpp +0 -0
  355. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/impl/utilities_impl.hpp +0 -0
  356. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/logger/basic.hpp +0 -0
  357. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/logger/levels.hpp +0 -0
  358. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/logger/stub.hpp +0 -0
  359. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/logger/syslog.hpp +0 -0
  360. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/message_buffer/alloc.hpp +0 -0
  361. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/message_buffer/message.hpp +0 -0
  362. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/message_buffer/pool.hpp +0 -0
  363. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/processors/base.hpp +0 -0
  364. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/processors/hybi00.hpp +0 -0
  365. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/processors/hybi07.hpp +0 -0
  366. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/processors/hybi08.hpp +0 -0
  367. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/processors/hybi13.hpp +0 -0
  368. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/processors/processor.hpp +0 -0
  369. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/random/none.hpp +0 -0
  370. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/random/random_device.hpp +0 -0
  371. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/roles/client_endpoint.hpp +0 -0
  372. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/roles/server_endpoint.hpp +0 -0
  373. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/server.hpp +0 -0
  374. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/sha1/sha1.hpp +0 -0
  375. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/asio/base.hpp +0 -0
  376. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/asio/connection.hpp +0 -0
  377. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/asio/endpoint.hpp +0 -0
  378. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/asio/security/base.hpp +0 -0
  379. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/asio/security/none.hpp +0 -0
  380. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/asio/security/tls.hpp +0 -0
  381. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/base/connection.hpp +0 -0
  382. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/base/endpoint.hpp +0 -0
  383. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/debug/base.hpp +0 -0
  384. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/debug/connection.hpp +0 -0
  385. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/debug/endpoint.hpp +0 -0
  386. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/iostream/base.hpp +0 -0
  387. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/iostream/connection.hpp +0 -0
  388. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/iostream/endpoint.hpp +0 -0
  389. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/stub/base.hpp +0 -0
  390. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/stub/connection.hpp +0 -0
  391. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/transport/stub/endpoint.hpp +0 -0
  392. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/uri.hpp +0 -0
  393. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/utf8_validator.hpp +0 -0
  394. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/utilities.hpp +0 -0
  395. data/src/cxx_supportlib/{vendor-copy → vendor-modified}/websocketpp/websocketpp/version.hpp +0 -0
  396. data/src/nginx_module/ConfigGeneral/AutoGeneratedDefinitions.c +16 -0
  397. data/src/nginx_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.c +12 -0
  398. data/src/nginx_module/ConfigGeneral/AutoGeneratedSetterFuncs.c +24 -0
  399. data/src/nginx_module/LocationConfig/AutoGeneratedCreateFunction.c +10 -0
  400. data/src/nginx_module/LocationConfig/AutoGeneratedHeaderSerialization.c +39 -0
  401. data/src/nginx_module/LocationConfig/AutoGeneratedManifestGeneration.c +26 -0
  402. data/src/nginx_module/LocationConfig/AutoGeneratedMergeFunction.c +6 -0
  403. data/src/nginx_module/LocationConfig/AutoGeneratedStruct.h +8 -0
  404. data/src/nginx_module/ngx_http_passenger_module.c +1 -0
  405. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/common.js +50 -29
  406. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config/cli-config.js +20 -20
  407. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config/npm-config.js +11 -11
  408. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config/syslog-config.js +3 -3
  409. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/config.js +8 -2
  410. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/container.js +2 -1
  411. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/logger.js +174 -146
  412. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/console.js +4 -2
  413. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/file.js +15 -5
  414. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/http.js +14 -4
  415. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports.js +26 -24
  416. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston.js +5 -5
  417. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/async/package.json +4 -13
  418. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/colors/package.json +19 -33
  419. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/cycle/package.json +11 -29
  420. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/eyes/package.json +12 -40
  421. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/isstream/package.json +3 -12
  422. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/stack-trace/lib/stack-trace.js +49 -24
  423. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/stack-trace/package.json +4 -16
  424. data/src/nodejs_supportlib/vendor-copy/winston/package.json +11 -55
  425. data/src/ruby_supportlib/phusion_passenger/admin_tools/instance_registry.rb +3 -2
  426. data/src/ruby_supportlib/phusion_passenger/apache2/config_options.rb +6 -0
  427. data/src/ruby_supportlib/phusion_passenger/config/nginx_engine_compiler.rb +3 -2
  428. data/src/ruby_supportlib/phusion_passenger/loader_shared_helpers.rb +8 -1
  429. data/src/ruby_supportlib/phusion_passenger/nginx/config_options.rb +12 -0
  430. data/src/ruby_supportlib/phusion_passenger/packaging.rb +1 -0
  431. data/src/ruby_supportlib/phusion_passenger/platform_info/binary_compatibility.rb +7 -5
  432. data/src/ruby_supportlib/phusion_passenger/platform_info/depcheck_specs/libs.rb +6 -2
  433. data/src/ruby_supportlib/phusion_passenger/platform_info/linux.rb +2 -1
  434. data/src/ruby_supportlib/phusion_passenger/platform_info/openssl.rb +1 -1
  435. data/src/ruby_supportlib/phusion_passenger/platform_info/operating_system.rb +17 -3
  436. data/src/ruby_supportlib/phusion_passenger/platform_info/pcre.rb +65 -0
  437. data/src/ruby_supportlib/phusion_passenger/request_handler/thread_handler.rb +18 -18
  438. data/src/ruby_supportlib/phusion_passenger/request_handler.rb +4 -1
  439. data/src/ruby_supportlib/phusion_passenger/standalone/config_options_list.rb +7 -1
  440. data/src/ruby_supportlib/phusion_passenger/standalone/start_command/builtin_engine.rb +1 -0
  441. data/src/ruby_supportlib/phusion_passenger.rb +5 -5
  442. metadata +148 -105
  443. data/src/cxx_supportlib/vendor-modified/boost/system/detail/is_generic_value.hpp +0 -125
  444. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/daily-rotate-file.js +0 -601
  445. data/src/nodejs_supportlib/vendor-copy/winston/lib/winston/transports/webhook.js +0 -146
  446. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/pkginfo/LICENSE +0 -19
  447. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/pkginfo/lib/pkginfo.js +0 -136
  448. data/src/nodejs_supportlib/vendor-copy/winston/node_modules/pkginfo/package.json +0 -56
@@ -709,6 +709,18 @@ passenger_conf_set_load_shell_envvars(ngx_conf_t *cf, ngx_command_t *cmd, void *
709
709
  return ngx_conf_set_flag_slot(cf, cmd, conf);
710
710
  }
711
711
 
712
+ static char *
713
+ passenger_conf_set_preload_bundler(ngx_conf_t *cf, ngx_command_t *cmd, void *conf) {
714
+ passenger_loc_conf_t *passenger_conf = conf;
715
+
716
+ passenger_conf->autogenerated.preload_bundler_explicitly_set = 1;
717
+ record_loc_conf_source_location(cf, passenger_conf,
718
+ &passenger_conf->autogenerated.preload_bundler_source_file,
719
+ &passenger_conf->autogenerated.preload_bundler_source_line);
720
+
721
+ return ngx_conf_set_flag_slot(cf, cmd, conf);
722
+ }
723
+
712
724
  static char *
713
725
  passenger_conf_set_max_request_queue_size(ngx_conf_t *cf, ngx_command_t *cmd, void *conf) {
714
726
  passenger_loc_conf_t *passenger_conf = conf;
@@ -937,6 +949,18 @@ passenger_conf_set_request_queue_overflow_status_code(ngx_conf_t *cf, ngx_comman
937
949
  return ngx_conf_set_num_slot(cf, cmd, conf);
938
950
  }
939
951
 
952
+ static char *
953
+ passenger_conf_set_spawn_exception_status_code(ngx_conf_t *cf, ngx_command_t *cmd, void *conf) {
954
+ passenger_loc_conf_t *passenger_conf = conf;
955
+
956
+ passenger_conf->autogenerated.spawn_exception_status_code_explicitly_set = 1;
957
+ record_loc_conf_source_location(cf, passenger_conf,
958
+ &passenger_conf->autogenerated.spawn_exception_status_code_source_file,
959
+ &passenger_conf->autogenerated.spawn_exception_status_code_source_line);
960
+
961
+ return ngx_conf_set_num_slot(cf, cmd, conf);
962
+ }
963
+
940
964
  static char *
941
965
  passenger_conf_set_buffer_upload(ngx_conf_t *cf, ngx_command_t *cmd, void *conf) {
942
966
  passenger_loc_conf_t *passenger_conf = conf;
@@ -72,6 +72,7 @@ passenger_create_autogenerated_loc_conf(passenger_autogenerated_loc_conf_t *con
72
72
  conf->direct_instance_request_address.data = NULL;
73
73
  conf->direct_instance_request_address.len = 0;
74
74
  conf->load_shell_envvars = NGX_CONF_UNSET;
75
+ conf->preload_bundler = NGX_CONF_UNSET;
75
76
  conf->max_request_queue_size = NGX_CONF_UNSET_UINT;
76
77
  conf->app_type.data = NULL;
77
78
  conf->app_type.len = 0;
@@ -91,6 +92,7 @@ passenger_create_autogenerated_loc_conf(passenger_autogenerated_loc_conf_t *con
91
92
  conf->headers_hash_max_size = NGX_CONF_UNSET_UINT;
92
93
  conf->headers_hash_bucket_size = NGX_CONF_UNSET_UINT;
93
94
  conf->request_queue_overflow_status_code = NGX_CONF_UNSET;
95
+ conf->spawn_exception_status_code = NGX_CONF_UNSET;
94
96
  conf->buffer_upload = NGX_CONF_UNSET;
95
97
  conf->sticky_sessions = NGX_CONF_UNSET;
96
98
  conf->sticky_sessions_cookie_name.data = NULL;
@@ -182,6 +184,10 @@ passenger_create_autogenerated_loc_conf(passenger_autogenerated_loc_conf_t *con
182
184
  conf->load_shell_envvars_source_file.len = 0;
183
185
  conf->load_shell_envvars_source_line = 0;
184
186
  conf->load_shell_envvars_explicitly_set = 0;
187
+ conf->preload_bundler_source_file.data = NULL;
188
+ conf->preload_bundler_source_file.len = 0;
189
+ conf->preload_bundler_source_line = 0;
190
+ conf->preload_bundler_explicitly_set = 0;
185
191
  conf->max_request_queue_size_source_file.data = NULL;
186
192
  conf->max_request_queue_size_source_file.len = 0;
187
193
  conf->max_request_queue_size_source_line = 0;
@@ -286,6 +292,10 @@ passenger_create_autogenerated_loc_conf(passenger_autogenerated_loc_conf_t *con
286
292
  conf->request_queue_overflow_status_code_source_file.len = 0;
287
293
  conf->request_queue_overflow_status_code_source_line = 0;
288
294
  conf->request_queue_overflow_status_code_explicitly_set = 0;
295
+ conf->spawn_exception_status_code_source_file.data = NULL;
296
+ conf->spawn_exception_status_code_source_file.len = 0;
297
+ conf->spawn_exception_status_code_source_line = 0;
298
+ conf->spawn_exception_status_code_explicitly_set = 0;
289
299
  conf->buffer_upload_source_file.data = NULL;
290
300
  conf->buffer_upload_source_file.len = 0;
291
301
  conf->buffer_upload_source_line = 0;
@@ -172,6 +172,13 @@ passenger_serialize_autogenerated_loc_conf_to_headers(ngx_conf_t *cf, passenger_
172
172
  : sizeof("f\r\n") - 1;
173
173
  }
174
174
 
175
+ if (conf->autogenerated.preload_bundler != NGX_CONF_UNSET) {
176
+ len += sizeof("!~PASSENGER_PRELOAD_BUNDLER: ") - 1;
177
+ len += conf->autogenerated.preload_bundler
178
+ ? sizeof("t\r\n") - 1
179
+ : sizeof("f\r\n") - 1;
180
+ }
181
+
175
182
  if (conf->autogenerated.max_request_queue_size != NGX_CONF_UNSET_UINT) {
176
183
  end = ngx_snprintf(int_buf,
177
184
  sizeof(int_buf) - 1,
@@ -231,6 +238,16 @@ passenger_serialize_autogenerated_loc_conf_to_headers(ngx_conf_t *cf, passenger_
231
238
  len += sizeof("\r\n") - 1;
232
239
  }
233
240
 
241
+ if (conf->autogenerated.spawn_exception_status_code != NGX_CONF_UNSET) {
242
+ end = ngx_snprintf(int_buf,
243
+ sizeof(int_buf) - 1,
244
+ "%d",
245
+ conf->autogenerated.spawn_exception_status_code);
246
+ len += sizeof("!~PASSENGER_SPAWN_EXCEPTION_STATUS_CODE: ") - 1;
247
+ len += end - int_buf;
248
+ len += sizeof("\r\n") - 1;
249
+ }
250
+
234
251
  if (conf->autogenerated.sticky_sessions != NGX_CONF_UNSET) {
235
252
  len += sizeof("!~PASSENGER_STICKY_SESSIONS: ") - 1;
236
253
  len += conf->autogenerated.sticky_sessions
@@ -443,6 +460,17 @@ passenger_serialize_autogenerated_loc_conf_to_headers(ngx_conf_t *cf, passenger_
443
460
  }
444
461
  }
445
462
 
463
+ if (conf->autogenerated.preload_bundler != NGX_CONF_UNSET) {
464
+ pos = ngx_copy(pos,
465
+ "!~PASSENGER_PRELOAD_BUNDLER: ",
466
+ sizeof("!~PASSENGER_PRELOAD_BUNDLER: ") - 1);
467
+ if (conf->autogenerated.preload_bundler) {
468
+ pos = ngx_copy(pos, "t\r\n", sizeof("t\r\n") - 1);
469
+ } else {
470
+ pos = ngx_copy(pos, "f\r\n", sizeof("f\r\n") - 1);
471
+ }
472
+ }
473
+
446
474
  if (conf->autogenerated.max_request_queue_size != NGX_CONF_UNSET_UINT) {
447
475
  pos = ngx_copy(pos,
448
476
  "!~PASSENGER_MAX_REQUEST_QUEUE_SIZE: ",
@@ -516,6 +544,17 @@ passenger_serialize_autogenerated_loc_conf_to_headers(ngx_conf_t *cf, passenger_
516
544
  pos = ngx_copy(pos, int_buf, end - int_buf);
517
545
  pos = ngx_copy(pos, (const u_char *) "\r\n", sizeof("\r\n") - 1);
518
546
  }
547
+ if (conf->autogenerated.spawn_exception_status_code != NGX_CONF_UNSET) {
548
+ pos = ngx_copy(pos,
549
+ "!~PASSENGER_SPAWN_EXCEPTION_STATUS_CODE: ",
550
+ sizeof("!~PASSENGER_SPAWN_EXCEPTION_STATUS_CODE: ") - 1);
551
+ end = ngx_snprintf(int_buf,
552
+ sizeof(int_buf) - 1,
553
+ "%d",
554
+ conf->autogenerated.spawn_exception_status_code);
555
+ pos = ngx_copy(pos, int_buf, end - int_buf);
556
+ pos = ngx_copy(pos, (const u_char *) "\r\n", sizeof("\r\n") - 1);
557
+ }
519
558
  if (conf->autogenerated.sticky_sessions != NGX_CONF_UNSET) {
520
559
  pos = ngx_copy(pos,
521
560
  "!~PASSENGER_STICKY_SESSIONS: ",
@@ -318,6 +318,19 @@ generate_config_manifest_for_autogenerated_loc_conf(manifest_gen_ctx_t *ctx, pas
318
318
  psg_json_value_set_bool(hierarchy_member, "value",
319
319
  plcf->autogenerated.load_shell_envvars);
320
320
  }
321
+ if (plcf->autogenerated.preload_bundler_explicitly_set) {
322
+ find_or_create_manifest_app_and_loc_options_containers(ctx,
323
+ plcf, cscf, clcf, &app_options_container, &loc_options_container);
324
+ option_container = find_or_create_manifest_option_container(ctx,
325
+ app_options_container,
326
+ "passenger_preload_bundler",
327
+ sizeof("passenger_preload_bundler") - 1);
328
+ hierarchy_member = add_manifest_option_container_hierarchy_member(option_container,
329
+ &plcf->autogenerated.preload_bundler_source_file,
330
+ plcf->autogenerated.preload_bundler_source_line);
331
+ psg_json_value_set_bool(hierarchy_member, "value",
332
+ plcf->autogenerated.preload_bundler);
333
+ }
321
334
  if (plcf->autogenerated.max_request_queue_size_explicitly_set) {
322
335
  find_or_create_manifest_app_and_loc_options_containers(ctx,
323
336
  plcf, cscf, clcf, &app_options_container, &loc_options_container);
@@ -596,6 +609,19 @@ generate_config_manifest_for_autogenerated_loc_conf(manifest_gen_ctx_t *ctx, pas
596
609
  psg_json_value_set_int(hierarchy_member, "value",
597
610
  plcf->autogenerated.request_queue_overflow_status_code);
598
611
  }
612
+ if (plcf->autogenerated.spawn_exception_status_code_explicitly_set) {
613
+ find_or_create_manifest_app_and_loc_options_containers(ctx,
614
+ plcf, cscf, clcf, &app_options_container, &loc_options_container);
615
+ option_container = find_or_create_manifest_option_container(ctx,
616
+ loc_options_container,
617
+ "passenger_spawn_exception_status_code",
618
+ sizeof("passenger_spawn_exception_status_code") - 1);
619
+ hierarchy_member = add_manifest_option_container_hierarchy_member(option_container,
620
+ &plcf->autogenerated.spawn_exception_status_code_source_file,
621
+ plcf->autogenerated.spawn_exception_status_code_source_line);
622
+ psg_json_value_set_int(hierarchy_member, "value",
623
+ plcf->autogenerated.spawn_exception_status_code);
624
+ }
599
625
  if (plcf->autogenerated.buffer_upload_explicitly_set) {
600
626
  find_or_create_manifest_app_and_loc_options_containers(ctx,
601
627
  plcf, cscf, clcf, &app_options_container, &loc_options_container);
@@ -107,6 +107,9 @@ passenger_merge_autogenerated_loc_conf(passenger_autogenerated_loc_conf_t *conf,
107
107
  ngx_conf_merge_value(conf->load_shell_envvars,
108
108
  prev->load_shell_envvars,
109
109
  1);
110
+ ngx_conf_merge_value(conf->preload_bundler,
111
+ prev->preload_bundler,
112
+ 0);
110
113
  ngx_conf_merge_uint_value(conf->max_request_queue_size,
111
114
  prev->max_request_queue_size,
112
115
  100);
@@ -151,6 +154,9 @@ passenger_merge_autogenerated_loc_conf(passenger_autogenerated_loc_conf_t *conf,
151
154
  ngx_conf_merge_value(conf->request_queue_overflow_status_code,
152
155
  prev->request_queue_overflow_status_code,
153
156
  503);
157
+ ngx_conf_merge_value(conf->spawn_exception_status_code,
158
+ prev->spawn_exception_status_code,
159
+ 500);
154
160
  ngx_conf_merge_value(conf->buffer_upload,
155
161
  prev->buffer_upload,
156
162
  0);
@@ -56,7 +56,9 @@ typedef struct {
56
56
  ngx_uint_t max_requests;
57
57
  ngx_uint_t min_instances;
58
58
  ngx_array_t *monitor_log_file;
59
+ ngx_flag_t preload_bundler;
59
60
  ngx_int_t request_queue_overflow_status_code;
61
+ ngx_int_t spawn_exception_status_code;
60
62
  ngx_uint_t start_timeout;
61
63
  ngx_flag_t sticky_sessions;
62
64
  ngx_str_t app_group_name;
@@ -110,10 +112,12 @@ typedef struct {
110
112
  ngx_str_t min_instances_source_file;
111
113
  ngx_str_t monitor_log_file_source_file;
112
114
  ngx_str_t nodejs_source_file;
115
+ ngx_str_t preload_bundler_source_file;
113
116
  ngx_str_t python_source_file;
114
117
  ngx_str_t request_queue_overflow_status_code_source_file;
115
118
  ngx_str_t restart_dir_source_file;
116
119
  ngx_str_t ruby_source_file;
120
+ ngx_str_t spawn_exception_status_code_source_file;
117
121
  ngx_str_t spawn_method_source_file;
118
122
  ngx_str_t start_timeout_source_file;
119
123
  ngx_str_t startup_file_source_file;
@@ -163,10 +167,12 @@ typedef struct {
163
167
  ngx_uint_t min_instances_source_line;
164
168
  ngx_uint_t monitor_log_file_source_line;
165
169
  ngx_uint_t nodejs_source_line;
170
+ ngx_uint_t preload_bundler_source_line;
166
171
  ngx_uint_t python_source_line;
167
172
  ngx_uint_t request_queue_overflow_status_code_source_line;
168
173
  ngx_uint_t restart_dir_source_line;
169
174
  ngx_uint_t ruby_source_line;
175
+ ngx_uint_t spawn_exception_status_code_source_line;
170
176
  ngx_uint_t spawn_method_source_line;
171
177
  ngx_uint_t start_timeout_source_line;
172
178
  ngx_uint_t startup_file_source_line;
@@ -216,10 +222,12 @@ typedef struct {
216
222
  ngx_int_t min_instances_explicitly_set;
217
223
  ngx_int_t monitor_log_file_explicitly_set;
218
224
  ngx_int_t nodejs_explicitly_set;
225
+ ngx_int_t preload_bundler_explicitly_set;
219
226
  ngx_int_t python_explicitly_set;
220
227
  ngx_int_t request_queue_overflow_status_code_explicitly_set;
221
228
  ngx_int_t restart_dir_explicitly_set;
222
229
  ngx_int_t ruby_explicitly_set;
230
+ ngx_int_t spawn_exception_status_code_explicitly_set;
223
231
  ngx_int_t spawn_method_explicitly_set;
224
232
  ngx_int_t start_timeout_explicitly_set;
225
233
  ngx_int_t startup_file_explicitly_set;
@@ -359,6 +359,7 @@ start_watchdog(ngx_cycle_t *cycle) {
359
359
  psg_json_value_set_str_ne (w_config, "server_software", NGINX_VER, strlen(NGINX_VER));
360
360
  psg_json_value_set_bool (w_config, "multi_app", 1);
361
361
  psg_json_value_set_bool (w_config, "default_load_shell_envvars", 1);
362
+ psg_json_value_set_bool (w_config, "default_preload_bundler", 0);
362
363
  psg_json_value_set_value (w_config, "config_manifest", -1, passenger_main_conf.manifest);
363
364
  psg_json_value_set_ngx_uint (w_config, "log_level", autogenerated_main_conf->log_level);
364
365
  psg_json_value_set_ngx_str_ne(w_config, "file_descriptor_log_target", &autogenerated_main_conf->file_descriptor_log_file);
@@ -32,7 +32,7 @@ exports.setLevels = function (target, past, current, isDefault) {
32
32
  }
33
33
 
34
34
  target.levels = current || config.npm.levels;
35
- if (target.padLevels) {
35
+ if (target.hasOwnProperty('padLevels') && target.padLevels) {
36
36
  target.levelLength = exports.longestElement(Object.keys(target.levels));
37
37
  }
38
38
 
@@ -77,20 +77,15 @@ exports.longestElement = function (xs) {
77
77
  // i.e. JSON objects that are either literals or objects (no Arrays, etc)
78
78
  //
79
79
  exports.clone = function (obj) {
80
- //
81
- // We only need to clone reference types (Object)
82
- //
83
- var copy = {};
84
-
85
80
  if (obj instanceof Error) {
86
81
  // With potential custom Error objects, this might not be exactly correct,
87
82
  // but probably close-enough for purposes of this lib.
88
- copy = new Error(obj.message);
83
+ var copy = { message: obj.message };
89
84
  Object.getOwnPropertyNames(obj).forEach(function (key) {
90
85
  copy[key] = obj[key];
91
86
  });
92
87
 
93
- return copy;
88
+ return cycle.decycle(copy);
94
89
  }
95
90
  else if (!(obj instanceof Object)) {
96
91
  return obj;
@@ -99,23 +94,34 @@ exports.clone = function (obj) {
99
94
  return new Date(obj.getTime());
100
95
  }
101
96
 
97
+ return clone(cycle.decycle(obj));
98
+ };
99
+
100
+ function clone(obj) {
101
+ //
102
+ // We only need to clone reference types (Object)
103
+ //
104
+ var copy = Array.isArray(obj) ? [] : {};
105
+
102
106
  for (var i in obj) {
103
- if (Array.isArray(obj[i])) {
104
- copy[i] = obj[i].slice(0);
105
- }
106
- else if (obj[i] instanceof Buffer) {
107
+ if (obj.hasOwnProperty(i)) {
108
+ if (Array.isArray(obj[i])) {
107
109
  copy[i] = obj[i].slice(0);
108
- }
109
- else if (typeof obj[i] != 'function') {
110
- copy[i] = obj[i] instanceof Object ? exports.clone(obj[i]) : obj[i];
111
- }
112
- else if (typeof obj[i] === 'function') {
113
- copy[i] = obj[i];
110
+ }
111
+ else if (obj[i] instanceof Buffer) {
112
+ copy[i] = obj[i].slice(0);
113
+ }
114
+ else if (typeof obj[i] != 'function') {
115
+ copy[i] = obj[i] instanceof Object ? exports.clone(obj[i]) : obj[i];
116
+ }
117
+ else if (typeof obj[i] === 'function') {
118
+ copy[i] = obj[i];
119
+ }
114
120
  }
115
121
  }
116
122
 
117
123
  return copy;
118
- };
124
+ }
119
125
 
120
126
  //
121
127
  // ### function log (options)
@@ -139,8 +145,8 @@ exports.log = function (options) {
139
145
  : exports.timestamp,
140
146
  timestamp = options.timestamp ? timestampFn() : null,
141
147
  showLevel = options.showLevel === undefined ? true : options.showLevel,
142
- meta = options.meta !== null && options.meta !== undefined && !(options.meta instanceof Error)
143
- ? exports.clone(cycle.decycle(options.meta))
148
+ meta = options.meta !== null && options.meta !== undefined
149
+ ? exports.clone(options.meta)
144
150
  : options.meta || null,
145
151
  output;
146
152
 
@@ -214,6 +220,12 @@ exports.log = function (options) {
214
220
  // Remark: this should really be a call to `util.format`.
215
221
  //
216
222
  if (typeof options.formatter == 'function') {
223
+ options.meta = meta || options.meta;
224
+ if (options.meta instanceof Error) {
225
+ // Force converting the Error to an plain object now so it
226
+ // will not be messed up by decycle() when cloning options
227
+ options.meta = exports.clone(options.meta);
228
+ }
217
229
  return String(options.formatter(exports.clone(options)));
218
230
  }
219
231
 
@@ -232,10 +244,6 @@ exports.log = function (options) {
232
244
  : options.message;
233
245
 
234
246
  if (meta !== null && meta !== undefined) {
235
- if (meta && meta instanceof Error && meta.stack) {
236
- meta = meta.stack;
237
- }
238
-
239
247
  if (typeof meta !== 'object') {
240
248
  output += ' ' + meta;
241
249
  }
@@ -246,7 +254,7 @@ exports.log = function (options) {
246
254
  output += ' ' + '\n' + util.inspect(meta, false, options.depth || null, options.colorize);
247
255
  } else if (
248
256
  options.humanReadableUnhandledException
249
- && Object.keys(meta).length === 5
257
+ && Object.keys(meta).length >= 5
250
258
  && meta.hasOwnProperty('date')
251
259
  && meta.hasOwnProperty('process')
252
260
  && meta.hasOwnProperty('os')
@@ -260,7 +268,10 @@ exports.log = function (options) {
260
268
  delete meta.stack;
261
269
  delete meta.trace;
262
270
  output += ' ' + exports.serialize(meta);
263
- output += '\n' + stack.join('\n');
271
+
272
+ if (stack) {
273
+ output += '\n' + stack.join('\n');
274
+ }
264
275
  } else {
265
276
  output += ' ' + exports.serialize(meta);
266
277
  }
@@ -308,6 +319,14 @@ exports.timestamp = function () {
308
319
  // logging to non-JSON inputs.
309
320
  //
310
321
  exports.serialize = function (obj, key) {
322
+ // symbols cannot be directly casted to strings
323
+ if (typeof key === 'symbol') {
324
+ key = key.toString()
325
+ }
326
+ if (typeof obj === 'symbol') {
327
+ obj = obj.toString()
328
+ }
329
+
311
330
  if (obj === null) {
312
331
  obj = 'null';
313
332
  }
@@ -365,7 +384,7 @@ exports.serialize = function (obj, key) {
365
384
  // `tail -f` a file. Options must include file.
366
385
  //
367
386
  exports.tailFile = function(options, callback) {
368
- var buffer = new Buffer(64 * 1024)
387
+ var buffer = Buffer.alloc(64 * 1024)
369
388
  , decode = new StringDecoder('utf8')
370
389
  , stream = new Stream
371
390
  , buff = ''
@@ -396,7 +415,7 @@ exports.tailFile = function(options, callback) {
396
415
 
397
416
  (function read() {
398
417
  if (stream.destroyed) {
399
- fs.close(fd);
418
+ fs.close(fd, nop);
400
419
  return;
401
420
  }
402
421
 
@@ -481,3 +500,5 @@ exports.stringArrayToSet = function (strArray, errMsg) {
481
500
  return set;
482
501
  }, Object.create(null));
483
502
  };
503
+
504
+ function nop () {}
@@ -9,27 +9,27 @@
9
9
  var cliConfig = exports;
10
10
 
11
11
  cliConfig.levels = {
12
- silly: 0,
13
- input: 1,
14
- verbose: 2,
15
- prompt: 3,
16
- debug: 4,
17
- info: 5,
18
- data: 6,
19
- help: 7,
20
- warn: 8,
21
- error: 9
12
+ error: 0,
13
+ warn: 1,
14
+ help: 2,
15
+ data: 3,
16
+ info: 4,
17
+ debug: 5,
18
+ prompt: 6,
19
+ verbose: 7,
20
+ input: 8,
21
+ silly: 9,
22
22
  };
23
23
 
24
24
  cliConfig.colors = {
25
- silly: 'magenta',
26
- input: 'grey',
27
- verbose: 'cyan',
28
- prompt: 'grey',
29
- debug: 'blue',
30
- info: 'green',
31
- data: 'grey',
32
- help: 'cyan',
25
+ error: 'red',
33
26
  warn: 'yellow',
34
- error: 'red'
35
- };
27
+ help: 'cyan',
28
+ data: 'grey',
29
+ info: 'green',
30
+ debug: 'blue',
31
+ prompt: 'grey',
32
+ verbose: 'cyan',
33
+ input: 'grey',
34
+ silly: 'magenta'
35
+ };
@@ -9,19 +9,19 @@
9
9
  var npmConfig = exports;
10
10
 
11
11
  npmConfig.levels = {
12
- silly: 0,
13
- debug: 1,
14
- verbose: 2,
15
- info: 3,
16
- warn: 4,
17
- error: 5
12
+ error: 0,
13
+ warn: 1,
14
+ info: 2,
15
+ verbose: 3,
16
+ debug: 4,
17
+ silly: 5
18
18
  };
19
19
 
20
20
  npmConfig.colors = {
21
- silly: 'magenta',
21
+ error: 'red',
22
+ warn: 'yellow',
23
+ info: 'green',
22
24
  verbose: 'cyan',
23
25
  debug: 'blue',
24
- info: 'green',
25
- warn: 'yellow',
26
- error: 'red'
27
- };
26
+ silly: 'magenta'
27
+ };
@@ -16,7 +16,7 @@ syslogConfig.levels = {
16
16
  warning: 4,
17
17
  notice: 5,
18
18
  info: 6,
19
- debug: 7,
19
+ debug: 7
20
20
  };
21
21
 
22
22
  syslogConfig.colors = {
@@ -27,5 +27,5 @@ syslogConfig.colors = {
27
27
  warning: 'red',
28
28
  notice: 'yellow',
29
29
  info: 'green',
30
- debug: 'blue',
31
- };
30
+ debug: 'blue'
31
+ };
@@ -8,6 +8,9 @@
8
8
 
9
9
  var colors = require('colors/safe');
10
10
 
11
+ // Fix colors not appearing in non-tty environments
12
+ colors.enabled = true;
13
+
11
14
  var config = exports,
12
15
  allColors = exports.allColors = {};
13
16
 
@@ -23,15 +26,18 @@ config.colorize = function (level, message) {
23
26
  for (var i = 0, l = allColors[level].length; i < l; ++i) {
24
27
  colorized = colors[allColors[level][i]](colorized);
25
28
  }
26
- } else if (allColors[level].match(/\s/)) {
29
+ }
30
+ else if (allColors[level].match(/\s/)) {
27
31
  var colorArr = allColors[level].split(/\s+/);
28
32
  for (var i = 0; i < colorArr.length; ++i) {
29
33
  colorized = colors[colorArr[i]](colorized);
30
34
  }
31
35
  allColors[level] = colorArr;
32
- } else {
36
+ }
37
+ else {
33
38
  colorized = colors[allColors[level]](colorized);
34
39
  }
40
+
35
41
  return colorized;
36
42
  };
37
43
 
@@ -58,7 +58,7 @@ Container.prototype.get = Container.prototype.add = function (id, options) {
58
58
  }
59
59
 
60
60
  Object.keys(options).forEach(function (key) {
61
- if (key === 'transports') {
61
+ if (key === 'transports' || key === 'filters' || key === 'rewriters') {
62
62
  return;
63
63
  }
64
64
 
@@ -73,6 +73,7 @@ Container.prototype.get = Container.prototype.add = function (id, options) {
73
73
  options.transports.push(new (winston.transports[name])(namedOptions));
74
74
  });
75
75
 
76
+ options.id = id;
76
77
  this.loggers[id] = new winston.Logger(options);
77
78
 
78
79
  this.loggers[id].on('close', function () {