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.
18 #include "hs-config.h"
20 const std::array<std::string, 3> HS_Config::keys_recover_type = { // based on hs-conf.json
27 * read configuration file to memory
36 int HS_Config::readConfig(void)
38 auto rootdir = std::string(getenv("AFM_APP_INSTALL_DIR"));
39 auto path = rootdir + "/etc/" + hs_conf_json;
40 if(readJsonFile(path.c_str(), &m_hs_conf) < 0) {
41 AFB_ERROR("read %s failed.", hs_conf_json.c_str());
45 path = rootdir + "/etc/" + lastmode_json;
46 if(readJsonFile(path.c_str(), &m_lastmode) < 0) {
47 AFB_ERROR("read %s failed.", lastmode_json.c_str());
55 * parse configuration file contents
65 int HS_Config::parseConfig(void)
67 struct json_object *handshake_obj, *times_obj, *sleep_obj;
68 if(json_object_object_get_ex(m_hs_conf, key_handshake.c_str(), &handshake_obj)
69 && json_object_object_get_ex(handshake_obj, key_times.c_str(), ×_obj)
70 && json_object_object_get_ex(handshake_obj, key_sleep.c_str(), &sleep_obj)) {
71 m_handshake_info.times = json_object_get_int(times_obj);
72 m_handshake_info.sleep = json_object_get_int(sleep_obj);
75 AFB_WARNING("get handshake info error, use default value.");
78 struct json_object *recover_obj;
79 if(json_object_object_get_ex(m_hs_conf, key_recover.c_str(), &recover_obj)) {
80 for(auto &m : keys_recover_type) {
81 struct json_object *obj;
82 if(json_object_object_get_ex(recover_obj, m.c_str(), &obj)) {
83 if(json_object_get_type(obj) != json_type_array ) {
86 m_recover_map[m] = std::move(getRecoverAppInfo(obj));
90 if(m_recover_map.empty()) {
91 AFB_ERROR("get homescreen recover list failed.");
96 AFB_ERROR("get homescreen recover object failed.");
100 if(json_object_get_type(m_lastmode) == json_type_array ) {
101 struct std::vector<recover_app_info> v_lastmode = std::move(getRecoverAppInfo(m_lastmode));
102 if(!v_lastmode.empty()) { // got saving lastmode isn't null, instead of default lastmode
103 m_recover_map[keys_recover_type[1]] = std::move(v_lastmode);
111 * get recover application information
115 * - obj : application information
118 * recover_app_info vector
121 std::vector<struct recover_app_info> HS_Config::getRecoverAppInfo(struct json_object *obj)
123 int array_len = json_object_array_length(obj);
124 std::vector<struct recover_app_info> v_app_info;
125 for (int i = 0; i < array_len; ++i) {
126 struct json_object *info_obj = json_object_array_get_idx(obj, i);
127 struct recover_app_info info;
128 struct json_object *value_obj;
129 if(json_object_object_get_ex(info_obj, key_appid.c_str(), &value_obj)) {
130 info.appid = json_object_get_string(value_obj);
133 AFB_ERROR("recover infomation doesn't include appid.");
137 if(json_object_object_get_ex(info_obj, key_visibility.c_str(), &value_obj)) {
138 std::string visibility = json_object_get_string(value_obj);
139 info.visibility = (visibility == "visible") ? true:false;
142 info.visibility = false;
144 v_app_info.push_back(info);