123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342 |
- #ifndef MODULE_WEB_H
- #define MODULE_WEB_H
- #include <memory>
- #include <string>
- #include"module_const.h"
- #include "rapidjson/prettywriter.h"
- #include "rapidjson/document.h"
- #include "websocket/wsClientMgr.h"
- class module_web : public singleton_base<module_web>
- {
- private:
- friend class singleton_base<module_web>;
- module_web()
- {
- }
- public:
-
- static void accept( int ID, std::string const& name,
- sio::message::ptr const& data, bool need_ack, sio::message::list &ack_resp );
-
- void init(std::map<std::string, YA::MSG_HANDLE_FUNC_TYPE>& MsgFuncList)
- {
- MsgFuncList.insert( std::make_pair( JSON_CMD_VALUE_REQUEST_ALL_DATA, &module_web::accept ) );
- MsgFuncList.insert( std::make_pair( JSON_CMD_VALUE_DEAL_HELP, &module_web::accept ) );
- MsgFuncList.insert( std::make_pair( JSON_CMD_VALUE_CALL_CARD_REQUEST, &module_web::accept ) );
- MsgFuncList.insert( std::make_pair( JSON_CMD_VALUE_CALL_CARD_CANCEL_REQUEST, &module_web::accept ) );
- }
-
- void response_login();
- };
- class tool_json
- {
- public:
- static bool try_get_iter(const char* key, const rapidjson::Value& node,
- rapidjson::Value::ConstMemberIterator& out_iter)
- {
- if(node.IsObject())
- {
- out_iter = node.FindMember(key);
- if(node.MemberEnd() == out_iter)
- {
- return false;
- }
- return true;
- }
- return false;
- }
- static bool try_get_value(int& d, const char* key, const rapidjson::Value& node)
- {
- rapidjson::Value::ConstMemberIterator iter;
- if(try_get_iter(key, node, iter))
- {
- if(iter->value.IsInt())
- {
- d = iter->value.GetInt();
- return true;
- }
- }
- return false;
- }
- static bool try_get_value(uint64_t& d, const char* key, const rapidjson::Value& node)
- {
- rapidjson::Value::ConstMemberIterator iter;
- if(try_get_iter(key, node, iter))
- {
- if(iter->value.IsUint64())
- {
- d = iter->value.GetUint64();
- return true;
- }
- }
- return false;
- }
- static bool try_get_value(double& d, const char* key, const rapidjson::Value& node)
- {
- rapidjson::Value::ConstMemberIterator iter;
- if(try_get_iter(key, node, iter))
- {
- if(iter->value.IsDouble())
- {
- d = iter->value.GetDouble();
- return true;
- }
- }
- return false;
- }
- static bool try_get_value(std::string& d, const char* key, const rapidjson::Value& node)
- {
- rapidjson::Value::ConstMemberIterator iter;
- if(try_get_iter(key, node, iter))
- {
- if(iter->value.IsString())
- {
- d = iter->value.GetString();
- return true;
- }
- }
- return false;
- }
- static int get_value(const char* key, const int& default_data, const rapidjson::Value& node)
- {
- rapidjson::Value::ConstMemberIterator iter;
- if(try_get_iter(key, node, iter))
- {
- if(iter->value.IsInt())
- {
- return iter->value.GetInt();
- }
- }
- return default_data;
- }
- static std::string get_value(const char* key, const std::string& default_data, const rapidjson::Value& node)
- {
- rapidjson::Value::ConstMemberIterator iter;
- if(try_get_iter(key, node, iter))
- {
- if(iter->value.IsString())
- {
- return iter->value.GetString();
- }
- }
- return default_data;
- }
- static std::string doc_to_json(rapidjson::Document& doc)
- {
- rapidjson::StringBuffer sb;
- rapidjson::PrettyWriter<rapidjson::StringBuffer> writer(sb);
- doc.Accept(writer);
- return sb.GetString();
- }
- static std::string ev_to_json(std::shared_ptr<ya_event> ev_ptr)
- {
- std::vector<std::shared_ptr<ya_event>> evs;
- evs.push_back(ev_ptr);
- return evs_to_json(evs);
- }
- static std::string evs_to_json(std::vector<std::shared_ptr<ya_event>> evs)
- {
- rapidjson::Document doc(rapidjson::kObjectType);
- rapidjson::Value data(rapidjson::kArrayType);
- rapidjson::Document::AllocatorType& allocator=doc.GetAllocator();
- auto it=evs.begin();
- for(;it!=evs.end();++it)
- {
- ev_to_node(*it, allocator, data);
- }
- doc.AddMember(JSON_ROOT_KEY_CMD,JSON_CMD_VALUE_EVENT, allocator);
- doc.AddMember(JSON_ROOT_KEY_VERSION,INTERFACE_VERSION, allocator);
- doc.AddMember(JSON_ROOT_KEY_DATA,data, allocator);
- rapidjson::StringBuffer sb;
- rapidjson::PrettyWriter<rapidjson::StringBuffer> writer(sb);
- doc.Accept(writer);
- return sb.GetString();
- }
- private:
- static void ev_to_node(std::shared_ptr<ya_event> ev_ptr,
- rapidjson::Document::AllocatorType& allocator,
- rapidjson::Value& out_data)
- {
- rapidjson::Value ev(rapidjson::kObjectType);
- ev.AddMember(JSON_KEY_EVENT_EVENT_ID,ev_ptr->get_id(), allocator);
- ev.AddMember(JSON_KEY_EVENT_STATUS,ev_ptr->m_status, allocator);
- ev.AddMember(JSON_KEY_EVENT_TYPE_ID,ev_ptr->m_ev_type, allocator);
- ev.AddMember(JSON_KEY_EVENT_OBJ_TYPE_ID,ev_ptr->m_obj_type, allocator);
- ev.AddMember(JSON_KEY_EVENT_OBJ_ID,ev_ptr->m_obj_id, allocator);
- ev.AddMember(JSON_KEY_EVENT_MAP_ID,ev_ptr->m_map_id, allocator);
- ev.AddMember(JSON_KEY_EVENT_AREA_ID,ev_ptr->m_area_id, allocator);
- ev.AddMember(JSON_KEY_EVENT_X,ev_ptr->x, allocator);
- ev.AddMember(JSON_KEY_EVENT_Y,ev_ptr->y, allocator);
- ev.AddMember(JSON_KEY_EVENT_LIMIT_VALUE,ev_ptr->m_limit_value, allocator);
- ev.AddMember(JSON_KEY_EVENT_CUR_VALUE,ev_ptr->m_cur_value, allocator);
- ev.AddMember(JSON_KEY_EVENT_CUR_TIME,tool_time::to_ms(ev_ptr->m_cur_time), allocator);
- ev.AddMember(JSON_KEY_EVENT_LANDMARK_ID,ev_ptr->m_landmarkid, allocator);
- ev.AddMember(JSON_KEY_EVENT_LANDMARK_DIRECTION,ev_ptr->m_landmarkdirect, allocator);
- ev.AddMember(JSON_KEY_EVENT_LANDMARK_DISTANCE,ev_ptr->m_landmarkdist, allocator);
- out_data.PushBack(ev, allocator);
- }
- };
- #endif
|