blob: 1f638adfa68e921a64fda0154bceefd18ede5cfd (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
|
/*
Itay Marom
Cisco Systems, Inc.
*/
/*
Copyright (c) 2015-2015 Cisco Systems, Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
#ifndef __TREX_RPC_REQ_RESP_API_H__
#define __TREX_RPC_REQ_RESP_API_H__
#include <trex_rpc_server_api.h>
/**
* request-response RPC server
*
* @author imarom (11-Aug-15)
*/
class TrexRpcServerReqRes : public TrexRpcServerInterface {
public:
TrexRpcServerReqRes(const TrexRpcServerConfig &cfg, std::mutex *lock = NULL);
protected:
void _rpc_thread_cb();
void _stop_rpc_thread();
private:
void handle_request(const std::string &request);
void handle_server_error(const std::string &specific_err);
static const int RPC_MAX_MSG_SIZE = (20 * 1024);
void *m_context;
void *m_socket;
uint8_t m_msg_buffer[RPC_MAX_MSG_SIZE];
};
#endif /* __TREX_RPC_REQ_RESP_API_H__ */
|