aboutsummaryrefslogtreecommitdiffstats
path: root/websocketpp/config
diff options
context:
space:
mode:
Diffstat (limited to 'websocketpp/config')
-rw-r--r--websocketpp/config/asio.hpp77
-rw-r--r--websocketpp/config/asio_client.hpp77
-rw-r--r--websocketpp/config/asio_no_tls.hpp73
-rw-r--r--websocketpp/config/asio_no_tls_client.hpp73
-rw-r--r--websocketpp/config/boost_config.hpp72
-rw-r--r--websocketpp/config/core.hpp285
-rw-r--r--websocketpp/config/core_client.hpp294
-rw-r--r--websocketpp/config/debug.hpp286
-rw-r--r--websocketpp/config/debug_asio.hpp77
-rw-r--r--websocketpp/config/debug_asio_no_tls.hpp73
-rw-r--r--websocketpp/config/minimal_client.hpp72
-rw-r--r--websocketpp/config/minimal_server.hpp312
12 files changed, 1771 insertions, 0 deletions
diff --git a/websocketpp/config/asio.hpp b/websocketpp/config/asio.hpp
new file mode 100644
index 00000000..d28d0fb8
--- /dev/null
+++ b/websocketpp/config/asio.hpp
@@ -0,0 +1,77 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_ASIO_TLS_HPP
+#define WEBSOCKETPP_CONFIG_ASIO_TLS_HPP
+
+#include <websocketpp/config/core.hpp>
+#include <websocketpp/transport/asio/endpoint.hpp>
+#include <websocketpp/transport/asio/security/tls.hpp>
+
+// Pull in non-tls config
+#include <websocketpp/config/asio_no_tls.hpp>
+
+// Define TLS config
+namespace websocketpp {
+namespace config {
+
+/// Server config with asio transport and TLS enabled
+struct asio_tls : public core {
+ typedef asio_tls type;
+ typedef core base;
+
+ typedef base::concurrency_type concurrency_type;
+
+ typedef base::request_type request_type;
+ typedef base::response_type response_type;
+
+ typedef base::message_type message_type;
+ typedef base::con_msg_manager_type con_msg_manager_type;
+ typedef base::endpoint_msg_manager_type endpoint_msg_manager_type;
+
+ typedef base::alog_type alog_type;
+ typedef base::elog_type elog_type;
+
+ typedef base::rng_type rng_type;
+
+ struct transport_config : public base::transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::alog_type alog_type;
+ typedef type::elog_type elog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+ typedef websocketpp::transport::asio::tls_socket::endpoint socket_type;
+ };
+
+ typedef websocketpp::transport::asio::endpoint<transport_config>
+ transport_type;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_ASIO_TLS_HPP
diff --git a/websocketpp/config/asio_client.hpp b/websocketpp/config/asio_client.hpp
new file mode 100644
index 00000000..1cb594d0
--- /dev/null
+++ b/websocketpp/config/asio_client.hpp
@@ -0,0 +1,77 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_ASIO_TLS_CLIENT_HPP
+#define WEBSOCKETPP_CONFIG_ASIO_TLS_CLIENT_HPP
+
+#include <websocketpp/config/core_client.hpp>
+#include <websocketpp/transport/asio/endpoint.hpp>
+#include <websocketpp/transport/asio/security/tls.hpp>
+
+// Pull in non-tls config
+#include <websocketpp/config/asio_no_tls_client.hpp>
+
+// Define TLS config
+namespace websocketpp {
+namespace config {
+
+/// Client config with asio transport and TLS enabled
+struct asio_tls_client : public core_client {
+ typedef asio_tls_client type;
+ typedef core_client base;
+
+ typedef base::concurrency_type concurrency_type;
+
+ typedef base::request_type request_type;
+ typedef base::response_type response_type;
+
+ typedef base::message_type message_type;
+ typedef base::con_msg_manager_type con_msg_manager_type;
+ typedef base::endpoint_msg_manager_type endpoint_msg_manager_type;
+
+ typedef base::alog_type alog_type;
+ typedef base::elog_type elog_type;
+
+ typedef base::rng_type rng_type;
+
+ struct transport_config : public base::transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::alog_type alog_type;
+ typedef type::elog_type elog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+ typedef websocketpp::transport::asio::tls_socket::endpoint socket_type;
+ };
+
+ typedef websocketpp::transport::asio::endpoint<transport_config>
+ transport_type;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_ASIO_TLS_CLIENT_HPP
diff --git a/websocketpp/config/asio_no_tls.hpp b/websocketpp/config/asio_no_tls.hpp
new file mode 100644
index 00000000..6c1357fb
--- /dev/null
+++ b/websocketpp/config/asio_no_tls.hpp
@@ -0,0 +1,73 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_ASIO_HPP
+#define WEBSOCKETPP_CONFIG_ASIO_HPP
+
+#include <websocketpp/config/core.hpp>
+#include <websocketpp/transport/asio/endpoint.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Server config with asio transport and TLS disabled
+struct asio : public core {
+ typedef asio type;
+ typedef core base;
+
+ typedef base::concurrency_type concurrency_type;
+
+ typedef base::request_type request_type;
+ typedef base::response_type response_type;
+
+ typedef base::message_type message_type;
+ typedef base::con_msg_manager_type con_msg_manager_type;
+ typedef base::endpoint_msg_manager_type endpoint_msg_manager_type;
+
+ typedef base::alog_type alog_type;
+ typedef base::elog_type elog_type;
+
+ typedef base::rng_type rng_type;
+
+ struct transport_config : public base::transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::alog_type alog_type;
+ typedef type::elog_type elog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+ typedef websocketpp::transport::asio::basic_socket::endpoint
+ socket_type;
+ };
+
+ typedef websocketpp::transport::asio::endpoint<transport_config>
+ transport_type;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_ASIO_HPP
diff --git a/websocketpp/config/asio_no_tls_client.hpp b/websocketpp/config/asio_no_tls_client.hpp
new file mode 100644
index 00000000..6e3f7ba0
--- /dev/null
+++ b/websocketpp/config/asio_no_tls_client.hpp
@@ -0,0 +1,73 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_ASIO_CLIENT_HPP
+#define WEBSOCKETPP_CONFIG_ASIO_CLIENT_HPP
+
+#include <websocketpp/config/core_client.hpp>
+#include <websocketpp/transport/asio/endpoint.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Client config with asio transport and TLS disabled
+struct asio_client : public core_client {
+ typedef asio_client type;
+ typedef core_client base;
+
+ typedef base::concurrency_type concurrency_type;
+
+ typedef base::request_type request_type;
+ typedef base::response_type response_type;
+
+ typedef base::message_type message_type;
+ typedef base::con_msg_manager_type con_msg_manager_type;
+ typedef base::endpoint_msg_manager_type endpoint_msg_manager_type;
+
+ typedef base::alog_type alog_type;
+ typedef base::elog_type elog_type;
+
+ typedef base::rng_type rng_type;
+
+ struct transport_config : public base::transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::alog_type alog_type;
+ typedef type::elog_type elog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+ typedef websocketpp::transport::asio::basic_socket::endpoint
+ socket_type;
+ };
+
+ typedef websocketpp::transport::asio::endpoint<transport_config>
+ transport_type;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_ASIO_CLIENT_HPP
diff --git a/websocketpp/config/boost_config.hpp b/websocketpp/config/boost_config.hpp
new file mode 100644
index 00000000..57671ccd
--- /dev/null
+++ b/websocketpp/config/boost_config.hpp
@@ -0,0 +1,72 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+ // This header defines WebSocket++ macros for C++11 compatibility based on the
+ // Boost.Config library. This will correctly configure most target platforms
+ // simply by including this header before any other WebSocket++ header.
+
+#ifndef WEBSOCKETPP_CONFIG_BOOST_CONFIG_HPP
+#define WEBSOCKETPP_CONFIG_BOOST_CONFIG_HPP
+
+#include <boost/config.hpp>
+
+// _WEBSOCKETPP_CPP11_MEMORY_ and _WEBSOCKETPP_CPP11_FUNCTIONAL_ presently
+// only work if either both or neither is defined.
+#if !defined BOOST_NO_CXX11_SMART_PTR && !defined BOOST_NO_CXX11_HDR_FUNCTIONAL
+ #define _WEBSOCKETPP_CPP11_MEMORY_
+ #define _WEBSOCKETPP_CPP11_FUNCTIONAL_
+#endif
+
+#ifdef BOOST_ASIO_HAS_STD_CHRONO
+ #define _WEBSOCKETPP_CPP11_CHRONO_
+#endif
+
+#ifndef BOOST_NO_CXX11_HDR_RANDOM
+ #define _WEBSOCKETPP_CPP11_RANDOM_DEVICE_
+#endif
+
+#ifndef BOOST_NO_CXX11_HDR_REGEX
+ #define _WEBSOCKETPP_CPP11_REGEX_
+#endif
+
+#ifndef BOOST_NO_CXX11_HDR_SYSTEM_ERROR
+ #define _WEBSOCKETPP_CPP11_SYSTEM_ERROR_
+#endif
+
+#ifndef BOOST_NO_CXX11_HDR_THREAD
+ #define _WEBSOCKETPP_CPP11_THREAD_
+#endif
+
+#ifndef BOOST_NO_CXX11_HDR_INITIALIZER_LIST
+ #define _WEBSOCKETPP_INITIALIZER_LISTS_
+#endif
+
+#define _WEBSOCKETPP_NOEXCEPT_TOKEN_ BOOST_NOEXCEPT
+#define _WEBSOCKETPP_CONSTEXPR_TOKEN_ BOOST_CONSTEXPR
+// TODO: nullptr support
+
+#endif // WEBSOCKETPP_CONFIG_BOOST_CONFIG_HPP
diff --git a/websocketpp/config/core.hpp b/websocketpp/config/core.hpp
new file mode 100644
index 00000000..a95b4021
--- /dev/null
+++ b/websocketpp/config/core.hpp
@@ -0,0 +1,285 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_CORE_HPP
+#define WEBSOCKETPP_CONFIG_CORE_HPP
+
+// Non-Policy common stuff
+#include <websocketpp/common/platforms.hpp>
+#include <websocketpp/common/cpp11.hpp>
+#include <websocketpp/common/stdint.hpp>
+
+// Concurrency
+#include <websocketpp/concurrency/basic.hpp>
+
+// Transport
+#include <websocketpp/transport/iostream/endpoint.hpp>
+
+// HTTP
+#include <websocketpp/http/request.hpp>
+#include <websocketpp/http/response.hpp>
+
+// Messages
+#include <websocketpp/message_buffer/message.hpp>
+#include <websocketpp/message_buffer/alloc.hpp>
+
+// Loggers
+#include <websocketpp/logger/basic.hpp>
+
+// RNG
+#include <websocketpp/random/none.hpp>
+
+// User stub base classes
+#include <websocketpp/endpoint_base.hpp>
+#include <websocketpp/connection_base.hpp>
+
+// Extensions
+#include <websocketpp/extensions/permessage_deflate/disabled.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Server config with iostream transport
+struct core {
+ typedef core type;
+
+ // Concurrency policy
+ typedef websocketpp::concurrency::basic concurrency_type;
+
+ // HTTP Parser Policies
+ typedef http::parser::request request_type;
+ typedef http::parser::response response_type;
+
+ // Message Policies
+ typedef message_buffer::message<message_buffer::alloc::con_msg_manager>
+ message_type;
+ typedef message_buffer::alloc::con_msg_manager<message_type>
+ con_msg_manager_type;
+ typedef message_buffer::alloc::endpoint_msg_manager<con_msg_manager_type>
+ endpoint_msg_manager_type;
+
+ /// Logging policies
+ typedef websocketpp::log::basic<concurrency_type,
+ websocketpp::log::elevel> elog_type;
+ typedef websocketpp::log::basic<concurrency_type,
+ websocketpp::log::alevel> alog_type;
+
+ /// RNG policies
+ typedef websocketpp::random::none::int_generator<uint32_t> rng_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization
+ /// code Disabling can provide a minor performance improvement to single
+ /// threaded applications
+ static bool const enable_multithreading = true;
+
+ struct transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::elog_type elog_type;
+ typedef type::alog_type alog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization
+ /// code Disabling can provide a minor performance improvement to single
+ /// threaded applications
+ static bool const enable_multithreading = true;
+
+ /// Default timer values (in ms)
+
+ /// Length of time to wait for socket pre-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use
+ */
+ static const long timeout_socket_pre_init = 5000;
+
+ /// Length of time to wait before a proxy handshake is aborted
+ static const long timeout_proxy = 5000;
+
+ /// Length of time to wait for socket post-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use.
+ * Often this means the TLS handshake
+ */
+ static const long timeout_socket_post_init = 5000;
+
+ /// Length of time to wait for dns resolution
+ static const long timeout_dns_resolve = 5000;
+
+ /// Length of time to wait for TCP connect
+ static const long timeout_connect = 5000;
+
+ /// Length of time to wait for socket shutdown
+ static const long timeout_socket_shutdown = 5000;
+ };
+
+ /// Transport Endpoint Component
+ typedef websocketpp::transport::iostream::endpoint<transport_config>
+ transport_type;
+
+ /// User overridable Endpoint base class
+ typedef websocketpp::endpoint_base endpoint_base;
+ /// User overridable Connection base class
+ typedef websocketpp::connection_base connection_base;
+
+ /// Default timer values (in ms)
+
+ /// Length of time before an opening handshake is aborted
+ static const long timeout_open_handshake = 5000;
+ /// Length of time before a closing handshake is aborted
+ static const long timeout_close_handshake = 5000;
+ /// Length of time to wait for a pong after a ping
+ static const long timeout_pong = 5000;
+
+ /// WebSocket Protocol version to use as a client
+ /**
+ * What version of the WebSocket Protocol to use for outgoing client
+ * connections. Setting this to a value other than 13 (RFC6455) is not
+ * recommended.
+ */
+ static const int client_version = 13; // RFC6455
+
+ /// Default static error logging channels
+ /**
+ * Which error logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level errors
+ */
+ static const websocketpp::log::level elog_level =
+ websocketpp::log::elevel::all ^ websocketpp::log::elevel::devel;
+
+ /// Default static access logging channels
+ /**
+ * Which access logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level access messages
+ */
+ static const websocketpp::log::level alog_level =
+ websocketpp::log::alevel::all ^ websocketpp::log::alevel::devel;
+
+ ///
+ static const size_t connection_read_buffer_size = 16384;
+
+ /// Drop connections immediately on protocol error.
+ /**
+ * Drop connections on protocol error rather than sending a close frame.
+ * Off by default. This may result in legit messages near the error being
+ * dropped as well. It may free up resources otherwise spent dealing with
+ * misbehaving clients.
+ */
+ static const bool drop_on_protocol_error = false;
+
+ /// Suppresses the return of detailed connection close information
+ /**
+ * Silence close suppresses the return of detailed connection close
+ * information during the closing handshake. This information is useful
+ * for debugging and presenting useful errors to end users but may be
+ * undesirable for security reasons in some production environments.
+ * Close reasons could be used by an attacker to confirm that the endpoint
+ * is out of resources or be used to identify the WebSocket implementation
+ * in use.
+ *
+ * Note: this will suppress *all* close codes, including those explicitly
+ * sent by local applications.
+ */
+ static const bool silent_close = false;
+
+ /// Default maximum message size
+ /**
+ * Default value for the processor's maximum message size. Maximum message size
+ * determines the point at which the library will fail a connection with the
+ * message_too_big protocol error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.3.0
+ */
+ static const size_t max_message_size = 32000000;
+
+ /// Default maximum http body size
+ /**
+ * Default value for the http parser's maximum body size. Maximum body size
+ * determines the point at which the library will abort reading an HTTP
+ * connection with the 413/request entity too large error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.5.0
+ */
+ static const size_t max_http_body_size = 32000000;
+
+ /// Global flag for enabling/disabling extensions
+ static const bool enable_extensions = true;
+
+ /// Extension specific settings:
+
+ /// permessage_compress extension
+ struct permessage_deflate_config {
+ typedef core::request_type request_type;
+
+ /// If the remote endpoint requests that we reset the compression
+ /// context after each message should we honor the request?
+ static const bool allow_disabling_context_takeover = true;
+
+ /// If the remote endpoint requests that we reduce the size of the
+ /// LZ77 sliding window size this is the lowest value that will be
+ /// allowed. Values range from 8 to 15. A value of 8 means we will
+ /// allow any possible window size. A value of 15 means do not allow
+ /// negotiation of the window size (ie require the default).
+ static const uint8_t minimum_outgoing_window_bits = 8;
+ };
+
+ typedef websocketpp::extensions::permessage_deflate::disabled
+ <permessage_deflate_config> permessage_deflate_type;
+
+ /// Autonegotiate permessage-deflate
+ /**
+ * Automatically enables the permessage-deflate extension.
+ *
+ * For clients this results in a permessage-deflate extension request being
+ * sent with every request rather than requiring it to be requested manually
+ *
+ * For servers this results in accepting the first set of extension settings
+ * requested by the client that we understand being used. The alternative is
+ * requiring the extension to be manually negotiated in `validate`. With
+ * auto-negotiate on, you may still override the auto-negotiate manually if
+ * needed.
+ */
+ //static const bool autonegotiate_compression = false;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_CORE_HPP
diff --git a/websocketpp/config/core_client.hpp b/websocketpp/config/core_client.hpp
new file mode 100644
index 00000000..dadf8a4e
--- /dev/null
+++ b/websocketpp/config/core_client.hpp
@@ -0,0 +1,294 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_CORE_CLIENT_HPP
+#define WEBSOCKETPP_CONFIG_CORE_CLIENT_HPP
+
+// Non-Policy common stuff
+#include <websocketpp/common/platforms.hpp>
+#include <websocketpp/common/cpp11.hpp>
+#include <websocketpp/common/stdint.hpp>
+
+// Concurrency
+#ifndef _WEBSOCKETPP_NO_THREADING_
+#include <websocketpp/concurrency/basic.hpp>
+#else
+#include <websocketpp/concurrency/none.hpp>
+#endif
+
+// Transport
+#include <websocketpp/transport/iostream/endpoint.hpp>
+
+// HTTP
+#include <websocketpp/http/request.hpp>
+#include <websocketpp/http/response.hpp>
+
+// Messages
+#include <websocketpp/message_buffer/message.hpp>
+#include <websocketpp/message_buffer/alloc.hpp>
+
+// Loggers
+#include <websocketpp/logger/basic.hpp>
+
+// RNG
+#include <websocketpp/random/random_device.hpp>
+
+// User stub base classes
+#include <websocketpp/endpoint_base.hpp>
+#include <websocketpp/connection_base.hpp>
+
+// Extensions
+#include <websocketpp/extensions/permessage_deflate/disabled.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Client config with iostream transport
+struct core_client {
+ typedef core_client type;
+
+ // Concurrency policy
+#ifndef _WEBSOCKETPP_NO_THREADING_
+ typedef websocketpp::concurrency::basic concurrency_type;
+#else
+ typedef websocketpp::concurrency::none concurrency_type;
+#endif
+
+ // HTTP Parser Policies
+ typedef http::parser::request request_type;
+ typedef http::parser::response response_type;
+
+ // Message Policies
+ typedef message_buffer::message<message_buffer::alloc::con_msg_manager>
+ message_type;
+ typedef message_buffer::alloc::con_msg_manager<message_type>
+ con_msg_manager_type;
+ typedef message_buffer::alloc::endpoint_msg_manager<con_msg_manager_type>
+ endpoint_msg_manager_type;
+
+ /// Logging policies
+ typedef websocketpp::log::basic<concurrency_type,
+ websocketpp::log::elevel> elog_type;
+ typedef websocketpp::log::basic<concurrency_type,
+ websocketpp::log::alevel> alog_type;
+
+ /// RNG policies
+ typedef websocketpp::random::random_device::int_generator<uint32_t,
+ concurrency_type> rng_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization code
+ /// Disabling can provide a minor performance improvement to single threaded
+ /// applications
+ static bool const enable_multithreading = true;
+
+ struct transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::elog_type elog_type;
+ typedef type::alog_type alog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization
+ /// code Disabling can provide a minor performance improvement to single
+ /// threaded applications
+ static bool const enable_multithreading = true;
+
+ /// Default timer values (in ms)
+
+ /// Length of time to wait for socket pre-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use
+ */
+ static const long timeout_socket_pre_init = 5000;
+
+ /// Length of time to wait before a proxy handshake is aborted
+ static const long timeout_proxy = 5000;
+
+ /// Length of time to wait for socket post-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use.
+ * Often this means the TLS handshake
+ */
+ static const long timeout_socket_post_init = 5000;
+
+ /// Length of time to wait for dns resolution
+ static const long timeout_dns_resolve = 5000;
+
+ /// Length of time to wait for TCP connect
+ static const long timeout_connect = 5000;
+
+ /// Length of time to wait for socket shutdown
+ static const long timeout_socket_shutdown = 5000;
+ };
+
+ /// Transport Endpoint Component
+ typedef websocketpp::transport::iostream::endpoint<transport_config>
+ transport_type;
+
+ /// User overridable Endpoint base class
+ typedef websocketpp::endpoint_base endpoint_base;
+ /// User overridable Connection base class
+ typedef websocketpp::connection_base connection_base;
+
+ /// Default timer values (in ms)
+
+ /// Length of time before an opening handshake is aborted
+ static const long timeout_open_handshake = 5000;
+ /// Length of time before a closing handshake is aborted
+ static const long timeout_close_handshake = 5000;
+ /// Length of time to wait for a pong after a ping
+ static const long timeout_pong = 5000;
+
+ /// WebSocket Protocol version to use as a client
+ /**
+ * What version of the WebSocket Protocol to use for outgoing client
+ * connections. Setting this to a value other than 13 (RFC6455) is not
+ * recommended.
+ */
+ static const int client_version = 13; // RFC6455
+
+ /// Default static error logging channels
+ /**
+ * Which error logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level errors
+ */
+ static const websocketpp::log::level elog_level =
+ websocketpp::log::elevel::all ^ websocketpp::log::elevel::devel;
+
+ /// Default static access logging channels
+ /**
+ * Which access logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level access messages
+ */
+ static const websocketpp::log::level alog_level =
+ websocketpp::log::alevel::all ^ websocketpp::log::alevel::devel;
+
+ ///
+ static const size_t connection_read_buffer_size = 16384;
+
+ /// Drop connections immediately on protocol error.
+ /**
+ * Drop connections on protocol error rather than sending a close frame.
+ * Off by default. This may result in legit messages near the error being
+ * dropped as well. It may free up resources otherwise spent dealing with
+ * misbehaving clients.
+ */
+ static const bool drop_on_protocol_error = false;
+
+ /// Suppresses the return of detailed connection close information
+ /**
+ * Silence close suppresses the return of detailed connection close
+ * information during the closing handshake. This information is useful
+ * for debugging and presenting useful errors to end users but may be
+ * undesirable for security reasons in some production environments.
+ * Close reasons could be used by an attacker to confirm that the endpoint
+ * is out of resources or be used to identify the WebSocket implementation
+ * in use.
+ *
+ * Note: this will suppress *all* close codes, including those explicitly
+ * sent by local applications.
+ */
+ static const bool silent_close = false;
+
+ /// Default maximum message size
+ /**
+ * Default value for the processor's maximum message size. Maximum message size
+ * determines the point at which the library will fail a connection with the
+ * message_too_big protocol error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.3.0
+ */
+ static const size_t max_message_size = 32000000;
+
+ /// Default maximum http body size
+ /**
+ * Default value for the http parser's maximum body size. Maximum body size
+ * determines the point at which the library will abort reading an HTTP
+ * connection with the 413/request entity too large error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.5.0
+ */
+ static const size_t max_http_body_size = 32000000;
+
+ /// Global flag for enabling/disabling extensions
+ static const bool enable_extensions = true;
+
+ /// Extension specific settings:
+
+ /// permessage_deflate extension
+ struct permessage_deflate_config {
+ typedef core_client::request_type request_type;
+
+ /// If the remote endpoint requests that we reset the compression
+ /// context after each message should we honor the request?
+ static const bool allow_disabling_context_takeover = true;
+
+ /// If the remote endpoint requests that we reduce the size of the
+ /// LZ77 sliding window size this is the lowest value that will be
+ /// allowed. Values range from 8 to 15. A value of 8 means we will
+ /// allow any possible window size. A value of 15 means do not allow
+ /// negotiation of the window size (ie require the default).
+ static const uint8_t minimum_outgoing_window_bits = 8;
+ };
+
+ typedef websocketpp::extensions::permessage_deflate::disabled
+ <permessage_deflate_config> permessage_deflate_type;
+
+ /// Autonegotiate permessage-compress
+ /**
+ * Automatically enables the permessage-compress extension.
+ *
+ * For clients this results in a permessage-compress extension request being
+ * sent with every request rather than requiring it to be requested manually
+ *
+ * For servers this results in accepting the first set of extension settings
+ * requested by the client that we understand being used. The alternative is
+ * requiring the extension to be manually negotiated in `validate`. With
+ * auto-negotiate on, you may still override the auto-negotiate manually if
+ * needed.
+ */
+ //static const bool autonegotiate_compression = false;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_CORE_CLIENT_HPP
diff --git a/websocketpp/config/debug.hpp b/websocketpp/config/debug.hpp
new file mode 100644
index 00000000..223f72fb
--- /dev/null
+++ b/websocketpp/config/debug.hpp
@@ -0,0 +1,286 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_DEBUG_HPP
+#define WEBSOCKETPP_CONFIG_DEBUG_HPP
+
+
+
+// Non-Policy common stuff
+#include <websocketpp/common/cpp11.hpp>
+#include <websocketpp/common/stdint.hpp>
+
+// Concurrency
+#include <websocketpp/concurrency/basic.hpp>
+
+// Transport
+#include <websocketpp/transport/iostream/endpoint.hpp>
+
+// HTTP
+#include <websocketpp/http/request.hpp>
+#include <websocketpp/http/response.hpp>
+
+// Messages
+#include <websocketpp/message_buffer/message.hpp>
+#include <websocketpp/message_buffer/alloc.hpp>
+
+// Loggers
+#include <websocketpp/logger/basic.hpp>
+
+// RNG
+#include <websocketpp/random/none.hpp>
+
+// User stub base classes
+#include <websocketpp/endpoint_base.hpp>
+#include <websocketpp/connection_base.hpp>
+
+// Extensions
+#include <websocketpp/extensions/permessage_deflate/disabled.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Client/Server debug config with iostream transport
+struct debug_core {
+ typedef debug_core type;
+
+ // Concurrency policy
+ typedef websocketpp::concurrency::basic concurrency_type;
+
+ // HTTP Parser Policies
+ typedef http::parser::request request_type;
+ typedef http::parser::response response_type;
+
+ // Message Policies
+ typedef message_buffer::message<message_buffer::alloc::con_msg_manager>
+ message_type;
+ typedef message_buffer::alloc::con_msg_manager<message_type>
+ con_msg_manager_type;
+ typedef message_buffer::alloc::endpoint_msg_manager<con_msg_manager_type>
+ endpoint_msg_manager_type;
+
+ /// Logging policies
+ typedef websocketpp::log::basic<concurrency_type,
+ websocketpp::log::elevel> elog_type;
+ typedef websocketpp::log::basic<concurrency_type,
+ websocketpp::log::alevel> alog_type;
+
+ /// RNG policies
+ typedef websocketpp::random::none::int_generator<uint32_t> rng_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization
+ /// code Disabling can provide a minor performance improvement to single
+ /// threaded applications
+ static bool const enable_multithreading = true;
+
+ struct transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::elog_type elog_type;
+ typedef type::alog_type alog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization
+ /// code Disabling can provide a minor performance improvement to single
+ /// threaded applications
+ static bool const enable_multithreading = true;
+
+ /// Default timer values (in ms)
+
+ /// Length of time to wait for socket pre-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use
+ */
+ static const long timeout_socket_pre_init = 5000;
+
+ /// Length of time to wait before a proxy handshake is aborted
+ static const long timeout_proxy = 5000;
+
+ /// Length of time to wait for socket post-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use.
+ * Often this means the TLS handshake
+ */
+ static const long timeout_socket_post_init = 5000;
+
+ /// Length of time to wait for dns resolution
+ static const long timeout_dns_resolve = 5000;
+
+ /// Length of time to wait for TCP connect
+ static const long timeout_connect = 5000;
+
+ /// Length of time to wait for socket shutdown
+ static const long timeout_socket_shutdown = 5000;
+ };
+
+ /// Transport Endpoint Component
+ typedef websocketpp::transport::iostream::endpoint<transport_config>
+ transport_type;
+
+ /// User overridable Endpoint base class
+ typedef websocketpp::endpoint_base endpoint_base;
+ /// User overridable Connection base class
+ typedef websocketpp::connection_base connection_base;
+
+ /// Default timer values (in ms)
+
+ /// Length of time before an opening handshake is aborted
+ static const long timeout_open_handshake = 5000;
+ /// Length of time before a closing handshake is aborted
+ static const long timeout_close_handshake = 5000;
+ /// Length of time to wait for a pong after a ping
+ static const long timeout_pong = 5000;
+
+ /// WebSocket Protocol version to use as a client
+ /**
+ * What version of the WebSocket Protocol to use for outgoing client
+ * connections. Setting this to a value other than 13 (RFC6455) is not
+ * recommended.
+ */
+ static const int client_version = 13; // RFC6455
+
+ /// Default static error logging channels
+ /**
+ * Which error logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level errors
+ */
+ static const websocketpp::log::level elog_level =
+ websocketpp::log::elevel::all;
+
+ /// Default static access logging channels
+ /**
+ * Which access logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level access messages
+ */
+ static const websocketpp::log::level alog_level =
+ websocketpp::log::alevel::all;
+
+ ///
+ static const size_t connection_read_buffer_size = 16384;
+
+ /// Drop connections immediately on protocol error.
+ /**
+ * Drop connections on protocol error rather than sending a close frame.
+ * Off by default. This may result in legit messages near the error being
+ * dropped as well. It may free up resources otherwise spent dealing with
+ * misbehaving clients.
+ */
+ static const bool drop_on_protocol_error = false;
+
+ /// Suppresses the return of detailed connection close information
+ /**
+ * Silence close suppresses the return of detailed connection close
+ * information during the closing handshake. This information is useful
+ * for debugging and presenting useful errors to end users but may be
+ * undesirable for security reasons in some production environments.
+ * Close reasons could be used by an attacker to confirm that the endpoint
+ * is out of resources or be used to identify the WebSocket implementation
+ * in use.
+ *
+ * Note: this will suppress *all* close codes, including those explicitly
+ * sent by local applications.
+ */
+ static const bool silent_close = false;
+
+ /// Default maximum message size
+ /**
+ * Default value for the processor's maximum message size. Maximum message size
+ * determines the point at which the library will fail a connection with the
+ * message_too_big protocol error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.3.0
+ */
+ static const size_t max_message_size = 32000000;
+
+ /// Default maximum http body size
+ /**
+ * Default value for the http parser's maximum body size. Maximum body size
+ * determines the point at which the library will abort reading an HTTP
+ * connection with the 413/request entity too large error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.5.0
+ */
+ static const size_t max_http_body_size = 32000000;
+
+ /// Global flag for enabling/disabling extensions
+ static const bool enable_extensions = true;
+
+ /// Extension specific settings:
+
+ /// permessage_compress extension
+ struct permessage_deflate_config {
+ typedef type::request_type request_type;
+
+ /// If the remote endpoint requests that we reset the compression
+ /// context after each message should we honor the request?
+ static const bool allow_disabling_context_takeover = true;
+
+ /// If the remote endpoint requests that we reduce the size of the
+ /// LZ77 sliding window size this is the lowest value that will be
+ /// allowed. Values range from 8 to 15. A value of 8 means we will
+ /// allow any possible window size. A value of 15 means do not allow
+ /// negotiation of the window size (ie require the default).
+ static const uint8_t minimum_outgoing_window_bits = 8;
+ };
+
+ typedef websocketpp::extensions::permessage_deflate::disabled
+ <permessage_deflate_config> permessage_deflate_type;
+
+ /// Autonegotiate permessage-deflate
+ /**
+ * Automatically enables the permessage-deflate extension.
+ *
+ * For clients this results in a permessage-deflate extension request being
+ * sent with every request rather than requiring it to be requested manually
+ *
+ * For servers this results in accepting the first set of extension settings
+ * requested by the client that we understand being used. The alternative is
+ * requiring the extension to be manually negotiated in `validate`. With
+ * auto-negotiate on, you may still override the auto-negotiate manually if
+ * needed.
+ */
+ //static const bool autonegotiate_compression = false;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_CORE_HPP
diff --git a/websocketpp/config/debug_asio.hpp b/websocketpp/config/debug_asio.hpp
new file mode 100644
index 00000000..a57c736c
--- /dev/null
+++ b/websocketpp/config/debug_asio.hpp
@@ -0,0 +1,77 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_ASIO_TLS_DEBUG_HPP
+#define WEBSOCKETPP_CONFIG_ASIO_TLS_DEBUG_HPP
+
+#include <websocketpp/config/debug.hpp>
+#include <websocketpp/transport/asio/endpoint.hpp>
+#include <websocketpp/transport/asio/security/tls.hpp>
+
+// Pull in non-tls config
+#include <websocketpp/config/debug_asio_no_tls.hpp>
+
+// Define TLS config
+namespace websocketpp {
+namespace config {
+
+/// Client/Server debug config with asio transport and TLS enabled
+struct debug_asio_tls : public debug_core {
+ typedef debug_asio_tls type;
+ typedef debug_core base;
+
+ typedef base::concurrency_type concurrency_type;
+
+ typedef base::request_type request_type;
+ typedef base::response_type response_type;
+
+ typedef base::message_type message_type;
+ typedef base::con_msg_manager_type con_msg_manager_type;
+ typedef base::endpoint_msg_manager_type endpoint_msg_manager_type;
+
+ typedef base::alog_type alog_type;
+ typedef base::elog_type elog_type;
+
+ typedef base::rng_type rng_type;
+
+ struct transport_config : public base::transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::alog_type alog_type;
+ typedef type::elog_type elog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+ typedef websocketpp::transport::asio::tls_socket::endpoint socket_type;
+ };
+
+ typedef websocketpp::transport::asio::endpoint<transport_config>
+ transport_type;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_ASIO_TLS_DEBUG_HPP
diff --git a/websocketpp/config/debug_asio_no_tls.hpp b/websocketpp/config/debug_asio_no_tls.hpp
new file mode 100644
index 00000000..b3dc83b4
--- /dev/null
+++ b/websocketpp/config/debug_asio_no_tls.hpp
@@ -0,0 +1,73 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_ASIO_DEBUG_HPP
+#define WEBSOCKETPP_CONFIG_ASIO_DEBUG_HPP
+
+#include <websocketpp/config/debug.hpp>
+#include <websocketpp/transport/asio/endpoint.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Client/Server debug config with asio transport and TLS disabled
+struct debug_asio : public debug_core {
+ typedef debug_asio type;
+ typedef debug_core base;
+
+ typedef base::concurrency_type concurrency_type;
+
+ typedef base::request_type request_type;
+ typedef base::response_type response_type;
+
+ typedef base::message_type message_type;
+ typedef base::con_msg_manager_type con_msg_manager_type;
+ typedef base::endpoint_msg_manager_type endpoint_msg_manager_type;
+
+ typedef base::alog_type alog_type;
+ typedef base::elog_type elog_type;
+
+ typedef base::rng_type rng_type;
+
+ struct transport_config : public base::transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::alog_type alog_type;
+ typedef type::elog_type elog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+ typedef websocketpp::transport::asio::basic_socket::endpoint
+ socket_type;
+ };
+
+ typedef websocketpp::transport::asio::endpoint<transport_config>
+ transport_type;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_ASIO_DEBUG_HPP
diff --git a/websocketpp/config/minimal_client.hpp b/websocketpp/config/minimal_client.hpp
new file mode 100644
index 00000000..72528cde
--- /dev/null
+++ b/websocketpp/config/minimal_client.hpp
@@ -0,0 +1,72 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_MINIMAL_CLIENT_HPP
+#define WEBSOCKETPP_CONFIG_MINIMAL_CLIENT_HPP
+
+#include <websocketpp/config/minimal_server.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Client config with minimal dependencies
+/**
+ * This config strips out as many dependencies as possible. It is suitable for
+ * use as a base class for custom configs that want to implement or choose their
+ * own policies for components that even the core config includes.
+ *
+ * NOTE: this config stubs out enough that it cannot be used directly. You must
+ * supply at least a transport policy and a cryptographically secure random
+ * number generation policy for a config based on `minimal_client` to do
+ * anything useful.
+ *
+ * Present dependency list for minimal_server config:
+ *
+ * C++98 STL:
+ * <algorithm>
+ * <map>
+ * <sstream>
+ * <string>
+ * <vector>
+ *
+ * C++11 STL or Boost
+ * <memory>
+ * <functional>
+ * <system_error>
+ *
+ * Operating System:
+ * <stdint.h> or <boost/cstdint.hpp>
+ * <netinet/in.h> or <winsock2.h> (for ntohl.. could potentially bundle this)
+ *
+ * @since 0.4.0-dev
+ */
+typedef minimal_server minimal_client;
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_MINIMAL_CLIENT_HPP
diff --git a/websocketpp/config/minimal_server.hpp b/websocketpp/config/minimal_server.hpp
new file mode 100644
index 00000000..dd1aedb9
--- /dev/null
+++ b/websocketpp/config/minimal_server.hpp
@@ -0,0 +1,312 @@
+/*
+ * Copyright (c) 2014, Peter Thorson. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions are met:
+ * * Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * * Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * * Neither the name of the WebSocket++ Project nor the
+ * names of its contributors may be used to endorse or promote products
+ * derived from this software without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
+ * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+ * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+ * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+ * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+ *
+ */
+
+#ifndef WEBSOCKETPP_CONFIG_MINIMAL_HPP
+#define WEBSOCKETPP_CONFIG_MINIMAL_HPP
+
+// Non-Policy common stuff
+#include <websocketpp/common/platforms.hpp>
+#include <websocketpp/common/cpp11.hpp>
+#include <websocketpp/common/stdint.hpp>
+
+// Concurrency
+#include <websocketpp/concurrency/none.hpp>
+
+// Transport
+#include <websocketpp/transport/stub/endpoint.hpp>
+
+// HTTP
+#include <websocketpp/http/request.hpp>
+#include <websocketpp/http/response.hpp>
+
+// Messages
+#include <websocketpp/message_buffer/message.hpp>
+#include <websocketpp/message_buffer/alloc.hpp>
+
+// Loggers
+#include <websocketpp/logger/stub.hpp>
+
+// RNG
+#include <websocketpp/random/none.hpp>
+
+// User stub base classes
+#include <websocketpp/endpoint_base.hpp>
+#include <websocketpp/connection_base.hpp>
+
+// Extensions
+#include <websocketpp/extensions/permessage_deflate/disabled.hpp>
+
+namespace websocketpp {
+namespace config {
+
+/// Server config with minimal dependencies
+/**
+ * This config strips out as many dependencies as possible. It is suitable for
+ * use as a base class for custom configs that want to implement or choose their
+ * own policies for components that even the core config includes.
+ *
+ * NOTE: this config stubs out enough that it cannot be used directly. You must
+ * supply at least a transport policy for a config based on `minimal_server` to
+ * do anything useful.
+ *
+ * Present dependency list for minimal_server config:
+ *
+ * C++98 STL:
+ * <algorithm>
+ * <map>
+ * <sstream>
+ * <string>
+ * <vector>
+ *
+ * C++11 STL or Boost
+ * <memory>
+ * <functional>
+ * <system_error>
+ *
+ * Operating System:
+ * <stdint.h> or <boost/cstdint.hpp>
+ * <netinet/in.h> or <winsock2.h> (for ntohl.. could potentially bundle this)
+ *
+ * @since 0.4.0-dev
+ */
+struct minimal_server {
+ typedef minimal_server type;
+
+ // Concurrency policy
+ typedef websocketpp::concurrency::none concurrency_type;
+
+ // HTTP Parser Policies
+ typedef http::parser::request request_type;
+ typedef http::parser::response response_type;
+
+ // Message Policies
+ typedef message_buffer::message<message_buffer::alloc::con_msg_manager>
+ message_type;
+ typedef message_buffer::alloc::con_msg_manager<message_type>
+ con_msg_manager_type;
+ typedef message_buffer::alloc::endpoint_msg_manager<con_msg_manager_type>
+ endpoint_msg_manager_type;
+
+ /// Logging policies
+ typedef websocketpp::log::stub elog_type;
+ typedef websocketpp::log::stub alog_type;
+
+ /// RNG policies
+ typedef websocketpp::random::none::int_generator<uint32_t> rng_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization
+ /// code Disabling can provide a minor performance improvement to single
+ /// threaded applications
+ static bool const enable_multithreading = true;
+
+ struct transport_config {
+ typedef type::concurrency_type concurrency_type;
+ typedef type::elog_type elog_type;
+ typedef type::alog_type alog_type;
+ typedef type::request_type request_type;
+ typedef type::response_type response_type;
+
+ /// Controls compile time enabling/disabling of thread syncronization
+ /// code Disabling can provide a minor performance improvement to single
+ /// threaded applications
+ static bool const enable_multithreading = true;
+
+ /// Default timer values (in ms)
+
+ /// Length of time to wait for socket pre-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use
+ */
+ static const long timeout_socket_pre_init = 5000;
+
+ /// Length of time to wait before a proxy handshake is aborted
+ static const long timeout_proxy = 5000;
+
+ /// Length of time to wait for socket post-initialization
+ /**
+ * Exactly what this includes depends on the socket policy in use.
+ * Often this means the TLS handshake
+ */
+ static const long timeout_socket_post_init = 5000;
+
+ /// Length of time to wait for dns resolution
+ static const long timeout_dns_resolve = 5000;
+
+ /// Length of time to wait for TCP connect
+ static const long timeout_connect = 5000;
+
+ /// Length of time to wait for socket shutdown
+ static const long timeout_socket_shutdown = 5000;
+ };
+
+ /// Transport Endpoint Component
+ typedef websocketpp::transport::stub::endpoint<transport_config>
+ transport_type;
+
+ /// User overridable Endpoint base class
+ typedef websocketpp::endpoint_base endpoint_base;
+ /// User overridable Connection base class
+ typedef websocketpp::connection_base connection_base;
+
+ /// Default timer values (in ms)
+
+ /// Length of time before an opening handshake is aborted
+ static const long timeout_open_handshake = 5000;
+ /// Length of time before a closing handshake is aborted
+ static const long timeout_close_handshake = 5000;
+ /// Length of time to wait for a pong after a ping
+ static const long timeout_pong = 5000;
+
+ /// WebSocket Protocol version to use as a client
+ /**
+ * What version of the WebSocket Protocol to use for outgoing client
+ * connections. Setting this to a value other than 13 (RFC6455) is not
+ * recommended.
+ */
+ static const int client_version = 13; // RFC6455
+
+ /// Default static error logging channels
+ /**
+ * Which error logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level errors
+ */
+ static const websocketpp::log::level elog_level =
+ websocketpp::log::elevel::none;
+
+ /// Default static access logging channels
+ /**
+ * Which access logging channels to enable at compile time. Channels not
+ * enabled here will be unable to be selected by programs using the library.
+ * This option gives an optimizing compiler the ability to remove entirely
+ * code to test whether or not to print out log messages on a certain
+ * channel
+ *
+ * Default is all except for development/debug level access messages
+ */
+ static const websocketpp::log::level alog_level =
+ websocketpp::log::alevel::none;
+
+ ///
+ static const size_t connection_read_buffer_size = 16384;
+
+ /// Drop connections immediately on protocol error.
+ /**
+ * Drop connections on protocol error rather than sending a close frame.
+ * Off by default. This may result in legit messages near the error being
+ * dropped as well. It may free up resources otherwise spent dealing with
+ * misbehaving clients.
+ */
+ static const bool drop_on_protocol_error = false;
+
+ /// Suppresses the return of detailed connection close information
+ /**
+ * Silence close suppresses the return of detailed connection close
+ * information during the closing handshake. This information is useful
+ * for debugging and presenting useful errors to end users but may be
+ * undesirable for security reasons in some production environments.
+ * Close reasons could be used by an attacker to confirm that the endpoint
+ * is out of resources or be used to identify the WebSocket implementation
+ * in use.
+ *
+ * Note: this will suppress *all* close codes, including those explicitly
+ * sent by local applications.
+ */
+ static const bool silent_close = false;
+
+ /// Default maximum message size
+ /**
+ * Default value for the processor's maximum message size. Maximum message size
+ * determines the point at which the library will fail a connection with the
+ * message_too_big protocol error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.4.0-alpha1
+ */
+ static const size_t max_message_size = 32000000;
+
+ /// Default maximum http body size
+ /**
+ * Default value for the http parser's maximum body size. Maximum body size
+ * determines the point at which the library will abort reading an HTTP
+ * connection with the 413/request entity too large error.
+ *
+ * The default is 32MB
+ *
+ * @since 0.5.0
+ */
+ static const size_t max_http_body_size = 32000000;
+
+ /// Global flag for enabling/disabling extensions
+ static const bool enable_extensions = true;
+
+ /// Extension specific settings:
+
+ /// permessage_compress extension
+ struct permessage_deflate_config {
+ typedef core::request_type request_type;
+
+ /// If the remote endpoint requests that we reset the compression
+ /// context after each message should we honor the request?
+ static const bool allow_disabling_context_takeover = true;
+
+ /// If the remote endpoint requests that we reduce the size of the
+ /// LZ77 sliding window size this is the lowest value that will be
+ /// allowed. Values range from 8 to 15. A value of 8 means we will
+ /// allow any possible window size. A value of 15 means do not allow
+ /// negotiation of the window size (ie require the default).
+ static const uint8_t minimum_outgoing_window_bits = 8;
+ };
+
+ typedef websocketpp::extensions::permessage_deflate::disabled
+ <permessage_deflate_config> permessage_deflate_type;
+
+ /// Autonegotiate permessage-deflate
+ /**
+ * Automatically enables the permessage-deflate extension.
+ *
+ * For clients this results in a permessage-deflate extension request being
+ * sent with every request rather than requiring it to be requested manually
+ *
+ * For servers this results in accepting the first set of extension settings
+ * requested by the client that we understand being used. The alternative is
+ * requiring the extension to be manually negotiated in `validate`. With
+ * auto-negotiate on, you may still override the auto-negotiate manually if
+ * needed.
+ */
+ //static const bool autonegotiate_compression = false;
+};
+
+} // namespace config
+} // namespace websocketpp
+
+#endif // WEBSOCKETPP_CONFIG_MINIMAL_HPP