4 * Copyright 2012 Samsung Electronics Co., Ltd
6 * Licensed under the Flora License, Version 1.1 (the "License");
7 * you may not use this file except in compliance with the License.
8 * You may obtain a copy of the License at
10 * http://www.tizenopensource.org/license
12 * Unless required by applicable law or agreed to in writing, software
13 * distributed under the License is distributed on an "AS IS" BASIS,
14 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15 * See the License for the specific language governing permissions and
16 * limitations under the License.
22 #include <ui-gadget-module.h>
23 #include <bundle_internal.h>
24 #include <efl_extension.h>
25 #include <libxml/xmlmemory.h>
26 #include <libxml/parser.h>
27 #include <libxml/tree.h>
31 #include "common_utils.h"
32 #include "i18nmanager.h"
34 #define SUPPLICANT_SERVICE "fi.w1.wpa_supplicant1"
35 #define SUPPLICANT_SERVICE_INTERFACE SUPPLICANT_SERVICE ".Interface"
36 #define COLOR_TABLE "/usr/apps/wifi-efl-ug/shared/res/tables/ug-wifi-efl_ChangeableColorTable.xml"
37 #define FONT_TABLE "/usr/apps/wifi-efl-ug/shared/res/tables/ug-wifi-efl_FontInfoTable.xml"
39 #define MODEL_CONFIG_FILE "/etc/config/model-config.xml"
40 #define TYPE_FIELD "string"
41 #define FEATURE_TAG "platform"
42 #define MODEL_CONFIG_TAG "model-config"
45 TIZEN_MODEL_UNKNOWN = 0,
46 TIZEN_MODEL_EMULATOR = 0x1,
47 TIZEN_MODEL_NOT_EMULATOR = 0x2,
50 static tizen_model_t emulator = TIZEN_MODEL_UNKNOWN;
55 } two_line_disp_data_t;
57 struct managed_idle_data {
63 struct gdbus_connection_data {
64 GDBusConnection *connection;
65 guint subscribe_id_supplicant;
68 static struct gdbus_connection_data gdbus_conn = { NULL, 0 };
69 static GSList *managed_idler_list = NULL;
70 static int (*rotate_cb)(enum appcore_rm, void*, Eina_Bool, Eina_Bool) = NULL;
71 static void *rotate_cb_data = NULL;
72 static Eina_Bool is_wps = EINA_FALSE;
73 static Eina_Bool is_setting = EINA_FALSE;
74 static Eina_Bool is_portrait_mode = EINA_TRUE;
75 static Ecore_Timer *scan_update_timer = NULL;
77 static char *__common_utils_2line_text_get(void *data, Evas_Object *obj, const char *part)
79 two_line_disp_data_t *item_data = (two_line_disp_data_t *)data;
80 if (!strcmp("elm.text", part))
81 return g_strdup(item_data->title_str);
82 else if (!strcmp("elm.text.sub", part))
83 return g_strdup(item_data->info_str);
88 static void __common_utils_2line_text_del(void *data, Evas_Object *obj)
90 two_line_disp_data_t *item_data = (two_line_disp_data_t *)data;
92 g_free(item_data->info_str);
93 g_free(item_data->title_str);
98 static void __common_utils_separator_del(void *data, Evas_Object *obj)
100 elm_genlist_item_class_free(data);
104 Eina_Bool common_utils_is_portrait_mode(void)
106 return is_portrait_mode;
109 static void __common_utils_set_portrait_mode(Eina_Bool on)
111 is_portrait_mode = on;
114 void common_utils_set_rotate_cb(int (*func)(enum appcore_rm, void*, Eina_Bool, Eina_Bool),
115 void *data, Eina_Bool wps_value, Eina_Bool setting_value)
118 rotate_cb_data = data;
120 is_setting = setting_value;
123 static void __common_utils_rotate_popup(enum appcore_rm rotmode)
126 rotate_cb(rotmode, rotate_cb_data, is_wps, is_setting);
129 void common_utils_contents_rotation_adjust(int event)
131 if (event == UG_EVENT_ROTATE_PORTRAIT ||
132 event == UG_EVENT_ROTATE_PORTRAIT_UPSIDEDOWN) {
133 __common_utils_rotate_popup(APPCORE_RM_PORTRAIT_NORMAL);
134 __common_utils_set_portrait_mode(EINA_TRUE);
136 __common_utils_rotate_popup(APPCORE_RM_LANDSCAPE_NORMAL);
137 __common_utils_set_portrait_mode(EINA_FALSE);
141 Elm_Object_Item* common_utils_add_dialogue_separator(Evas_Object* genlist, const char *separator_style)
143 assertm_if(NULL == genlist, "NULL!!");
145 static Elm_Genlist_Item_Class *separator_itc;
146 separator_itc = elm_genlist_item_class_new();
147 separator_itc->item_style = separator_style;
148 separator_itc->func.text_get = NULL;
149 separator_itc->func.content_get = NULL;
150 separator_itc->func.state_get = NULL;
151 separator_itc->func.del = __common_utils_separator_del;
153 Elm_Object_Item* sep = elm_genlist_item_append(
158 ELM_GENLIST_ITEM_GROUP,
162 assertm_if(NULL == sep, "NULL!!");
164 elm_genlist_item_select_mode_set(sep, ELM_OBJECT_SELECT_MODE_DISPLAY_ONLY);
169 char *common_utils_get_ap_security_type_info_txt(const char *pkg_name,
170 wifi_device_info_t *device_info, bool check_fav)
172 bool favorite = false;
174 char *status_txt = NULL;
176 /* TODO: temporary disabled */
178 wifi_manager_connection_state_e state;
179 wifi_connection_error_e error;
181 wifi_manager_ap_get_connection_state(device_info->ap, &state);
182 if (state == WIFI_MANAGER_CONNECTION_STATE_FAILURE) {
183 error = wlan_manager_get_connection_error_state(device_info->ap);
185 if (error == WIFI_MANAGER_CONNECTION_ERROR_INVALID_KEY)
186 return g_strdup(sc(pkg_name,
187 I18N_TYPE_WIFI_AUTHENTICATION_ERROR_OCCURRED));
189 if (error == WIFI_MANAGER_CONNECTION_ERROR_DHCP_FAILED)
190 return g_strdup(sc(pkg_name,
191 I18N_TYPE_WIFI_FAILED_TO_OBTAIN_IP_ADDRESS));
195 switch (device_info->security_mode) {
196 case WLAN_SEC_MODE_NONE: /** Security disabled */
197 status_txt = g_strdup(sc(pkg_name, I18N_TYPE_Open));
199 case WLAN_SEC_MODE_IEEE8021X: /** EAP */
200 status_txt = g_strdup_printf("%s (%s)", sc(pkg_name, I18N_TYPE_Secured),
201 sc(pkg_name, I18N_TYPE_EAP));
203 case WLAN_SEC_MODE_WEP: /** WEP */
204 case WLAN_SEC_MODE_WPA_PSK: /** WPA-PSK */
205 case WLAN_SEC_MODE_WPA2_PSK: /** WPA2-PSK */
206 if (TRUE == device_info->wps_mode) {
207 status_txt = g_strdup_printf("%s (%s)", sc(pkg_name,
208 I18N_TYPE_Secured), sc(pkg_name, I18N_TYPE_WPS_Available));
210 status_txt = g_strdup(sc(pkg_name, I18N_TYPE_Secured));
213 default: /** Unknown */
214 status_txt = g_strdup(sc(pkg_name, I18N_TYPE_Unknown));
218 if (true == check_fav) {
219 wifi_manager_ap_is_favorite(device_info->ap, &favorite);
220 if (true == favorite) {
222 status_txt = g_strdup_printf("%s, %s",
223 sc(pkg_name, I18N_TYPE_Saved), temp);
231 void common_utils_get_device_icon(wifi_device_info_t *device_info, char **icon_path)
233 char buf[MAX_DEVICE_ICON_PATH_STR_LEN] = {'\0', };
235 g_strlcat(buf, "A01-3_icon", sizeof(buf));
237 if (device_info->security_mode != WLAN_SEC_MODE_NONE)
238 g_strlcat(buf, "_lock", sizeof(buf));
240 switch (wlan_manager_get_signal_strength(device_info->rssi)) {
241 case SIGNAL_STRENGTH_TYPE_EXCELLENT:
242 g_strlcat(buf, "_03", sizeof(buf));
244 case SIGNAL_STRENGTH_TYPE_GOOD:
245 g_strlcat(buf, "_02", sizeof(buf));
247 case SIGNAL_STRENGTH_TYPE_WEAK:
248 g_strlcat(buf, "_01", sizeof(buf));
250 case SIGNAL_STRENGTH_TYPE_VERY_WEAK:
251 case SIGNAL_STRENGTH_TYPE_NULL:
253 g_strlcat(buf, "_00", sizeof(buf));
258 *icon_path = g_strdup_printf("%s", buf);
261 char *common_utils_get_rssi_text(const char *str_pkg_name, int rssi)
263 switch (wlan_manager_get_signal_strength(rssi)) {
264 case SIGNAL_STRENGTH_TYPE_EXCELLENT:
265 return g_strdup(sc(str_pkg_name, I18N_TYPE_Excellent));
266 case SIGNAL_STRENGTH_TYPE_GOOD:
267 return g_strdup(sc(str_pkg_name, I18N_TYPE_Good));
269 return g_strdup(sc(str_pkg_name, I18N_TYPE_Weak));
273 void common_utils_set_edit_box_imf_panel_evnt_cb(Elm_Object_Item *item,
274 imf_ctxt_panel_cb_t input_panel_cb, void *user_data)
276 __COMMON_FUNC_ENTER__;
277 common_utils_entry_info_t *entry_info;
278 entry_info = elm_object_item_data_get(item);
282 entry_info->input_panel_cb = input_panel_cb;
283 entry_info->input_panel_cb_data = user_data;
285 Evas_Object *entry = elm_object_item_part_content_get(item, "elm.icon.entry");
286 Ecore_IMF_Context *imf_ctxt = elm_entry_imf_context_get(entry);
287 if (imf_ctxt && entry_info->input_panel_cb) {
288 /* Deleting the previously attached callback */
289 ecore_imf_context_input_panel_event_callback_del(imf_ctxt,
290 ECORE_IMF_INPUT_PANEL_STATE_EVENT,
291 entry_info->input_panel_cb);
292 ecore_imf_context_input_panel_event_callback_add(imf_ctxt,
293 ECORE_IMF_INPUT_PANEL_STATE_EVENT,
294 entry_info->input_panel_cb,
295 entry_info->input_panel_cb_data);
296 DEBUG_LOG(UG_NAME_NORMAL, "set the imf ctxt cbs");
299 __COMMON_FUNC_EXIT__;
303 void common_utils_edit_box_focus_set(Elm_Object_Item *item, Eina_Bool focus_set)
305 __COMMON_FUNC_ENTER__;
309 Evas_Object *entry = elm_object_item_part_content_get(item, "elm.icon.entry");
312 elm_object_focus_set(entry, focus_set);
313 elm_object_focus_allow_set(entry, focus_set);
316 __COMMON_FUNC_EXIT__;
320 void common_utils_edit_box_allow_focus_set(Elm_Object_Item *item,
323 __COMMON_FUNC_ENTER__;
327 Evas_Object *entry = elm_object_item_part_content_get(item, "elm.icon.entry");
328 elm_object_focus_allow_set(entry, focus_set);
330 __COMMON_FUNC_EXIT__;
334 Elm_Object_Item *common_utils_add_2_line_txt_disabled_item(
335 Evas_Object* view_list, const char *style_name,
336 const char *line1_txt, const char *line2_txt)
338 static Elm_Genlist_Item_Class two_line_display_itc;
339 two_line_disp_data_t *two_line_data = NULL;
340 Elm_Object_Item *item = NULL;
342 two_line_display_itc.item_style = style_name;
343 two_line_display_itc.func.text_get = __common_utils_2line_text_get;
344 two_line_display_itc.func.content_get = NULL;
345 two_line_display_itc.func.state_get = NULL;
346 two_line_display_itc.func.del = __common_utils_2line_text_del;
348 two_line_data = g_new0(two_line_disp_data_t, 1);
349 two_line_data->title_str = g_strdup(line1_txt);
350 two_line_data->info_str = g_strdup(line2_txt);
351 SECURE_INFO_LOG(UG_NAME_NORMAL, "title_str = %s info_str = %s",
352 two_line_data->title_str, two_line_data->info_str);
354 item = elm_genlist_item_append(view_list, &two_line_display_itc,
355 two_line_data, NULL, ELM_GENLIST_ITEM_NONE, NULL, NULL);
356 elm_object_item_disabled_set(item, TRUE);
361 char *common_utils_get_list_item_entry_txt(Elm_Object_Item *entry_item)
363 common_utils_entry_info_t *entry_info =
364 (common_utils_entry_info_t *)elm_object_item_data_get(entry_item);
365 if (entry_info == NULL)
368 DEBUG_LOG(UG_NAME_NORMAL, "entry_info: 0x%x", entry_info);
370 return g_strdup(entry_info->entry_txt);
373 Evas_Object *common_utils_create_layout(Evas_Object *navi_frame)
376 layout = elm_layout_add(navi_frame);
377 elm_layout_theme_set(layout, "layout", "application", "noindicator");
378 evas_object_size_hint_weight_set(layout, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
379 evas_object_show(layout);
384 static void __common_utils_del_popup(void *data, Evas_Object *obj, void *event_info)
386 Evas_Object *popup = (Evas_Object *)data;
387 evas_object_del(popup);
390 Evas_Object *common_utils_show_info_popup(Evas_Object *parent,
391 popup_btn_info_t *popup_data)
393 __COMMON_FUNC_ENTER__;
395 Evas_Object *popup = elm_popup_add(parent);
399 ERROR_LOG(UG_NAME_ERR, "Could not add popup");
403 elm_popup_align_set(popup, ELM_NOTIFY_ALIGN_FILL, 1.0);
404 evas_object_size_hint_weight_set(popup, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
406 if (popup_data->title_txt) {
407 txt = evas_textblock_text_utf8_to_markup(NULL, popup_data->title_txt);
408 elm_object_domain_translatable_part_text_set(popup,
409 "title,text", PACKAGE, txt);
413 if (popup_data->info_txt) {
414 elm_object_domain_translatable_text_set(popup, PACKAGE,
415 popup_data->info_txt);
418 if (popup_data->btn1_txt) {
419 Evas_Object *btn_1 = elm_button_add(popup);
420 elm_object_style_set(btn_1, "popup");
421 elm_object_domain_translatable_text_set(btn_1, PACKAGE ,
422 popup_data->btn1_txt);
423 elm_object_part_content_set(popup, "button1", btn_1);
424 if (popup_data->btn1_cb) {
425 evas_object_smart_callback_add(btn_1, "clicked",
426 popup_data->btn1_cb, popup_data->btn1_data);
427 eext_object_event_callback_add(popup, EEXT_CALLBACK_BACK,
428 popup_data->btn1_cb, popup_data->btn1_data);
430 evas_object_smart_callback_add(btn_1, "clicked",
431 __common_utils_del_popup, popup);
432 eext_object_event_callback_add(popup, EEXT_CALLBACK_BACK,
433 __common_utils_del_popup, popup);
437 if (popup_data->btn2_txt) {
438 Evas_Object *btn_2 = elm_button_add(popup);
439 elm_object_style_set(btn_2, "popup");
440 /* This button reference used in case of hidden AP case */
441 popup_data->btn = btn_2;
442 elm_object_domain_translatable_text_set(btn_2, PACKAGE,
443 popup_data->btn2_txt);
444 elm_object_part_content_set(popup, "button2", btn_2);
445 //evas_object_smart_callback_add(btn_2, "clicked", popup_data->btn2_cb, NULL);
446 evas_object_show(popup);
447 if (popup_data->btn2_cb) {
448 evas_object_smart_callback_add(btn_2, "clicked",
449 popup_data->btn2_cb, popup_data->btn2_data);
451 evas_object_smart_callback_add(btn_2, "clicked",
452 __common_utils_del_popup, popup);
456 evas_object_show(popup);
457 elm_object_focus_set(popup, EINA_TRUE);
462 Evas_Object *common_utils_show_info_ok_popup(Evas_Object *win,
463 const char *str_pkg_name, const char *info_txt,
464 Evas_Smart_Cb ok_cb, void *cb_data)
466 popup_btn_info_t popup_data;
468 memset(&popup_data, 0, sizeof(popup_data));
469 popup_data.info_txt = (char *)info_txt;
470 popup_data.btn1_txt = sc(str_pkg_name, I18N_TYPE_Ok);
471 popup_data.btn1_cb = ok_cb;
472 popup_data.btn1_data = cb_data;
474 return common_utils_show_info_popup(win, &popup_data);
477 Evas_Object *common_utils_show_info_timeout_popup(Evas_Object *win,
478 const char* info_text, const double timeout)
480 Evas_Object *popup = elm_popup_add(win);
482 elm_object_text_set(popup, info_text);
483 elm_popup_timeout_set(popup, timeout);
484 evas_object_smart_callback_add(popup, "timeout",
485 __common_utils_del_popup, popup);
486 evas_object_size_hint_weight_set(popup, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
487 elm_popup_orient_set(popup, ELM_POPUP_ORIENT_CENTER);
488 evas_object_show(popup);
493 int common_utils_get_rotate_angle(enum appcore_rm rotate_mode)
496 if (APPCORE_RM_UNKNOWN == rotate_mode)
497 appcore_get_rotation_state(&rotate_mode);
499 DEBUG_LOG(SP_NAME_NORMAL, "rotate_mode = %d", rotate_mode);
501 switch (rotate_mode) {
502 case APPCORE_RM_PORTRAIT_NORMAL: /**< Portrait mode */
503 DEBUG_LOG(SP_NAME_NORMAL, "rotate mode is APPCORE_RM_PORTRAIT_NORMAL");
507 case APPCORE_RM_PORTRAIT_REVERSE: /**< Portrait upside down mode */
508 DEBUG_LOG(SP_NAME_NORMAL, "rotate mode is APPCORE_RM_PORTRAIT_REVERSE");
512 case APPCORE_RM_LANDSCAPE_NORMAL: /**< Left handed landscape mode */
513 DEBUG_LOG(SP_NAME_NORMAL, "rotate mode is APPCORE_RM_LANDSCAPE_NORMAL");
517 case APPCORE_RM_LANDSCAPE_REVERSE: /**< Right handed landscape mode */
518 DEBUG_LOG(SP_NAME_NORMAL, "rotate mode is APPCORE_RM_LANDSCAPE_REVERSE");
523 ERROR_LOG(SP_NAME_ERR, "Invalid rotate mode. The default value (0) is set to 'rotate_angle'.");
531 wlan_security_mode_type_t common_utils_get_sec_mode(wifi_manager_security_type_e sec_type)
534 case WIFI_MANAGER_SECURITY_TYPE_NONE:
535 return WLAN_SEC_MODE_NONE;
536 case WIFI_MANAGER_SECURITY_TYPE_WEP:
537 return WLAN_SEC_MODE_WEP;
538 case WIFI_MANAGER_SECURITY_TYPE_WPA_PSK:
539 return WLAN_SEC_MODE_WPA_PSK;
540 case WIFI_MANAGER_SECURITY_TYPE_WPA2_PSK:
541 return WLAN_SEC_MODE_WPA_PSK;
542 case WIFI_MANAGER_SECURITY_TYPE_EAP:
543 return WLAN_SEC_MODE_IEEE8021X;
545 return WLAN_SEC_MODE_NONE;
548 return WLAN_SEC_MODE_NONE;
551 int common_utils_send_message_to_net_popup(const char *title,
552 const char *content, const char *type, const char *ssid)
555 bundle *b = bundle_create();
557 bundle_add_str(b, "_SYSPOPUP_TITLE_", title);
558 bundle_add_str(b, "_SYSPOPUP_CONTENT_", content);
559 bundle_add_str(b, "_SYSPOPUP_TYPE_", type);
560 bundle_add_str(b, "_AP_NAME_", ssid);
562 ret = aul_launch_app("net.netpopup", b);
569 int common_utils_send_restriction_to_net_popup(const char *title,
570 const char *type, const char *restriction)
573 bundle *b = bundle_create();
575 bundle_add_str(b, "_SYSPOPUP_TITLE_", title);
576 bundle_add_str(b, "_SYSPOPUP_CONTENT_", "security restriction");
577 bundle_add_str(b, "_SYSPOPUP_TYPE_", type);
578 bundle_add_str(b, "_RESTRICTED_TYPE_", restriction);
580 ret = aul_launch_app("net.netpopup", b);
587 int common_util_set_system_registry(const char *key, int value)
589 __COMMON_FUNC_ENTER__;
591 if (vconf_set_int(key, value) < 0) {
592 ERROR_LOG(UG_NAME_NORMAL, "Failed to set vconf");
594 __COMMON_FUNC_EXIT__;
598 __COMMON_FUNC_EXIT__;
602 int common_util_get_system_registry(const char *key)
604 __COMMON_FUNC_ENTER__;
608 if (vconf_get_int(key, &value) < 0) {
609 ERROR_LOG(UG_NAME_NORMAL, "Failed to get vconf");
611 __COMMON_FUNC_EXIT__;
615 __COMMON_FUNC_EXIT__;
619 static void __common_util_managed_idle_destroy_cb(gpointer data)
624 managed_idler_list = g_slist_remove(managed_idler_list, data);
628 static gboolean __common_util_managed_idle_cb(gpointer user_data)
630 struct managed_idle_data *data = (struct managed_idle_data *)user_data;
635 return data->func(data->user_data);
638 guint common_util_managed_idle_add(GSourceFunc func, gpointer user_data)
641 struct managed_idle_data *data;
646 data = g_try_new0(struct managed_idle_data, 1);
651 data->user_data = user_data;
653 id = g_idle_add_full(G_PRIORITY_DEFAULT_IDLE, __common_util_managed_idle_cb,
654 data, __common_util_managed_idle_destroy_cb);
662 managed_idler_list = g_slist_append(managed_idler_list, data);
667 void common_util_managed_idle_cleanup(void)
669 if (managed_idler_list == NULL)
672 GSList *cur = managed_idler_list;
674 struct managed_idle_data *data;
677 GSList *next = cur->next;
678 data = (struct managed_idle_data *)cur->data;
680 src = g_main_context_find_source_by_id(g_main_context_default(), data->id);
682 g_source_destroy(src);
683 cur = managed_idler_list;
689 g_slist_free(managed_idler_list);
690 managed_idler_list = NULL;
693 void common_util_managed_ecore_scan_update_timer_add(double interval,
694 common_util_scan_update_cb callback, void *data)
696 if (callback == NULL)
699 common_util_managed_ecore_scan_update_timer_del();
701 scan_update_timer = ecore_timer_add(interval, callback, data);
704 void common_util_managed_ecore_scan_update_timer_del(void)
706 if (scan_update_timer != NULL) {
707 ecore_timer_del(scan_update_timer);
708 scan_update_timer = NULL;
712 void common_util_manager_ecore_scan_update_timer_reset(void)
714 scan_update_timer = NULL;
717 static GDBusConnection *common_util_get_gdbus_conn(void)
719 GError *error = NULL;
721 if (gdbus_conn.connection != NULL)
722 return gdbus_conn.connection;
724 #if !GLIB_CHECK_VERSION(2, 36, 0)
728 gdbus_conn.connection = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &error);
729 if (gdbus_conn.connection == NULL) {
730 ERROR_LOG(UG_NAME_NORMAL,
731 "Failed to connect to the D-BUS daemon: [%s]\n", error->message);
736 return gdbus_conn.connection;
739 gboolean common_util_subscribe_scanning_signal(GDBusSignalCallback callback)
741 GDBusConnection *connection;
743 connection = common_util_get_gdbus_conn();
744 if (connection == NULL) {
745 ERROR_LOG(UG_NAME_NORMAL, "failed to get gdbus_conn");
749 /* Create supplicant service connection */
750 gdbus_conn.subscribe_id_supplicant = g_dbus_connection_signal_subscribe(
753 SUPPLICANT_SERVICE_INTERFACE,
757 G_DBUS_SIGNAL_FLAGS_NONE,
762 if (gdbus_conn.subscribe_id_supplicant == 0) {
763 ERROR_LOG(UG_NAME_NORMAL, "Failed register signals "
765 gdbus_conn.subscribe_id_supplicant);
772 gboolean common_util_unsubscribe_scanning_signal(void)
774 GDBusConnection *connection;
776 connection = common_util_get_gdbus_conn();
777 if (connection == NULL) {
778 ERROR_LOG(UG_NAME_NORMAL, "failed to get gdbus_conn");
782 g_dbus_connection_signal_unsubscribe(connection,
783 gdbus_conn.subscribe_id_supplicant);
785 g_object_unref(gdbus_conn.connection);
786 gdbus_conn.connection = NULL;
791 int common_utils_get_sim_state(void)
793 int value = VCONFKEY_TELEPHONY_SIM_UNKNOWN;
796 value = common_util_get_system_registry(VCONFKEY_TELEPHONY_SIM_SLOT);
797 INFO_LOG(UG_NAME_NORMAL, "SIM slot 1 state : %d", value);
798 if (value == VCONFKEY_TELEPHONY_SIM_INSERTED)
801 sim_count = common_util_get_system_registry(
802 VCONFKEY_TELEPHONY_SIM_SLOT_COUNT);
806 value = common_util_get_system_registry(VCONFKEY_TELEPHONY_SIM_SLOT2);
807 INFO_LOG(UG_NAME_NORMAL, "SIM slot 2 state : %d", value);
812 static inline int __get_model_from_model_config_xml(const char *field, char **value)
814 char *node_name = NULL;
815 char *node_value = NULL;
816 xmlNode *cur_node = NULL;
817 xmlNodePtr cur_ptr = NULL;
818 xmlNodePtr model_ptr = NULL;
819 xmlDocPtr xml_doc = NULL;
821 xml_doc = xmlParseFile(MODEL_CONFIG_FILE);
825 cur_ptr = xmlDocGetRootElement(xml_doc);
826 if (cur_ptr == NULL) {
831 for (cur_node = cur_ptr; cur_node; cur_node = cur_node->next) {
832 if (!xmlStrcmp(cur_ptr->name, (const xmlChar*)MODEL_CONFIG_TAG))
836 if (cur_ptr == NULL) {
841 cur_ptr = cur_ptr->xmlChildrenNode;
842 for (cur_node = cur_ptr; cur_node; cur_node = cur_node->next) {
843 if (!xmlStrcmp(cur_node->name, (const xmlChar*)FEATURE_TAG)) {
844 model_ptr = cur_node;
849 if (model_ptr == NULL) {
855 cur_ptr = model_ptr->xmlChildrenNode;
857 for (cur_node = cur_ptr; cur_node; cur_node = cur_node->next) {
858 if (cur_node->type == XML_ELEMENT_NODE) {
859 node_name = (char *)xmlGetProp(cur_node, (const xmlChar*)"name");
861 if (!strncmp(node_name, field, strlen(node_name))) {
862 node_value = (char *)xmlNodeListGetString(xml_doc, cur_node->xmlChildrenNode, 1);
864 *value = strdup(node_value);
879 Eina_Bool _is_emulator(void)
881 char *model_name = NULL;
883 if (emulator == TIZEN_MODEL_EMULATOR)
885 else if (emulator == TIZEN_MODEL_NOT_EMULATOR)
888 if (__get_model_from_model_config_xml("tizen.org/system/model_name", &model_name) < 0)
891 if (model_name == NULL)
894 if (strncmp(model_name, "Emulator", strlen("Emulator")) == 0) {
896 emulator = TIZEN_MODEL_EMULATOR;
900 emulator = TIZEN_MODEL_NOT_EMULATOR;