passenger 5.1.12 → 5.2.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of passenger might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG +18 -1
- data/Rakefile +4 -1
- data/build/agent.rb +2 -2
- data/build/apache2.rb +17 -10
- data/build/basics.rb +18 -4
- data/build/common_library.rb +7 -3
- data/build/cxx_tests.rb +2 -7
- data/build/misc.rb +3 -1
- data/build/nginx.rb +11 -5
- data/build/oxt_tests.rb +0 -3
- data/build/packaging.rb +3 -2
- data/build/schema_printer.rb +103 -0
- data/build/support/cplusplus.rb +2 -2
- data/build/support/cxx_dependency_map.rb +2575 -868
- data/dev/ci/lib/functions.sh +1 -1
- data/dev/ci/lib/set-container-envvars.sh +1 -1
- data/dev/ci/lib/setup-container.sh +1 -1
- data/dev/ci/run-tests-natively +1 -1
- data/dev/ci/run-tests-with-docker +1 -1
- data/dev/ci/scripts/debug-console-wrapper.sh +1 -1
- data/dev/ci/scripts/docker-entrypoint-stage2.sh +1 -1
- data/dev/ci/scripts/docker-entrypoint.sh +1 -1
- data/dev/ci/scripts/inituidgid +1 -1
- data/dev/ci/scripts/run-tests-natively-stage2.sh +1 -1
- data/dev/ci/scripts/setup-host-natively.sh +1 -1
- data/dev/ci/setup-host +1 -1
- data/dev/ci/tests/apache2/run +1 -1
- data/dev/ci/tests/apache2/setup +1 -1
- data/dev/ci/tests/cxx/run +1 -1
- data/dev/ci/tests/cxx/setup +1 -1
- data/dev/ci/tests/debian/Jenkinsfile +0 -1
- data/dev/ci/tests/debian/run +1 -1
- data/dev/ci/tests/nginx-dynamic/run +1 -1
- data/dev/ci/tests/nginx-dynamic/setup +1 -1
- data/dev/ci/tests/nginx/run +1 -1
- data/dev/ci/tests/nginx/setup +1 -1
- data/dev/ci/tests/nodejs/run +1 -1
- data/dev/ci/tests/nodejs/setup +1 -1
- data/dev/ci/tests/rpm/run +1 -1
- data/dev/ci/tests/ruby/run +1 -1
- data/dev/ci/tests/ruby/setup +1 -1
- data/dev/ci/tests/source-packaging/run +1 -1
- data/dev/ci/tests/source-packaging/setup +1 -1
- data/dev/ci/tests/standalone/run +1 -1
- data/dev/ci/tests/standalone/setup +1 -1
- data/dev/configkit-schemas/index.json +1708 -0
- data/dev/configkit-schemas/update_schema_inline_comments.rb +118 -0
- data/dev/copy_boost_headers +13 -1
- data/dev/index_cxx_dependencies.rb +20 -7
- data/dev/vagrant/provision.sh +1 -1
- data/resources/mime.types +1 -0
- data/resources/templates/standalone/http.erb +1 -6
- data/src/agent/Core/AdminPanelConnector.h +550 -0
- data/src/agent/Core/ApiServer.h +159 -97
- data/src/agent/Core/ApplicationPool/Group.h +2 -0
- data/src/agent/Core/ApplicationPool/Group/InternalUtils.cpp +3 -2
- data/src/agent/Core/ApplicationPool/Group/StateInspection.cpp +109 -0
- data/src/agent/Core/ApplicationPool/Implementation.cpp +5 -3
- data/src/agent/Core/ApplicationPool/Options.h +5 -6
- data/src/agent/Core/ApplicationPool/Pool.h +59 -2
- data/src/agent/Core/ApplicationPool/Pool/GeneralUtils.cpp +3 -3
- data/src/agent/Core/ApplicationPool/Pool/InitializationAndShutdown.cpp +2 -2
- data/src/agent/Core/ApplicationPool/Pool/Miscellaneous.cpp +6 -0
- data/src/agent/Core/ApplicationPool/Pool/StateInspection.cpp +129 -0
- data/src/agent/Core/Config.h +475 -0
- data/src/agent/Core/ConfigChange.cpp +349 -0
- data/src/agent/Core/ConfigChange.h +54 -0
- data/src/agent/Core/Controller.h +35 -3
- data/src/agent/Core/Controller/CheckoutSession.cpp +1 -1
- data/src/agent/Core/Controller/Config.cpp +0 -2
- data/src/agent/Core/Controller/Config.h +168 -104
- data/src/agent/Core/Controller/ForwardResponse.cpp +1 -1
- data/src/agent/Core/Controller/InitRequest.cpp +14 -15
- data/src/agent/Core/Controller/InitializationAndShutdown.cpp +34 -44
- data/src/agent/Core/Controller/Request.h +0 -1
- data/src/agent/Core/CoreMain.cpp +236 -349
- data/src/agent/Core/OptionParser.h +75 -89
- data/src/agent/Core/SecurityUpdateChecker.h +263 -100
- data/src/agent/Core/SpawningKit/Config.h +6 -2
- data/src/agent/Core/SpawningKit/Spawner.h +0 -45
- data/src/agent/Core/SpawningKit/UserSwitchingRules.h +1 -0
- data/src/agent/Shared/ApiAccountUtils.h +318 -0
- data/src/agent/Shared/ApiServerUtils.h +3 -104
- data/src/agent/Shared/Fundamentals/Initialization.cpp +81 -44
- data/src/agent/Shared/Fundamentals/Initialization.h +12 -7
- data/src/agent/TempDirToucher/TempDirToucherMain.cpp +21 -0
- data/src/agent/Watchdog/AgentWatcher.cpp +1 -1
- data/src/agent/Watchdog/ApiServer.h +100 -14
- data/src/agent/Watchdog/Config.h +340 -0
- data/src/agent/Watchdog/CoreWatcher.cpp +27 -13
- data/src/agent/Watchdog/InstanceDirToucher.cpp +1 -1
- data/src/agent/Watchdog/WatchdogMain.cpp +190 -206
- data/src/apache2_module/Bucket.cpp +4 -0
- data/src/apache2_module/Bucket.h +7 -3
- data/src/apache2_module/CBindings.cpp +49 -0
- data/src/apache2_module/Config.cpp +242 -0
- data/src/apache2_module/Config.h +109 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedDefinitions.cpp +485 -0
- data/src/apache2_module/{ConfigurationCommands.cpp.cxxcodebuilder → ConfigGeneral/AutoGeneratedDefinitions.cpp.cxxcodebuilder} +29 -15
- data/src/apache2_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.cpp +298 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.cpp.cxxcodebuilder +171 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedSetterFuncs.cpp +854 -0
- data/src/apache2_module/ConfigGeneral/AutoGeneratedSetterFuncs.cpp.cxxcodebuilder +188 -0
- data/src/apache2_module/ConfigGeneral/ManifestGeneration.h +610 -0
- data/src/apache2_module/ConfigGeneral/SetterFuncs.h +65 -0
- data/src/apache2_module/DirConfig/AutoGeneratedCreateFunction.cpp +174 -0
- data/src/apache2_module/{MergeDirConfig.cpp.cxxcodebuilder → DirConfig/AutoGeneratedCreateFunction.cpp.cxxcodebuilder} +54 -32
- data/src/apache2_module/DirConfig/AutoGeneratedHeaderSerialization.cpp +113 -0
- data/src/apache2_module/{SetHeaders.cpp.cxxcodebuilder → DirConfig/AutoGeneratedHeaderSerialization.cpp.cxxcodebuilder} +34 -23
- data/src/apache2_module/DirConfig/AutoGeneratedManifestGeneration.cpp +426 -0
- data/src/apache2_module/DirConfig/AutoGeneratedManifestGeneration.cpp.cxxcodebuilder +165 -0
- data/src/apache2_module/DirConfig/AutoGeneratedMergeFunction.cpp +269 -0
- data/src/apache2_module/DirConfig/AutoGeneratedMergeFunction.cpp.cxxcodebuilder +148 -0
- data/src/apache2_module/DirConfig/AutoGeneratedStruct.h +534 -0
- data/src/apache2_module/DirConfig/AutoGeneratedStruct.h.cxxcodebuilder +230 -0
- data/src/apache2_module/DirectoryMapper.h +19 -16
- data/src/apache2_module/Hooks.cpp +124 -138
- data/src/apache2_module/Hooks.h +9 -14
- data/src/apache2_module/ServerConfig/AutoGeneratedManifestGeneration.cpp +263 -0
- data/src/apache2_module/ServerConfig/AutoGeneratedManifestGeneration.cpp.cxxcodebuilder +152 -0
- data/src/apache2_module/ServerConfig/AutoGeneratedStruct.h +299 -0
- data/src/apache2_module/{ConfigurationFields.hpp.cxxcodebuilder → ServerConfig/AutoGeneratedStruct.h.cxxcodebuilder} +105 -18
- data/src/apache2_module/Utils.h +215 -0
- data/src/apache2_module/mod_passenger.c +16 -8
- data/src/cxx_supportlib/AppTypes.h +2 -0
- data/src/cxx_supportlib/ConfigKit/ConfigKit.h +1 -1
- data/src/cxx_supportlib/ConfigKit/DummyTranslator.h +8 -8
- data/src/cxx_supportlib/ConfigKit/IN_PRACTICE.md +7 -41
- data/src/cxx_supportlib/ConfigKit/PrefixTranslator.h +12 -66
- data/src/cxx_supportlib/ConfigKit/Schema.h +62 -11
- data/src/cxx_supportlib/ConfigKit/{ValidationUtils.h → SchemaUtils.h} +12 -3
- data/src/cxx_supportlib/ConfigKit/Store.h +17 -9
- data/src/cxx_supportlib/ConfigKit/SubComponentUtils.h +2 -1
- data/src/cxx_supportlib/ConfigKit/TableTranslator.h +13 -70
- data/src/cxx_supportlib/ConfigKit/Translator.h +125 -0
- data/src/cxx_supportlib/Constants.h +1 -3
- data/src/cxx_supportlib/FileTools/FileManip.cpp +297 -0
- data/src/cxx_supportlib/FileTools/FileManip.h +162 -0
- data/src/cxx_supportlib/{Utils → FileTools}/LargeFiles.cpp +6 -3
- data/src/cxx_supportlib/{Utils → FileTools}/LargeFiles.h +7 -5
- data/src/cxx_supportlib/FileTools/PathManip.cpp +240 -0
- data/src/cxx_supportlib/FileTools/PathManip.h +91 -0
- data/src/cxx_supportlib/FileTools/PathManipCBindings.cpp +62 -0
- data/src/{apache2_module/Configuration.h → cxx_supportlib/FileTools/PathManipCBindings.h} +12 -19
- data/src/cxx_supportlib/Hooks.h +19 -16
- data/src/cxx_supportlib/InstanceDirectory.h +11 -0
- data/src/cxx_supportlib/JsonTools/Autocast.h +79 -0
- data/src/cxx_supportlib/JsonTools/CBindings.cpp +364 -0
- data/src/cxx_supportlib/JsonTools/CBindings.h +101 -0
- data/src/cxx_supportlib/LoggingKit/Config.h +13 -0
- data/src/cxx_supportlib/LoggingKit/Context.h +5 -2
- data/src/cxx_supportlib/LoggingKit/Forward.h +0 -1
- data/src/cxx_supportlib/LoggingKit/Implementation.cpp +12 -4
- data/src/cxx_supportlib/ResourceLocator.h +15 -0
- data/src/cxx_supportlib/ServerKit/Config.h +156 -0
- data/src/cxx_supportlib/ServerKit/Context.h +59 -38
- data/src/cxx_supportlib/ServerKit/FileBufferedChannel.h +3 -2
- data/src/cxx_supportlib/ServerKit/HttpHeaderParser.h +2 -2
- data/src/cxx_supportlib/ServerKit/HttpServer.h +16 -2
- data/src/cxx_supportlib/ServerKit/Server.h +32 -15
- data/src/cxx_supportlib/Utils.cpp +0 -441
- data/src/cxx_supportlib/Utils.h +0 -158
- data/src/cxx_supportlib/Utils/Curl.h +1 -0
- data/src/cxx_supportlib/Utils/ProcessMetricsCollector.h +1 -0
- data/src/cxx_supportlib/Utils/StrIntUtilsNoStrictAliasing.cpp +2 -0
- data/src/cxx_supportlib/Utils/VariantMap.h +31 -0
- data/src/cxx_supportlib/WatchdogLauncher.cpp +7 -79
- data/src/cxx_supportlib/WatchdogLauncher.h +50 -53
- data/src/cxx_supportlib/WebSocketCommandReverseServer.h +981 -0
- data/src/cxx_supportlib/oxt/macros.hpp +9 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/COPYING +145 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/changelog.md +342 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/readme.md +49 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/base64/base64.hpp +178 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/client.hpp +33 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/close.hpp +342 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/asio.hpp +131 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/asio_ssl.hpp +39 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/chrono.hpp +68 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/connection_hdl.hpp +52 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/cpp11.hpp +162 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/functional.hpp +105 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/md5.hpp +448 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/memory.hpp +89 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/network.hpp +106 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/platforms.hpp +46 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/random.hpp +82 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/regex.hpp +59 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/stdint.hpp +73 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/system_error.hpp +84 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/thread.hpp +84 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/time.hpp +56 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/common/type_traits.hpp +65 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/concurrency/basic.hpp +46 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/concurrency/none.hpp +80 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/asio.hpp +77 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/asio_client.hpp +77 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/asio_no_tls.hpp +73 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/asio_no_tls_client.hpp +73 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/boost_config.hpp +72 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/core.hpp +285 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/core_client.hpp +294 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/debug.hpp +286 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/debug_asio.hpp +77 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/debug_asio_no_tls.hpp +73 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/minimal_client.hpp +72 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/config/minimal_server.hpp +312 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/connection.hpp +1651 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/connection_base.hpp +38 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/endpoint.hpp +700 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/endpoint_base.hpp +38 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/error.hpp +277 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/extensions/extension.hpp +102 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/extensions/permessage_deflate/disabled.hpp +128 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/extensions/permessage_deflate/enabled.hpp +752 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/frame.hpp +861 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/http/constants.hpp +308 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/http/impl/parser.hpp +196 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/http/impl/request.hpp +191 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/http/impl/response.hpp +266 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/http/parser.hpp +619 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/http/request.hpp +124 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/http/response.hpp +188 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/impl/connection_impl.hpp +2372 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/impl/endpoint_impl.hpp +269 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/impl/utilities_impl.hpp +87 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/logger/basic.hpp +199 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/logger/levels.hpp +203 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/logger/stub.hpp +119 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/logger/syslog.hpp +146 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/message_buffer/alloc.hpp +105 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/message_buffer/message.hpp +340 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/message_buffer/pool.hpp +229 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/processors/base.hpp +299 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/processors/hybi00.hpp +462 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/processors/hybi07.hpp +78 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/processors/hybi08.hpp +83 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/processors/hybi13.hpp +1056 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/processors/processor.hpp +407 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/random/none.hpp +60 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/random/random_device.hpp +80 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/roles/client_endpoint.hpp +173 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/roles/server_endpoint.hpp +190 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/server.hpp +33 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/sha1/sha1.hpp +189 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/asio/base.hpp +232 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/asio/connection.hpp +1204 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/asio/endpoint.hpp +1147 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/asio/security/base.hpp +159 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/asio/security/none.hpp +370 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/asio/security/tls.hpp +484 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/base/connection.hpp +238 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/base/endpoint.hpp +77 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/debug/base.hpp +104 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/debug/connection.hpp +412 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/debug/endpoint.hpp +140 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/iostream/base.hpp +133 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/iostream/connection.hpp +714 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/iostream/endpoint.hpp +222 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/stub/base.hpp +95 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/stub/connection.hpp +286 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/transport/stub/endpoint.hpp +140 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/uri.hpp +355 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/utf8_validator.hpp +154 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/utilities.hpp +182 -0
- data/src/cxx_supportlib/vendor-copy/websocketpp/websocketpp/version.hpp +61 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio.hpp +121 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/async_result.hpp +96 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_datagram_socket.hpp +951 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_deadline_timer.hpp +520 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_io_object.hpp +258 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_raw_socket.hpp +942 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_seq_packet_socket.hpp +567 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_serial_port.hpp +697 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_signal_set.hpp +386 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket.hpp +1519 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket_acceptor.hpp +1137 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket_iostream.hpp +288 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_socket_streambuf.hpp +569 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_stream_socket.hpp +854 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_streambuf.hpp +371 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_streambuf_fwd.hpp +35 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/basic_waitable_timer.hpp +521 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffer.hpp +2241 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffered_read_stream.hpp +246 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffered_read_stream_fwd.hpp +27 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffered_stream.hpp +260 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffered_stream_fwd.hpp +27 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffered_write_stream.hpp +238 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffered_write_stream_fwd.hpp +27 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/buffers_iterator.hpp +483 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/completion_condition.hpp +220 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/connect.hpp +825 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/coroutine.hpp +330 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/datagram_socket_service.hpp +438 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/deadline_timer.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/deadline_timer_service.hpp +173 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/addressof.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/array.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/array_fwd.hpp +34 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/assert.hpp +32 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/atomic_count.hpp +47 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/base_from_completion_cond.hpp +70 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/bind_handler.hpp +491 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/buffer_resize_guard.hpp +68 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/buffer_sequence_adapter.hpp +385 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/buffered_stream_storage.hpp +128 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/call_stack.hpp +127 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/chrono_time_traits.hpp +192 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/completion_handler.hpp +83 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/config.hpp +1050 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/consuming_buffers.hpp +294 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/cstdint.hpp +48 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/date_time_fwd.hpp +34 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/deadline_timer_service.hpp +229 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/dependent_type.hpp +38 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/descriptor_ops.hpp +119 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/descriptor_read_op.hpp +121 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/descriptor_write_op.hpp +121 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/dev_poll_reactor.hpp +208 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/epoll_reactor.hpp +244 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/event.hpp +50 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/eventfd_select_interrupter.hpp +85 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/fd_set_adapter.hpp +41 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/fenced_block.hpp +82 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/function.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/gcc_arm_fenced_block.hpp +91 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/gcc_hppa_fenced_block.hpp +68 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/gcc_sync_fenced_block.hpp +65 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/gcc_x86_fenced_block.hpp +99 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_alloc_helpers.hpp +82 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_cont_helpers.hpp +45 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_invoke_helpers.hpp +57 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_tracking.hpp +161 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/handler_type_requirements.hpp +480 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/hash_map.hpp +333 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/buffer_sequence_adapter.ipp +120 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/descriptor_ops.ipp +453 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.hpp +80 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/dev_poll_reactor.ipp +432 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.hpp +78 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/epoll_reactor.ipp +688 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/eventfd_select_interrupter.ipp +167 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/handler_tracking.ipp +307 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.hpp +82 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/kqueue_reactor.ipp +498 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/pipe_select_interrupter.ipp +126 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/posix_event.ipp +49 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/posix_mutex.ipp +48 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/posix_thread.ipp +76 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/posix_tss_ptr.ipp +48 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/reactive_descriptor_service.ipp +210 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/reactive_serial_port_service.ipp +153 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/reactive_socket_service_base.ipp +269 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/resolver_service_base.ipp +132 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.hpp +89 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/select_reactor.ipp +315 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/service_registry.hpp +90 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/service_registry.ipp +190 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/signal_set_service.ipp +649 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/socket_ops.ipp +3470 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/socket_select_interrupter.ipp +178 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/strand_service.hpp +120 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/strand_service.ipp +178 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/task_io_service.hpp +80 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/task_io_service.ipp +476 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/throw_error.ipp +47 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/timer_queue_ptime.ipp +86 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/impl/timer_queue_set.ipp +103 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/io_control.hpp +136 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/keyword_tss_ptr.hpp +72 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/kqueue_reactor.hpp +222 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/limits.hpp +26 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/local_free_on_block_exit.hpp +61 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/macos_fenced_block.hpp +63 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/memory.hpp +31 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/mutex.hpp +50 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/noncopyable.hpp +45 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_event.hpp +90 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_fenced_block.hpp +47 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_mutex.hpp +66 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_reactor.hpp +69 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_signal_blocker.hpp +71 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_socket_service.hpp +500 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_static_mutex.hpp +62 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_thread.hpp +63 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/null_tss_ptr.hpp +70 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/object_pool.hpp +148 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/old_win_sdk_compat.hpp +216 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/op_queue.hpp +158 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/operation.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/pipe_select_interrupter.hpp +91 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/pop_options.hpp +131 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/posix_event.hpp +128 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/posix_fd_set_adapter.hpp +120 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/posix_mutex.hpp +78 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/posix_signal_blocker.hpp +87 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/posix_static_mutex.hpp +66 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/posix_thread.hpp +107 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/posix_tss_ptr.hpp +81 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/push_options.hpp +166 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_descriptor_service.hpp +324 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_null_buffers_op.hpp +90 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_serial_port_service.hpp +236 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_accept_op.hpp +138 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_connect_op.hpp +108 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_recv_op.hpp +125 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_recvfrom_op.hpp +135 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_recvmsg_op.hpp +127 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_send_op.hpp +122 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_sendto_op.hpp +125 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service.hpp +460 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactive_socket_service_base.hpp +452 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor.hpp +32 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_fwd.hpp +42 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op.hpp +63 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/reactor_op_queue.hpp +170 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/regex_fwd.hpp +35 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolve_endpoint_op.hpp +123 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolve_op.hpp +133 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolver_service.hpp +131 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/resolver_service_base.hpp +131 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/scoped_lock.hpp +103 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/scoped_ptr.hpp +81 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/select_interrupter.hpp +48 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/select_reactor.hpp +221 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/service_registry.hpp +146 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/shared_ptr.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/signal_blocker.hpp +46 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/signal_handler.hpp +84 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/signal_init.hpp +49 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/signal_op.hpp +51 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/signal_set_service.hpp +218 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/socket_holder.hpp +100 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/socket_ops.hpp +336 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/socket_option.hpp +318 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/socket_select_interrupter.hpp +93 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/socket_types.hpp +410 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/solaris_fenced_block.hpp +63 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/static_mutex.hpp +54 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/std_event.hpp +178 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/std_fenced_block.hpp +64 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/std_mutex.hpp +75 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/std_static_mutex.hpp +83 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/std_thread.hpp +67 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/strand_service.hpp +144 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/task_io_service.hpp +203 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/task_io_service_operation.hpp +78 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/task_io_service_thread_info.hpp +42 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/thread.hpp +58 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/thread_info_base.hpp +93 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/throw_error.hpp +55 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/throw_exception.hpp +53 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue.hpp +333 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue_base.hpp +70 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue_ptime.hpp +95 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_queue_set.hpp +68 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_scheduler.hpp +35 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/timer_scheduler_fwd.hpp +42 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/tss_ptr.hpp +71 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/type_traits.hpp +60 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/variadic_templates.hpp +63 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/wait_handler.hpp +85 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/wait_op.hpp +47 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/weak_ptr.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/win_iocp_serial_port_service.hpp +230 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/winsock_init.hpp +130 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/detail/wrapped_handler.hpp +293 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/error.hpp +345 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/generic/basic_endpoint.hpp +195 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/generic/datagram_protocol.hpp +125 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/generic/detail/endpoint.hpp +135 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/generic/detail/impl/endpoint.ipp +111 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/generic/raw_protocol.hpp +123 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/generic/seq_packet_protocol.hpp +124 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/generic/stream_protocol.hpp +129 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/handler_alloc_hook.hpp +83 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/handler_continuation_hook.hpp +56 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/handler_invoke_hook.hpp +87 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/handler_type.hpp +114 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/high_resolution_timer.hpp +65 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_read_stream.hpp +360 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/buffered_write_stream.hpp +340 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/connect.hpp +432 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/error.ipp +130 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/handler_alloc_hook.ipp +79 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/io_service.hpp +156 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/io_service.ipp +157 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read.hpp +755 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_at.hpp +812 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/read_until.hpp +1149 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/serial_port_base.hpp +61 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/serial_port_base.ipp +556 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/spawn.hpp +355 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/src.cpp +25 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/src.hpp +73 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/use_future.hpp +179 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write.hpp +767 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/impl/write_at.hpp +827 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/io_service.hpp +772 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/address.hpp +202 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/address_v4.hpp +243 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/address_v6.hpp +248 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_endpoint.hpp +265 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_resolver.hpp +270 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_resolver_entry.hpp +96 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_resolver_iterator.hpp +262 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/basic_resolver_query.hpp +246 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/detail/endpoint.hpp +141 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/detail/impl/endpoint.ipp +206 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/detail/socket_option.hpp +571 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/host_name.hpp +44 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/icmp.hpp +117 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/address.hpp +55 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/address.ipp +228 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/address_v4.hpp +55 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/address_v4.ipp +180 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/address_v6.hpp +55 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/address_v6.ipp +300 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/basic_endpoint.hpp +57 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/impl/host_name.ipp +56 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/multicast.hpp +193 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/resolver_query_base.hpp +132 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/resolver_service.hpp +178 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/tcp.hpp +157 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/udp.hpp +113 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/unicast.hpp +72 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ip/v6_only.hpp +71 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/is_read_buffered.hpp +61 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/is_write_buffered.hpp +61 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/local/basic_endpoint.hpp +241 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/local/connect_pair.hpp +106 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/local/datagram_protocol.hpp +82 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/local/detail/endpoint.hpp +135 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/local/detail/impl/endpoint.ipp +130 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/local/stream_protocol.hpp +92 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/placeholders.hpp +125 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_descriptor.hpp +492 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/basic_stream_descriptor.hpp +364 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/descriptor_base.hpp +99 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/stream_descriptor.hpp +39 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/posix/stream_descriptor_service.hpp +262 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/raw_socket_service.hpp +438 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/read.hpp +633 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_at.hpp +666 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/read_until.hpp +925 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/seq_packet_socket_service.hpp +386 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/serial_port.hpp +38 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/serial_port_base.hpp +169 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/serial_port_service.hpp +255 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/signal_set.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/signal_set_service.hpp +136 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/socket_acceptor_service.hpp +308 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/socket_base.hpp +522 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/spawn.hpp +267 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/basic_context.hpp +42 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/context.hpp +789 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/context_base.hpp +194 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/context_service.hpp +42 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/buffered_handshake_op.hpp +112 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/engine.hpp +166 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/handshake_op.hpp +70 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/impl/engine.ipp +327 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/impl/openssl_init.ipp +166 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/io.hpp +351 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/openssl_init.hpp +103 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/openssl_types.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/password_callback.hpp +74 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/read_op.hpp +75 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/shutdown_op.hpp +62 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/stream_core.hpp +128 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/verify_callback.hpp +70 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/detail/write_op.hpp +75 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/error.hpp +115 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/context.hpp +73 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/context.ipp +1177 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/error.ipp +102 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/rfc2818_verification.ipp +168 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/impl/src.hpp +28 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/old/basic_context.hpp +436 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/old/context_service.hpp +176 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/old/detail/openssl_context_service.hpp +396 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/old/detail/openssl_operation.hpp +526 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/old/detail/openssl_stream_service.hpp +573 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/old/stream.hpp +503 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/old/stream_service.hpp +186 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/rfc2818_verification.hpp +102 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream.hpp +758 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream_base.hpp +54 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/stream_service.hpp +42 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/verify_context.hpp +75 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/ssl/verify_mode.hpp +65 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/steady_timer.hpp +63 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/strand.hpp +254 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/stream_socket_service.hpp +382 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/streambuf.hpp +35 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/system_timer.hpp +59 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/time_traits.hpp +88 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/unyield.hpp +21 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/use_future.hpp +94 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/version.hpp +23 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/wait_traits.hpp +43 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/waitable_timer_service.hpp +170 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_handle.hpp +283 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_object_handle.hpp +180 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_random_access_handle.hpp +378 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/basic_stream_handle.hpp +361 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/object_handle.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/object_handle_service.hpp +179 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/overlapped_ptr.hpp +118 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/random_access_handle.hpp +39 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/random_access_handle_service.hpp +222 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/stream_handle.hpp +39 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/windows/stream_handle_service.hpp +220 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/write.hpp +620 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/write_at.hpp +672 -0
- data/src/cxx_supportlib/vendor-modified/boost/asio/yield.hpp +23 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono.hpp +20 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/chrono.hpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/chrono_io.hpp +34 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/chrono.hpp +46 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/mac/chrono.hpp +242 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/mac/process_cpu_clocks.hpp +356 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/mac/thread_clock.hpp +92 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/posix/chrono.hpp +121 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/posix/process_cpu_clocks.hpp +354 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/posix/thread_clock.hpp +92 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/process_cpu_clocks.hpp +46 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/inlined/thread_clock.hpp +46 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/no_warning/signed_unsigned_cmp.hpp +54 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/detail/scan_keyword.hpp +163 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/floor.hpp +36 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/include.hpp +23 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/duration_get.hpp +593 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/duration_io.hpp +295 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/duration_put.hpp +317 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/duration_style.hpp +35 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/duration_units.hpp +1003 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/ios_base_state.hpp +152 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/time_point_get.hpp +330 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/time_point_io.hpp +1243 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/time_point_put.hpp +261 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/time_point_units.hpp +260 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/timezone.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/utility/ios_base_state_ptr.hpp +437 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/utility/manip_base.hpp +101 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io/utility/to_string.hpp +50 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/io_v1/chrono_io.hpp +637 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/process_cpu_clocks.hpp +525 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/round.hpp +59 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/thread_clock.hpp +75 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/typeof/boost/chrono/chrono.hpp +32 -0
- data/src/cxx_supportlib/vendor-modified/boost/chrono/typeof/boost/ratio.hpp +24 -0
- data/src/cxx_supportlib/vendor-modified/boost/detail/atomic_count.hpp +21 -0
- data/src/cxx_supportlib/vendor-modified/boost/integer/common_factor.hpp +16 -0
- data/src/cxx_supportlib/vendor-modified/boost/integer/common_factor_rt.hpp +460 -0
- data/src/cxx_supportlib/vendor-modified/boost/integer/integer_log2.hpp +112 -0
- data/src/cxx_supportlib/vendor-modified/boost/integer/integer_mask.hpp +126 -0
- data/src/cxx_supportlib/vendor-modified/boost/integer/static_min_max.hpp +51 -0
- data/src/cxx_supportlib/vendor-modified/boost/libs/chrono/src/chrono.cpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/libs/chrono/src/process_cpu_clocks.cpp +18 -0
- data/src/cxx_supportlib/vendor-modified/boost/libs/chrono/src/thread_clock.cpp +19 -0
- data/src/cxx_supportlib/vendor-modified/boost/libs/random/src/random_device.cpp +250 -0
- data/src/cxx_supportlib/vendor-modified/boost/pointer_cast.hpp +121 -0
- data/src/cxx_supportlib/vendor-modified/boost/random.hpp +91 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/additive_combine.hpp +283 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/bernoulli_distribution.hpp +197 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/beta_distribution.hpp +184 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/binomial_distribution.hpp +434 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/cauchy_distribution.hpp +214 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/chi_squared_distribution.hpp +209 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/auto_link.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/config.hpp +18 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/const_mod.hpp +216 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/disable_warnings.hpp +29 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/enable_warnings.hpp +22 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/generator_bits.hpp +36 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/generator_seed_seq.hpp +40 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/int_float_pair.hpp +121 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/integer_log2.hpp +84 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/iterator_mixin.hpp +45 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/large_arithmetic.hpp +122 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/operators.hpp +84 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/polynomial.hpp +384 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/ptr_helper.hpp +67 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/seed.hpp +115 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/seed_impl.hpp +398 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/signed_unsigned_tools.hpp +89 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/uniform_int_float.hpp +76 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/detail/vector_io.hpp +75 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/discard_block.hpp +241 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/discrete_distribution.hpp +636 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/exponential_distribution.hpp +386 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/extreme_value_distribution.hpp +177 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/fisher_f_distribution.hpp +183 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/gamma_distribution.hpp +292 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/generate_canonical.hpp +96 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/geometric_distribution.hpp +267 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/hyperexponential_distribution.hpp +883 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/independent_bits.hpp +271 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/inversive_congruential.hpp +267 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/lagged_fibonacci.hpp +537 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/laplace_distribution.hpp +175 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/linear_congruential.hpp +466 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/linear_feedback_shift.hpp +217 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/lognormal_distribution.hpp +254 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/mersenne_twister.hpp +682 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/negative_binomial_distribution.hpp +220 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/non_central_chi_squared_distribution.hpp +221 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/normal_distribution.hpp +374 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/piecewise_constant_distribution.hpp +466 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/piecewise_linear_distribution.hpp +531 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/poisson_distribution.hpp +360 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/random_device.hpp +143 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/random_number_generator.hpp +73 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/ranlux.hpp +99 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/seed_seq.hpp +118 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/shuffle_order.hpp +269 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/shuffle_output.hpp +51 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/student_t_distribution.hpp +180 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/subtract_with_carry.hpp +613 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/taus88.hpp +45 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/traits.hpp +107 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/triangle_distribution.hpp +232 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/uniform_01.hpp +257 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/uniform_int.hpp +99 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/uniform_int_distribution.hpp +419 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/uniform_on_sphere.hpp +284 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/uniform_real.hpp +82 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/uniform_real_distribution.hpp +241 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/uniform_smallint.hpp +307 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/variate_generator.hpp +122 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/weibull_distribution.hpp +177 -0
- data/src/cxx_supportlib/vendor-modified/boost/random/xor_combine.hpp +208 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio.hpp +14 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/detail/ratio_io.hpp +1342 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/include.hpp +16 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/abs.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/arithmetic.hpp +22 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/comparison.hpp +19 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/divides.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/equal_to.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/gcd.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/greater.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/greater_equal.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/lcm.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/less.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/less_equal.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/minus.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/negate.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/not_equal_to.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/numeric_cast.hpp +31 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/plus.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/rational_c_tag.hpp +25 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/rational_constant.hpp +15 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/sign.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/mpl/times.hpp +30 -0
- data/src/cxx_supportlib/vendor-modified/boost/ratio/ratio_io.hpp +1076 -0
- data/src/cxx_supportlib/vendor-modified/boost/rational.hpp +1002 -0
- data/src/cxx_supportlib/vendor-modified/modp_b64.cpp +11 -0
- data/src/helper-scripts/rack-preloader.rb +1 -1
- data/src/nginx_module/{ConfigurationCommands.c → ConfigGeneral/AutoGeneratedDefinitions.c} +351 -134
- data/src/nginx_module/{ConfigurationCommands.c.cxxcodebuilder → ConfigGeneral/AutoGeneratedDefinitions.c.cxxcodebuilder} +14 -25
- data/src/nginx_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.c +396 -0
- data/src/nginx_module/ConfigGeneral/AutoGeneratedManifestDefaultsInitialization.c.cxxcodebuilder +160 -0
- data/src/nginx_module/ConfigGeneral/AutoGeneratedSetterFuncs.c +831 -0
- data/src/nginx_module/ConfigGeneral/AutoGeneratedSetterFuncs.c.cxxcodebuilder +168 -0
- data/src/nginx_module/ConfigGeneral/ManifestGeneration.c +887 -0
- data/src/nginx_module/ConfigGeneral/ManifestGeneration.h +100 -0
- data/src/nginx_module/Configuration.c +165 -621
- data/src/nginx_module/Configuration.h +43 -33
- data/src/nginx_module/ContentHandler.c +46 -40
- data/src/nginx_module/LocationConfig/AutoGeneratedCreateFunction.c +282 -0
- data/src/nginx_module/{CreateLocationConfig.c.cxxcodebuilder → LocationConfig/AutoGeneratedCreateFunction.c.cxxcodebuilder} +43 -17
- data/src/nginx_module/{CacheLocationConfig.c → LocationConfig/AutoGeneratedHeaderSerialization.c} +148 -180
- data/src/nginx_module/{CacheLocationConfig.c.cxxcodebuilder → LocationConfig/AutoGeneratedHeaderSerialization.c.cxxcodebuilder} +13 -11
- data/src/nginx_module/LocationConfig/AutoGeneratedManifestGeneration.c +595 -0
- data/src/nginx_module/LocationConfig/AutoGeneratedManifestGeneration.c.cxxcodebuilder +190 -0
- data/src/nginx_module/{MergeLocationConfig.c → LocationConfig/AutoGeneratedMergeFunction.c} +32 -42
- data/src/nginx_module/{MergeLocationConfig.c.cxxcodebuilder → LocationConfig/AutoGeneratedMergeFunction.c.cxxcodebuilder} +18 -11
- data/src/nginx_module/LocationConfig/AutoGeneratedStruct.h +220 -0
- data/src/nginx_module/{LocationConfig.h.cxxcodebuilder → LocationConfig/AutoGeneratedStruct.h.cxxcodebuilder} +70 -48
- data/src/nginx_module/MainConfig/AutoGeneratedCreateFunction.c +163 -0
- data/src/nginx_module/MainConfig/AutoGeneratedCreateFunction.c.cxxcodebuilder +125 -0
- data/src/nginx_module/MainConfig/AutoGeneratedManifestGeneration.c +303 -0
- data/src/nginx_module/MainConfig/AutoGeneratedManifestGeneration.c.cxxcodebuilder +173 -0
- data/src/nginx_module/MainConfig/AutoGeneratedStruct.h +133 -0
- data/src/nginx_module/MainConfig/AutoGeneratedStruct.h.cxxcodebuilder +154 -0
- data/src/nginx_module/config +13 -4
- data/src/nginx_module/ngx_http_passenger_module.c +154 -84
- data/src/ruby_supportlib/phusion_passenger.rb +2 -2
- data/src/ruby_supportlib/phusion_passenger/apache2/config_options.rb +613 -131
- data/src/ruby_supportlib/phusion_passenger/apache2/config_utils.rb +52 -0
- data/src/ruby_supportlib/phusion_passenger/common_library.rb +18 -4
- data/src/ruby_supportlib/phusion_passenger/config/main.rb +2 -0
- data/src/ruby_supportlib/phusion_passenger/config/system_properties_command.rb +104 -0
- data/src/ruby_supportlib/phusion_passenger/constants.rb +0 -2
- data/src/ruby_supportlib/phusion_passenger/nginx/config_options.rb +470 -138
- data/src/ruby_supportlib/phusion_passenger/packaging.rb +1 -0
- data/src/ruby_supportlib/phusion_passenger/platform_info.rb +17 -0
- data/src/ruby_supportlib/phusion_passenger/platform_info/apache.rb +11 -1
- data/src/ruby_supportlib/phusion_passenger/platform_info/compiler.rb +7 -7
- data/src/ruby_supportlib/phusion_passenger/platform_info/networking.rb +293 -0
- data/src/ruby_supportlib/phusion_passenger/standalone/config_options_list.rb +8 -54
- data/src/ruby_supportlib/phusion_passenger/standalone/start_command.rb +1 -5
- data/src/ruby_supportlib/phusion_passenger/standalone/start_command/builtin_engine.rb +4 -7
- data/src/ruby_supportlib/phusion_passenger/vendor/daemon_controller.rb +1 -1
- data/src/schema_printer/SchemaPrinterMain.cpp +78 -0
- data/src/schema_printer/SchemaPrinterMain.cpp.cxxcodebuilder +116 -0
- metadata +671 -30
- data/src/apache2_module/Configuration.cpp +0 -737
- data/src/apache2_module/Configuration.hpp +0 -274
- data/src/apache2_module/ConfigurationCommands.cpp +0 -199
- data/src/apache2_module/ConfigurationFields.hpp +0 -187
- data/src/apache2_module/ConfigurationSetters.cpp +0 -436
- data/src/apache2_module/ConfigurationSetters.cpp.cxxcodebuilder +0 -144
- data/src/apache2_module/CreateDirConfig.cpp +0 -68
- data/src/apache2_module/CreateDirConfig.cpp.cxxcodebuilder +0 -81
- data/src/apache2_module/MergeDirConfig.cpp +0 -155
- data/src/apache2_module/SetHeaders.cpp +0 -111
- data/src/nginx_module/CreateLocationConfig.c +0 -100
- data/src/nginx_module/LocationConfig.h +0 -95
@@ -0,0 +1,981 @@
|
|
1
|
+
/*
|
2
|
+
* Phusion Passenger - https://www.phusionpassenger.com/
|
3
|
+
* Copyright (c) 2017 Phusion Holding B.V.
|
4
|
+
*
|
5
|
+
* "Passenger", "Phusion Passenger" and "Union Station" are registered
|
6
|
+
* trademarks of Phusion Holding B.V.
|
7
|
+
*
|
8
|
+
* Permission is hereby granted, free of charge, to any person obtaining a copy
|
9
|
+
* of this software and associated documentation files (the "Software"), to deal
|
10
|
+
* in the Software without restriction, including without limitation the rights
|
11
|
+
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
12
|
+
* copies of the Software, and to permit persons to whom the Software is
|
13
|
+
* furnished to do so, subject to the following conditions:
|
14
|
+
*
|
15
|
+
* The above copyright notice and this permission notice shall be included in
|
16
|
+
* all copies or substantial portions of the Software.
|
17
|
+
*
|
18
|
+
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
19
|
+
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
20
|
+
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
21
|
+
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
22
|
+
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
23
|
+
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
24
|
+
* THE SOFTWARE.
|
25
|
+
*/
|
26
|
+
#ifndef _PASSENGER_WEB_SOCKET_COMMAND_REVERSE_SERVER_H_
|
27
|
+
#define _PASSENGER_WEB_SOCKET_COMMAND_REVERSE_SERVER_H_
|
28
|
+
|
29
|
+
#include <websocketpp/config/asio_no_tls_client.hpp>
|
30
|
+
#include <websocketpp/client.hpp>
|
31
|
+
|
32
|
+
#include <boost/make_shared.hpp>
|
33
|
+
#include <boost/function.hpp>
|
34
|
+
#include <oxt/backtrace.hpp>
|
35
|
+
#include <oxt/macros.hpp>
|
36
|
+
|
37
|
+
#include <string>
|
38
|
+
#include <vector>
|
39
|
+
#include <deque>
|
40
|
+
#include <cstring>
|
41
|
+
|
42
|
+
#include <jsoncpp/json.h>
|
43
|
+
#include <modp_b64.h>
|
44
|
+
|
45
|
+
#include <LoggingKit/Logging.h>
|
46
|
+
#include <ConfigKit/ConfigKit.h>
|
47
|
+
#include <ConfigKit/AsyncUtils.h>
|
48
|
+
#include <Exceptions.h>
|
49
|
+
#include <FileTools/PathManip.h>
|
50
|
+
#include <Utils.h>
|
51
|
+
#include <Utils/StrIntUtils.h>
|
52
|
+
#include <Utils/IOUtils.h>
|
53
|
+
|
54
|
+
namespace Passenger {
|
55
|
+
|
56
|
+
using namespace std;
|
57
|
+
|
58
|
+
|
59
|
+
#define WCRS_DEBUG_FRAME(self, expr1, expr2) \
|
60
|
+
P_LOG_UNLIKELY(Passenger::LoggingKit::context, \
|
61
|
+
(self)->_getDataDebugLevel(), \
|
62
|
+
__FILE__, __LINE__, \
|
63
|
+
(self)->_getLogPrefix() << expr1 << " \"" \
|
64
|
+
<< cEscapeString(expr2) << "\"")
|
65
|
+
|
66
|
+
|
67
|
+
/**
|
68
|
+
* A generic WebSocket command "server" that implements a request/response
|
69
|
+
* model.
|
70
|
+
*
|
71
|
+
* The reason why the name contains the word "reverse" is because it doesn't
|
72
|
+
* actually listens on a port. Instead, it connects to a port and receives
|
73
|
+
* commands from there.
|
74
|
+
*
|
75
|
+
* This class is generic in the sense that it handles all sorts of connection
|
76
|
+
* management logic such as reconnecting on failure, handling pings, timeouts,
|
77
|
+
* configuration, basic flow control, etc. It doesn't contain any logic for
|
78
|
+
* actually handling incoming commands: you are supposed to supply a function
|
79
|
+
* for handling incoming commands (the message handler). This allows seperating
|
80
|
+
* all the connection management logic from the actual message handling
|
81
|
+
* business logic.
|
82
|
+
*
|
83
|
+
* ## Usage
|
84
|
+
*
|
85
|
+
* static bool
|
86
|
+
* onMessage(WebSocketCommandReverseServer *server,
|
87
|
+
* const WebSocketCommandReverseServer::ConnectionPtr &conn,
|
88
|
+
* const WebSocketCommandReverseServer::MessagePtr &msg)
|
89
|
+
* {
|
90
|
+
* P_INFO("Message received: " << msg->get_payload());
|
91
|
+
* conn->send("Echo: " + msg->get_payload());
|
92
|
+
* return true;
|
93
|
+
* }
|
94
|
+
*
|
95
|
+
*
|
96
|
+
* // Set configuration
|
97
|
+
* Json::Value config;
|
98
|
+
* config["url"] = "ws://127.0.0.1:8001/";
|
99
|
+
*
|
100
|
+
* // Create and initialize the server
|
101
|
+
* WebSocketCommandReverseServer::Schema schema;
|
102
|
+
* WebSocketCommandReverseServer server(schema, onMessage, config);
|
103
|
+
* server.initialize();
|
104
|
+
*
|
105
|
+
* // Enter the server's main loop. This blocks until something
|
106
|
+
* // calls `server.shutdown()`.
|
107
|
+
* server.run();
|
108
|
+
*
|
109
|
+
* ## About the concurrency and I/O model
|
110
|
+
*
|
111
|
+
* WebSocketCommandReverseServer uses the WebSocket++ library and the
|
112
|
+
* Boost Asio I/O library. WebSocketCommandReverseServer manages its own
|
113
|
+
* event loop.
|
114
|
+
*
|
115
|
+
* The message handler will be called from the event loop's thread, so
|
116
|
+
* be careful.
|
117
|
+
*
|
118
|
+
* ## About flow control and backpressure
|
119
|
+
*
|
120
|
+
* We purposefully do not implement any flow control/backpressure on the
|
121
|
+
* WebSocket's _writing_ side. That is, if we send a large amount of data to
|
122
|
+
* the remote, then we do not wait until all that data has actually been
|
123
|
+
* sent out before proceeding to read the next message. Unfortunately the
|
124
|
+
* WebSocket++ API does not allow us to efficiently implement that:
|
125
|
+
* https://github.com/zaphoyd/websocketpp/issues/477
|
126
|
+
*
|
127
|
+
* As of 4 September 2017 (Boost 1.64.0, WebSocket++ 0.7.0),
|
128
|
+
* we also do not implement any flow control/backpressure
|
129
|
+
* on the WebSocket's _reading_ side. If the server floods us with requests
|
130
|
+
* then all of them will be buffered. We are unable to implement flow control
|
131
|
+
* on the reading side because of a bug in either WebSocket++ or ASIO: if you
|
132
|
+
* pause/resume the WebSocket then it results in data loss or data corruption.
|
133
|
+
*
|
134
|
+
* So the server is responsible for ensuring that it does not overload the
|
135
|
+
* WebSocketCommandReverseServer.
|
136
|
+
*/
|
137
|
+
class WebSocketCommandReverseServer {
|
138
|
+
public:
|
139
|
+
/*
|
140
|
+
* BEGIN ConfigKit schema: Passenger::WebSocketCommandReverseServer::Schema
|
141
|
+
* (do not edit: following text is automatically generated
|
142
|
+
* by 'rake configkit_schemas_inline_comments')
|
143
|
+
*
|
144
|
+
* authentication object - secret
|
145
|
+
* close_timeout float - default(10.0)
|
146
|
+
* connect_timeout float - default(30.0)
|
147
|
+
* data_debug boolean - default(false)
|
148
|
+
* log_prefix string - -
|
149
|
+
* ping_interval float - default(30.0)
|
150
|
+
* ping_timeout float - default(30.0)
|
151
|
+
* proxy_password string - secret
|
152
|
+
* proxy_timeout float - default(30.0)
|
153
|
+
* proxy_url string - -
|
154
|
+
* proxy_username string - -
|
155
|
+
* reconnect_timeout float - default(5.0)
|
156
|
+
* url string required -
|
157
|
+
* websocketpp_debug_access boolean - default(false)
|
158
|
+
* websocketpp_debug_error boolean - default(false)
|
159
|
+
*
|
160
|
+
* END
|
161
|
+
*/
|
162
|
+
class Schema: public ConfigKit::Schema {
|
163
|
+
private:
|
164
|
+
void initialize() {
|
165
|
+
using namespace ConfigKit;
|
166
|
+
|
167
|
+
add("url", STRING_TYPE, REQUIRED);
|
168
|
+
add("log_prefix", STRING_TYPE, OPTIONAL);
|
169
|
+
add("websocketpp_debug_access", BOOL_TYPE, OPTIONAL, false);
|
170
|
+
add("websocketpp_debug_error", BOOL_TYPE, OPTIONAL, false);
|
171
|
+
add("data_debug", BOOL_TYPE, OPTIONAL, false);
|
172
|
+
add("authentication", OBJECT_TYPE, OPTIONAL | SECRET);
|
173
|
+
add("proxy_url", STRING_TYPE, OPTIONAL);
|
174
|
+
add("proxy_username", STRING_TYPE, OPTIONAL);
|
175
|
+
add("proxy_password", STRING_TYPE, OPTIONAL | SECRET);
|
176
|
+
add("proxy_timeout", FLOAT_TYPE, OPTIONAL, 30.0);
|
177
|
+
add("connect_timeout", FLOAT_TYPE, OPTIONAL, 30.0);
|
178
|
+
add("ping_interval", FLOAT_TYPE, OPTIONAL, 30.0);
|
179
|
+
add("ping_timeout", FLOAT_TYPE, OPTIONAL, 30.0);
|
180
|
+
add("close_timeout", FLOAT_TYPE, OPTIONAL, 10.0);
|
181
|
+
add("reconnect_timeout", FLOAT_TYPE, OPTIONAL, 5.0);
|
182
|
+
|
183
|
+
addValidator(validateAuthentication);
|
184
|
+
addNormalizer(normalizeAuthentication);
|
185
|
+
}
|
186
|
+
|
187
|
+
static void validateAuthentication(const ConfigKit::Store &config, vector<ConfigKit::Error> &errors) {
|
188
|
+
typedef ConfigKit::Error Error;
|
189
|
+
|
190
|
+
if (config["authentication"].isNull() || !config["authentication"].isObject()) {
|
191
|
+
return;
|
192
|
+
}
|
193
|
+
|
194
|
+
if (!config["authentication"]["type"].isNull()) {
|
195
|
+
if (config["authentication"]["type"] != "basic") {
|
196
|
+
errors.push_back(Error("When '{{authentication}}' is given,"
|
197
|
+
" its 'type' key may only be set to 'basic'"));
|
198
|
+
}
|
199
|
+
}
|
200
|
+
if (!config["authentication"]["username"].isString()) {
|
201
|
+
errors.push_back(Error("When '{{authentication}}' is given,"
|
202
|
+
" its 'username' key must be a string"));
|
203
|
+
}
|
204
|
+
if (config["authentication"].isMember("password_file")) {
|
205
|
+
if (!config["authentication"]["password_file"].isString()) {
|
206
|
+
errors.push_back(Error("When '{{authentication}}' is given,"
|
207
|
+
" its 'password_file' key must be a string"));
|
208
|
+
}
|
209
|
+
if (config["authentication"].isMember("password")) {
|
210
|
+
errors.push_back(Error("When '{{authentication}}' is given,"
|
211
|
+
" it may not contain both a 'password_file' and a 'password' key"));
|
212
|
+
}
|
213
|
+
} else if (config["authentication"].isMember("password")) {
|
214
|
+
if (!config["authentication"]["password"].isString()) {
|
215
|
+
errors.push_back(Error("When '{{authentication}}' is given,"
|
216
|
+
" its 'password' key must be a string"));
|
217
|
+
}
|
218
|
+
} else {
|
219
|
+
errors.push_back(Error("When '{{authentication}}' is given,"
|
220
|
+
" it must have a 'password_file' or 'password' key"));
|
221
|
+
}
|
222
|
+
}
|
223
|
+
|
224
|
+
static Json::Value normalizeAuthentication(const Json::Value &effectiveValues) {
|
225
|
+
Json::Value auth = effectiveValues["authentication"];
|
226
|
+
if (auth.isNull()) {
|
227
|
+
return Json::nullValue;
|
228
|
+
}
|
229
|
+
|
230
|
+
Json::Value updates;
|
231
|
+
if (auth["type"].isNull()) {
|
232
|
+
auth["type"] = "basic";
|
233
|
+
}
|
234
|
+
if (auth.isMember("password_file")) {
|
235
|
+
auth["password_file"] = absolutizePath(auth["password_file"].asString());
|
236
|
+
}
|
237
|
+
updates["authentication"] = auth;
|
238
|
+
return updates;
|
239
|
+
}
|
240
|
+
|
241
|
+
public:
|
242
|
+
Schema() {
|
243
|
+
initialize();
|
244
|
+
finalize();
|
245
|
+
}
|
246
|
+
|
247
|
+
Schema(bool _subclassing) {
|
248
|
+
initialize();
|
249
|
+
}
|
250
|
+
};
|
251
|
+
|
252
|
+
struct ConfigRealization {
|
253
|
+
string logPrefix;
|
254
|
+
bool dataDebug;
|
255
|
+
|
256
|
+
ConfigRealization(const ConfigKit::Store &config)
|
257
|
+
: logPrefix(config["log_prefix"].asString()),
|
258
|
+
dataDebug(config["data_debug"].asBool())
|
259
|
+
{ }
|
260
|
+
|
261
|
+
void swap(ConfigRealization &other) BOOST_NOEXCEPT_OR_NOTHROW {
|
262
|
+
logPrefix.swap(other.logPrefix);
|
263
|
+
std::swap(dataDebug, other.dataDebug);
|
264
|
+
}
|
265
|
+
};
|
266
|
+
|
267
|
+
struct ConfigChangeRequest {
|
268
|
+
boost::scoped_ptr<ConfigKit::Store> config;
|
269
|
+
boost::scoped_ptr<ConfigRealization> configRlz;
|
270
|
+
};
|
271
|
+
|
272
|
+
typedef websocketpp::client<websocketpp::config::asio_client> Endpoint;
|
273
|
+
typedef Endpoint::connection_ptr ConnectionPtr;
|
274
|
+
typedef Endpoint::message_ptr MessagePtr;
|
275
|
+
typedef websocketpp::connection_hdl ConnectionWeakPtr;
|
276
|
+
|
277
|
+
typedef boost::function<void ()> Callback;
|
278
|
+
typedef boost::function<void (const Json::Value &doc)> InspectCallback;
|
279
|
+
typedef boost::function<bool (WebSocketCommandReverseServer *server,
|
280
|
+
const ConnectionPtr &conn, const MessagePtr &msg)> MessageHandler;
|
281
|
+
|
282
|
+
enum State {
|
283
|
+
UNINITIALIZED,
|
284
|
+
NOT_CONNECTED,
|
285
|
+
CONNECTING,
|
286
|
+
WAITING_FOR_REQUEST,
|
287
|
+
REPLYING,
|
288
|
+
CLOSING,
|
289
|
+
SHUT_DOWN
|
290
|
+
};
|
291
|
+
|
292
|
+
private:
|
293
|
+
ConfigKit::Store config;
|
294
|
+
ConfigRealization configRlz;
|
295
|
+
|
296
|
+
Endpoint endpoint;
|
297
|
+
ConnectionPtr conn;
|
298
|
+
boost::shared_ptr<boost::asio::deadline_timer> timer;
|
299
|
+
MessageHandler messageHandler;
|
300
|
+
Callback shutdownCallback;
|
301
|
+
mutable boost::mutex stateSyncher;
|
302
|
+
State state;
|
303
|
+
deque<MessagePtr> buffer;
|
304
|
+
bool reconnectAfterReply;
|
305
|
+
bool shuttingDown;
|
306
|
+
|
307
|
+
/**
|
308
|
+
* It could happen that a certain method or handler is invoked
|
309
|
+
* for a connection that has already been closed. For example,
|
310
|
+
* after the message handler was invoked and before the message
|
311
|
+
* handler called doneReplying(), it could happen that the connection
|
312
|
+
* was reset. This method allows detecting those cases so that
|
313
|
+
* the code can decide not to do anything.
|
314
|
+
*/
|
315
|
+
bool isCurrentConnection(const ConnectionPtr &c) {
|
316
|
+
return conn && c.get() == conn.get();
|
317
|
+
}
|
318
|
+
|
319
|
+
bool isCurrentConnection(const ConnectionWeakPtr &wconn) {
|
320
|
+
return conn && endpoint.get_con_from_hdl(wconn).get() == conn.get();
|
321
|
+
}
|
322
|
+
|
323
|
+
static bool connectionIsConnected(const ConnectionPtr &c) {
|
324
|
+
websocketpp::session::state::value state = c->get_state();
|
325
|
+
return state == websocketpp::session::state::connecting
|
326
|
+
|| state == websocketpp::session::state::open;
|
327
|
+
}
|
328
|
+
|
329
|
+
bool isConnected(const ConnectionPtr &c) {
|
330
|
+
return isCurrentConnection(c) && connectionIsConnected(c);
|
331
|
+
}
|
332
|
+
|
333
|
+
bool isConnected(const ConnectionWeakPtr &wconn) {
|
334
|
+
if (OXT_UNLIKELY(!conn)) {
|
335
|
+
return false;
|
336
|
+
}
|
337
|
+
|
338
|
+
ConnectionPtr c = endpoint.get_con_from_hdl(wconn);
|
339
|
+
if (OXT_UNLIKELY(c.get() != conn.get())) {
|
340
|
+
return false;
|
341
|
+
}
|
342
|
+
|
343
|
+
return connectionIsConnected(c);
|
344
|
+
}
|
345
|
+
|
346
|
+
const string &getLogPrefix() const {
|
347
|
+
return configRlz.logPrefix;
|
348
|
+
}
|
349
|
+
|
350
|
+
void activateConfigUpdates(const ConfigKit::Store *oldConfig) {
|
351
|
+
if (config["websocketpp_debug_access"].asBool()) {
|
352
|
+
endpoint.set_access_channels(websocketpp::log::alevel::all);
|
353
|
+
} else {
|
354
|
+
endpoint.clear_access_channels(websocketpp::log::alevel::all);
|
355
|
+
}
|
356
|
+
if (config["websocketpp_debug_error"].asBool()) {
|
357
|
+
endpoint.set_error_channels(websocketpp::log::elevel::all);
|
358
|
+
} else {
|
359
|
+
endpoint.clear_error_channels(websocketpp::log::elevel::all);
|
360
|
+
}
|
361
|
+
|
362
|
+
if (oldConfig == NULL) {
|
363
|
+
return;
|
364
|
+
}
|
365
|
+
bool shouldReconnect =
|
366
|
+
oldConfig->get("url").asString() != config["url"].asString() ||
|
367
|
+
oldConfig->get("proxy_url").asString() != config["proxy_url"].asString() ||
|
368
|
+
oldConfig->get("data_debug").asBool() != config["data_debug"].asBool() ||
|
369
|
+
oldConfig->get("websocketpp_debug_access").asBool() != config["websocketpp_debug_access"].asBool() ||
|
370
|
+
oldConfig->get("websocketpp_debug_error").asBool() != config["websocketpp_debug_error"].asBool();
|
371
|
+
if (shouldReconnect) {
|
372
|
+
internalReconnect();
|
373
|
+
}
|
374
|
+
}
|
375
|
+
|
376
|
+
void internalInspectState(const InspectCallback callback) {
|
377
|
+
Json::Value doc(Json::objectValue);
|
378
|
+
doc["state"] = getStateString();
|
379
|
+
doc["buffer"]["message_count"] = (Json::UInt) buffer.size();
|
380
|
+
if (reconnectAfterReply) {
|
381
|
+
doc["reconnect_planned"] = true;
|
382
|
+
}
|
383
|
+
if (shuttingDown) {
|
384
|
+
doc["shutting_down"] = true;
|
385
|
+
}
|
386
|
+
callback(doc);
|
387
|
+
}
|
388
|
+
|
389
|
+
string getStateString() const {
|
390
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
391
|
+
switch (state) {
|
392
|
+
case UNINITIALIZED:
|
393
|
+
return "UNINITIALIZED";
|
394
|
+
case NOT_CONNECTED:
|
395
|
+
return "NOT_CONNECTED";
|
396
|
+
case CONNECTING:
|
397
|
+
return "CONNECTING";
|
398
|
+
case WAITING_FOR_REQUEST:
|
399
|
+
return "WAITING_FOR_REQUEST";
|
400
|
+
case REPLYING:
|
401
|
+
return "REPLYING";
|
402
|
+
case CLOSING:
|
403
|
+
return "CLOSING";
|
404
|
+
case SHUT_DOWN:
|
405
|
+
return "SHUT_DOWN";
|
406
|
+
default:
|
407
|
+
return "UNKNOWN";
|
408
|
+
};
|
409
|
+
}
|
410
|
+
|
411
|
+
void internalShutdown(const Callback callback) {
|
412
|
+
shuttingDown = true;
|
413
|
+
shutdownCallback = callback;
|
414
|
+
closeConnection(websocketpp::close::status::going_away,
|
415
|
+
"shutting down");
|
416
|
+
}
|
417
|
+
|
418
|
+
void startConnect() {
|
419
|
+
websocketpp::lib::error_code ec;
|
420
|
+
|
421
|
+
{
|
422
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
423
|
+
state = CONNECTING;
|
424
|
+
}
|
425
|
+
|
426
|
+
P_NOTICE(getLogPrefix() << "Connecting to " << config["url"].asString());
|
427
|
+
conn = endpoint.get_connection(config["url"].asString(), ec);
|
428
|
+
if (ec) {
|
429
|
+
P_ERROR(getLogPrefix() << "Error setting up a socket to "
|
430
|
+
<< config["url"].asString() << ": " << ec.message());
|
431
|
+
{
|
432
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
433
|
+
state = NOT_CONNECTED;
|
434
|
+
}
|
435
|
+
scheduleReconnect();
|
436
|
+
return;
|
437
|
+
}
|
438
|
+
|
439
|
+
if (!applyConnectionConfig(conn)) {
|
440
|
+
// applyConnectionConfig() already logs an error.
|
441
|
+
{
|
442
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
443
|
+
state = NOT_CONNECTED;
|
444
|
+
}
|
445
|
+
scheduleReconnect();
|
446
|
+
return;
|
447
|
+
}
|
448
|
+
|
449
|
+
using websocketpp::lib::placeholders::_1;
|
450
|
+
using websocketpp::lib::placeholders::_2;
|
451
|
+
|
452
|
+
if (!config["authentication"].isNull()) {
|
453
|
+
try {
|
454
|
+
addBasicAuthHeader(conn);
|
455
|
+
} catch (const std::exception &e) {
|
456
|
+
P_ERROR(getLogPrefix() << "Error setting up basic authentication: "
|
457
|
+
<< e.what());
|
458
|
+
{
|
459
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
460
|
+
state = NOT_CONNECTED;
|
461
|
+
}
|
462
|
+
scheduleReconnect();
|
463
|
+
return;
|
464
|
+
}
|
465
|
+
}
|
466
|
+
|
467
|
+
conn->set_socket_init_handler(websocketpp::lib::bind(
|
468
|
+
&WebSocketCommandReverseServer::onSocketInit,
|
469
|
+
this,
|
470
|
+
_1,
|
471
|
+
_2));
|
472
|
+
conn->set_open_handler(websocketpp::lib::bind(
|
473
|
+
&WebSocketCommandReverseServer::onConnected,
|
474
|
+
this,
|
475
|
+
_1));
|
476
|
+
conn->set_fail_handler(websocketpp::lib::bind(
|
477
|
+
&WebSocketCommandReverseServer::onConnectFailed,
|
478
|
+
this,
|
479
|
+
websocketpp::lib::placeholders::_1));
|
480
|
+
conn->set_close_handler(websocketpp::lib::bind(
|
481
|
+
&WebSocketCommandReverseServer::onConnectionClosed,
|
482
|
+
this,
|
483
|
+
websocketpp::lib::placeholders::_1));
|
484
|
+
conn->set_pong_timeout_handler(websocketpp::lib::bind(
|
485
|
+
&WebSocketCommandReverseServer::onPongTimeout,
|
486
|
+
this,
|
487
|
+
_1,
|
488
|
+
_2));
|
489
|
+
conn->set_pong_handler(websocketpp::lib::bind(
|
490
|
+
&WebSocketCommandReverseServer::onPong,
|
491
|
+
this,
|
492
|
+
_1,
|
493
|
+
_2));
|
494
|
+
conn->set_message_handler(websocketpp::lib::bind(
|
495
|
+
&WebSocketCommandReverseServer::onMessage,
|
496
|
+
this,
|
497
|
+
_1,
|
498
|
+
_2));
|
499
|
+
|
500
|
+
endpoint.connect(conn);
|
501
|
+
}
|
502
|
+
|
503
|
+
void addBasicAuthHeader(ConnectionPtr &conn) {
|
504
|
+
string username = config["authentication"]["username"].asString();
|
505
|
+
string password;
|
506
|
+
if (config["authentication"].isMember("password_file")) {
|
507
|
+
password = strip(readAll(config["authentication"]["password_file"].asString()));
|
508
|
+
} else {
|
509
|
+
password = config["authentication"]["password"].asString();
|
510
|
+
}
|
511
|
+
string data = modp::b64_encode(username + ":" + password);
|
512
|
+
conn->append_header("Authorization", "Basic " + data);
|
513
|
+
}
|
514
|
+
|
515
|
+
bool applyConnectionConfig(ConnectionPtr &conn) {
|
516
|
+
websocketpp::lib::error_code ec;
|
517
|
+
|
518
|
+
if (!config["proxy_url"].isNull()) {
|
519
|
+
conn->set_proxy(config["proxy_url"].asString(), ec);
|
520
|
+
if (ec) {
|
521
|
+
P_ERROR(getLogPrefix()
|
522
|
+
<< "Error setting proxy URL to "
|
523
|
+
<< config["proxy_url"].asString() << ": "
|
524
|
+
<< ec.message());
|
525
|
+
return false;
|
526
|
+
}
|
527
|
+
|
528
|
+
if (!config["proxy_username"].isNull() || !config["proxy_password"].isNull()) {
|
529
|
+
conn->set_proxy_basic_auth(config["proxy_username"].asString(),
|
530
|
+
config["proxy_password"].asString(), ec);
|
531
|
+
if (ec) {
|
532
|
+
P_ERROR(getLogPrefix()
|
533
|
+
<< "Error setting proxy authentication credentials to "
|
534
|
+
<< config["proxy_username"].asString() << ":<password omitted>:"
|
535
|
+
<< ec.message());
|
536
|
+
return false;
|
537
|
+
}
|
538
|
+
}
|
539
|
+
|
540
|
+
conn->set_proxy_timeout(config["proxy_timeout"].asDouble() * 1000, ec);
|
541
|
+
if (ec) {
|
542
|
+
P_ERROR(getLogPrefix()
|
543
|
+
<< "Error setting proxy timeout to "
|
544
|
+
<< config["proxy_timeout"].asDouble() << " seconds: "
|
545
|
+
<< ec.message());
|
546
|
+
return false;
|
547
|
+
}
|
548
|
+
}
|
549
|
+
|
550
|
+
conn->set_open_handshake_timeout(config["connect_timeout"].asDouble() * 1000);
|
551
|
+
conn->set_pong_timeout(config["ping_timeout"].asDouble() * 1000);
|
552
|
+
conn->set_close_handshake_timeout(config["close_timeout"].asDouble() * 1000);
|
553
|
+
|
554
|
+
return true;
|
555
|
+
}
|
556
|
+
|
557
|
+
void internalReconnect() {
|
558
|
+
switch (state) {
|
559
|
+
case NOT_CONNECTED:
|
560
|
+
// Do nothing.
|
561
|
+
break;
|
562
|
+
case CONNECTING:
|
563
|
+
case WAITING_FOR_REQUEST:
|
564
|
+
closeConnection(websocketpp::close::status::service_restart,
|
565
|
+
"reestablishing connection in order to apply configuration updates");
|
566
|
+
break;
|
567
|
+
case REPLYING:
|
568
|
+
reconnectAfterReply = true;
|
569
|
+
return;
|
570
|
+
default:
|
571
|
+
P_BUG("Unsupported state " + toString(state));
|
572
|
+
}
|
573
|
+
}
|
574
|
+
|
575
|
+
void scheduleReconnect() {
|
576
|
+
P_NOTICE(getLogPrefix() << "Reestablishing connection in " <<
|
577
|
+
config["reconnect_timeout"].asDouble() << " seconds");
|
578
|
+
restartTimer(config["reconnect_timeout"].asDouble() * 1000);
|
579
|
+
}
|
580
|
+
|
581
|
+
void closeConnection(websocketpp::close::status::value code,
|
582
|
+
const string &reason)
|
583
|
+
{
|
584
|
+
websocketpp::lib::error_code ec;
|
585
|
+
|
586
|
+
{
|
587
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
588
|
+
state = CLOSING;
|
589
|
+
}
|
590
|
+
|
591
|
+
P_NOTICE(getLogPrefix() << "Closing connection: " << reason);
|
592
|
+
reconnectAfterReply = false;
|
593
|
+
timer->cancel();
|
594
|
+
conn->close(code, reason, ec);
|
595
|
+
conn.reset();
|
596
|
+
if (ec) {
|
597
|
+
P_WARN(getLogPrefix() << "Error closing connection: " << ec.message());
|
598
|
+
}
|
599
|
+
|
600
|
+
{
|
601
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
602
|
+
state = NOT_CONNECTED;
|
603
|
+
}
|
604
|
+
if (!shuttingDown) {
|
605
|
+
scheduleReconnect();
|
606
|
+
}
|
607
|
+
}
|
608
|
+
|
609
|
+
void restartTimer(unsigned int ms) {
|
610
|
+
timer->expires_from_now(boost::posix_time::milliseconds(ms));
|
611
|
+
timer->async_wait(boost::bind(
|
612
|
+
&WebSocketCommandReverseServer::onTimeout,
|
613
|
+
this,
|
614
|
+
boost::placeholders::_1));
|
615
|
+
}
|
616
|
+
|
617
|
+
void onSocketInit(ConnectionWeakPtr wconn, boost::asio::ip::tcp::socket &s) {
|
618
|
+
boost::asio::ip::tcp::no_delay option(true);
|
619
|
+
s.set_option(option);
|
620
|
+
}
|
621
|
+
|
622
|
+
void onConnected(ConnectionWeakPtr wconn) {
|
623
|
+
if (!isConnected(wconn)) {
|
624
|
+
P_DEBUG(getLogPrefix() << "onConnected: stale connection");
|
625
|
+
return;
|
626
|
+
}
|
627
|
+
|
628
|
+
P_NOTICE(getLogPrefix() << "Connection established");
|
629
|
+
{
|
630
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
631
|
+
state = WAITING_FOR_REQUEST;
|
632
|
+
}
|
633
|
+
buffer.clear();
|
634
|
+
P_DEBUG(getLogPrefix() << "Scheduling next ping in " <<
|
635
|
+
config["ping_interval"].asDouble() << " seconds");
|
636
|
+
restartTimer(config["ping_interval"].asDouble() * 1000);
|
637
|
+
}
|
638
|
+
|
639
|
+
void onConnectFailed(ConnectionWeakPtr wconn) {
|
640
|
+
if (!isCurrentConnection(wconn)) {
|
641
|
+
P_DEBUG(getLogPrefix() << "onConnectFailed: not current connection");
|
642
|
+
return;
|
643
|
+
}
|
644
|
+
|
645
|
+
if (LoggingKit::getLevel() >= LoggingKit::ERROR) {
|
646
|
+
string message;
|
647
|
+
if (strcmp(conn->get_ec().category().name(), "websocketpp.processor") == 0
|
648
|
+
&& conn->get_ec().value() == websocketpp::processor::error::invalid_http_status)
|
649
|
+
{
|
650
|
+
if (conn->get_response_code() == websocketpp::http::status_code::unauthorized) {
|
651
|
+
message = "server authentication error";
|
652
|
+
} else {
|
653
|
+
message = conn->get_ec().message();
|
654
|
+
}
|
655
|
+
} else {
|
656
|
+
message = conn->get_ec().message();
|
657
|
+
}
|
658
|
+
P_ERROR(getLogPrefix() << "Unable to establish connection: " << message);
|
659
|
+
}
|
660
|
+
{
|
661
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
662
|
+
state = NOT_CONNECTED;
|
663
|
+
}
|
664
|
+
scheduleReconnect();
|
665
|
+
}
|
666
|
+
|
667
|
+
void onConnectionClosed(ConnectionWeakPtr wconn) {
|
668
|
+
if (!isCurrentConnection(wconn)) {
|
669
|
+
P_DEBUG(getLogPrefix() << "onConnectionClosed: not current connection");
|
670
|
+
return;
|
671
|
+
}
|
672
|
+
|
673
|
+
P_NOTICE(getLogPrefix() << "Connection closed (server close reason: " <<
|
674
|
+
conn->get_remote_close_code() << ": " <<
|
675
|
+
conn->get_remote_close_reason() << ")");
|
676
|
+
{
|
677
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
678
|
+
state = NOT_CONNECTED;
|
679
|
+
}
|
680
|
+
reconnectAfterReply = false;
|
681
|
+
|
682
|
+
if (shuttingDown) {
|
683
|
+
timer->cancel();
|
684
|
+
} else {
|
685
|
+
scheduleReconnect();
|
686
|
+
}
|
687
|
+
}
|
688
|
+
|
689
|
+
void onTimeout(const boost::system::error_code &e) {
|
690
|
+
if (e.value() == boost::system::errc::operation_canceled) {
|
691
|
+
P_DEBUG(getLogPrefix() << "onTimeout: operation cancelled");
|
692
|
+
return;
|
693
|
+
}
|
694
|
+
if (e) {
|
695
|
+
P_ERROR(getLogPrefix() << "Error in timer: " << e.message());
|
696
|
+
return;
|
697
|
+
}
|
698
|
+
|
699
|
+
websocketpp::lib::error_code ec;
|
700
|
+
|
701
|
+
switch (state) {
|
702
|
+
case NOT_CONNECTED:
|
703
|
+
startConnect();
|
704
|
+
break;
|
705
|
+
case WAITING_FOR_REQUEST:
|
706
|
+
case REPLYING:
|
707
|
+
P_DEBUG(getLogPrefix() << "Sending ping");
|
708
|
+
conn->ping("ping", ec);
|
709
|
+
if (ec) {
|
710
|
+
closeConnection(websocketpp::close::status::normal,
|
711
|
+
"error sending ping");
|
712
|
+
}
|
713
|
+
// After sending the ping, we wait until either
|
714
|
+
// onPong() or onPongTimeout() is called before
|
715
|
+
// scheduling the next ping.
|
716
|
+
break;
|
717
|
+
default:
|
718
|
+
P_BUG("Unsupported state " + toString(state));
|
719
|
+
break;
|
720
|
+
}
|
721
|
+
}
|
722
|
+
|
723
|
+
void onPongTimeout(ConnectionWeakPtr wconn, const string &payload) {
|
724
|
+
if (!isCurrentConnection(wconn)) {
|
725
|
+
P_DEBUG(getLogPrefix() << "onPongTimeout: not current connection");
|
726
|
+
return;
|
727
|
+
}
|
728
|
+
|
729
|
+
switch (state) {
|
730
|
+
case REPLYING:
|
731
|
+
// Ignore pong timeouts while replying because
|
732
|
+
// reading is paused while replying.
|
733
|
+
P_DEBUG(getLogPrefix() << "onPongTimeout: ignoring REPLYING state");
|
734
|
+
break;
|
735
|
+
default:
|
736
|
+
P_DEBUG(getLogPrefix() << "onPongTimeout: closing connection");
|
737
|
+
closeConnection(websocketpp::close::status::normal,
|
738
|
+
"reconnecting because of pong timeout");
|
739
|
+
break;
|
740
|
+
}
|
741
|
+
}
|
742
|
+
|
743
|
+
void onPong(ConnectionWeakPtr wconn, const string &payload) {
|
744
|
+
if (!isConnected(wconn)) {
|
745
|
+
P_DEBUG(getLogPrefix() << "onPong: stale connection");
|
746
|
+
return;
|
747
|
+
}
|
748
|
+
|
749
|
+
P_DEBUG(getLogPrefix() << "Pong received. Scheduling next ping in " <<
|
750
|
+
config["ping_interval"].asDouble() << " seconds");
|
751
|
+
restartTimer(config["ping_interval"].asDouble() * 1000);
|
752
|
+
}
|
753
|
+
|
754
|
+
void onMessage(ConnectionWeakPtr wconn, MessagePtr msg) {
|
755
|
+
if (!isConnected(wconn)) {
|
756
|
+
P_DEBUG(getLogPrefix() << "onMessage: stale connection");
|
757
|
+
return;
|
758
|
+
}
|
759
|
+
|
760
|
+
switch (state) {
|
761
|
+
case WAITING_FOR_REQUEST:
|
762
|
+
P_DEBUG(getLogPrefix() << "onMessage: got frame of " <<
|
763
|
+
msg->get_payload().size() << " bytes");
|
764
|
+
WCRS_DEBUG_FRAME(this, "Received message's frame data:", msg->get_payload());
|
765
|
+
{
|
766
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
767
|
+
state = REPLYING;
|
768
|
+
}
|
769
|
+
if (messageHandler(this, conn, msg)) {
|
770
|
+
doneReplying(conn);
|
771
|
+
} else {
|
772
|
+
// We do not pause the connection here because of what appears
|
773
|
+
// to be an ASIO bug.
|
774
|
+
// See class header comments, "About flow control and backpressure".
|
775
|
+
//conn->pause_reading();
|
776
|
+
}
|
777
|
+
break;
|
778
|
+
case CLOSING:
|
779
|
+
// Ignore any incoming messages while closing.
|
780
|
+
P_DEBUG(getLogPrefix() << "onMessage: ignoring CLOSING state");
|
781
|
+
break;
|
782
|
+
case REPLYING:
|
783
|
+
// Even if we call conn->pause_reading(), WebSocket++
|
784
|
+
// may already have received further messages in its buffer,
|
785
|
+
// which it will still pass to us. Don't process these
|
786
|
+
// and just buffer them.
|
787
|
+
P_DEBUG(getLogPrefix() << "onMessage: got frame of " <<
|
788
|
+
msg->get_payload().size() << " bytes (pushed to buffer -> "
|
789
|
+
<< (buffer.size() + 1) << " entries)");
|
790
|
+
WCRS_DEBUG_FRAME(this, "Received message's frame data:", msg->get_payload());
|
791
|
+
buffer.push_back(msg);
|
792
|
+
break;
|
793
|
+
default:
|
794
|
+
P_BUG("Unsupported state " + toString(state));
|
795
|
+
}
|
796
|
+
}
|
797
|
+
|
798
|
+
public:
|
799
|
+
WebSocketCommandReverseServer(const Schema &schema, const MessageHandler &_messageHandler,
|
800
|
+
const Json::Value &initialConfig,
|
801
|
+
const ConfigKit::Translator &translator = ConfigKit::DummyTranslator())
|
802
|
+
: config(schema, initialConfig, translator),
|
803
|
+
configRlz(config),
|
804
|
+
messageHandler(_messageHandler),
|
805
|
+
state(UNINITIALIZED),
|
806
|
+
reconnectAfterReply(false),
|
807
|
+
shuttingDown(false)
|
808
|
+
{
|
809
|
+
activateConfigUpdates(NULL);
|
810
|
+
}
|
811
|
+
|
812
|
+
void initialize() {
|
813
|
+
endpoint.init_asio();
|
814
|
+
state = NOT_CONNECTED;
|
815
|
+
timer = boost::make_shared<boost::asio::deadline_timer, boost::asio::io_service &>(
|
816
|
+
endpoint.get_io_service());
|
817
|
+
startConnect();
|
818
|
+
}
|
819
|
+
|
820
|
+
/**
|
821
|
+
* Enter the server's event loop. This method blocks until
|
822
|
+
* the server is shut down.
|
823
|
+
*
|
824
|
+
* May only be called once, and only after `initialize()` is called.
|
825
|
+
*/
|
826
|
+
void run() {
|
827
|
+
endpoint.run();
|
828
|
+
{
|
829
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
830
|
+
state = SHUT_DOWN;
|
831
|
+
}
|
832
|
+
if (shutdownCallback) {
|
833
|
+
shutdownCallback();
|
834
|
+
}
|
835
|
+
}
|
836
|
+
|
837
|
+
|
838
|
+
const ConfigKit::Store &getConfig() const {
|
839
|
+
return config;
|
840
|
+
}
|
841
|
+
|
842
|
+
boost::asio::io_service &getIoService() {
|
843
|
+
return endpoint.get_io_service();
|
844
|
+
}
|
845
|
+
|
846
|
+
|
847
|
+
bool prepareConfigChange(const Json::Value &updates,
|
848
|
+
vector<ConfigKit::Error> &errors, ConfigChangeRequest &req)
|
849
|
+
{
|
850
|
+
req.config.reset(new ConfigKit::Store(config, updates, errors));
|
851
|
+
if (errors.empty()) {
|
852
|
+
req.configRlz.reset(new ConfigRealization(*req.config));
|
853
|
+
}
|
854
|
+
return errors.empty();
|
855
|
+
}
|
856
|
+
|
857
|
+
void commitConfigChange(ConfigChangeRequest &req) BOOST_NOEXCEPT_OR_NOTHROW {
|
858
|
+
config.swap(*req.config);
|
859
|
+
configRlz.swap(*req.configRlz);
|
860
|
+
activateConfigUpdates(req.config.get());
|
861
|
+
}
|
862
|
+
|
863
|
+
Json::Value inspectConfig() const {
|
864
|
+
return config.inspect();
|
865
|
+
}
|
866
|
+
|
867
|
+
|
868
|
+
void asyncPrepareConfigChange(const Json::Value &updates,
|
869
|
+
ConfigChangeRequest &req,
|
870
|
+
const ConfigKit::CallbackTypes<WebSocketCommandReverseServer>::PrepareConfigChange &callback)
|
871
|
+
{
|
872
|
+
endpoint.get_io_service().post(boost::bind(
|
873
|
+
ConfigKit::callPrepareConfigChangeAndCallback<WebSocketCommandReverseServer>,
|
874
|
+
this, updates, &req, callback));
|
875
|
+
}
|
876
|
+
|
877
|
+
void asyncCommitConfigChange(ConfigChangeRequest &req,
|
878
|
+
const ConfigKit::CallbackTypes<WebSocketCommandReverseServer>::CommitConfigChange &callback)
|
879
|
+
BOOST_NOEXCEPT_OR_NOTHROW
|
880
|
+
{
|
881
|
+
endpoint.get_io_service().post(boost::bind(
|
882
|
+
ConfigKit::callCommitConfigChangeAndCallback<WebSocketCommandReverseServer>,
|
883
|
+
this, &req, callback));
|
884
|
+
}
|
885
|
+
|
886
|
+
void asyncInspectConfig(const ConfigKit::CallbackTypes<WebSocketCommandReverseServer>::InspectConfig &callback) {
|
887
|
+
endpoint.get_io_service().post(boost::bind(
|
888
|
+
ConfigKit::callInspectConfigAndCallback<WebSocketCommandReverseServer>,
|
889
|
+
this, callback));
|
890
|
+
}
|
891
|
+
|
892
|
+
void asyncInspectState(const InspectCallback &callback) {
|
893
|
+
endpoint.get_io_service().post(boost::bind(
|
894
|
+
&WebSocketCommandReverseServer::internalInspectState,
|
895
|
+
this, callback));
|
896
|
+
}
|
897
|
+
|
898
|
+
/**
|
899
|
+
* Prepares this server for shut down. It will finish any replies that
|
900
|
+
* are in-flight and will close the connection. When finished, it will
|
901
|
+
* call the given callback (if any) from the thread that invoked
|
902
|
+
* `run()`.
|
903
|
+
*
|
904
|
+
* May only be called when the event loop is running.
|
905
|
+
* This method is thread-safe and may be called from any thread.
|
906
|
+
*/
|
907
|
+
void asyncShutdown(const Callback &callback = Callback()) {
|
908
|
+
endpoint.get_io_service().post(boost::bind(
|
909
|
+
&WebSocketCommandReverseServer::internalShutdown,
|
910
|
+
this, callback));
|
911
|
+
}
|
912
|
+
|
913
|
+
|
914
|
+
/**
|
915
|
+
* When the message handler is done sending a reply, it must
|
916
|
+
* call this method to tell the server that the reply is done.
|
917
|
+
*
|
918
|
+
* May only be called when the server is in the REPLYING state.
|
919
|
+
* May only be called from the event loop's thread.
|
920
|
+
*/
|
921
|
+
void doneReplying(const ConnectionPtr &conn) {
|
922
|
+
begin:
|
923
|
+
|
924
|
+
if (!isConnected(conn)) {
|
925
|
+
P_DEBUG(getLogPrefix() << "doneReplying: stale connection");
|
926
|
+
return;
|
927
|
+
}
|
928
|
+
|
929
|
+
P_DEBUG(getLogPrefix() << "Done replying");
|
930
|
+
P_ASSERT_EQ(state, REPLYING);
|
931
|
+
|
932
|
+
{
|
933
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
934
|
+
state = WAITING_FOR_REQUEST;
|
935
|
+
}
|
936
|
+
if (reconnectAfterReply) {
|
937
|
+
reconnectAfterReply = false;
|
938
|
+
internalReconnect();
|
939
|
+
return;
|
940
|
+
}
|
941
|
+
|
942
|
+
if (buffer.empty()) {
|
943
|
+
// We do not resume the connection here because of what appears
|
944
|
+
// to be an ASIO bug.
|
945
|
+
// See class header comments, "About flow control and backpressure".
|
946
|
+
//conn->resume_reading();
|
947
|
+
} else {
|
948
|
+
MessagePtr msg = buffer.front();
|
949
|
+
P_DEBUG(getLogPrefix() << "Process next message in buffer ("
|
950
|
+
<< buffer.size() << " entries): " <<
|
951
|
+
msg->get_payload().size() << " bytes");
|
952
|
+
WCRS_DEBUG_FRAME(this, "Buffered message's frame data:", msg->get_payload());
|
953
|
+
buffer.pop_front();
|
954
|
+
{
|
955
|
+
boost::lock_guard<boost::mutex> l(stateSyncher);
|
956
|
+
state = REPLYING;
|
957
|
+
}
|
958
|
+
if (messageHandler(this, conn, msg)) {
|
959
|
+
goto begin;
|
960
|
+
}
|
961
|
+
}
|
962
|
+
}
|
963
|
+
|
964
|
+
|
965
|
+
const string &_getLogPrefix() const {
|
966
|
+
return getLogPrefix();
|
967
|
+
}
|
968
|
+
|
969
|
+
LoggingKit::Level _getDataDebugLevel() const {
|
970
|
+
if (OXT_UNLIKELY(configRlz.dataDebug)) {
|
971
|
+
return LoggingKit::NOTICE;
|
972
|
+
} else {
|
973
|
+
return LoggingKit::DEBUG2;
|
974
|
+
}
|
975
|
+
}
|
976
|
+
};
|
977
|
+
|
978
|
+
|
979
|
+
} // namespace Passenger
|
980
|
+
|
981
|
+
#endif /* _PASSENGER_WEB_SOCKET_COMMAND_REVERSE_SERVER_H_ */
|