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.
21 #include <sys/types.h>
33 #include <livebox-service.h>
35 #include "client_life.h"
39 #include "slave_life.h"
40 #include "critical_log.h"
48 static void lcd_state_cb(keynode_t *node, void *user_data)
53 xmonitor_handle_state_changes();
56 HAPI int setting_is_lcd_off(void)
60 if (vconf_get_int(VCONFKEY_PM_STATE, &state) != 0) {
61 ErrPrint("Idle lock state is not valid\n");
62 state = VCONFKEY_PM_STATE_NORMAL; /* UNLOCK */
65 DbgPrint("State: %d, (%d:lcdoff, %d:sleep)\n", state, VCONFKEY_PM_STATE_LCDOFF, VCONFKEY_PM_STATE_SLEEP);
66 return state == VCONFKEY_PM_STATE_LCDOFF || state == VCONFKEY_PM_STATE_SLEEP;
69 static void power_off_cb(keynode_t *node, void *user_data)
72 CRITICAL_LOG("Terminated(vconf)\n");
74 if (vconf_get_int(VCONFKEY_SYSMAN_POWER_OFF_STATUS, &val) != 0) {
75 ErrPrint("Failed to get power off status (%d)\n", val);
79 if (val == VCONFKEY_SYSMAN_POWER_OFF_DIRECT || val == VCONFKEY_SYSMAN_POWER_OFF_RESTART) {
82 fd = creat("/tmp/.stop.provider", 0644);
83 if (fd < 0 || close(fd) < 0)
84 ErrPrint("stop.provider [%s]\n", strerror(errno));
86 vconf_set_bool(VCONFKEY_MASTER_STARTED, 0);
88 ecore_main_loop_quit();
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);
103 setenv("LC_CTYPE", region, 1);
104 setenv("LC_NUMERIC", region, 1);
105 setenv("LC_TIME", region, 1);
106 setenv("LC_COLLATE", region, 1);
107 setenv("LC_MONETARY", region, 1);
108 setenv("LC_PAPER", region, 1);
109 setenv("LC_NAME", region, 1);
110 setenv("LC_ADDRESS", region, 1);
111 setenv("LC_TELEPHONE", region, 1);
112 setenv("LC_MEASUREMENT", region, 1);
113 setenv("LC_IDENTIFICATION", region, 1);
115 r = setlocale(LC_ALL, "");
117 ErrPrint("Failed to change region\n");
122 static void lang_changed_cb(keynode_t *node, void *user_data)
127 lang = vconf_get_str(VCONFKEY_LANGSET);
131 setenv("LANG", lang, 1);
132 setenv("LC_MESSAGES", lang, 1);
134 r = setlocale(LC_ALL, "");
136 ErrPrint("Failed to change locale\n");
138 DbgPrint("Locale: %s\n", setlocale(LC_ALL, NULL));
142 static void ail_info_cb(keynode_t *node, void *user_data)
144 Eina_List *inst_list;
146 struct inst_info *inst;
150 struct pkg_info *info;
157 event = vconf_get_str(VCONFKEY_AIL_INFO_STATE);
161 len = strlen("update:");
162 if (!strncasecmp(event, "update:", len))
166 DbgPrint("AppId: [%s]\n", appid);
168 enabled = package_is_enabled(appid);
170 DbgPrint("AppId: %s, %d\n", appid, enabled);
181 pkg_list = (Eina_List *)package_list();
182 EINA_LIST_FOREACH(pkg_list, l, info) {
184 pkgname = livebox_service_mainappid(package_name(info));
188 if (strcmp(appid, pkgname)) {
192 DbgPrint("Package disabled: %s (%s)\n", pkgname, appid);
195 inst_list = package_instance_list(info);
196 EINA_LIST_FOREACH_SAFE(inst_list, j, n, inst) {
197 instance_destroy(inst);
205 HAPI int setting_init(void)
209 ret = vconf_notify_key_changed(VCONFKEY_PM_STATE, lcd_state_cb, NULL);
211 ErrPrint("Failed to add vconf for lock state: %d\n", ret);
213 ret = vconf_notify_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, power_off_cb, NULL);
215 ErrPrint("Failed to add vconf for power state: %d \n", ret);
217 ret = vconf_notify_key_changed(VCONFKEY_LANGSET, lang_changed_cb, NULL);
219 ErrPrint("Failed to add vconf for lang change: %d\n", ret);
221 ret = vconf_notify_key_changed(VCONFKEY_REGIONFORMAT, region_changed_cb, NULL);
223 ErrPrint("Failed to add vconf for region change: %d\n", ret);
225 ret = vconf_notify_key_changed(VCONFKEY_AIL_INFO_STATE, ail_info_cb, NULL);
227 ErrPrint("Failed to add vconf for ail info state: %d\n", ret);
229 lang_changed_cb(NULL, NULL);
230 region_changed_cb(NULL, NULL);
234 HAPI int setting_fini(void)
238 ret = vconf_ignore_key_changed(VCONFKEY_REGIONFORMAT, region_changed_cb);
240 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
242 ret = vconf_ignore_key_changed(VCONFKEY_LANGSET, lang_changed_cb);
244 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
246 ret = vconf_ignore_key_changed(VCONFKEY_PM_STATE, lcd_state_cb);
248 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
250 ret = vconf_ignore_key_changed(VCONFKEY_SYSMAN_POWER_OFF_STATUS, power_off_cb);
252 ErrPrint("Failed to ignore vconf key (%d)\n", ret);
254 ret = vconf_ignore_key_changed(VCONFKEY_AIL_INFO_STATE, ail_info_cb);
256 ErrPrint("Failed to ignore vconf key (%d)\n", ret);