+
+/**
+ * registerShortcut event
+ *
+ * #### Parameters
+ * - request : the request
+ *
+ * #### Return
+ * 0 : success
+ * others : fail
+ *
+ */
+int HS_Client::registerShortcut(afb_req_t request)
+{
+ int ret = 0;
+ struct json_object *param_obj;
+ if(json_object_object_get_ex(afb_req_json(request), _parameter, ¶m_obj)) {
+ struct json_object* push_obj = json_object_new_object();
+ hs_add_object_to_json_object_str( push_obj, 4, _application_id, my_id.c_str(), _type, __FUNCTION__);
+ json_object_object_add(push_obj, _parameter, param_obj);
+ afb_event_push(my_event, push_obj);
+ }
+ else {
+ AFB_WARNING("please input parameter.");
+ ret = AFB_EVENT_BAD_REQUEST;
+ }
+ return ret;
+}
+
+/**
+ * updateShortcut event
+ *
+ * #### Parameters
+ * - request : the request
+ *
+ * #### Return
+ * 0 : success
+ * others : fail
+ *
+ */
+int HS_Client::updateShortcut(afb_req_t request)
+{
+ AFB_INFO("%s application_id = %s.", __FUNCTION__, my_id.c_str());
+ int ret = 0;
+ std::list<std::pair<std::string, std::string>> new_shortcut_list;
+ struct json_object *req_json = afb_req_json(request);
+ struct json_object *param_obj, *shortcut_obj;
+ if(json_object_object_get_ex(afb_req_json(request), _parameter, ¶m_obj)
+ && json_object_object_get_ex(param_obj, _shortcut, &shortcut_obj)) {
+ if(json_object_get_type(shortcut_obj) == json_type_array ) {
+ int array_len = json_object_array_length(shortcut_obj);
+ for (int i = 0; i < array_len; ++i) {
+ struct json_object *obj = json_object_array_get_idx(shortcut_obj, i);
+ struct json_object *appid_obj, *appname_obj;
+ if(json_object_object_get_ex(obj, _shortcut_id, &appid_obj)
+ && json_object_object_get_ex(obj, _shortcut_name, &appname_obj)) {
+ new_shortcut_list.push_back(std::pair<std::string, std::string>(json_object_get_string(appid_obj),
+ json_object_get_string(appname_obj)));
+ }
+ else {
+ AFB_WARNING("shortcut list json object pattern error.");
+ ret = AFB_EVENT_BAD_REQUEST;
+ break;
+ }
+ }
+ }
+ else {
+ AFB_WARNING("json object pattern error.");
+ ret = AFB_EVENT_BAD_REQUEST;
+ }
+ }
+ else {
+ AFB_WARNING("input json object error.");
+ ret = AFB_EVENT_BAD_REQUEST;
+ }
+
+ if(ret == 0) {
+ HS_Client::shortcut_list.swap(new_shortcut_list);
+ pushUpdateShortcutEvent();
+ }
+ return ret;
+}
+
+/**
+ * check if client subscribe event
+ *
+ * #### Parameters
+ * - event: homescreen event, tap_shortcut etc.
+ *
+ * #### Return
+ * true: found
+ * false: not found
+ *
+ */
+bool HS_Client::checkEvent(const char* event)
+{
+ auto ip = event_list.find(std::string(event));
+ if(ip == event_list.end())
+ return false;
+ else
+ return true;
+}
+
+/**
+ * check if event is supporting
+ *
+ * #### Parameters
+ * - event: homescreen event, tap_shortcut etc.
+ *
+ * #### Return
+ * true: support
+ * false: not fosupportund
+ *
+ */
+bool HS_Client::isSupportEvent(const char* event)
+{
+ int ret = hs_search_event_name_index(event);
+ return ret == -1 ? false : true;
+}
+
+/**
+ * handle homescreen event
+ *
+ * #### Parameters
+ * - request : the request
+ * - verb: request verb name
+ *
+ * #### Return
+ * 0: success
+ * others: fail
+ *
+ */
+int HS_Client::handleRequest(afb_req_t request, const char *verb)
+{
+ AFB_DEBUG("called.");
+ if((strcasecmp(verb, "subscribe") && strcasecmp(verb, "unsubscribe")) && !checkEvent(verb))
+ return 0;
+
+ int ret = AFB_EVENT_BAD_REQUEST;
+ auto ip = func_list.find(std::string(verb));
+ if(ip != func_list.end() && ip->second != nullptr) {
+ AFB_INFO("[%s]verb found", verb);
+ ret = (this->*(ip->second))(request);
+ }
+ return ret;
+}
+
+/**
+ * push event
+ *
+ * #### Parameters
+ * - event : the event want to push
+ * - param : the parameter contents of event
+ *
+ * #### Return
+ * 0 : success
+ * others : fail
+ *
+ */
+int HS_Client::pushEvent(const char *event, struct json_object *param)
+{
+ if(!checkEvent(event))
+ return 0;
+
+ sleep(1);
+ AFB_INFO("called, event=%s.",event);
+ struct json_object* push_obj = json_object_new_object();
+ hs_add_object_to_json_object_str( push_obj, 4, _application_id, my_id.c_str(), _type, event);
+ if(param != nullptr)
+ json_object_object_add(push_obj, _parameter, param);
+ afb_event_push(my_event, push_obj);
+ return 0;
+}
+
+/**
+ * push updateShortcut event
+ *
+ * #### Parameters
+ * None
+ *
+ * #### Return
+ * Nothing
+ *
+ */
+void HS_Client::pushUpdateShortcutEvent(void)
+{
+ struct json_object* arr_obj = json_object_new_array();
+ for(auto &it : HS_Client::shortcut_list) {
+ struct json_object* obj = json_object_new_object();
+ json_object_object_add(obj, _shortcut_id, json_object_new_string(it.first.c_str()));
+ json_object_object_add(obj, _shortcut_name, json_object_new_string(it.second.c_str()));
+ json_object_array_add(arr_obj, obj);
+ }
+ struct json_object* shortcut_obj = json_object_new_object();
+ json_object_object_add(shortcut_obj, _shortcut, arr_obj);
+ struct json_object* push_obj = json_object_new_object();
+ hs_add_object_to_json_object_str(push_obj, 4, _application_id, my_id.c_str(), _type, "updateShortcut");
+ json_object_object_add(push_obj, _parameter, shortcut_obj);
+ afb_event_push(my_event, push_obj);
+}
\ No newline at end of file