NS-3 based Named Data Networking (NDN) simulator
ndnSIM 2.3: NDN, CCN, CCNx, content centric networks
API Documentation
Main Page
Related Pages
Modules
Namespaces
Classes
Files
File List
File Members
ndnSIM
ndnSIM documentation
All Attributes
All GlobalValues
All LogComponents
All TraceSources
Todo List
Deprecated List
Modules
Namespaces
Classes
Files
File List
File Members
•
All
Classes
Namespaces
Files
Functions
Variables
Typedefs
Enumerations
Enumerator
Friends
Macros
Modules
Pages
step1.cpp
Go to the documentation of this file.
1
/*
2
* Copyright (c) 2015, Peter Thorson. All rights reserved.
3
*
4
* Redistribution and use in source and binary forms, with or without
5
* modification, are permitted provided that the following conditions are met:
6
* * Redistributions of source code must retain the above copyright
7
* notice, this list of conditions and the following disclaimer.
8
* * Redistributions in binary form must reproduce the above copyright
9
* notice, this list of conditions and the following disclaimer in the
10
* documentation and/or other materials provided with the distribution.
11
* * Neither the name of the WebSocket++ Project nor the
12
* names of its contributors may be used to endorse or promote products
13
* derived from this software without specific prior written permission.
14
*
15
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
16
* AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18
* ARE DISCLAIMED. IN NO EVENT SHALL PETER THORSON BE LIABLE FOR ANY
19
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
20
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
21
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
22
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
23
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
24
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
25
*/
26
27
// **NOTE:** This file is a snapshot of the WebSocket++ utility server tutorial.
28
// Additional related material can be found in the tutorials/utility_server
29
// directory of the WebSocket++ repository.
30
31
// The ASIO_STANDALONE define is necessary to use the standalone version of Asio.
32
// Remove if you are using Boost Asio.
33
#define ASIO_STANDALONE
34
35
#include <
websocketpp/config/asio_no_tls.hpp
>
36
#include <
websocketpp/server.hpp
>
37
38
#include <functional>
39
40
typedef
websocketpp::server<websocketpp::config::asio>
server
;
41
42
class
utility_server
{
43
public
:
44
utility_server
() {
45
// Set logging settings
46
m_endpoint.
set_error_channels
(
websocketpp::log::elevel::all
);
47
m_endpoint.
set_access_channels
(
websocketpp::log::alevel::all
^
websocketpp::log::alevel::frame_payload
);
48
49
// Initialize Asio
50
m_endpoint.
init_asio
();
51
}
52
53
void
run
() {
54
// Listen on port 9002
55
m_endpoint.
listen
(9002);
56
57
// Queues a connection accept operation
58
m_endpoint.
start_accept
();
59
60
// Start the Asio io_service run loop
61
m_endpoint.
run
();
62
}
63
private
:
64
server
m_endpoint;
65
};
66
67
int
main
() {
68
utility_server
s;
69
s.
run
();
70
return
0;
71
}
websocketpp::log::alevel::all
static level const all
Special aggregate value representing "all levels".
Definition:
levels.hpp:152
utility_server
Definition:
step1.cpp:42
server
websocketpp::server< websocketpp::config::asio > server
Definition:
step1.cpp:40
utility_server::utility_server
utility_server()
Definition:
step1.cpp:44
websocketpp::log::alevel::frame_payload
static level const frame_payload
One line per frame, includes the full message payload (warning: chatty)
Definition:
levels.hpp:129
main
int main()
Definition:
step1.cpp:34
websocketpp::transport::asio::endpoint::init_asio
void init_asio(io_service_ptr ptr, lib::error_code &ec)
initialize asio transport with external io_service (exception free)
Definition:
endpoint.hpp:181
utility_server::run
void run()
Definition:
step1.cpp:53
websocketpp::server::start_accept
void start_accept(lib::error_code &ec)
Starts the server's async connection acceptance loop (exception free)
Definition:
server_endpoint.hpp:121
websocketpp::server< websocketpp::config::asio >
websocketpp::endpoint::set_access_channels
void set_access_channels(log::level channels)
Set Access logging channel.
Definition:
endpoint.hpp:220
asio_no_tls.hpp
websocketpp::endpoint::set_error_channels
void set_error_channels(log::level channels)
Set Error logging channel.
Definition:
endpoint.hpp:242
websocketpp::transport::asio::endpoint::run
std::size_t run()
wraps the run method of the internal io_service object
Definition:
endpoint.hpp:613
websocketpp::transport::asio::endpoint::listen
void listen(lib::asio::ip::tcp::endpoint const &ep, lib::error_code &ec)
Set up endpoint for listening manually (exception free)
Definition:
endpoint.hpp:391
websocketpp::log::elevel::all
static level const all
Special aggregate value representing "all levels".
Definition:
levels.hpp:80
server.hpp
ndnSIM
NFD
websocketpp
tutorials
utility_server
step1.cpp
Generated on Thu Nov 2 2017 03:30:29 for ndnSIM by
1.8.11