1
0

module_meta_date_changed.cpp 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515
  1. #include "module_meta_date_changed.h"
  2. #include"area_business_person_attendance.h"
  3. #include"area_business_car_attendance.h"
  4. #include"common_tool.h"
  5. #include "websocket/wsClientMgr.h"
  6. #include"db/db_api/CDBSingletonDefine.h"
  7. #include"event.h"
  8. #include"ant.h"
  9. #include"card.h"
  10. #include"area.h"
  11. ///基础数据
  12. void module_meta_date_changed::accept(sio::message::ptr const& data)
  13. {
  14. std::string name="";
  15. if(!tool_map::try_get_value(name, JSON_KEY_NAME, data))
  16. {
  17. log_error("web发来的数据: 基础数据找不到name字段");
  18. return;
  19. }
  20. std_debug("基础数据 receive meta_data_changed: %s", name.c_str());
  21. int64_t id=-1;
  22. tool_map::try_get_value(id, JSON_KEY_ID, data);
  23. std::string op_type="";
  24. tool_map::try_get_value(op_type, JSON_KEY_OP_TYPE, data);
  25. if(-1 != id && !op_type.empty())
  26. {
  27. EDIT_TYPE_ID edit_type_id;
  28. if(!try_get_edit_type_id(op_type, edit_type_id))
  29. {
  30. log_error("web发来的数据: 基础数据op_type字段错误:op_type=%s", op_type.c_str());
  31. return;
  32. }
  33. if(JSON_KEY_NAME_VEHICLE == name || JSON_KEY_NAME_VEHICLE_EXTEND == name)
  34. {
  35. deal_call_edit_vehicle(id, edit_type_id);
  36. }
  37. else if(JSON_KEY_NAME_STAFF == name || JSON_KEY_NAME_STAFF_EXTEND == name)
  38. {
  39. deal_call_edit_staff(id, edit_type_id);
  40. }
  41. else if(JSON_KEY_NAME_CARD == name)
  42. {
  43. deal_call_edit_card(id, edit_type_id);
  44. }
  45. else if(JSON_KEY_NAME_AREA == name)
  46. {
  47. deal_call_edit_area(id, edit_type_id);
  48. }
  49. else if(JSON_KEY_NAME_READER == name)
  50. {
  51. deal_call_edit_reader(id, edit_type_id);
  52. }
  53. else if ("antenna" == name)
  54. {
  55. deal_call_edit_antenna(id,edit_type_id);
  56. }
  57. else if(JSON_KEY_NAME_PATH == name)
  58. {
  59. deal_call_edit_path(id, edit_type_id);
  60. }
  61. else if(JSON_KEY_NAME_MAP == name)
  62. {
  63. deal_call_edit_map(id, edit_type_id);
  64. }
  65. else if (JSON_KEY_NAME_LIGHT == name)
  66. {
  67. deal_call_edit_light(id,edit_type_id);///待实现
  68. }
  69. else if ("lights_group" == name)
  70. {
  71. deal_call_edit_lights_group(id,edit_type_id);///待实现
  72. }
  73. else
  74. {
  75. log_error("web发来的数据: 基础数据name字段错误:name=%s", name.c_str());
  76. }
  77. }
  78. else
  79. {
  80. if(JSON_KEY_NAME_SETTING == name)
  81. {
  82. //阈值限制接口
  83. init_setting(); ///待实现
  84. }
  85. else
  86. {
  87. log_error("web发来的数据: 基础数据name字段错误:name=%s", name.c_str());
  88. }
  89. }
  90. }
  91. ///3.清除卡相关信息,区域相关,分站相关,考勤相关,清除定时器,
  92. ///速度,状态 呼救 呼叫 告警相关。即保留基础信息,其他的重置。
  93. void module_meta_date_changed::clear_card(std::shared_ptr<card_location_base> card_ptr)
  94. {
  95. auto rea_tool = card_ptr->get_area_tool();
  96. rea_tool->on_leave(card_ptr);
  97. //card_ptr->clear();
  98. // //删除
  99. // //card_ptr->del_card_pos();
  100. // 升井 删除所有报警信息
  101. for(int i=0; i < CARD_EVENT_COUNT_MAX; i++ )
  102. {
  103. if (i == EVENT_TYPE::ET_CARD_LOW_POWER_SERIOUS)
  104. {
  105. continue;
  106. }
  107. uint64_t id = tool_other::type_id_to_u64(card_ptr->m_type, card_ptr->m_id);
  108. event_tool::instance()->handle_event(OT_CARD, static_cast<EVENT_TYPE>(i), id, 0, 0, false);
  109. // auto ev_ptr = event_list::instance()->get_event_card(
  110. // card_ptr->m_id, card_ptr->m_type, static_cast<EVENT_TYPE>(i));
  111. // if(ev_ptr && !ev_ptr->is_end()) //
  112. // {
  113. // event_list::copy_event(card_ptr, ev_ptr);
  114. // ev_ptr->m_status = ES_END;
  115. // event_list::save_event(ev_ptr);
  116. // }
  117. }
  118. }
  119. void module_meta_date_changed::deal_call_edit_vehicle(int64_t id64, EDIT_TYPE_ID edit_type_id)
  120. {
  121. //车信息修改 id64=车ID vehicle_id
  122. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  123. {
  124. char sql[1024] = {'\0'};
  125. sprintf(sql,"select card_id from dat_vehicle_extend where vehicle_id=%d;", (int)id64);
  126. std::string Error;
  127. YADB::CDBResultSet DBRes;
  128. sDBConnPool.Query(sql,DBRes,Error);
  129. int64_t nCount = DBRes.GetRecordCount( Error );
  130. if (nCount > 0)
  131. {
  132. int64_t card_id = 0;
  133. while ( DBRes.GetNextRecod(Error) )
  134. {
  135. std::string szCard_id;
  136. DBRes.GetField( "card_id",szCard_id, Error );
  137. card_id = atoll(szCard_id.c_str());
  138. }
  139. card_list::instance()->init_vehicle(card_id);
  140. }
  141. }
  142. else if(ET_DELETE == edit_type_id)
  143. {
  144. auto c = card_list::instance()->get_card_by_cid(id64);
  145. remove_card(c);
  146. //auto str = tool_other::to13str(id64);
  147. //remove_card(tool_other::id64_to_id(str), tool_other::id64_to_type(str));
  148. }
  149. }
  150. void module_meta_date_changed::deal_call_edit_staff(int64_t id64, EDIT_TYPE_ID edit_type_id)
  151. {
  152. //人员信息更改 id64=人员ID staff_id
  153. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  154. {
  155. char sql[1024] = {'\0'};
  156. sprintf(sql,"select card_id from dat_staff_extend where staff_id=%d;", (int)id64);
  157. std::string Error;
  158. YADB::CDBResultSet DBRes;
  159. sDBConnPool.Query(sql,DBRes,Error);
  160. int64_t nCount = DBRes.GetRecordCount( Error );
  161. if (nCount > 0)
  162. {
  163. int64_t card_id = 0;
  164. while ( DBRes.GetNextRecod(Error) )
  165. {
  166. std::string szCard_id;
  167. DBRes.GetField( "card_id",szCard_id, Error );
  168. card_id = atoll(szCard_id.c_str());
  169. }
  170. card_list::instance()->init_staffer(card_id);
  171. }
  172. }
  173. else if(ET_DELETE == edit_type_id)
  174. {
  175. auto c = card_list::instance()->get_card_by_cid(id64);
  176. remove_card(c);
  177. //auto str = tool_other::to13str(id64);
  178. //remove_card(tool_other::id64_to_id(str), tool_other::id64_to_type(str));
  179. }
  180. }
  181. void module_meta_date_changed::deal_call_edit_card(int64_t id64, EDIT_TYPE_ID edit_type_id)
  182. {
  183. std::string card_id64_str = tool_other::to13str(static_cast<uint64_t>(id64));
  184. int type = tool_other::id64_to_type(card_id64_str);
  185. if(tool_other::is_person(type))
  186. {
  187. deal_call_edit_staff(id64, edit_type_id);
  188. }
  189. else if(tool_other::is_vehicle(type))
  190. {
  191. deal_call_edit_vehicle(id64, edit_type_id);
  192. }
  193. else
  194. {
  195. log_error("基础数据 删除卡type不对:type=%d", type);
  196. }
  197. }
  198. void module_meta_date_changed::deal_call_edit_area(int id, EDIT_TYPE_ID edit_type_id)
  199. {
  200. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  201. {
  202. if(is_monkeycar_area(id))
  203. {
  204. area_list::instance()->init_monkeycar_area(id);
  205. }
  206. else
  207. {
  208. area_list::instance()->init_from_db(id);
  209. }
  210. }
  211. else if(ET_DELETE == edit_type_id)
  212. {
  213. auto area_ptr = area_list::instance()->get(id);
  214. if(!area_ptr)
  215. {
  216. log_info("区域已经删除:areaid=%d", id);
  217. return;
  218. }
  219. //删除告警
  220. delete_area_event(area_ptr);
  221. area_list::instance()->remove(id);
  222. }
  223. }
  224. void module_meta_date_changed::deal_call_edit_reader(int id, EDIT_TYPE_ID edit_type_id)
  225. {
  226. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  227. {
  228. sit_list::instance()->init_site(id);
  229. }
  230. else if(ET_DELETE == edit_type_id)
  231. {
  232. //删除告警
  233. sit_list::instance()->remove(id);
  234. }
  235. }
  236. void module_meta_date_changed::deal_call_edit_antenna(int id,EDIT_TYPE_ID edit_type_id)
  237. {
  238. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  239. {
  240. sit_list::instance()->read_sit_list(id);
  241. }
  242. else if(ET_DELETE == edit_type_id)
  243. {
  244. delete_antenna(id);
  245. }
  246. }
  247. void module_meta_date_changed::deal_call_edit_path(int id, EDIT_TYPE_ID edit_type_id)
  248. {
  249. if(ET_INSERT == edit_type_id)
  250. {
  251. log_error("path不支持增加操作");
  252. std_debug("path不支持增加操作");
  253. }
  254. else if(ET_UPDATE == edit_type_id)
  255. {
  256. sit_list::instance()->read_ant_path(id);
  257. }
  258. else if(ET_DELETE == edit_type_id)
  259. {
  260. auto sit_ptr = sit_list::instance()->get(id);
  261. if(sit_ptr)
  262. {
  263. sit_ptr->clear_path();
  264. }
  265. log_info("path删除成功,分站id=%d", id);
  266. std_debug("path删除成功,分站id=%d", id);
  267. }
  268. }
  269. void module_meta_date_changed::deal_call_edit_map(int id, EDIT_TYPE_ID edit_type_id)
  270. {
  271. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  272. {
  273. if(!is_cur_map(id))
  274. {
  275. log_info("修改的不是当前使用的地图,要修改地图id=%d,当前使用地图id=%d", id, cur_map_id());
  276. return;
  277. }
  278. update_map_info(id);
  279. }
  280. else if(ET_DELETE == edit_type_id)
  281. {
  282. if(is_cur_map(id))
  283. {
  284. log_error("删除了当前使用的地图");
  285. return;
  286. }
  287. }
  288. }
  289. void module_meta_date_changed::deal_call_edit_light(int id, EDIT_TYPE_ID edit_type_id)
  290. {
  291. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  292. {
  293. }
  294. else if(ET_DELETE == edit_type_id)
  295. {
  296. }
  297. }
  298. void module_meta_date_changed::deal_call_edit_lights_group(int id, EDIT_TYPE_ID edit_type_id)
  299. {
  300. if(ET_INSERT == edit_type_id || ET_UPDATE == edit_type_id)
  301. {
  302. }
  303. else if(ET_DELETE == edit_type_id)
  304. {
  305. }
  306. }
  307. void module_meta_date_changed::init_setting()
  308. {
  309. //pRes = getMysqlRes("select setting_id, name, type, value from dat_setting;");
  310. }
  311. void module_meta_date_changed::remove_card(uint32_t id, int32_t type) {
  312. uint64_t card_id = tool_other::type_id_to_u64(type, id);
  313. auto card_ptr = card_list::instance()->get(card_id);
  314. if (!card_ptr) {
  315. log_error("基础数据, 在全局列表中删除卡,全局列表中已经不存在此卡, id=%d, type=%d", id, type);
  316. return;
  317. }
  318. remove_card(card_ptr);
  319. }
  320. void module_meta_date_changed::remove_card(std::shared_ptr<card_location_base> card_ptr)
  321. {
  322. if (!card_ptr)
  323. {
  324. return;
  325. }
  326. log_info("基础数据, 在全局列表中删除卡成功, id=%d, type=%d",card_ptr->m_type, card_ptr->m_id);
  327. // auto area_hover_ptr = card_ptr->get_area_hover();
  328. // if(area_hover_ptr && 0!=area_hover_ptr->id() && 0!=area_hover_ptr->mapid())
  329. // {
  330. // module_area::on_leave(card_ptr->m_id, area_hover_ptr, card_ptr->m_type);
  331. // }
  332. // if(card_ptr->is_person())
  333. // {
  334. // module_attendance_person::up_mine(card_ptr, nullptr);
  335. // }
  336. // else
  337. // {
  338. // module_attendance_vehicle::save_attendance(card_ptr, nullptr);
  339. // module_meta_date_changed::clear_card(card_ptr);
  340. // }
  341. module_meta_date_changed::clear_card(card_ptr);
  342. // 避免状态重置
  343. uint64_t card_id = tool_other::type_id_to_u64(card_ptr->m_type, card_ptr->m_id);
  344. card_list::instance()->remove(card_id);
  345. }
  346. bool module_meta_date_changed::try_get_edit_type_id(const std::string& op_type, EDIT_TYPE_ID& out_edit_type_id)
  347. {
  348. if(JSON_KEY_OP_TYPE_UPDATE == op_type)
  349. {
  350. out_edit_type_id = ET_UPDATE;
  351. }
  352. else if(JSON_KEY_OP_TYPE_DELETE == op_type)
  353. {
  354. out_edit_type_id = ET_DELETE;
  355. }
  356. else if(JSON_KEY_OP_TYPE_INSERT == op_type)
  357. {
  358. out_edit_type_id = ET_INSERT;
  359. }
  360. else
  361. {
  362. return false;
  363. }
  364. return true;
  365. }
  366. bool module_meta_date_changed::is_monkeycar_area(int area_id)
  367. {
  368. char sql[1024] = {'\0'};
  369. sprintf(sql,"select monkeycar_areaid from dat_monkeycar_base_info where monkeycar_areaid=%d;", area_id);
  370. std::string Error;
  371. YADB::CDBResultSet DBRes;
  372. sDBConnPool.Query(sql,DBRes,Error);
  373. int64_t nCount = DBRes.GetRecordCount( Error );
  374. log_info("monkeycar_area区域查询:nCount=%d,sql=%s", nCount, sql);
  375. std_debug("monkeycar_area区域查询:nCount=%d,sql=%s", nCount, sql);
  376. return (nCount > 0);
  377. }
  378. ///删除区域所有报警信息
  379. void module_meta_date_changed::delete_area_event(std::shared_ptr<area> area_ptr)
  380. {
  381. for(int i=0; i < CARD_EVENT_COUNT_MAX; i++ )
  382. {
  383. event_tool::instance()->handle_event(OT_AREA, static_cast<EVENT_TYPE>(i), area_ptr->id(), 0, 0, false);
  384. }
  385. }
  386. void module_meta_date_changed::delete_antenna(int id)
  387. {
  388. int sitid=-8;
  389. auto map = sit_list::instance()->m_map;
  390. for(auto&it:map)
  391. {
  392. auto sit_ptr = it.second;
  393. if(sit_ptr->m_ant[0].m_id == id)
  394. {
  395. sitid=sit_ptr->m_id;
  396. sit_ptr->delete_antenna(0);
  397. break;
  398. }
  399. if(sit_ptr->m_ant[1].m_id == id)
  400. {
  401. sitid=sit_ptr->m_id;
  402. sit_ptr->delete_antenna(1);
  403. break;
  404. }
  405. }
  406. if(sitid==-8)
  407. {
  408. std_debug("天线已经删除了,在分站列表中找不到该天线:天线id=%d", id);
  409. log_info("天线已经删除了,在分站列表中找不到该天线:天线id=%d", id);
  410. }
  411. else
  412. {
  413. std_debug("删除天线成功:天线id=%d,分站id=%d", id, sitid);
  414. log_info("删除天线成功:天线id=%d,分站id=%d", id, sitid);
  415. }
  416. }
  417. bool module_meta_date_changed::is_cur_map(int id)
  418. {
  419. return cur_map_id()==id;
  420. }
  421. int module_meta_date_changed::cur_map_id()
  422. {
  423. auto tmp = area_list::instance()->m_map;
  424. for(auto&it:tmp)
  425. {
  426. if(0!=it.second->m_mapid)
  427. {
  428. return it.second->m_mapid;
  429. }
  430. }
  431. return -1;
  432. }
  433. void module_meta_date_changed::update_map_info(int id)
  434. {
  435. std::string sql = "SELECT scale FROM dat_map WHERE map_id=";
  436. sql.append(std::to_string(id));
  437. sql.append(";");
  438. std_debug("修改地图 sql=%s", sql.c_str());
  439. log_info("修改地图 sql=%s", sql.c_str());
  440. std::string Error;
  441. YADB::CDBResultSet DBRes;
  442. sDBConnPool.Query(sql.c_str(),DBRes,Error);
  443. int nCount = DBRes.GetRecordCount( Error );
  444. if (nCount < 1)
  445. {
  446. log_error("修改地图失败,数据库中找不到: map_id=%d", id);
  447. return ;
  448. }
  449. double scale = 0;
  450. DBRes.GetField( "scale",scale, Error );
  451. auto area = area_list::instance()->m_map;
  452. for(auto& it : area)
  453. {
  454. it.second->m_scale = scale;
  455. }
  456. auto site = sit_list::instance()->m_map;
  457. for(auto& it : site)
  458. {
  459. it.second->m_scale = scale;
  460. }
  461. }