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>
35 #include <libxml/parser.h>
36 #include <libxml/xmlreader.h>
37 #include <libxml/xmlschemas.h>
41 #include "pkgmgr_parser.h"
42 #include "pkgmgrinfo_basic.h"
43 #include "pkgmgrinfo_private.h"
44 #include "pkgmgrinfo_debug.h"
45 #include "pkgmgr-info.h"
46 #include "pkgmgr_parser_db.h"
47 #include "pkgmgr_parser_internal.h"
49 static int _pkginfo_get_pkginfo(const char *pkgid, uid_t uid,
50 pkgmgr_pkginfo_x **pkginfo);
51 static char *_get_filtered_query(const char *query_raw,
52 pkgmgrinfo_filter_x *filter);
54 static bool _get_bool_value(const char *str)
58 else if (!strcasecmp(str, "true"))
64 static gint __compare_func(gconstpointer data1, gconstpointer data2)
66 pkgmgrinfo_node_x *node1 = (pkgmgrinfo_node_x*)data1;
67 pkgmgrinfo_node_x *node2 = (pkgmgrinfo_node_x*)data2;
68 if (node1->prop == node2->prop)
70 else if (node1->prop > node2->prop)
76 static void __destroy_each_node(gpointer data, gpointer user_data)
79 pkgmgrinfo_node_x *node = (pkgmgrinfo_node_x*)data;
92 static void __cleanup_pkginfo(pkgmgr_pkginfo_x *data)
96 free((void *)data->locale);
100 pkgmgrinfo_basic_free_package(data->pkg_info);
106 static int __child_element(xmlTextReaderPtr reader, int depth)
108 int ret = xmlTextReaderRead(reader);
109 int cur = xmlTextReaderDepth(reader);
112 switch (xmlTextReaderNodeType(reader)) {
113 case XML_READER_TYPE_ELEMENT:
114 if (cur == depth + 1)
117 case XML_READER_TYPE_TEXT:
118 /*text is handled by each function separately*/
119 if (cur == depth + 1)
122 case XML_READER_TYPE_END_ELEMENT:
131 ret = xmlTextReaderRead(reader);
132 cur = xmlTextReaderDepth(reader);
137 long long _pkgmgr_calculate_dir_size(char *dirname)
141 int q = 0; /*quotient*/
142 int r = 0; /*remainder*/
144 struct dirent *ep = NULL;
145 struct stat fileinfo;
146 char abs_filename[FILENAME_MAX] = { 0, };
147 retvm_if(dirname == NULL, PMINFO_R_ERROR, "dirname is NULL");
149 dp = opendir(dirname);
151 while ((ep = readdir(dp)) != NULL) {
152 if (!strcmp(ep->d_name, ".") ||
153 !strcmp(ep->d_name, "..")) {
156 snprintf(abs_filename, FILENAME_MAX, "%s/%s", dirname,
158 if (lstat(abs_filename, &fileinfo) < 0)
159 perror(abs_filename);
161 if (S_ISDIR(fileinfo.st_mode)) {
162 total += fileinfo.st_size;
163 if (strcmp(ep->d_name, ".")
164 && strcmp(ep->d_name, "..")) {
165 ret = _pkgmgr_calculate_dir_size
169 } else if (S_ISLNK(fileinfo.st_mode)) {
172 /*It is a file. Calculate the actual
173 size occupied (in terms of 4096 blocks)*/
174 q = (fileinfo.st_size / BLOCK_SIZE);
175 r = (fileinfo.st_size % BLOCK_SIZE);
179 total += q * BLOCK_SIZE;
185 _LOGE("Couldn't open the directory\n");
192 static gint __list_strcmp(gconstpointer a, gconstpointer b)
194 return strcmp((char *)a, (char *)b);
197 static int _pkginfo_get_list(sqlite3 *db, const char *locale,
198 pkgmgrinfo_filter_x *filter, GList **list)
200 static const char query_raw[] =
201 "SELECT DISTINCT package_info.package FROM package_info"
202 " LEFT OUTER JOIN package_localized_info"
203 " ON package_info.package=package_localized_info.package"
204 " AND package_localized_info.package_locale=%Q "
205 " LEFT OUTER JOIN package_privilege_info"
206 " ON package_info.package=package_privilege_info.package";
209 char *query_localized;
213 query = _get_filtered_query(query_raw, filter);
216 query_localized = sqlite3_mprintf(query, locale);
218 if (query_localized == NULL)
221 ret = sqlite3_prepare_v2(db, query_localized,
222 strlen(query_localized), &stmt, NULL);
223 sqlite3_free(query_localized);
224 if (ret != SQLITE_OK) {
225 LOGE("prepare failed: %s", sqlite3_errmsg(db));
229 while (sqlite3_step(stmt) == SQLITE_ROW) {
230 _save_column_str(stmt, 0, (const char **)&pkgid);
232 *list = g_list_insert_sorted(*list, pkgid,
236 sqlite3_finalize(stmt);
241 static int _pkginfo_get_filtered_list(pkgmgrinfo_filter_x *filter, uid_t uid,
251 locale = _get_system_locale();
253 return PMINFO_R_ERROR;
255 dbpath = getUserPkgParserDBPathUID(uid);
256 if (dbpath == NULL) {
258 return PMINFO_R_ERROR;
261 ret = sqlite3_open_v2(dbpath, &db, SQLITE_OPEN_READONLY, NULL);
262 if (ret != SQLITE_OK) {
263 _LOGE("failed to open db: %d", ret);
265 return PMINFO_R_ERROR;
268 if (_pkginfo_get_list(db, locale, filter, list)) {
270 sqlite3_close_v2(db);
271 return PMINFO_R_ERROR;
273 sqlite3_close_v2(db);
275 if (uid == GLOBAL_USER) {
280 /* search again from global */
281 dbpath = getUserPkgParserDBPathUID(GLOBAL_USER);
282 if (dbpath == NULL) {
284 return PMINFO_R_ERROR;
287 ret = sqlite3_open_v2(dbpath, &db, SQLITE_OPEN_READONLY, NULL);
288 if (ret != SQLITE_OK) {
289 _LOGE("failed to open db: %d", ret);
291 return PMINFO_R_ERROR;
294 if (_pkginfo_get_list(db, locale, filter, list)) {
296 sqlite3_close_v2(db);
297 return PMINFO_R_ERROR;
299 sqlite3_close_v2(db);
301 /* remove duplicate element:
302 * since the list is sorted, we can remove duplicates in linear time
304 for (tmp = *list, tmp2 = g_list_next(tmp); tmp;
305 tmp = tmp2, tmp2 = g_list_next(tmp)) {
306 if (tmp->prev == NULL || tmp->data == NULL)
308 if (strcmp((const char *)tmp->prev->data,
309 (const char *)tmp->data) == 0)
310 *list = g_list_delete_link(*list, tmp);
319 static int _pkginfo_get_filtered_foreach_pkginfo(pkgmgrinfo_filter_x *filter,
320 pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data, uid_t uid)
323 pkgmgr_pkginfo_x *info;
329 ret = _pkginfo_get_filtered_list(filter, uid, &list);
330 if (ret != PMINFO_R_OK)
331 return PMINFO_R_ERROR;
333 for (tmp = list; tmp; tmp = tmp->next) {
334 pkgid = (char *)tmp->data;
336 ret = _pkginfo_get_pkginfo(pkgid, uid, &info);
337 if (ret == PMINFO_R_ENOENT && uid != GLOBAL_USER)
338 ret = _pkginfo_get_pkginfo(pkgid, GLOBAL_USER,
340 if (ret != PMINFO_R_OK) {
344 if (pkg_list_cb(info, user_data) < 0)
346 pkgmgrinfo_pkginfo_destroy_pkginfo(info);
356 API int pkgmgrinfo_pkginfo_get_usr_list(pkgmgrinfo_pkg_list_cb pkg_list_cb,
357 void *user_data, uid_t uid)
359 if (pkg_list_cb == NULL) {
360 LOGE("invalid parameter");
361 return PMINFO_R_EINVAL;
364 return _pkginfo_get_filtered_foreach_pkginfo(NULL, pkg_list_cb,
368 API int pkgmgrinfo_pkginfo_get_list(pkgmgrinfo_pkg_list_cb pkg_list_cb, void *user_data)
370 return pkgmgrinfo_pkginfo_get_usr_list(pkg_list_cb, user_data, GLOBAL_USER);
373 static int _pkginfo_get_author(sqlite3 *db, const char *pkgid,
376 static const char query_raw[] =
377 "SELECT author_name, author_email, author_href "
378 "FROM package_info WHERE package=%Q";
385 query = sqlite3_mprintf(query_raw, pkgid);
387 LOGE("out of memory");
388 return PMINFO_R_ERROR;
391 ret = sqlite3_prepare_v2(db, query, strlen(query),
394 if (ret != SQLITE_OK) {
395 LOGE("prepare failed: %s", sqlite3_errmsg(db));
396 return PMINFO_R_ERROR;
399 if (sqlite3_step(stmt) == SQLITE_ERROR) {
400 LOGE("step error: %s", sqlite3_errmsg(db));
401 sqlite3_finalize(stmt);
402 return PMINFO_R_ERROR;
405 /* one author per one package */
406 info = calloc(1, sizeof(author_x));
408 LOGE("out of memory");
409 sqlite3_finalize(stmt);
410 return PMINFO_R_ERROR;
413 _save_column_str(stmt, idx++, &info->text);
414 _save_column_str(stmt, idx++, &info->email);
415 _save_column_str(stmt, idx++, &info->href);
419 sqlite3_finalize(stmt);
424 static int _pkginfo_get_label(sqlite3 *db, const char *pkgid,
425 const char *locale, label_x **label)
427 static const char query_raw[] =
428 "SELECT package_label, package_locale "
429 "FROM package_localized_info "
430 "WHERE package=%Q AND package_locale IN (%Q, %Q)";
437 query = sqlite3_mprintf(query_raw, pkgid, locale, DEFAULT_LOCALE);
439 LOGE("out of memory");
440 return PMINFO_R_ERROR;
443 ret = sqlite3_prepare_v2(db, query, strlen(query),
446 if (ret != SQLITE_OK) {
447 LOGE("prepare failed: %s", sqlite3_errmsg(db));
448 return PMINFO_R_ERROR;
451 while (sqlite3_step(stmt) == SQLITE_ROW) {
452 info = calloc(1, sizeof(label_x));
454 LOGE("out of memory");
455 sqlite3_finalize(stmt);
457 LISTHEAD(*label, info);
460 return PMINFO_R_ERROR;
463 _save_column_str(stmt, idx++, &info->text);
464 _save_column_str(stmt, idx++, &info->lang);
465 LISTADD(*label, info);
469 LISTHEAD(*label, info);
473 sqlite3_finalize(stmt);
478 static int _pkginfo_get_icon(sqlite3 *db, const char *pkgid, const char *locale,
481 static const char query_raw[] =
482 "SELECT package_icon, package_locale "
483 "FROM package_localized_info "
484 "WHERE package=%Q AND package_locale IN (%Q, %Q)";
491 query = sqlite3_mprintf(query_raw, pkgid, locale, DEFAULT_LOCALE);
493 LOGE("out of memory");
494 return PMINFO_R_ERROR;
497 ret = sqlite3_prepare_v2(db, query, strlen(query),
500 if (ret != SQLITE_OK) {
501 LOGE("prepare failed: %s", sqlite3_errmsg(db));
502 return PMINFO_R_ERROR;
505 while (sqlite3_step(stmt) == SQLITE_ROW) {
506 info = calloc(1, sizeof(icon_x));
508 LOGE("out of memory");
509 sqlite3_finalize(stmt);
511 LISTHEAD(*icon, info);
514 return PMINFO_R_ERROR;
517 _save_column_str(stmt, idx++, &info->text);
518 _save_column_str(stmt, idx++, &info->lang);
519 LISTADD(*icon, info);
523 LISTHEAD(*icon, info);
527 sqlite3_finalize(stmt);
532 static int _pkginfo_get_description(sqlite3 *db, const char *pkgid,
533 const char *locale, description_x **description)
535 static const char query_raw[] =
536 "SELECT package_description, package_locale "
537 "FROM package_localized_info "
538 "WHERE package=%Q AND package_locale IN (%Q, %Q)";
545 query = sqlite3_mprintf(query_raw, pkgid, locale, DEFAULT_LOCALE);
547 LOGE("out of memory");
548 return PMINFO_R_ERROR;
551 ret = sqlite3_prepare_v2(db, query, strlen(query),
554 if (ret != SQLITE_OK) {
555 LOGE("prepare failed: %s", sqlite3_errmsg(db));
556 return PMINFO_R_ERROR;
559 while (sqlite3_step(stmt) == SQLITE_ROW) {
560 info = calloc(1, sizeof(description_x));
562 LOGE("out of memory");
563 sqlite3_finalize(stmt);
565 LISTHEAD(*description, info);
568 return PMINFO_R_ERROR;
571 _save_column_str(stmt, idx++, &info->text);
572 _save_column_str(stmt, idx++, &info->lang);
573 LISTADD(*description, info);
577 LISTHEAD(*description, info);
581 sqlite3_finalize(stmt);
586 static int _pkginfo_get_privilege(sqlite3 *db, const char *pkgid,
587 privileges_x **privileges)
589 static const char query_raw[] =
590 "SELECT privilege FROM package_privilege_info WHERE package=%Q";
597 /* privilege list should stored in privileges_x... */
598 p = calloc(1, sizeof(privileges_x));
600 LOGE("out of memory");
601 return PMINFO_R_ERROR;
605 query = sqlite3_mprintf(query_raw, pkgid);
607 LOGE("out of memory");
609 return PMINFO_R_ERROR;
612 ret = sqlite3_prepare_v2(db, query, strlen(query),
615 if (ret != SQLITE_OK) {
616 LOGE("prepare failed: %s", sqlite3_errmsg(db));
618 return PMINFO_R_ERROR;
621 while (sqlite3_step(stmt) == SQLITE_ROW) {
622 info = calloc(1, sizeof(privilege_x));
624 LOGE("out of memory");
625 sqlite3_finalize(stmt);
627 LISTHEAD(p->privilege, info);
630 return PMINFO_R_ERROR;
632 _save_column_str(stmt, 0, &info->text);
633 LISTADD(p->privilege, info);
637 LISTHEAD(p->privilege, info);
641 sqlite3_finalize(stmt);
646 static char *_get_filtered_query(const char *query_raw,
647 pkgmgrinfo_filter_x *filter)
649 char buf[MAX_QUERY_LEN] = { 0, };
658 strncat(buf, query_raw, MAX_QUERY_LEN - 1);
660 for (list = head; list; list = list->next) {
661 /* TODO: revise condition getter function */
662 __get_filter_condition(list->data, &condition);
663 if (condition == NULL)
665 if (buf[strlen(query_raw)] == '\0') {
666 len += strlen(" WHERE ");
667 strncat(buf, " WHERE ", MAX_QUERY_LEN - len - 1);
669 len += strlen(" AND ");
670 strncat(buf, " AND ", MAX_QUERY_LEN -len - 1);
672 len += strlen(condition);
673 strncat(buf, condition, sizeof(buf) - len - 1);
681 static int _pkginfo_get_package(sqlite3 *db, const char *pkgid,
682 const char *locale, package_x **package)
684 static const char query_raw[] =
685 "SELECT package, package_version, "
686 "install_location, package_removable, package_preload, "
687 "package_readonly, package_update, package_appsetting, "
688 "package_system, package_type, package_size, installed_time, "
689 "installed_storage, storeclient_id, mainapp_id, package_url, "
690 "root_path, csc_path, package_nodisplay, package_api_version, "
691 "package_support_disable "
692 "FROM package_info WHERE package=%Q";
699 query = sqlite3_mprintf(query_raw, pkgid);
701 LOGE("out of memory");
702 return PMINFO_R_ERROR;
705 ret = sqlite3_prepare_v2(db, query, strlen(query),
708 if (ret != SQLITE_OK) {
709 LOGE("prepare failed: %s", sqlite3_errmsg(db));
710 return PMINFO_R_ERROR;
713 ret = sqlite3_step(stmt);
714 if (ret == SQLITE_DONE) {
715 sqlite3_finalize(stmt);
716 return PMINFO_R_ENOENT;
717 } else if (ret != SQLITE_ROW) {
718 LOGE("step failed: %s", sqlite3_errmsg(db));
719 sqlite3_finalize(stmt);
720 return PMINFO_R_ERROR;
723 info = calloc(1, sizeof(package_x));
725 LOGE("out of memory");
726 sqlite3_finalize(stmt);
727 return PMINFO_R_ERROR;
730 _save_column_str(stmt, idx++, &info->package);
731 _save_column_str(stmt, idx++, &info->version);
732 _save_column_str(stmt, idx++, &info->installlocation);
733 _save_column_str(stmt, idx++, &info->removable);
734 _save_column_str(stmt, idx++, &info->preload);
735 _save_column_str(stmt, idx++, &info->readonly);
736 _save_column_str(stmt, idx++, &info->update);
737 _save_column_str(stmt, idx++, &info->appsetting);
738 _save_column_str(stmt, idx++, &info->system);
739 _save_column_str(stmt, idx++, &info->type);
740 _save_column_str(stmt, idx++, &info->package_size);
741 _save_column_str(stmt, idx++, &info->installed_time);
742 _save_column_str(stmt, idx++, &info->installed_storage);
743 _save_column_str(stmt, idx++, &info->storeclient_id);
744 _save_column_str(stmt, idx++, &info->mainapp_id);
745 _save_column_str(stmt, idx++, &info->package_url);
746 _save_column_str(stmt, idx++, &info->root_path);
747 _save_column_str(stmt, idx++, &info->csc_path);
748 _save_column_str(stmt, idx++, &info->nodisplay_setting);
749 _save_column_str(stmt, idx++, &info->api_version);
750 _save_column_str(stmt, idx++, &info->support_disable);
752 if (_pkginfo_get_author(db, info->package, &info->author)) {
753 pkgmgrinfo_basic_free_package(info);
754 sqlite3_finalize(stmt);
755 return PMINFO_R_ERROR;
758 if (_pkginfo_get_label(db, info->package, locale, &info->label)) {
759 pkgmgrinfo_basic_free_package(info);
760 sqlite3_finalize(stmt);
761 return PMINFO_R_ERROR;
764 if (_pkginfo_get_icon(db, info->package, locale, &info->icon)) {
765 pkgmgrinfo_basic_free_package(info);
766 sqlite3_finalize(stmt);
767 return PMINFO_R_ERROR;
770 if (_pkginfo_get_description(db, info->package, locale,
771 &info->description)) {
772 pkgmgrinfo_basic_free_package(info);
773 sqlite3_finalize(stmt);
774 return PMINFO_R_ERROR;
777 if (_pkginfo_get_privilege(db, info->package, &info->privileges)) {
778 pkgmgrinfo_basic_free_package(info);
779 sqlite3_finalize(stmt);
780 return PMINFO_R_ERROR;
784 sqlite3_finalize(stmt);
789 static int _pkginfo_get_pkginfo(const char *pkgid, uid_t uid,
790 pkgmgr_pkginfo_x **pkginfo)
796 pkgmgr_pkginfo_x *info;
798 dbpath = getUserPkgParserDBPathUID(uid);
800 return PMINFO_R_ERROR;
802 locale = _get_system_locale();
804 return PMINFO_R_ERROR;
806 ret = sqlite3_open_v2(dbpath, &db, SQLITE_OPEN_READONLY, NULL);
807 if (ret != SQLITE_OK) {
808 _LOGE("failed to open db: %d", ret);
810 return PMINFO_R_ERROR;
813 info = calloc(1, sizeof(pkgmgr_pkginfo_x));
815 _LOGE("out of memory");
817 sqlite3_close_v2(db);
818 return PMINFO_R_ERROR;
821 ret = _pkginfo_get_package(db, pkgid, locale, &info->pkg_info);
822 if (ret != PMINFO_R_OK) {
825 sqlite3_close_v2(db);
829 info->locale = locale;
831 info->pkg_info->for_all_users = strdup(
832 uid != GLOBAL_USER ? "false" : "true");
836 sqlite3_close_v2(db);
841 API int pkgmgrinfo_pkginfo_get_usr_pkginfo(const char *pkgid, uid_t uid,
842 pkgmgrinfo_pkginfo_h *handle)
846 if (pkgid == NULL || handle == NULL) {
847 LOGE("invalid parameter");
848 return PMINFO_R_EINVAL;
851 ret = _pkginfo_get_pkginfo(pkgid, uid, (pkgmgr_pkginfo_x **)handle);
852 if (ret == PMINFO_R_ENOENT && uid != GLOBAL_USER)
853 ret = _pkginfo_get_pkginfo(pkgid, GLOBAL_USER,
854 (pkgmgr_pkginfo_x **)handle);
856 if (ret != PMINFO_R_OK)
857 _LOGE("failed to get pkginfo of %s for user %d", pkgid, uid);
862 API int pkgmgrinfo_pkginfo_get_pkginfo(const char *pkgid, pkgmgrinfo_pkginfo_h *handle)
864 return pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, GLOBAL_USER, handle);
867 API int pkgmgrinfo_pkginfo_get_pkgname(pkgmgrinfo_pkginfo_h handle, char **pkg_name)
869 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
871 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
872 retvm_if(pkg_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
874 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
875 return PMINFO_R_ERROR;
877 *pkg_name = (char *)info->pkg_info->package;
882 API int pkgmgrinfo_pkginfo_get_pkgid(pkgmgrinfo_pkginfo_h handle, char **pkgid)
884 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
886 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
887 retvm_if(pkgid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
889 if (info->pkg_info == NULL || info->pkg_info->package == NULL)
890 return PMINFO_R_ERROR;
892 *pkgid = (char *)info->pkg_info->package;
897 API int pkgmgrinfo_pkginfo_get_type(pkgmgrinfo_pkginfo_h handle, char **type)
899 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
901 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
902 retvm_if(type == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
904 if (info->pkg_info == NULL || info->pkg_info->type == NULL)
905 return PMINFO_R_ERROR;
907 *type = (char *)info->pkg_info->type;
912 API int pkgmgrinfo_pkginfo_get_version(pkgmgrinfo_pkginfo_h handle, char **version)
914 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
916 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
917 retvm_if(version == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
919 if (info->pkg_info == NULL || info->pkg_info->version == NULL)
920 return PMINFO_R_ERROR;
922 *version = (char *)info->pkg_info->version;
927 API int pkgmgrinfo_pkginfo_get_install_location(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_install_location *location)
930 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
932 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
933 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
935 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
936 return PMINFO_R_ERROR;
938 val = (char *)info->pkg_info->installlocation;
939 if (strcmp(val, "internal-only") == 0)
940 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
941 else if (strcmp(val, "prefer-external") == 0)
942 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
944 *location = PMINFO_INSTALL_LOCATION_AUTO;
949 API int pkgmgrinfo_pkginfo_get_package_size(pkgmgrinfo_pkginfo_h handle, int *size)
951 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
953 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
954 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
956 if (info->pkg_info == NULL || info->pkg_info->package_size == NULL)
957 return PMINFO_R_ERROR;
959 *size = atoi((char *)info->pkg_info->package_size);
964 API int pkgmgrinfo_pkginfo_get_total_size(pkgmgrinfo_pkginfo_h handle, int *size)
967 char device_path[PKG_STRING_LEN_MAX] = { '\0', };
968 long long rw_size = 0;
969 long long ro_size = 0;
970 long long tmp_size = 0;
971 long long total_size = 0;
972 struct stat fileinfo;
975 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
976 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
978 ret = pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
980 return PMINFO_R_ERROR;
983 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/bin", PKG_RW_PATH, pkgid);
984 if (lstat(device_path, &fileinfo) == 0) {
985 if (!S_ISLNK(fileinfo.st_mode)) {
986 tmp_size = _pkgmgr_calculate_dir_size(device_path);
992 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/info", PKG_RW_PATH, pkgid);
993 if (lstat(device_path, &fileinfo) == 0) {
994 if (!S_ISLNK(fileinfo.st_mode)) {
995 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1001 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/res", PKG_RW_PATH, pkgid);
1002 if (lstat(device_path, &fileinfo) == 0) {
1003 if (!S_ISLNK(fileinfo.st_mode)) {
1004 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1006 rw_size += tmp_size;
1010 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/data", PKG_RW_PATH, pkgid);
1011 if (lstat(device_path, &fileinfo) == 0) {
1012 if (!S_ISLNK(fileinfo.st_mode)) {
1013 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1015 rw_size += tmp_size;
1019 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/shared", PKG_RW_PATH, pkgid);
1020 if (lstat(device_path, &fileinfo) == 0) {
1021 if (!S_ISLNK(fileinfo.st_mode)) {
1022 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1024 rw_size += tmp_size;
1028 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/setting", PKG_RW_PATH, pkgid);
1029 if (lstat(device_path, &fileinfo) == 0) {
1030 if (!S_ISLNK(fileinfo.st_mode)) {
1031 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1033 rw_size += tmp_size;
1038 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/bin", PKG_RO_PATH, pkgid);
1039 if (lstat(device_path, &fileinfo) == 0) {
1040 if (!S_ISLNK(fileinfo.st_mode)) {
1041 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1043 ro_size += tmp_size;
1047 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/info", PKG_RO_PATH, pkgid);
1048 if (lstat(device_path, &fileinfo) == 0) {
1049 if (!S_ISLNK(fileinfo.st_mode)) {
1050 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1052 ro_size += tmp_size;
1056 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/res", PKG_RO_PATH, pkgid);
1057 if (lstat(device_path, &fileinfo) == 0) {
1058 if (!S_ISLNK(fileinfo.st_mode)) {
1059 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1061 ro_size += tmp_size;
1065 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/data", PKG_RO_PATH, pkgid);
1066 if (lstat(device_path, &fileinfo) == 0) {
1067 if (!S_ISLNK(fileinfo.st_mode)) {
1068 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1070 ro_size += tmp_size;
1074 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/shared", PKG_RO_PATH, pkgid);
1075 if (lstat(device_path, &fileinfo) == 0) {
1076 if (!S_ISLNK(fileinfo.st_mode)) {
1077 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1079 ro_size += tmp_size;
1083 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/setting", PKG_RO_PATH, pkgid);
1084 if (lstat(device_path, &fileinfo) == 0) {
1085 if (!S_ISLNK(fileinfo.st_mode)) {
1086 tmp_size = _pkgmgr_calculate_dir_size(device_path);
1088 ro_size += tmp_size;
1093 total_size = rw_size + ro_size;
1094 *size = (int)total_size;
1099 API int pkgmgrinfo_pkginfo_get_data_size(pkgmgrinfo_pkginfo_h handle, int *size)
1102 char device_path[PKG_STRING_LEN_MAX] = { '\0', };
1103 long long total_size = 0;
1105 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1106 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1108 if (pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid) < 0)
1109 return PMINFO_R_ERROR;
1111 snprintf(device_path, PKG_STRING_LEN_MAX, "%s%s/data", PKG_RW_PATH, pkgid);
1112 if (access(device_path, R_OK) == 0)
1113 total_size = _pkgmgr_calculate_dir_size(device_path);
1115 return PMINFO_R_ERROR;
1117 *size = (int)total_size;
1122 API int pkgmgrinfo_pkginfo_get_icon(pkgmgrinfo_pkginfo_h handle, char **icon)
1126 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1128 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1129 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1131 locale = info->locale;
1132 retvm_if(locale == NULL, PMINFO_R_ERROR, "manifest locale is NULL");
1134 for (ptr = info->pkg_info->icon; ptr != NULL; ptr = ptr->next) {
1135 if (ptr->lang == NULL)
1138 if (strcmp(ptr->lang, locale) == 0) {
1139 *icon = (char *)ptr->text;
1140 if (strcasecmp(*icon, "(null)") == 0) {
1141 locale = DEFAULT_LOCALE;
1146 } else if (strcmp(ptr->lang, DEFAULT_LOCALE) == 0) {
1147 *icon = (char *)ptr->text;
1152 return PMINFO_R_ERROR;
1155 API int pkgmgrinfo_pkginfo_get_label(pkgmgrinfo_pkginfo_h handle, char **label)
1159 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1161 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1162 retvm_if(label == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL");
1164 locale = info->locale;
1165 retvm_if(locale == NULL, PMINFO_R_ERROR, "manifest locale is NULL");
1167 for (ptr = info->pkg_info->label; ptr != NULL; ptr = ptr->next) {
1168 if (ptr->lang == NULL)
1171 if (strcmp(ptr->lang, locale) == 0) {
1172 *label = (char *)ptr->text;
1173 if (strcasecmp(*label, "(null)") == 0) {
1174 locale = DEFAULT_LOCALE;
1179 } else if (strcmp(ptr->lang, DEFAULT_LOCALE) == 0) {
1180 *label = (char *)ptr->text;
1185 return PMINFO_R_ERROR;
1188 API int pkgmgrinfo_pkginfo_get_description(pkgmgrinfo_pkginfo_h handle, char **description)
1192 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1194 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1195 retvm_if(description == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1197 locale = info->locale;
1198 retvm_if(locale == NULL, PMINFO_R_ERROR, "manifest locale is NULL");
1200 for (ptr = info->pkg_info->description; ptr != NULL; ptr = ptr->next) {
1201 if (ptr->lang == NULL)
1204 if (strcmp(ptr->lang, locale) == 0) {
1205 *description = (char *)ptr->text;
1206 if (strcasecmp(*description, PKGMGR_PARSER_EMPTY_STR) == 0) {
1207 locale = DEFAULT_LOCALE;
1212 } else if (strcmp(ptr->lang, DEFAULT_LOCALE) == 0) {
1213 *description = (char *)ptr->text;
1218 return PMINFO_R_ERROR;
1221 API int pkgmgrinfo_pkginfo_get_author_name(pkgmgrinfo_pkginfo_h handle, char **author_name)
1223 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1225 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1226 retvm_if(author_name == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1228 if (info->pkg_info == NULL || info->pkg_info->author == NULL ||
1229 info->pkg_info->author->text == NULL)
1230 return PMINFO_R_ERROR;
1232 *author_name = (char *)info->pkg_info->author->text;
1237 API int pkgmgrinfo_pkginfo_get_author_email(pkgmgrinfo_pkginfo_h handle, char **author_email)
1239 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1241 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1242 retvm_if(author_email == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1244 if (info->pkg_info == NULL || info->pkg_info->author == NULL ||
1245 info->pkg_info->author->email == NULL)
1246 return PMINFO_R_ERROR;
1248 *author_email = (char *)info->pkg_info->author->email;
1253 API int pkgmgrinfo_pkginfo_get_author_href(pkgmgrinfo_pkginfo_h handle, char **author_href)
1255 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1257 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1258 retvm_if(author_href == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1260 if (info->pkg_info == NULL || info->pkg_info->author == NULL ||
1261 info->pkg_info->author->href == NULL)
1262 return PMINFO_R_ERROR;
1264 *author_href = (char *)info->pkg_info->author->href;
1269 API int pkgmgrinfo_pkginfo_get_installed_storage(pkgmgrinfo_pkginfo_h handle, pkgmgrinfo_installed_storage *storage)
1271 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1273 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1274 retvm_if(storage == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1276 if (info->pkg_info == NULL || info->pkg_info->installed_storage == NULL)
1277 return PMINFO_R_ERROR;
1279 if (strcmp(info->pkg_info->installed_storage,"installed_internal") == 0)
1280 *storage = PMINFO_INTERNAL_STORAGE;
1281 else if (strcmp(info->pkg_info->installed_storage,"installed_external") == 0)
1282 *storage = PMINFO_EXTERNAL_STORAGE;
1284 return PMINFO_R_ERROR;
1289 API int pkgmgrinfo_pkginfo_get_installed_time(pkgmgrinfo_pkginfo_h handle, int *installed_time)
1291 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1293 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1294 retvm_if(installed_time == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1296 if (info->pkg_info == NULL || info->pkg_info->installed_time == NULL)
1297 return PMINFO_R_ERROR;
1299 *installed_time = atoi(info->pkg_info->installed_time);
1304 API int pkgmgrinfo_pkginfo_get_storeclientid(pkgmgrinfo_pkginfo_h handle, char **storeclientid)
1306 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1308 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1309 retvm_if(storeclientid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1311 if (info->pkg_info == NULL || info->pkg_info->storeclient_id == NULL)
1312 return PMINFO_R_ERROR;
1314 *storeclientid = (char *)info->pkg_info->storeclient_id;
1319 API int pkgmgrinfo_pkginfo_get_mainappid(pkgmgrinfo_pkginfo_h handle, char **mainappid)
1321 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1323 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1324 retvm_if(mainappid == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1326 if (info->pkg_info == NULL || info->pkg_info->mainapp_id == NULL)
1327 return PMINFO_R_ERROR;
1329 *mainappid = (char *)info->pkg_info->mainapp_id;
1334 API int pkgmgrinfo_pkginfo_get_url(pkgmgrinfo_pkginfo_h handle, char **url)
1336 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1338 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1339 retvm_if(url == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1341 if (info->pkg_info == NULL || info->pkg_info->package_url == NULL)
1342 return PMINFO_R_ERROR;
1344 *url = (char *)info->pkg_info->package_url;
1349 API int pkgmgrinfo_pkginfo_get_size_from_xml(const char *manifest, int *size)
1351 const char *val = NULL;
1352 const xmlChar *node;
1353 xmlTextReaderPtr reader;
1354 retvm_if(manifest == NULL, PMINFO_R_EINVAL, "Input argument is NULL\n");
1355 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1358 reader = xmlReaderForFile(manifest, NULL, 0);
1361 if (__child_element(reader, -1)) {
1362 node = xmlTextReaderConstName(reader);
1364 _LOGE("xmlTextReaderConstName value is NULL\n");
1365 xmlFreeTextReader(reader);
1367 return PMINFO_R_ERROR;
1370 if (!strcmp(ASC_CHAR(node), "manifest")) {
1371 if (xmlTextReaderGetAttribute(reader, XML_CHAR("size")))
1372 val = ASC_CHAR(xmlTextReaderGetAttribute(reader, XML_CHAR("size")));
1378 _LOGE("package size is not specified\n");
1379 xmlFreeTextReader(reader);
1381 return PMINFO_R_ERROR;
1384 _LOGE("Unable to create xml reader\n");
1385 xmlFreeTextReader(reader);
1387 return PMINFO_R_ERROR;
1391 _LOGE("xmlReaderForFile value is NULL\n");
1393 return PMINFO_R_ERROR;
1396 xmlFreeTextReader(reader);
1402 API int pkgmgrinfo_pkginfo_get_location_from_xml(const char *manifest, pkgmgrinfo_install_location *location)
1404 const char *val = NULL;
1405 const xmlChar *node;
1406 xmlTextReaderPtr reader;
1407 retvm_if(manifest == NULL, PMINFO_R_EINVAL, "Input argument is NULL\n");
1408 retvm_if(location == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1411 reader = xmlReaderForFile(manifest, NULL, 0);
1414 if ( __child_element(reader, -1)) {
1415 node = xmlTextReaderConstName(reader);
1417 _LOGE("xmlTextReaderConstName value is NULL\n");
1418 xmlFreeTextReader(reader);
1420 return PMINFO_R_ERROR;
1423 if (!strcmp(ASC_CHAR(node), "manifest")) {
1424 if (xmlTextReaderGetAttribute(reader, XML_CHAR("install-location")))
1425 val = ASC_CHAR(xmlTextReaderGetAttribute(reader, XML_CHAR("install-location")));
1428 if (strcmp(val, "internal-only") == 0)
1429 *location = PMINFO_INSTALL_LOCATION_INTERNAL_ONLY;
1430 else if (strcmp(val, "prefer-external") == 0)
1431 *location = PMINFO_INSTALL_LOCATION_PREFER_EXTERNAL;
1433 *location = PMINFO_INSTALL_LOCATION_AUTO;
1436 _LOGE("Unable to create xml reader\n");
1437 xmlFreeTextReader(reader);
1439 return PMINFO_R_ERROR;
1443 _LOGE("xmlReaderForFile value is NULL\n");
1445 return PMINFO_R_ERROR;
1448 xmlFreeTextReader(reader);
1455 API int pkgmgrinfo_pkginfo_get_root_path(pkgmgrinfo_pkginfo_h handle, char **path)
1457 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1459 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1460 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1462 if (info->pkg_info == NULL || info->pkg_info->root_path == NULL)
1463 return PMINFO_R_ERROR;
1465 *path = (char *)info->pkg_info->root_path;
1470 API int pkgmgrinfo_pkginfo_get_csc_path(pkgmgrinfo_pkginfo_h handle, char **path)
1472 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1474 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1475 retvm_if(path == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1477 if (info->pkg_info == NULL || info->pkg_info->csc_path == NULL)
1478 return PMINFO_R_ERROR;
1480 *path = (char *)info->pkg_info->csc_path;
1486 API int pkgmgrinfo_pkginfo_is_accessible(pkgmgrinfo_pkginfo_h handle, bool *accessible)
1488 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1489 retvm_if(accessible == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1491 #if 0 //smack issue occured, check later
1493 pkgmgrinfo_pkginfo_get_pkgid(handle, &pkgid);
1495 _LOGD("invalid func parameters\n");
1496 return PMINFO_R_ERROR;
1498 _LOGD("pkgmgr_get_pkg_external_validation() called\n");
1501 char app_mmc_path[FILENAME_MAX] = { 0, };
1502 char app_dir_path[FILENAME_MAX] = { 0, };
1503 char app_mmc_internal_path[FILENAME_MAX] = { 0, };
1504 snprintf(app_dir_path, FILENAME_MAX,"%s%s", PKG_INSTALLATION_PATH, pkgid);
1505 snprintf(app_mmc_path, FILENAME_MAX,"%s%s", PKG_SD_PATH, pkgid);
1506 snprintf(app_mmc_internal_path, FILENAME_MAX,"%s%s/.mmc", PKG_INSTALLATION_PATH, pkgid);
1508 /*check whether application is in external memory or not */
1509 fp = fopen(app_mmc_path, "r");
1511 _LOGD(" app path in external memory not accesible\n");
1516 _LOGD("pkgmgr_get_pkg_external_validation() : SD_CARD \n");
1520 /*check whether application is in internal or not */
1521 fp = fopen(app_dir_path, "r");
1523 _LOGD(" app path in internal memory not accesible\n");
1525 return PMINFO_R_ERROR;
1528 /*check whether the application is installed in SD card
1529 but SD card is not present*/
1530 fp = fopen(app_mmc_internal_path, "r");
1533 _LOGD("pkgmgr_get_pkg_external_validation() : INTERNAL_MEM \n");
1538 _LOGD("pkgmgr_get_pkg_external_validation() : ERROR_MMC_STATUS \n");
1543 _LOGD("pkgmgr_get_pkg_external_validation() end\n");
1550 API int pkgmgrinfo_pkginfo_is_removable(pkgmgrinfo_pkginfo_h handle, bool *removable)
1552 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1554 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1555 retvm_if(removable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1557 if (info->pkg_info == NULL || info->pkg_info->removable == NULL)
1558 return PMINFO_R_ERROR;
1560 *removable = _get_bool_value(info->pkg_info->removable);
1565 API int pkgmgrinfo_pkginfo_is_movable(pkgmgrinfo_pkginfo_h handle, bool *movable)
1568 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1570 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1571 retvm_if(movable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1573 if (info->pkg_info == NULL || info->pkg_info->installlocation == NULL)
1574 return PMINFO_R_ERROR;
1576 val = (char *)info->pkg_info->installlocation;
1577 if (strcmp(val, "internal-only") == 0)
1579 else if (strcmp(val, "prefer-external") == 0)
1587 API int pkgmgrinfo_pkginfo_is_preload(pkgmgrinfo_pkginfo_h handle, bool *preload)
1589 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1591 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1592 retvm_if(preload == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1594 if (info->pkg_info == NULL || info->pkg_info->preload == NULL)
1595 return PMINFO_R_ERROR;
1597 *preload = _get_bool_value(info->pkg_info->preload);
1602 API int pkgmgrinfo_pkginfo_is_system(pkgmgrinfo_pkginfo_h handle, bool *system)
1604 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1606 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1607 retvm_if(system == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1609 if (info->pkg_info == NULL || info->pkg_info->system == NULL)
1610 return PMINFO_R_ERROR;
1612 *system = _get_bool_value(info->pkg_info->system);
1617 API int pkgmgrinfo_pkginfo_is_readonly(pkgmgrinfo_pkginfo_h handle, bool *readonly)
1619 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1621 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1622 retvm_if(readonly == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1624 if (info->pkg_info == NULL || info->pkg_info->readonly == NULL)
1625 return PMINFO_R_ERROR;
1627 *readonly = _get_bool_value(info->pkg_info->readonly);
1632 API int pkgmgrinfo_pkginfo_is_update(pkgmgrinfo_pkginfo_h handle, bool *update)
1634 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1636 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1637 retvm_if(update == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1639 if (info->pkg_info == NULL || info->pkg_info->update == NULL)
1640 return PMINFO_R_ERROR;
1642 *update = _get_bool_value(info->pkg_info->update);
1647 API int pkgmgrinfo_pkginfo_is_support_disable(pkgmgrinfo_pkginfo_h handle, bool *support_disable)
1649 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1651 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1652 retvm_if(support_disable == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1654 if (info->pkg_info == NULL || info->pkg_info->support_disable == NULL)
1655 return PMINFO_R_ERROR;
1657 *support_disable = _get_bool_value(info->pkg_info->support_disable);
1662 API int pkgmgrinfo_pkginfo_is_for_all_users(pkgmgrinfo_pkginfo_h handle, bool *for_all_users)
1664 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1666 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1667 retvm_if(for_all_users == NULL, PMINFO_R_EINVAL, "Argument supplied to hold return value is NULL\n");
1669 if (info->pkg_info == NULL || info->pkg_info->for_all_users == NULL)
1670 return PMINFO_R_ERROR;
1672 *for_all_users = _get_bool_value(info->pkg_info->for_all_users);
1677 API int pkgmgrinfo_pkginfo_destroy_pkginfo(pkgmgrinfo_pkginfo_h handle)
1679 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1681 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL\n");
1683 __cleanup_pkginfo(info);
1688 API int pkgmgrinfo_pkginfo_filter_create(pkgmgrinfo_pkginfo_filter_h *handle)
1690 pkgmgrinfo_filter_x *filter;
1692 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle output parameter is NULL\n");
1694 filter = (pkgmgrinfo_filter_x*)calloc(1, sizeof(pkgmgrinfo_filter_x));
1695 if (filter == NULL) {
1696 _LOGE("Out of Memory!!!");
1697 return PMINFO_R_ERROR;
1705 API int pkgmgrinfo_pkginfo_filter_destroy(pkgmgrinfo_pkginfo_filter_h handle)
1707 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1709 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1712 g_slist_foreach(filter->list, __destroy_each_node, NULL);
1713 g_slist_free(filter->list);
1721 API int pkgmgrinfo_pkginfo_filter_add_int(pkgmgrinfo_pkginfo_filter_h handle,
1722 const char *property, const int value)
1724 char buf[PKG_VALUE_STRING_LEN_MAX] = {'\0'};
1728 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1729 pkgmgrinfo_node_x *node;
1731 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1732 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1734 prop = _pminfo_pkginfo_convert_to_prop_int(property);
1735 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_INT ||
1736 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_INT) {
1737 _LOGE("Invalid Integer Property\n");
1738 return PMINFO_R_EINVAL;
1740 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1742 _LOGE("Out of Memory!!!\n");
1743 return PMINFO_R_ERROR;
1745 snprintf(buf, PKG_VALUE_STRING_LEN_MAX - 1, "%d", value);
1746 val = strndup(buf, PKG_VALUE_STRING_LEN_MAX - 1);
1748 _LOGE("Out of Memory\n");
1750 return PMINFO_R_ERROR;
1754 /*If API is called multiple times for same property, we should override the previous values.
1755 Last value set will be used for filtering.*/
1756 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1758 filter->list = g_slist_delete_link(filter->list, link);
1759 filter->list = g_slist_append(filter->list, (gpointer)node);
1764 API int pkgmgrinfo_pkginfo_filter_add_bool(pkgmgrinfo_pkginfo_filter_h handle,
1765 const char *property, const bool value)
1770 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1771 pkgmgrinfo_node_x *node;
1773 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1774 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1776 prop = _pminfo_pkginfo_convert_to_prop_bool(property);
1777 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_BOOL ||
1778 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_BOOL) {
1779 _LOGE("Invalid Boolean Property\n");
1780 return PMINFO_R_EINVAL;
1782 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1784 _LOGE("Out of Memory!!!\n");
1785 return PMINFO_R_ERROR;
1788 val = strndup("('true','True')", 15);
1790 val = strndup("('false','False')", 17);
1792 _LOGE("Out of Memory\n");
1794 return PMINFO_R_ERROR;
1798 /*If API is called multiple times for same property, we should override the previous values.
1799 Last value set will be used for filtering.*/
1800 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1802 filter->list = g_slist_delete_link(filter->list, link);
1803 filter->list = g_slist_append(filter->list, (gpointer)node);
1808 API int pkgmgrinfo_pkginfo_filter_add_string(pkgmgrinfo_pkginfo_filter_h handle,
1809 const char *property, const char *value)
1814 pkgmgrinfo_filter_x *filter = (pkgmgrinfo_filter_x *)handle;
1815 pkgmgrinfo_node_x *node;
1817 retvm_if(handle == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1818 retvm_if(property == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1819 retvm_if(value == NULL, PMINFO_R_EINVAL, "Filter handle input parameter is NULL\n");
1821 prop = _pminfo_pkginfo_convert_to_prop_str(property);
1822 if (prop < E_PMINFO_PKGINFO_PROP_PACKAGE_MIN_STR ||
1823 prop > E_PMINFO_PKGINFO_PROP_PACKAGE_MAX_STR) {
1824 _LOGE("Invalid String Property\n");
1825 return PMINFO_R_EINVAL;
1827 node = (pkgmgrinfo_node_x *)calloc(1, sizeof(pkgmgrinfo_node_x));
1829 _LOGE("Out of Memory!!!\n");
1830 return PMINFO_R_ERROR;
1832 if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_AUTO) == 0)
1833 val = strndup("auto", PKG_STRING_LEN_MAX - 1);
1834 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_INTERNAL) == 0)
1835 val = strndup("internal-only", PKG_STRING_LEN_MAX - 1);
1836 else if (strcmp(value, PMINFO_PKGINFO_INSTALL_LOCATION_EXTERNAL) == 0)
1837 val = strndup("prefer-external", PKG_STRING_LEN_MAX - 1);
1838 else if (strcmp(value, "installed_internal") == 0)
1839 val = strndup("installed_internal", PKG_STRING_LEN_MAX - 1);
1840 else if (strcmp(value, "installed_external") == 0)
1841 val = strndup("installed_external", PKG_STRING_LEN_MAX - 1);
1843 val = strndup(value, PKG_STRING_LEN_MAX - 1);
1845 _LOGE("Out of Memory\n");
1847 return PMINFO_R_ERROR;
1851 /*If API is called multiple times for same property, we should override the previous values.
1852 Last value set will be used for filtering.*/
1853 link = g_slist_find_custom(filter->list, (gconstpointer)node, __compare_func);
1855 filter->list = g_slist_delete_link(filter->list, link);
1856 filter->list = g_slist_append(filter->list, (gpointer)node);
1861 API int pkgmgrinfo_pkginfo_usr_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count, uid_t uid)
1866 if (handle == NULL || count == NULL) {
1867 _LOGE("invalid parameter");
1868 return PMINFO_R_EINVAL;
1871 ret = _pkginfo_get_filtered_list((pkgmgrinfo_filter_x *)handle, uid, &list);
1872 if (ret != PMINFO_R_OK)
1873 return PMINFO_R_ERROR;
1875 *count = g_list_length(list);
1877 g_list_free_full(list, free);
1882 API int pkgmgrinfo_pkginfo_filter_count(pkgmgrinfo_pkginfo_filter_h handle, int *count)
1884 return pkgmgrinfo_pkginfo_usr_filter_count(handle, count, GLOBAL_USER);
1887 API int pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(
1888 pkgmgrinfo_pkginfo_filter_h handle,
1889 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data, uid_t uid)
1891 if (handle == NULL || pkg_cb == NULL) {
1892 LOGE("invalid parameter");
1893 return PMINFO_R_EINVAL;
1896 return _pkginfo_get_filtered_foreach_pkginfo(handle, pkg_cb, user_data,
1900 API int pkgmgrinfo_pkginfo_filter_foreach_pkginfo(pkgmgrinfo_pkginfo_filter_h handle,
1901 pkgmgrinfo_pkg_list_cb pkg_cb, void *user_data)
1903 return pkgmgrinfo_pkginfo_usr_filter_foreach_pkginfo(handle, pkg_cb, user_data, GLOBAL_USER);
1906 API int pkgmgrinfo_pkginfo_foreach_privilege(pkgmgrinfo_pkginfo_h handle,
1907 pkgmgrinfo_pkg_privilege_list_cb privilege_func, void *user_data)
1909 retvm_if(handle == NULL, PMINFO_R_EINVAL, "pkginfo handle is NULL");
1910 retvm_if(privilege_func == NULL, PMINFO_R_EINVAL, "Callback function is NULL");
1912 privilege_x *ptr = NULL;
1913 pkgmgr_pkginfo_x *info = (pkgmgr_pkginfo_x *)handle;
1914 ptr = info->pkg_info->privileges->privilege;
1915 for (; ptr; ptr = ptr->next) {
1917 ret = privilege_func(ptr->text, user_data);
1925 API int pkgmgrinfo_create_pkgusrdbinfo(const char *pkgid, uid_t uid, pkgmgrinfo_pkgdbinfo_h *handle)
1927 retvm_if(!pkgid, PMINFO_R_EINVAL, "pkgid is NULL");
1928 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
1930 char *manifest = NULL;
1931 manifest_x *mfx = NULL;
1933 manifest = pkgmgr_parser_get_usr_manifest_file(pkgid, uid);
1934 retvm_if(manifest == NULL, PMINFO_R_EINVAL, "pkg[%s] dont have manifest file", pkgid);
1936 mfx = pkgmgr_parser_usr_process_manifest_xml(manifest, uid);
1941 retvm_if(mfx == NULL, PMINFO_R_EINVAL, "pkg[%s] parsing fail", pkgid);
1943 *handle = (void *)mfx;
1948 API int pkgmgrinfo_create_pkgdbinfo(const char *pkgid, pkgmgrinfo_pkgdbinfo_h *handle)
1950 retvm_if(!pkgid, PMINFO_R_EINVAL, "pkgid is NULL");
1951 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
1953 char *manifest = NULL;
1954 manifest_x *mfx = NULL;
1956 manifest = pkgmgr_parser_get_manifest_file(pkgid);
1957 retvm_if(manifest == NULL, PMINFO_R_EINVAL, "pkg[%s] dont have manifest file", pkgid);
1959 mfx = pkgmgr_parser_process_manifest_xml(manifest);
1964 retvm_if(mfx == NULL, PMINFO_R_EINVAL, "pkg[%s] parsing fail", pkgid);
1966 *handle = (void *)mfx;
1971 API int pkgmgrinfo_set_type_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, const char *type)
1974 manifest_x *mfx = (manifest_x *)handle;
1976 retvm_if(!type, PMINFO_R_EINVAL, "Argument supplied is NULL");
1977 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
1980 retvm_if(len > PKG_TYPE_STRING_LEN_MAX, PMINFO_R_EINVAL, "pkg type length exceeds the max limit");
1983 free((void *)mfx->type);
1985 mfx->type = strndup(type, PKG_TYPE_STRING_LEN_MAX);
1990 API int pkgmgrinfo_set_version_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, const char *version)
1993 manifest_x *mfx = (manifest_x *)handle;
1995 retvm_if(!version, PMINFO_R_EINVAL, "Argument supplied is NULL");
1996 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
1998 len = strlen(version);
1999 retvm_if(len > PKG_TYPE_STRING_LEN_MAX, PMINFO_R_EINVAL, "pkg type length exceeds the max limit");
2002 free((void *)mfx->version);
2004 mfx->version = strndup(version, PKG_VERSION_STRING_LEN_MAX);
2008 API int pkgmgrinfo_set_install_location_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, INSTALL_LOCATION location)
2010 manifest_x *mfx = (manifest_x *)handle;
2012 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2013 retvm_if((location < 0) || (location > 1), PMINFO_R_EINVAL, "Argument supplied is NULL");
2015 if (mfx->installlocation)
2016 free((void *)mfx->installlocation);
2018 if (location == INSTALL_INTERNAL)
2019 mfx->installlocation = strdup("internal-only");
2020 else if (location == INSTALL_EXTERNAL)
2021 mfx->installlocation = strdup("prefer-external");
2026 API int pkgmgrinfo_set_size_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, const char *size)
2028 manifest_x *mfx = (manifest_x *)handle;
2030 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2031 retvm_if(size == NULL, PMINFO_R_EINVAL, "Argument supplied is NULL");
2033 if (mfx->package_size)
2034 free((void *)mfx->package_size);
2036 mfx->package_size = strdup(size);
2041 API int pkgmgrinfo_set_label_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, const char *label_txt, const char *locale)
2044 manifest_x *mfx = (manifest_x *)handle;
2047 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2048 retvm_if(!label_txt, PMINFO_R_EINVAL, "Argument supplied is NULL");
2050 len = strlen(label_txt);
2051 retvm_if(len > PKG_TYPE_STRING_LEN_MAX, PMINFO_R_EINVAL, "pkg type length exceeds the max limit");
2053 label = calloc(1, sizeof(label_x));
2054 retvm_if(label == NULL, PMINFO_R_EINVAL, "Malloc Failed");
2056 LISTADD(mfx->label, label);
2058 mfx->label->lang = strdup(locale);
2060 mfx->label->lang = strdup(DEFAULT_LOCALE);
2061 mfx->label->text = strdup(label_txt);
2066 API int pkgmgrinfo_set_icon_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, const char *icon_txt, const char *locale)
2069 manifest_x *mfx = (manifest_x *)handle;
2072 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2073 retvm_if(!icon_txt, PMINFO_R_EINVAL, "Argument supplied is NULL");
2075 len = strlen(icon_txt);
2076 retvm_if(len > PKG_TYPE_STRING_LEN_MAX, PMINFO_R_EINVAL, "pkg type length exceeds the max limit");
2078 icon = calloc(1, sizeof(icon_x));
2079 retvm_if(icon == NULL, PMINFO_R_EINVAL, "Malloc Failed");
2081 LISTADD(mfx->icon, icon);
2083 mfx->icon->lang = strdup(locale);
2085 mfx->icon->lang = strdup(DEFAULT_LOCALE);
2086 mfx->icon->text = strdup(icon_txt);
2091 API int pkgmgrinfo_set_description_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, const char *desc_txt, const char *locale)
2093 int len = strlen(desc_txt);
2094 manifest_x *mfx = (manifest_x *)handle;
2095 description_x *description;
2097 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2098 retvm_if(!desc_txt, PMINFO_R_EINVAL, "Argument supplied is NULL");
2100 len = strlen(desc_txt);
2101 retvm_if(len > PKG_TYPE_STRING_LEN_MAX, PMINFO_R_EINVAL, "pkg type length exceeds the max limit");
2103 description = calloc(1, sizeof(description_x));
2104 retvm_if(description == NULL, PMINFO_R_EINVAL, "Malloc Failed");
2106 LISTADD(mfx->description, description);
2108 mfx->description->lang = strdup(locale);
2110 mfx->description->lang = strdup(DEFAULT_LOCALE);
2111 mfx->description->text = strdup(desc_txt);
2116 API int pkgmgrinfo_set_author_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, const char *author_name,
2117 const char *author_email, const char *author_href, const char *locale)
2119 manifest_x *mfx = (manifest_x *)handle;
2122 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2124 author = calloc(1, sizeof(author_x));
2125 retvm_if(author == NULL, PMINFO_R_EINVAL, "Argument supplied is NULL");
2127 LISTADD(mfx->author, author);
2129 mfx->author->text = strdup(author_name);
2131 mfx->author->email = strdup(author_email);
2133 mfx->author->href = strdup(author_href);
2135 mfx->author->lang = strdup(locale);
2137 mfx->author->lang = strdup(DEFAULT_LOCALE);
2141 API int pkgmgrinfo_set_removable_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, int removable)
2143 manifest_x *mfx = (manifest_x *)handle;
2145 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2146 retvm_if((removable < 0) || (removable > 1), PMINFO_R_EINVAL, "Argument supplied is NULL");
2149 free((void *)mfx->removable);
2152 mfx->removable = strdup("false");
2153 else if (removable == 1)
2154 mfx->removable = strdup("true");
2159 API int pkgmgrinfo_set_preload_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, int preload)
2161 manifest_x *mfx = (manifest_x *)handle;
2163 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2164 retvm_if((preload < 0) || (preload > 1), PMINFO_R_EINVAL, "Argument supplied is NULL");
2167 free((void *)mfx->preload);
2170 mfx->preload = strdup("false");
2171 else if (preload == 1)
2172 mfx->preload = strdup("true");
2177 API int pkgmgrinfo_set_installed_storage_to_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle, INSTALL_LOCATION location)
2179 manifest_x *mfx = (manifest_x *)handle;
2181 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2182 retvm_if((location < 0) || (location > 1), PMINFO_R_EINVAL, "Argument supplied is NULL");
2184 if (mfx->installed_storage)
2185 free((void *)mfx->installed_storage);
2187 if (location == INSTALL_INTERNAL)
2188 mfx->installed_storage = strdup("installed_internal");
2189 else if (location == INSTALL_EXTERNAL)
2190 mfx->installed_storage = strdup("installed_external");
2195 API int pkgmgrinfo_save_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle)
2198 manifest_x *mfx = (manifest_x *)handle;
2199 mfx = (manifest_x *)handle;
2201 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2203 ret = pkgmgr_parser_update_manifest_info_in_db(mfx);
2205 _LOGE("Successfully stored info in DB\n");
2208 _LOGE("Failed to store info in DB\n");
2209 return PMINFO_R_ERROR;
2213 API int pkgmgrinfo_save_pkgusrdbinfo(pkgmgrinfo_pkgdbinfo_h handle, uid_t uid)
2216 manifest_x *mfx = (manifest_x *)handle;
2218 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2220 ret = pkgmgr_parser_update_manifest_info_in_usr_db(mfx, uid);
2222 _LOGE("Successfully stored info in DB\n");
2225 _LOGE("Failed to store info in DB\n");
2226 return PMINFO_R_ERROR;
2230 API int pkgmgrinfo_destroy_pkgdbinfo(pkgmgrinfo_pkgdbinfo_h handle)
2232 manifest_x *mfx = (manifest_x *)handle;
2234 retvm_if(!handle, PMINFO_R_EINVAL, "Argument supplied is NULL");
2236 pkgmgrinfo_basic_free_package(mfx);