fix bug
[apps/agl-service-homescreen.git] / src / hs-clientmanager.cpp
index 8735c2e..832c64f 100644 (file)
  * See the License for the specific language governing permissions and
  * limitations under the License.
  */
+
+#include <cstring>
 #include <algorithm>
 #include "hs-clientmanager.h"
-#include "hmi-debug.h"
+#include "hs-apprecover.h"
 
 static const char _homescreen[] = "homescreen";
 
@@ -70,7 +72,7 @@ HS_ClientManager* HS_ClientManager::instance(void)
  */
 int HS_ClientManager::init(void)
 {
-    HMI_NOTICE("homescreen-service","called.");
+    AFB_NOTICE("called.");
 }
 
 /**
@@ -88,7 +90,7 @@ HS_ClientCtxt* HS_ClientManager::createClientCtxt(afb_req_t req, std::string app
     HS_ClientCtxt *ctxt = (HS_ClientCtxt *)afb_req_context_get(req);
     if (!ctxt)
     {
-        HMI_NOTICE("homescreen-service", "create new session for %s", appid.c_str());
+        AFB_INFO( "create new session for %s", appid.c_str());
         HS_ClientCtxt *ctxt = new HS_ClientCtxt(appid.c_str());
         afb_req_session_set_LOA(req, 1);
         afb_req_context_set(req, ctxt, cbRemoveClientCtxt);
@@ -142,11 +144,11 @@ void HS_ClientManager::removeClientCtxt(void *data)
     HS_ClientCtxt *ctxt = (HS_ClientCtxt *)data;
     if(ctxt == nullptr)
     {
-        HMI_ERROR("homescreen-service", "data is nullptr");
+        AFB_WARNING( "data is nullptr");
         return;
     }
 
-    HMI_NOTICE("homescreen-service", "remove app %s", ctxt->id.c_str());
+    AFB_INFO( "remove app %s", ctxt->id.c_str());
     std::lock_guard<std::mutex> lock(this->mtx);
     removeClient(ctxt->id);
     delete appid2ctxt[ctxt->id];
@@ -168,15 +170,17 @@ void HS_ClientManager::removeClientCtxt(void *data)
  */
 int HS_ClientManager::handleRequest(afb_req_t request, const char *verb, const char *appid)
 {
-    HMI_NOTICE("homescreen-service","verb=[%s],appid=[%s].", verb, appid);
+    AFB_INFO("verb=[%s],appid=[%s].", verb, appid);
     int ret = 0;
-    std::lock_guard<std::mutex> lock(this->mtx);
+    bool isRegisterApp = false;
     if(appid == nullptr) {
+        std::lock_guard<std::mutex> lock(this->mtx);
         for(auto m : client_list) {
             m.second->handleRequest(request, verb);
         }
     }
     else {
+        std::lock_guard<std::mutex> lock(this->mtx);
         auto ip = client_list.find(std::string(appid));
         if(ip != client_list.end()) {
             ret = ip->second->handleRequest(request, verb);
@@ -186,13 +190,17 @@ int HS_ClientManager::handleRequest(afb_req_t request, const char *verb, const c
                 appid2ctxt[appid] = createClientCtxt(request, appid);
                 HS_Client* client = addClient(request, appid);
                 ret = client->handleRequest(request, "subscribe");
+                isRegisterApp = true;
             }
             else {
-                HMI_NOTICE("homescreen-service","not exist session");
+                AFB_NOTICE("not exist session");
                 ret = AFB_REQ_NOT_STARTED_APPLICATION;
             }
         }
     }
+    if(isRegisterApp) {
+        checkRegisterApp(std::string(appid));
+    }
     return ret;
 }
 
@@ -211,8 +219,9 @@ int HS_ClientManager::handleRequest(afb_req_t request, const char *verb, const c
  */
 int HS_ClientManager::pushEvent(const char *event, struct json_object *param, std::string appid)
 {
+    AFB_INFO("event=[%s], appid=[%s].", event, appid.c_str());
     if(event == nullptr) {
-        HMI_ERROR("homescreen-service","event name is null.");
+        AFB_WARNING("event name is null.");
         return -1;
     }
 
@@ -230,4 +239,28 @@ int HS_ClientManager::pushEvent(const char *event, struct json_object *param, st
     }
 
     return 0;
+}
+
+/**
+ * check register application
+ *
+ * #### Parameters
+ *  - appid : register application's id
+ *
+ * #### Return
+ * None
+ *
+ */
+void HS_ClientManager::checkRegisterApp(const std::string &appid)
+{
+    AFB_INFO("appid=[%s].", appid.c_str());
+    if(HS_AppRecover::instance()->registerRecoveredApp(appid)) {
+        AFB_NOTICE("register recover application.");
+        return;
+    }
+
+    if(startup_appid == appid) {
+        startup_appid.clear();
+        pushEvent("showWindow", nullptr, appid);
+    }
 }
\ No newline at end of file