2 * Copyright (c) 2000 - 2015 Samsung Electronics Co., Ltd. All rights reserved.
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 <Elementary.h>
20 #include <sys/types.h>
26 #include <Ecore_Wl2.h>
29 #include <systemd/sd-daemon.h>
30 #include <ode/internal-encryption.h>
40 #include "process_mgr.h"
44 #include "dbus_util.h"
46 static void _set_starter_sequence(int val)
48 vconf_set_int(VCONFKEY_STARTER_SEQUENCE, val);
53 static void _signal_handler(int signum, siginfo_t *info, void *unused)
55 _D("_signal_handler : Terminated...");
61 static int _power_off_cb(status_active_key_e key, void *data)
63 int val = status_active_get()->sysman_power_off_status;
65 if (val == VCONFKEY_SYSMAN_POWER_OFF_DIRECT
66 || val == VCONFKEY_SYSMAN_POWER_OFF_RESTART) {
67 _D("_power_off_cb : Terminated...");
76 static void _language_changed_cb(keynode_t *node, void *data)
82 lang = vconf_keynode_get_str(node);
85 _D("language is changed : %s", lang);
87 elm_language_set(lang);
92 static int _set_i18n(const char *domain, const char *dir)
101 char *lang = vconf_get_str(VCONFKEY_LANGSET);
102 r = setlocale(LC_ALL, lang);
104 _E("setlocale() error");
110 r = bindtextdomain(domain, dir);
112 _E("bindtextdomain() error");
115 r = textdomain(domain);
117 _E("textdomain() error");
120 if (vconf_notify_key_changed(VCONFKEY_LANGSET, _language_changed_cb, NULL) < 0) {
121 _E("Failed to register changed cb : %s", VCONFKEY_LANGSET);
129 static int _check_dead_signal(int pid, void *data)
133 int indicator_pid = 0;
134 int quickpanel_pid = 0;
137 _D("Process %d is termianted", pid);
145 * starter try to re-launch these apps when the app is dead.
147 home_pid = home_mgr_get_home_pid();
148 volume_pid = home_mgr_get_volume_pid();
149 indicator_pid = home_mgr_get_indicator_pid();
150 quickpanel_pid = home_mgr_get_quickpanel_pid();
151 lock_pid = lock_mgr_get_lock_pid();
153 if (pid == home_pid) {
154 _D("Homescreen is dead");
155 home_mgr_relaunch_homescreen();
156 } else if (pid == volume_pid) {
157 _D("volume is dead");
158 home_mgr_relaunch_volume();
159 } else if (pid == indicator_pid) {
160 _D("indicator is dead");
161 home_mgr_relaunch_indicator();
162 } else if (pid == quickpanel_pid) {
163 _D("quickpanel is dead");
164 home_mgr_relaunch_quickpanel();
165 } else if (pid == lock_pid) {
166 _D("lockscreen is dead");
169 _D("Unknown process, ignore it");
177 static void _launch_apps(void)
179 /* Tells the service manager that service startup is finished */
180 sd_notify(0, "READY=1");
183 * After user data partition mount,
184 * launch lockscreen, homescreen, etc.
190 * Set the starter sequence vconfkey.
191 * '1' menas that booting seqeunce is done.
193 _set_starter_sequence(1);
198 static void _init(void)
200 struct sigaction act;
201 char err_buf[128] = { 0, };
204 memset(&act, 0x00, sizeof(struct sigaction));
205 act.sa_sigaction = _signal_handler;
206 act.sa_flags = SA_SIGINFO;
208 ret = sigemptyset(&act.sa_mask);
210 if (strerror_r(errno, err_buf, sizeof(err_buf)) == 0) {
211 _E("Failed to sigemptyset[%d / %s]", errno, err_buf);
214 ret = sigaddset(&act.sa_mask, SIGTERM);
216 if (strerror_r(errno, err_buf, sizeof(err_buf)) == 0) {
217 _E("Failed to sigaddset[%d / %s]", errno, err_buf);
220 ret = sigaction(SIGTERM, &act, NULL);
222 if (strerror_r(errno, err_buf, sizeof(err_buf)) == 0) {
223 _E("Failed to sigaction[%d / %s]", errno, err_buf);
227 _set_i18n(PACKAGE, LOCALEDIR);
230 status_active_register_cb(STATUS_ACTIVE_KEY_SYSMAN_POWER_OFF_STATUS, _power_off_cb, NULL);
234 hw_key_create_window();
237 * Initialize starter sequence vconfkey.
239 _set_starter_sequence(0);
241 ret = starter_execute_ode_process(BEFORE_LOCKSCREEN);
243 _E("Failed to execute ode process");
246 aul_listen_app_dead_signal(_check_dead_signal, NULL);
251 static void _fini(void)
256 hw_key_destroy_window();
260 status_active_unregister_cb(STATUS_ACTIVE_KEY_SYSMAN_POWER_OFF_STATUS, _power_off_cb);
263 if (vconf_ignore_key_changed(VCONFKEY_LANGSET, _language_changed_cb) < 0) {
264 _E("Failed to unregister changed cb : %s", VCONFKEY_LANGSET);
270 int main(int argc, char *argv[])
273 Ecore_Wl2_Display *display = NULL;
275 _D("starter is launched..!!");
277 ret = elm_init(argc, argv);
279 _E("elm_init() failed : %d", ret);
283 ret = ecore_wl2_init();
285 _E("ecore_wl2_init() failed : %d", ret);
290 display = ecore_wl2_display_get(NULL);
292 _W("There's no display");
293 display = ecore_wl2_display_connect(NULL);
295 _E("Failed to connect display");
308 ecore_wl2_display_disconnect(display);
309 ecore_wl2_shutdown();
319 static void _mount_complete_cb(void *user_data)
321 _D("Mount is successfully completed");
326 int starter_execute_ode_process(int booting_state)
328 _D("This call is before or after Lockscreen: %d", booting_state);
329 int ret = ODE_ERROR_NONE;
332 ret = ode_internal_encryption_get_state(&ode_state);
333 if (ret != ODE_ERROR_NONE) {
334 _E("Failed to get ODE state, ret: %d", ret);
338 if (booting_state == BEFORE_LOCKSCREEN) {
339 if (ode_state == ODE_STATE_ENCRYPTED) {
342 ret = ode_internal_encryption_set_mount_event_cb(_mount_complete_cb, NULL);
343 if (ret != ODE_ERROR_NONE) {
344 _E("Failed to set mount event cb");
349 } else if (booting_state == AFTER_LOCKSCREEN) {
350 if (ode_state == ODE_STATE_ENCRYPTED) {
351 _D("ODE state is: %d, and we should mount at this time", ode_state);
353 ret = ode_internal_encryption_mount();
354 if (ret != ODE_ERROR_NONE) {
355 _E("Failed to mount");
359 sd_notify(0, "READY=1");
362 vconf_set_int(VCONFKEY_STARTER_SEQUENCE, 1);
364 _D("ODE state is: %d, Do nothing");