2 * Copyright (c) 2019 TOYOTA MOTOR CORPORATION
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
17 #include "hs-apprecover.h"
18 #include "hs-appinfo.h"
20 #include "hs-clientmanager.h"
23 HS_AppRecover* HS_AppRecover::me = nullptr;
26 * screen_update event handler
30 * - event : received event name
31 * - object : received json object
34 * 0 : event can transfer to others
35 * 1 : event not transfer to others
37 int on_screen_update_event(afb_api_t api, const char *event, struct json_object *object)
39 HS_AppRecover::instance()->screenUpdated(object);
50 * HS_AppRecover instance pointer
53 HS_AppRecover* HS_AppRecover::instance(void)
56 me = new HS_AppRecover();
62 * HS_AppRecover initialize function
65 * - api : the api serving the request
72 int HS_AppRecover::init(afb_api_t api)
74 setEventHook("windowmanager/screenUpdated", on_screen_update_event);
76 wm_proxy.subscribe(api, HS_WmProxy::Event_ScreenUpdated);
81 * starting recover applications
85 * - map : recover app map
91 void HS_AppRecover::startRecovery(afb_api_t api)
93 for(auto &key : HS_Config::keys_recover_type) {
94 for(auto &m : recover_app_map[key]){
95 struct app_recover_info recover_info = {
97 .visibility = m.visibility,
100 m_recover_apps_list[m.appid] = std::move(recover_info);
102 // recover application
103 auto it = m_recovering_set.find(m.appid);
104 if(it == m_recovering_set.end()) {
105 m_recovering_set.insert(m.appid);
106 std::string &after = m_recover_apps_list[m.appid].after;
108 auto w = m_wait_recover_set.find(m_recover_apps_list[m.appid].after);
109 if(w != m_wait_recover_set.end()) {
110 m_wait_recover_set[after].insert(m.appid);
113 std::set<std::string> new_set;
114 new_set.insert(m.appid);
115 m_wait_recover_set[after] = std::move(new_set);
117 continue; // don't immediately start application, wait until after applicaiton started.
119 startApplication(api, m.appid);
123 recover_app_map.clear();
127 * register started applications
130 * - appid : application id liked "dashboard"
133 * false : not recover app
137 bool HS_AppRecover::registerRecoveredApp(afb_api_t api, const std::string &appid)
140 if(m_recovering_set.empty()) {
144 AFB_INFO("recover appid=[%s].", appid.c_str());
145 auto it = m_recovering_set.find(appid);
146 if(it != m_recovering_set.end()) {
147 m_recovering_set.erase(appid);
148 auto ip = m_recover_apps_list.find(appid);
149 if(ip != m_recover_apps_list.end()
150 && ip->second.visibility) {
151 HS_ClientManager::instance()->pushEvent("showWindow", nullptr, appid);
156 // check wait recover application
157 auto w = m_wait_recover_set.find(appid);
158 if(w != m_wait_recover_set.end()) {
159 for(auto &ref : m_wait_recover_set[appid]) {
160 startApplication(api, ref);
162 m_wait_recover_set.erase(appid);
168 * screenUpdated event handler
171 * - obj : screenUpdate object
177 void HS_AppRecover::screenUpdated(struct json_object *obj)
179 if(m_lastmode_list.empty()) {
180 AFB_NOTICE("init lastmode is null, so don't record lastmode.");
184 std::set<std::string> s_mode;
185 struct json_object *ids_obj;
186 if(json_object_object_get_ex(obj, key_ids.c_str(), &ids_obj)) {
187 if(json_object_get_type(ids_obj) == json_type_array) {
188 int array_len = json_object_array_length(ids_obj);
189 for (int i = 0; i < array_len; ++i) {
190 struct json_object *j_id = json_object_array_get_idx(ids_obj, i);
191 std::string appid = json_object_get_string(j_id);
192 if(!isHomescreenApp(appid)) {
193 s_mode.insert(appid);
196 if(!s_mode.empty()) {
197 updateLastmode(s_mode);
201 AFB_WARNING("screenUpdated list isn't array.");
211 * - appid : application id liked "dashboard"
217 void HS_AppRecover::startApplication(afb_api_t api, const std::string &appid)
219 HS_AfmMainProxy afm_proxy;
220 afm_proxy.start(api, HS_AppInfo::instance()->getAppProperty(appid, _keyId));
224 * update lastmode file
227 * - set : new lastmode set
233 void HS_AppRecover::updateLastmode(std::set<std::string> &set)
235 if(set.size() == m_lastmode_list.size()) {
238 auto it = m_lastmode_list.find(m);
239 if(it == m_lastmode_list.end()) {
244 if(is_same) { // lastmode aren't changed
249 m_lastmode_list.swap(set);
250 struct json_object *arr_obj = json_object_new_array();
251 for(auto &it : m_lastmode_list) {
252 struct json_object *j_obj = json_object_new_object();
253 json_object_object_add(j_obj, HS_Config::key_appid.c_str(), json_object_new_string(it.c_str()));
254 json_object_object_add(j_obj, HS_Config::key_visibility.c_str(), json_object_new_string("visible"));
255 json_object_array_add(arr_obj, j_obj);
258 auto path = HS_Config::root_dir + "/etc/" + HS_Config::lastmode_json;
259 if(writeJsonFile(path.c_str(), arr_obj) < 0) {
260 AFB_ERROR("write lastmode error.");
265 * judge whether app is Homescreen app
268 * - appid : application id
271 * true : homescreen app
272 * false : not homescreen app
275 bool HS_AppRecover::isHomescreenApp(const std::string &appid) const
277 auto it = m_recover_apps_list.find(appid);
278 if(it != m_recover_apps_list.end()
279 && it->second.recover_type == HS_Config::keys_recover_type[0]) {