12using websocketpp::lib::placeholders::_1;
13using websocketpp::lib::placeholders::_2;
14using websocketpp::lib::bind;
17typedef websocketpp::lib::shared_ptr<boost::asio::ssl::context>
context_ptr;
21template <
typename Endpo
intType>
23 typename EndpointType::message_ptr msg)
25 std::cout <<
"on_message called with hdl: " << hdl.lock().get()
26 <<
" and message: " << msg->get_payload()
30 s->send(hdl, msg->get_payload(), msg->get_opcode());
31 }
catch (
const websocketpp::lib::error_code& e) {
32 std::cout <<
"Echo failed because: " << e
33 <<
"(" << e.message() <<
")" << std::endl;
43 std::cout <<
"on_tls_init called with hdl: " << hdl.lock().get() << std::endl;
44 context_ptr ctx(
new boost::asio::ssl::context(boost::asio::ssl::context::tlsv1));
47 ctx->set_options(boost::asio::ssl::context::default_workarounds |
48 boost::asio::ssl::context::no_sslv2 |
49 boost::asio::ssl::context::no_sslv3 |
50 boost::asio::ssl::context::single_dh_use);
52 ctx->use_certificate_chain_file(
"server.pem");
53 ctx->use_private_key_file(
"server.pem", boost::asio::ssl::context::pem);
54 }
catch (std::exception& e) {
55 std::cout << e.what() << std::endl;
63 boost::asio::io_service ios;
68 endpoint_plain.init_asio(&ios);
71 endpoint_plain.listen(80);
76 endpoint_tls.init_asio(&ios);
80 endpoint_tls.set_tls_init_handler(bind(&
on_tls_init,::_1));
82 endpoint_tls.listen(443);
void set_message_handler(message_handler h)
Server endpoint role based on the given config.
void start_accept(lib::error_code &ec)
Starts the server's async connection acceptance loop (exception free)
websocketpp::lib::shared_ptr< boost::asio::ssl::context > context_ptr
context_ptr on_tls_init(websocketpp::connection_hdl hdl)
websocketpp::server< websocketpp::config::asio_tls > server_tls
websocketpp::server< websocketpp::config::asio > server_plain
websocketpp::lib::shared_ptr< boost::asio::ssl::context > context_ptr
void on_message(EndpointType *s, websocketpp::connection_hdl hdl, typename EndpointType::message_ptr msg)
std::string get_password()
lib::weak_ptr< void > connection_hdl
A handle to uniquely identify a connection.