13 #include "pkgmgr-info.h"
14 #include "pkgmgrinfo_debug.h"
15 #include "pkgmgrinfo_private.h"
16 #include "pkgmgr_parser.h"
18 static bool _get_bool_value(const char *str)
22 else if (!strcasecmp(str, "true"))
28 static void __cleanup_appinfo(pkgmgr_appinfo_x *data)
30 pkgmgr_appinfo_x *info = data;
31 pkgmgr_appinfo_x *tmp;
33 while (info != NULL) {
36 free((void *)info->package);
38 free((void *)info->locale);
40 pkgmgrinfo_basic_free_application(info->app_info);
47 static char *_get_filtered_query(const char *query_raw,
48 pkgmgrinfo_filter_x *filter)
50 char buf[MAX_QUERY_LEN] = { 0, };
59 strncat(buf, query_raw, MAX_QUERY_LEN - 1);
61 for (list = head; list; list = list->next) {
62 /* TODO: revise condition getter function */
63 __get_filter_condition(list->data, &condition);
64 if (condition == NULL)
66 if (buf[strlen(query_raw)] == '\0') {
67 len += strlen(" WHERE ");
68 strncat(buf, " WHERE ", MAX_QUERY_LEN - len - 1);
70 len += strlen(" AND ");
71 strncat(buf, " AND ", MAX_QUERY_LEN -len - 1);
73 len += strlen(condition);
74 strncat(buf, condition, sizeof(buf) - len - 1);
82 static gint __list_strcmp(gconstpointer a, gconstpointer b)
84 return strcmp((char *)a, (char *)b);
87 static gint _appinfo_get_list(sqlite3 *db, const char *locale,
88 pkgmgrinfo_filter_x *filter, GList **list)
90 static const char query_raw[] =
91 "SELECT DISTINCT package_app_info.app_id FROM package_app_info"
92 " LEFT OUTER JOIN package_app_localized_info"
93 " ON package_app_info.app_id=package_app_localized_info.app_id"
94 " AND package_app_localized_info.app_locale=%Q"
95 " LEFT OUTER JOIN package_app_app_category"
96 " ON package_app_info.app_id=package_app_app_category.app_id"
97 " LEFT OUTER JOIN package_app_app_control"
98 " ON package_app_info.app_id=package_app_app_control.app_id"
99 " LEFT OUTER JOIN package_app_app_metadata"
100 " ON package_app_info.app_id=package_app_app_metadata.app_id ";
103 char *query_localized;
107 query = _get_filtered_query(query_raw, filter);
109 return PMINFO_R_ERROR;
110 query_localized = sqlite3_mprintf(query, locale);
112 if (query_localized == NULL)
113 return PMINFO_R_ERROR;
115 ret = sqlite3_prepare_v2(db, query_localized,
116 strlen(query_localized), &stmt, NULL);
117 sqlite3_free(query_localized);
118 if (ret != SQLITE_OK) {
119 LOGE("prepare failed: %s", sqlite3_errmsg(db));
120 return PMINFO_R_ERROR;
123 while (sqlite3_step(stmt) == SQLITE_ROW) {
124 _save_column_str(stmt, 0, (const char **)&appid);
126 *list = g_list_insert_sorted(*list, appid,
130 sqlite3_finalize(stmt);
135 static int _appinfo_get_filtered_list(pkgmgrinfo_filter_x *filter, uid_t uid,
145 locale = _get_system_locale();
147 return PMINFO_R_ERROR;
149 dbpath = getUserPkgParserDBPathUID(uid);
150 if (dbpath == NULL) {
152 return PMINFO_R_ERROR;
155 ret = sqlite3_open_v2(dbpath, &db, SQLITE_OPEN_READONLY, NULL);
156 if (ret != SQLITE_OK) {
157 _LOGE("failed to open db: %d", ret);
159 return PMINFO_R_ERROR;
162 if (_appinfo_get_list(db, locale, filter, list)) {
164 sqlite3_close_v2(db);
165 return PMINFO_R_ERROR;
167 sqlite3_close_v2(db);
169 if (uid == GLOBAL_USER) {
174 /* search again from global */
175 dbpath = getUserPkgParserDBPathUID(GLOBAL_USER);
176 if (dbpath == NULL) {
178 return PMINFO_R_ERROR;
181 ret = sqlite3_open_v2(dbpath, &db, SQLITE_OPEN_READONLY, NULL);
182 if (ret != SQLITE_OK) {
183 _LOGE("failed to open db: %d", ret);
185 return PMINFO_R_ERROR;
188 if (_appinfo_get_list(db, locale, filter, list)) {
190 sqlite3_close_v2(db);
191 return PMINFO_R_ERROR;
193 sqlite3_close_v2(db);
195 /* remove duplicate element:
196 * since the list is sorted, we can remove duplicates in linear time
198 for (tmp = *list, tmp2 = g_list_next(tmp); tmp;
199 tmp = tmp2, tmp2 = g_list_next(tmp)) {
200 if (tmp->prev == NULL || tmp->data == NULL)
202 if (strcmp((const char *)tmp->prev->data,
203 (const char *)tmp->data) == 0)
204 *list = g_list_delete_link(*list, tmp);
212 static int _appinfo_get_label(sqlite3 *db, const char *appid,
213 const char *locale, GList **label)
215 static const char query_raw[] =
216 "SELECT app_label, app_locale "
217 "FROM package_app_localized_info "
218 "WHERE app_id=%Q AND app_locale IN (%Q, %Q)";
225 query = sqlite3_mprintf(query_raw, appid, locale, DEFAULT_LOCALE);
227 LOGE("out of memory");
228 return PMINFO_R_ERROR;
231 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
233 if (ret != SQLITE_OK) {
234 LOGE("prepare failed: %s", sqlite3_errmsg(db));
235 return PMINFO_R_ERROR;
238 while (sqlite3_step(stmt) == SQLITE_ROW) {
239 info = calloc(1, sizeof(label_x));
241 LOGE("out of memory");
242 sqlite3_finalize(stmt);
243 return PMINFO_R_ERROR;
246 _save_column_str(stmt, idx++, &info->text);
247 _save_column_str(stmt, idx++, &info->lang);
248 *label = g_list_append(*label, info);
251 sqlite3_finalize(stmt);
256 static void _appinfo_modify_icon(const char *appid, const char **icon)
258 char buf[PKG_VALUE_STRING_LEN_MAX];
261 if (*icon == NULL || (*icon)[0] == '/' || !strcasecmp(*icon, "(null)"))
265 snprintf(buf, sizeof(buf), "%s%s.png", getIconPath(getuid()), appid);
270 static int _appinfo_get_icon(sqlite3 *db, const char *appid, const char *locale,
273 static const char query_raw[] =
274 "SELECT app_icon, app_locale "
275 "FROM package_app_localized_info "
276 "WHERE app_id=%Q AND app_locale IN (%Q, %Q)";
283 query = sqlite3_mprintf(query_raw, appid, locale, DEFAULT_LOCALE);
285 LOGE("out of memory");
286 return PMINFO_R_ERROR;
289 ret = sqlite3_prepare_v2(db, query, strlen(query),
292 if (ret != SQLITE_OK) {
293 LOGE("prepare failed: %s", sqlite3_errmsg(db));
294 return PMINFO_R_ERROR;
297 while (sqlite3_step(stmt) == SQLITE_ROW) {
298 info = calloc(1, sizeof(icon_x));
300 LOGE("out of memory");
301 sqlite3_finalize(stmt);
302 return PMINFO_R_ERROR;
305 _save_column_str(stmt, idx++, &info->text);
306 /* FIXME: this is a workaround. this must be removed later */
307 _appinfo_modify_icon(appid, &info->text);
308 _save_column_str(stmt, idx++, &info->lang);
309 *icon = g_list_append(*icon, info);
312 sqlite3_finalize(stmt);
317 static int _appinfo_get_category(sqlite3 *db, const char *appid,
320 static const char query_raw[] =
321 "SELECT category FROM package_app_app_category WHERE app_id=%Q";
327 query = sqlite3_mprintf(query_raw, appid);
329 LOGE("out of memory");
330 return PMINFO_R_ERROR;
333 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
335 if (ret != SQLITE_OK) {
336 LOGE("prepare failed: %s", sqlite3_errmsg(db));
337 return PMINFO_R_ERROR;
340 while (sqlite3_step(stmt) == SQLITE_ROW) {
342 _save_column_str(stmt, 0, &val);
344 *category = g_list_append(*category, (gpointer)val);
347 sqlite3_finalize(stmt);
352 static void __parse_appcontrol(GList **appcontrol, char *appcontrol_str)
359 if (appcontrol_str == NULL)
362 dup = strdup(appcontrol_str);
364 ac = calloc(1, sizeof(appcontrol_x));
366 _LOGE("out of memory");
369 token = strtok_r(dup, "|", &ptr);
370 if (token && strcmp(token, "NULL"))
371 ac->operation = strdup(token);
372 token = strtok_r(NULL, "|", &ptr);
373 if (token && strcmp(token, "NULL"))
374 ac->uri = strdup(token);
375 token = strtok_r(NULL, "|", &ptr);
376 if (token && strcmp(token, "NULL"))
377 ac->mime = strdup(token);
378 *appcontrol = g_list_append(*appcontrol, ac);
379 } while ((token = strtok_r(NULL, ";", &ptr)));
384 static int _appinfo_get_app_control(sqlite3 *db, const char *appid,
387 static const char query_raw[] =
388 "SELECT app_control FROM package_app_app_control "
395 query = sqlite3_mprintf(query_raw, appid);
397 LOGE("out of memory");
398 return PMINFO_R_ERROR;
401 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
403 if (ret != SQLITE_OK) {
404 LOGE("prepare failed: %s", sqlite3_errmsg(db));
405 return PMINFO_R_ERROR;
408 while (sqlite3_step(stmt) == SQLITE_ROW) {
410 _save_column_str(stmt, 0, (const char **)&str);
412 __parse_appcontrol(appcontrol, str);
416 sqlite3_finalize(stmt);
421 static int _appinfo_get_data_control(sqlite3 *db, const char *appid,
424 static const char query_raw[] =
425 "SELECT providerid, access, type "
426 "FROM package_app_data_control WHERE app_id=%Q";
433 query = sqlite3_mprintf(query_raw, appid);
435 LOGE("out of memory");
436 return PMINFO_R_ERROR;
439 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
441 if (ret != SQLITE_OK) {
442 LOGE("prepare failed: %s", sqlite3_errmsg(db));
443 return PMINFO_R_ERROR;
446 while (sqlite3_step(stmt) == SQLITE_ROW) {
447 info = calloc(1, sizeof(datacontrol_x));
449 LOGE("out of memory");
450 sqlite3_finalize(stmt);
451 return PMINFO_R_ERROR;
454 _save_column_str(stmt, idx++, &info->providerid);
455 _save_column_str(stmt, idx++, &info->access);
456 _save_column_str(stmt, idx++, &info->type);
457 *datacontrol = g_list_append(*datacontrol, info);
460 sqlite3_finalize(stmt);
465 static int _appinfo_get_metadata(sqlite3 *db, const char *appid,
468 static const char query_raw[] =
469 "SELECT md_key, md_value "
470 "FROM package_app_app_metadata WHERE app_id=%Q";
477 query = sqlite3_mprintf(query_raw, appid);
479 LOGE("out of memory");
480 return PMINFO_R_ERROR;
483 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
485 if (ret != SQLITE_OK) {
486 LOGE("prepare failed: %s", sqlite3_errmsg(db));
487 return PMINFO_R_ERROR;
490 while (sqlite3_step(stmt) == SQLITE_ROW) {
491 info = calloc(1, sizeof(metadata_x));
493 LOGE("out of memory");
494 sqlite3_finalize(stmt);
495 return PMINFO_R_ERROR;
498 _save_column_str(stmt, idx++, &info->key);
499 _save_column_str(stmt, idx++, &info->value);
500 *metadata = g_list_append(*metadata, info);
503 sqlite3_finalize(stmt);
509 static GList *__get_background_category(char *value)
511 GList *category_list = NULL;
512 int convert_value = 0;
513 if (!value || strlen(value) == 0)
516 convert_value = atoi(value);
517 if (convert_value < 0)
520 if (convert_value & APP_BG_CATEGORY_USER_DISABLE_TRUE_VAL)
521 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_USER_DISABLE_TRUE_STR));
523 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_USER_DISABLE_FALSE_STR));
525 if (convert_value & APP_BG_CATEGORY_MEDIA_VAL)
526 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_MEDIA_STR));
528 if (convert_value & APP_BG_CATEGORY_DOWNLOAD_VAL)
529 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_DOWNLOAD_STR));
531 if (convert_value & APP_BG_CATEGORY_BGNETWORK_VAL)
532 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_BGNETWORK_STR));
534 if (convert_value & APP_BG_CATEGORY_LOCATION_VAL)
535 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_LOCATION_STR));
537 if (convert_value & APP_BG_CATEGORY_SENSOR_VAL)
538 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_SENSOR_STR));
540 if (convert_value & APP_BG_CATEGORY_IOTCOMM_VAL)
541 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_IOTCOMM_STR));
543 if (convert_value & APP_BG_CATEGORY_SYSTEM_VAL)
544 category_list = g_list_append(category_list, strdup(APP_BG_CATEGORY_SYSTEM));
546 return category_list;
550 static int _appinfo_get_application(sqlite3 *db, const char *appid,
551 const char *locale, application_x **application)
553 static const char query_raw[] =
554 "SELECT app_id, app_component, app_exec, app_nodisplay, "
555 "app_type, app_onboot, app_multiple, app_autorestart, "
556 "app_taskmanage, app_enabled, app_hwacceleration, "
557 "app_screenreader, app_mainapp, app_recentimage, "
558 "app_launchcondition, app_indicatordisplay, app_portraitimg, "
559 "app_landscapeimg, app_guestmodevisibility, "
560 "app_permissiontype, app_preload, app_submode, "
561 "app_submode_mainid, app_launch_mode, app_ui_gadget, "
562 "app_support_disable, "
563 "component_type, package, app_process_pool, app_installed_storage, "
564 "app_background_category "
565 "FROM package_app_info WHERE app_id='%s' AND app_disable='false' "
567 "(SELECT app_id from package_app_disable_for_user WHERE uid='%d')";
569 char query[MAX_QUERY_LEN] = { '\0' };
573 char *bg_category_str = NULL;
574 snprintf(query, MAX_QUERY_LEN - 1, query_raw, appid, (int)getuid());
575 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
576 if (ret != SQLITE_OK) {
577 LOGE("prepare failed: %s", sqlite3_errmsg(db));
578 return PMINFO_R_ERROR;
581 ret = sqlite3_step(stmt);
582 if (ret == SQLITE_DONE) {
583 sqlite3_finalize(stmt);
584 return PMINFO_R_ENOENT;
585 } else if (ret != SQLITE_ROW) {
586 LOGE("step failed: %s", sqlite3_errmsg(db));
587 sqlite3_finalize(stmt);
588 return PMINFO_R_ERROR;
591 info = calloc(1, sizeof(application_x));
593 LOGE("out of memory");
594 sqlite3_finalize(stmt);
595 return PMINFO_R_ERROR;
598 _save_column_str(stmt, idx++, &info->appid);
599 _save_column_str(stmt, idx++, &info->component);
600 _save_column_str(stmt, idx++, &info->exec);
601 _save_column_str(stmt, idx++, &info->nodisplay);
602 _save_column_str(stmt, idx++, &info->type);
603 _save_column_str(stmt, idx++, &info->onboot);
604 _save_column_str(stmt, idx++, &info->multiple);
605 _save_column_str(stmt, idx++, &info->autorestart);
606 _save_column_str(stmt, idx++, &info->taskmanage);
607 _save_column_str(stmt, idx++, &info->enabled);
608 _save_column_str(stmt, idx++, &info->hwacceleration);
609 _save_column_str(stmt, idx++, &info->screenreader);
610 _save_column_str(stmt, idx++, &info->mainapp);
611 _save_column_str(stmt, idx++, &info->recentimage);
612 _save_column_str(stmt, idx++, &info->launchcondition);
613 _save_column_str(stmt, idx++, &info->indicatordisplay);
614 _save_column_str(stmt, idx++, &info->portraitimg);
615 _save_column_str(stmt, idx++, &info->landscapeimg);
616 _save_column_str(stmt, idx++, &info->guestmode_visibility);
617 _save_column_str(stmt, idx++, &info->permission_type);
618 _save_column_str(stmt, idx++, &info->preload);
619 _save_column_str(stmt, idx++, &info->submode);
620 _save_column_str(stmt, idx++, &info->submode_mainid);
621 _save_column_str(stmt, idx++, &info->launch_mode);
622 _save_column_str(stmt, idx++, &info->ui_gadget);
623 _save_column_str(stmt, idx++, &info->support_disable);
624 _save_column_str(stmt, idx++, &info->component_type);
625 _save_column_str(stmt, idx++, &info->package);
626 _save_column_str(stmt, idx++, &info->process_pool);
627 _save_column_str(stmt, idx++, &info->installed_storage);
628 _save_column_str(stmt, idx++, &bg_category_str);
630 info->background_category = __get_background_category(bg_category_str);
632 if (_appinfo_get_label(db, info->appid, locale, &info->label)) {
633 pkgmgrinfo_basic_free_application(info);
634 sqlite3_finalize(stmt);
635 return PMINFO_R_ERROR;
638 if (_appinfo_get_icon(db, info->appid, locale, &info->icon)) {
639 pkgmgrinfo_basic_free_application(info);
640 sqlite3_finalize(stmt);
641 return PMINFO_R_ERROR;
644 if (_appinfo_get_category(db, info->appid, &info->category)) {
645 pkgmgrinfo_basic_free_application(info);
646 sqlite3_finalize(stmt);
647 return PMINFO_R_ERROR;
650 if (_appinfo_get_app_control(db, info->appid, &info->appcontrol)) {
651 pkgmgrinfo_basic_free_application(info);
652 sqlite3_finalize(stmt);
653 return PMINFO_R_ERROR;
656 if (_appinfo_get_data_control(db, info->appid, &info->datacontrol)) {
657 pkgmgrinfo_basic_free_application(info);
658 sqlite3_finalize(stmt);
659 return PMINFO_R_ERROR;
662 if (_appinfo_get_metadata(db, info->appid, &info->metadata)) {
663 pkgmgrinfo_basic_free_application(info);
664 sqlite3_finalize(stmt);
665 return PMINFO_R_ERROR;
670 sqlite3_finalize(stmt);
675 static int _appinfo_get_appinfo(const char *appid, uid_t uid,
676 pkgmgr_appinfo_x **appinfo)
682 pkgmgr_appinfo_x *info;
684 dbpath = getUserPkgParserDBPathUID(uid);
686 return PMINFO_R_ERROR;
688 locale = _get_system_locale();
690 return PMINFO_R_ERROR;
692 ret = sqlite3_open_v2(dbpath, &db, SQLITE_OPEN_READONLY, NULL);
693 if (ret != SQLITE_OK) {
694 _LOGE("failed to open db: %d", ret);
696 return PMINFO_R_ERROR;
699 info = calloc(1, sizeof(pkgmgr_appinfo_x));
701 _LOGE("out of memory");
703 sqlite3_close_v2(db);
704 return PMINFO_R_ERROR;
707 ret = _appinfo_get_application(db, appid, locale, &info->app_info);
708 if (ret != PMINFO_R_OK) {
711 sqlite3_close_v2(db);
715 info->locale = locale;
716 info->package = strdup(info->app_info->package);
720 sqlite3_close_v2(db);
725 API int pkgmgrinfo_appinfo_get_usr_appinfo(const char *appid, uid_t uid,
726 pkgmgrinfo_appinfo_h *handle)
730 if (appid == NULL || handle == NULL) {
731 LOGE("invalid parameter");
732 return PMINFO_R_EINVAL;
735 ret = _appinfo_get_appinfo(appid, uid, (pkgmgr_appinfo_x **)handle);
736 if (ret == PMINFO_R_ENOENT && uid != GLOBAL_USER)
737 ret = _appinfo_get_appinfo(appid, GLOBAL_USER,
738 (pkgmgr_appinfo_x **)handle);
740 if (ret != PMINFO_R_OK)
741 _LOGE("failed to get appinfo of %s for user %d", appid, uid);
746 API int pkgmgrinfo_appinfo_get_appinfo(const char *appid, pkgmgrinfo_appinfo_h *handle)
748 return pkgmgrinfo_appinfo_get_usr_appinfo(appid, GLOBAL_USER, handle);
751 static int _appinfo_get_filtered_foreach_appinfo(uid_t uid,
752 pkgmgrinfo_filter_x *filter, pkgmgrinfo_app_list_cb app_list_cb,
756 pkgmgr_appinfo_x *info;
762 ret = _appinfo_get_filtered_list(filter, uid, &list);
763 if (ret != PMINFO_R_OK)
764 return PMINFO_R_ERROR;
766 for (tmp = list; tmp; tmp = tmp->next) {
767 appid = (char *)tmp->data;
769 ret = _appinfo_get_appinfo(appid, uid, &info);
770 if (ret == PMINFO_R_ENOENT && uid != GLOBAL_USER)
771 ret = _appinfo_get_appinfo(appid, GLOBAL_USER,
773 if (ret != PMINFO_R_OK) {
777 if (app_list_cb(info, user_data) < 0)
779 pkgmgrinfo_appinfo_destroy_appinfo(info);
789 API int pkgmgrinfo_appinfo_get_usr_list(pkgmgrinfo_pkginfo_h handle,
790 pkgmgrinfo_app_component component,
791 pkgmgrinfo_app_list_cb app_func, void *user_data, uid_t uid)
794 pkgmgrinfo_appinfo_filter_h filter;
796 const char *comp_str = NULL;
798 if (handle == NULL || app_func == NULL) {
799 LOGE("invalied parameter");
800 return PMINFO_R_EINVAL;
803 if (pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid)) {
804 LOGE("invalid parameter");
805 return PMINFO_R_EINVAL;
808 if (pkgmgrinfo_appinfo_filter_create(&filter))
809 return PMINFO_R_ERROR;
811 if (pkgmgrinfo_appinfo_filter_add_string(filter,
812 PMINFO_APPINFO_PROP_APP_PACKAGE, pkgid)) {
813 pkgmgrinfo_appinfo_filter_destroy(filter);
814 return PMINFO_R_ERROR;
817 if (uid == GLOBAL_USER) {
818 if (pkgmgrinfo_appinfo_filter_add_int(filter,
819 PMINFO_APPINFO_PROP_APP_DISABLE_FOR_USER, (int)getuid())) {
820 pkgmgrinfo_appinfo_filter_destroy(filter);
821 return PMINFO_R_ERROR;
827 comp_str = PMINFO_APPINFO_UI_APP;
830 comp_str = PMINFO_APPINFO_SVC_APP;
837 if (pkgmgrinfo_appinfo_filter_add_string(filter,
838 PMINFO_APPINFO_PROP_APP_COMPONENT,
840 pkgmgrinfo_appinfo_filter_destroy(filter);
841 return PMINFO_R_ERROR;
845 ret = _appinfo_get_filtered_foreach_appinfo(uid, filter, app_func,
848 pkgmgrinfo_appinfo_filter_destroy(filter);
853 API int pkgmgrinfo_appinfo_get_list(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_app_component component,
854 pkgmgrinfo_app_list_cb app_func, void *user_data)
856 return pkgmgrinfo_appinfo_get_usr_list(handle, component, app_func, user_data, GLOBAL_USER);
859 API int pkgmgrinfo_appinfo_get_usr_install_list(pkgmgrinfo_app_list_cb app_func, uid_t uid, void *user_data)
861 if (app_func == NULL) {
862 LOGE("invalid parameter");
863 return PMINFO_R_EINVAL;
866 return _appinfo_get_filtered_foreach_appinfo(uid, NULL, app_func,
870 API int pkgmgrinfo_appinfo_get_install_list(pkgmgrinfo_app_list_cb app_func, void *user_data)
872 return pkgmgrinfo_appinfo_get_usr_install_list(app_func, GLOBAL_USER, user_data);
875 API int pkgmgrinfo_appinfo_get_usr_installed_list(pkgmgrinfo_app_list_cb app_func, uid_t uid, void *user_data)
877 if (app_func == NULL) {
878 LOGE("invalid parameter");
879 return PMINFO_R_EINVAL;
882 return _appinfo_get_filtered_foreach_appinfo(uid, NULL, app_func,
886 API int pkgmgrinfo_appinfo_get_installed_list(pkgmgrinfo_app_list_cb app_func, void *user_data)
888 return pkgmgrinfo_appinfo_get_usr_installed_list(app_func, GLOBAL_USER, user_data);
891 API int pkgmgrinfo_appinfo_get_appid(pkgmgrinfo_appinfo_h handle, char **appid)
893 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
895 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
896 retvm_if(appid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
898 if (info->app_info == NULL || info->app_info->appid == NULL)
899 return PMINFO_R_ERROR;
900 *appid = (char *)info->app_info->appid;
905 API int pkgmgrinfo_appinfo_get_pkgname(pkgmgrinfo_appinfo_h handle, char **pkg_name)
907 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
909 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
910 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
912 if (info->package == NULL)
913 return PMINFO_R_ERROR;
915 *pkg_name = (char *)info->package;
920 API int pkgmgrinfo_appinfo_get_pkgid(pkgmgrinfo_appinfo_h handle, char **pkgid)
922 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
924 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
925 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
927 if (info->package == NULL)
928 return PMINFO_R_ERROR;
930 *pkgid = (char *)info->package;
935 API int pkgmgrinfo_appinfo_get_exec(pkgmgrinfo_appinfo_h handle, char **exec)
937 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
939 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
940 retvm_if(exec == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
942 if (info->app_info == NULL || info->app_info->exec == NULL)
943 return PMINFO_R_ERROR;
944 *exec = (char *)info->app_info->exec;
950 API int pkgmgrinfo_appinfo_get_icon(pkgmgrinfo_appinfo_h handle, char **icon)
955 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
957 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
958 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
960 locale = info->locale;
961 retvm_if(locale == NULL, PMINFO_R_ERROR, "manifest locale is NULL");
963 if (info->app_info == NULL)
964 return PMINFO_R_ERROR;
966 for (tmp = info->app_info->icon; tmp; tmp = tmp->next) {
967 ptr = (icon_x *)tmp->data;
968 if (ptr == NULL || ptr->text == NULL || ptr->lang == NULL ||
969 !strcasecmp(ptr->text, "(null)") ||
970 strcmp(ptr->lang, locale))
972 *icon = (char *)ptr->text;
976 locale = DEFAULT_LOCALE;
977 for (tmp = info->app_info->icon; tmp; tmp = tmp->next) {
978 ptr = (icon_x *)tmp->data;
979 if (ptr == NULL || ptr->text == NULL || ptr->lang == NULL ||
980 strcmp(ptr->lang, locale))
982 *icon = (char *)ptr->text;
986 return PMINFO_R_ERROR;
990 API int pkgmgrinfo_appinfo_get_label(pkgmgrinfo_appinfo_h handle, char **label)
995 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
997 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
998 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1000 locale = info->locale;
1001 retvm_if(locale == NULL, PMINFO_R_ERROR, "manifest locale is NULL");
1003 if (info->app_info == NULL)
1004 return PMINFO_R_ERROR;
1006 for (tmp = info->app_info->label; tmp; tmp = tmp->next) {
1007 ptr = (label_x *)tmp->data;
1008 if (ptr == NULL || ptr->text == NULL || ptr->lang == NULL ||
1009 strcmp(ptr->lang, locale))
1011 *label = (char *)ptr->text;
1015 locale = DEFAULT_LOCALE;
1016 for (tmp = info->app_info->label; tmp; tmp = tmp->next) {
1017 ptr = (label_x *)tmp->data;
1018 if (ptr == NULL || ptr->text == NULL || ptr->lang == NULL ||
1019 strcmp(ptr->lang, locale))
1021 *label = (char *)ptr->text;
1025 return PMINFO_R_ERROR;
1028 static char *_get_localed_label(const char *appid, const char *locale, uid_t uid)
1030 char *result = NULL;
1032 sqlite3_stmt *stmt = NULL;
1035 const char *manifest_db;
1037 manifest_db = getUserPkgParserDBPathUID(uid);
1038 if (manifest_db == NULL) {
1039 _LOGE("Failed to get manifest db path");
1043 if (sqlite3_open_v2(manifest_db, &db, SQLITE_OPEN_READONLY, NULL) != SQLITE_OK) {
1044 _LOGE("DB open fail\n");
1048 query = sqlite3_mprintf("select app_label from package_app_localized_info where app_id=%Q and app_locale=%Q", appid, locale);
1049 if (query == NULL) {
1050 _LOGE("Out of memory");
1054 if (sqlite3_prepare_v2(db, query, -1, &stmt, NULL) != SQLITE_OK) {
1055 _LOGE("prepare_v2 fail\n");
1059 if (sqlite3_step(stmt) == SQLITE_ROW) {
1060 val = (char *)sqlite3_column_text(stmt, 0);
1062 result = strdup(val);
1066 sqlite3_finalize(stmt);
1067 sqlite3_free(query);
1073 API int pkgmgrinfo_appinfo_usr_get_localed_label(const char *appid, const char *locale, uid_t uid, char **label)
1077 retvm_if(appid == NULL || locale == NULL || label == NULL, PMINFO_R_EINVAL, "Argument is NULL");
1079 val = _get_localed_label(appid, locale, uid);
1081 val = _get_localed_label(appid, DEFAULT_LOCALE, uid);
1084 return PMINFO_R_ERROR;
1091 API int pkgmgrinfo_appinfo_get_localed_label(const char *appid, const char *locale, char **label)
1093 return pkgmgrinfo_appinfo_usr_get_localed_label(appid, locale, GLOBAL_USER, label);
1096 static pkgmgrinfo_app_component __appcomponent_convert(const char *comp)
1098 if ( strcasecmp(comp, "uiapp") == 0)
1099 return PMINFO_UI_APP;
1100 else if ( strcasecmp(comp, "svcapp") == 0)
1101 return PMINFO_SVC_APP;
1106 API int pkgmgrinfo_appinfo_get_component(pkgmgrinfo_appinfo_h handle, pkgmgrinfo_app_component *component)
1108 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1111 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1112 retvm_if(component == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1114 if (info->app_info == NULL)
1115 return PMINFO_R_ERROR;
1117 comp = __appcomponent_convert(info->app_info->component);
1119 return PMINFO_R_ERROR;
1126 API int pkgmgrinfo_appinfo_get_apptype(pkgmgrinfo_appinfo_h handle, char **app_type)
1128 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1130 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1131 retvm_if(app_type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1133 if (info->app_info == NULL || info->app_info->type == NULL)
1134 return PMINFO_R_ERROR;
1135 *app_type = (char *)info->app_info->type;
1140 API int pkgmgrinfo_appinfo_get_operation(pkgmgrinfo_appcontrol_h handle,
1141 int *operation_count, char ***operation)
1143 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1144 retvm_if(operation == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1145 retvm_if(operation_count == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1146 pkgmgrinfo_appcontrol_x *data = (pkgmgrinfo_appcontrol_x *)handle;
1147 *operation_count = data->operation_count;
1148 *operation = data->operation;
1152 API int pkgmgrinfo_appinfo_get_uri(pkgmgrinfo_appcontrol_h handle,
1153 int *uri_count, char ***uri)
1155 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1156 retvm_if(uri == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1157 retvm_if(uri_count == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1158 pkgmgrinfo_appcontrol_x *data = (pkgmgrinfo_appcontrol_x *)handle;
1159 *uri_count = data->uri_count;
1164 API int pkgmgrinfo_appinfo_get_mime(pkgmgrinfo_appcontrol_h handle,
1165 int *mime_count, char ***mime)
1167 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1168 retvm_if(mime == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1169 retvm_if(mime_count == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1170 pkgmgrinfo_appcontrol_x *data = (pkgmgrinfo_appcontrol_x *)handle;
1171 *mime_count = data->mime_count;
1176 API int pkgmgrinfo_appinfo_get_subapp(pkgmgrinfo_appcontrol_h handle,
1177 int *subapp_count, char ***subapp)
1179 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1180 retvm_if(subapp == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1181 retvm_if(subapp_count == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1182 pkgmgrinfo_appcontrol_x *data = (pkgmgrinfo_appcontrol_x *)handle;
1183 *subapp_count = data->subapp_count;
1184 *subapp = data->subapp;
1188 API int pkgmgrinfo_appinfo_get_setting_icon(pkgmgrinfo_appinfo_h handle, char **icon)
1193 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1195 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1196 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1198 if (info->app_info == NULL)
1199 return PMINFO_R_ERROR;
1201 for (tmp = info->app_info->icon; tmp; tmp = tmp->next) {
1202 ptr = (icon_x *)tmp->data;
1203 if (ptr == NULL || ptr->section == NULL)
1206 val = (char *)ptr->section;
1207 if (val && strcmp(val, "setting") == 0) {
1208 *icon = (char *)ptr->text;
1213 return PMINFO_R_ERROR;
1217 API int pkgmgrinfo_appinfo_get_notification_icon(pkgmgrinfo_appinfo_h handle, char **icon)
1222 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1224 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1225 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1227 if (info->app_info == NULL)
1228 return PMINFO_R_ERROR;
1230 for (tmp = info->app_info->icon; tmp; tmp = tmp->next) {
1231 ptr = (icon_x *)tmp->data;
1232 if (ptr == NULL || ptr->section == NULL)
1235 val = (char *)ptr->section;
1236 if (val && strcmp(val, "notification") == 0){
1237 *icon = (char *)ptr->text;
1242 return PMINFO_R_ERROR;
1245 API int pkgmgrinfo_appinfo_get_recent_image_type(pkgmgrinfo_appinfo_h handle, pkgmgrinfo_app_recentimage *type)
1248 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1250 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1251 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1253 if (info->app_info == NULL || info->app_info->recentimage == NULL)
1254 return PMINFO_R_ERROR;
1256 val = (char *)info->app_info->recentimage;
1257 if (strcasecmp(val, "capture") == 0)
1258 *type = PMINFO_RECENTIMAGE_USE_CAPTURE;
1259 else if (strcasecmp(val, "icon") == 0)
1260 *type = PMINFO_RECENTIMAGE_USE_ICON;
1262 *type = PMINFO_RECENTIMAGE_USE_NOTHING;
1267 API int pkgmgrinfo_appinfo_get_preview_image(pkgmgrinfo_appinfo_h handle, char **preview_img)
1272 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1274 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1275 retvm_if(preview_img == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1277 if (info->app_info == NULL)
1278 return PMINFO_R_ERROR;
1280 for (tmp = info->app_info->image; tmp; tmp = tmp->next) {
1281 ptr = (image_x *)tmp->data;
1282 if (ptr == NULL || ptr->section == NULL)
1285 val = (char *)ptr->section;
1286 if (val && strcmp(val, "preview") == 0) {
1287 *preview_img = (char *)ptr->text;
1292 return PMINFO_R_ERROR;
1295 API int pkgmgrinfo_appinfo_get_permission_type(pkgmgrinfo_appinfo_h handle, pkgmgrinfo_permission_type *permission)
1298 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1300 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1301 retvm_if(permission == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1303 val = info->app_info->permission_type;
1305 return PMINFO_R_ERROR;
1307 if (strcmp(val, "signature") == 0)
1308 *permission = PMINFO_PERMISSION_SIGNATURE;
1309 else if (strcmp(val, "privilege") == 0)
1310 *permission = PMINFO_PERMISSION_PRIVILEGE;
1312 *permission = PMINFO_PERMISSION_NORMAL;
1317 API int pkgmgrinfo_appinfo_get_component_type(pkgmgrinfo_appinfo_h handle, char **component_type)
1319 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1321 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1322 retvm_if(component_type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1324 if (info->app_info == NULL || info->app_info->component_type == NULL)
1325 return PMINFO_R_ERROR;
1327 *component_type = (char *)info->app_info->component_type;
1332 API int pkgmgrinfo_appinfo_get_hwacceleration(pkgmgrinfo_appinfo_h handle, pkgmgrinfo_app_hwacceleration *hwacceleration)
1335 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1337 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1338 retvm_if(hwacceleration == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1340 if (info->app_info == NULL || info->app_info->hwacceleration == NULL)
1341 return PMINFO_R_ERROR;
1343 val = (char *)info->app_info->hwacceleration;
1344 if (strcasecmp(val, "not-use-GL") == 0)
1345 *hwacceleration = PMINFO_HWACCELERATION_NOT_USE_GL;
1346 else if (strcasecmp(val, "use-GL") == 0)
1347 *hwacceleration = PMINFO_HWACCELERATION_USE_GL;
1349 *hwacceleration = PMINFO_HWACCELERATION_USE_SYSTEM_SETTING;
1354 API int pkgmgrinfo_appinfo_get_screenreader(pkgmgrinfo_appinfo_h handle, pkgmgrinfo_app_screenreader *screenreader)
1357 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1359 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1360 retvm_if(screenreader == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1362 if (info->app_info == NULL || info->app_info->screenreader == NULL)
1363 return PMINFO_R_ERROR;
1365 val = (char *)info->app_info->screenreader;
1366 if (strcasecmp(val, "screenreader-off") == 0)
1367 *screenreader = PMINFO_SCREENREADER_OFF;
1368 else if (strcasecmp(val, "screenreader-on") == 0)
1369 *screenreader = PMINFO_SCREENREADER_ON;
1371 *screenreader = PMINFO_SCREENREADER_USE_SYSTEM_SETTING;
1376 API int pkgmgrinfo_appinfo_get_effectimage(pkgmgrinfo_appinfo_h handle, char **portrait_img, char **landscape_img)
1378 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1380 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1381 retvm_if(portrait_img == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1382 retvm_if(landscape_img == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1384 if (info->app_info == NULL || info->app_info->portraitimg ||
1385 info->app_info->landscapeimg == NULL)
1386 return PMINFO_R_ERROR;
1388 *portrait_img = (char *)info->app_info->portraitimg;
1389 *landscape_img = (char *)info->app_info->landscapeimg;
1394 API int pkgmgrinfo_appinfo_get_effectimage_type(pkgmgrinfo_appinfo_h handle, char **effectimage_type)
1396 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1398 if (handle == NULL || effectimage_type == NULL) {
1399 LOGE("invalid parameter");
1400 return PMINFO_R_EINVAL;
1403 if (info->app_info == NULL || info->app_info->effectimage_type == NULL)
1404 return PMINFO_R_ERROR;
1406 *effectimage_type = (char *)info->app_info->effectimage_type;
1411 API int pkgmgrinfo_appinfo_get_submode_mainid(pkgmgrinfo_appinfo_h handle, char **submode_mainid)
1413 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1415 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1416 retvm_if(submode_mainid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1418 if (info->app_info == NULL || info->app_info->submode_mainid == NULL)
1419 return PMINFO_R_ERROR;
1421 *submode_mainid = (char *)info->app_info->submode_mainid;
1426 API int pkgmgrinfo_appinfo_get_installed_storage_location(pkgmgrinfo_appinfo_h handle, pkgmgrinfo_installed_storage *storage)
1428 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1429 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1431 if (info->app_info && info->app_info->installed_storage){
1432 if (strcmp(info->app_info->installed_storage,"installed_internal") == 0)
1433 *storage = PMINFO_INTERNAL_STORAGE;
1434 else if (strcmp(info->app_info->installed_storage,"installed_external") == 0)
1435 *storage = PMINFO_EXTERNAL_STORAGE;
1437 return PMINFO_R_ERROR;
1439 return PMINFO_R_ERROR;
1444 API int pkgmgrinfo_appinfo_get_launch_mode(pkgmgrinfo_appinfo_h handle, char **mode)
1446 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1448 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1449 retvm_if(mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1451 if (info->app_info->launch_mode == NULL)
1452 return PMINFO_R_ERROR;
1454 *mode = (char *)(info->app_info->launch_mode);
1459 API int pkgmgrinfo_appinfo_get_alias_appid(pkgmgrinfo_appinfo_h handle, char **alias_appid)
1461 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1463 if (handle == NULL || alias_appid == NULL) {
1464 LOGE("invalid parameter");
1465 return PMINFO_R_EINVAL;
1468 if (info->app_info == NULL || info->app_info->alias_appid == NULL)
1469 return PMINFO_R_ERROR;
1471 *alias_appid = (char *)info->app_info->alias_appid;
1476 API int pkgmgrinfo_appinfo_get_effective_appid(pkgmgrinfo_appinfo_h handle, char **effective_appid)
1478 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1480 if (handle == NULL || effective_appid == NULL) {
1481 LOGE("invalid parameter");
1482 return PMINFO_R_EINVAL;
1485 if (info->app_info == NULL || info->app_info->effective_appid == NULL)
1486 return PMINFO_R_ERROR;
1488 *effective_appid = (char *)info->app_info->effective_appid;
1493 API int pkgmgrinfo_appinfo_usr_get_datacontrol_info(const char *providerid, const char *type, uid_t uid, char **appid, char **access)
1495 retvm_if(providerid == NULL, PMINFO_R_EINVAL, "Argument supplied is NULL\n");
1496 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied is NULL\n");
1497 retvm_if(appid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1498 retvm_if(access == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1500 int ret = PMINFO_R_OK;
1502 sqlite3_stmt *stmt = NULL;
1505 ret = __open_manifest_db(uid, true);
1506 retvm_if(ret != SQLITE_OK, ret = PMINFO_R_ERROR, "connect db [%s] failed!", MANIFEST_DB);
1508 /*Start constructing query*/
1509 query = sqlite3_mprintf("select * from package_app_data_control where providerid=%Q and type=%Q", providerid, type);
1512 ret = sqlite3_prepare_v2(GET_DB(manifest_db), query, strlen(query), &stmt, NULL);
1513 tryvm_if(ret != PMINFO_R_OK, ret = PMINFO_R_ERROR, "sqlite3_prepare_v2 failed[%s]\n", query);
1516 ret = sqlite3_step(stmt);
1517 tryvm_if((ret != SQLITE_ROW) || (ret == SQLITE_DONE), ret = PMINFO_R_ERROR, "No records found");
1519 *appid = strdup((char *)sqlite3_column_text(stmt, 0));
1520 *access = strdup((char *)sqlite3_column_text(stmt, 2));
1525 sqlite3_free(query);
1526 sqlite3_finalize(stmt);
1527 __close_manifest_db();
1531 API int pkgmgrinfo_appinfo_get_datacontrol_info(const char *providerid, const char *type, char **appid, char **access)
1533 return pkgmgrinfo_appinfo_usr_get_datacontrol_info(providerid, type, GLOBAL_USER, appid, access);
1536 API int pkgmgrinfo_appinfo_usr_get_datacontrol_appid(const char *providerid, uid_t uid, char **appid)
1538 retvm_if(providerid == NULL, PMINFO_R_EINVAL, "Argument supplied is NULL\n");
1539 retvm_if(appid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1541 int ret = PMINFO_R_OK;
1543 sqlite3_stmt *stmt = NULL;
1546 ret = __open_manifest_db(uid, true);
1547 retvm_if(ret != SQLITE_OK, ret = PMINFO_R_ERROR, "connect db [%s] failed!", MANIFEST_DB);
1549 /*Start constructing query*/
1550 query = sqlite3_mprintf("select * from package_app_data_control where providerid=%Q", providerid);
1553 ret = sqlite3_prepare_v2(GET_DB(manifest_db), query, strlen(query), &stmt, NULL);
1554 tryvm_if(ret != PMINFO_R_OK, ret = PMINFO_R_ERROR, "sqlite3_prepare_v2 failed[%s]\n", query);
1557 ret = sqlite3_step(stmt);
1558 tryvm_if((ret != SQLITE_ROW) || (ret == SQLITE_DONE), ret = PMINFO_R_ERROR, "No records found");
1560 *appid = strdup((char *)sqlite3_column_text(stmt, 0));
1565 sqlite3_free(query);
1566 sqlite3_finalize(stmt);
1567 __close_manifest_db();
1571 API int pkgmgrinfo_appinfo_get_datacontrol_appid(const char *providerid, char **appid)
1573 return pkgmgrinfo_appinfo_usr_get_datacontrol_appid(providerid, GLOBAL_USER, appid);
1576 API int pkgmgrinfo_appinfo_foreach_permission(pkgmgrinfo_appinfo_h handle,
1577 pkgmgrinfo_app_permission_list_cb permission_func, void *user_data)
1579 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1580 retvm_if(permission_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1584 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1586 if (info->app_info == NULL)
1587 return PMINFO_R_ERROR;
1589 for (tmp = info->app_info->permission; tmp; tmp = tmp->next) {
1590 ptr = (permission_x *)tmp->data;
1594 ret = permission_func(ptr->value, user_data);
1602 API int pkgmgrinfo_appinfo_foreach_category(pkgmgrinfo_appinfo_h handle,
1603 pkgmgrinfo_app_category_list_cb category_func, void *user_data)
1605 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1606 retvm_if(category_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1608 const char *category;
1610 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1612 if (info->app_info == NULL)
1613 return PMINFO_R_ERROR;
1615 for (tmp = info->app_info->category; tmp; tmp = tmp->next) {
1616 category = (const char *)tmp->data;
1618 ret = category_func(category, user_data);
1626 API int pkgmgrinfo_appinfo_foreach_metadata(pkgmgrinfo_appinfo_h handle,
1627 pkgmgrinfo_app_metadata_list_cb metadata_func, void *user_data)
1629 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1630 retvm_if(metadata_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1634 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1636 if (info->app_info == NULL)
1637 return PMINFO_R_ERROR;
1639 for (tmp = info->app_info->metadata; tmp; tmp = tmp->next) {
1640 ptr = (metadata_x *)tmp->data;
1644 ret = metadata_func(ptr->key, ptr->value, user_data);
1652 API int pkgmgrinfo_appinfo_foreach_appcontrol(pkgmgrinfo_appinfo_h handle,
1653 pkgmgrinfo_app_control_list_cb appcontrol_func, void *user_data)
1655 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1656 retvm_if(appcontrol_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1658 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1659 appcontrol_x *appcontrol;
1662 if (info->app_info == NULL)
1663 return PMINFO_R_ERROR;
1665 for (tmp = info->app_info->appcontrol; tmp; tmp = tmp->next) {
1666 appcontrol = (appcontrol_x *)tmp->data;
1667 if (appcontrol == NULL)
1669 ret = appcontrol_func(appcontrol->operation, appcontrol->uri, appcontrol->mime, user_data);
1677 API int pkgmgrinfo_appinfo_foreach_background_category(
1678 pkgmgrinfo_appinfo_h handle,
1679 pkgmgrinfo_app_background_category_list_cb category_func,
1682 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1686 if (handle == NULL || category_func == NULL || info->app_info == NULL) {
1687 LOGE("invalid parameter");
1688 return PMINFO_R_EINVAL;
1691 for (tmp = info->app_info->background_category; tmp; tmp = tmp->next) {
1692 category = (char *)tmp->data;
1693 if (category == NULL)
1696 if (category_func(category, user_data) < 0)
1703 API int pkgmgrinfo_appinfo_is_nodisplay(pkgmgrinfo_appinfo_h handle, bool *nodisplay)
1705 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1706 retvm_if(nodisplay == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1707 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1709 if (info->app_info == NULL || info->app_info->nodisplay == NULL)
1710 return PMINFO_R_ERROR;
1712 *nodisplay = _get_bool_value(info->app_info->nodisplay);
1717 API int pkgmgrinfo_appinfo_is_multiple(pkgmgrinfo_appinfo_h handle, bool *multiple)
1719 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1720 retvm_if(multiple == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1721 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1723 if (info->app_info == NULL || info->app_info->multiple == NULL)
1724 return PMINFO_R_ERROR;
1726 *multiple = _get_bool_value(info->app_info->multiple);
1731 API int pkgmgrinfo_appinfo_is_indicator_display_allowed(pkgmgrinfo_appinfo_h handle, bool *indicator_disp)
1733 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1734 retvm_if(indicator_disp == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1735 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1737 if (info->app_info == NULL || info->app_info->indicatordisplay == NULL)
1738 return PMINFO_R_ERROR;
1740 *indicator_disp = _get_bool_value(info->app_info->indicatordisplay);
1745 API int pkgmgrinfo_appinfo_is_taskmanage(pkgmgrinfo_appinfo_h handle, bool *taskmanage)
1747 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1748 retvm_if(taskmanage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1749 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1751 if (info->app_info == NULL || info->app_info->taskmanage == NULL)
1752 return PMINFO_R_ERROR;
1754 *taskmanage = _get_bool_value(info->app_info->taskmanage);
1759 API int pkgmgrinfo_appinfo_is_enabled(pkgmgrinfo_appinfo_h handle, bool *enabled)
1761 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1762 retvm_if(enabled == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1763 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1765 if (info->app_info == NULL || info->app_info->enabled == NULL)
1766 return PMINFO_R_ERROR;
1768 *enabled = _get_bool_value(info->app_info->enabled);
1773 API int pkgmgrinfo_appinfo_is_onboot(pkgmgrinfo_appinfo_h handle, bool *onboot)
1775 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1776 retvm_if(onboot == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1777 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1779 if (info->app_info == NULL || info->app_info->onboot == NULL)
1780 return PMINFO_R_ERROR;
1782 *onboot = _get_bool_value(info->app_info->onboot);
1787 API int pkgmgrinfo_appinfo_is_autorestart(pkgmgrinfo_appinfo_h handle, bool *autorestart)
1789 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1790 retvm_if(autorestart == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1791 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1793 if (info->app_info == NULL || info->app_info->autorestart == NULL)
1794 return PMINFO_R_ERROR;
1796 *autorestart = _get_bool_value(info->app_info->autorestart);
1801 API int pkgmgrinfo_appinfo_is_mainapp(pkgmgrinfo_appinfo_h handle, bool *mainapp)
1803 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1804 retvm_if(mainapp == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1805 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1807 if (info->app_info == NULL || info->app_info->mainapp == NULL)
1808 return PMINFO_R_ERROR;
1810 *mainapp = _get_bool_value(info->app_info->mainapp);
1815 API int pkgmgrinfo_appinfo_is_preload(pkgmgrinfo_appinfo_h handle, bool *preload)
1817 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1818 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1819 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1821 if (info->app_info == NULL || info->app_info->preload == NULL)
1822 return PMINFO_R_ERROR;
1824 *preload = _get_bool_value(info->app_info->preload);
1829 API int pkgmgrinfo_appinfo_is_submode(pkgmgrinfo_appinfo_h handle, bool *submode)
1831 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
1832 retvm_if(submode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1833 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1835 if (info->app_info == NULL || info->app_info->submode == NULL)
1836 return PMINFO_R_ERROR;
1838 *submode = _get_bool_value(info->app_info->submode);
1843 API int pkgmgrinfo_appinfo_is_process_pool(pkgmgrinfo_appinfo_h handle, bool *process_pool)
1845 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1847 if (handle == NULL || process_pool == NULL) {
1848 LOGE("invalid parameter");
1849 return PMINFO_R_EINVAL;
1852 if (info->app_info == NULL)
1853 return PMINFO_R_ERROR;
1855 *process_pool = _get_bool_value(info->app_info->process_pool);
1860 API int pkgmgrinfo_appinfo_is_category_exist(pkgmgrinfo_appinfo_h handle, const char *category, bool *exist)
1862 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1863 retvm_if(category == NULL, PMINFO_R_EINVAL, "category is NULL");
1864 retvm_if(exist == NULL, PMINFO_R_EINVAL, "exist is NULL");
1868 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1870 if (info->app_info == NULL)
1871 return PMINFO_R_ERROR;
1874 for (tmp = info->app_info->category; tmp; tmp = tmp->next) {
1875 val = (const char *)tmp->data;
1878 if (strcasecmp(val, category) == 0) {
1887 API int pkgmgrinfo_appinfo_is_ui_gadget(pkgmgrinfo_appinfo_h handle,
1890 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1892 if (info == NULL || info->app_info == NULL || ui_gadget == NULL) {
1893 _LOGE("invalid parameter");
1894 return PMINFO_R_EINVAL;
1897 *ui_gadget = _get_bool_value(info->app_info->ui_gadget);
1902 API int pkgmgrinfo_appinfo_is_support_disable(pkgmgrinfo_appinfo_h handle,
1903 bool *support_disable)
1905 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1907 if (info == NULL || info->app_info == NULL || support_disable == NULL) {
1908 _LOGE("invalid parameter");
1909 return PMINFO_R_EINVAL;
1912 *support_disable = _get_bool_value(info->app_info->support_disable);
1917 API int pkgmgrinfo_appinfo_destroy_appinfo(pkgmgrinfo_appinfo_h handle)
1919 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL");
1920 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
1921 __cleanup_appinfo(info);
1925 API int pkgmgrinfo_appinfo_filter_create(pkgmgrinfo_appinfo_filter_h *handle)
1927 return (pkgmgrinfo_pkginfo_filter_create(handle));
1930 API int pkgmgrinfo_appinfo_filter_destroy(pkgmgrinfo_appinfo_filter_h handle)
1932 return (pkgmgrinfo_pkginfo_filter_destroy(handle));
1935 static gint __compare_func(gconstpointer data1, gconstpointer data2)
1937 pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x*)data1;
1938 pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x*)data2;
1939 if (node1->prop == node2->prop)
1941 else if (node1->prop > node2->prop)
1947 API int pkgmgrinfo_appinfo_filter_add_int(pkgmgrinfo_appinfo_filter_h handle,
1948 const char *property, const int value)
1950 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1951 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1952 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1954 GSList *link = NULL;
1956 prop = _pminfo_appinfo_convert_to_prop_int(property);
1957 if (prop < E_PMINFO_APPINFO_PROP_APP_MIN_INT ||
1958 prop > E_PMINFO_APPINFO_PROP_APP_MAX_INT) {
1959 _LOGE("Invalid Integer Property\n");
1960 return PMINFO_R_EINVAL;
1962 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x*)handle;
1963 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x*)calloc(1, sizeof(pkgmgrinfo_node_x));
1965 _LOGE("Out of Memory!!!\n");
1966 return PMINFO_R_ERROR;
1968 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1969 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1971 _LOGE("Out of Memory\n");
1974 return PMINFO_R_ERROR;
1978 /*If API is called multiple times for same property, we should override the previous values.
1979 Last value set will be used for filtering.*/
1980 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1982 filter->list = g_slist_delete_link(filter->list, link);
1983 filter->list = g_slist_append(filter->list, (gpointer)node);
1988 API int pkgmgrinfo_appinfo_filter_add_bool(pkgmgrinfo_appinfo_filter_h handle,
1989 const char *property, const bool value)
1991 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1992 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1994 GSList *link = NULL;
1996 prop = _pminfo_appinfo_convert_to_prop_bool(property);
1997 if (prop < E_PMINFO_APPINFO_PROP_APP_MIN_BOOL ||
1998 prop > E_PMINFO_APPINFO_PROP_APP_MAX_BOOL) {
1999 _LOGE("Invalid Boolean Property\n");
2000 return PMINFO_R_EINVAL;
2002 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x*)handle;
2003 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x*)calloc(1, sizeof(pkgmgrinfo_node_x));
2005 _LOGE("Out of Memory!!!\n");
2006 return PMINFO_R_ERROR;
2009 val = strndup("('true','True')", 15);
2011 val = strndup("('false','False')", 17);
2013 _LOGE("Out of Memory\n");
2016 return PMINFO_R_ERROR;
2020 /*If API is called multiple times for same property, we should override the previous values.
2021 Last value set will be used for filtering.*/
2022 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
2024 filter->list = g_slist_delete_link(filter->list, link);
2025 filter->list = g_slist_append(filter->list, (gpointer)node);
2030 API int pkgmgrinfo_appinfo_filter_add_string(pkgmgrinfo_appinfo_filter_h handle,
2031 const char *property, const char *value)
2033 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
2034 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
2035 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
2037 pkgmgrinfo_node_x *ptr = NULL;
2038 char prev[PKG_STRING_LEN_MAX] = {'\0'};
2039 char temp[PKG_STRING_LEN_MAX] = {'\0'};
2040 GSList *link = NULL;
2042 prop = _pminfo_appinfo_convert_to_prop_str(property);
2043 if (prop < E_PMINFO_APPINFO_PROP_APP_MIN_STR ||
2044 prop > E_PMINFO_APPINFO_PROP_APP_MAX_STR) {
2045 _LOGE("Invalid String Property\n");
2046 return PMINFO_R_EINVAL;
2048 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x*)handle;
2049 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x*)calloc(1, sizeof(pkgmgrinfo_node_x));
2051 _LOGE("Out of Memory!!!\n");
2052 return PMINFO_R_ERROR;
2056 case E_PMINFO_APPINFO_PROP_APP_COMPONENT:
2057 if (strcmp(value, PMINFO_APPINFO_UI_APP) == 0)
2058 val = strndup("uiapp", PKG_STRING_LEN_MAX - 1);
2060 val = strndup("svcapp", PKG_STRING_LEN_MAX - 1);
2062 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
2064 filter->list = g_slist_delete_link(filter->list, link);
2065 filter->list = g_slist_append(filter->list, (gpointer)node);
2067 case E_PMINFO_APPINFO_PROP_APP_CATEGORY:
2068 case E_PMINFO_APPINFO_PROP_APP_OPERATION:
2069 case E_PMINFO_APPINFO_PROP_APP_URI:
2070 case E_PMINFO_APPINFO_PROP_APP_MIME:
2071 val = (char *)calloc(1, PKG_STRING_LEN_MAX);
2073 _LOGE("Out of Memory\n");
2076 return PMINFO_R_ERROR;
2078 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
2080 ptr = (pkgmgrinfo_node_x *)link->data;
2081 strncpy(prev, ptr->value, PKG_STRING_LEN_MAX - 1);
2082 _LOGE("Previous value is %s\n", prev);
2083 filter->list = g_slist_delete_link(filter->list, link);
2084 snprintf(temp, PKG_STRING_LEN_MAX - 1, "%s , '%s'", prev, value);
2085 strncpy(val, temp, PKG_STRING_LEN_MAX - 1);
2086 _LOGE("New value is %s\n", val);
2088 filter->list = g_slist_append(filter->list, (gpointer)node);
2089 memset(temp, '\0', PKG_STRING_LEN_MAX);
2091 snprintf(temp, PKG_STRING_LEN_MAX - 1, "'%s'", value);
2092 strncpy(val, temp, PKG_STRING_LEN_MAX - 1);
2093 _LOGE("First value is %s\n", val);
2095 filter->list = g_slist_append(filter->list, (gpointer)node);
2096 memset(temp, '\0', PKG_STRING_LEN_MAX);
2100 node->value = strndup(value, PKG_STRING_LEN_MAX - 1);
2101 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
2103 filter->list = g_slist_delete_link(filter->list, link);
2104 filter->list = g_slist_append(filter->list, (gpointer)node);
2110 API int pkgmgrinfo_appinfo_usr_filter_count(pkgmgrinfo_appinfo_filter_h handle, int *count, uid_t uid)
2115 if (handle == NULL || count == NULL) {
2116 _LOGE("invalid parameter");
2117 return PMINFO_R_EINVAL;
2120 ret = _appinfo_get_filtered_list(handle, uid, &list);
2121 if (ret != PMINFO_R_OK)
2122 return PMINFO_R_ERROR;
2124 *count = g_list_length(list);
2126 g_list_free_full(list, free);
2131 API int pkgmgrinfo_appinfo_filter_count(pkgmgrinfo_appinfo_filter_h handle, int *count)
2133 return pkgmgrinfo_appinfo_usr_filter_count(handle, count, GLOBAL_USER);
2136 API int pkgmgrinfo_appinfo_usr_filter_foreach_appinfo(
2137 pkgmgrinfo_appinfo_filter_h handle,
2138 pkgmgrinfo_app_list_cb app_cb, void *user_data, uid_t uid)
2140 if (handle == NULL || app_cb == NULL) {
2141 LOGE("invalid parameter");
2142 return PMINFO_R_EINVAL;
2145 return _appinfo_get_filtered_foreach_appinfo(uid, handle, app_cb,
2149 API int pkgmgrinfo_appinfo_filter_foreach_appinfo(pkgmgrinfo_appinfo_filter_h handle,
2150 pkgmgrinfo_app_list_cb app_cb, void * user_data)
2152 return pkgmgrinfo_appinfo_usr_filter_foreach_appinfo(handle, app_cb, user_data, GLOBAL_USER);
2155 API int pkgmgrinfo_appinfo_metadata_filter_create(pkgmgrinfo_appinfo_metadata_filter_h *handle)
2157 return (pkgmgrinfo_pkginfo_filter_create(handle));
2160 API int pkgmgrinfo_appinfo_metadata_filter_destroy(pkgmgrinfo_appinfo_metadata_filter_h handle)
2162 return (pkgmgrinfo_pkginfo_filter_destroy(handle));
2165 API int pkgmgrinfo_appinfo_metadata_filter_add(
2166 pkgmgrinfo_appinfo_metadata_filter_h handle,
2167 const char *key, const char *value)
2171 ret = pkgmgrinfo_appinfo_filter_add_string(handle,
2172 PMINFO_APPINFO_PROP_APP_METADATA_KEY, key);
2173 if (ret != PMINFO_R_OK)
2176 /* value can be NULL.
2177 * In that case all apps with specified key should be displayed
2180 ret = pkgmgrinfo_appinfo_filter_add_string(handle,
2181 PMINFO_APPINFO_PROP_APP_METADATA_VALUE, value);
2182 if (ret != PMINFO_R_OK)
2189 API int pkgmgrinfo_appinfo_usr_metadata_filter_foreach(
2190 pkgmgrinfo_appinfo_metadata_filter_h handle,
2191 pkgmgrinfo_app_list_cb app_cb, void *user_data, uid_t uid)
2193 if (handle == NULL || app_cb == NULL) {
2194 LOGE("invalid parameter");
2195 return PMINFO_R_EINVAL;
2198 return _appinfo_get_filtered_foreach_appinfo(uid, handle, app_cb,
2202 API int pkgmgrinfo_appinfo_metadata_filter_foreach(
2203 pkgmgrinfo_appinfo_metadata_filter_h handle,
2204 pkgmgrinfo_app_list_cb app_cb, void *user_data)
2206 return pkgmgrinfo_appinfo_usr_metadata_filter_foreach(handle, app_cb,
2207 user_data, GLOBAL_USER);
2210 API int pkgmgrinfo_appinfo_is_guestmode_visibility(pkgmgrinfo_appinfo_h handle, bool *status)
2213 pkgmgr_appinfo_x *info = (pkgmgr_appinfo_x *)handle;
2215 retvm_if(handle == NULL, PMINFO_R_EINVAL, "appinfo handle is NULL\n");
2216 retvm_if(status == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
2218 val = info->app_info->guestmode_visibility;
2219 *status = _get_bool_value(val);