2 * Copyright 2013 Samsung Electronics Co., Ltd
4 * Licensed under the Flora License, Version 1.1 (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://floralicense.org/license/
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.
22 #include <sys/types.h>
34 #include <livebox-service.h>
36 #include "client_life.h"
40 #include "slave_life.h"
41 #include "critical_log.h"
55 static void lcd_state_cb(keynode_t *node, void *user_data)
61 xmonitor_handle_state_changes();
64 HAPI int setting_is_lcd_off(void)
68 if (vconf_get_int(VCONFKEY_PM_STATE, &state) != 0) {
69 ErrPrint("Idle lock state is not valid\n");
70 state = VCONFKEY_PM_STATE_NORMAL; /* UNLOCK */
73 DbgPrint("State: %d, (%d:lcdoff, %d:sleep)\n", state, VCONFKEY_PM_STATE_LCDOFF, VCONFKEY_PM_STATE_SLEEP);
74 return state == VCONFKEY_PM_STATE_LCDOFF || state == VCONFKEY_PM_STATE_SLEEP;
77 static void power_off_cb(keynode_t *node, void *user_data)
80 CRITICAL_LOG("Terminated(vconf)\n");
82 if (vconf_get_int(VCONFKEY_SYSMAN_POWER_OFF_STATUS, &val) != 0) {
83 ErrPrint("Failed to get power off status (%d)\n", val);
87 if (val == VCONFKEY_SYSMAN_POWER_OFF_DIRECT || val == VCONFKEY_SYSMAN_POWER_OFF_RESTART) {
88 DbgPrint("Power off requested: Ignored\n");
90 ErrPrint("Unknown power state: %d\n", val);
94 static void region_changed_cb(keynode_t *node, void *user_data)
99 region = vconf_get_str(VCONFKEY_REGIONFORMAT);
104 setenv("LC_CTYPE", region, 1);
105 setenv("LC_NUMERIC", region, 1);
106 setenv("LC_TIME", region, 1);
107 setenv("LC_COLLATE", region, 1);
108 setenv("LC_MONETARY", region, 1);
109 setenv("LC_PAPER", region, 1);
110 setenv("LC_NAME", region, 1);
111 setenv("LC_ADDRESS", region, 1);
112 setenv("LC_TELEPHONE", region, 1);
113 setenv("LC_MEASUREMENT", region, 1);
114 setenv("LC_IDENTIFICATION", region, 1);
116 r = setlocale(LC_ALL, "");
118 ErrPrint("Failed to change region\n");
124 static void lang_changed_cb(keynode_t *node, void *user_data)
129 lang = vconf_get_str(VCONFKEY_LANGSET);
134 setenv("LANG", lang, 1);
135 setenv("LC_MESSAGES", lang, 1);
137 r = setlocale(LC_ALL, "");
139 ErrPrint("Failed to change locale\n");
142 DbgPrint("Locale: %s\n", setlocale(LC_ALL, NULL));
146 static void ail_info_cb(keynode_t *node, void *user_data)
148 Eina_List *inst_list;
150 struct inst_info *inst;
154 struct pkg_info *info;
161 event = vconf_get_str(VCONFKEY_AIL_INFO_STATE);
166 len = strlen("update:");
167 if (!strncasecmp(event, "update:", len)) {
172 DbgPrint("AppId: [%s]\n", appid);
174 enabled = package_is_enabled(appid);
176 DbgPrint("AppId: %s, %d\n", appid, enabled);
187 pkg_list = (Eina_List *)package_list();
188 EINA_LIST_FOREACH(pkg_list, l, info) {
190 pkgname = livebox_service_mainappid(package_name(info));
193 * Even if we failed to get package name,
194 * Try to use the ordinal package name first.
196 pkgname = strdup(package_name(info));
197 DbgPrint("Try to use the pkgname: %s\n", pkgname);
203 if (strcmp(appid, pkgname)) {
207 DbgPrint("Package disabled: %s (%s)\n", pkgname, appid);
210 inst_list = package_instance_list(info);
211 EINA_LIST_FOREACH_SAFE(inst_list, j, n, inst) {
212 instance_destroy(inst, INSTANCE_DESTROY_DEFAULT);
220 static void low_mem_cb(keynode_t *node, void *user_data)
224 val = vconf_keynode_get_int(node);
226 if (val >= VCONFKEY_SYSMAN_LOW_MEMORY_SOFT_WARNING) {
227 CRITICAL_LOG("Low memory: level %d\n", val);
228 if (s_info.deactivated == 0) {
229 s_info.deactivated = 1;
230 //slave_deactivate_all(0, 1);
232 ErrPrint("Fall into the low mem status\n");
235 CRITICAL_LOG("Normal memory: level %d\n", val);
236 if (s_info.deactivated == 1) {
237 s_info.deactivated = 0;
238 //slave_activate_all();
239 ErrPrint("Recover from the low mem status\n");
244 HAPI int setting_init(void)
248 ret = vconf_notify_key_changed(VCONFKEY_PM_STATE, lcd_state_cb, NULL);
250 ErrPrint("Failed to add vconf for lock state: %d\n", ret);
253 ret = vconf_notify_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, power_off_cb, NULL);
255 ErrPrint("Failed to add vconf for power state: %d \n", ret);
258 ret = vconf_notify_key_changed(VCONFKEY_LANGSET, lang_changed_cb, NULL);
260 ErrPrint("Failed to add vconf for lang change: %d\n", ret);
263 ret = vconf_notify_key_changed(VCONFKEY_REGIONFORMAT, region_changed_cb, NULL);
265 ErrPrint("Failed to add vconf for region change: %d\n", ret);
268 ret = vconf_notify_key_changed(VCONFKEY_AIL_INFO_STATE, ail_info_cb, NULL);
270 ErrPrint("Failed to add vconf for ail info state: %d\n", ret);
273 ret = vconf_notify_key_changed(VCONFKEY_SYSMAN_LOW_MEMORY, low_mem_cb, NULL);
275 ErrPrint("Failed to add vconf for low mem monitor: %d\n", ret);
278 lang_changed_cb(NULL, NULL);
279 region_changed_cb(NULL, NULL);
283 HAPI int setting_fini(void)
287 ret = vconf_ignore_key_changed(VCONFKEY_SYSMAN_LOW_MEMORY, low_mem_cb);
289 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
292 ret = vconf_ignore_key_changed(VCONFKEY_REGIONFORMAT, region_changed_cb);
294 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
297 ret = vconf_ignore_key_changed(VCONFKEY_LANGSET, lang_changed_cb);
299 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
302 ret = vconf_ignore_key_changed(VCONFKEY_PM_STATE, lcd_state_cb);
304 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
307 ret = vconf_ignore_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, power_off_cb);
309 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
312 ret = vconf_ignore_key_changed(VCONFKEY_AIL_INFO_STATE, ail_info_cb);
314 ErrPrint("Failed to ignore vconf key (%d)\n", ret);