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>
36 #include "pkgmgrinfo_basic.h"
37 #include "pkgmgrinfo_private.h"
38 #include "pkgmgrinfo_debug.h"
39 #include "pkgmgr-info.h"
40 #include "manager/pkginfo_manager.h"
42 static bool _get_bool_value(const char *str)
44 if (str && !strcmp(str, "true"))
50 static gint __compare_func(gconstpointer data1, gconstpointer data2)
52 pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x *)data1;
53 pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x *)data2;
54 if (node1->prop == node2->prop)
56 else if (node1->prop > node2->prop)
62 static gint __pkg_disable_chk_func(gconstpointer data1, gconstpointer data2)
64 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data1;
66 if (node->prop == E_PMINFO_PKGINFO_PROP_PACKAGE_DISABLE)
72 static void __destroy_metadata_node(gpointer data)
74 pkgmgrinfo_metadata_node_x *node = (pkgmgrinfo_metadata_node_x *)data;
82 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
86 free((void *)data->locale);
90 pkgmgrinfo_basic_free_package(data->pkg_info);
96 static void __free_packages(gpointer data)
98 pkgmgrinfo_basic_free_package((package_x *)data);
101 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
108 link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
115 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
116 pkgmgrinfo_filter_x *filter, int flag,
117 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
121 pkgmgr_pkginfo_x info;
126 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
129 return PMINFO_R_ERROR;
131 if (__check_disable_filter_exist(filter) == false) {
132 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
133 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
134 if (ret != PMINFO_R_OK) {
135 _LOGE("Failed to add filter");
136 g_hash_table_destroy(list);
137 return PMINFO_R_ERROR;
141 ret = _pkginfo_get_packages(uid, filter, flag, list);
142 if (ret == PMINFO_R_ERROR) {
143 g_hash_table_destroy(list);
147 g_hash_table_iter_init(&iter, list);
148 while (g_hash_table_iter_next(&iter, NULL, &value)) {
149 pkg = (package_x *)value;
152 info.locale = pkg->locale;
153 if (pkg_list_cb(&info, user_data) < 0)
157 g_hash_table_destroy(list);
162 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
163 pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
167 pkgmgr_pkginfo_x *info;
169 if (pkgid == NULL || filter == NULL || handle == NULL) {
170 LOGE("invalid parameter");
171 return PMINFO_R_EINVAL;
174 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
177 return PMINFO_R_ERROR;
179 ret = _pkginfo_get_packages(uid, filter, PMINFO_PKGINFO_GET_ALL, list);
180 if (ret != PMINFO_R_OK) {
181 g_hash_table_destroy(list);
185 if (!g_hash_table_size(list) || !g_hash_table_lookup(list, pkgid)) {
186 _LOGD("pkginfo for [%s] is not existed for user [%d]",
188 g_hash_table_destroy(list);
189 return PMINFO_R_ENOENT;
192 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
194 _LOGE("out of memory");
195 g_hash_table_destroy(list);
196 return PMINFO_R_ERROR;
200 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
201 info->locale = strdup(info->pkg_info->locale);
202 if (info->locale == NULL) {
203 _LOGE("Out of memory");
204 g_hash_table_destroy(list);
206 return PMINFO_R_ERROR;
209 /* just free list only */
210 g_hash_table_steal(list, (gconstpointer)pkgid);
211 g_hash_table_destroy(list);
218 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
219 pkgmgrinfo_pkginfo_h *handle)
222 pkgmgrinfo_pkginfo_filter_h filter;
224 if (pkgid == NULL || handle == NULL) {
225 LOGE("invalid parameter");
226 return PMINFO_R_EINVAL;
229 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
230 if (ret != PMINFO_R_OK)
233 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
234 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
235 if (ret != PMINFO_R_OK) {
236 pkgmgrinfo_pkginfo_filter_destroy(filter);
237 return PMINFO_R_ERROR;
240 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
241 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
242 if (ret != PMINFO_R_OK) {
243 pkgmgrinfo_pkginfo_filter_destroy(filter);
244 return PMINFO_R_ERROR;
246 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
247 pkgmgrinfo_pkginfo_filter_destroy(filter);
252 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
253 pkgmgrinfo_pkginfo_h *handle)
255 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
258 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
259 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
262 pkgmgrinfo_pkginfo_filter_h filter;
264 if (pkgid == NULL || handle == NULL) {
265 LOGE("invalid parameter");
266 return PMINFO_R_EINVAL;
269 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
270 if (ret != PMINFO_R_OK) {
274 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
275 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
276 if (ret != PMINFO_R_OK) {
277 pkgmgrinfo_pkginfo_filter_destroy(filter);
278 return PMINFO_R_ERROR;
281 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
282 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
283 if (ret != PMINFO_R_OK) {
284 pkgmgrinfo_pkginfo_filter_destroy(filter);
285 return PMINFO_R_ERROR;
288 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
289 if (ret == PMINFO_R_ENOENT)
290 LOGE("disabled pkginfo for [%s] is not existed for user [%d]",
292 pkgmgrinfo_pkginfo_filter_destroy(filter);
296 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
297 pkgmgrinfo_pkginfo_h *handle)
300 pkgmgrinfo_pkginfo_filter_h filter;
302 if (pkgid == NULL || handle == NULL) {
303 LOGE("invalid parameter");
304 return PMINFO_R_EINVAL;
307 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
308 if (ret != PMINFO_R_OK)
311 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
312 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
313 if (ret != PMINFO_R_OK) {
314 pkgmgrinfo_pkginfo_filter_destroy(filter);
315 return PMINFO_R_ERROR;
318 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
319 PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
320 if (ret != PMINFO_R_OK) {
321 pkgmgrinfo_pkginfo_filter_destroy(filter);
322 return PMINFO_R_ERROR;
325 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
326 pkgmgrinfo_pkginfo_filter_destroy(filter);
331 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
332 pkgmgrinfo_pkginfo_h *handle)
334 return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
338 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
339 pkgmgrinfo_pkginfo_h *handle)
341 return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
344 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
345 int flag, void *user_data, uid_t uid)
348 pkgmgrinfo_pkginfo_filter_h filter;
350 if (pkg_list_cb == NULL) {
351 LOGE("invalid parameter");
352 return PMINFO_R_EINVAL;
355 /* create an empty filter */
356 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
357 if (ret != PMINFO_R_OK)
360 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
361 pkg_list_cb, user_data);
363 pkgmgrinfo_pkginfo_filter_destroy(filter);
368 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
369 int flag, void *user_data)
371 return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
372 user_data, _getuid());
375 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
376 void *user_data, uid_t uid)
379 pkgmgrinfo_pkginfo_filter_h filter;
381 if (pkg_list_cb == NULL) {
382 LOGE("invalid parameter");
383 return PMINFO_R_EINVAL;
386 /* create an empty filter */
387 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
388 if (ret != PMINFO_R_OK)
391 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
392 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
394 pkgmgrinfo_pkginfo_filter_destroy(filter);
399 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
402 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
406 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
407 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
410 pkgmgrinfo_pkginfo_filter_h filter;
412 if (pkg_list_cb == NULL) {
413 LOGE("invalid parameter");
414 return PMINFO_R_EINVAL;
417 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
418 if (ret != PMINFO_R_OK)
421 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
422 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
423 if (ret != PMINFO_R_OK) {
424 pkgmgrinfo_pkginfo_filter_destroy(filter);
425 return PMINFO_R_ERROR;
428 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
429 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
431 pkgmgrinfo_pkginfo_filter_destroy(filter);
436 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
439 return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
443 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
445 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
447 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
448 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
450 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
451 return PMINFO_R_ERROR;
453 *pkg_name = (char *)info->pkg_info->package;
458 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
460 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
462 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
463 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
465 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
466 return PMINFO_R_ERROR;
468 *pkgid = (char *)info->pkg_info->package;
473 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
475 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
477 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
478 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
480 if (info->pkg_info == NULL)
481 return PMINFO_R_ERROR;
483 if (info->pkg_info->type == NULL)
486 *type = (char *)info->pkg_info->type;
491 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
493 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
495 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
496 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
498 if (info->pkg_info == NULL)
499 return PMINFO_R_ERROR;
501 if (info->pkg_info->version == NULL)
504 *version = (char *)info->pkg_info->version;
509 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
511 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
513 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
514 retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
516 if (info->pkg_info == NULL)
517 return PMINFO_R_ERROR;
519 if (info->pkg_info->api_version == NULL)
522 *api_version = (char *)info->pkg_info->api_version;
527 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
529 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
531 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
532 retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
534 if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
535 return PMINFO_R_ERROR;
537 *tep_name = (char *)info->pkg_info->tep_name;
542 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
544 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
546 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
547 retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
549 if (info->pkg_info == NULL)
550 return PMINFO_R_ERROR;
552 if (info->pkg_info->zip_mount_file == NULL)
553 *zip_mount_file = "";
555 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
560 API int pkgmgrinfo_pkginfo_get_external_image_path(pkgmgrinfo_pkginfo_h handle, char **ext_image_path)
562 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
564 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
565 retvm_if(ext_image_path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
567 if (info->pkg_info == NULL)
568 return PMINFO_R_ERROR;
570 if (info->pkg_info->external_path == NULL)
571 return PMINFO_R_ENOENT;
573 *ext_image_path = (char *)info->pkg_info->external_path;
578 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
581 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
583 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
584 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
586 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
587 return PMINFO_R_ERROR;
589 val = (char *)info->pkg_info->installlocation;
590 if (strcmp(val, "internal-only") == 0)
591 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
592 else if (strcmp(val, "prefer-external") == 0)
593 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
595 *location = PMINFO_INSTALL_LOCATION_AUTO;
600 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
602 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
605 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
606 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
608 if (info->pkg_info == NULL)
609 return PMINFO_R_ERROR;
611 if (info->pkg_info->package_size == NULL) {
614 _LOGE("out of memory");
615 return PMINFO_R_ERROR;
617 info->pkg_info->package_size = temp;
621 *size = atoi((char *)info->pkg_info->package_size);
626 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
629 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
631 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
632 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
634 if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
635 return PMINFO_R_ERROR;
637 ptr = (icon_x *)info->pkg_info->icon->data;
639 return PMINFO_R_ERROR;
641 /* TODO : should we return empty string if there was no icon? */
642 if (ptr->text == NULL)
650 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
653 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
655 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
656 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
658 if (info->pkg_info == NULL || info->pkg_info->label == NULL)
659 return PMINFO_R_ERROR;
661 ptr = (label_x *)info->pkg_info->label->data;
663 return PMINFO_R_ERROR;
665 /* TODO : should we return empty string if there was no label? */
666 if (ptr->text == NULL)
674 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
677 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
679 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
680 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
682 if (info->pkg_info == NULL || info->pkg_info->description == NULL)
683 return PMINFO_R_ERROR;
685 ptr = (description_x *)info->pkg_info->description->data;
687 return PMINFO_R_ERROR;
689 if (ptr->text == NULL)
692 *description = (char *)ptr->text;
697 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
699 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
702 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
703 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
705 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
706 return PMINFO_R_ERROR;
708 author = (author_x *)info->pkg_info->author->data;
710 return PMINFO_R_ERROR;
712 if (author->text == NULL)
715 *author_name = (char *)author->text;
720 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
722 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
725 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
726 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
728 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
729 return PMINFO_R_ERROR;
731 author = (author_x *)info->pkg_info->author->data;
733 return PMINFO_R_ERROR;
735 if (author->email == NULL)
738 *author_email = (char *)author->email;
743 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
745 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
748 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
749 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
751 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
752 return PMINFO_R_ERROR;
754 author = (author_x *)info->pkg_info->author->data;
756 return PMINFO_R_ERROR;
758 if (author->href == NULL)
761 *author_href = (char *)author->href;
766 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
768 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
770 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
771 retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
773 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
774 return PMINFO_R_ERROR;
776 if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
777 *storage = PMINFO_INTERNAL_STORAGE;
778 else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
779 *storage = PMINFO_EXTERNAL_STORAGE;
780 else if (strcmp(info->pkg_info->installed_storage, "installed_extended") == 0)
781 *storage = PMINFO_EXTENDED_STORAGE;
783 return PMINFO_R_ERROR;
788 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
790 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
792 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
793 retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
795 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
796 return PMINFO_R_ERROR;
798 *installed_time = atoi(info->pkg_info->installed_time);
803 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
805 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
807 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
808 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
810 if (info->pkg_info == NULL)
811 return PMINFO_R_ERROR;
813 if (info->pkg_info->storeclient_id == NULL)
816 *storeclientid = (char *)info->pkg_info->storeclient_id;
821 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
823 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
825 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
826 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
828 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
829 return PMINFO_R_ERROR;
831 *mainappid = (char *)info->pkg_info->mainapp_id;
836 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
838 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
840 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
841 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
843 if (info->pkg_info == NULL)
844 return PMINFO_R_ERROR;
846 if (info->pkg_info->package_url == NULL)
849 *url = (char *)info->pkg_info->package_url;
854 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
856 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
858 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
859 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
861 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
862 return PMINFO_R_ERROR;
864 *path = (char *)info->pkg_info->root_path;
869 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
871 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
873 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
874 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
876 if (info->pkg_info == NULL)
877 return PMINFO_R_ERROR;
879 if (info->pkg_info->csc_path == NULL)
882 *path = (char *)info->pkg_info->csc_path;
887 API int pkgmgrinfo_pkginfo_get_res_type(pkgmgrinfo_pkginfo_h handle,
890 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
892 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
893 retvm_if(res_type == NULL, PMINFO_R_EINVAL,
894 "Argument supplied to hold return value is NULL\n");
896 if (info->pkg_info == NULL)
897 return PMINFO_R_ERROR;
899 if (info->pkg_info->res_type == NULL)
900 return PMINFO_R_ENOENT;
902 *res_type = (char *)info->pkg_info->res_type;
907 API int pkgmgrinfo_pkginfo_get_res_version(pkgmgrinfo_pkginfo_h handle,
910 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
912 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
913 retvm_if(res_version == NULL, PMINFO_R_EINVAL,
914 "Argument supplied to hold return value is NULL\n");
916 if (info->pkg_info == NULL)
917 return PMINFO_R_ERROR;
919 if (info->pkg_info->res_version == NULL)
920 return PMINFO_R_ENOENT;
922 *res_version = (char *)info->pkg_info->res_version;
927 API int pkgmgrinfo_pkginfo_get_light_user_switch_mode(pkgmgrinfo_pkginfo_h handle, char **mode)
929 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
931 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
932 retvm_if(mode == NULL, PMINFO_R_EINVAL,
933 "Argument supplied to hold return value is NULL\n");
935 if (info->pkg_info == NULL)
936 return PMINFO_R_ERROR;
938 if (info->pkg_info->light_user_switch_mode == NULL)
939 return PMINFO_R_ERROR;
941 *mode = (char *)info->pkg_info->light_user_switch_mode;
946 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
948 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
949 retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
951 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
952 if (info->pkg_info->support_mode)
953 *support_mode = atoi(info->pkg_info->support_mode);
960 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
962 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
963 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
965 #if 0 /* smack issue occured, check later */
967 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
969 _LOGD("invalid func parameters\n");
970 return PMINFO_R_ERROR;
972 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
975 char app_mmc_path[FILENAME_MAX] = { 0, };
976 char app_dir_path[FILENAME_MAX] = { 0, };
977 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
978 snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
979 snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
980 snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
982 /*check whether application is in external memory or not */
983 fp = fopen(app_mmc_path, "r");
985 _LOGD(" app path in external memory not accesible\n");
990 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
994 /*check whether application is in internal or not */
996 _LOGD(" app path in internal memory not accesible\n");
998 return PMINFO_R_ERROR;
1001 /*check whether the application is installed in SD card
1002 but SD card is not present*/
1003 fp = fopen(app_mmc_internal_path, "r");
1006 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1010 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1015 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1022 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1024 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1026 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1027 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1029 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1030 return PMINFO_R_ERROR;
1032 *removable = _get_bool_value(info->pkg_info->removable);
1037 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1040 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1042 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1043 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1045 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1046 return PMINFO_R_ERROR;
1048 val = (char *)info->pkg_info->installlocation;
1049 if (strcmp(val, "internal-only") == 0)
1057 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1059 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1061 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1062 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1064 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1065 return PMINFO_R_ERROR;
1067 *preload = _get_bool_value(info->pkg_info->preload);
1072 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1074 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1076 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1077 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1079 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1080 return PMINFO_R_ERROR;
1082 *system = _get_bool_value(info->pkg_info->system);
1087 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1089 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1091 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1092 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1094 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1095 return PMINFO_R_ERROR;
1097 *readonly = _get_bool_value(info->pkg_info->readonly);
1102 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
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(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1109 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1110 return PMINFO_R_ERROR;
1112 *update = _get_bool_value(info->pkg_info->update);
1117 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1119 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1121 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1122 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1124 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1125 return PMINFO_R_ERROR;
1127 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1132 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1134 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1136 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1137 retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1139 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1140 return PMINFO_R_ERROR;
1142 *global = _get_bool_value(info->pkg_info->for_all_users);
1147 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1149 return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1152 API int pkgmgrinfo_pkginfo_is_lib(pkgmgrinfo_pkginfo_h handle, bool *lib)
1154 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1156 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1157 retvm_if(lib == NULL, PMINFO_R_EINVAL,
1158 "Argument supplied to hold return value is NULL\n");
1160 if (info->pkg_info == NULL || info->pkg_info->lib == NULL)
1161 return PMINFO_R_ERROR;
1163 *lib = _get_bool_value(info->pkg_info->lib);
1168 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1170 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1172 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1174 __cleanup_pkginfo(info);
1179 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1181 pkgmgrinfo_filter_x *filter;
1183 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1185 filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1186 if (filter == NULL) {
1187 _LOGE("Out of Memory!!!");
1188 return PMINFO_R_ERROR;
1196 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1198 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1200 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1203 g_slist_free_full(filter->list,
1204 (GDestroyNotify)_pkgmgrinfo_node_destroy);
1206 if (filter->list_metadata)
1207 g_slist_free_full(filter->list_metadata,
1208 __destroy_metadata_node);
1209 if (filter->list_pkg_metadata)
1210 g_slist_free_full(filter->list_pkg_metadata,
1211 __destroy_metadata_node);
1218 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1219 const char *property, const int value)
1221 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1225 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1226 pkgmgrinfo_node_x *node;
1228 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1229 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1231 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1232 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1233 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1234 _LOGE("Invalid Integer Property\n");
1235 return PMINFO_R_EINVAL;
1237 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1239 _LOGE("Out of Memory!!!\n");
1240 return PMINFO_R_ERROR;
1242 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1243 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1245 _LOGE("Out of Memory\n");
1247 return PMINFO_R_ERROR;
1251 /*If API is called multiple times for same property, we should override the previous values.
1252 Last value set will be used for filtering.*/
1253 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1255 _pkgmgrinfo_node_destroy(link->data);
1256 filter->list = g_slist_delete_link(filter->list, link);
1258 filter->list = g_slist_append(filter->list, (gpointer)node);
1263 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1264 const char *property, const bool value)
1269 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1270 pkgmgrinfo_node_x *node;
1272 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1273 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1275 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1276 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1277 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1278 _LOGE("Invalid Boolean Property\n");
1279 return PMINFO_R_EINVAL;
1281 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1283 _LOGE("Out of Memory!!!\n");
1284 return PMINFO_R_ERROR;
1287 val = strndup("true", 4);
1289 val = strndup("false", 5);
1291 _LOGE("Out of Memory\n");
1293 return PMINFO_R_ERROR;
1297 /*If API is called multiple times for same property, we should override the previous values.
1298 Last value set will be used for filtering.*/
1299 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1301 _pkgmgrinfo_node_destroy(link->data);
1302 filter->list = g_slist_delete_link(filter->list, link);
1304 filter->list = g_slist_append(filter->list, (gpointer)node);
1309 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1310 const char *property, const char *value)
1315 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1316 pkgmgrinfo_node_x *node;
1318 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1319 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1320 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1322 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1323 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1324 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1325 _LOGE("Invalid String Property\n");
1326 return PMINFO_R_EINVAL;
1328 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1330 _LOGE("Out of Memory!!!\n");
1331 return PMINFO_R_ERROR;
1333 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1334 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1335 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1336 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1337 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1338 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1339 else if (strcmp(value, "installed_internal") == 0)
1340 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1341 else if (strcmp(value, "installed_external") == 0)
1342 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1344 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1346 _LOGE("Out of Memory\n");
1348 return PMINFO_R_ERROR;
1352 /*If API is called multiple times for same property, we should override the previous values.
1353 Last value set will be used for filtering.*/
1354 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1356 _pkgmgrinfo_node_destroy(link->data);
1357 filter->list = g_slist_delete_link(filter->list, link);
1359 filter->list = g_slist_append(filter->list, (gpointer)node);
1364 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1368 GHashTable *list = NULL;
1370 if (handle == NULL || count == NULL) {
1371 _LOGE("invalid parameter");
1372 return PMINFO_R_EINVAL;
1375 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1378 return PMINFO_R_ERROR;
1380 if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1381 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1382 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1383 if (ret != PMINFO_R_OK) {
1384 g_hash_table_destroy(list);
1385 return PMINFO_R_ERROR;
1389 ret = _pkginfo_get_packages(uid, handle, PMINFO_PKGINFO_GET_BASICINFO, list);
1390 query_count = g_hash_table_size(list);
1391 g_hash_table_destroy(list);
1392 if (ret == PMINFO_R_ERROR)
1394 *count = query_count;
1398 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1400 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1403 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1404 pkgmgrinfo_pkginfo_filter_h handle,
1405 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1407 if (handle == NULL || pkg_cb == NULL) {
1408 LOGE("invalid parameter");
1409 return PMINFO_R_EINVAL;
1412 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1413 PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1416 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1417 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1419 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1422 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1423 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1425 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1426 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1428 privilege_x *privilege;
1429 appdefined_privilege_x *appdefined_privilege;
1431 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1433 if (info->pkg_info == NULL)
1434 return PMINFO_R_ERROR;
1436 for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1437 privilege = (privilege_x *)tmp->data;
1438 if (privilege == NULL)
1440 ret = privilege_func(privilege->value, user_data);
1445 for (tmp = info->pkg_info->appdefined_privileges; tmp;
1447 appdefined_privilege = (appdefined_privilege_x *)tmp->data;
1448 if (appdefined_privilege == NULL)
1450 ret = privilege_func(appdefined_privilege->value, user_data);
1457 API int pkgmgrinfo_pkginfo_foreach_plugin(pkgmgrinfo_pkginfo_h handle,
1458 pkgmgrinfo_plugin_list_cb plugin_func, void *user_data)
1460 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1461 retvm_if(plugin_func == NULL, PMINFO_R_EINVAL,
1462 "Callback function is NULL");
1466 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1468 if (info->pkg_info == NULL)
1469 return PMINFO_R_ERROR;
1471 for (tmp = info->pkg_info->plugin; tmp; tmp = tmp->next) {
1472 plugin = (plugin_x *)tmp->data;
1475 ret = plugin_func(plugin->pkgid, plugin->appid,
1476 plugin->plugin_type, plugin->plugin_name, user_data);
1484 API int pkgmgrinfo_pkginfo_foreach_appdefined_privilege(
1485 pkgmgrinfo_pkginfo_h handle,
1486 pkgmgrinfo_pkg_appdefined_privilege_list_cb privilege_func,
1489 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1490 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL,
1491 "Callback function is NULL");
1493 appdefined_privilege_x *privilege;
1495 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1497 if (info->pkg_info == NULL)
1498 return PMINFO_R_ERROR;
1500 for (tmp = info->pkg_info->appdefined_privileges; tmp;
1502 privilege = (appdefined_privilege_x *)tmp->data;
1503 if (privilege == NULL)
1505 ret = privilege_func(privilege->value, privilege->license,
1513 API int pkgmgrinfo_pkginfo_foreach_dependency(pkgmgrinfo_pkginfo_h handle,
1514 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1518 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1520 dependency_x *dependency;
1522 if (handle == NULL || dependency_cb == NULL) {
1523 LOGE("invalid parameter");
1524 return PMINFO_R_EINVAL;
1527 if (info->pkg_info == NULL)
1528 return PMINFO_R_ERROR;
1530 for (tmp = info->pkg_info->dependencies; tmp; tmp = tmp->next) {
1531 dependency = (dependency_x *)tmp->data;
1532 if (dependency == NULL)
1534 ret = dependency_cb(info->pkg_info->package,
1535 dependency->depends_on, dependency->type,
1536 dependency->required_version, user_data);
1544 static void __free_depends_on(gpointer data)
1546 dependency_x *dep = (dependency_x *)data;
1547 pkgmgrinfo_basic_free_dependency(dep);
1550 /* This API is not exported at the header file */
1551 API int pkgmgrinfo_pkginfo_foreach_depends_on_by_pkgid(const char *pkgid,
1552 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1553 void *user_data, uid_t uid)
1556 GList *pkg_list = NULL;
1560 if (pkgid == NULL || dependency_cb == NULL) {
1561 LOGE("invalid parameter");
1562 return PMINFO_R_EINVAL;
1565 ret = _pkginfo_get_depends_on(uid, pkgid, &pkg_list);
1566 if (ret != PMINFO_R_OK)
1567 return PMINFO_R_ERROR;
1569 for (l = pkg_list; l != NULL; l = g_list_next(l)) {
1570 dep = (dependency_x *)l->data;
1571 ret = dependency_cb(dep->pkgid, dep->depends_on,
1572 dep->type, dep->required_version, user_data);
1576 g_list_free_full(pkg_list, __free_depends_on);
1581 API int pkgmgrinfo_pkginfo_foreach_depends_on(pkgmgrinfo_pkginfo_h handle,
1582 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1585 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1587 if (handle == NULL || dependency_cb == NULL || info->pkg_info == NULL) {
1588 LOGE("invalid parameter");
1589 return PMINFO_R_EINVAL;
1592 return pkgmgrinfo_pkginfo_foreach_depends_on_by_pkgid(
1593 info->pkg_info->package, dependency_cb, user_data,
1597 API int pkgmgrinfo_pkginfo_foreach_res_allowed_package(
1598 pkgmgrinfo_pkginfo_h handle,
1599 pkgmgrinfo_res_allowed_package_list_cb res_allowed_package_cb,
1603 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1605 res_allowed_package_x *res_allowed_package;
1607 if (handle == NULL || res_allowed_package_cb == NULL) {
1608 LOGE("invalid parameter");
1609 return PMINFO_R_EINVAL;
1612 if (info->pkg_info == NULL)
1613 return PMINFO_R_ERROR;
1615 for (res_pkgs = info->pkg_info->res_allowed_packages; res_pkgs;
1616 res_pkgs = res_pkgs->next) {
1617 res_allowed_package = (res_allowed_package_x *)res_pkgs->data;
1618 if (res_allowed_package == NULL)
1621 ret = res_allowed_package_cb(
1622 res_allowed_package->allowed_package,
1623 res_allowed_package->required_privileges,
1632 API int pkgmgrinfo_pkginfo_foreach_required_privilege(
1633 required_privilege_h handle,
1634 pkgmgrinfo_pkg_privilege_list_cb privilege_func,
1640 if (privilege_func == NULL) {
1641 LOGE("invalid parameter");
1642 return PMINFO_R_EINVAL;
1645 for (privs = (GList *)handle; privs; privs = privs->next) {
1646 ret = privilege_func((char *)privs->data, user_data);
1654 int __compare_package_version(const char *version, int *major,
1655 int *minor, int *macro, int *nano)
1657 char *version_temp = NULL;
1658 char *major_str = NULL;
1659 char *minor_str = NULL;
1660 char *macro_str = NULL;
1661 char *nano_str = NULL;
1662 char *save_str = NULL;
1664 if (version == NULL || major == NULL || minor == NULL ||
1665 macro == NULL || nano == NULL) {
1666 return PMINFO_R_EINVAL;
1669 version_temp = strdup(version);
1670 if (version_temp == NULL) {
1671 LOGE("Out of memory");
1672 return PMINFO_R_ERROR;
1675 major_str = strtok_r(version_temp, ".", &save_str);
1676 if (major_str == NULL) {
1677 _LOGE("major version is NULL");
1679 return PMINFO_R_ERROR;
1682 minor_str = strtok_r(NULL, ".", &save_str);
1683 if (minor_str == NULL) {
1684 _LOGE("minor version is NULL");
1686 return PMINFO_R_ERROR;
1689 *major = atoi(major_str);
1690 *minor = atoi(minor_str);
1693 macro_str = strtok_r(NULL, ".", &save_str);
1694 if (macro_str == NULL) {
1695 _LOGD("macro version is NULL");
1697 *macro = atoi(macro_str);
1698 nano_str = strtok_r(NULL, ".", &save_str);
1700 *nano = atoi(nano_str);
1701 _LOGD("nano version exists");
1704 _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1705 " macro = [%d], nano = [%d]", version, *major,
1706 *minor, *macro, *nano);
1713 API int pkgmgrinfo_compare_package_version(const char *current_version,
1714 const char *target_version,
1715 pkgmgrinfo_version_compare_type *res)
1718 int current_version_major = 0;
1719 int current_version_minor = 0;
1720 int current_version_macro = 0;
1721 int current_version_nano = 0;
1722 int target_version_major = 0;
1723 int target_version_minor = 0;
1724 int target_version_macro = 0;
1725 int target_version_nano = 0;
1727 if (current_version == NULL || target_version == NULL ||
1729 _LOGE("Invalid parameter");
1730 return PMINFO_R_EINVAL;
1733 ret = __compare_package_version(target_version,
1734 &target_version_major, &target_version_minor,
1735 &target_version_macro, &target_version_nano);
1737 _LOGE("Failed to compare target version(%d)", ret);
1738 return PMINFO_R_ERROR;
1741 ret = __compare_package_version(current_version,
1742 ¤t_version_major, ¤t_version_minor,
1743 ¤t_version_macro, ¤t_version_nano);
1745 _LOGE("Failed to compare current version(%d)", ret);
1746 return PMINFO_R_ERROR;
1749 _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
1750 target_version_minor, target_version_macro,
1751 target_version_nano, current_version_major,
1752 current_version_minor, current_version_macro,
1753 target_version_nano);
1755 if (target_version_major > current_version_major)
1756 *res = PMINFO_VERSION_NEW;
1757 else if (target_version_major < current_version_major)
1758 *res = PMINFO_VERSION_OLD;
1759 else if (target_version_minor > current_version_minor)
1760 *res = PMINFO_VERSION_NEW;
1761 else if (target_version_minor < current_version_minor)
1762 *res = PMINFO_VERSION_OLD;
1763 else if (target_version_macro > current_version_macro)
1764 *res = PMINFO_VERSION_NEW;
1765 else if (target_version_macro < current_version_macro)
1766 *res = PMINFO_VERSION_OLD;
1767 else if (target_version_nano > current_version_nano)
1768 *res = PMINFO_VERSION_NEW;
1769 else if (target_version_nano < current_version_nano)
1770 *res = PMINFO_VERSION_OLD;
1772 *res = PMINFO_VERSION_SAME;
1777 API int pkgmgrinfo_pkginfo_foreach_metadata(pkgmgrinfo_pkginfo_h handle,
1778 pkgmgrinfo_pkg_metadata_list_cb metadata_func, void *user_data)
1780 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1781 retvm_if(metadata_func == NULL, PMINFO_R_EINVAL,
1782 "Callback function is NULL");
1786 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1788 if (info->pkg_info == NULL)
1789 return PMINFO_R_ERROR;
1791 for (tmp = info->pkg_info->metadata; tmp; tmp = tmp->next) {
1792 ptr = (metadata_x *)tmp->data;
1796 ret = metadata_func(ptr->key, ptr->value ?
1797 ptr->value : "", user_data);
1805 API int pkgmgrinfo_pkginfo_metadata_filter_create(
1806 pkgmgrinfo_pkginfo_metadata_filter_h *handle)
1808 return pkgmgrinfo_pkginfo_filter_create(handle);
1811 API int pkgmgrinfo_pkginfo_metadata_filter_destroy(
1812 pkgmgrinfo_pkginfo_metadata_filter_h handle)
1814 return pkgmgrinfo_pkginfo_filter_destroy(handle);
1817 API int pkgmgrinfo_pkginfo_metadata_filter_add(
1818 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1819 const char *key, const char *value)
1821 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1822 pkgmgrinfo_metadata_node_x *node;
1824 /* value can be NULL.
1825 * In that case all pkgs with specified key should be displayed
1827 if (handle == NULL || key == NULL) {
1828 LOGE("invalid parameter");
1829 return PMINFO_R_EINVAL;
1832 node = calloc(1, sizeof(pkgmgrinfo_metadata_node_x));
1834 LOGE("out of memory");
1835 return PMINFO_R_ERROR;
1838 node->key = strdup(key);
1839 if (value && strlen(value))
1840 node->value = strdup(value);
1842 filter->list_pkg_metadata = g_slist_append(filter->list_pkg_metadata,
1848 API int pkgmgrinfo_pkginfo_usr_metadata_filter_foreach(
1849 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1850 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1852 if (handle == NULL || pkg_cb == NULL) {
1853 LOGE("invalid parameter");
1854 return PMINFO_R_EINVAL;
1857 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1859 if (pkgmgrinfo_pkginfo_filter_add_bool(filter,
1860 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false))
1861 return PMINFO_R_ERROR;
1863 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1864 PMINFO_PKGINFO_GET_ALL, pkg_cb,
1868 API int pkgmgrinfo_pkginfo_metadata_filter_foreach(
1869 pkgmgrinfo_pkginfo_metadata_filter_h handle,
1870 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1872 return pkgmgrinfo_pkginfo_usr_metadata_filter_foreach(handle, pkg_cb,
1873 user_data, _getuid());
1876 API int pkgmgrinfo_pkginfo_get_metadata_value(
1877 pkgmgrinfo_pkginfo_h handle, const char *metadata_key,
1878 char **metadata_value)
1880 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1881 retvm_if(metadata_key == NULL, PMINFO_R_EINVAL, "metadata_key is NULL");
1882 retvm_if(metadata_value == NULL, PMINFO_R_EINVAL,
1883 "metadata_value is NULL");
1885 GList *list_md = NULL;
1886 metadata_x *metadata = NULL;
1887 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1889 list_md = info->pkg_info->metadata;
1891 for (; list_md; list_md = list_md->next) {
1892 metadata = (metadata_x *)list_md->data;
1893 if (metadata && metadata->key) {
1894 if (strcasecmp(metadata->key, metadata_key) == 0) {
1895 if (metadata->value == NULL)
1896 *metadata_value = "";
1899 (char *)metadata->value;
1905 return PMINFO_R_EINVAL;