* 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";
+const std::string _listen_all("all");
HS_ClientManager* HS_ClientManager::me = nullptr;
*/
int HS_ClientManager::init(void)
{
- HMI_NOTICE("homescreen-service","called.");
+ listener_list.clear();
+ std::list<listener_interface*> interface_list;
+ listener_list[_listen_all] = std::move(interface_list);
}
/**
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);
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];
*/
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);
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) {
+ notifyListener(request->api, std::string(appid));
+ }
return ret;
}
*/
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;
}
}
return 0;
+}
+
+/**
+ * check register application
+ *
+ * #### Parameters
+ * - api : the api
+ * - appid : register application's id
+ *
+ * #### Return
+ * true : checked
+ * false : not checked
+ *
+ */
+bool HS_ClientManager::checkRegisterApp(afb_api_t api, const std::string &appid)
+{
+ bool ret = true;
+ auto &ip = listener_list[_listen_all];
+ if(!ip.empty()) {
+ for(auto &it : ip) {
+ it->notify(api, appid);
+ }
+ }
+ else if(startup_appid == appid) {
+ startup_appid.clear();
+ pushEvent("showWindow", nullptr, appid);
+ }
+ else {
+ ret = false;
+ }
+ return ret;
+}
+
+/**
+ * check whether application was started
+ *
+ * #### Parameters
+ * - appid : application's id
+ *
+ * #### Return
+ * true : started
+ * false : not start
+ *
+ */
+bool HS_ClientManager::isAppStarted(const std::string &appid)
+{
+ auto it = client_list.find(appid);
+ return it != client_list.end() ? true : false;
+}
+
+/**
+ * add app register listener
+ *
+ * #### Parameters
+ * - listener_interface : listener interface
+ *
+ * #### Return
+ * None
+ *
+ */
+void HS_ClientManager::addListener(listener_interface* listener)
+{
+ for (auto &it : listener->listenAppSet()) {
+ auto ip = listener_list.find(it);
+ if(ip != listener_list.end()) {
+ ip->second.push_back(listener);
+ }
+ else {
+ std::list<listener_interface*> lst;
+ lst.push_back(listener);
+ listener_list[it] = std::move(lst);
+ }
+ }
+}
+
+/**
+ * remove app register listener
+ *
+ * #### Parameters
+ * - listener_interface : listener interface
+ *
+ * #### Return
+ * None
+ *
+ */
+void HS_ClientManager::removeListener(listener_interface* listener)
+{
+ for (auto &iter : listener->listenAppSet()) {
+ auto it = listener_list.find(iter);
+ if(it != listener_list.end()) {
+ auto ip = it->second.begin();
+ for(; ip != it->second.end(); ++ip) {
+ if(listener->myUid() == (*ip)->myUid()) {
+ break;
+ }
+ }
+ it->second.erase(ip);
+ if(it->second.empty()) {
+ listener_list.erase(it->first);
+ }
+ }
+ }
+}
+
+/**
+ * notify listener
+ *
+ * #### Parameters
+ * - api : the api
+ * - appid : register application's id
+ *
+ * #### Return
+ * None
+ *
+ */
+void HS_ClientManager::notifyListener(afb_api_t api, const std::string &appid)
+{
+ if (checkRegisterApp(api, appid)) {
+ return;
+ }
+
+ AFB_INFO("listen %s, notified", appid.c_str());
+ std::list<listener_interface*> interface_list;
+ auto ip = listener_list.find(appid);
+ if(ip != listener_list.end()) {
+ if(!ip->second.empty()) {
+ interface_list = ip->second;
+ }
+ else {
+ AFB_WARNING("listener is null.");
+ return;
+ }
+ }
+
+ for(auto &it : interface_list) {
+ it->notify(api, appid);
+ }
+
}
\ No newline at end of file