don't publish updateShortcut event when subscribe
[apps/agl-service-homescreen.git] / src / hs-client.cpp
index c927442..5da52bb 100644 (file)
@@ -14,9 +14,9 @@
  * limitations under the License.
  */
 
+#include <cstring>
 #include "hs-client.h"
 #include "hs-helper.h"
-#include "hmi-debug.h"
 
 static const char _event[] = "event";
 static const char _type[] = "type";
@@ -26,6 +26,9 @@ static const char _icon[] = "icon";
 static const char _parameter[] = "parameter";
 static const char _replyto[] = "replyto";
 static const char _caller[] = "caller";
+static const char _shortcut[] = "shortcut";
+static const char _shortcut_id[] = "shortcut_id";
+static const char _shortcut_name[] = "shortcut_name";
 
 // homescreen-service event and event handler function list
 const std::unordered_map<std::string, HS_Client::func_handler> HS_Client::func_list {
@@ -39,9 +42,12 @@ const std::unordered_map<std::string, HS_Client::func_handler> HS_Client::func_l
     {"unsubscribe",         &HS_Client::unsubscribe},
     {"showNotification",    &HS_Client::showNotification},
     {"showInformation",     &HS_Client::showInformation},
-    {"application-list-changed", nullptr}
+    {"registerShortcut",    &HS_Client::registerShortcut},
+    {"updateShortcut",      &HS_Client::updateShortcut}
 };
 
+std::list<std::pair<std::string, std::string>> HS_Client::shortcut_list;
+
 /**
  * HS_Client construction function
  *
@@ -54,7 +60,6 @@ const std::unordered_map<std::string, HS_Client::func_handler> HS_Client::func_l
  */
 HS_Client::HS_Client(afb_req_t request, std::string id) : my_id(id)
 {
-    HMI_NOTICE("homescreen-service","called.");
     my_event = afb_api_make_event(request->api, id.c_str());
 }
 
@@ -70,7 +75,6 @@ HS_Client::HS_Client(afb_req_t request, std::string id) : my_id(id)
  */
 HS_Client::~HS_Client()
 {
-    HMI_NOTICE("homescreen-service","called.");
     afb_event_unref(my_event);
 }
 
@@ -87,7 +91,7 @@ HS_Client::~HS_Client()
  */
 int HS_Client::tap_shortcut(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service","request appid = %s.", my_id.c_str());
+    AFB_INFO("request appid = %s.", my_id.c_str());
     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__);
@@ -111,14 +115,14 @@ int HS_Client::on_screen_message(afb_req_t request)
     int ret = 0;
     const char* value = afb_req_value(request, _display_message);
     if (value) {
-        HMI_NOTICE("homescreen-service","push %s event message [%s].", __FUNCTION__, value);
+        AFB_INFO("push %s event message [%s].", __FUNCTION__, value);
         struct json_object* push_obj = json_object_new_object();
         hs_add_object_to_json_object_str( push_obj, 4, _display_message, value,
         _type, __FUNCTION__);
         afb_event_push(my_event, push_obj);
     }
     else {
-        HMI_NOTICE("homescreen-service","Please input display_message");
+        AFB_WARNING("Please input display_message");
         ret = AFB_EVENT_BAD_REQUEST;
     }
     return ret;
@@ -140,14 +144,14 @@ int HS_Client::on_screen_reply(afb_req_t request)
     int ret = 0;
     const char* value = afb_req_value(request, _reply_message);
     if (value) {
-        HMI_NOTICE("homescreen-service","push %s event message [%s].", __FUNCTION__, value);
+        AFB_INFO("push %s event message [%s].", __FUNCTION__, value);
         struct json_object* push_obj = json_object_new_object();
         hs_add_object_to_json_object_str( push_obj, 4, _reply_message, value,
         _type, __FUNCTION__);
         afb_event_push(my_event, push_obj);
     }
     else {
-        HMI_NOTICE("homescreen-service","Please input reply_message");
+        AFB_WARNING("Please input reply_message");
         ret = AFB_EVENT_BAD_REQUEST;
     }
     return ret;
@@ -166,13 +170,12 @@ int HS_Client::on_screen_reply(afb_req_t request)
  */
 int HS_Client::subscribe(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service"," called.");
     int ret = 0;
     const char *value = afb_req_value(request, _event);
     if(value) {
-        HMI_NOTICE("homescreen-service","subscribe event %s", value);
+        AFB_INFO("subscribe event %s", value);
         if(!isSupportEvent(value)) {
-            HMI_NOTICE("homescreen-service","subscibe event isn't existing.");
+            AFB_WARNING("subscibe event isn't existing.");
             ret = AFB_EVENT_BAD_REQUEST;
         }
         else {
@@ -186,7 +189,7 @@ int HS_Client::subscribe(afb_req_t request)
         }
     }
     else {
-        HMI_NOTICE("homescreen-service","Please input event name");
+        AFB_WARNING("Please input event name");
         ret = AFB_EVENT_BAD_REQUEST;
     }
     return ret;
@@ -205,18 +208,17 @@ int HS_Client::subscribe(afb_req_t request)
  */
 int HS_Client::unsubscribe(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service"," called.");
     int ret = 0;
     const char *value = afb_req_value(request, _event);
     if(value) {
-        HMI_NOTICE("homescreen-service","unsubscribe %s event", value);
+        AFB_INFO("unsubscribe %s event", value);
         event_list.erase(std::string(value));
         if(event_list.empty()) {
             ret = afb_req_unsubscribe(request, my_event);
         }
     }
     else {
-        HMI_NOTICE("homescreen-service","Please input event name");
+        AFB_WARNING("Please input event name");
         ret = AFB_EVENT_BAD_REQUEST;
     }
     return ret;
@@ -235,7 +237,7 @@ int HS_Client::unsubscribe(afb_req_t request)
  */
 int HS_Client::showWindow(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service","%s application_id = %s.", __FUNCTION__, my_id.c_str());
+    AFB_INFO("%s application_id = %s.", __FUNCTION__, my_id.c_str());
     int ret = 0;
     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__);
@@ -243,7 +245,7 @@ int HS_Client::showWindow(afb_req_t request)
     if(param) {
         std::string req_appid = std::move(get_application_id(request));
         if(req_appid.empty()) {
-            HMI_NOTICE("homescreen-service","can't get application identifier");
+            AFB_WARNING("can't get application identifier");
             return AFB_REQ_GETAPPLICATIONID_ERROR;
         }
 
@@ -253,7 +255,7 @@ int HS_Client::showWindow(afb_req_t request)
         afb_event_push(my_event, push_obj);
     }
     else {
-        HMI_ERROR("homescreen-service","please input correct parameter.");
+        AFB_WARNING("please input correct parameter.");
         ret = AFB_EVENT_BAD_REQUEST;
     }
     return ret;
@@ -272,10 +274,9 @@ int HS_Client::showWindow(afb_req_t request)
  */
 int HS_Client::hideWindow(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service"," called.");
     std::string req_appid = std::move(get_application_id(request));
     if(req_appid.empty()) {
-        HMI_NOTICE("homescreen-service","can't get application identifier");
+        AFB_WARNING("can't get application identifier");
         return AFB_REQ_GETAPPLICATIONID_ERROR;
     }
 
@@ -302,7 +303,7 @@ int HS_Client::hideWindow(afb_req_t request)
  */
 int HS_Client::replyShowWindow(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service","%s application_id = %s.", __FUNCTION__, my_id.c_str());
+    AFB_INFO("%s application_id = %s.", __FUNCTION__, my_id.c_str());
     int ret = 0;
     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__);
@@ -312,7 +313,7 @@ int HS_Client::replyShowWindow(afb_req_t request)
         afb_event_push(my_event, push_obj);
     }
     else {
-        HMI_ERROR("homescreen-service","please input correct parameter.");
+        AFB_WARNING("please input correct parameter.");
         ret = AFB_EVENT_BAD_REQUEST;
     }
     return ret;
@@ -331,14 +332,13 @@ int HS_Client::replyShowWindow(afb_req_t request)
  */
 int HS_Client::showNotification(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service"," called.");
     int ret = 0;
     const char *value = afb_req_value(request, _text);
     if(value) {
-        HMI_NOTICE("homescreen-service","text is %s", value);
+        AFB_INFO("text is %s", value);
         std::string appid =std::move(get_application_id(request));
         if(appid.empty()) {
-            HMI_NOTICE("homescreen-service","can't get application identifier");
+            AFB_WARNING("can't get application identifier");
             return AFB_REQ_GETAPPLICATIONID_ERROR;
         }
 
@@ -354,12 +354,12 @@ int HS_Client::showNotification(afb_req_t request)
             afb_event_push(my_event, push_obj);
         }
         else {
-            HMI_NOTICE("homescreen-service","please input icon.");
+            AFB_WARNING("please input icon.");
             ret = AFB_REQ_SHOWNOTIFICATION_ERROR;
         }
     }
     else {
-        HMI_NOTICE("homescreen-service","please input text.");
+        AFB_WARNING("please input text.");
         ret = AFB_REQ_SHOWNOTIFICATION_ERROR;
     }
 
@@ -379,14 +379,13 @@ int HS_Client::showNotification(afb_req_t request)
  */
 int HS_Client::showInformation(afb_req_t request)
 {
-    HMI_NOTICE("homescreen-service"," called.");
     int ret = 0;
     const char *value = afb_req_value(request, _info);
     if(value) {
-        HMI_NOTICE("homescreen-service","info is %s", value);
+        AFB_INFO("info is %s", value);
         std::string appid = std::move(get_application_id(request));
         if(appid.empty()) {
-            HMI_NOTICE("homescreen-service","can't get application identifier");
+            AFB_WARNING("can't get application identifier");
             return AFB_REQ_GETAPPLICATIONID_ERROR;
         }
 
@@ -398,13 +397,95 @@ int HS_Client::showInformation(afb_req_t request)
         afb_event_push(my_event, push_obj);
     }
     else {
-        HMI_NOTICE("homescreen-service","please input information.");
+        AFB_WARNING("please input information.");
         ret = AFB_REQ_SHOWINFORMATION_ERROR;
     }
 
     return ret;
 }
 
+/**
+ * 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, &param_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, &param_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
  *
@@ -438,11 +519,8 @@ bool HS_Client::checkEvent(const char* event)
  */
 bool HS_Client::isSupportEvent(const char* event)
 {
-    auto ip = func_list.find(std::string(event));
-    if(ip == func_list.end())
-        return false;
-    else
-        return true;
+    int ret = hs_search_event_name_index(event);
+    return ret == -1 ? false : true;
 }
 
 /**
@@ -459,14 +537,13 @@ bool HS_Client::isSupportEvent(const char* event)
  */
 int HS_Client::handleRequest(afb_req_t request, const char *verb)
 {
-    HMI_NOTICE("homescreen-service","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) {
-        HMI_NOTICE("homescreen-service","[%s]verb found", verb);
+        AFB_INFO("[%s]verb found", verb);
         ret = (this->*(ip->second))(request);
     }
     return ret;
@@ -489,11 +566,38 @@ int HS_Client::pushEvent(const char *event, struct json_object *param)
     if(!checkEvent(event))
         return 0;
 
-    HMI_NOTICE("homescreen-service","called, event=%s.",event);
+    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;
-}
\ No newline at end of file
+}
+
+/**
+ * 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