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"
42 #include "manager/pkginfo_manager.h"
44 static bool _get_bool_value(const char *str)
46 if (str && !strcmp(str, "true"))
52 static gint __compare_func(gconstpointer data1, gconstpointer data2)
54 pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x *)data1;
55 pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x *)data2;
56 if (node1->prop == node2->prop)
58 else if (node1->prop > node2->prop)
64 static gint __pkg_disable_chk_func(gconstpointer data1, gconstpointer data2)
66 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data1;
68 if (node->prop == E_PMINFO_PKGINFO_PROP_PACKAGE_DISABLE)
74 static void __destroy_each_node(gpointer data, gpointer user_data)
77 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x *)data;
90 static void __destroy_metadata_node(gpointer data)
92 pkgmgrinfo_metadata_node_x *node = (pkgmgrinfo_metadata_node_x *)data;
100 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
102 ret_if(data == NULL);
104 free((void *)data->locale);
108 pkgmgrinfo_basic_free_package(data->pkg_info);
114 static void __free_packages(gpointer data)
116 pkgmgrinfo_basic_free_package((package_x *)data);
119 static bool __check_disable_filter_exist(pkgmgrinfo_filter_x *filter)
126 link = g_slist_find_custom(filter->list, NULL, __pkg_disable_chk_func);
133 static int _pkginfo_get_filtered_foreach_pkginfo(uid_t uid,
134 pkgmgrinfo_filter_x *filter, int flag,
135 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
139 pkgmgr_pkginfo_x info;
144 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
147 return PMINFO_R_ERROR;
149 if (__check_disable_filter_exist(filter) == false) {
150 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
151 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
152 if (ret != PMINFO_R_OK) {
153 _LOGE("Failed to add filter");
154 g_hash_table_destroy(list);
155 return PMINFO_R_ERROR;
159 ret = _pkginfo_get_packages(uid, filter, flag, list);
160 if (ret != PMINFO_R_OK) {
161 g_hash_table_destroy(list);
162 return PMINFO_R_ERROR;
165 g_hash_table_iter_init(&iter, list);
166 while (g_hash_table_iter_next(&iter, NULL, &value)) {
167 pkg = (package_x *)value;
170 info.locale = pkg->locale;
171 if (pkg_list_cb(&info, user_data) < 0)
175 g_hash_table_destroy(list);
180 static int _pkgmgrinfo_get_pkginfo(const char *pkgid, uid_t uid,
181 pkgmgrinfo_pkginfo_filter_h filter, pkgmgrinfo_pkginfo_h *handle)
185 pkgmgr_pkginfo_x *info;
187 if (pkgid == NULL || filter == NULL || handle == NULL) {
188 LOGE("invalid parameter");
189 return PMINFO_R_EINVAL;
192 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
195 return PMINFO_R_ERROR;
197 ret = _pkginfo_get_packages(uid, filter, PMINFO_PKGINFO_GET_ALL, list);
198 if (ret != PMINFO_R_OK) {
199 g_hash_table_destroy(list);
203 if (!g_hash_table_size(list)) {
204 _LOGD("pkginfo for [%s] is not existed for user [%d]",
206 g_hash_table_destroy(list);
207 return PMINFO_R_ENOENT;
210 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
212 _LOGE("out of memory");
213 g_hash_table_destroy(list);
214 return PMINFO_R_ERROR;
218 info->pkg_info = (package_x *)g_hash_table_lookup(list, pkgid);
219 info->locale = strdup(info->pkg_info->locale);
220 if (info->locale == NULL) {
221 _LOGE("Out of memory");
222 g_hash_table_destroy(list);
224 return PMINFO_R_ERROR;
227 /* just free list only */
228 g_hash_table_steal(list, (gconstpointer)pkgid);
229 g_hash_table_destroy(list);
236 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
237 pkgmgrinfo_pkginfo_h *handle)
240 pkgmgrinfo_pkginfo_filter_h filter;
243 if (pkgid == NULL || handle == NULL) {
244 LOGE("invalid parameter");
245 return PMINFO_R_EINVAL;
248 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
251 return PMINFO_R_ERROR;
253 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
254 if (ret != PMINFO_R_OK)
257 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
258 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
259 if (ret != PMINFO_R_OK) {
260 pkgmgrinfo_pkginfo_filter_destroy(filter);
261 return PMINFO_R_ERROR;
264 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
265 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
266 if (ret != PMINFO_R_OK) {
267 pkgmgrinfo_pkginfo_filter_destroy(filter);
268 return PMINFO_R_ERROR;
270 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
271 pkgmgrinfo_pkginfo_filter_destroy(filter);
276 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid,
277 pkgmgrinfo_pkginfo_h *handle)
279 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, _getuid(), handle);
282 API int pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(const char *pkgid,
283 uid_t uid, pkgmgrinfo_pkginfo_h *handle)
286 pkgmgrinfo_pkginfo_filter_h filter;
288 if (pkgid == NULL || handle == NULL) {
289 LOGE("invalid parameter");
290 return PMINFO_R_EINVAL;
293 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
294 if (ret != PMINFO_R_OK) {
298 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
299 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
300 if (ret != PMINFO_R_OK) {
301 pkgmgrinfo_pkginfo_filter_destroy(filter);
302 return PMINFO_R_ERROR;
305 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
306 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
307 if (ret != PMINFO_R_OK) {
308 pkgmgrinfo_pkginfo_filter_destroy(filter);
309 return PMINFO_R_ERROR;
312 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
313 if (ret == PMINFO_R_ENOENT)
314 LOGE("disabled pkginfo for [%s] is not existed for user [%d]",
316 pkgmgrinfo_pkginfo_filter_destroy(filter);
320 API int pkgmgrinfo_pkginfo_get_usr_all_pkginfo(const char *pkgid, uid_t uid,
321 pkgmgrinfo_pkginfo_h *handle)
324 pkgmgrinfo_pkginfo_filter_h filter;
326 if (pkgid == NULL || handle == NULL) {
327 LOGE("invalid parameter");
328 return PMINFO_R_EINVAL;
331 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
332 if (ret != PMINFO_R_OK)
335 ret = pkgmgrinfo_pkginfo_filter_add_string(filter,
336 PMINFO_PKGINFO_PROP_PACKAGE_ID, pkgid);
337 if (ret != PMINFO_R_OK) {
338 pkgmgrinfo_pkginfo_filter_destroy(filter);
339 return PMINFO_R_ERROR;
342 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
343 PMINFO_PKGINFO_PROP_PACKAGE_CHECK_STORAGE, false);
344 if (ret != PMINFO_R_OK) {
345 pkgmgrinfo_pkginfo_filter_destroy(filter);
346 return PMINFO_R_ERROR;
349 ret = _pkgmgrinfo_get_pkginfo(pkgid, uid, filter, handle);
350 pkgmgrinfo_pkginfo_filter_destroy(filter);
355 API int pkgmgrinfo_pkginfo_get_disabled_pkginfo(const char *pkgid,
356 pkgmgrinfo_pkginfo_h *handle)
358 return pkgmgrinfo_pkginfo_get_usr_disabled_pkginfo(pkgid, _getuid(),
362 API int pkgmgrinfo_pkginfo_get_all_pkginfo(const char *pkgid,
363 pkgmgrinfo_pkginfo_h *handle)
365 return pkgmgrinfo_pkginfo_get_usr_all_pkginfo(pkgid, _getuid(), handle);
368 API int pkgmgrinfo_pkginfo_get_usr_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
369 int flag, void *user_data, uid_t uid)
372 pkgmgrinfo_pkginfo_filter_h filter;
374 if (pkg_list_cb == NULL) {
375 LOGE("invalid parameter");
376 return PMINFO_R_EINVAL;
379 /* create an empty filter */
380 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
381 if (ret != PMINFO_R_OK)
384 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter, flag,
385 pkg_list_cb, user_data);
387 pkgmgrinfo_pkginfo_filter_destroy(filter);
392 API int pkgmgrinfo_pkginfo_get_list_full(pkgmgrinfo_pkg_list_cb pkg_list_cb,
393 int flag, void *user_data)
395 return pkgmgrinfo_pkginfo_get_usr_list_full(pkg_list_cb, flag,
396 user_data, _getuid());
399 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
400 void *user_data, uid_t uid)
403 pkgmgrinfo_pkginfo_filter_h filter;
405 if (pkg_list_cb == NULL) {
406 LOGE("invalid parameter");
407 return PMINFO_R_EINVAL;
410 /* create an empty filter */
411 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
412 if (ret != PMINFO_R_OK)
415 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
416 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
418 pkgmgrinfo_pkginfo_filter_destroy(filter);
423 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
426 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data,
430 API int pkgmgrinfo_pkginfo_get_usr_disabled_list(
431 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
434 pkgmgrinfo_pkginfo_filter_h filter;
436 if (pkg_list_cb == NULL) {
437 LOGE("invalid parameter");
438 return PMINFO_R_EINVAL;
441 ret = pkgmgrinfo_pkginfo_filter_create(&filter);
442 if (ret != PMINFO_R_OK)
445 ret = pkgmgrinfo_pkginfo_filter_add_bool(filter,
446 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, true);
447 if (ret != PMINFO_R_OK) {
448 pkgmgrinfo_pkginfo_filter_destroy(filter);
449 return PMINFO_R_ERROR;
452 ret = _pkginfo_get_filtered_foreach_pkginfo(uid, filter,
453 PMINFO_PKGINFO_GET_ALL, pkg_list_cb, user_data);
455 pkgmgrinfo_pkginfo_filter_destroy(filter);
460 API int pkgmgrinfo_pkginfo_get_disabled_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
463 return pkgmgrinfo_pkginfo_get_usr_disabled_list(pkg_list_cb, user_data,
467 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
469 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
471 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
472 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
474 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
475 return PMINFO_R_ERROR;
477 *pkg_name = (char *)info->pkg_info->package;
482 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
484 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
486 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
487 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
489 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
490 return PMINFO_R_ERROR;
492 *pkgid = (char *)info->pkg_info->package;
497 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
499 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
501 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
502 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
504 if (info->pkg_info == NULL)
505 return PMINFO_R_ERROR;
507 if (info->pkg_info->type == NULL)
510 *type = (char *)info->pkg_info->type;
515 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
517 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
519 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
520 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
522 if (info->pkg_info == NULL)
523 return PMINFO_R_ERROR;
525 if (info->pkg_info->version == NULL)
528 *version = (char *)info->pkg_info->version;
533 API int pkgmgrinfo_pkginfo_get_api_version(pkgmgrinfo_pkginfo_h handle, char **api_version)
535 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
537 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
538 retvm_if(api_version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
540 if (info->pkg_info == NULL)
541 return PMINFO_R_ERROR;
543 if (info->pkg_info->api_version == NULL)
546 *api_version = (char *)info->pkg_info->api_version;
551 API int pkgmgrinfo_pkginfo_get_tep_name(pkgmgrinfo_pkginfo_h handle, char **tep_name)
553 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
555 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
556 retvm_if(tep_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
558 if (info->pkg_info == NULL || info->pkg_info->tep_name == NULL)
559 return PMINFO_R_ERROR;
561 *tep_name = (char *)info->pkg_info->tep_name;
566 API int pkgmgrinfo_pkginfo_get_zip_mount_file(pkgmgrinfo_pkginfo_h handle, char **zip_mount_file)
568 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
570 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
571 retvm_if(zip_mount_file == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
573 if (info->pkg_info == NULL)
574 return PMINFO_R_ERROR;
576 if (info->pkg_info->zip_mount_file == NULL)
577 *zip_mount_file = "";
579 *zip_mount_file = (char *)info->pkg_info->zip_mount_file;
584 API int pkgmgrinfo_pkginfo_get_external_image_path(pkgmgrinfo_pkginfo_h handle, char **ext_image_path)
586 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
588 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
589 retvm_if(ext_image_path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
591 if (info->pkg_info == NULL)
592 return PMINFO_R_ERROR;
594 if (info->pkg_info->external_path == NULL)
595 return PMINFO_R_ENOENT;
597 *ext_image_path = (char *)info->pkg_info->external_path;
602 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
605 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
607 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
608 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
610 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
611 return PMINFO_R_ERROR;
613 val = (char *)info->pkg_info->installlocation;
614 if (strcmp(val, "internal-only") == 0)
615 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
616 else if (strcmp(val, "prefer-external") == 0)
617 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
619 *location = PMINFO_INSTALL_LOCATION_AUTO;
624 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
626 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
629 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
630 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
632 if (info->pkg_info == NULL)
633 return PMINFO_R_ERROR;
635 if (info->pkg_info->package_size == NULL) {
638 _LOGE("out of memory");
639 return PMINFO_R_ERROR;
641 info->pkg_info->package_size = temp;
645 *size = atoi((char *)info->pkg_info->package_size);
650 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
653 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
655 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
656 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
658 if (info->pkg_info == NULL || info->pkg_info->icon == NULL)
659 return PMINFO_R_ERROR;
661 ptr = (icon_x *)info->pkg_info->icon->data;
663 return PMINFO_R_ERROR;
665 /* TODO : should we return empty string if there was no icon? */
666 if (ptr->text == NULL)
674 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
677 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
679 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
680 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
682 if (info->pkg_info == NULL || info->pkg_info->label == NULL)
683 return PMINFO_R_ERROR;
685 ptr = (label_x *)info->pkg_info->label->data;
687 return PMINFO_R_ERROR;
689 /* TODO : should we return empty string if there was no label? */
690 if (ptr->text == NULL)
698 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
701 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
703 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
704 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
706 if (info->pkg_info == NULL || info->pkg_info->description == NULL)
707 return PMINFO_R_ERROR;
709 ptr = (description_x *)info->pkg_info->description->data;
711 return PMINFO_R_ERROR;
713 if (ptr->text == NULL)
716 *description = (char *)ptr->text;
721 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
723 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
726 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
727 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
729 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
730 return PMINFO_R_ERROR;
732 author = (author_x *)info->pkg_info->author->data;
734 return PMINFO_R_ERROR;
736 if (author->text == NULL)
739 *author_name = (char *)author->text;
744 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
746 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
749 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
750 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
752 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
753 return PMINFO_R_ERROR;
755 author = (author_x *)info->pkg_info->author->data;
757 return PMINFO_R_ERROR;
759 if (author->email == NULL)
762 *author_email = (char *)author->email;
767 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
769 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
772 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
773 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
775 if (info->pkg_info == NULL || info->pkg_info->author == NULL)
776 return PMINFO_R_ERROR;
778 author = (author_x *)info->pkg_info->author->data;
780 return PMINFO_R_ERROR;
782 if (author->href == NULL)
785 *author_href = (char *)author->href;
790 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
792 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
794 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
795 retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
797 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
798 return PMINFO_R_ERROR;
800 if (strcmp(info->pkg_info->installed_storage, "installed_internal") == 0)
801 *storage = PMINFO_INTERNAL_STORAGE;
802 else if (strcmp(info->pkg_info->installed_storage, "installed_external") == 0)
803 *storage = PMINFO_EXTERNAL_STORAGE;
804 else if (strcmp(info->pkg_info->installed_storage, "installed_extended") == 0)
805 *storage = PMINFO_EXTENDED_STORAGE;
807 return PMINFO_R_ERROR;
812 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
814 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
816 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
817 retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
819 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
820 return PMINFO_R_ERROR;
822 *installed_time = atoi(info->pkg_info->installed_time);
827 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
829 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
831 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
832 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
834 if (info->pkg_info == NULL)
835 return PMINFO_R_ERROR;
837 if (info->pkg_info->storeclient_id == NULL)
840 *storeclientid = (char *)info->pkg_info->storeclient_id;
845 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
847 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
849 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
850 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
852 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
853 return PMINFO_R_ERROR;
855 *mainappid = (char *)info->pkg_info->mainapp_id;
860 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
862 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
864 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
865 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
867 if (info->pkg_info == NULL)
868 return PMINFO_R_ERROR;
870 if (info->pkg_info->package_url == NULL)
873 *url = (char *)info->pkg_info->package_url;
878 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
880 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
882 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
883 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
885 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
886 return PMINFO_R_ERROR;
888 *path = (char *)info->pkg_info->root_path;
893 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
895 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
897 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
898 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
900 if (info->pkg_info == NULL)
901 return PMINFO_R_ERROR;
903 if (info->pkg_info->csc_path == NULL)
906 *path = (char *)info->pkg_info->csc_path;
911 API int pkgmgrinfo_pkginfo_get_support_mode(pkgmgrinfo_pkginfo_h handle, int *support_mode)
913 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
914 retvm_if(support_mode == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
916 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
917 if (info->pkg_info->support_mode)
918 *support_mode = atoi(info->pkg_info->support_mode);
925 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
927 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
928 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
930 #if 0 /* smack issue occured, check later */
932 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
934 _LOGD("invalid func parameters\n");
935 return PMINFO_R_ERROR;
937 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
940 char app_mmc_path[FILENAME_MAX] = { 0, };
941 char app_dir_path[FILENAME_MAX] = { 0, };
942 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
943 snprintf(app_dir_path, FILENAME_MAX, "%s%s", PKG_INSTALLATION_PATH, pkgid);
944 snprintf(app_mmc_path, FILENAME_MAX, "%s%s", PKG_SD_PATH, pkgid);
945 snprintf(app_mmc_internal_path, FILENAME_MAX, "%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
947 /*check whether application is in external memory or not */
948 fp = fopen(app_mmc_path, "r");
950 _LOGD(" app path in external memory not accesible\n");
955 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
959 /*check whether application is in internal or not */
961 _LOGD(" app path in internal memory not accesible\n");
963 return PMINFO_R_ERROR;
966 /*check whether the application is installed in SD card
967 but SD card is not present*/
968 fp = fopen(app_mmc_internal_path, "r");
971 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
975 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
980 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
987 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
989 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
991 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
992 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
994 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
995 return PMINFO_R_ERROR;
997 *removable = _get_bool_value(info->pkg_info->removable);
1002 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1005 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1007 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1008 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1010 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1011 return PMINFO_R_ERROR;
1013 val = (char *)info->pkg_info->installlocation;
1014 if (strcmp(val, "internal-only") == 0)
1022 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
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(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1029 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1030 return PMINFO_R_ERROR;
1032 *preload = _get_bool_value(info->pkg_info->preload);
1037 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1039 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1041 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1042 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1044 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1045 return PMINFO_R_ERROR;
1047 *system = _get_bool_value(info->pkg_info->system);
1052 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1054 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1056 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1057 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1059 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1060 return PMINFO_R_ERROR;
1062 *readonly = _get_bool_value(info->pkg_info->readonly);
1067 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1069 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1071 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1072 retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1074 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1075 return PMINFO_R_ERROR;
1077 *update = _get_bool_value(info->pkg_info->update);
1082 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1084 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1086 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1087 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1089 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1090 return PMINFO_R_ERROR;
1092 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1097 API int pkgmgrinfo_pkginfo_is_global(pkgmgrinfo_pkginfo_h handle, bool *global)
1099 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1101 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1102 retvm_if(global == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1104 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1105 return PMINFO_R_ERROR;
1107 *global = _get_bool_value(info->pkg_info->for_all_users);
1112 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1114 return pkgmgrinfo_pkginfo_is_global(handle, for_all_users);
1117 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1119 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1121 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1123 __cleanup_pkginfo(info);
1128 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1130 pkgmgrinfo_filter_x *filter;
1132 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1134 filter = (pkgmgrinfo_filter_x *)calloc(1, sizeof(pkgmgrinfo_filter_x));
1135 if (filter == NULL) {
1136 _LOGE("Out of Memory!!!");
1137 return PMINFO_R_ERROR;
1145 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1147 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1149 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1152 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1153 g_slist_free(filter->list);
1156 g_slist_free_full(filter->list_metadata, __destroy_metadata_node);
1163 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1164 const char *property, const int value)
1166 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1170 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1171 pkgmgrinfo_node_x *node;
1173 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1174 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1176 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1177 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1178 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1179 _LOGE("Invalid Integer Property\n");
1180 return PMINFO_R_EINVAL;
1182 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1184 _LOGE("Out of Memory!!!\n");
1185 return PMINFO_R_ERROR;
1187 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1188 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1190 _LOGE("Out of Memory\n");
1192 return PMINFO_R_ERROR;
1196 /*If API is called multiple times for same property, we should override the previous values.
1197 Last value set will be used for filtering.*/
1198 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1200 filter->list = g_slist_delete_link(filter->list, link);
1201 filter->list = g_slist_append(filter->list, (gpointer)node);
1206 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1207 const char *property, const bool value)
1212 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1213 pkgmgrinfo_node_x *node;
1215 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1216 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1218 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1219 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1220 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1221 _LOGE("Invalid Boolean Property\n");
1222 return PMINFO_R_EINVAL;
1224 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1226 _LOGE("Out of Memory!!!\n");
1227 return PMINFO_R_ERROR;
1230 val = strndup("true", 4);
1232 val = strndup("false", 5);
1234 _LOGE("Out of Memory\n");
1236 return PMINFO_R_ERROR;
1240 /*If API is called multiple times for same property, we should override the previous values.
1241 Last value set will be used for filtering.*/
1242 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1244 filter->list = g_slist_delete_link(filter->list, link);
1245 filter->list = g_slist_append(filter->list, (gpointer)node);
1250 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1251 const char *property, const char *value)
1256 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1257 pkgmgrinfo_node_x *node;
1259 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1260 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1261 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1263 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1264 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1265 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1266 _LOGE("Invalid String Property\n");
1267 return PMINFO_R_EINVAL;
1269 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1271 _LOGE("Out of Memory!!!\n");
1272 return PMINFO_R_ERROR;
1274 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1275 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1276 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1277 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1278 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1279 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1280 else if (strcmp(value, "installed_internal") == 0)
1281 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1282 else if (strcmp(value, "installed_external") == 0)
1283 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1285 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1287 _LOGE("Out of Memory\n");
1289 return PMINFO_R_ERROR;
1293 /*If API is called multiple times for same property, we should override the previous values.
1294 Last value set will be used for filtering.*/
1295 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1297 filter->list = g_slist_delete_link(filter->list, link);
1298 filter->list = g_slist_append(filter->list, (gpointer)node);
1303 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1306 GHashTable *list = NULL;
1308 if (handle == NULL || count == NULL) {
1309 _LOGE("invalid parameter");
1310 return PMINFO_R_EINVAL;
1313 list = g_hash_table_new_full(g_str_hash, g_str_equal, NULL,
1316 return PMINFO_R_ERROR;
1318 if (__check_disable_filter_exist((pkgmgrinfo_filter_x *)handle) == false) {
1319 ret = pkgmgrinfo_pkginfo_filter_add_bool(handle,
1320 PMINFO_PKGINFO_PROP_PACKAGE_DISABLE, false);
1321 if (ret != PMINFO_R_OK) {
1322 g_hash_table_destroy(list);
1323 return PMINFO_R_ERROR;
1327 ret = _pkginfo_get_packages(uid, handle, PMINFO_PKGINFO_GET_BASICINFO, list);
1328 if (ret != PMINFO_R_OK) {
1329 g_hash_table_destroy(list);
1330 return PMINFO_R_ERROR;
1332 *count = g_hash_table_size(list);
1334 g_hash_table_destroy(list);
1339 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1341 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, _getuid());
1344 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1345 pkgmgrinfo_pkginfo_filter_h handle,
1346 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1348 if (handle == NULL || pkg_cb == NULL) {
1349 LOGE("invalid parameter");
1350 return PMINFO_R_EINVAL;
1353 return _pkginfo_get_filtered_foreach_pkginfo(uid, handle,
1354 PMINFO_PKGINFO_GET_ALL, pkg_cb, user_data);
1357 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1358 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1360 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, _getuid());
1363 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1364 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1366 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1367 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1369 privilege_x *privilege;
1370 appdefined_privilege_x *appdefined_privilege;
1372 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1374 if (info->pkg_info == NULL)
1375 return PMINFO_R_ERROR;
1377 for (tmp = info->pkg_info->privileges; tmp; tmp = tmp->next) {
1378 privilege = (privilege_x *)tmp->data;
1379 if (privilege == NULL)
1381 ret = privilege_func(privilege->value, user_data);
1386 for (tmp = info->pkg_info->appdefined_privileges; tmp;
1388 appdefined_privilege = (appdefined_privilege_x *)tmp->data;
1389 if (appdefined_privilege == NULL)
1391 ret = privilege_func(appdefined_privilege->value, user_data);
1398 API int pkgmgrinfo_pkginfo_foreach_plugin(pkgmgrinfo_pkginfo_h handle,
1399 pkgmgrinfo_plugin_list_cb plugin_func, void *user_data)
1401 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1402 retvm_if(plugin_func == NULL, PMINFO_R_EINVAL,
1403 "Callback function is NULL");
1407 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1409 if (info->pkg_info == NULL)
1410 return PMINFO_R_ERROR;
1412 for (tmp = info->pkg_info->plugin; tmp; tmp = tmp->next) {
1413 plugin = (plugin_x *)tmp->data;
1416 ret = plugin_func(plugin->pkgid, plugin->appid,
1417 plugin->plugin_type, plugin->plugin_name, user_data);
1425 API int pkgmgrinfo_pkginfo_foreach_appdefined_privilege(
1426 pkgmgrinfo_pkginfo_h handle,
1427 pkgmgrinfo_pkg_appdefined_privilege_list_cb privilege_func,
1430 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1431 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL,
1432 "Callback function is NULL");
1434 appdefined_privilege_x *privilege;
1436 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1438 if (info->pkg_info == NULL)
1439 return PMINFO_R_ERROR;
1441 for (tmp = info->pkg_info->appdefined_privileges; tmp;
1443 privilege = (appdefined_privilege_x *)tmp->data;
1444 if (privilege == NULL)
1446 ret = privilege_func(privilege->value, privilege->license,
1454 API int pkgmgrinfo_pkginfo_foreach_dependency(pkgmgrinfo_pkginfo_h handle,
1455 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1459 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1461 dependency_x *dependency;
1463 if (handle == NULL || dependency_cb == NULL) {
1464 LOGE("invalid parameter");
1465 return PMINFO_R_EINVAL;
1468 if (info->pkg_info == NULL)
1469 return PMINFO_R_ERROR;
1471 for (tmp = info->pkg_info->dependencies; tmp; tmp = tmp->next) {
1472 dependency = (dependency_x *)tmp->data;
1473 if (dependency == NULL)
1475 ret = dependency_cb(info->pkg_info->package,
1476 dependency->depends_on, dependency->type,
1477 dependency->required_version, user_data);
1492 static int _get_depends_on(sqlite3 *db, const char *pkgid, GQueue **queue,
1493 GHashTable **table, GList **pkg_list)
1495 static const char query[] =
1496 "SELECT package, depends_on, type, required_version "
1497 "FROM package_dependency_info WHERE depends_on=?";
1500 struct depends_on *req;
1502 /* already checked */
1503 if (!g_hash_table_insert(*table, strdup(pkgid), GINT_TO_POINTER(1)))
1506 ret = sqlite3_prepare_v2(db, query, strlen(query), &stmt, NULL);
1507 if (ret != SQLITE_OK) {
1508 LOGE("prepare failed: %s", sqlite3_errmsg(db));
1509 return PMINFO_R_ERROR;
1512 ret = sqlite3_bind_text(stmt, 1, pkgid, -1, SQLITE_STATIC);
1513 if (ret != SQLITE_OK) {
1514 LOGE("bind failed: %s", sqlite3_errmsg(db));
1515 sqlite3_finalize(stmt);
1516 return PMINFO_R_ERROR;
1519 while (sqlite3_step(stmt) == SQLITE_ROW) {
1520 req = calloc(1, sizeof(struct depends_on));
1522 LOGE("out of memory");
1523 sqlite3_finalize(stmt);
1524 return PMINFO_R_ERROR;
1526 _save_column_str(stmt, 0, &req->from);
1527 _save_column_str(stmt, 1, &req->to);
1528 _save_column_str(stmt, 2, &req->type);
1529 _save_column_str(stmt, 3, &req->version);
1531 *pkg_list = g_list_prepend(*pkg_list, req);
1532 g_queue_push_tail(*queue, strdup(req->from));
1535 sqlite3_finalize(stmt);
1540 static int _pkginfo_foreach_depends_on(uid_t uid, const char *pkgid,
1550 dbpath = getUserPkgParserDBPathUID(uid);
1552 return PMINFO_R_ERROR;
1554 ret = __open_db(dbpath, &db, SQLITE_OPEN_READONLY);
1555 if (ret != SQLITE_OK) {
1556 LOGD("failed to open db(%s): %d", dbpath, ret);
1558 return PMINFO_R_ERROR;
1562 queue = g_queue_new();
1563 if (queue == NULL) {
1564 LOGE("out of memory");
1565 sqlite3_close_v2(db);
1566 return PMINFO_R_ERROR;
1569 table = g_hash_table_new_full(g_str_hash, g_str_equal, free, NULL);
1571 g_queue_push_tail(queue, strdup(pkgid));
1572 while (!g_queue_is_empty(queue)) {
1573 item = g_queue_pop_head(queue);
1574 ret = _get_depends_on(db, item, &queue, &table, pkg_list);
1576 if (ret != PMINFO_R_OK) {
1577 LOGE("failed to get pkgs depends on %s", pkgid);
1578 g_hash_table_destroy(table);
1579 g_queue_free_full(queue, free);
1580 sqlite3_close_v2(db);
1581 return PMINFO_R_ERROR;
1585 g_hash_table_destroy(table);
1586 g_queue_free_full(queue, free);
1587 sqlite3_close_v2(db);
1592 static void __free_depends_on(gpointer data)
1594 struct depends_on *dep = (struct depends_on *)data;
1603 // TODO: need to change this
1604 API int pkgmgrinfo_pkginfo_foreach_depends_on(pkgmgrinfo_pkginfo_h handle,
1605 pkgmgrinfo_pkg_dependency_list_cb dependency_cb,
1609 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1610 GList *pkg_list = NULL;
1612 struct depends_on *dep;
1614 if (handle == NULL || dependency_cb == NULL || info->pkg_info == NULL) {
1615 LOGE("invalid parameter");
1616 return PMINFO_R_EINVAL;
1619 ret = _pkginfo_foreach_depends_on(info->uid, info->pkg_info->package,
1621 if (ret == PMINFO_R_OK && info->uid != GLOBAL_USER)
1622 ret = _pkginfo_foreach_depends_on(GLOBAL_USER,
1623 info->pkg_info->package, &pkg_list);
1625 if (ret != PMINFO_R_OK) {
1626 g_list_free_full(pkg_list, __free_depends_on);
1630 for (l = pkg_list; l != NULL; l = l->next) {
1631 dep = (struct depends_on *)l->data;
1632 ret = dependency_cb(dep->from, dep->to, dep->type, dep->version,
1638 g_list_free_full(pkg_list, __free_depends_on);
1643 int __compare_package_version(const char *version, int *major,
1644 int *minor, int *macro, int *nano)
1646 char *version_temp = NULL;
1647 char *major_str = NULL;
1648 char *minor_str = NULL;
1649 char *macro_str = NULL;
1650 char *nano_str = NULL;
1651 char *save_str = NULL;
1653 if (version == NULL || major == NULL || minor == NULL ||
1654 macro == NULL || nano == NULL) {
1655 return PMINFO_R_EINVAL;
1658 version_temp = strdup(version);
1659 if (version_temp == NULL) {
1660 LOGE("Out of memory");
1661 return PMINFO_R_ERROR;
1664 major_str = strtok_r(version_temp, ".", &save_str);
1665 if (major_str == NULL) {
1666 _LOGE("major version is NULL");
1668 return PMINFO_R_ERROR;
1671 minor_str = strtok_r(NULL, ".", &save_str);
1672 if (minor_str == NULL) {
1673 _LOGE("minor version is NULL");
1675 return PMINFO_R_ERROR;
1678 *major = atoi(major_str);
1679 *minor = atoi(minor_str);
1682 macro_str = strtok_r(NULL, ".", &save_str);
1683 if (macro_str == NULL) {
1684 _LOGD("macro version is NULL");
1686 *macro = atoi(macro_str);
1687 nano_str = strtok_r(NULL, ".", &save_str);
1689 *nano = atoi(nano_str);
1690 _LOGD("nano version exists");
1693 _LOGD("version = [%s] -> major = [%d], minor = [%d]," \
1694 " macro = [%d], nano = [%d]", version, *major,
1695 *minor, *macro, *nano);
1702 API int pkgmgrinfo_compare_package_version(const char *current_version,
1703 const char *target_version,
1704 pkgmgrinfo_version_compare_type *res)
1707 int current_version_major = 0;
1708 int current_version_minor = 0;
1709 int current_version_macro = 0;
1710 int current_version_nano = 0;
1711 int target_version_major = 0;
1712 int target_version_minor = 0;
1713 int target_version_macro = 0;
1714 int target_version_nano = 0;
1716 if (current_version == NULL || target_version == NULL ||
1718 _LOGE("Invalid parameter");
1719 return PMINFO_R_EINVAL;
1722 ret = __compare_package_version(target_version,
1723 &target_version_major, &target_version_minor,
1724 &target_version_macro, &target_version_nano);
1726 _LOGE("Failed to compare target version(%d)", ret);
1727 return PMINFO_R_ERROR;
1730 ret = __compare_package_version(current_version,
1731 ¤t_version_major, ¤t_version_minor,
1732 ¤t_version_macro, ¤t_version_nano);
1734 _LOGE("Failed to compare current version(%d)", ret);
1735 return PMINFO_R_ERROR;
1738 _LOGD("new[%d.%d.%d.%d] old[%d.%d.%d.%d]", target_version_major,
1739 target_version_minor, target_version_macro,
1740 target_version_nano, current_version_major,
1741 current_version_minor, current_version_macro,
1742 target_version_nano);
1744 if (target_version_major > current_version_major)
1745 *res = PMINFO_VERSION_NEW;
1746 else if (target_version_major < current_version_major)
1747 *res = PMINFO_VERSION_OLD;
1748 else if (target_version_minor > current_version_minor)
1749 *res = PMINFO_VERSION_NEW;
1750 else if (target_version_minor < current_version_minor)
1751 *res = PMINFO_VERSION_OLD;
1752 else if (target_version_macro > current_version_macro)
1753 *res = PMINFO_VERSION_NEW;
1754 else if (target_version_macro < current_version_macro)
1755 *res = PMINFO_VERSION_OLD;
1756 else if (target_version_nano > current_version_nano)
1757 *res = PMINFO_VERSION_NEW;
1758 else if (target_version_nano < current_version_nano)
1759 *res = PMINFO_VERSION_OLD;
1761 *res = PMINFO_VERSION_SAME;