mirror of https://github.com/CrowCpp/Crow.git
Compare commits
5 Commits
6214d2fae3
...
2faf2a2adf
Author | SHA1 | Date |
---|---|---|
AndTokm | 2faf2a2adf | |
Nabzokek Zubkenkanakov | 4fbd9b471f | |
bugdea1er | 3e9eb1172a | |
bugdea1er | e3ff9238a4 | |
ssams | 96e049666e |
|
@ -46,6 +46,7 @@ option(CROW_BUILD_EXAMPLES "Build the examples in the project" ${CROW_I
|
|||
option(CROW_BUILD_TESTS "Build the tests in the project" ${CROW_IS_MAIN_PROJECT})
|
||||
option(CROW_AMALGAMATE "Combine all headers into one" OFF)
|
||||
option(CROW_INSTALL "Add install step for Crow" ON )
|
||||
option(CROW_USE_BOOST "Use Boost.Asio for Crow" OFF)
|
||||
|
||||
# Possible values: ssl, compression
|
||||
option(CROW_FEATURES "Enable features extending Crow's abilities" "")
|
||||
|
@ -62,12 +63,20 @@ target_include_directories(Crow
|
|||
$<INSTALL_INTERFACE:include>
|
||||
)
|
||||
|
||||
find_package(asio REQUIRED)
|
||||
|
||||
target_link_libraries(Crow
|
||||
INTERFACE
|
||||
asio::asio
|
||||
)
|
||||
if(CROW_USE_BOOST)
|
||||
find_package(Boost 1.64 COMPONENTS system date_time REQUIRED)
|
||||
target_link_libraries(Crow
|
||||
INTERFACE
|
||||
Boost::boost Boost::system Boost::date_time
|
||||
)
|
||||
target_compile_definitions(Crow INTERFACE CROW_USE_BOOST)
|
||||
else()
|
||||
find_package(asio REQUIRED)
|
||||
target_link_libraries(Crow
|
||||
INTERFACE
|
||||
asio::asio
|
||||
)
|
||||
endif()
|
||||
|
||||
target_compile_definitions(Crow INTERFACE "")
|
||||
|
||||
|
|
2
Doxyfile
2
Doxyfile
|
@ -772,7 +772,7 @@ SHOW_FILES = YES
|
|||
# Folder Tree View (if specified).
|
||||
# The default value is: YES.
|
||||
|
||||
SHOW_NAMESPACES = NO
|
||||
SHOW_NAMESPACES = YES
|
||||
|
||||
# The FILE_VERSION_FILTER tag can be used to specify a program or script that
|
||||
# doxygen should invoke to get the current version for each file (typically from
|
||||
|
|
|
@ -125,6 +125,7 @@ Crow defines the following status codes:
|
|||
403 Forbidden
|
||||
404 Not Found
|
||||
405 Method Not Allowed
|
||||
406 Not Acceptable
|
||||
407 Proxy Authentication Required
|
||||
409 Conflict
|
||||
410 Gone
|
||||
|
|
|
@ -1,8 +1,4 @@
|
|||
/*
|
||||
*
|
||||
* TinySHA1 - a header only implementation of the SHA1 algorithm in C++. Based
|
||||
* on the implementation in boost::uuid::details.
|
||||
*
|
||||
/*
|
||||
* SHA1 Wikipedia Page: http://en.wikipedia.org/wiki/SHA-1
|
||||
*
|
||||
* Copyright (c) 2012-22 SAURAV MOHAPATRA <mohaps@gmail.com>
|
||||
|
@ -19,14 +15,35 @@
|
|||
* ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
||||
* OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||
*/
|
||||
|
||||
/**
|
||||
* \file TinySHA1.hpp
|
||||
* \author SAURAV MOHAPATRA <mohaps@gmail.com>
|
||||
* \date 2012-22
|
||||
* \brief TinySHA1 - a header only implementation of the SHA1 algorithm in C++. Based
|
||||
* on the implementation in boost::uuid::details.
|
||||
*
|
||||
* In this file are defined:
|
||||
* - sha1::SHA1
|
||||
*/
|
||||
#ifndef _TINY_SHA1_HPP_
|
||||
#define _TINY_SHA1_HPP_
|
||||
#include <cstdio>
|
||||
#include <cstdlib>
|
||||
#include <cstring>
|
||||
#include <stdint.h>
|
||||
|
||||
/**
|
||||
* \namespace sha1
|
||||
* \brief Here is defined the SHA1 class
|
||||
*/
|
||||
namespace sha1
|
||||
{
|
||||
/**
|
||||
* \class SHA1
|
||||
* \brief A tiny SHA1 algorithm implementation used internally in the
|
||||
* Crow server (specifically in crow/websocket.h).
|
||||
*/
|
||||
class SHA1
|
||||
{
|
||||
public:
|
||||
|
|
|
@ -1,3 +1,20 @@
|
|||
/**
|
||||
* \file crow/app.h
|
||||
* \brief This file includes the definition of the crow::Crow class,
|
||||
* the crow::App and crow::SimpleApp aliases, and some macros.
|
||||
*
|
||||
* In this file are defined:
|
||||
* - crow::Crow
|
||||
* - crow::App
|
||||
* - crow::SimpleApp
|
||||
* - \ref CROW_ROUTE
|
||||
* - \ref CROW_BP_ROUTE
|
||||
* - \ref CROW_WEBSOCKET_ROUTE
|
||||
* - \ref CROW_MIDDLEWARES
|
||||
* - \ref CROW_CATCHALL_ROUTE
|
||||
* - \ref CROW_BP_CATCHALL_ROUTE
|
||||
*/
|
||||
|
||||
#pragma once
|
||||
|
||||
#include <chrono>
|
||||
|
@ -22,52 +39,185 @@
|
|||
#include "crow/websocket.h"
|
||||
#ifdef CROW_ENABLE_COMPRESSION
|
||||
#include "crow/compression.h"
|
||||
#endif
|
||||
#endif // #ifdef CROW_ENABLE_COMPRESSION
|
||||
|
||||
|
||||
#ifdef CROW_MSVC_WORKAROUND
|
||||
#define CROW_ROUTE(app, url) app.route_dynamic(url)
|
||||
#define CROW_BP_ROUTE(blueprint, url) blueprint.new_rule_dynamic(url)
|
||||
#else
|
||||
|
||||
#define CROW_ROUTE(app, url) app.route_dynamic(url) // See the documentation in the comment below.
|
||||
#define CROW_BP_ROUTE(blueprint, url) blueprint.new_rule_dynamic(url) // See the documentation in the comment below.
|
||||
|
||||
#else // #ifdef CROW_MSVC_WORKAROUND
|
||||
|
||||
/**
|
||||
* \def CROW_ROUTE(app, url)
|
||||
* \brief Creates a route for app using a rule.
|
||||
*
|
||||
* It use crow::Crow::route_dynamic or crow::Crow::route to define
|
||||
* a rule for your application. It's usage is like this:
|
||||
*
|
||||
* ```cpp
|
||||
* auto app = crow::SimpleApp(); // or crow::App()
|
||||
* CROW_ROUTE(app, "/")
|
||||
* ([](){
|
||||
* return "<h1>Hello, world!</h1>";
|
||||
* });
|
||||
* ```
|
||||
*
|
||||
* This is the recommended way to define routes in a crow application.
|
||||
* \see [Page of guide "Routes"](https://crowcpp.org/master/guides/routes/).
|
||||
*/
|
||||
#define CROW_ROUTE(app, url) app.template route<crow::black_magic::get_parameter_tag(url)>(url)
|
||||
|
||||
/**
|
||||
* \def CROW_BP_ROUTE(blueprint, url)
|
||||
* \brief Creates a route for a blueprint using a rule.
|
||||
*
|
||||
* It may use crow::Blueprint::new_rule_dynamic or
|
||||
* crow::Blueprint::new_rule_tagged to define a new rule for
|
||||
* an given blueprint. It's usage is similar
|
||||
* to CROW_ROUTE macro:
|
||||
*
|
||||
* ```cpp
|
||||
* crow::Blueprint my_bp();
|
||||
* CROW_BP_ROUTE(my_bp, "/")
|
||||
* ([](){
|
||||
* return "<h1>Hello, world!</h1>";
|
||||
* });
|
||||
* ```
|
||||
*
|
||||
* This is the recommended way to define routes in a crow blueprint
|
||||
* because of its compile-time capabilities.
|
||||
*
|
||||
* \see [Page of the guide "Blueprints"](https://crowcpp.org/master/guides/blueprints/).
|
||||
*/
|
||||
#define CROW_BP_ROUTE(blueprint, url) blueprint.new_rule_tagged<crow::black_magic::get_parameter_tag(url)>(url)
|
||||
|
||||
/**
|
||||
* \def CROW_WEBSOCKET_ROUTE(app, url)
|
||||
* \brief Defines WebSocket route for app.
|
||||
*
|
||||
* It binds a WebSocket route to app. Easy solution to implement
|
||||
* WebSockets in your app. The usage syntax of this macro is
|
||||
* like this:
|
||||
*
|
||||
* ```cpp
|
||||
* auto app = crow::SimpleApp(); // or crow::App()
|
||||
* CROW_WEBSOCKET_ROUTE(app, "/ws")
|
||||
* .onopen([&](crow::websocket::connection& conn){
|
||||
* do_something();
|
||||
* })
|
||||
* .onclose([&](crow::websocket::connection& conn, const std::string& reason){
|
||||
* do_something();
|
||||
* })
|
||||
* .onmessage([&](crow::websocket::connection&, const std::string& data, bool is_binary){
|
||||
* if (is_binary)
|
||||
* do_something(data);
|
||||
* else
|
||||
* do_something_else(data);
|
||||
* });
|
||||
* ```
|
||||
*
|
||||
* \see [Page of the guide "WebSockets"](https://crowcpp.org/master/guides/websockets/).
|
||||
*/
|
||||
#define CROW_WEBSOCKET_ROUTE(app, url) app.route<crow::black_magic::get_parameter_tag(url)>(url).websocket<std::remove_reference<decltype(app)>::type>(&app)
|
||||
|
||||
/**
|
||||
* \def CROW_MIDDLEWARES(app, ...)
|
||||
* \brief Enable a Middleware for an specific route in app
|
||||
* or blueprint.
|
||||
*
|
||||
* It defines the usage of a Middleware in one route. And it
|
||||
* can be used in both crow::SimpleApp (and crow::App) instances and
|
||||
* crow::Blueprint. Its usage syntax is like this:
|
||||
*
|
||||
* ```cpp
|
||||
* auto app = crow::SimpleApp(); // or crow::App()
|
||||
* CROW_ROUTE(app, "/with_middleware")
|
||||
* .CROW_MIDDLEWARES(app, LocalMiddleware) // Can be used more than one
|
||||
* ([]() { // middleware.
|
||||
* return "Hello world!";
|
||||
* });
|
||||
* ```
|
||||
*
|
||||
* \see [Page of the guide "Middlewares"](https://crowcpp.org/master/guides/middleware/).
|
||||
*/
|
||||
#define CROW_MIDDLEWARES(app, ...) template middlewares<typename std::remove_reference<decltype(app)>::type, __VA_ARGS__>()
|
||||
#endif
|
||||
|
||||
#endif // #ifdef CROW_MSVC_WORKAROUND
|
||||
|
||||
/**
|
||||
* \def CROW_CATCHALL_ROUTE(app)
|
||||
* \brief Defines a custom catchall route for app using a
|
||||
* custom rule.
|
||||
*
|
||||
* It defines a handler when the client make a request for an
|
||||
* undefined route. Instead of just reply with a `404` status
|
||||
* code (default behavior), you can define a custom handler
|
||||
* using this macro.
|
||||
*
|
||||
* \see [Page of the guide "Routes" (Catchall routes)](https://crowcpp.org/master/guides/routes/#catchall-routes).
|
||||
*/
|
||||
#define CROW_CATCHALL_ROUTE(app) app.catchall_route()
|
||||
|
||||
/**
|
||||
* \def CROW_BP_CATCHALL_ROUTE(blueprint)
|
||||
* \brief Defines a custom catchall route for blueprint
|
||||
* using a custom rule.
|
||||
*
|
||||
* It defines a handler when the client make a request for an
|
||||
* undefined route in the blueprint.
|
||||
*
|
||||
* \see [Page of the guide "Blueprint" (Define a custom Catchall route)](https://crowcpp.org/master/guides/blueprints/#define-a-custom-catchall-route).
|
||||
*/
|
||||
#define CROW_BP_CATCHALL_ROUTE(blueprint) blueprint.catchall_rule()
|
||||
|
||||
|
||||
/**
|
||||
* \namespace crow
|
||||
* \brief The main namespace of the library. In this namespace
|
||||
* is defined the most important classes and functions of the
|
||||
* library.
|
||||
*
|
||||
* Within this namespace, the Crow class, Router class, Connection
|
||||
* class, and other are defined.
|
||||
*/
|
||||
namespace crow
|
||||
{
|
||||
#ifdef CROW_ENABLE_SSL
|
||||
using ssl_context_t = asio::ssl::context;
|
||||
#endif
|
||||
/// The main server application
|
||||
|
||||
///
|
||||
/// Use `SimpleApp` or `App<Middleware1, Middleware2, etc...>`
|
||||
/**
|
||||
* \class Crow
|
||||
* \brief The main server application class.
|
||||
*
|
||||
* Use crow::SimpleApp or crow::App<Middleware1, Middleware2, etc...> instead of
|
||||
* directly instantiate this class.
|
||||
*/
|
||||
template<typename... Middlewares>
|
||||
class Crow
|
||||
{
|
||||
public:
|
||||
/// This crow application
|
||||
/// \brief This is the crow application
|
||||
using self_t = Crow;
|
||||
/// The HTTP server
|
||||
|
||||
/// \brief The HTTP server
|
||||
using server_t = Server<Crow, SocketAdaptor, Middlewares...>;
|
||||
|
||||
#ifdef CROW_ENABLE_SSL
|
||||
/// An HTTP server that runs on SSL with an SSLAdaptor
|
||||
/// \brief An HTTP server that runs on SSL with an SSLAdaptor
|
||||
using ssl_server_t = Server<Crow, SSLAdaptor, Middlewares...>;
|
||||
#endif
|
||||
Crow()
|
||||
{}
|
||||
|
||||
/// Construct Crow with a subset of middleware
|
||||
/// \brief Construct Crow with a subset of middleware
|
||||
template<typename... Ts>
|
||||
Crow(Ts&&... ts):
|
||||
middlewares_(make_middleware_tuple(std::forward<Ts>(ts)...))
|
||||
{}
|
||||
|
||||
/// Process an Upgrade request
|
||||
|
||||
/// \brief Process an Upgrade request
|
||||
///
|
||||
/// Currently used to upgrade an HTTP connection to a WebSocket connection
|
||||
template<typename Adaptor>
|
||||
|
@ -76,19 +226,19 @@ namespace crow
|
|||
router_.handle_upgrade(req, res, adaptor);
|
||||
}
|
||||
|
||||
/// Process only the method and URL of a request and provide a route (or an error response)
|
||||
/// \brief Process only the method and URL of a request and provide a route (or an error response)
|
||||
std::unique_ptr<routing_handle_result> handle_initial(request& req, response& res)
|
||||
{
|
||||
return router_.handle_initial(req, res);
|
||||
}
|
||||
|
||||
/// Process the fully parsed request and generate a response for it
|
||||
/// \brief Process the fully parsed request and generate a response for it
|
||||
void handle(request& req, response& res, std::unique_ptr<routing_handle_result>& found)
|
||||
{
|
||||
router_.handle<self_t>(req, res, *found);
|
||||
}
|
||||
|
||||
/// Process a fully parsed request from start to finish (primarily used for debugging)
|
||||
/// \brief Process a fully parsed request from start to finish (primarily used for debugging)
|
||||
void handle_full(request& req, response& res)
|
||||
{
|
||||
auto found = handle_initial(req, res);
|
||||
|
@ -96,13 +246,13 @@ namespace crow
|
|||
handle(req, res, found);
|
||||
}
|
||||
|
||||
/// Create a dynamic route using a rule (**Use CROW_ROUTE instead**)
|
||||
/// \brief Create a dynamic route using a rule (**Use CROW_ROUTE instead**)
|
||||
DynamicRule& route_dynamic(const std::string& rule)
|
||||
{
|
||||
return router_.new_rule_dynamic(rule);
|
||||
}
|
||||
|
||||
/// Create a route using a rule (**Use CROW_ROUTE instead**)
|
||||
/// \brief Create a route using a rule (**Use CROW_ROUTE instead**)
|
||||
template<uint64_t Tag>
|
||||
#ifdef CROW_GCC83_WORKAROUND
|
||||
auto& route(const std::string& rule)
|
||||
|
@ -118,20 +268,20 @@ namespace crow
|
|||
return router_.new_rule_tagged<Tag>(rule);
|
||||
}
|
||||
|
||||
/// Create a route for any requests without a proper route (**Use CROW_CATCHALL_ROUTE instead**)
|
||||
/// \brief Create a route for any requests without a proper route (**Use CROW_CATCHALL_ROUTE instead**)
|
||||
CatchallRule& catchall_route()
|
||||
{
|
||||
return router_.catchall_rule();
|
||||
}
|
||||
|
||||
/// Set the default max payload size for websockets
|
||||
/// \brief Set the default max payload size for websockets
|
||||
self_t& websocket_max_payload(uint64_t max_payload)
|
||||
{
|
||||
max_payload_ = max_payload;
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// Get the default max payload size for websockets
|
||||
/// \brief Get the default max payload size for websockets
|
||||
uint64_t websocket_max_payload()
|
||||
{
|
||||
return max_payload_;
|
||||
|
@ -154,53 +304,53 @@ namespace crow
|
|||
return signals_;
|
||||
}
|
||||
|
||||
/// Set the port that Crow will handle requests on
|
||||
/// \brief Set the port that Crow will handle requests on
|
||||
self_t& port(std::uint16_t port)
|
||||
{
|
||||
port_ = port;
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// Get the port that Crow will handle requests on
|
||||
/// \brief Get the port that Crow will handle requests on
|
||||
std::uint16_t port()
|
||||
{
|
||||
return port_;
|
||||
}
|
||||
|
||||
/// Set the connection timeout in seconds (default is 5)
|
||||
/// \brief Set the connection timeout in seconds (default is 5)
|
||||
self_t& timeout(std::uint8_t timeout)
|
||||
{
|
||||
timeout_ = timeout;
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// Set the server name
|
||||
/// \brief Set the server name
|
||||
self_t& server_name(std::string server_name)
|
||||
{
|
||||
server_name_ = server_name;
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// The IP address that Crow will handle requests on (default is 0.0.0.0)
|
||||
/// \brief The IP address that Crow will handle requests on (default is 0.0.0.0)
|
||||
self_t& bindaddr(std::string bindaddr)
|
||||
{
|
||||
bindaddr_ = bindaddr;
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// Get the address that Crow will handle requests on
|
||||
/// \brief Get the address that Crow will handle requests on
|
||||
std::string bindaddr()
|
||||
{
|
||||
return bindaddr_;
|
||||
}
|
||||
|
||||
/// Run the server on multiple threads using all available threads
|
||||
/// \brief Run the server on multiple threads using all available threads
|
||||
self_t& multithreaded()
|
||||
{
|
||||
return concurrency(std::thread::hardware_concurrency());
|
||||
}
|
||||
|
||||
/// Run the server on multiple threads using a specific number
|
||||
/// \brief Run the server on multiple threads using a specific number
|
||||
self_t& concurrency(std::uint16_t concurrency)
|
||||
{
|
||||
if (concurrency < 2) // Crow can have a minimum of 2 threads running
|
||||
|
@ -209,29 +359,27 @@ namespace crow
|
|||
return *this;
|
||||
}
|
||||
|
||||
/// Get the number of threads that server is using
|
||||
/// \brief Get the number of threads that server is using
|
||||
std::uint16_t concurrency()
|
||||
{
|
||||
return concurrency_;
|
||||
}
|
||||
|
||||
/// Set the server's log level
|
||||
|
||||
/// \brief Set the server's log level
|
||||
///
|
||||
/// Possible values are:<br>
|
||||
/// crow::LogLevel::Debug (0)<br>
|
||||
/// crow::LogLevel::Info (1)<br>
|
||||
/// crow::LogLevel::Warning (2)<br>
|
||||
/// crow::LogLevel::Error (3)<br>
|
||||
/// crow::LogLevel::Critical (4)<br>
|
||||
/// Possible values are:
|
||||
/// - crow::LogLevel::Debug (0)
|
||||
/// - crow::LogLevel::Info (1)
|
||||
/// - crow::LogLevel::Warning (2)
|
||||
/// - crow::LogLevel::Error (3)
|
||||
/// - crow::LogLevel::Critical (4)
|
||||
self_t& loglevel(LogLevel level)
|
||||
{
|
||||
crow::logger::setLogLevel(level);
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// Set the response body size (in bytes) beyond which Crow automatically streams responses (Default is 1MiB)
|
||||
|
||||
/// \brief Set the response body size (in bytes) beyond which Crow automatically streams responses (Default is 1MiB)
|
||||
///
|
||||
/// Any streamed response is unaffected by Crow's timer, and therefore won't timeout before a response is fully sent.
|
||||
self_t& stream_threshold(size_t threshold)
|
||||
|
@ -240,20 +388,20 @@ namespace crow
|
|||
return *this;
|
||||
}
|
||||
|
||||
/// Get the response body size (in bytes) beyond which Crow automatically streams responses
|
||||
/// \brief Get the response body size (in bytes) beyond which Crow automatically streams responses
|
||||
size_t& stream_threshold()
|
||||
{
|
||||
return res_stream_threshold_;
|
||||
}
|
||||
|
||||
|
||||
self_t& register_blueprint(Blueprint& blueprint)
|
||||
{
|
||||
router_.register_blueprint(blueprint);
|
||||
return *this;
|
||||
}
|
||||
|
||||
/// Set the function to call to handle uncaught exceptions generated in routes (Default generates error 500).
|
||||
|
||||
/// \brief Set the function to call to handle uncaught exceptions generated in routes (Default generates error 500).
|
||||
///
|
||||
/// The function must have the following signature: void(crow::response&).
|
||||
/// It must set the response passed in argument to the function, which will be sent back to the client.
|
||||
|
@ -270,7 +418,7 @@ namespace crow
|
|||
return router_.exception_handler();
|
||||
}
|
||||
|
||||
/// Set a custom duration and function to run on every tick
|
||||
/// \brief Set a custom duration and function to run on every tick
|
||||
template<typename Duration, typename Func>
|
||||
self_t& tick(Duration d, Func f)
|
||||
{
|
||||
|
@ -280,6 +428,7 @@ namespace crow
|
|||
}
|
||||
|
||||
#ifdef CROW_ENABLE_COMPRESSION
|
||||
|
||||
self_t& use_compression(compression::algorithm algorithm)
|
||||
{
|
||||
comp_algorithm_ = algorithm;
|
||||
|
@ -298,7 +447,7 @@ namespace crow
|
|||
}
|
||||
#endif
|
||||
|
||||
/// Apply blueprints
|
||||
/// \brief Apply blueprints
|
||||
void add_blueprint()
|
||||
{
|
||||
#if defined(__APPLE__) || defined(__MACH__)
|
||||
|
@ -321,7 +470,7 @@ namespace crow
|
|||
router_.validate_bp();
|
||||
}
|
||||
|
||||
/// Go through the rules, upgrade them if possible, and add them to the list of rules
|
||||
/// \brief Go through the rules, upgrade them if possible, and add them to the list of rules
|
||||
void add_static_dir()
|
||||
{
|
||||
if (are_static_routes_added()) return;
|
||||
|
@ -335,13 +484,13 @@ namespace crow
|
|||
set_static_routes_added();
|
||||
}
|
||||
|
||||
/// A wrapper for `validate()` in the router
|
||||
/// \brief A wrapper for `validate()` in the router
|
||||
void validate()
|
||||
{
|
||||
router_.validate();
|
||||
}
|
||||
|
||||
/// Run the server
|
||||
/// \brief Run the server
|
||||
void run()
|
||||
{
|
||||
#ifndef CROW_DISABLE_STATIC_DIR
|
||||
|
@ -377,7 +526,7 @@ namespace crow
|
|||
}
|
||||
}
|
||||
|
||||
/// Non-blocking version of \ref run()
|
||||
/// \brief Non-blocking version of \ref run()
|
||||
///
|
||||
/// The output from this method needs to be saved into a variable!
|
||||
/// Otherwise the call will be made on the same thread.
|
||||
|
@ -388,7 +537,7 @@ namespace crow
|
|||
});
|
||||
}
|
||||
|
||||
/// Stop the server
|
||||
/// \brief Stop the server
|
||||
void stop()
|
||||
{
|
||||
#ifdef CROW_ENABLE_SSL
|
||||
|
@ -420,7 +569,7 @@ namespace crow
|
|||
websockets_.erase(std::remove(websockets_.begin(), websockets_.end(), conn), websockets_.end());
|
||||
}
|
||||
|
||||
/// Print the routing paths defined for each HTTP method
|
||||
/// \brief Print the routing paths defined for each HTTP method
|
||||
void debug_print()
|
||||
{
|
||||
CROW_LOG_DEBUG << "Routing:";
|
||||
|
@ -430,7 +579,7 @@ namespace crow
|
|||
|
||||
#ifdef CROW_ENABLE_SSL
|
||||
|
||||
/// Use certificate and key files for SSL
|
||||
/// \brief Use certificate and key files for SSL
|
||||
self_t& ssl_file(const std::string& crt_filename, const std::string& key_filename)
|
||||
{
|
||||
ssl_used_ = true;
|
||||
|
@ -443,7 +592,7 @@ namespace crow
|
|||
return *this;
|
||||
}
|
||||
|
||||
/// Use .pem file for SSL
|
||||
/// \brief Use `.pem` file for SSL
|
||||
self_t& ssl_file(const std::string& pem_filename)
|
||||
{
|
||||
ssl_used_ = true;
|
||||
|
@ -455,7 +604,7 @@ namespace crow
|
|||
return *this;
|
||||
}
|
||||
|
||||
/// Use certificate chain and key files for SSL
|
||||
/// \brief Use certificate chain and key files for SSL
|
||||
self_t& ssl_chainfile(const std::string& crt_filename, const std::string& key_filename)
|
||||
{
|
||||
ssl_used_ = true;
|
||||
|
@ -480,6 +629,7 @@ namespace crow
|
|||
return ssl_used_;
|
||||
}
|
||||
#else
|
||||
|
||||
template<typename T, typename... Remain>
|
||||
self_t& ssl_file(T&&, Remain&&...)
|
||||
{
|
||||
|
@ -536,7 +686,7 @@ namespace crow
|
|||
return utility::get_element_by_type<T, Middlewares...>(middlewares_);
|
||||
}
|
||||
|
||||
/// Wait until the server has properly started
|
||||
/// \brief Wait until the server has properly started
|
||||
void wait_for_server_start()
|
||||
{
|
||||
{
|
||||
|
@ -562,7 +712,7 @@ namespace crow
|
|||
black_magic::tuple_extract<Middlewares, decltype(fwd)>(fwd))...);
|
||||
}
|
||||
|
||||
/// Notify anything using `wait_for_server_start()` to proceed
|
||||
/// \brief Notify anything using \ref wait_for_server_start() to proceed
|
||||
void notify_server_start()
|
||||
{
|
||||
std::unique_lock<std::mutex> lock(start_mutex_);
|
||||
|
@ -614,7 +764,13 @@ namespace crow
|
|||
std::mutex start_mutex_;
|
||||
std::vector<crow::websocket::connection*> websockets_;
|
||||
};
|
||||
|
||||
/// \brief Alias of Crow<Middlewares...>. Useful if you want
|
||||
/// a instance of an Crow application that require Middlewares
|
||||
template<typename... Middlewares>
|
||||
using App = Crow<Middlewares...>;
|
||||
|
||||
/// \brief Alias of Crow<>. Useful if you want a instance of
|
||||
/// an Crow application that doesn't require of Middlewares
|
||||
using SimpleApp = Crow<>;
|
||||
} // namespace crow
|
||||
|
|
|
@ -190,6 +190,7 @@ namespace crow
|
|||
FORBIDDEN = 403,
|
||||
NOT_FOUND = 404,
|
||||
METHOD_NOT_ALLOWED = 405,
|
||||
NOT_ACCEPTABLE = 406,
|
||||
PROXY_AUTHENTICATION_REQUIRED = 407,
|
||||
CONFLICT = 409,
|
||||
GONE = 410,
|
||||
|
|
|
@ -5,7 +5,7 @@
|
|||
#include <zlib.h>
|
||||
|
||||
// http://zlib.net/manual.html
|
||||
namespace crow
|
||||
namespace crow // NOTE: Already documented in "crow/app.h"
|
||||
{
|
||||
namespace compression
|
||||
{
|
||||
|
|
|
@ -1,32 +1,43 @@
|
|||
#pragma once
|
||||
|
||||
#ifdef CROW_USE_BOOST
|
||||
#include <boost/asio.hpp>
|
||||
#else
|
||||
#ifndef ASIO_STANDALONE
|
||||
#define ASIO_STANDALONE
|
||||
#endif
|
||||
#include <asio.hpp>
|
||||
#endif
|
||||
|
||||
#include <algorithm>
|
||||
#include <atomic>
|
||||
#include <chrono>
|
||||
#include <vector>
|
||||
#include <memory>
|
||||
#include <vector>
|
||||
|
||||
#include "crow/http_parser_merged.h"
|
||||
#include "crow/common.h"
|
||||
#include "crow/parser.h"
|
||||
#include "crow/compression.h"
|
||||
#include "crow/http_response.h"
|
||||
#include "crow/logging.h"
|
||||
#include "crow/settings.h"
|
||||
#include "crow/task_timer.h"
|
||||
#include "crow/middleware_context.h"
|
||||
#include "crow/middleware.h"
|
||||
#include "crow/middleware_context.h"
|
||||
#include "crow/parser.h"
|
||||
#include "crow/settings.h"
|
||||
#include "crow/socket_adaptors.h"
|
||||
#include "crow/compression.h"
|
||||
#include "crow/task_timer.h"
|
||||
#include "crow/utility.h"
|
||||
|
||||
namespace crow
|
||||
{
|
||||
#ifdef CROW_USE_BOOST
|
||||
namespace asio = boost::asio;
|
||||
using error_code = boost::system::error_code;
|
||||
#else
|
||||
using error_code = asio::error_code;
|
||||
#endif
|
||||
using tcp = asio::ip::tcp;
|
||||
|
||||
|
||||
#ifdef CROW_ENABLE_DEBUG
|
||||
static std::atomic<int> connectionCount;
|
||||
#endif
|
||||
|
@ -81,7 +92,7 @@ namespace crow
|
|||
void start()
|
||||
{
|
||||
auto self = this->shared_from_this();
|
||||
adaptor_.start([self](const asio::error_code& ec) {
|
||||
adaptor_.start([self](const error_code& ec) {
|
||||
if (!ec)
|
||||
{
|
||||
self->start_deadline();
|
||||
|
@ -312,6 +323,7 @@ namespace crow
|
|||
{status::FORBIDDEN, "HTTP/1.1 403 Forbidden\r\n"},
|
||||
{status::NOT_FOUND, "HTTP/1.1 404 Not Found\r\n"},
|
||||
{status::METHOD_NOT_ALLOWED, "HTTP/1.1 405 Method Not Allowed\r\n"},
|
||||
{status::NOT_ACCEPTABLE, "HTTP/1.1 406 Not Acceptable\r\n"},
|
||||
{status::PROXY_AUTHENTICATION_REQUIRED, "HTTP/1.1 407 Proxy Authentication Required\r\n"},
|
||||
{status::CONFLICT, "HTTP/1.1 409 Conflict\r\n"},
|
||||
{status::GONE, "HTTP/1.1 410 Gone\r\n"},
|
||||
|
@ -473,7 +485,7 @@ namespace crow
|
|||
auto self = this->shared_from_this();
|
||||
adaptor_.socket().async_read_some(
|
||||
asio::buffer(buffer_),
|
||||
[self](const asio::error_code& ec, std::size_t bytes_transferred) {
|
||||
[self](const error_code& ec, std::size_t bytes_transferred) {
|
||||
bool error_while_reading = true;
|
||||
if (!ec)
|
||||
{
|
||||
|
@ -516,7 +528,7 @@ namespace crow
|
|||
auto self = this->shared_from_this();
|
||||
asio::async_write(
|
||||
adaptor_.socket(), buffers_,
|
||||
[self](const asio::error_code& ec, std::size_t /*bytes_transferred*/) {
|
||||
[self](const error_code& ec, std::size_t /*bytes_transferred*/) {
|
||||
self->res.clear();
|
||||
self->res_body_copy_.clear();
|
||||
if (!self->continue_requested)
|
||||
|
@ -547,7 +559,7 @@ namespace crow
|
|||
inline void do_write_sync(std::vector<asio::const_buffer>& buffers)
|
||||
{
|
||||
|
||||
asio::write(adaptor_.socket(), buffers, [&](asio::error_code ec, std::size_t) {
|
||||
asio::write(adaptor_.socket(), buffers, [&](error_code ec, std::size_t) {
|
||||
if (!ec)
|
||||
{
|
||||
return false;
|
||||
|
|
|
@ -1,16 +1,24 @@
|
|||
#pragma once
|
||||
|
||||
#ifdef CROW_USE_BOOST
|
||||
#include <boost/asio.hpp>
|
||||
#else
|
||||
#ifndef ASIO_STANDALONE
|
||||
#define ASIO_STANDALONE
|
||||
#endif
|
||||
#include <asio.hpp>
|
||||
#endif
|
||||
|
||||
#include "crow/common.h"
|
||||
#include "crow/ci_map.h"
|
||||
#include "crow/query_string.h"
|
||||
|
||||
namespace crow
|
||||
namespace crow // NOTE: Already documented in "crow/app.h"
|
||||
{
|
||||
#ifdef CROW_USE_BOOST
|
||||
namespace asio = boost::asio;
|
||||
#endif
|
||||
|
||||
/// Find and return the value associated with the key. (returns an empty string if nothing is found)
|
||||
template<typename T>
|
||||
inline const std::string& get_header_value(const T& headers, const std::string& key)
|
||||
|
|
|
@ -1,6 +1,11 @@
|
|||
#pragma once
|
||||
|
||||
#include <chrono>
|
||||
#ifdef CROW_USE_BOOST
|
||||
#include <boost/asio.hpp>
|
||||
#ifdef CROW_ENABLE_SSL
|
||||
#include <boost/asio/ssl.hpp>
|
||||
#endif
|
||||
#else
|
||||
#ifndef ASIO_STANDALONE
|
||||
#define ASIO_STANDALONE
|
||||
#endif
|
||||
|
@ -8,19 +13,29 @@
|
|||
#ifdef CROW_ENABLE_SSL
|
||||
#include <asio/ssl.hpp>
|
||||
#endif
|
||||
#include <cstdint>
|
||||
#endif
|
||||
|
||||
#include <atomic>
|
||||
#include <chrono>
|
||||
#include <cstdint>
|
||||
#include <future>
|
||||
#include <vector>
|
||||
#include <memory>
|
||||
#include <vector>
|
||||
|
||||
#include "crow/version.h"
|
||||
#include "crow/http_connection.h"
|
||||
#include "crow/logging.h"
|
||||
#include "crow/task_timer.h"
|
||||
|
||||
namespace crow
|
||||
|
||||
namespace crow // NOTE: Already documented in "crow/app.h"
|
||||
{
|
||||
#ifdef CROW_USE_BOOST
|
||||
namespace asio = boost::asio;
|
||||
using error_code = boost::system::error_code;
|
||||
#else
|
||||
using error_code = asio::error_code;
|
||||
#endif
|
||||
using tcp = asio::ip::tcp;
|
||||
|
||||
template<typename Handler, typename Adaptor = SocketAdaptor, typename... Middlewares>
|
||||
|
@ -52,7 +67,7 @@ namespace crow
|
|||
{
|
||||
tick_function_();
|
||||
tick_timer_.expires_after(std::chrono::milliseconds(tick_interval_.count()));
|
||||
tick_timer_.async_wait([this](const asio::error_code& ec) {
|
||||
tick_timer_.async_wait([this](const error_code& ec) {
|
||||
if (ec)
|
||||
return;
|
||||
on_tick();
|
||||
|
@ -128,7 +143,7 @@ namespace crow
|
|||
{
|
||||
tick_timer_.expires_after(std::chrono::milliseconds(tick_interval_.count()));
|
||||
tick_timer_.async_wait(
|
||||
[this](const asio::error_code& ec) {
|
||||
[this](const error_code& ec) {
|
||||
if (ec)
|
||||
return;
|
||||
on_tick();
|
||||
|
@ -143,7 +158,7 @@ namespace crow
|
|||
CROW_LOG_INFO << "Call `app.loglevel(crow::LogLevel::Warning)` to hide Info level logs.";
|
||||
|
||||
signals_.async_wait(
|
||||
[&](const asio::error_code& /*error*/, int /*signal_number*/) {
|
||||
[&](const error_code& /*error*/, int /*signal_number*/) {
|
||||
stop();
|
||||
});
|
||||
|
||||
|
@ -227,7 +242,7 @@ namespace crow
|
|||
|
||||
acceptor_.async_accept(
|
||||
p->socket(),
|
||||
[this, p, &is, service_idx](asio::error_code ec) {
|
||||
[this, p, &is, service_idx](error_code ec) {
|
||||
if (!ec)
|
||||
{
|
||||
is.post(
|
||||
|
|
|
@ -25,7 +25,7 @@ using std::isinf;
|
|||
using std::isnan;
|
||||
|
||||
|
||||
namespace crow
|
||||
namespace crow // NOTE: Already documented in "crow/app.h"
|
||||
{
|
||||
namespace mustache
|
||||
{
|
||||
|
|
|
@ -9,7 +9,7 @@
|
|||
#include <iostream>
|
||||
#include <utility>
|
||||
|
||||
namespace crow
|
||||
namespace crow // NOTE: Already documented in "crow/app.h"
|
||||
{
|
||||
|
||||
/// Local middleware should extend ILocalMiddleware
|
||||
|
|
|
@ -18,7 +18,7 @@
|
|||
#include "crow/mustache.h"
|
||||
#include "crow/middleware.h"
|
||||
|
||||
namespace crow
|
||||
namespace crow // NOTE: Already documented in "crow/app.h"
|
||||
{
|
||||
|
||||
constexpr const uint16_t INVALID_BP_ID{((uint16_t)-1)};
|
||||
|
|
|
@ -1,20 +1,37 @@
|
|||
#pragma once
|
||||
|
||||
#ifdef CROW_USE_BOOST
|
||||
#include <boost/asio.hpp>
|
||||
#include <boost/asio/version.hpp>
|
||||
#ifdef CROW_ENABLE_SSL
|
||||
#include <boost/asio/ssl.hpp>
|
||||
#endif
|
||||
#else
|
||||
#ifndef ASIO_STANDALONE
|
||||
#define ASIO_STANDALONE
|
||||
#endif
|
||||
#include <asio.hpp>
|
||||
#include <asio/version.hpp>
|
||||
#ifdef CROW_ENABLE_SSL
|
||||
#include <asio/ssl.hpp>
|
||||
#endif
|
||||
#endif
|
||||
#include "crow/settings.h"
|
||||
#include <asio/version.hpp>
|
||||
#if ASIO_VERSION >= 101300 // 1.13.0
|
||||
|
||||
#if (CROW_USE_BOOST && BOOST_VERSION >= 107000) || (ASIO_VERSION >= 101300)
|
||||
#define GET_IO_SERVICE(s) ((asio::io_context&)(s).get_executor().context())
|
||||
#else
|
||||
#define GET_IO_SERVICE(s) ((s).get_io_service())
|
||||
#endif
|
||||
|
||||
namespace crow
|
||||
{
|
||||
#ifdef CROW_USE_BOOST
|
||||
namespace asio = boost::asio;
|
||||
using error_code = boost::system::error_code;
|
||||
#else
|
||||
using error_code = asio::error_code;
|
||||
#endif
|
||||
using tcp = asio::ip::tcp;
|
||||
|
||||
/// A wrapper for the asio::ip::tcp::socket and asio::ssl::stream
|
||||
|
@ -54,32 +71,32 @@ namespace crow
|
|||
|
||||
void close()
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
socket_.close(ec);
|
||||
}
|
||||
|
||||
void shutdown_readwrite()
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
socket_.shutdown(asio::socket_base::shutdown_type::shutdown_both, ec);
|
||||
}
|
||||
|
||||
void shutdown_write()
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
socket_.shutdown(asio::socket_base::shutdown_type::shutdown_send, ec);
|
||||
}
|
||||
|
||||
void shutdown_read()
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
socket_.shutdown(asio::socket_base::shutdown_type::shutdown_receive, ec);
|
||||
}
|
||||
|
||||
template<typename F>
|
||||
void start(F f)
|
||||
{
|
||||
f(asio::error_code());
|
||||
f(error_code());
|
||||
}
|
||||
|
||||
tcp::socket socket_;
|
||||
|
@ -119,7 +136,7 @@ namespace crow
|
|||
{
|
||||
if (is_open())
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
raw_socket().close(ec);
|
||||
}
|
||||
}
|
||||
|
@ -128,7 +145,7 @@ namespace crow
|
|||
{
|
||||
if (is_open())
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
raw_socket().shutdown(asio::socket_base::shutdown_type::shutdown_both, ec);
|
||||
}
|
||||
}
|
||||
|
@ -137,7 +154,7 @@ namespace crow
|
|||
{
|
||||
if (is_open())
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
raw_socket().shutdown(asio::socket_base::shutdown_type::shutdown_send, ec);
|
||||
}
|
||||
}
|
||||
|
@ -146,7 +163,7 @@ namespace crow
|
|||
{
|
||||
if (is_open())
|
||||
{
|
||||
asio::error_code ec;
|
||||
error_code ec;
|
||||
raw_socket().shutdown(asio::socket_base::shutdown_type::shutdown_receive, ec);
|
||||
}
|
||||
}
|
||||
|
@ -160,7 +177,7 @@ namespace crow
|
|||
void start(F f)
|
||||
{
|
||||
ssl_socket_->async_handshake(asio::ssl::stream_base::server,
|
||||
[f](const asio::error_code& ec) {
|
||||
[f](const error_code& ec) {
|
||||
f(ec);
|
||||
});
|
||||
}
|
||||
|
|
|
@ -1,10 +1,15 @@
|
|||
#pragma once
|
||||
|
||||
#ifdef CROW_USE_BOOST
|
||||
#include <boost/asio.hpp>
|
||||
#include <boost/asio/basic_waitable_timer.hpp>
|
||||
#else
|
||||
#ifndef ASIO_STANDALONE
|
||||
#define ASIO_STANDALONE
|
||||
#endif
|
||||
#include <asio.hpp>
|
||||
#include <asio/basic_waitable_timer.hpp>
|
||||
#endif
|
||||
|
||||
#include <chrono>
|
||||
#include <functional>
|
||||
|
@ -15,6 +20,12 @@
|
|||
|
||||
namespace crow
|
||||
{
|
||||
#ifdef CROW_USE_BOOST
|
||||
namespace asio = boost::asio;
|
||||
using error_code = boost::system::error_code;
|
||||
#else
|
||||
using error_code = asio::error_code;
|
||||
#endif
|
||||
namespace detail
|
||||
{
|
||||
|
||||
|
@ -112,7 +123,7 @@ namespace crow
|
|||
if (tasks_.empty()) highest_id_ = 0;
|
||||
}
|
||||
|
||||
void tick_handler(const asio::error_code& ec)
|
||||
void tick_handler(const error_code& ec)
|
||||
{
|
||||
if (ec) return;
|
||||
|
||||
|
|
|
@ -6,8 +6,22 @@
|
|||
#include "crow/TinySHA1.hpp"
|
||||
#include "crow/utility.h"
|
||||
|
||||
namespace crow
|
||||
namespace crow // NOTE: Already documented in "crow/app.h"
|
||||
{
|
||||
#ifdef CROW_USE_BOOST
|
||||
namespace asio = boost::asio;
|
||||
using error_code = boost::system::error_code;
|
||||
#else
|
||||
using error_code = asio::error_code;
|
||||
#endif
|
||||
|
||||
/**
|
||||
* \namespace crow::websocket
|
||||
* \brief Namespace that includes the \ref Connection class
|
||||
* and \ref connection struct. Useful for WebSockets connection.
|
||||
*
|
||||
* Used specially in crow/websocket.h, crow/app.h and crow/routing.h
|
||||
*/
|
||||
namespace websocket
|
||||
{
|
||||
enum class WebSocketReadState
|
||||
|
@ -299,7 +313,7 @@ namespace crow
|
|||
//asio::async_read(adaptor_.socket(), asio::buffer(&mini_header_, 1),
|
||||
adaptor_.socket().async_read_some(
|
||||
asio::buffer(&mini_header_, 2),
|
||||
[this](const asio::error_code& ec, std::size_t
|
||||
[this](const error_code& ec, std::size_t
|
||||
#ifdef CROW_ENABLE_DEBUG
|
||||
bytes_transferred
|
||||
#endif
|
||||
|
@ -367,7 +381,7 @@ namespace crow
|
|||
remaining_length16_ = 0;
|
||||
asio::async_read(
|
||||
adaptor_.socket(), asio::buffer(&remaining_length16_, 2),
|
||||
[this](const asio::error_code& ec, std::size_t
|
||||
[this](const error_code& ec, std::size_t
|
||||
#ifdef CROW_ENABLE_DEBUG
|
||||
bytes_transferred
|
||||
#endif
|
||||
|
@ -403,7 +417,7 @@ namespace crow
|
|||
{
|
||||
asio::async_read(
|
||||
adaptor_.socket(), asio::buffer(&remaining_length_, 8),
|
||||
[this](const asio::error_code& ec, std::size_t
|
||||
[this](const error_code& ec, std::size_t
|
||||
#ifdef CROW_ENABLE_DEBUG
|
||||
bytes_transferred
|
||||
#endif
|
||||
|
@ -447,7 +461,7 @@ namespace crow
|
|||
{
|
||||
asio::async_read(
|
||||
adaptor_.socket(), asio::buffer((char*)&mask_, 4),
|
||||
[this](const asio::error_code& ec, std::size_t
|
||||
[this](const error_code& ec, std::size_t
|
||||
#ifdef CROW_ENABLE_DEBUG
|
||||
bytes_transferred
|
||||
#endif
|
||||
|
@ -489,7 +503,7 @@ namespace crow
|
|||
to_read = remaining_length_;
|
||||
adaptor_.socket().async_read_some(
|
||||
asio::buffer(buffer_, static_cast<std::size_t>(to_read)),
|
||||
[this](const asio::error_code& ec, std::size_t bytes_transferred) {
|
||||
[this](const error_code& ec, std::size_t bytes_transferred) {
|
||||
is_reading = false;
|
||||
|
||||
if (!ec)
|
||||
|
@ -641,7 +655,7 @@ namespace crow
|
|||
auto watch = std::weak_ptr<void>{anchor_};
|
||||
asio::async_write(
|
||||
adaptor_.socket(), buffers,
|
||||
[&, watch](const asio::error_code& ec, std::size_t /*bytes_transferred*/) {
|
||||
[&, watch](const error_code& ec, std::size_t /*bytes_transferred*/) {
|
||||
if (!ec && !close_connection_)
|
||||
{
|
||||
sending_buffers_.clear();
|
||||
|
|
|
@ -19,6 +19,13 @@
|
|||
using namespace std;
|
||||
using namespace crow;
|
||||
|
||||
#ifdef CROW_USE_BOOST
|
||||
namespace asio = boost::asio;
|
||||
using asio_error_code = boost::system::error_code;
|
||||
#else
|
||||
using asio_error_code = asio::error_code;
|
||||
#endif
|
||||
|
||||
#define LOCALHOST_ADDRESS "127.0.0.1"
|
||||
|
||||
TEST_CASE("Rule")
|
||||
|
@ -2925,7 +2932,7 @@ TEST_CASE("websocket_max_payload")
|
|||
}
|
||||
}
|
||||
|
||||
asio::error_code ec;
|
||||
asio_error_code ec;
|
||||
c.lowest_layer().shutdown(asio::socket_base::shutdown_type::shutdown_both, ec);
|
||||
|
||||
app.stop();
|
||||
|
@ -3510,7 +3517,7 @@ TEST_CASE("timeout")
|
|||
asio::ip::address::from_string(LOCALHOST_ADDRESS), 45451));
|
||||
|
||||
auto receive_future = async(launch::async, [&]() {
|
||||
asio::error_code ec;
|
||||
asio_error_code ec;
|
||||
c.receive(asio::buffer(buf, 2048), 0, ec);
|
||||
return ec;
|
||||
});
|
||||
|
@ -3530,7 +3537,7 @@ TEST_CASE("timeout")
|
|||
|
||||
size_t received;
|
||||
auto receive_future = async(launch::async, [&]() {
|
||||
asio::error_code ec;
|
||||
asio_error_code ec;
|
||||
received = c.receive(asio::buffer(buf, 2048), 0, ec);
|
||||
return ec;
|
||||
});
|
||||
|
|
Loading…
Reference in New Issue