-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathParameters.cpp
199 lines (181 loc) · 5.58 KB
/
Parameters.cpp
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
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
/**
* @file Parameters.cpp
* @Author BeeeOn team (MS)
* @date April, 2016
* @brief
*/
#include "Parameters.h"
using namespace std;
using Poco::AutoPtr;
using Poco::Logger;
using Poco::Util::IniFileConfiguration;
using Poco::Net::NetworkInterface;
using Poco::Net::IPAddress;
Parameters::Parameters(Aggregator &_agg, IOTMessage _msg, Logger &_log):
log(_log),
agg(_agg),
msg(_msg)
{
ada_type = "other";
AutoPtr<IniFileConfiguration> cfg_param;
try {
cfg_param = new IniFileConfiguration(string(MODULES_DIR)+string(MOD_PARAM)+".ini");
ada_type = cfg_param->getString(string(MOD_PARAM) + ".type", "other");
}
catch (Poco::Exception& ex) {
log.error("Error: Exception with config file reading: " + (string)ex.displayText());
ada_type = "other";
}
msg.state = "getparameters";
msg.priority = MSG_PRIO_PARAM;
msg.offset = 0;
if(toFloatFromString(msg.protocol_version) < 1.1)
log.error("Old protocol version!");
log.information("=== Adaapp Started ===");
}
/**
* Processing the request from the server.
* Return true in case of success or false if a message is not supported.
*/
bool Parameters::cmdFromServer(Command cmd)
{
if (toFloatFromString(cmd.protocol_version) < 1.1) {
return false;
}
if (cmd.state == "getparameters") { // new request from the server
log.information("cmdFromServer | state == getparameters");
CmdParam filled_params; // (will be) filled struct for send
switch (cmd.params.param_id) {
case SRV_PING:
filled_params = getDummy(cmd.params);
break;
case SRV_GET_GW_IP_LIST:
filled_params = getLocalIp(cmd.params);
break;
case SRV_GET_GW_TYPE:
filled_params = getGatetype(cmd.params);
break;
default: return false;
}
msg.params = filled_params; // add parameters block (struct)
msg.state = "parameters"; // for answer is this state
msg.time = time(NULL); // set actual time
agg.sendData(msg); // send (response) to server
return true;
}
else if (cmd.state == "parameters") { // response from the server or other information
log.information("cmdFromServer | state == parameters");
switch (cmd.params.param_id) {
case GW_PING:
log.information("Server PING me");
break;
case GW_GET_DEV_NAME: /*label*/
case GW_GET_DEV_ROOM: /*room*/
case GW_GET_DEV_CREDENTIALS: /*vptpasswd*/
justPrintToLog(cmd.params);
break;
case GW_GET_ALL_DEVS:
allsensors(cmd.params);
break;
default: return false;
}
}
return true;
}
/**
* Sending a request to the server.
* This function concurrently returns an answer from the server.
* In case of an error returns the original unchanged structure.
*/
CmdParam Parameters::askServer(CmdParam cmd_request)
{
if (cmd_request.param_id < GW_PING || cmd_request.param_id > GW_END){
log.error("Ask the Server: Wrong param_id");
cmd_request.status = false;
return cmd_request; // id of requirement must be specified
}
if(toFloatFromString(msg.protocol_version) < 1.1){ // old protocol version
cmd_request.status = false;
return cmd_request;
}
msg.params = cmd_request; // add parameters block (struct)
msg.state = "getparameters"; // for request is this state
msg.time = time(NULL); // set actual time
log.information("Ask the Server | state = getparameters | param_id = " + toStringFromInt(cmd_request.param_id));
pair<bool, Command> response = agg.sendData(msg); // send to server
if (response.first && response.second.state == "parameters"){
log.information("Ask the Server | return OK");
justPrintToLog(response.second.params);
response.second.params.status = true;
return response.second.params; // prayers were answered
}
log.information("Ask the Server | return FAIL");
cmd_request.status = false;
return cmd_request;
}
CmdParam Parameters::getAllPairedDevices()
{
CmdParam request;
request.param_id = GW_GET_ALL_DEVS;
return askServer(request);
}
/**
* Returns a vector (list) of IP address (active connections).
*/
vector<string> Parameters::getIP()
{
vector<string> list_of_ip;
NetworkInterface::Map m = NetworkInterface::map(false, false);
for (NetworkInterface::Map::const_iterator it = m.begin(); it != m.end(); ++it) {
if ( ! it->second.isUp())
continue;
typedef NetworkInterface::AddressList List;
const List& ipList = it->second.addressList();
for (auto ip: ipList) {
std::string tmp = ip.get<NetworkInterface::IP_ADDRESS>().toString();
if ( (! ip.get<NetworkInterface::IP_ADDRESS>().isLoopback()) && // no localhost
(ip.get<NetworkInterface::IP_ADDRESS>().family() == Poco::Net::IPAddress::IPv4) && // only IPv4
(std::find(list_of_ip.begin(), list_of_ip.end(), tmp) == list_of_ip.end()) ) { // not in list
list_of_ip.push_back(tmp); // add
}
}
}
return list_of_ip;
}
void Parameters::allsensors(CmdParam incomer)
{
log.information("Refresh euid list");
euides.clear();
for(auto item: incomer.value){
log.information(" " + item.first + " (" + item.second + ")");
euides.push_back(item);
}
}
void Parameters::justPrintToLog(CmdParam incomer)
{
log.information("Parameters from server, param_id = ", incomer.param_id);
for(auto item: incomer.value){
log.information(" " + item.first + " (" + item.second + ")");
}
}
CmdParam Parameters::getDummy(CmdParam incomer)
{
log.information("get Dummy");
incomer.value.push_back({"",""});
return incomer;
}
CmdParam Parameters::getLocalIp(CmdParam incomer)
{
log.information("get Local IP");
vector<string> ip_list = getIP();
for (auto item: ip_list){
incomer.value.push_back({item,""});
}
return incomer;
}
CmdParam Parameters::getGatetype(CmdParam incomer)
{
log.information("get Gate type");
incomer.value.push_back({ada_type,""});
return incomer;
}