main.cpp 39 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734
  1. #include <iostream>
  2. #include "httppost.h"
  3. #include "cwmp.nsmap"
  4. #include "soapcwmpService.h"
  5. #include "plugin/threads.h"
  6. #include <vector>
  7. #include <algorithm>
  8. #include <signal.h>
  9. #include <thread>
  10. #include <fstream>
  11. #include "json.hpp"
  12. #include <mysql++/mysql++.h>
  13. #include <zdb.h>
  14. #define HOST "localhost"
  15. #define USER "acs"
  16. #define PASSWORD "159753"
  17. #define DATABASE "ACS"
  18. #define PORT 3306
  19. using json = nlohmann::json;
  20. int port = 7547;
  21. //int port = 8001;
  22. int POST_handler(struct soap *soap);
  23. struct http_post_handlers http_post_handlers[] = {
  24. {"POST", POST_handler},
  25. {NULL}
  26. };
  27. std::string currentISO8601TimeUTC() {
  28. std::time_t t = std::time(nullptr);
  29. std::ostringstream ss;
  30. ss << std::put_time(std::localtime(&t), "%FT%T %Z");
  31. return ss.str();
  32. }
  33. void handler(int s) {
  34. printf("Sassan Caught SIGPIPE ...\n");
  35. }
  36. void *process_request(void *arg) {
  37. cwmpService *service = (cwmpService *) arg;
  38. THREAD_DETACH(THREAD_ID);
  39. if (service) {
  40. service->serve();
  41. service->destroy(); /* clean up */
  42. delete service;
  43. }
  44. return NULL;
  45. }
  46. //<editor-fold desc="zbx_keys">
  47. std::string zbx_keys[] = {"InternetGatewayDevice.WANDevice.1.WANConnectionDevice.1.WANIPConnection.1.Uptime",
  48. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.UL_MCS",
  49. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.TX_Power",
  50. "InternetGatewayDevice.DeviceInfo.SoftwareVersion",
  51. "InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.SINR2",
  52. "InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.SINR1",
  53. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.RSRP2",
  54. "InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.RSRQ",
  55. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.RSRQ",
  56. "InternetGatewayDevice.LANDevice.1.LANHostConfigManagement.DHCPServerEnable",
  57. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Setting.Status",
  58. "InternetGatewayDevice.WANDevice.1.WANConnectionDevice.1.WANIPConnection.1.ConnectionStatus",
  59. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.RSRP1",
  60. "InternetGatewayDevice.WANDevice.1.WANConnectionDevice.1.WANIPConnection.1.ExternalIPAddress",
  61. "InternetGatewayDevice.WEB_GUI.Overview.DeviceInfo.IMSI",
  62. "InternetGatewayDevice.WEB_GUI.Overview.DeviceInfo.IMEI",
  63. "InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.EnodeBId",
  64. "InternetGatewayDevice.DeviceInfo.MemoryStatus.Free",
  65. "InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.EnodeBId",
  66. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.DL_MCS",
  67. "InternetGatewayDevice.Time.CurrentLocalTime",
  68. "InternetGatewayDevice.DeviceInfo.ProcessStatus.CPUUsage",
  69. "InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.CellId",
  70. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.BytesSent",
  71. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.BytesReceived",
  72. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.PacketsReceived",
  73. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.PacketsSent",
  74. "InternetGatewayDevice.DeviceInfo.UpTime",
  75. "InternetGatewayDevice.DeviceInfo.X_TGT_IMSI",
  76. "InternetGatewayDevice.WEB_GUI.Network.Network_Mode.WANIPAddress",
  77. "InternetGatewayDevice.WEB_GUI.Network.ScanMode.Settings.PCILock",
  78. "InternetGatewayDevice.WEB_GUI.Overview.LTEStatus.DnsServer",
  79. "InternetGatewayDevice.DeviceInfo.HardwareVersion",
  80. "InternetGatewayDevice.DeviceInfo.Manufacturer",
  81. "InternetGatewayDevice.DeviceInfo.ManufacturerOUI",
  82. "InternetGatewayDevice.DeviceInfo.ModelName",
  83. "InternetGatewayDevice.DeviceInfo.ModelNumber",
  84. "InternetGatewayDevice.DeviceInfo.Description",
  85. "InternetGatewayDevice.DeviceInfo.ProductClass",
  86. "InternetGatewayDevice.DeviceInfo.SerialNumber",
  87. "InternetGatewayDevice.LANDevice.1.LANEthernetInterfaceConfig.1.Enable",
  88. "InternetGatewayDevice.LANDevice.1.LANEthernetInterfaceConfig.2.Enable",
  89. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Enable",
  90. "InternetGatewayDevice.WEB_GUI.Overview.LTEStatus.DL_DataRate_Current",
  91. "InternetGatewayDevice.WEB_GUI.Overview.LTEStatus.UL_DataRate_Current",
  92. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.PCI",
  93. "InternetGatewayDevice.WEB_GUI.Overview.LANStatus.MacAddress",
  94. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.DL_Frequency",
  95. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.UL_Frequency",
  96. "InternetGatewayDevice.ManagementServer.ConnectionRequestURL",
  97. "InternetGatewayDevice.LANDevice.1.LANHostConfigManagement.IPInterface.1.IPInterfaceIPAddress"
  98. };
  99. //</editor-fold>
  100. void ZBX_Send(char **Name, char **Value, char **imsi) {
  101. if (!strcmp(*Name, "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.DL_MCS") == 0 or
  102. !strcmp(*Name, "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.UL_MCS") == 0) {
  103. if (!strcmp(*Value, "QPSK")) {
  104. *Value = "4";
  105. } else if (!strcmp(*Value, "QAM8")) {
  106. *Value = "8";
  107. } else if (!strcmp(*Value, "QAM16")) {
  108. *Value = "16";
  109. } else if (!strcmp(*Value, "QAM32")) {
  110. *Value = "32";
  111. } else if (!strcmp(*Value, "QAM64")) {
  112. *Value = "64";
  113. }
  114. std::ofstream zbx_data;
  115. std::string _time{};
  116. time_t second;
  117. second = time(NULL);
  118. std::stringstream strstream;
  119. strstream << second;
  120. strstream >> _time;
  121. zbx_data.open("/var/tmp/zbx_sender-" + _time, std::ios_base::app);
  122. zbx_data << "IMSI-" << *imsi << " " << *Name << " " << second << " \"" << *Value << "\"" << std::endl;
  123. }
  124. }
  125. std::string url_encode(const std::string &value) {
  126. std::ostringstream escaped;
  127. escaped.fill('0');
  128. escaped << std::hex;
  129. for (std::string::const_iterator i = value.begin(), n = value.end(); i != n; ++i) {
  130. std::string::value_type c = (*i);
  131. // Keep alphanumeric and other accepted characters intact
  132. if (isalnum(c) || c == '-' || c == '_' || c == '.' || c == '~') {
  133. escaped << c;
  134. continue;
  135. }
  136. // Any other characters are percent-encoded
  137. escaped << std::uppercase;
  138. escaped << '%' << std::setw(2) << int((unsigned char) c);
  139. escaped << std::nouppercase;
  140. }
  141. return escaped.str();
  142. }
  143. int main() {
  144. signal(SIGPIPE, handler);
  145. std::cout << "TR069 Server Started on Port " << port << "(1.3)...\n" << std::endl;
  146. cwmpService service(SOAP_XML_INDENT);
  147. service.soap->send_timeout = service.soap->recv_timeout = 5;
  148. service.soap->transfer_timeout = 60;
  149. service.soap->keep_alive = 20;
  150. service.soap->tcp_keep_alive = 1;
  151. service.soap->bind_flags |= SO_REUSEADDR;
  152. service.soap->bind_flags |= SO_REUSEPORT;
  153. service.soap->bind_flags |= MSG_NOSIGNAL;
  154. soap_init2(service.soap, SOAP_IO_KEEPALIVE, SOAP_IO_KEEPALIVE);
  155. SOAP_SOCKET m = service.bind(NULL, port, 100); /* master socket */
  156. if (soap_valid_socket(m)) {
  157. while (soap_valid_socket(service.accept())) {
  158. THREAD_TYPE tid;
  159. void *arg = (void *) service.copy();
  160. if (arg)
  161. while (THREAD_CREATE(&tid, (void *(*)(void *)) process_request, arg))
  162. sleep(1);
  163. }
  164. }
  165. service.soap_stream_fault(std::cerr);
  166. service.destroy(); /* clean up */
  167. return 0;
  168. }
  169. int POST_handler(struct soap *soap) {
  170. // struct _cwmp__GetParameterValues *res = soap_new__cwmp__GetParameterValues(soap, -1);
  171. // struct ParameterNames *list = soap_new_ParameterNames(soap, -1);
  172. const char *buf;
  173. size_t len;
  174. buf = soap_http_get_body(soap, &len);
  175. // std::cerr<<"Sassan3 ID: "<<soap->header->cwmp__SupportedCWMPVersions<<std::endl;
  176. // std::cerr<<"Debug1: "<<len<<std::endl;
  177. // std::cerr<<"Debug2: "<<buf<<std::endl;
  178. /* if HTTP has a content type header or a HTTP body is present then return 404 */
  179. if (len == 0) {
  180. std::cerr << "Sassan 204...: " << buf << std::endl;
  181. return 204; // HTTP 400 Bad Request
  182. // }else {
  183. // std::cerr<<"Debug0: "<<buf<<std::endl;
  184. // std::cerr<<"Debug1: "<<len<<std::endl;
  185. // std::cerr<<"Debug2: "<<buf<<std::endl;
  186. }
  187. // if (soap->http_content || soap_http_has_body(soap))
  188. // return 404;
  189. // (void)soap_end_recv(soap);
  190. // /* populate the response with one array item */
  191. // if (res && list)
  192. // {
  193. // list->__size = 1;
  194. // if ((list->__ptrstring = (char**)soap_malloc(soap, list->__size * sizeof(char*))) != NULL)
  195. // {
  196. // list->__ptrstring[0] = soap_strdup(soap, "...");
  197. // res->ParameterNames = list;
  198. // }
  199. // }
  200. // /* send response */
  201. // soap->encodingStyle = "";
  202. // soap_serializeheader(soap);
  203. // soap_serialize__cwmp__GetParameterValues(soap, res);
  204. // if (soap_begin_count(soap))
  205. // return soap->error;
  206. // if (soap->mode & SOAP_IO_LENGTH)
  207. // {
  208. // if (soap_envelope_begin_out(soap)
  209. // || soap_putheader(soap)
  210. // || soap_body_begin_out(soap)
  211. // || soap_put__cwmp__GetParameterValues(soap, res, "cwmp:GetParameterValues", "")
  212. // || soap_body_end_out(soap)
  213. // || soap_envelope_end_out(soap))
  214. // return soap->error;
  215. // };
  216. // if (soap_end_count(soap)
  217. // || soap_response(soap, SOAP_OK)
  218. // || soap_envelope_begin_out(soap)
  219. // || soap_putheader(soap)
  220. // || soap_body_begin_out(soap)
  221. // || soap_put__cwmp__GetParameterValues(soap, res, "cwmp:GetParameterValues", "")
  222. // || soap_body_end_out(soap)
  223. // || soap_envelope_end_out(soap)
  224. // || soap_end_send(soap))
  225. // return soap->error;
  226. // return soap_closesock(soap);
  227. }
  228. int cwmpService::GetParameterNames(struct _cwmp__GetParameterNames *cwmp__GetParameterNames,
  229. struct _cwmp__GetParameterNamesResponse *cwmp__GetParameterNamesResponse) { return SOAP_OK; }
  230. int cwmpService::GetParameterValues(struct _cwmp__GetParameterValues *cwmp__GetParameterValues,
  231. struct _cwmp__GetParameterValuesResponse *cwmp__GetParameterValuesResponse) { return SOAP_OK; }
  232. int cwmpService::SetParameterValues(struct _cwmp__SetParameterValues *cwmp__SetParameterValues,
  233. struct _cwmp__SetParameterValuesResponse *cwmp__SetParameterValuesResponse) {
  234. return SOAP_OK;
  235. }
  236. int cwmpService::SetParameterAttributes(
  237. struct _cwmp__SetParameterAttributes *cwmp__SetParameterAttributes,
  238. struct _cwmp__SetParameterAttributesResponse *cwmp__SetParameterAttributesResponse) { return SOAP_OK; }
  239. int cwmpService::GetParameterAttributes(struct _cwmp__GetParameterAttributes *cwmp__GetParameterAttributes,
  240. struct _cwmp__GetParameterAttributesResponse *cwmp__GetParameterAttributesResponse) { return SOAP_OK; }
  241. int cwmpService::Download(struct _cwmp__Download *cwmp__Download,
  242. struct _cwmp__DownloadResponse *cwmp__DownloadResponse) { return SOAP_OK; }
  243. int cwmpService::Upload(
  244. struct _cwmp__Upload *cwmp__Upload,
  245. struct _cwmp__UploadResponse *cwmp__UploadResponse) { return SOAP_OK; }
  246. int cwmpService::AddObject(
  247. struct _cwmp__AddObject *cwmp__AddObject,
  248. struct _cwmp__AddObjectResponse *cwmp__AddObjectResponse) { return SOAP_OK; }
  249. int cwmpService::DeleteObject(
  250. struct _cwmp__DeleteObject *cwmp__DeleteObject,
  251. struct _cwmp__DeleteObjectResponse *cwmp__DeleteObjectResponse) { return SOAP_OK; }
  252. int cwmpService::GetRPCMethods(
  253. struct _cwmp__GetRPCMethods *cwmp__GetRPCMethods,
  254. struct _cwmp__GetRPCMethodsResponse *cwmp__GetRPCMethodsResponse) { return SOAP_OK; }
  255. int cwmpService::GetParameterValuesResponse(
  256. struct _cwmp__GetParameterValuesResponse *cwmp__GetParameterValuesResponse) { return SOAP_OK; }
  257. int cwmpService::Inform(struct _cwmp__Inform *cwmp__Inform, struct _cwmp__InformResponse *cwmp__InformResponse,
  258. struct soap *soap) {
  259. std::string _id = std::string(cwmp__Inform->DeviceId->OUI) + "-" + std::string(cwmp__Inform->DeviceId->ProductClass)
  260. + "-" + std::string(cwmp__Inform->DeviceId->SerialNumber);
  261. std::cerr << "Inform Recieved from: " << url_encode(_id) << " at " << time(NULL) << std::endl;
  262. char *imsi;
  263. char *ip;
  264. auto timestamp = std::chrono::high_resolution_clock::now();
  265. std::vector<std::thread> th;
  266. std::vector<std::thread> th_acs;
  267. // int indexes[24];
  268. std::vector<int> ind;
  269. std::ofstream outfile;
  270. outfile.open("/var/tmp/tr069/" + url_encode(_id), std::ios::out | std::ios::trunc);
  271. std::ofstream mongoData;
  272. time_t second;
  273. std::string _time;
  274. std::map<std::string, std::string> tr069{};
  275. second = time(NULL);
  276. std::stringstream strstream;
  277. strstream << second;
  278. strstream >> _time;
  279. ip = soap->host;
  280. for (int i = 0; i < cwmp__Inform->ParameterList->__size; ++i) {
  281. char *_Name = cwmp__Inform->ParameterList->__ptrParameterValueStruct[i]->Name;
  282. char *_Value = cwmp__Inform->ParameterList->__ptrParameterValueStruct[i]->Value;
  283. if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.X_TGT_IMSI") == 0) {
  284. imsi = _Value;
  285. break;
  286. }
  287. }
  288. for (int i = 0; i < cwmp__Inform->ParameterList->__size; ++i) {
  289. char *_Name = cwmp__Inform->ParameterList->__ptrParameterValueStruct[i]->Name;
  290. char *_Value = cwmp__Inform->ParameterList->__ptrParameterValueStruct[i]->Value;
  291. outfile << _Name << ": " << _Value << std::endl;
  292. // if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.X_TGT_IMSI") == 0) {
  293. // imsi = _Value;
  294. // }
  295. // if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.Network_Mode.WANIPAddress") == 0) {
  296. // ip = _Value;
  297. // }
  298. std::string cpe = cwmp__Inform->DeviceId->SerialNumber;
  299. auto j = std::find(std::begin(zbx_keys), std::end(zbx_keys), _Name);
  300. if (j != std::end(zbx_keys)) {
  301. if (!strcmp(_Name, "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.DL_MCS") == 0 or
  302. !strcmp(_Name, "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.UL_MCS") == 0) {
  303. if (!strcmp(_Value, "QPSK")) {
  304. _Value = "4";
  305. } else if (!strcmp(_Value, "QAM8")) {
  306. _Value = "8";
  307. } else if (!strcmp(_Value, "QAM16")) {
  308. _Value = "16";
  309. } else if (!strcmp(_Value, "QAM32")) {
  310. _Value = "32";
  311. } else if (!strcmp(_Value, "QAM64")) {
  312. _Value = "64";
  313. }
  314. std::ofstream zbx_data;
  315. std::string _time{};
  316. time_t second;
  317. second = time(NULL);
  318. std::stringstream strstream;
  319. strstream << second;
  320. strstream >> _time;
  321. zbx_data.open("/var/tmp/zbx_sender-" + _time, std::ios_base::app);
  322. zbx_data << "IMSI-" << imsi << " " << _Name << " " << second << " \"" << _Value << "\"" << std::endl;
  323. }
  324. //<editor-fold desc="Map Filler">
  325. if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.HardwareVersion") == 0)
  326. tr069.insert({"HardwareVersion", _Value});
  327. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.SoftwareVersion") == 0)
  328. tr069.insert({"SoftwareVersion", _Value});
  329. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.UpTime") == 0)
  330. tr069.insert({"UpTime", _Value});
  331. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Overview.DeviceInfo.IMEI") == 0)
  332. tr069.insert({"IMEI", _Value});
  333. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.X_TGT_IMSI") == 0)
  334. tr069.insert({"IMSI", _Value});
  335. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.MemoryStatus.Free") == 0)
  336. tr069.insert({"Free", _Value});
  337. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.ProcessStatus.CPUUsage") == 0)
  338. tr069.insert({"CPUUsage", _Value});
  339. else if (std::string(_Name).compare("InternetGatewayDevice.Time.CurrentLocalTime") == 0)
  340. tr069.insert({"CurrentLocalTime", _Value});
  341. else if (std::string(_Name).compare(
  342. "InternetGatewayDevice.LANDevice.1.LANEthernetInterfaceConfig.1.Enable") == 0)
  343. tr069.insert({"LAN1Enable", _Value});
  344. else if (std::string(_Name).compare(
  345. "InternetGatewayDevice.LANDevice.1.LANEthernetInterfaceConfig.2.Enable") == 0)
  346. tr069.insert({"LAN2Enable", _Value});
  347. else if (std::string(_Name).compare("InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.SINR1") == 0)
  348. tr069.insert({"SINR1", _Value});
  349. else if (std::string(_Name).compare("InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.SINR2") == 0)
  350. tr069.insert({"SINR2", _Value});
  351. else if (std::string(_Name).compare("InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.EnodeBId") ==
  352. 0)
  353. tr069.insert({"EnodeBId", _Value});
  354. else if (std::string(_Name).compare("InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.CellId") == 0)
  355. tr069.insert({"CellId", _Value});
  356. else if (std::string(_Name).compare(
  357. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.BytesSent") == 0)
  358. tr069.insert({"BytesSent", _Value});
  359. else if (std::string(_Name).compare(
  360. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.BytesReceived") == 0)
  361. tr069.insert({"BytesReceived", _Value});
  362. else if (std::string(_Name).compare(
  363. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.PacketsSent") == 0)
  364. tr069.insert({"PacketsSent", _Value});
  365. else if (std::string(_Name).compare(
  366. "InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Stats.PacketsReceived") == 0)
  367. tr069.insert({"PacketsReceived", _Value});
  368. else if (std::string(_Name).compare(
  369. "InternetGatewayDevice.WANDevice.1.WANConnectionDevice.1.WANIPConnection.1.ConnectionStatus") == 0)
  370. tr069.insert({"ConnectionStatus", _Value});
  371. else if (std::string(_Name).compare(
  372. "InternetGatewayDevice.WANDevice.1.WANConnectionDevice.1.WANIPConnection.1.Uptime") == 0)
  373. tr069.insert({"Uptime", _Value});
  374. else if (std::string(_Name).compare(
  375. "InternetGatewayDevice.WANDevice.1.WANConnectionDevice.1.WANIPConnection.1.ExternalIPAddress") == 0)
  376. tr069.insert({"ExternalIPAddress", _Value});
  377. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.RSRP1") == 0)
  378. tr069.insert({"RSRP1", _Value});
  379. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.RSRP2") == 0)
  380. tr069.insert({"RSRP2", _Value});
  381. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.TX_Power") ==
  382. 0)
  383. tr069.insert({"TX_Power", _Value});
  384. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.DL_MCS") == 0)
  385. tr069.insert({"DL_MCS", _Value});
  386. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.UL_MCS") == 0)
  387. tr069.insert({"UL_MCS", _Value});
  388. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Setting.Status") ==
  389. 0)
  390. tr069.insert({"LTEStatus", _Value});
  391. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.ScanMode.Settings.PCILock") == 0)
  392. tr069.insert({"PCILock", _Value});
  393. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.Network_Mode.WANIPAddress") == 0)
  394. tr069.insert({"WANIPAddress", _Value});
  395. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Overview.LTEStatus.DnsServer") == 0)
  396. tr069.insert({"DnsServer", _Value});
  397. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Overview.DeviceInfo.IMSI") == 0)
  398. tr069.insert({"IMSI", _Value});
  399. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.Manufacturer") == 0)
  400. tr069.insert({"Manufacturer", _Value});
  401. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.ManufacturerOUI") == 0)
  402. tr069.insert({"OUI", _Value});
  403. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.ModelName") == 0)
  404. tr069.insert({"ModelName", _Value});
  405. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.ModelNumber") == 0)
  406. tr069.insert({"ModelNumber", _Value});
  407. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.Description") == 0)
  408. tr069.insert({"Description", _Value});
  409. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.ProductClass") == 0)
  410. tr069.insert({"ProductClass", _Value});
  411. else if (std::string(_Name).compare("InternetGatewayDevice.DeviceInfo.SerialNumber") == 0)
  412. tr069.insert({"SerialNumber", _Value});
  413. else if (std::string(_Name).compare("InternetGatewayDevice.WANDevice.1.X_TGT_WANNetConfigInfo.RSRQ") == 0)
  414. tr069.insert({"RSRQ", _Value});
  415. else if (std::string(_Name).compare(
  416. "InternetGatewayDevice.LANDevice.1.LANHostConfigManagement.DHCPServerEnable") == 0)
  417. tr069.insert({"DHCPServerEnable", _Value});
  418. else if (
  419. std::string(_Name).compare("InternetGatewayDevice.WANDevice.1.WANEthernetInterfaceConfig.Enable") ==
  420. 0)
  421. tr069.insert({"WANEthernetInterfaceConfigEnable", _Value});
  422. else if (std::string(_Name).compare("InternetGatewayDevice.ManagementServer.ConnectionRequestURL") == 0)
  423. tr069.insert({"ConnectionRequestURL", _Value});
  424. else if (std::string(_Name).compare(
  425. "InternetGatewayDevice.WEB_GUI.Overview.LTEStatus.DL_DataRate_Current") == 0)
  426. tr069.insert({"DL_DataRate_Current", _Value});
  427. else if (std::string(_Name).compare(
  428. "InternetGatewayDevice.WEB_GUI.Overview.LTEStatus.UL_DataRate_Current") == 0)
  429. tr069.insert({"UL_DataRate_Current", _Value});
  430. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.PCI") == 0)
  431. tr069.insert({"PCI", _Value});
  432. else if (std::string(_Name).compare(
  433. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.UL_Frequency") == 0)
  434. tr069.insert({"UL_Frequency", _Value});
  435. else if (std::string(_Name).compare(
  436. "InternetGatewayDevice.WEB_GUI.Network.LTE_Setting.Status.DL_Frequency") == 0)
  437. tr069.insert({"DL_Frequency", _Value});
  438. else if (std::string(_Name).compare(
  439. "InternetGatewayDevice.LANDevice.1.LANHostConfigManagement.IPInterface.1.IPInterfaceIPAddress") ==
  440. 0)
  441. tr069.insert({"IPInterfaceIPAddress", _Value});
  442. else if (std::string(_Name).compare("InternetGatewayDevice.WEB_GUI.Overview.LANStatus.MacAddress") == 0)
  443. tr069.insert({"MacAddress", _Value});
  444. // std::cerr<<"Key: "<<cwmp__Inform->ParameterList->__ptrParameterValueStruct[i]->Name<<std::endl;
  445. // std::cerr<<"Value: "<<cwmp__Inform->ParameterList->__ptrParameterValueStruct[i]->Value<<std::endl;
  446. //</editor-fold>
  447. }
  448. }
  449. std::ofstream zbx_data;
  450. zbx_data.open("/var/tmp/zbx_sender-" + _time, std::ios_base::app);
  451. zbx_data << "IMSI-" << imsi << " " << "BytsReceived" << " " << second << " \"" << tr069["BytesReceived"] << "\""
  452. << std::endl;
  453. zbx_data << "IMSI-" << imsi << " " << "BytsSent" << " " << second << " \"" << tr069["BytesSent"] << "\""
  454. << std::endl;
  455. //<editor-fold desc="Json">
  456. std::string ISOTime = currentISO8601TimeUTC();
  457. json tr069_json{};
  458. tr069_json["_id"] = url_encode(_id);
  459. tr069_json["_deviceId"]["_Manufacturer"] = cwmp__Inform->DeviceId->Manufacturer;
  460. tr069_json["_deviceId"]["_OUI"] = cwmp__Inform->DeviceId->OUI;
  461. tr069_json["_deviceId"]["_ProductClass"] = cwmp__Inform->DeviceId->ProductClass;
  462. tr069_json["_deviceId"]["_SerialNumber"] = cwmp__Inform->DeviceId->SerialNumber;
  463. tr069_json["_lastInform"] = ISOTime;
  464. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANConnectionDevice"]["1"]["WANIPConnection"]["1"]["Uptime"]["_value"] = tr069["Uptime"];
  465. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["UL_MCS"]["_value"] = tr069["UL_MCS"];
  466. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["TX_Power"]["_value"] = tr069["TX_Power"];
  467. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["SoftwareVersion"]["_value"] = tr069["SoftwareVersion"];
  468. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["X_TGT_WANNetConfigInfo"]["SINR2"]["_value"] = tr069["SINR2"];
  469. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["X_TGT_WANNetConfigInfo"]["SINR1"]["_value"] = tr069["SINR1"];
  470. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["RSRP2"]["_value"] = tr069["RSRP2"];
  471. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["X_TGT_WANNetConfigInfo"]["RSRQ"]["_value"] = tr069["RSRQ"];
  472. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["RSRQ"]["_value"] = tr069["RSRQ"];
  473. tr069_json["InternetGatewayDevice"]["LANDevice"]["1"]["LANHostConfigManagement"]["DHCPServerEnable"]["_value"] = tr069["DHCPServerEnable"];
  474. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Setting"]["Status"]["_value"] = tr069["LTEStatus"];
  475. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANConnectionDevice"]["1"]["WANIPConnection"]["1"]["ConnectionStatus"]["_value"] = tr069["ConnectionStatus"];
  476. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["RSRP1"]["_value"] = tr069["RSRP1"];
  477. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANConnectionDevice"]["1"]["WANIPConnection"]["1"]["ExternalIPAddress"]["_value"] = tr069["ExternalIPAddress"];
  478. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Overview"]["DeviceInfo"]["IMSI"]["_value"] = tr069["IMSI"];
  479. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Overview"]["DeviceInfo"]["IMEI"]["_value"] = tr069["IMEI"];
  480. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["X_TGT_WANNetConfigInfo"]["EnodeBId"]["_value"] = tr069["EnodeBId"];
  481. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["MemoryStatus"]["Free"]["_value"] = tr069["Free"];
  482. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["X_TGT_WANNetConfigInfo"]["EnodeBId"]["_value"] = tr069["EnodeBId"];
  483. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["DL_MCS"]["_value"] = tr069["DL_MCS"];
  484. tr069_json["InternetGatewayDevice"]["Time"]["CurrentLocalTime"]["_value"] = tr069["CurrentLocalTime"];
  485. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["ProcessStatus"]["CPUUsage"]["_value"] = tr069["CPUUsage"];
  486. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["X_TGT_WANNetConfigInfo"]["CellId"]["_value"] = tr069["CellId"];
  487. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANEthernetInterfaceConfig"]["Stats"]["BytesSent"]["_value"] = tr069["BytesSent"];
  488. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANEthernetInterfaceConfig"]["Stats"]["BytesReceived"]["_value"] = tr069["BytesReceived"];
  489. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANEthernetInterfaceConfig"]["Stats"]["PacketsReceived"]["_value"] = tr069["PacketsReceived"];
  490. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANEthernetInterfaceConfig"]["Stats"]["PacketsSent"]["_value"] = tr069["PacketsSent"];
  491. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["UpTime"]["_value"] = tr069["UpTime"];
  492. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["X_TGT_IMSI"]["_value"] = tr069["IMSI"];
  493. tr069_json["InternetGatewayDevice"]["LANDevice"]["1"]["LANEthernetInterfaceConfig"]["1"]["Enable"]["_value"] = tr069["Enable"];
  494. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["Network_Mode"]["WANIPAddress"]["_value"] = tr069["WANIPAddress"];
  495. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["ScanMode"]["Settings"]["PCILock"]["_value"] = tr069["PCILock"];
  496. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Overview"]["LTEStatus"]["DnsServer"]["_value"] = tr069["DnsServer"];
  497. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["HardwareVersion"]["_value"] = tr069["HardwareVersion"];
  498. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["Manufacturer"]["_value"] = cwmp__Inform->DeviceId->Manufacturer;
  499. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["ManufacturerOUI"]["_value"] = cwmp__Inform->DeviceId->OUI;
  500. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["ModelName"]["_value"] = tr069["ModelName"];
  501. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["ModelNumber"]["_value"] = tr069["ModelNumber"];
  502. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["Description"]["_value"] = tr069["Description"];
  503. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["ProductClass"]["_value"] = cwmp__Inform->DeviceId->ProductClass;
  504. tr069_json["InternetGatewayDevice"]["DeviceInfo"]["SerialNumber"]["_value"] = cwmp__Inform->DeviceId->SerialNumber;
  505. tr069_json["InternetGatewayDevice"]["LANDevice"]["1"]["LANEthernetInterfaceConfig"]["1"]["Enable"]["_value"] = tr069["LAN1Enable"];
  506. tr069_json["InternetGatewayDevice"]["LANDevice"]["1"]["LANEthernetInterfaceConfig"]["2"]["Enable"]["_value"] = tr069["LAN2Enable"];
  507. tr069_json["InternetGatewayDevice"]["ManagementServer"]["ConnectionRequestURL"]["_value"] = tr069["ConnectionRequestURL"];
  508. tr069_json["InternetGatewayDevice"]["WANDevice"]["1"]["WANEthernetInterfaceConfig"]["Enable"]["_value"] = tr069["WANEthernetInterfaceConfigEnable"];
  509. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Overview"]["LTEStatus"]["DL_DataRate_Current"]["_value"] = tr069["DL_DataRate_Current"];
  510. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Overview"]["LTEStatus"]["UL_DataRate_Current"]["_value"] = tr069["UL_DataRate_Current"];
  511. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["PCI"]["_value"] = tr069["PCI"];
  512. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Overview"]["LANStatus"]["MacAddress"]["_value"] = tr069["MacAddress"];
  513. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["DL_Frequency"]["_value"] = tr069["DL_Frequency"];
  514. tr069_json["InternetGatewayDevice"]["WEB_GUI"]["Network"]["LTE_Setting"]["Status"]["UL_Frequency"]["_value"] = tr069["UL_Frequency"];
  515. tr069_json["InternetGatewayDevice"]["LANDevice"]["1"]["IPInterface"]["1"]["IPInterfaceIPAddress"]["_value"] = tr069["IPInterfaceIPAddress"];
  516. //</editor-fold>
  517. std::ofstream json_data;
  518. second = time(NULL);
  519. strstream << second;
  520. strstream >> _time;
  521. json_data.open("/var/tmp/json_data/json-" + _time, std::ios_base::app);
  522. // json_data.open("/var/tmp/json_data/" + url_encode(_id) + "_" + _time, std::ios_base::app);
  523. json_data << tr069_json.dump(4);
  524. mysqlpp::Connection conn(false);
  525. mysqlpp::Query query = conn.query();
  526. try {
  527. conn.connect(DATABASE, HOST, USER, PASSWORD, PORT);
  528. query << "replace into Device_List values ('" + std::string(ip) + "','" + imsi + "',NOW()" + ")";
  529. query.execute();
  530. } catch (mysqlpp::BadQuery er) { // handle any connection or
  531. std::cerr << "Error on IMSI-" << imsi << " :" << er.what() << std::endl;
  532. }
  533. conn.disconnect();
  534. return SOAP_OK;
  535. }
  536. int cwmpService::FactoryReset(struct _cwmp__FactoryReset *cwmp__factoryReset,
  537. struct _cwmp__FactoryResetResponse *cwmp__factoryResetResponse) { return SOAP_OK; }
  538. int cwmpService::Reboot(struct _cwmp__Reboot *cwmp__Reboot,
  539. struct _cwmp__RebootResponse *cwmp__RebootResponse) { return SOAP_OK; }
  540. int cwmpService::CheckQueue(struct soap *soap, cwmpService *cwmpService1) {
  541. // std::cerr << "IP: " << soap->host << std::endl;
  542. soap->error = 0;
  543. std::string IMSI{}, s, id;
  544. const char *_actionParameters = "";
  545. int action{0};
  546. /*
  547. * {
  548. "FileType":"1",
  549. "URL":"http://172.20.9.24:808/ZLT_P11S_P13-NO_LOGO-P11PLUS-EN_48.3_update_file-all_2019_12_19_20_21_02.zip",
  550. "FilesSize":"4367707",
  551. "SuccessURL":null,
  552. "FailureURL":null
  553. }
  554. */
  555. std::stringstream strValue;
  556. json actionParameters = {};
  557. mysqlpp::Connection conn(false);
  558. mysqlpp::Query query = conn.query();
  559. mysqlpp::Query _query = conn.query();
  560. try {
  561. conn.connect(DATABASE, HOST, USER, PASSWORD, PORT);
  562. query
  563. << "select t.id, d.IMSI , t.action , t.ActionParameters from TaskList as t join Device_List as d on t.IMSI=d.IMSI where d.IP='"
  564. << soap->host
  565. << "' and t.response is null and t.Active=0 and t.`datetime` < NOW() order by id limit 1;";
  566. mysqlpp::StoreQueryResult result = query.store();
  567. if (result.size() == 0)
  568. return soap->error = 204;
  569. mysqlpp::StoreQueryResult::const_iterator it;
  570. for (it = result.begin(); it != result.end(); ++it) {
  571. mysqlpp::Row row = *it;
  572. strValue << row["id"];
  573. strValue >> id;
  574. strValue << row["IMSI"];
  575. strValue >> IMSI;
  576. action = row["action"];
  577. _actionParameters = row["ActionParameters"];
  578. }
  579. // std::cerr<<"Size of result+: "<<result.size()<<std::endl;
  580. s = std::string(_actionParameters);
  581. _query << "update TaskList set Active=1 where id='" << id << "';";
  582. _query.execute();
  583. } catch (mysqlpp::BadQuery er) { // handle any connection or
  584. std::cerr << "Error on CPE with IP: " << soap->host << " :" << er.what() << std::endl;
  585. }
  586. conn.disconnect();
  587. actionParameters = json::parse(s);
  588. if (action == 1) {
  589. try {
  590. std::cerr << "sending download request for " << soap->host << std::endl;
  591. int DelaySeconds = 1;
  592. std::string str = actionParameters["FileType"];
  593. char *FileType = new char[str.length() + 1];
  594. strcpy(FileType, str.c_str());
  595. str = actionParameters["URL"];
  596. char *URL = new char[str.length() + 1];
  597. strcpy(URL, str.c_str());
  598. char *Username = NULL;
  599. char *Password = NULL;
  600. int FileSize = std::stoi(std::string(actionParameters["FilesSize"]));
  601. char *TargetFileName = NULL;
  602. str = actionParameters["SuccessURL"];
  603. char *SuccessURL = new char[str.length() + 1];
  604. strcpy(SuccessURL, str.c_str());
  605. str = actionParameters["FailureURL"];
  606. char *FailureURL = new char[str.length() + 1];
  607. strcpy(FailureURL, str.c_str());
  608. return CustomeDownload(soap, this, DelaySeconds, FileType, URL, Username, Password, FileSize, TargetFileName,
  609. SuccessURL, FailureURL);
  610. } catch (std::exception ex) { // handle any connection or
  611. std::cerr << "Error on CPE with IP: " << soap->host << " :" << ex.what() << std::endl;
  612. }
  613. }
  614. //
  615. // return CustomeDownload(soap, this, std::__cxx11::string(), std::__cxx11::string(), std::__cxx11::string(),
  616. // std::__cxx11::string(), std::__cxx11::string(), std::__cxx11::string(),
  617. // std::__cxx11::string(),
  618. // std::__cxx11::string(), std::__cxx11::string());
  619. // return soap_closesock(soap);
  620. return soap->error = 204;
  621. }
  622. int cwmpService::CustomeDownloadResponse(struct soap *pSoap, cwmpService *pService) {
  623. std::cerr << "Upgrade Response received." << std::endl;
  624. std::stringstream strValue;
  625. std::string IMSI{}, s, id;
  626. soap->error = 0;
  627. mysqlpp::Connection conn(false);
  628. mysqlpp::Query query = conn.query();
  629. mysqlpp::Query _query = conn.query();
  630. try {
  631. conn.connect(DATABASE, HOST, USER, PASSWORD, PORT);
  632. query
  633. << "select t.id from TaskList as t join Device_List as d on t.IMSI=d.IMSI where d.IP='"
  634. << soap->host << "' and t.response is null and t.Active=1 order by id limit 1;";
  635. mysqlpp::StoreQueryResult result = query.store();
  636. if (result.size() == 0)
  637. return soap->error = 204;
  638. mysqlpp::StoreQueryResult::const_iterator it;
  639. for (it = result.begin(); it != result.end(); ++it) {
  640. mysqlpp::Row row = *it;
  641. strValue << row["id"];
  642. strValue >> id;
  643. }
  644. } catch (mysqlpp::BadQuery er) { // handle any connection or
  645. std::cerr << "Error on CPE with IP: " << soap->host << " :" << er.what() << std::endl;
  646. }
  647. _query << "update TaskList set Response='Done' where id='" << id << "';";
  648. _query.execute();
  649. conn.disconnect();
  650. // struct _cwmp__DownloadResponse cwmp__downloadResponse;
  651. // if ((soap->mode & SOAP_IO_LENGTH)) {
  652. // if (soap_envelope_begin_out(soap)
  653. // || soap_putheader(soap)
  654. // || soap_body_begin_out(soap)
  655. // || soap_put__cwmp__DownloadResponse(soap, &cwmp__downloadResponse, "cwmp:DownloadResponse", "")
  656. // || soap_body_end_out(soap)
  657. // || soap_envelope_end_out(soap))
  658. // return soap->error;
  659. // };
  660. // if (soap_end_count(soap)
  661. // || soap_response(soap, SOAP_OK)
  662. // || soap_envelope_begin_out(soap)
  663. // || soap_putheader(soap)
  664. // || soap_body_begin_out(soap)
  665. // || soap_put__cwmp__DownloadResponse(soap, &cwmp__downloadResponse, "cwmp:DownloadResponse", "")
  666. // || soap_body_end_out(soap)
  667. // || soap_envelope_end_out(soap)
  668. // || soap_end_send(soap))
  669. // return soap->error;
  670. soap->keep_alive = 0;
  671. return soap_closesock(soap);
  672. }