4 * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
6 * Contact: Jayoun Lee <airjany@samsung.com>, Sewook Park <sewook7.park@samsung.com>,
7 * Jaeho Lee <jaeho81.lee@samsung.com>, Shobhit Srivastava <shobhit.s@samsung.com>
9 * Licensed under the Apache License, Version 2.0 (the "License");
10 * you may not use this file except in compliance with the License.
11 * You may obtain a copy of the License at
13 * http://www.apache.org/licenses/LICENSE-2.0
15 * Unless required by applicable law or agreed to in writing, software
16 * distributed under the License is distributed on an "AS IS" BASIS,
17 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18 * See the License for the specific language governing permissions and
19 * limitations under the License.
30 #include <sys/smack.h>
31 #include <linux/limits.h>
38 #include "pkgmgrinfo_basic.h"
39 #include "pkgmgrinfo_private.h"
40 #include "pkgmgrinfo_debug.h"
41 #include "pkgmgr-info.h"
43 static bool _get_bool_value(const char *str)
45 if (str && !strcmp(str, "true"))
51 static gint __compare_func(gconstpointer data1, gconstpointer data2)
53 pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x *)data1;
54 pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x *)data2;
55 if (node1->prop == node2->prop)
57 else if (node1->prop > node2->prop)
63 static gint __pkg_disable_chk_func(gconstpointer data1, gconstpointer data2)
65 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data1;
67 if (node->prop == E_PMINFO_PKGINFO_PROP_PACKAGE_DISABLE)
73 static void __destroy_each_node(gpointer data, gpointer user_data)
76 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data;
89 static void __destroy_metadata_node(gpointer data)
91 pkgmgrinfo_metadata_node_x *node = (pkgmgrinfo_metadata_node_x *)data;
99 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
101 ret_if(data == NULL);
103 free((void *)data->locale);
107 pkgmgrinfo_basic_free_package(data->pkg_info);
113 long long _pkgmgr_calculate_dir_size(char *dirname)
117 int q = 0; /*quotient*/
118 int r = 0; /*remainder*/
121 struct stat fileinfo;
122 char abs_filename[FILENAME_MAX] = { 0, };
123 retvm_if(dirname == NULL, PMINFO_R_ERROR, "dirname is NULL");
125 dp = opendir(dirname);
127 _LOGE("Couldn't open the directory\n");
131 for (ep = readdir(dp); ep != NULL; ep = readdir(dp)) {
132 if (!strcmp(ep->d_name, ".") ||
133 !strcmp(ep->d_name, "..")) {
136 snprintf(abs_filename, FILENAME_MAX, "%s/%s", dirname,
138 if (lstat(abs_filename, &fileinfo) < 0)
139 perror(abs_filename);
141 if (S_ISDIR(fileinfo.st_mode)) {
142 total += fileinfo.st_size;
143 if (strcmp(ep->d_name, ".")
144 && strcmp(ep->d_name, "..")) {
145 ret = _pkgmgr_calculate_dir_size
149 } else if (S_ISLNK(fileinfo.st_mode)) {
152 /*It is a file. Calculate the actual
153 size occupied (in terms of 4096 blocks)*/
154 q = (fileinfo.st_size / BLOCK_SIZE);
155 r = (fileinfo.st_size % BLOCK_SIZE);
158 total += q * BLOCK_SIZE;
167 static int _pkginfo_add_description_info_into_list(const char *locale,
168 char *record, GList **description)
172 info = calloc(1, sizeof(description_x));
174 LOGE("out of memory");
175 return PMINFO_R_ERROR;
177 info->lang = strdup(locale);
179 *description = g_list_append(*description, info);
184 static int _pkginfo_get_privilege(sqlite3 *db, const char *pkgid,
187 static const char query_raw[] =
188 "SELECT DISTINCT privilege, type FROM package_privilege_info "
193 privilege_x *privilege;
195 query = sqlite3_mprintf(query_raw, pkgid);
197 LOGE("out of memory");
198 return PMINFO_R_ERROR;
201 ret = sqlite3_prepare_v2(db, query, strlen(query),
204 if (ret != SQLITE_OK) {
205 LOGE("prepare failed: %s", sqlite3_errmsg(db));
206 return PMINFO_R_ERROR;
209 while (sqlite3_step(stmt) == SQLITE_ROW) {
210 privilege = calloc(1, sizeof(privilege_x));
211 _save_column_str(stmt, 0, &privilege->value);
212 _save_column_str(stmt, 1, &privilege->type);
213 *privileges = g_list_append(*privileges,
214 (gpointer)privilege);
217 sqlite3_finalize(stmt);
222 static const char join_localized_info[] =
223 " LEFT OUTER JOIN package_localized_info"
224 " ON pi.package=package_localized_info.package"
225 " AND package_localized_info.package_locale=?";
226 static const char join_privilege_info[] =
227 " LEFT OUTER JOIN package_privilege_info"
228 " ON pi.package=package_privilege_info.package";
230 static int _get_filtered_query(pkgmgrinfo_filter_x *filter,
231 const char *locale, uid_t uid, char **query, GList **bind_params)
234 char buf[MAX_QUERY_LEN] = { '\0' };
235 char buf2[MAX_QUERY_LEN] = { '\0' };
236 char *condition = NULL;
243 strncat(buf, " WHERE 1=1 ", MAX_QUERY_LEN - len - 1);
244 len += strlen(" WHERE 1=1 ");
245 for (list = filter->list; list; list = list->next) {
246 joined |= __get_filter_condition(list->data, uid, &condition,
248 if (condition == NULL)
251 strncat(buf, " AND ", MAX_QUERY_LEN - len - 1);
252 len += strlen(" AND ");
254 strncat(buf, condition, sizeof(buf) - len - 1);
255 len += strlen(condition);
260 if (joined & E_PMINFO_PKGINFO_JOIN_LOCALIZED_INFO) {
261 strncat(buf2, join_localized_info, MAX_QUERY_LEN - len - 1);
262 len += strlen(join_localized_info);
263 *bind_params = g_list_append(*bind_params, strdup(locale));
265 if (joined & E_PMINFO_PKGINFO_JOIN_PRIVILEGE_INFO) {
266 strncat(buf2, join_privilege_info, MAX_QUERY_LEN - len - 1);
267 len += strlen(join_privilege_info);
269 strncat(buf2, buf, MAX_QUERY_LEN - len - 1);
271 *query = strdup(buf2);
273 return PMINFO_R_ERROR;
278 static void __free_packages(gpointer data)
280 pkgmgrinfo_basic_free_package((package_x *)data);
283 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
290 link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
297 static int __bind_params(sqlite3_stmt *stmt, GList *params)
299 GList *tmp_list = NULL;
303 if (stmt == NULL || params == NULL)
304 return PMINFO_R_EINVAL;
308 ret = sqlite3_bind_text(stmt, ++idx, (char *)tmp_list->data, -1, SQLITE_STATIC);
309 if (ret != SQLITE_OK)
310 return PMINFO_R_ERROR;
311 tmp_list = tmp_list->next;
317 static bool __check_package_storage_status(pkgmgrinfo_filter_x *tmp_filter)
319 GSList *tmp_list = NULL;
320 pkgmgrinfo_node_x *tmp_node = NULL;
323 property = _pminfo_pkginfo_convert_to_prop_bool(PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE);
324 for (tmp_list = tmp_filter->list; tmp_list != NULL;
325 tmp_list = g_slist_next(tmp_list)) {
326 tmp_node = (pkgmgrinfo_node_x *)tmp_list->data;
327 if (property == tmp_node->prop) {
328 if (strcmp(tmp_node->value, "true") == 0)
337 static int _pkginfo_get_packages(uid_t uid, const char *locale,
338 pkgmgrinfo_filter_x *filter, int flag, GHashTable *packages)
340 static const char query_raw[] =
341 "SELECT DISTINCT pi.package, pi.installed_storage, pi.external_path";
342 static const char query_basic[] =
343 ", pi.package_version, pi.install_location, "
344 "pi.package_removable, pi.package_preload, pi.package_readonly, "
345 "pi.package_update, pi.package_appsetting, pi.package_system, "
346 "pi.package_type, pi.package_size, pi.installed_time, "
347 "pi.storeclient_id, pi.mainapp_id, pi.package_url, pi.root_path, "
348 "pi.csc_path, pi.package_nodisplay, pi.package_api_version, "
349 "pi.package_support_disable, pi.package_tep_name, "
350 "pi.package_zip_mount_file, pi.package_support_mode";
351 static const char query_author[] =
352 ", pi.author_name, pi.author_email, pi.author_href";
353 static const char query_label[] =
355 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
356 "(SELECT package_label FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
357 static const char query_icon[] =
359 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
360 "(SELECT package_icon FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
361 static const char query_description[] =
363 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale=?), "
364 "(SELECT package_description FROM package_localized_info WHERE pi.package=package AND package_locale='No Locale'))";
365 static const char query_from_clause[] = " FROM package_info as pi";
366 int ret = PMINFO_R_ERROR;
370 char *tmp_record = NULL;
371 char *constraints = NULL;
372 char query[MAX_QUERY_LEN] = { '\0' };
373 package_x *info = NULL;
374 author_x *author = NULL;
375 GList *bind_params = NULL;
377 sqlite3_stmt *stmt = NULL;
378 pkgmgrinfo_filter_x *tmp_filter = NULL;
379 bool is_check_storage = true;
380 const uid_t global_user_uid = GLOBAL_USER;
382 dbpath = getUserPkgParserDBPathUID(uid);
384 return PMINFO_R_ERROR;
386 ret = __open_db(dbpath, &db, SQLITE_OPEN_READONLY);
387 if (ret != SQLITE_OK) {
388 _LOGD("failed to open db(%s): %d", dbpath, ret);
390 return PMINFO_R_ERROR;
394 if (filter != NULL) {
397 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
398 if (ret != PMINFO_R_OK) {
399 _LOGE("Failed to create filter");
400 return PMINFO_R_ERROR;
404 is_check_storage = __check_package_storage_status(tmp_filter);
406 query_len = strlen(query_raw);
407 snprintf(query, MAX_QUERY_LEN - 1, "%s", query_raw);
408 if (flag & PMINFO_APPINFO_GET_BASICINFO) {
409 strncat(query, query_basic, MAX_QUERY_LEN - query_len - 1);
410 query_len += strlen(query_basic);
412 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
413 strncat(query, query_author, MAX_QUERY_LEN - query_len - 1);
414 query_len += strlen(query_author);
416 if (flag & PMINFO_PKGINFO_GET_LABEL) {
417 strncat(query, query_label, MAX_QUERY_LEN - query_len - 1);
418 query_len += strlen(query_label);
419 bind_params = g_list_append(bind_params, strdup(locale));
421 if (flag & PMINFO_PKGINFO_GET_ICON) {
422 strncat(query, query_icon, MAX_QUERY_LEN - query_len - 1);
423 query_len += strlen(query_icon);
424 bind_params = g_list_append(bind_params, strdup(locale));
426 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
427 strncat(query, query_description, MAX_QUERY_LEN - query_len - 1);
428 query_len += strlen(query_description);
429 bind_params = g_list_append(bind_params, strdup(locale));
432 strncat(query, query_from_clause, MAX_QUERY_LEN - query_len - 1);
433 query_len += strlen(query_from_clause);
435 ret = _get_filtered_query(tmp_filter, locale, uid, &constraints, &bind_params);
436 if (ret != PMINFO_R_OK) {
437 LOGE("Failed to get WHERE clause");
442 strncat(query, constraints, MAX_QUERY_LEN - query_len - 1);
444 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
445 if (ret != SQLITE_OK) {
446 LOGE("prepare failed: %s", sqlite3_errmsg(db));
447 ret = PMINFO_R_ERROR;
451 ret = __bind_params(stmt, bind_params);
452 if (ret != SQLITE_OK) {
453 LOGE("Failed to bind parameters");
457 while (sqlite3_step(stmt) == SQLITE_ROW) {
458 info = calloc(1, sizeof(package_x));
460 LOGE("out of memory");
461 ret = PMINFO_R_ERROR;
465 _save_column_str(stmt, idx++, &info->package);
466 _save_column_str(stmt, idx++, &info->installed_storage);
467 _save_column_str(stmt, idx++, &info->external_path);
469 if (flag & PMINFO_APPINFO_GET_BASICINFO) {
470 _save_column_str(stmt, idx++, &info->version);
471 _save_column_str(stmt, idx++, &info->installlocation);
472 _save_column_str(stmt, idx++, &info->removable);
473 _save_column_str(stmt, idx++, &info->preload);
474 _save_column_str(stmt, idx++, &info->readonly);
475 _save_column_str(stmt, idx++, &info->update);
476 _save_column_str(stmt, idx++, &info->appsetting);
477 _save_column_str(stmt, idx++, &info->system);
478 _save_column_str(stmt, idx++, &info->type);
479 _save_column_str(stmt, idx++, &info->package_size);
480 _save_column_str(stmt, idx++, &info->installed_time);
481 _save_column_str(stmt, idx++, &info->storeclient_id);
482 _save_column_str(stmt, idx++, &info->mainapp_id);
483 _save_column_str(stmt, idx++, &info->package_url);
484 _save_column_str(stmt, idx++, &info->root_path);
485 _save_column_str(stmt, idx++, &info->csc_path);
486 _save_column_str(stmt, idx++, &info->nodisplay_setting);
487 _save_column_str(stmt, idx++, &info->api_version);
488 _save_column_str(stmt, idx++, &info->support_disable);
489 _save_column_str(stmt, idx++, &info->tep_name);
490 _save_column_str(stmt, idx++, &info->zip_mount_file);
491 _save_column_str(stmt, idx++, &info->support_mode);
494 info->for_all_users =
495 strdup((uid != global_user_uid) ? "false" : "true");
497 if (flag & PMINFO_PKGINFO_GET_AUTHOR) {
498 /* TODO : author should be retrieved at package_localized_info */
499 author = calloc(1, sizeof(author_x));
500 if (author == NULL) {
501 ret = PMINFO_R_ERROR;
504 _save_column_str(stmt, idx++, &author->text);
505 _save_column_str(stmt, idx++, &author->email);
506 _save_column_str(stmt, idx++, &author->href);
507 info->author = g_list_append(info->author, author);
510 if (flag & PMINFO_PKGINFO_GET_LABEL) {
512 _save_column_str(stmt, idx++, &tmp_record);
514 if (_add_label_info_into_list(locale, tmp_record, &info->label)) {
515 ret = PMINFO_R_ERROR;
520 if (flag & PMINFO_PKGINFO_GET_ICON) {
522 _save_column_str(stmt, idx++, &tmp_record);
523 if (_add_icon_info_into_list(locale, tmp_record, &info->icon)) {
524 ret = PMINFO_R_ERROR;
529 if (flag & PMINFO_PKGINFO_GET_DESCRIPTION) {
531 _save_column_str(stmt, idx++, &tmp_record);
532 if (_pkginfo_add_description_info_into_list(locale, tmp_record,
533 &info->description)) {
534 ret = PMINFO_R_ERROR;
539 if (flag & PMINFO_PKGINFO_GET_PRIVILEGE) {
540 if (_pkginfo_get_privilege(db, info->package,
541 &info->privileges)) {
542 ret = PMINFO_R_ERROR;
547 if (is_check_storage &&
548 __pkginfo_check_installed_storage(info) != PMINFO_R_OK) {
549 ret = PMINFO_R_ERROR;
550 pkgmgrinfo_basic_free_package(info);
555 g_hash_table_insert(packages, (gpointer)info->package,
565 if (ret != PMINFO_R_OK && info != NULL)
566 pkgmgrinfo_basic_free_package(info);
569 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
571 g_list_free_full(bind_params, free);
572 sqlite3_close_v2(db);
574 sqlite3_finalize(stmt);
579 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
580 pkgmgrinfo_filter_x *filter, int flag,
581 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
586 pkgmgr_pkginfo_x info;
587 pkgmgrinfo_filter_x *tmp_filter = NULL;
592 locale = _get_system_locale();
594 return PMINFO_R_ERROR;
596 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
600 return PMINFO_R_ERROR;
603 if (filter != NULL) {
604 tmp_filter = (pkgmgrinfo_filter_x *)filter;
606 ret = pkgmgrinfo_pkginfo_filter_create((void *)&tmp_filter);
607 if (ret != PMINFO_R_OK) {
608 _LOGE("Failed to create filter");
609 g_hash_table_destroy(list);
610 return PMINFO_R_ERROR;
614 if (__check_disable_filter_exist(tmp_filter) == false)
615 pkgmgrinfo_pkginfo_filter_add_bool(tmp_filter,
616 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
618 ret = _pkginfo_get_packages(uid, locale, tmp_filter,
619 flag | PMINFO_PKGINFO_GET_BASICINFO, list);
620 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
621 ret = _pkginfo_get_packages(GLOBAL_USER, locale, tmp_filter,
622 flag | PMINFO_PKGINFO_GET_BASICINFO, list);
624 if (ret != PMINFO_R_OK) {
625 g_hash_table_destroy(list);
628 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
629 return PMINFO_R_ERROR;
632 g_hash_table_iter_init(&iter, list);
633 while (g_hash_table_iter_next(&iter, NULL, &value)) {
634 pkg = (package_x *)value;
637 info.locale = locale;
638 if (pkg_list_cb(&info, user_data) < 0)
642 g_hash_table_destroy(list);
646 pkgmgrinfo_pkginfo_filter_destroy(tmp_filter);
651 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
652 pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
657 pkgmgr_pkginfo_x *info;
659 if (pkgid == NULL || filter == NULL || handle == NULL) {
660 LOGE("invalid parameter");
661 return PMINFO_R_EINVAL;
664 locale = _get_system_locale();
666 return PMINFO_R_ERROR;
668 list = g_hash_table_new(g_str_hash, g_str_equal);
671 return PMINFO_R_ERROR;
674 ret = _pkginfo_get_packages(uid, locale, filter,
675 PMINFO_PKGINFO_GET_ALL, list);
676 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
677 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
678 PMINFO_PKGINFO_GET_ALL, list);
680 if (!g_hash_table_size(list)) {
681 _LOGI("pkginfo for [%s] is not existed for user [%d]",
683 g_hash_table_destroy(list);
685 return PMINFO_R_ENOENT;
688 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
690 _LOGE("out of memory");
691 g_hash_table_destroy(list);
693 return PMINFO_R_ERROR;
697 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
698 info->locale = locale;
700 /* just free list only */
701 g_hash_table_destroy(list);
708 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
709 pkgmgrinfo_pkginfo_h *handle)
712 pkgmgrinfo_pkginfo_filter_h filter;
714 if (pkgid == NULL || handle == NULL) {
715 LOGE("invalid parameter");
716 return PMINFO_R_EINVAL;
719 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
720 if (ret != PMINFO_R_OK)
723 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
724 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
725 if (ret != PMINFO_R_OK) {
726 pkgmgrinfo_pkginfo_filter_destroy(filter);
727 return PMINFO_R_ERROR;
730 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
731 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
732 if (ret != PMINFO_R_OK) {
733 pkgmgrinfo_pkginfo_filter_destroy(filter);
734 return PMINFO_R_ERROR;
737 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
738 pkgmgrinfo_pkginfo_filter_destroy(filter);
743 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
744 pkgmgrinfo_pkginfo_h *handle)
746 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
749 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
750 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
755 pkgmgrinfo_pkginfo_filter_h filter;
756 pkgmgr_pkginfo_x *info;
758 if (pkgid == NULL || handle == NULL) {
759 LOGE("invalid parameter");
760 return PMINFO_R_EINVAL;
763 locale = _get_system_locale();
765 return PMINFO_R_ERROR;
767 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
768 if (ret != PMINFO_R_OK) {
773 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
774 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
775 if (ret != PMINFO_R_OK) {
776 pkgmgrinfo_pkginfo_filter_destroy(filter);
778 return PMINFO_R_ERROR;
781 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
782 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
783 if (ret != PMINFO_R_OK) {
784 pkgmgrinfo_pkginfo_filter_destroy(filter);
786 return PMINFO_R_ERROR;
789 list = g_hash_table_new(g_str_hash, g_str_equal);
791 pkgmgrinfo_pkginfo_filter_destroy(filter);
793 return PMINFO_R_ERROR;
796 ret = _pkginfo_get_packages(uid, locale, filter,
797 PMINFO_PKGINFO_GET_ALL, list);
798 if (!g_hash_table_size(list) && uid != GLOBAL_USER)
799 ret = _pkginfo_get_packages(GLOBAL_USER, locale, filter,
800 PMINFO_PKGINFO_GET_ALL, list);
802 pkgmgrinfo_pkginfo_filter_destroy(filter);
803 if (ret != PMINFO_R_OK) {
804 g_hash_table_destroy(list);
809 if (!g_hash_table_size(list)) {
810 _LOGI("disabled pkginfo for [%s] is not existed for user [%d]",
812 g_hash_table_destroy(list);
814 return PMINFO_R_ENOENT;
817 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
819 _LOGE("out of memory");
820 g_hash_table_destroy(list);
822 return PMINFO_R_ERROR;
826 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
827 info->locale = locale;
829 /* just free list only */
830 g_hash_table_destroy(list);
837 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
838 pkgmgrinfo_pkginfo_h *handle)
842 pkgmgrinfo_pkginfo_filter_h filter;
844 if (pkgid == NULL || handle == NULL) {
845 LOGE("invalid parameter");
846 return PMINFO_R_EINVAL;
849 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
850 if (ret != PMINFO_R_OK)
853 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
854 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
855 if (ret != PMINFO_R_OK) {
856 pkgmgrinfo_pkginfo_filter_destroy(filter);
857 return PMINFO_R_ERROR;
860 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
861 PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
862 if (ret != PMINFO_R_OK) {
863 pkgmgrinfo_pkginfo_filter_destroy(filter);
864 return PMINFO_R_ERROR;
867 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
868 pkgmgrinfo_pkginfo_filter_destroy(filter);
873 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
874 pkgmgrinfo_pkginfo_h *handle)
876 return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
880 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
881 pkgmgrinfo_pkginfo_h *handle)
883 return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
886 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
887 int flag, void *user_data, uid_t uid)
890 pkgmgrinfo_pkginfo_filter_h filter;
892 if (pkg_list_cb == NULL) {
893 LOGE("invalid parameter");
894 return PMINFO_R_EINVAL;
897 /* create an empty filter */
898 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
899 if (ret != PMINFO_R_OK)
902 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
903 pkg_list_cb, user_data);
905 pkgmgrinfo_pkginfo_filter_destroy(filter);
910 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
911 int flag, void *user_data)
913 return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
914 user_data, _getuid());
917 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
918 void *user_data, uid_t uid)
921 pkgmgrinfo_pkginfo_filter_h filter;
923 if (pkg_list_cb == NULL) {
924 LOGE("invalid parameter");
925 return PMINFO_R_EINVAL;
928 /* create an empty filter */
929 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
930 if (ret != PMINFO_R_OK)
933 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
934 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
936 pkgmgrinfo_pkginfo_filter_destroy(filter);
941 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
944 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
948 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
949 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
952 pkgmgrinfo_pkginfo_filter_h filter;
954 if (pkg_list_cb == NULL) {
955 LOGE("invalid parameter");
956 return PMINFO_R_EINVAL;
959 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
960 if (ret != PMINFO_R_OK)
963 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
964 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
965 if (ret != PMINFO_R_OK) {
966 pkgmgrinfo_pkginfo_filter_destroy(filter);
967 return PMINFO_R_ERROR;
970 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
971 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
973 pkgmgrinfo_pkginfo_filter_destroy(filter);
978 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
981 return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
985 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
987 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
989 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
990 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
992 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
993 return PMINFO_R_ERROR;
995 *pkg_name = (char *)info->pkg_info->package;
1000 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
1002 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1004 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1005 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1007 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
1008 return PMINFO_R_ERROR;
1010 *pkgid = (char *)info->pkg_info->package;
1015 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
1017 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1019 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1020 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1022 if (info->pkg_info == NULL)
1023 return PMINFO_R_ERROR;
1025 if (info->pkg_info->type == NULL)
1028 *type = (char *)info->pkg_info->type;
1033 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
1035 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1037 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1038 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1040 if (info->pkg_info == NULL)
1041 return PMINFO_R_ERROR;
1043 if (info->pkg_info->version == NULL)
1046 *version = (char *)info->pkg_info->version;
1051 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
1053 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1055 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1056 retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1058 if (info->pkg_info == NULL)
1059 return PMINFO_R_ERROR;
1061 if (info->pkg_info->api_version == NULL)
1064 *api_version = (char *)info->pkg_info->api_version;
1069 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
1071 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1073 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1074 retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1076 if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
1077 return PMINFO_R_ERROR;
1079 *tep_name = (char *)info->pkg_info->tep_name;
1084 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
1086 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1088 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1089 retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1091 if (info->pkg_info == NULL)
1092 return PMINFO_R_ERROR;
1094 if (info->pkg_info->zip_mount_file == NULL)
1095 *zip_mount_file = "";
1097 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
1102 API int pkgmgrinfo_pkginfo_get_external_image_path(pkgmgrinfo_pkginfo_h handle, char **ext_image_path)
1104 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1106 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1107 retvm_if(ext_image_path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1109 if (info->pkg_info == NULL)
1110 return PMINFO_R_ERROR;
1112 if (info->pkg_info->external_path == NULL)
1113 return PMINFO_R_ENOENT;
1115 *ext_image_path = (char *)info->pkg_info->external_path;
1120 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
1123 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1125 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1126 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1128 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1129 return PMINFO_R_ERROR;
1131 val = (char *)info->pkg_info->installlocation;
1132 if (strcmp(val, "internal-only") == 0)
1133 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
1134 else if (strcmp(val, "prefer-external") == 0)
1135 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
1137 *location = PMINFO_INSTALL_LOCATION_AUTO;
1142 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
1144 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1147 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1148 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1150 if (info->pkg_info == NULL)
1151 return PMINFO_R_ERROR;
1153 if (info->pkg_info->package_size == NULL) {
1156 _LOGE("out of memory");
1157 return PMINFO_R_ERROR;
1159 info->pkg_info->package_size = temp;
1163 *size = atoi((char *)info->pkg_info->package_size);
1168 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
1171 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1173 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1174 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1176 if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
1177 return PMINFO_R_ERROR;
1179 ptr = (icon_x *)info->pkg_info->icon->data;
1181 return PMINFO_R_ERROR;
1183 /* TODO : should we return empty string if there was no icon? */
1184 if (ptr->text == NULL)
1192 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
1195 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1197 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1198 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1200 if (info->pkg_info == NULL || info->pkg_info->label == NULL)
1201 return PMINFO_R_ERROR;
1203 ptr = (label_x *)info->pkg_info->label->data;
1205 return PMINFO_R_ERROR;
1207 /* TODO : should we return empty string if there was no label? */
1208 if (ptr->text == NULL)
1216 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
1219 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1221 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1222 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1224 if (info->pkg_info == NULL || info->pkg_info->description == NULL)
1225 return PMINFO_R_ERROR;
1227 ptr = (description_x *)info->pkg_info->description->data;
1229 return PMINFO_R_ERROR;
1231 if (ptr->text == NULL)
1234 *description = (char *)ptr->text;
1239 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
1241 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1244 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1245 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1247 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1248 return PMINFO_R_ERROR;
1250 author = (author_x *)info->pkg_info->author->data;
1252 return PMINFO_R_ERROR;
1254 if (author->text == NULL)
1257 *author_name = (char *)author->text;
1262 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
1264 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1267 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1268 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1270 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1271 return PMINFO_R_ERROR;
1273 author = (author_x *)info->pkg_info->author->data;
1275 return PMINFO_R_ERROR;
1277 if (author->email == NULL)
1280 *author_email = (char *)author->email;
1285 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
1287 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1290 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1291 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1293 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
1294 return PMINFO_R_ERROR;
1296 author = (author_x *)info->pkg_info->author->data;
1298 return PMINFO_R_ERROR;
1300 if (author->href == NULL)
1303 *author_href = (char *)author->href;
1308 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
1310 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1312 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1313 retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1315 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
1316 return PMINFO_R_ERROR;
1318 if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
1319 *storage = PMINFO_INTERNAL_STORAGE;
1320 else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
1321 *storage = PMINFO_EXTERNAL_STORAGE;
1323 return PMINFO_R_ERROR;
1328 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
1330 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1332 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1333 retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1335 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
1336 return PMINFO_R_ERROR;
1338 *installed_time = atoi(info->pkg_info->installed_time);
1343 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
1345 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1347 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1348 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1350 if (info->pkg_info == NULL)
1351 return PMINFO_R_ERROR;
1353 if (info->pkg_info->storeclient_id == NULL)
1354 *storeclientid = "";
1356 *storeclientid = (char *)info->pkg_info->storeclient_id;
1361 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
1363 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1365 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1366 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1368 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
1369 return PMINFO_R_ERROR;
1371 *mainappid = (char *)info->pkg_info->mainapp_id;
1376 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
1378 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1380 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1381 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1383 if (info->pkg_info == NULL)
1384 return PMINFO_R_ERROR;
1386 if (info->pkg_info->package_url == NULL)
1389 *url = (char *)info->pkg_info->package_url;
1394 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
1396 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1398 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1399 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1401 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
1402 return PMINFO_R_ERROR;
1404 *path = (char *)info->pkg_info->root_path;
1409 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
1411 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1413 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1414 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1416 if (info->pkg_info == NULL)
1417 return PMINFO_R_ERROR;
1419 if (info->pkg_info->csc_path == NULL)
1422 *path = (char *)info->pkg_info->csc_path;
1427 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
1429 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1430 retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1432 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1433 if (info->pkg_info->support_mode)
1434 *support_mode = atoi(info->pkg_info->support_mode);
1441 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
1443 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1444 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1446 #if 0 /* smack issue occured, check later */
1448 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
1449 if (pkgid == NULL) {
1450 _LOGD("invalid func parameters\n");
1451 return PMINFO_R_ERROR;
1453 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
1456 char app_mmc_path[FILENAME_MAX] = { 0, };
1457 char app_dir_path[FILENAME_MAX] = { 0, };
1458 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
1459 snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
1460 snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
1461 snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
1463 /*check whether application is in external memory or not */
1464 fp = fopen(app_mmc_path, "r");
1466 _LOGD(" app path in external memory not accesible\n");
1471 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
1475 /*check whether application is in internal or not */
1477 _LOGD(" app path in internal memory not accesible\n");
1479 return PMINFO_R_ERROR;
1482 /*check whether the application is installed in SD card
1483 but SD card is not present*/
1484 fp = fopen(app_mmc_internal_path, "r");
1487 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1491 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1496 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1503 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1505 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1507 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1508 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1510 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1511 return PMINFO_R_ERROR;
1513 *removable = _get_bool_value(info->pkg_info->removable);
1518 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1521 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1523 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1524 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1526 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1527 return PMINFO_R_ERROR;
1529 val = (char *)info->pkg_info->installlocation;
1530 if (strcmp(val, "internal-only") == 0)
1532 else if (strcmp(val, "prefer-external") == 0)
1540 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1542 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1544 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1545 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1547 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1548 return PMINFO_R_ERROR;
1550 *preload = _get_bool_value(info->pkg_info->preload);
1555 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1557 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1559 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1560 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1562 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1563 return PMINFO_R_ERROR;
1565 *system = _get_bool_value(info->pkg_info->system);
1570 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1572 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1574 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1575 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1577 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1578 return PMINFO_R_ERROR;
1580 *readonly = _get_bool_value(info->pkg_info->readonly);
1585 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1587 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1589 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1590 retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1592 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1593 return PMINFO_R_ERROR;
1595 *update = _get_bool_value(info->pkg_info->update);
1600 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1602 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1604 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1605 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1607 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1608 return PMINFO_R_ERROR;
1610 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1615 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1617 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1619 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1620 retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1622 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1623 return PMINFO_R_ERROR;
1625 *global = _get_bool_value(info->pkg_info->for_all_users);
1630 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1632 return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1635 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1637 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1639 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1641 __cleanup_pkginfo(info);
1646 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1648 pkgmgrinfo_filter_x *filter;
1650 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1652 filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1653 if (filter == NULL) {
1654 _LOGE("Out of Memory!!!");
1655 return PMINFO_R_ERROR;
1663 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1665 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1667 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1670 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1671 g_slist_free(filter->list);
1674 g_slist_free_full(filter->list_metadata, __destroy_metadata_node);
1681 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1682 const char *property, const int value)
1684 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1688 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1689 pkgmgrinfo_node_x *node;
1691 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1692 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1694 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1695 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1696 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1697 _LOGE("Invalid Integer Property\n");
1698 return PMINFO_R_EINVAL;
1700 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1702 _LOGE("Out of Memory!!!\n");
1703 return PMINFO_R_ERROR;
1705 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1706 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1708 _LOGE("Out of Memory\n");
1710 return PMINFO_R_ERROR;
1714 /*If API is called multiple times for same property, we should override the previous values.
1715 Last value set will be used for filtering.*/
1716 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1718 filter->list = g_slist_delete_link(filter->list, link);
1719 filter->list = g_slist_append(filter->list, (gpointer)node);
1724 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1725 const char *property, const bool value)
1730 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1731 pkgmgrinfo_node_x *node;
1733 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1734 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1736 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1737 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1738 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1739 _LOGE("Invalid Boolean Property\n");
1740 return PMINFO_R_EINVAL;
1742 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1744 _LOGE("Out of Memory!!!\n");
1745 return PMINFO_R_ERROR;
1748 val = strndup("true", 4);
1750 val = strndup("false", 5);
1752 _LOGE("Out of Memory\n");
1754 return PMINFO_R_ERROR;
1758 /*If API is called multiple times for same property, we should override the previous values.
1759 Last value set will be used for filtering.*/
1760 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1762 filter->list = g_slist_delete_link(filter->list, link);
1763 filter->list = g_slist_append(filter->list, (gpointer)node);
1768 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1769 const char *property, const char *value)
1774 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1775 pkgmgrinfo_node_x *node;
1777 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1778 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1779 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1781 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1782 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1783 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1784 _LOGE("Invalid String Property\n");
1785 return PMINFO_R_EINVAL;
1787 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1789 _LOGE("Out of Memory!!!\n");
1790 return PMINFO_R_ERROR;
1792 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1793 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1794 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1795 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1796 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1797 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1798 else if (strcmp(value, "installed_internal") == 0)
1799 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1800 else if (strcmp(value, "installed_external") == 0)
1801 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1803 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1805 _LOGE("Out of Memory\n");
1807 return PMINFO_R_ERROR;
1811 /*If API is called multiple times for same property, we should override the previous values.
1812 Last value set will be used for filtering.*/
1813 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1815 filter->list = g_slist_delete_link(filter->list, link);
1816 filter->list = g_slist_append(filter->list, (gpointer)node);
1821 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1825 GHashTable *list = NULL;
1827 if (handle == NULL || count == NULL) {
1828 _LOGE("invalid parameter");
1829 return PMINFO_R_EINVAL;
1832 locale = _get_system_locale();
1834 return PMINFO_R_ERROR;
1836 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1840 return PMINFO_R_ERROR;
1843 if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1844 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1845 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1846 if (ret != PMINFO_R_OK) {
1848 g_hash_table_destroy(list);
1849 return PMINFO_R_ERROR;
1853 ret = _pkginfo_get_packages(uid, locale,
1854 (pkgmgrinfo_filter_x *)handle, 0, list);
1855 if (ret == PMINFO_R_OK && uid != GLOBAL_USER)
1856 ret = _pkginfo_get_packages(GLOBAL_USER, locale, handle, 0,
1859 if (ret != PMINFO_R_OK) {
1860 g_hash_table_destroy(list);
1862 return PMINFO_R_ERROR;
1865 *count = g_hash_table_size(list);
1867 g_hash_table_destroy(list);
1873 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1875 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1878 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1879 pkgmgrinfo_pkginfo_filter_h handle,
1880 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1882 if (handle == NULL || pkg_cb == NULL) {
1883 LOGE("invalid parameter");
1884 return PMINFO_R_EINVAL;
1887 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1888 PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1891 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1892 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1894 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1897 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1898 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1900 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1901 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1903 privilege_x *privilege;
1905 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1907 if (info->pkg_info == NULL)
1908 return PMINFO_R_ERROR;
1910 for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1911 privilege = (privilege_x *)tmp->data;
1912 if (privilege == NULL)
1914 ret = privilege_func(privilege->value, user_data);
1921 int __compare_package_version(const char *version, int *major,
1922 int *minor, int *macro, int *nano)
1924 char *version_temp = NULL;
1925 char *major_str = NULL;
1926 char *minor_str = NULL;
1927 char *macro_str = NULL;
1928 char *nano_str = NULL;
1929 char *save_str = NULL;
1931 if (version == NULL || major == NULL || minor == NULL ||
1932 macro == NULL || nano == NULL) {
1933 return PMINFO_R_EINVAL;
1936 version_temp = strdup(version);
1937 if (version_temp == NULL) {
1938 LOGE("Out of memory");
1939 return PMINFO_R_ERROR;
1942 major_str = strtok_r(version_temp, ".", &save_str);
1943 if (major_str == NULL) {
1944 _LOGE("major version is NULL");
1946 return PMINFO_R_ERROR;
1949 minor_str = strtok_r(NULL, ".", &save_str);
1950 if (minor_str == NULL) {
1951 _LOGE("minor version is NULL");
1953 return PMINFO_R_ERROR;
1956 *major = atoi(major_str);
1957 *minor = atoi(minor_str);
1960 macro_str = strtok_r(NULL, ".", &save_str);
1961 if (macro_str == NULL) {
1962 _LOGD("macro version is NULL");
1964 *macro = atoi(macro_str);
1965 nano_str = strtok_r(NULL, ".", &save_str);
1967 *nano = atoi(nano_str);
1968 _LOGD("nano version exists");
1971 _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1972 " macro = [%d], nano = [%d]", version, *major,
1973 *minor, *macro, *nano);
1980 API int pkgmgrinfo_compare_package_version(const char *current_version,
1981 const char *target_version,
1982 pkgmgrinfo_version_compare_type *res)
1985 int current_version_major = 0;
1986 int current_version_minor = 0;
1987 int current_version_macro = 0;
1988 int current_version_nano = 0;
1989 int target_version_major = 0;
1990 int target_version_minor = 0;
1991 int target_version_macro = 0;
1992 int target_version_nano = 0;
1994 if (current_version == NULL || target_version == NULL ||
1996 _LOGE("Invalid parameter");
1997 return PMINFO_R_EINVAL;
2000 ret = __compare_package_version(target_version,
2001 &target_version_major, &target_version_minor,
2002 &target_version_macro, &target_version_nano);
2004 _LOGE("Failed to compare target version(%d)", ret);
2005 return PMINFO_R_ERROR;
2008 ret = __compare_package_version(current_version,
2009 ¤t_version_major, ¤t_version_minor,
2010 ¤t_version_macro, ¤t_version_nano);
2012 _LOGE("Failed to compare current version(%d)", ret);
2013 return PMINFO_R_ERROR;
2016 _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
2017 target_version_minor, target_version_macro,
2018 target_version_nano, current_version_major,
2019 current_version_minor, current_version_macro,
2020 target_version_nano);
2022 if (target_version_major > current_version_major)
2023 *res = PMINFO_VERSION_NEW;
2024 else if (target_version_major < current_version_major)
2025 *res = PMINFO_VERSION_OLD;
2026 else if (target_version_minor > current_version_minor)
2027 *res = PMINFO_VERSION_NEW;
2028 else if (target_version_minor < current_version_minor)
2029 *res = PMINFO_VERSION_OLD;
2030 else if (target_version_macro > current_version_macro)
2031 *res = PMINFO_VERSION_NEW;
2032 else if (target_version_macro < current_version_macro)
2033 *res = PMINFO_VERSION_OLD;
2034 else if (target_version_nano > current_version_nano)
2035 *res = PMINFO_VERSION_NEW;
2036 else if (target_version_nano < current_version_nano)
2037 *res = PMINFO_VERSION_OLD;
2039 *res = PMINFO_VERSION_SAME;