[Feature] Add icon for driving mode .
[apps/core/preloaded/settings.git] / setting-common / src / setting-cfg.c
1 /*
2  * setting
3  *
4  * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd.
5  *
6  * Contact: MyoungJune Park <mj2004.park@samsung.com>
7  *
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  * http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  *
20  */
21
22 #include <setting-cfg.h>
23 #include <setting-debug.h>
24 #include <stdio.h>
25 #include <Elementary.h>
26 #include <setting-common-general-func.h>
27 #include <unistd.h>
28
29 #define CFG_FILE_DIR_PATH       "/opt/data/setting/"
30 #define CFG_FILE_PATH           CFG_FILE_DIR_PATH"setting.cfg"
31
32 JsonParser* parser;
33 JsonNode*   root; /* category_list */
34
35 char* setting_cfg_get_path()
36 {
37         return CFG_FILE_PATH;
38 }
39
40 int setting_cfg_file_write( JsonNode * node );
41
42 #define __create_an_item(item_name, icon_path, ug_args, defaultPos, is_resetable) do\
43 {\
44         if (!is_ug_installed_by_ug_args(ug_args)) break;\
45         menu_item = json_node_new(JSON_NODE_OBJECT); \
46         object = json_object_new(); \
47         json_node_take_object(menu_item, object); \
48         json_object_set_string_member(object, "key_name", item_name); \
49         json_object_set_string_member(object, "icon_path", icon_path); \
50         json_object_set_string_member(object, "ug_args", ug_args); \
51         json_object_set_int_member(object, "pos", defaultPos); \
52         json_object_set_int_member(object, "click_times", 0); \
53         json_object_set_int_member(object, "is_resetable", is_resetable); \
54         json_array_add_element(menu, menu_item); \
55 } while(0);\
56
57 #define __create_an_item_by_pkg(item_name, pkg_name, ug_args, defaultPos, is_resetable) do\
58 {\
59         if (!is_ug_installed_by_ug_args(ug_args)) break;\
60         menu_item = json_node_new(JSON_NODE_OBJECT); \
61         object = json_object_new(); \
62         char* __temp_##item_name = get_icon_path(pkg_name); \
63         json_node_take_object(menu_item, object); \
64         json_object_set_string_member(object, "key_name", item_name); \
65         json_object_set_string_member(object, "icon_path", __temp_##item_name); \
66         json_object_set_string_member(object, "ug_args", ug_args); \
67         json_object_set_int_member(object, "pos", defaultPos); \
68         json_object_set_int_member(object, "click_times", 0); \
69         json_object_set_int_member(object, "is_resetable", is_resetable); \
70         json_array_add_element(menu, menu_item); \
71         free(__temp_##item_name); __temp_##item_name = NULL; \
72 } while(0);\
73
74
75 #define __create_a_menu(menu_name)\
76 {\
77         category = json_node_new( JSON_NODE_OBJECT );\
78         object = json_object_new();\
79         json_node_take_object ( category, object );\
80         json_object_set_string_member( object, "name", menu_name );\
81         menu = json_array_new();\
82         json_object_set_array_member( object, "menu", menu );\
83         json_array_add_element( json_node_get_array( category_list ), category );\
84 }
85
86 void setting_cfg_print( void )
87 {
88         JsonNode * node = root;
89
90         JsonGenerator *generator = json_generator_new ();
91         g_object_set( generator, "pretty", TRUE, NULL );
92         json_generator_set_root ( generator, node );
93         gchar *data = json_generator_to_data ( generator, NULL );
94         SETTING_TRACE( "%s", (char *)data );
95
96         g_free(data);
97         g_object_unref(generator);
98 }
99
100 /* create config file from scratch */
101 int setting_cfg_create(void)
102 {
103         JsonNode *category_list, *category, *menu_item;
104         JsonArray *menu;
105         JsonObject *object;
106
107         /* Category list */
108         category_list = json_node_new (JSON_NODE_ARRAY);
109         json_node_take_array ( category_list, json_array_new () );
110
111         /* Connectivity */
112         __create_a_menu(KeyStr_Connectivity);
113
114         __create_an_item(KeyStr_FlightMode, IMG_FlightMode, NULL, Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
115         __create_an_item(KeyStr_WiFi, IMG_WiFi, "wifi-efl-UG", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
116         __create_an_item(KeyStr_MobileAP, IMG_MobileAP, "setting-mobile-ap-ug", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
117         __create_an_item(KeyStr_Location, IMG_Location, "setting-location-efl", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
118         __create_an_item(KeyStr_Network, IMG_Network, "setting-network-efl", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
119         __create_an_item(KeyStr_Bluetooth, IMG_Bluetooth, "setting-bluetooth-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
120         __create_an_item(KeyStr_NFC, IMG_NFC, "setting-nfc-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
121
122 #if SUPPORT_DATA_USAGE
123         __create_an_item(KeyStr_DataUsage, IMG_DataUsage, "setting-datausage-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
124 #endif
125
126 #if SUPPORT_WIFI_DIRECT
127         __create_an_item(KeyStr_WiFiDirect, IMG_WiFiDirect, "setting-wifidirect-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
128 #endif
129
130 #if SUPPORT_ALLSHARECAST
131         // Allshare Cast -- Here
132         __create_an_item(KeyStr_AllShareCast, IMG_AllShareCast, "setting-allshare-cast-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
133 #endif
134
135 #if SUPPORT_AllShare
136         // allshare setting
137         __create_an_item(KeyStr_NearbyDevices, IMG_AllShare, "setting-allshare-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
138 #endif
139
140         if ( ! is_slp_binary()) {
141                 __create_an_item(KeyStr_KeisOverWifi, IMG_KeisOverWifi, "kies-via-wifi", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
142         }
143
144         if ( ! is_slp_binary()) {
145                 __create_an_item(KeyStr_Synchronise, IMG_Synchronise, "setting-synchronise-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
146         }
147
148         /* System */
149         __create_a_menu(KeyStr_System);
150         /* a new group..        */
151
152         __create_an_item(KeyStr_EventsNotifications, IMG_EventsNotifications, "setting-phone-efl|viewtype:notification", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
153
154         // Wallpaper -- here
155 #if SUPPORT_WALLPAPER
156         /* kinds of wallpaper version.. */
157         __create_an_item(KeyStr_Wallpaper, IMG_Wallpaper, "setting-display-efl|viewtype:wallpaper", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
158 #endif
159
160         __create_an_item(KeyStr_Sounds, IMG_Sounds, "setting-profile-efl", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
161
162 #if SUPPOR_SEPARATE_BRIGHTNESS
163         __create_an_item(KeyStr_Brightness, IMG_Brightness, "setting-display-efl|viewtype:brightness", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
164 #endif
165
166         __create_an_item(KeyStr_Security, IMG_Security, "setting-security-efl", Cfg_Item_Pos_Level0, Cfg_Item_Resetable);
167
168 #if SUPPORT_POWERSAVING
169         __create_an_item(KeyStr_Powersaving, IMG_Powersaving, "setting-powersaving-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
170 #endif
171
172 #if SUPPORT_MOTIONS
173         __create_an_item(KeyStr_Motions, IMG_Motion, "setting-motion-efl|viewtype:motions", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
174 #endif
175
176 #if SUPPORT_ACCESSIBILITY
177         __create_an_item(KeyStr_Accessibility, IMG_Accessibility, "setting-accessibility-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
178 #endif
179
180 #if SUPPORT_FONT
181         __create_an_item(KeyStr_Font, IMG_Font, "setting-font-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
182 #endif
183
184         __create_an_item(KeyStr_Display, IMG_Dispaly, "setting-display-efl|viewtype:main", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
185 #if SUPPORT_MENUSCREEN
186         __create_an_item(KeyStr_Menuscreen, IMG_Menuscreen, "setting-homescreen-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
187 #endif
188         __create_an_item(KeyStr_Landscape, IMG_Landscape, NULL, Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
189         __create_an_item(KeyStr_DateTime, IMG_DateTime, "setting-time-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
190         __create_an_item(KeyStr_LanguageRegion, IMG_DisplayLanguage, "setting-phone-efl|viewtype:language", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
191         __create_an_item(KeyStr_KeyboradLanguage, IMG_KeyboradLanguage, "isfsetting-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
192
193 #if SUPPORT_VOICEINOUT
194         __create_an_item(KeyStr_VoiceInOut, IMG_VoiceInOut, "setting-voice-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
195 #endif
196         __create_an_item(keystr_Drivingmode, IMG_DrivingMode, "setting-drivingmode-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
197 #if SUPPORT_STORAGE
198         __create_an_item(KeyStr_Storage, IMG_DefaultIcon, "setting-storage-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
199 #endif
200         __create_an_item(KeyStr_ManageApps, IMG_MANAGE_APPS, "setting-manage-applications-efl|viewtype:manage-applications", Cfg_Item_Pos_Level1,
201                             Cfg_Item_Resetable);
202
203         __create_an_item(KeyStr_WebApps, IMG_Web_Apps, "webapp-common-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
204
205 #if SUPPORT_CERTIFICATES
206         __create_an_item(KeyStr_CertUI, IMG_MANAGE_APPS, "setting-manage-certificates-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
207 #endif
208
209         __create_an_item(KeyStr_Memory, IMG_Memory, "setting-memory-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
210         __create_an_item(KeyStr_Reset, IMG_Reset, "setting-reset-efl", Cfg_Item_Pos_Level1, Cfg_Item_unResetable);
211         __create_an_item(KeyStr_DeveloperOption, IMG_USBconnection, "setting-developeroption-efl|viewtype:usb", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
212         __create_an_item(KeyStr_AboutPhone, IMG_AboutPhone, "setting-about-efl", Cfg_Item_Pos_Level1, Cfg_Item_Resetable);
213
214         /* Applications */
215         __create_a_menu(KeyStr_Applications);
216
217         __create_an_item(KeyStr_Accounts, IMG_Accounts, "setting-myaccount-efl|mode:account_list", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
218         __create_an_item(KeyStr_Call, IMG_Call, "setting-call-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
219         __create_an_item(KeyStr_Messages, IMG_Messages, "msg-setting-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
220         __create_an_item(KeyStr_Email, IMG_Email, "email-setting-efl|VIEW_TYPE:main-view", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
221         __create_an_item(KeyStr_Contacts, IMG_Contacts, "contacts-settings-efl|request_type:71", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
222
223         __create_an_item(KeyStr_Calendar, IMG_Calendar, "calendar-settings-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
224
225         __create_an_item(KeyStr_Gallery, IMG_Gallery, "setting-gallery-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
226         __create_an_item(KeyStr_VoiceRecorder, IMG_VoiceRecorder, "setting-voicerecorder-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
227
228 #if SUPPORT_FMradio
229         // FMradio setting
230         __create_an_item_by_pkg(KeyStr_FMRadio, "com.samsung.fm-radio", "setting-fmradio-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
231         SETTING_TRACE_DEBUG("Added FMRadio");
232 #endif
233
234
235
236
237
238
239 #if DISABLED_CODE
240         __create_an_item_by_pkg(KeyStr_NFC, "com.samsung.nfc-app", "setting-nfc-efl", Cfg_Item_Pos_Level0, Cfg_Item_unResetable);
241 #endif
242
243         /* Downloaded App */
244         __create_a_menu(KeyStr_DownloadedAPPs);
245
246         /* write to file */
247         int ret = setting_cfg_file_write( category_list );
248
249         json_node_free( category_list );
250
251         return ret;
252 }
253
254
255 /* load file */
256 int setting_cfg_file_read( void )
257 {
258 #if DISABLED_CODE
259         if (access( CFG_FILE_PATH, R_OK|F_OK ) !=0 )
260         {
261                 SETTING_TRACE("file [%s] not legal, need to check your file-system.[%s:%d]\n", CFG_FILE_PATH, __FILE__, __LINE__);
262                 //return Cfg_Error_Type_FilePermissionDenied;
263                 return FALSE;
264         }
265 #endif
266         parser = json_parser_new (); /* to be freed on exit */
267
268         /* file -> parser */
269         GError *error = NULL;
270         gboolean ret = json_parser_load_from_file( parser, CFG_FILE_PATH, &error );
271
272         if( FALSE == ret )
273         {
274                 return FALSE;
275 #if DISABLED_CODE
276                 SETTING_TRACE_ERROR("error->message:%s", (char*)(error->message));
277
278         /* The file is existing and can be accessed normally, but it was
279          * loaded failed as a json script, it means setting.cfg is
280          * damaged(not the normal formatting ), we need to remove
281          * the file and recreate in next running time*/
282                 SETTING_TRACE_ERROR("The file[%s] is existing and can be accessed "\
283                             "normally, but it was loaded failed as a json "\
284                             "script, it means setting.cfg is damaged (the "\
285                             "formatting ia abnormal), we need to remove the"\
286                             " file and recreate in next running time!",
287                             CFG_FILE_PATH);
288
289         SETTING_TRACE("Trying to removing the damaged file.");
290         if (remove(CFG_FILE_PATH) != 0)
291         {
292             SETTING_TRACE_ERROR("Error to remove the damaged file");
293             return FALSE;
294         }
295
296         if( FALSE == setting_cfg_create() )
297         {
298             SETTING_TRACE_ERROR("Error to create a new config file");
299             return FALSE;
300         }
301         /*if the failed is  caused by reading the file recursively invoking */
302         return setting_cfg_file_read();
303 #endif
304         }
305
306         /* parser -> root */
307         root = json_parser_get_root( parser ); /* to be freed on exit*/
308         return TRUE;
309 }
310
311 /**
312 * @brief dump JSON to file
313 */
314 int setting_cfg_file_write( JsonNode * node )
315 {
316         GError *error = NULL;
317         JsonGenerator *generator = json_generator_new ();
318         json_generator_set_root ( generator, node );
319         g_object_set( generator, "pretty", TRUE, NULL ); //write file in indent format
320         gboolean ret = json_generator_to_file( generator, CFG_FILE_PATH, &error );
321         g_object_unref(generator);
322
323         /* ***BEGIN***  DAC black screen SAMSUNG 2010/8/9 add
324          *add read permission
325          *chown -R inhouse:inhouse /home/inhouse/setting.cfg
326          */
327         if( FALSE == ret )
328         {
329                 SETTING_TRACE_ERROR("Error writing file %s!", CFG_FILE_PATH );
330                 return FALSE;
331         }
332         return TRUE;
333 }
334
335 /*   public functions  */
336 #if DISABLED_CODE
337 int setting_cfg_init( void )
338 {
339         g_type_init ();
340
341         struct stat st;
342         //int ret = -1;
343
344         if (access( CFG_FILE_DIR_PATH, R_OK|W_OK|F_OK ) !=0 )
345     {
346                 SETTING_TRACE_ERROR("dir [%s] not legal, need to check your file-system.[%s:%d]\n", CFG_FILE_DIR_PATH, __FILE__, __LINE__);
347         return Cfg_Error_Type_DirPermissionDenied;
348     }
349         if( stat(CFG_FILE_DIR_PATH, &st) != 0)/* to make more stable */
350         {
351                 /* if (0 != system("sudo mkdir /opt/data/setting/")); */
352                 /* if (EINA_TRUE != ecore_file_mkpath(CFG_FILE_DIR_PATH)); */
353                 if (EINA_TRUE != ecore_file_mkdir(CFG_FILE_DIR_PATH));
354                 {
355                         perror("mkdir");
356                         return Cfg_Error_Type_Mkdir_Failed;
357                 }
358         }
359
360         if( stat(CFG_FILE_PATH, &st) != 0)
361         {
362                 SETTING_TRACE_ERROR("Config file doesn't exist. Create it!");
363                 if(     FALSE == setting_cfg_create() )
364                 {
365                         /* perror("setting_cfg_create"); */
366                         return Cfg_Error_Type_CreateCfg_Failed;
367                 }
368                 stat(CFG_FILE_PATH, &st);
369         }
370         /* ***BEGIN***  error handle(caused by unstable file system) SAMSUNG 2010/9/10 add*/
371         else if (0 == st.st_size ||
372              0 != access( CFG_FILE_PATH, R_OK|F_OK ))
373         {
374                 SETTING_TRACE("the %s is 0 Byte, we need to recreate it.", CFG_FILE_PATH);
375                 /* delete the file */
376                 if (remove(CFG_FILE_PATH) != 0)
377                 {
378                         perror("remove");
379                         return Cfg_Error_Type_RemoveCfg_Failed;
380                 }
381                 if(     FALSE == setting_cfg_create() )
382                 {
383                         /* perror("setting_cfg_create"); */
384                         return Cfg_Error_Type_CreateCfg_Failed;
385                 }
386
387         }
388         /* ****END****  error handle(caused by unstable  file system) SAMSUNG 2010/9/10 add
389          * cfg file exists but invalid -> re-create
390          * load file into parser
391          */
392         if( FALSE == setting_cfg_file_read() )
393         {
394                 /* remove current setting file */
395                 if (remove(CFG_FILE_PATH) != 0)
396                 {
397                         /* perror("remove"); */
398                         return Cfg_Error_Type_RemoveCfg_Failed;
399                 }
400                 return Cfg_Error_Type_ReadCfg_Failed;
401         }
402
403         return Cfg_Error_Type_Sucess;
404 }
405 #endif
406
407 int setting_cfg_init( void )
408 {
409         g_type_init ();
410
411         if (!access(CFG_FILE_PATH, R_OK|W_OK|F_OK )) { // succeed to access
412                 if(!setting_cfg_file_read()) { // return FALSE
413                         if (remove(CFG_FILE_PATH)) {
414                                 return Cfg_Error_Type_RemoveCfg_Failed;
415                         }
416                         return Cfg_Error_Type_ReadCfg_Failed;
417                 }
418
419                 return Cfg_Error_Type_Sucess;
420         } else { // fail to access
421                 switch (errno) {
422                         // file non-existing case
423                         case ENOENT:
424                                 SETTING_TRACE_ERROR("non-existing file/dir");
425                                 ecore_file_mkdir(CFG_FILE_DIR_PATH);
426                                 if (!setting_cfg_create()) { // return FALSE
427                                         SETTING_TRACE_ERROR("Error to create a new config file");
428                                         return Cfg_Error_Type_CreateCfg_Failed;
429                                 }
430                                 if(!setting_cfg_file_read() ) { // return FALSE
431                                         if (remove(CFG_FILE_PATH)) {
432                                                 return Cfg_Error_Type_RemoveCfg_Failed;
433                                         }
434                                         return Cfg_Error_Type_ReadCfg_Failed;
435                                 }
436
437                                 return Cfg_Error_Type_Sucess;
438                         // other cases
439                         case EACCES:
440                         case EROFS:
441                         default:
442                                 return Cfg_Error_Type_DirPermissionDenied;
443                 }
444         }
445 }
446
447 void setting_cfg_exit( void )
448 {
449         json_node_free(root);
450         g_object_unref (parser);
451 }
452
453 int setting_cfg_file_update( void )
454 {
455         if (access( CFG_FILE_PATH, W_OK|F_OK ) !=0 )
456         {
457                 return FALSE;
458         }
459         return setting_cfg_file_write( root );
460 }
461
462 int setting_cfg_get_category_length( void )
463 {
464         return json_array_get_length( json_node_get_array( root ) );
465 }
466
467 char* setting_cfg_get_category_name( int category_index )
468 {
469         JsonObject * category_obj = json_array_get_object_element( json_node_get_array( root ), category_index );
470         return (char*)json_object_get_string_member( category_obj, "name" );
471 }
472
473 int setting_cfg_get_menu_length( int category_index )
474 {
475         JsonObject * category_obj = json_array_get_object_element( json_node_get_array( root ), category_index );
476         JsonArray * menu = json_object_get_array_member( category_obj, "menu" );
477         return json_array_get_length( menu );
478 }
479
480 char * setting_cfg_get_keyname_idx( int category_index, int menu_index )
481 {
482         JsonObject * category_obj = json_array_get_object_element( json_node_get_array( root ), category_index );
483         JsonArray * menu = json_object_get_array_member( category_obj, "menu" );
484         JsonObject * menu_item = json_array_get_object_element( menu, menu_index );
485         return (char*)json_object_get_string_member( menu_item, "key_name" );
486 }
487
488 char * setting_cfg_get_string_field_idx( int category_index, int menu_index, char *field_name)
489 {
490         JsonObject * category_obj = json_array_get_object_element( json_node_get_array( root ), category_index );
491         JsonArray * menu = json_object_get_array_member( category_obj, "menu" );
492         JsonObject * menu_item = json_array_get_object_element( menu, menu_index );
493
494         char *data = (char *)json_object_get_string_member( menu_item, field_name );
495         if (!safeStrCmp(data, "(null)"))/* pass NULL to ug_args when create setting.cfg. */
496         {
497                 return NULL;
498         }
499         return data;
500 }
501
502 int setting_cfg_get_int_field_idx( int category_index, int menu_index , char *field_name)
503 {
504         JsonObject * category_obj = json_array_get_object_element( json_node_get_array( root ), category_index );
505         JsonArray * menu = json_object_get_array_member( category_obj, "menu" );
506         JsonObject * menu_item = json_array_get_object_element( menu, menu_index );
507         return json_object_get_int_member( menu_item, field_name );
508 }
509
510 char * setting_cfg_get_icon_path_idx( int category_index, int menu_index )
511 {
512         return setting_cfg_get_string_field_idx(category_index, menu_index, "icon_path");
513 }
514
515 char * setting_cfg_get_ug_args_idx( int category_index, int menu_index )
516 {
517         return setting_cfg_get_string_field_idx(category_index, menu_index, "ug_args");
518 }
519
520 char * setting_cfg_get_ugpath_idx( int category_index, int menu_index )
521 {
522         return setting_cfg_get_string_field_idx(category_index, menu_index, "ug_path");
523 }
524
525 char * setting_cfg_get_ugpath( char * keyname )
526 {
527         int i, j;
528         for( i = 0; i < setting_cfg_get_category_length(); i++ )
529         {
530                 for( j = 0; j < setting_cfg_get_menu_length( i ); j++ )
531                 {
532                         if( safeStrCmp( setting_cfg_get_keyname_idx( i, j ), keyname ) == 0 )
533                                 return setting_cfg_get_ugpath_idx( i, j );
534                 }
535         }
536         return NULL;
537 }
538
539 int setting_cfg_get_pos_idx( int category_index, int menu_index )
540 {
541         return setting_cfg_get_int_field_idx(category_index, menu_index, "pos");
542 }
543
544 int setting_cfg_get_pos( char * keyname )
545 {
546         int i, j;
547         for( i = 0; i < setting_cfg_get_category_length(); i++ )
548         {
549                 for( j = 0; j < setting_cfg_get_menu_length( i ); j++ )
550                 {
551                         if( safeStrCmp( setting_cfg_get_keyname_idx( i, j ), keyname ) == 0 )
552                                 return setting_cfg_get_pos_idx( i, j );
553                 }
554         }
555         return 0;
556 }
557
558 void setting_cfg_set_pos_idx( int category_index, int menu_index, int pos )
559 {
560         JsonObject * category_obj = json_array_get_object_element( json_node_get_array( root ), category_index );
561         JsonArray * menu = json_object_get_array_member( category_obj, "menu" );
562         JsonObject * menu_item = json_array_get_object_element( menu, menu_index );
563         json_object_remove_member( menu_item, "pos" );
564         json_object_set_int_member( menu_item, "pos", pos );
565 }
566
567 void setting_cfg_set_pos( char * keyname, int pos )
568 {
569         int i, j;
570         for( i = 0; i < setting_cfg_get_category_length(); i++ )
571         {
572                 for( j = 0; j < setting_cfg_get_menu_length( i ); j++ )
573                 {
574                         if( safeStrCmp( setting_cfg_get_keyname_idx( i, j ), keyname ) == 0 )
575                         {
576                                 setting_cfg_set_pos_idx( i, j, pos );
577                                 return ;
578                         }
579                 }
580         }
581
582 }
583
584 int setting_cfg_get_click_times_idx( int category_index, int menu_index )
585 {
586         return setting_cfg_get_int_field_idx(category_index, menu_index, "click_times");
587 }
588
589 int setting_cfg_get_click_times( char * keyname )
590 {
591         int i, j;
592         for( i = 0; i < setting_cfg_get_category_length(); i++ )
593         {
594                 for( j = 0; j < setting_cfg_get_menu_length( i ); j++ )
595                 {
596                         if( safeStrCmp( setting_cfg_get_keyname_idx( i, j ), keyname ) == 0 )
597                                 return setting_cfg_get_click_times_idx( i, j );
598                 }
599         }
600         return 0;
601 }
602
603 void setting_cfg_set_click_times_idx( int category_index, int menu_index, int click_times )
604 {
605         JsonObject * category_obj = json_array_get_object_element( json_node_get_array( root ), category_index );
606         JsonArray * menu = json_object_get_array_member( category_obj, "menu" );
607         JsonObject * menu_item = json_array_get_object_element( menu, menu_index );
608         json_object_remove_member( menu_item, "click_times" );
609         json_object_set_int_member( menu_item, "click_times", click_times );
610 }
611
612 void setting_cfg_set_click_times( char * keyname, int click_times )
613 {
614         int i, j;
615         for( i = 0; i < setting_cfg_get_category_length(); i++ )
616         {
617                 for( j = 0; j < setting_cfg_get_menu_length( i ); j++ )
618                 {
619                         if( safeStrCmp( setting_cfg_get_keyname_idx( i, j ), keyname ) == 0 )
620                         {
621                                 setting_cfg_set_click_times_idx( i, j, click_times );
622                                 return ;
623                         }
624                 }
625         }
626
627 }
628
629 int setting_cfg_get_resetable_flag_idx(int category_index, int menu_index)
630 {
631         return setting_cfg_get_int_field_idx(category_index, menu_index,
632                                              "is_resetable");
633 }
634
635 void setting_cfg_add_downloaded_app( char *keyname, char *icon_path, char *ug_args, int pos)
636 {
637         int i;
638         JsonNode *menu_item;
639         JsonObject *object;
640         JsonArray *menu;
641
642         for( i=0; i<setting_cfg_get_category_length(); i++ )
643         {
644                 if( safeStrCmp( setting_cfg_get_category_name(i), "Downloaded App" ) == 0 )
645                 {
646                         menu_item = json_node_new( JSON_NODE_OBJECT );
647                         object = json_object_new();
648                         json_node_take_object ( menu_item, object );
649                         json_object_set_string_member( object, "key_name", keyname );
650                         json_object_set_string_member( object, "icon_path", icon_path );
651                         json_object_set_string_member( object, "ug_args", ug_args );
652                         json_object_set_int_member( object, "pos", pos );
653
654                         object = json_array_get_object_element( json_node_get_array( root ), i );
655                         menu = json_object_get_array_member( object, "menu" );
656                         json_array_add_element( menu, menu_item );
657                 }
658         }
659 }
660
661 void setting_cfg_remove_downloaded_app( char * keyname )
662 {
663         int i, j;
664         JsonObject *object;
665         JsonArray *menu;
666
667         for( i = 0; i < setting_cfg_get_category_length(); i++ )
668         {
669                 if( safeStrCmp( setting_cfg_get_category_name(i), "Downloaded App" ) == 0 )
670                 {
671                         for( j = 0; j < setting_cfg_get_menu_length( i ); j++ )
672                         {
673                                 if( safeStrCmp( setting_cfg_get_keyname_idx( i, j ), keyname ) == 0 )
674                                 {
675                                         object = json_array_get_object_element( json_node_get_array( root ), i );
676                                         menu = json_object_get_array_member( object, "menu" );
677                                         json_array_remove_element( menu, j );
678                                         return ;
679                                 }
680                         }
681                 }
682         }
683 }
684
685 bool is_ug_installed_by_ug_args(void *data)
686 {
687         retv_if(!data, TRUE);//if passing NULL,drawing it
688         char* ug_args = data;
689         char *ug_name = get_ug_path_from_ug_args(ug_args);
690
691         char ug_file_opt[PATH_MAX];
692         if (snprintf(ug_file_opt, PATH_MAX, "%s/libug-%s.so", SETTING_UG_PATH, ug_name) < 0)
693                 return false;
694
695         struct stat st;
696         bool result_opt = false;
697
698         if(stat(ug_file_opt, &st) == 0) {
699                 result_opt = true;
700         } else {
701                 SETTING_TRACE_ERROR(" %s is *NOT* present\n", ug_file_opt);
702                 result_opt = false;
703         }
704
705         //-------------------------------------------------------------------------------------
706         char ug_file_usr[PATH_MAX];
707         bool result_usr = false;
708         if (snprintf(ug_file_usr, PATH_MAX, "%s/libug-%s.so", SETTING_UG_PATH_USR, ug_name) < 0)
709                 return false;
710
711         if(stat(ug_file_usr, &st) == 0) {
712                 result_usr = true;
713         } else {
714                 SETTING_TRACE_ERROR(" %s is *NOT* present\n", ug_file_usr);
715                 result_usr = false;
716         }
717
718         // false  & false --> false
719         // true   & false --> true
720         // false  & true  --> true
721         // true   &  true  --> true
722
723         return (result_usr || result_opt);
724 }
725
726 /*other relative function*/
727 char *get_ug_path_from_ug_args(void *data)
728 {
729         /*SETTING_TRACE_BEGIN;*/
730         char *p = (char *)data;
731         if (NULL == p || '\0' == p[0]) {
732                 return NULL;
733         }
734
735         char *q = strchr(p, '|');
736         char *path = NULL;
737
738         if (q) {                /* copy out the content before '|'; eg, ab|cd */
739                 path = (char *)calloc(1, q - p + 1);
740                 setting_retvm_if(!path, NULL, "calloc failed");
741                 safeCopyStr(path, p, q - p);
742                 /* redundant handle */
743                 path[q - p] = '\0';
744         } else {                /* copy out all the content. eg.abb */
745
746                 path = (char *)calloc(1, safeStrLen(p) + 1);
747                 setting_retvm_if(!path, NULL, "calloc failed");
748                 safeCopyStr(path, p, safeStrLen(p));
749         }
750         /*SETTING_TRACE("get the ug['%s']", path);*/
751         return path;
752 }
753
754 service_h get_bundle_from_ug_args(void *data)
755 {
756         /*SETTING_TRACE_BEGIN;*/
757         char *p = (char *)data;
758         if (NULL == p || '\0' == p[0]) {
759                 return NULL;
760         }
761         char *m = NULL;
762         char *q = strchr(p, '|');
763         if (q) {                /* (key, value) pairs exit. eg: ug_args = "sevenemail-setting-efl|caller:setting; cmd:main option" */
764                 /* alloc data */
765                 service_h svc;
766                 if (service_create(&svc))
767                         return NULL;
768                 int str_len = safeStrLen(p) + 1;
769                 char *v_key = (char *)calloc(1, str_len);
770                 if (!v_key) {
771                         service_destroy(svc);
772                         return NULL;
773                 }
774
775                 char *v_value = (char *)calloc(1, str_len);
776                 if (!v_value) {
777                         service_destroy(svc);
778                         FREE(v_key);
779                         return NULL;
780                 }
781
782                 p = ++q;
783                 while (p) {
784                         q = strchr(p, ';');
785                         if (q) {        /* not the last field */
786                                 m = strchr(p, ':');     /* ziduannei */
787                                 if (m) {
788                                         safeCopyStr(v_key, p, m - p);
789
790                                         ++m;
791                                         safeCopyStr(v_value, m, q - m);
792                                         SETTING_TRACE
793                                             ("To add ('%s', '%s') to bundle data",
794                                              v_key, v_value);
795                                         service_add_extra_data(svc, v_key, v_value);
796                                 } else {
797                                         SETTING_TRACE_ERROR
798                                             ("invalid key-value format!!\n");
799                                         break;  /* end the whole while */
800                                 }
801                         } else {        /* the last field */
802
803                                 m = strchr(p, ':');     /* ziduannei */
804                                 if (m) {
805                                         safeCopyStr(v_key, p, m - p);
806                                         ++m;
807                                         safeCopyStr(v_value, m, safeStrLen(m));
808
809                                         service_add_extra_data(svc, v_key, v_value);
810                                 } else {
811                                         SETTING_TRACE_ERROR
812                                             ("invalid key-value format!!\n");
813                                 }
814                                 break;  /* end the whole while */
815                         }
816
817                         memset(v_key, '\0', str_len);
818                         memset(v_value, '\0', str_len);
819                         p = ++q;
820                 }
821
822                 FREE(v_key);
823                 FREE(v_value);
824                 return svc;
825         } else {                /* eg: ug_args = "setting-browser-efl" */
826
827                 /*SETTING_TRACE("(key, value) pairs not exit");*/
828                 return NULL;
829         }
830
831 }
832