Add api for getting privileged shared resource path
[platform/core/api/package-manager.git] / src / package_manager.c
index b8683f1..b00c7d0 100644 (file)
 
 #include <package-manager.h>
 #include <pkgmgr_installer.h>
+#include <pkgmgr_installer_error.h>
 #include <pkgmgr-info.h>
 #include <tzplatform_config.h>
 
 #include "package_manager.h"
 #include "package_manager_internal.h"
 
-static GHashTable *__cb_table = NULL;
-
 #define GLOBAL_USER tzplatform_getuid(TZ_SYS_GLOBALAPP_USER)
+#define USER_HOME tzplatform_getenv(TZ_USER_HOME)
+
+#define PRIV_SHARED_RES "priv_shared_res"
+
 typedef struct _request_event_info {
        int req_id;
        package_manager_event_type_e event_type;
@@ -50,7 +53,9 @@ struct package_manager_s {
        pkgmgr_mode mode;
        GHashTable *event_info_table;
        package_manager_event_cb event_cb;
+       package_manager_res_event_cb res_event_cb;
        void *user_data;
+       GMutex mutex;
 };
 
 struct package_manager_request_s {
@@ -62,12 +67,14 @@ struct package_manager_request_s {
        request_event_info *head;
        package_manager_request_event_cb event_cb;
        GHashTable *request_cb_table;
+       int n_paths;
        void *user_data;
 };
 
 struct package_manager_request_cb_info {
        int req_id;
        package_manager_request_event_cb callback;
+       package_manager_request_res_event_cb res_callback;
        void *user_data;
 };
 
@@ -90,6 +97,10 @@ struct package_updateinfo_request_s {
        pkg_update_info_t *updateinfo_handle;
 };
 
+struct package_manager_res_event_info_s {
+       pkgmgr_res_event_info *res_event_info_handle;
+};
+
 static int package_manager_request_new_id()
 {
        static int request_handle_id = 0;
@@ -188,6 +199,27 @@ static int __insert_request_cb_info(package_manager_request_h request, int req_i
        return 0;
 }
 
+static int __insert_res_request_cb_info(package_manager_request_h request,
+               int req_id, package_manager_request_res_event_cb callback,
+               void *user_data)
+{
+       struct package_manager_request_cb_info *cb_info;
+
+       if (request->request_cb_table == NULL)
+               return -1;
+
+       cb_info = calloc(1, sizeof(struct package_manager_request_cb_info));
+       if (cb_info == NULL)
+               return -1;
+       cb_info->req_id = req_id;
+       cb_info->res_callback = callback;
+       cb_info->user_data = user_data;
+       _LOGD("insert req_id(%d)", req_id);
+       g_hash_table_insert(request->request_cb_table, GINT_TO_POINTER(cb_info->req_id), cb_info);
+
+       return 0;
+}
+
 API int package_manager_request_create(package_manager_request_h *request)
 {
        struct package_manager_request_s *package_manager_request;
@@ -274,6 +306,10 @@ API int package_manager_request_set_event_cb(package_manager_request_h request,
 {
        int ret;
 
+       if (package_manager_client_validate_handle(request))
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+
        ret = check_privilege(PRIVILEGE_PACKAGE_MANAGER_INFO);
        if (ret != PACKAGE_MANAGER_ERROR_NONE)
                return ret;
@@ -363,12 +399,69 @@ static int package_manager_get_event_type(const char *key,
                *event_type = PACKAGE_MANAGER_EVENT_TYPE_MOVE;
        else if (strcasecmp(key, PKGMGR_INSTALLER_CLEAR_EVENT_STR) == 0)
                *event_type = PACKAGE_MANAGER_EVENT_TYPE_CLEAR;
+       else if (strcasecmp(key, PKGMGR_INSTALLER_RES_COPY_EVENT_STR) == 0)
+               *event_type = PACKAGE_MANAGER_EVENT_TYPE_RES_COPY;
+       else if (strcasecmp(key, PKGMGR_INSTALLER_RES_CREATE_DIR_EVENT_STR) == 0)
+               *event_type = PACKAGE_MANAGER_EVENT_TYPE_RES_CREATE_DIR;
+       else if (strcasecmp(key, PKGMGR_INSTALLER_RES_REMOVE_EVENT_STR) == 0)
+               *event_type = PACKAGE_MANAGER_EVENT_TYPE_RES_REMOVE;
+       else if (strcasecmp(key, PKGMGR_INSTALLER_RES_UNINSTALL_EVENT_STR) == 0)
+               *event_type = PACKAGE_MANAGER_EVENT_TYPE_RES_UNINSTALL;
        else
                return PACKAGE_MANAGER_ERROR_INVALID_PARAMETER;
 
        return PACKAGE_MANAGER_ERROR_NONE;
 }
 
+static package_manager_error_e __convert_to_error(int errcode)
+{
+       switch (errcode) {
+       case PKGMGR_INSTALLER_ERRCODE_UNDEFINED_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_GLOBALSYMLINK_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_GRANT_PERMISSION_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_IMAGE_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_PARSE_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_RECOVERY_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_DELTA_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_APP_DIR_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_CONFIG_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_ICON_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_MANIFEST_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_OUT_OF_SPACE:
+       case PKGMGR_INSTALLER_ERRCODE_ERROR:
+               return PACKAGE_MANAGER_ERROR_SYSTEM_ERROR;
+       case PKGMGR_INSTALLER_ERRCODE_UNZIP_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_SECURITY_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_REGISTER_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_PRIVILEGE_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_SIGNATURE_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_SIGNATURE_INVALID:
+       case PKGMGR_INSTALLER_ERRCODE_CERT_ERROR:
+       case PKGMGR_INSTALLER_ERRCODE_AUTHOR_CERT_NOT_MATCH:
+       case PKGMGR_INSTALLER_ERRCODE_AUTHOR_CERT_NOT_FOUND:
+       case PKGMGR_INSTALLER_ERRCODE_ICON_NOT_FOUND:
+       case PKGMGR_INSTALLER_ERRCODE_MANIFEST_NOT_FOUND:
+               return PACKAGE_MANAGER_ERROR_IO_ERROR;
+       case PKGMGR_INSTALLER_ERRCODE_PACKAGE_NOT_FOUND:
+               return PACKAGE_MANAGER_ERROR_NO_SUCH_PACKAGE;
+       case PKGMGR_INSTALLER_ERRCODE_OPERATION_NOT_ALLOWED:
+               return PACKAGE_MANAGER_ERROR_PERMISSION_DENIED;
+       case PKGMGR_INSTALLER_ERRCODE_INVALID_VALUE:
+               return PACKAGE_MANAGER_ERROR_INVALID_PARAMETER;
+       case PKGMGR_INSTALLER_ERRCODE_OK:
+               return PACKAGE_MANAGER_ERROR_NONE;
+       default:
+               return PACKAGE_MANAGER_ERROR_SYSTEM_ERROR;
+       }
+}
+
+static package_manager_error_e __convert_str_to_error(const char *val)
+{
+       int errcode = atoi(val);
+
+       return __convert_to_error(errcode);
+}
+
 static int __add_event_info(request_event_info **head, int req_id,
                            package_manager_event_type_e event_type,
                            package_manager_event_state_e event_state)
@@ -512,7 +605,7 @@ static int request_event_handler(uid_t target_uid, int req_id, const char *pkg_t
                                          pkg_name, event_type,
                                          PACKAGE_MANAGER_EVENT_STATE_FAILED,
                                          0,
-                                         PACKAGE_MANAGER_ERROR_NONE,
+                                         __convert_str_to_error(val),
                                          request->user_data);
 
        } else if (strcasecmp(key, "end") == 0) {
@@ -535,7 +628,7 @@ static int request_event_handler(uid_t target_uid, int req_id, const char *pkg_t
                                                          pkg_name, event_type,
                                                          PACKAGE_MANAGER_EVENT_STATE_FAILED,
                                                          0,
-                                                         PACKAGE_MANAGER_ERROR_NONE,
+                                                         PACKAGE_MANAGER_ERROR_SYSTEM_ERROR,
                                                          request->user_data);
                }
        }
@@ -612,16 +705,20 @@ static int internal_request_callback(uid_t target_uid, int req_id, const char *p
                                pkg_name, event_type,
                                PACKAGE_MANAGER_EVENT_STATE_FAILED,
                                0,
-                               PACKAGE_MANAGER_ERROR_NONE,
+                               __convert_str_to_error(val),
                                user_data);
                }
        } else if (strcasecmp(key, "end") == 0) {
                if (__find_event_info(&request->head, req_id, &event_type,
                                &event_state) == 0) {
                        if (request->request_cb_table) {
-                               _LOGD("remove item, req_id(%d)", req_id);
-                               g_hash_table_remove(request->request_cb_table,
-                                       GINT_TO_POINTER(req_id));
+                               request->n_paths--;
+                               if (request->n_paths < 1) {
+                                       _LOGD("remove item, req_id(%d)", req_id);
+                                       g_hash_table_remove(
+                                               request->request_cb_table,
+                                               GINT_TO_POINTER(req_id));
+                               }
                        }
                        if (event_state != PACKAGE_MANAGER_EVENT_STATE_FAILED) {
                                if (strcasecmp(val, "ok") == 0) {
@@ -636,7 +733,7 @@ static int internal_request_callback(uid_t target_uid, int req_id, const char *p
                                                pkg_name, event_type,
                                                PACKAGE_MANAGER_EVENT_STATE_FAILED,
                                                0,
-                                               PACKAGE_MANAGER_ERROR_NONE,
+                                               PACKAGE_MANAGER_ERROR_SYSTEM_ERROR,
                                                user_data);
                                }
                        }
@@ -648,6 +745,68 @@ static int internal_request_callback(uid_t target_uid, int req_id, const char *p
        return 0;
 }
 
+static void internal_res_request_callback(uid_t target_uid, int req_id,
+               const char *pkgid, const char *request_type, const char *status,
+               pkgmgr_res_event_info *handle, void *data)
+{
+       int ret;
+       package_manager_event_type_e event_type = -1;
+       package_manager_event_state_e event_state = -1;
+       struct package_manager_request_cb_info *cb_info;
+       package_manager_request_res_event_cb event_cb;
+       struct package_manager_res_event_info_s event_info;
+       void *user_data = NULL;
+
+       _LOGD("request callback called, req_id[%d]", req_id);
+
+       package_manager_request_h request = data;
+       event_info.res_event_info_handle = handle;
+
+       if (request->request_cb_table)
+               cb_info = g_hash_table_lookup(request->request_cb_table,
+                               GINT_TO_POINTER(req_id));
+       else
+               cb_info = NULL;
+
+       if (!cb_info || (cb_info && !cb_info->res_callback)) {
+               _LOGE("no callback info");
+               return;
+       }
+
+       if (cb_info->req_id != req_id) {
+               _LOGE("not matched request id");
+               return;
+       }
+
+       event_cb = cb_info->res_callback;
+       user_data = cb_info->user_data;
+
+       ret = package_manager_get_event_type(request_type, &event_type);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               return;
+       if (strcasecmp(status, "start") == 0) {
+               event_state = PACKAGE_MANAGER_EVENT_STATE_STARTED;
+       } else if (strcasecmp(status, "fail") == 0) {
+               event_state = PACKAGE_MANAGER_EVENT_STATE_FAILED;
+               _LOGD("remove item, req_id(%d)", req_id);
+               g_hash_table_remove(request->request_cb_table,
+                               GINT_TO_POINTER(req_id));
+       } else if (strcasecmp(status, "ok") == 0) {
+               event_state = PACKAGE_MANAGER_EVENT_STATE_COMPLETED;
+               _LOGD("remove item, req_id(%d)", req_id);
+               g_hash_table_remove(request->request_cb_table,
+                               GINT_TO_POINTER(req_id));
+       } else {
+               _LOGE("unexpected event");
+               return;
+       }
+
+       event_cb(req_id, pkgid, event_type, event_state,
+                       &event_info, user_data);
+
+       return;
+}
+
 static int __request_install(package_manager_request_h request,
                const char *path, pkgmgr_handler event_cb, int *id)
 {
@@ -685,6 +844,63 @@ static int __request_install(package_manager_request_h request,
        return PACKAGE_MANAGER_ERROR_NONE;
 }
 
+static int __request_install_packages(package_manager_request_h request,
+               const char **paths, int n_paths, pkgmgr_handler event_cb,
+               int *id)
+{
+       int retval;
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (package_manager_client_validate_handle(request))
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+
+       if (paths == NULL || n_paths < 1)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+       request->n_paths = n_paths;
+       int request_id = 0;
+       request_id = pkgmgr_client_install_packages(request->pc, paths,
+                       n_paths, event_cb ? event_cb : request_event_handler,
+                       request);
+
+       if (request_id == PKGMGR_R_EINVAL)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ENOPKG)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_NO_SUCH_PACKAGE,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ENOMEM)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EIO)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_IO_ERROR,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EPRIV)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_PERMISSION_DENIED,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ESYSTEM ||
+                       request_id == PKGMGR_R_ECOMM ||
+                       request_id == PKGMGR_R_ERROR)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_SYSTEM_ERROR,
+                               __FUNCTION__, NULL);
+
+       if (id)
+               *id = request_id;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
 static int __request_uninstall(package_manager_request_h request,
                const char *name, pkgmgr_handler event_cb, int *id)
 {
@@ -798,6 +1014,155 @@ static int __request_mount_install(package_manager_request_h request,
        return PACKAGE_MANAGER_ERROR_NONE;
 }
 
+static int __request_mount_install_packages(package_manager_request_h request,
+               const char **paths, int n_paths, pkgmgr_handler event_cb,
+               int *id)
+{
+       int retval;
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (package_manager_client_validate_handle(request))
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+
+       if (paths == NULL || n_paths < 1)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+       request->n_paths = n_paths;
+       int request_id = 0;
+       request_id = pkgmgr_client_mount_install_packages(request->pc, paths,
+                       n_paths, event_cb ? event_cb : request_event_handler,
+                       request);
+
+       if (request_id == PKGMGR_R_EINVAL)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ENOPKG)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_NO_SUCH_PACKAGE,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ENOMEM)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EIO)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_IO_ERROR,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EPRIV)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_PERMISSION_DENIED,
+                               __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ESYSTEM ||
+                       request_id == PKGMGR_R_ECOMM ||
+                       request_id == PKGMGR_R_ERROR)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_SYSTEM_ERROR,
+                               __FUNCTION__, NULL);
+
+       if (id)
+               *id = request_id;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+static int __request_res_copy(package_manager_request_h request,
+               pkgmgr_res_handler event_cb, int *id)
+{
+       int retval;
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (package_manager_client_validate_handle(request))
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+
+       int request_id = 0;
+       request_id = pkgmgr_client_res_copy(request->pc, event_cb, request);
+
+       if (request_id == PKGMGR_R_EINVAL)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ENOMEM)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EIO)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EPRIV)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_PERMISSION_DENIED, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ESYSTEM || request_id == PKGMGR_R_ECOMM || request_id == PKGMGR_R_ERROR)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
+
+       if (id)
+               *id = request_id;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+static int __request_res_create_dir(package_manager_request_h request,
+               pkgmgr_res_handler event_cb, int *id)
+{
+       int retval;
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (package_manager_client_validate_handle(request))
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+
+       int request_id = 0;
+       request_id = pkgmgr_client_res_create_dir(request->pc, event_cb, request);
+
+       if (request_id == PKGMGR_R_EINVAL)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ENOMEM)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EIO)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EPRIV)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_PERMISSION_DENIED, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ESYSTEM || request_id == PKGMGR_R_ECOMM || request_id == PKGMGR_R_ERROR)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
+
+       if (id)
+               *id = request_id;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+static int __request_res_remove(package_manager_request_h request,
+               pkgmgr_res_handler event_cb, int *id)
+{
+       int retval;
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (package_manager_client_validate_handle(request))
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+
+       int request_id = 0;
+       request_id = pkgmgr_client_res_remove(request->pc, event_cb, request);
+
+       if (request_id == PKGMGR_R_EINVAL)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ENOMEM)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EIO)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_EPRIV)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_PERMISSION_DENIED, __FUNCTION__, NULL);
+       else if (request_id == PKGMGR_R_ESYSTEM || request_id == PKGMGR_R_ECOMM || request_id == PKGMGR_R_ERROR)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
+
+       if (id)
+               *id = request_id;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
 
 API int package_manager_request_install(package_manager_request_h request,
                                const char *path, int *id)
@@ -829,6 +1194,42 @@ API int package_manager_request_install_with_cb(package_manager_request_h reques
        return ret;
 }
 
+API int package_manager_request_install_packages(
+               package_manager_request_h request, const char **paths,
+               int paths_count, int *id)
+{
+       return __request_install_packages(request, paths, paths_count, NULL, id);
+}
+
+API int package_manager_request_install_packages_with_cb(
+               package_manager_request_h request, const char **paths,
+               int paths_count, package_manager_request_event_cb callback,
+               void *user_data, int *id)
+{
+       int ret;
+       int req_id = 0;
+
+       if (request->request_cb_table == NULL)
+               __initialize_request_cb_table(request);
+
+       ret = __request_install_packages(request, paths, paths_count,
+                       internal_request_callback, &req_id);
+
+       if (req_id > 0) {
+               ret = __insert_request_cb_info(request, req_id, callback,
+                               user_data);
+               if (ret < 0)
+                       return package_manager_error(
+                                       PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                                       __FUNCTION__,
+                                       "failed to create request cb info");
+               if (id)
+                       *id = req_id;
+       }
+
+       return ret;
+}
+
 API int package_manager_request_uninstall(package_manager_request_h request,
                const char *name, int *id)
 {
@@ -919,6 +1320,43 @@ API int package_manager_request_mount_install_with_cb(package_manager_request_h
        return ret;
 }
 
+API int package_manager_request_mount_install_packages(
+               package_manager_request_h request, const char **paths,
+               int paths_count, int *id)
+{
+       return __request_mount_install_packages(request, paths, paths_count, NULL,
+                       id);
+}
+
+API int package_manager_request_mount_install_packages_with_cb(
+               package_manager_request_h request, const char **paths,
+               int paths_count, package_manager_request_event_cb callback,
+               void *user_data, int *id)
+{
+       int ret;
+       int req_id = 0;
+
+       if (request->request_cb_table == NULL)
+               __initialize_request_cb_table(request);
+
+       ret = __request_mount_install_packages(request, paths, paths_count,
+                       internal_request_callback, &req_id);
+
+       if (req_id > 0) {
+               ret = __insert_request_cb_info(request, req_id, callback,
+                               user_data);
+               if (ret < 0)
+                       return package_manager_error(
+                                       PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                                       __FUNCTION__,
+                                       "failed to create request cb info");
+               if (id)
+                       *id = req_id;
+       }
+
+       return ret;
+}
+
 API int package_manager_create(package_manager_h *manager)
 {
        int retval;
@@ -954,6 +1392,7 @@ API int package_manager_create(package_manager_h *manager)
        }
 
        package_manager->handle_id = package_manager_new_id();
+       g_mutex_init(&package_manager->mutex);
 
        *manager = package_manager;
 
@@ -977,6 +1416,7 @@ API int package_manager_destroy(package_manager_h manager)
                     NULL);
        }
 
+       g_mutex_clear(&manager->mutex);
        pkgmgr_client_free(manager->pc);
        g_hash_table_destroy(manager->event_info_table);
        free(manager);
@@ -1013,11 +1453,15 @@ static int internal_callback(uid_t target_uid, int req_id, const char *pkg_type,
                                const char *pkg_name, const char *key,
                                const char *val, const void *pmsg, void *data)
 {
-       int ret = -1;
-       package_manager_event_type_e event_type = -1;
        struct package_manager_event_info *info = NULL;
+       int ret = -1;
        package_manager_h manager = data;
        uid_t uid = target_uid;
+       bool invoke_callback = false;
+       package_manager_event_type_e event_type = -1;
+       package_manager_event_state_e event_state;
+       int progress = 0;
+       package_manager_error_e error = PACKAGE_MANAGER_ERROR_NONE;
 
        _LOGD("req_id(%d), pkg_name(%s), type(%s), key(%s), val(%s)",
                        req_id, pkg_name, pkg_type, key, val);
@@ -1029,6 +1473,7 @@ static int internal_callback(uid_t target_uid, int req_id, const char *pkg_type,
                return PACKAGE_MANAGER_ERROR_NONE;
 
        if (manager && manager->event_info_table) {
+               g_mutex_lock(&manager->mutex);
                info = g_hash_table_lookup(manager->event_info_table, pkg_name);
        } else {
                _LOGE("invalid handle");
@@ -1038,74 +1483,135 @@ static int internal_callback(uid_t target_uid, int req_id, const char *pkg_type,
        if (!info) {
                if (strcasecmp(key, "start") != 0) {
                        _LOGD("unexpected signal or no info(removed)");
+                       g_mutex_unlock(&manager->mutex);
                        return PACKAGE_MANAGER_ERROR_NONE;
                }
        }
 
        if (strcasecmp(key, "start") == 0) {
                ret = package_manager_get_event_type(val, &event_type);
-               if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+                       g_mutex_unlock(&manager->mutex);
                        return PACKAGE_MANAGER_ERROR_INVALID_PARAMETER;
+               }
 
                if (!info) {
                        __insert_event_info(manager, pkg_name, event_type,
                                        PACKAGE_MANAGER_EVENT_STATE_STARTED);
 
-                       if (manager->event_cb && getuid() == uid)
-                               manager->event_cb(pkg_type, pkg_name,
-                                               event_type,
-                                               PACKAGE_MANAGER_EVENT_STATE_STARTED,
-                                               0,
-                                               PACKAGE_MANAGER_ERROR_NONE,
-                                               manager->user_data);
+                       event_state = PACKAGE_MANAGER_EVENT_STATE_STARTED;
+                       progress = 0;
+                       error = PACKAGE_MANAGER_ERROR_NONE;
+                       invoke_callback = true;
                } else {
                        _LOGE("unexpected start event");
                }
        } else if (strcasecmp(key, "install_percent") == 0
                   || strcasecmp(key, "progress_percent") == 0) {
                info->event_state = PACKAGE_MANAGER_EVENT_STATE_PROCESSING;
-               if (manager->event_cb && getuid() == uid)
-                       manager->event_cb(pkg_type, pkg_name,
-                                       info->event_type,
-                                       info->event_state,
-                                       atoi(val),
-                                       PACKAGE_MANAGER_ERROR_NONE,
-                                       manager->user_data);
+               event_type = info->event_type;
+               event_state = info->event_state;
+               progress = atoi(val);
+               error = PACKAGE_MANAGER_ERROR_NONE;
+               invoke_callback = true;
        } else if (strcasecmp(key, "error") == 0) {
                info->event_state = PACKAGE_MANAGER_EVENT_STATE_FAILED;
-               if (manager->event_cb && getuid() == uid)
-                       manager->event_cb(pkg_type, pkg_name,
-                                       info->event_type,
-                                       info->event_state,
-                                       0,
-                                       PACKAGE_MANAGER_ERROR_NONE,
-                                       manager->user_data);
+               event_type = info->event_type;
+               event_state = info->event_state;
+               progress = 0;
+               error = __convert_str_to_error(val);
+               invoke_callback = true;
        } else if (strcasecmp(key, "end") == 0) {
                if (info->event_state != PACKAGE_MANAGER_EVENT_STATE_FAILED) {
-                       if (manager->event_cb && getuid() == uid) {
-                               if (strcasecmp(val, "ok") == 0) {
-                                       manager->event_cb(pkg_type, pkg_name,
-                                               info->event_type,
-                                               PACKAGE_MANAGER_EVENT_STATE_COMPLETED,
-                                               100,
-                                               PACKAGE_MANAGER_ERROR_NONE,
-                                               manager->user_data);
-                               } else {
-                                       manager->event_cb(pkg_type, pkg_name,
-                                               info->event_type,
-                                               PACKAGE_MANAGER_EVENT_STATE_FAILED,
-                                               0,
-                                               PACKAGE_MANAGER_ERROR_NONE,
-                                               manager->user_data);
-                               }
+                       if (strcasecmp(val, "ok") == 0) {
+                               event_type = info->event_type;
+                               event_state =
+                                       PACKAGE_MANAGER_EVENT_STATE_COMPLETED;
+                               progress = 100;
+                               error = PACKAGE_MANAGER_ERROR_NONE;
+                               invoke_callback = true;
+                       } else {
+                               event_type = info->event_type;
+                               event_state =
+                                       PACKAGE_MANAGER_EVENT_STATE_FAILED;
+                               progress = 0;
+                               error = PACKAGE_MANAGER_ERROR_SYSTEM_ERROR;
+                               invoke_callback = true;
                        }
                }
                g_hash_table_remove(manager->event_info_table, info->pkg_name);
        }
+       g_mutex_unlock(&manager->mutex);
+
+       if (invoke_callback && manager->event_cb && getuid() == uid) {
+               manager->event_cb(pkg_type, pkg_name, event_type, event_state,
+                               progress, error, manager->user_data);
+       }
 
        return PACKAGE_MANAGER_ERROR_NONE;
 }
 
+static void internal_res_callback(uid_t target_uid, int req_id,
+               const char *pkgid, const char *request_type, const char *status,
+               pkgmgr_res_event_info *handle, void *data)
+{
+       int ret = -1;
+       package_manager_h manager = data;
+       uid_t uid = target_uid;
+       package_manager_event_type_e event_type = -1;
+       package_manager_event_state_e event_state;
+       struct package_manager_res_event_info_s event_info;
+
+       event_info.res_event_info_handle = handle;
+
+       _LOGD("req_id(%d), pkg_name(%s), request_type(%s), status(%s)",
+                       req_id, pkgid, request_type, status);
+
+       if (target_uid == GLOBAL_USER)
+               uid = getuid();
+
+       if (__validate_event_signal(uid))
+               return;
+
+       if (manager) {
+               g_mutex_lock(&manager->mutex);
+       } else {
+               _LOGE("invalid handle");
+               return;
+       }
+       ret = package_manager_get_event_type(request_type, &event_type);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE) {
+               g_mutex_unlock(&manager->mutex);
+               return;
+       }
+
+       if (strcasecmp(status, "start") == 0) {
+               event_state = PACKAGE_MANAGER_EVENT_STATE_STARTED;
+       } else if (strcasecmp(status, "fail") == 0) {
+               event_state = PACKAGE_MANAGER_EVENT_STATE_FAILED;
+       } else if (strcasecmp(status, "ok") == 0) {
+               event_state = PACKAGE_MANAGER_EVENT_STATE_COMPLETED;
+       } else {
+               _LOGE("unexpected event");
+               g_mutex_unlock(&manager->mutex);
+               return;
+       }
+       g_mutex_unlock(&manager->mutex);
+
+       if (manager->res_event_cb && getuid() == uid) {
+               _LOGE("call callback");
+               manager->res_event_cb(pkgid, event_type, event_state,
+                               &event_info, manager->user_data);
+       } else {
+               if (!manager->res_event_cb)
+                       _LOGE("res_event_cb is null");
+               if (getuid() != uid)
+                       _LOGE("getuid : %d, uid : %d", getuid(), uid);
+       }
+
+       return;
+}
+
 static int __convert_status_type(package_manager_status_type_e status_type)
 {
        int type = 0;
@@ -1127,6 +1633,14 @@ static int __convert_status_type(package_manager_status_type_e status_type)
                type |= PKGMGR_CLIENT_STATUS_INSTALL_PROGRESS;
        if (status_type & PACKAGE_MANAGER_STATUS_TYPE_GET_SIZE)
                type |= PKGMGR_CLIENT_STATUS_GET_SIZE;
+       if (status_type & PACKAGE_MANAGER_STATUS_TYPE_RES_COPY)
+               type |= PKGMGR_CLIENT_STATUS_RES_COPY;
+       if (status_type & PACKAGE_MANAGER_STATUS_TYPE_RES_CREATE_DIR)
+               type |= PKGMGR_CLIENT_STATUS_RES_CREATE_DIR;
+       if (status_type & PACKAGE_MANAGER_STATUS_TYPE_RES_REMOVE)
+               type |= PKGMGR_CLIENT_STATUS_RES_REMOVE;
+       if (status_type & PACKAGE_MANAGER_STATUS_TYPE_RES_UNINSTALL)
+               type |= PKGMGR_CLIENT_STATUS_RES_UNINSTALL;
 
        return type;
 }
@@ -1141,7 +1655,11 @@ API int package_manager_set_event_status(package_manager_h manager, int status_t
                PACKAGE_MANAGER_STATUS_TYPE_MOVE |
                PACKAGE_MANAGER_STATUS_TYPE_CLEAR_DATA |
                PACKAGE_MANAGER_STATUS_TYPE_INSTALL_PROGRESS |
-               PACKAGE_MANAGER_STATUS_TYPE_GET_SIZE;
+               PACKAGE_MANAGER_STATUS_TYPE_GET_SIZE |
+               PACKAGE_MANAGER_STATUS_TYPE_RES_COPY |
+               PACKAGE_MANAGER_STATUS_TYPE_RES_CREATE_DIR |
+               PACKAGE_MANAGER_STATUS_TYPE_RES_REMOVE |
+               PACKAGE_MANAGER_STATUS_TYPE_RES_UNINSTALL;
 
        if (manager == NULL)
                return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
@@ -1162,7 +1680,6 @@ API int package_manager_set_event_cb(package_manager_h manager,
                                 package_manager_event_cb callback,
                                 void *user_data)
 {
-
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_INFO);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1178,6 +1695,12 @@ API int package_manager_set_event_cb(package_manager_h manager,
        manager->event_cb = callback;
        manager->user_data = user_data;
 
+       retval = pkgmgr_client_remove_listen_status(manager->pc);
+       if (retval < 0) {
+               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR,
+                       __FUNCTION__, NULL);
+       }
+
        retval = pkgmgr_client_listen_status(manager->pc,
                        internal_callback, manager);
        if (retval < 0) {
@@ -1194,6 +1717,40 @@ API int package_manager_set_event_cb(package_manager_h manager,
        return PACKAGE_MANAGER_ERROR_NONE;
 }
 
+API int package_manager_set_res_event_cb(package_manager_h manager,
+               package_manager_res_event_cb callback, void *user_data)
+{
+       int retval;
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (package_manager_validate_handle(manager)) {
+               return
+                   package_manager_error
+                   (PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__,
+                    NULL);
+       }
+
+       manager->res_event_cb = callback;
+       manager->user_data = user_data;
+
+       retval = pkgmgr_client_remove_listen_status(manager->pc);
+       if (retval < 0) {
+               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR,
+                       __FUNCTION__, NULL);
+       }
+
+       retval = pkgmgr_client_listen_res_status(manager->pc,
+                       internal_res_callback, manager);
+       if (retval < 0) {
+               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR,
+                       __FUNCTION__, NULL);
+       }
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
 API int package_manager_unset_event_cb(package_manager_h manager)
 {
        if (manager == NULL) {
@@ -1205,9 +1762,12 @@ API int package_manager_unset_event_cb(package_manager_h manager)
 
        int retval;
        manager->event_cb = NULL;
+       manager->res_event_cb = NULL;
        manager->user_data = NULL;
 
+       g_mutex_lock(&manager->mutex);
        g_hash_table_remove_all(manager->event_info_table);
+       g_mutex_unlock(&manager->mutex);
 
        retval = pkgmgr_client_remove_listen_status(manager->pc);
        if (retval == PKGMGR_R_EINVAL)
@@ -1277,7 +1837,6 @@ API int package_manager_get_package_info(const char *package_id, package_info_h
 API int package_manager_foreach_package_info(package_manager_package_info_cb callback,
                                        void *user_data)
 {
-
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_INFO);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1320,7 +1879,6 @@ API int package_manager_compare_app_cert_info(const char *lhs_app_id, const char
 
 API int package_manager_is_preload_package_by_app_id(const char *app_id, bool *preload)
 {
-
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_INFO);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1363,7 +1921,6 @@ API int package_manager_is_preload_package_by_app_id(const char *app_id, bool *p
 
 API int package_manager_get_permission_type(const char *app_id, package_manager_permission_type_e *permission_type)
 {
-
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_INFO);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1394,7 +1951,6 @@ API int package_manager_get_permission_type(const char *app_id, package_manager_
 
 API int package_manager_clear_cache_dir(const char *package_id)
 {
-
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_CACHE);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1480,7 +2036,6 @@ API int package_manager_clear_data_dir(const char *package_id)
 
 API int package_manager_clear_all_cache_dir(void)
 {
-
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1489,23 +2044,25 @@ API int package_manager_clear_all_cache_dir(void)
        return package_manager_clear_cache_dir(PKG_CLEAR_ALL_CACHE);
 }
 
-static void __free_client(gpointer data)
-{
-       pkgmgr_client *pc = (pkgmgr_client *)data;
-       pkgmgr_client_free(pc);
-}
+struct getsize_cbdata {
+       pkgmgr_client *pc;
+       void *cb;
+       void *user_data;
+};
 
-static void __initialize_cb_table(void)
+static void __free_getsize_cbdata(struct getsize_cbdata *cbdata)
 {
-       __cb_table = g_hash_table_new_full(g_direct_hash, g_direct_equal, __free_client, NULL);
+       pkgmgr_client_free(cbdata->pc);
+       free(cbdata);
 }
 
 static void __result_cb(pkgmgr_client *pc, const char *pkgid, const pkg_size_info_t *result, void *user_data)
 {
-       package_manager_size_info_receive_cb callback = g_hash_table_lookup(__cb_table, pc);
+       struct getsize_cbdata *cbdata = (struct getsize_cbdata *)user_data;
+       package_manager_size_info_receive_cb callback = cbdata->cb;
        if (callback == NULL) {
                _LOGE("callback is null.");
-               g_hash_table_remove(__cb_table, pc);
+               __free_getsize_cbdata(cbdata);
                return;
        }
 
@@ -1517,17 +2074,18 @@ static void __result_cb(pkgmgr_client *pc, const char *pkgid, const pkg_size_inf
        size_info.external_cache_size = result->ext_cache_size;
        size_info.external_app_size   = result->ext_app_size;
 
-       callback(pkgid, (package_size_info_h)&size_info, user_data);
+       callback(pkgid, (package_size_info_h)&size_info, cbdata->user_data);
 
-       g_hash_table_remove(__cb_table, pc);
+       __free_getsize_cbdata(cbdata);
 }
 
 static void __total_result_cb(pkgmgr_client *pc, const pkg_size_info_t *result, void *user_data)
 {
-       package_manager_total_size_info_receive_cb callback = g_hash_table_lookup(__cb_table, pc);
+       struct getsize_cbdata *cbdata = (struct getsize_cbdata *)user_data;
+       package_manager_total_size_info_receive_cb callback = cbdata->cb;
        if (callback == NULL) {
                _LOGE("callback is null.");
-               g_hash_table_remove(__cb_table, pc);
+               __free_getsize_cbdata(cbdata);
                return;
        }
 
@@ -1539,55 +2097,58 @@ static void __total_result_cb(pkgmgr_client *pc, const pkg_size_info_t *result,
        size_info.external_cache_size = result->ext_cache_size;
        size_info.external_app_size   = result->ext_app_size;
 
-       callback((package_size_info_h)&size_info, user_data);
+       callback((package_size_info_h)&size_info, cbdata->user_data);
 
-       g_hash_table_remove(__cb_table, pc);
+       __free_getsize_cbdata(cbdata);
 }
 
 static int _get_pkg_size_info(const char *package_id, void *callback, void *user_data)
 {
+       struct getsize_cbdata *cbdata;
+
        if (package_id == NULL || callback == NULL)
                return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
 
-       if (__cb_table == NULL)
-               __initialize_cb_table();
+       cbdata = malloc(sizeof(struct getsize_cbdata));
+       if (cbdata == NULL)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY, __FUNCTION__, NULL);
 
        pkgmgr_client *pc = pkgmgr_client_new(PC_REQUEST);
-       if (pc == NULL)
+       if (pc == NULL) {
+               free(cbdata);
                return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
+       }
+
+       cbdata->pc = pc;
+       cbdata->cb = callback;
+       cbdata->user_data = user_data;
 
        int res = 0;
        if (strcmp(package_id, PKG_SIZE_INFO_TOTAL) != 0)
-               res = pkgmgr_client_get_package_size_info(pc, package_id, __result_cb, user_data);
+               res = pkgmgr_client_get_package_size_info(pc, package_id, __result_cb, cbdata);
        else
-               res = pkgmgr_client_get_total_package_size_info(pc, __total_result_cb, user_data);
-
-       if (res == PKGMGR_R_EINVAL) {
-               pkgmgr_client_free(pc);
-               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
-       } else if (res == PKGMGR_R_ENOPKG) {
-               pkgmgr_client_free(pc);
-               return package_manager_error(PACKAGE_MANAGER_ERROR_NO_SUCH_PACKAGE, __FUNCTION__, NULL);
-       } else if (res == PKGMGR_R_ENOMEM) {
-               pkgmgr_client_free(pc);
-               return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY, __FUNCTION__, NULL);
-       } else if (res == PKGMGR_R_EIO) {
-               pkgmgr_client_free(pc);
-               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR, __FUNCTION__, NULL);
-       } else if (res == PKGMGR_R_EPRIV) {
-               pkgmgr_client_free(pc);
-               return package_manager_error(PACKAGE_MANAGER_ERROR_PERMISSION_DENIED, __FUNCTION__, NULL);
-       } else if (res == PKGMGR_R_ESYSTEM || res == PKGMGR_R_ECOMM || res == PKGMGR_R_ERROR) {
-               pkgmgr_client_free(pc);
-               return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
-       } else if (res != PKGMGR_R_OK) {
-               _LOGE("Unexpected error");
-               pkgmgr_client_free(pc);
-               return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
+               res = pkgmgr_client_get_total_package_size_info(pc, __total_result_cb, cbdata);
+
+       if (res != PKGMGR_R_OK) {
+               __free_getsize_cbdata(cbdata);
+               if (res == PKGMGR_R_EINVAL) {
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+               } else if (res == PKGMGR_R_ENOPKG) {
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_NO_SUCH_PACKAGE, __FUNCTION__, NULL);
+               } else if (res == PKGMGR_R_ENOMEM) {
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY, __FUNCTION__, NULL);
+               } else if (res == PKGMGR_R_EIO) {
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR, __FUNCTION__, NULL);
+               } else if (res == PKGMGR_R_EPRIV) {
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_PERMISSION_DENIED, __FUNCTION__, NULL);
+               } else if (res == PKGMGR_R_ESYSTEM || res == PKGMGR_R_ECOMM || res == PKGMGR_R_ERROR) {
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
+               } else {
+                       _LOGE("Unexpected error");
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR, __FUNCTION__, NULL);
+               }
        }
 
-       g_hash_table_insert(__cb_table, pc, callback);
-
        return PACKAGE_MANAGER_ERROR_NONE;
 }
 
@@ -1663,9 +2224,27 @@ API int package_manager_filter_add_bool(package_manager_filter_h handle,
        return PACKAGE_MANAGER_ERROR_NONE;
 }
 
-API int package_manager_filter_count(package_manager_filter_h handle, int *count)
+
+API int package_manager_filter_add_string(package_manager_filter_h handle, const char *property, const char *value)
 {
+       int retval;
+
+       if ((handle == NULL) || (property == NULL) || (value == NULL)) {
+               return
+                   package_manager_error
+                   (PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__,
+                    NULL);
+       }
+
+       retval = pkgmgrinfo_pkginfo_filter_add_string(handle, property, value);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_IO_ERROR, __FUNCTION__, NULL);
 
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+API int package_manager_filter_count(package_manager_filter_h handle, int *count)
+{
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_INFO);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1684,7 +2263,6 @@ API int package_manager_filter_count(package_manager_filter_h handle, int *count
 API int package_manager_filter_foreach_package_info(package_manager_filter_h handle,
                package_manager_package_info_cb callback, void *user_data)
 {
-
        int retval;
        retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_INFO);
        if (retval != PACKAGE_MANAGER_ERROR_NONE)
@@ -1938,3 +2516,317 @@ API int package_manager_updateinfo_request_unregister_all(package_updateinfo_req
 
        return PACKAGE_MANAGER_ERROR_NONE;
 }
+
+API int package_manager_request_add_res_copy_path(
+               package_manager_request_h request,
+               const char *src_path, const char *dest_path)
+{
+       int retval = 0;
+
+       if (package_manager_client_validate_handle(request)
+                       || src_path == NULL || dest_path == NULL) {
+               return
+                       package_manager_error
+                       (PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__,
+                        NULL);
+       }
+
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (pkgmgr_client_add_res_copy_path(request->pc, src_path, dest_path))
+               return PACKAGE_MANAGER_ERROR_SYSTEM_ERROR;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+API int package_manager_request_res_copy_with_cb(package_manager_request_h request,
+               package_manager_request_res_event_cb callback,
+               void *user_data, int *id)
+{
+       int ret;
+       int req_id = 0;
+
+       if (package_manager_client_validate_handle(request)
+                       || callback == NULL || id == NULL) {
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+       }
+
+       ret = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               return ret;
+
+       if (request->request_cb_table == NULL)
+               __initialize_request_cb_table(request);
+
+       ret = __request_res_copy(request, internal_res_request_callback, &req_id);
+
+       if (req_id > 0) {
+               ret = __insert_res_request_cb_info(request, req_id,
+                               callback, user_data);
+               if (ret < 0)
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                                       __FUNCTION__, "failed to create request cb info");
+               if (id)
+                       *id = req_id;
+       }
+
+       return ret;
+}
+
+API int package_manager_request_add_res_create_dir_path(
+               package_manager_request_h request, const char *dir_path)
+{
+       int retval = 0;
+
+       if (package_manager_client_validate_handle(request)
+                       || dir_path == NULL) {
+               return
+                       package_manager_error
+                       (PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__,
+                        NULL);
+       }
+
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (pkgmgr_client_add_res_create_dir_path(request->pc, dir_path))
+               return PACKAGE_MANAGER_ERROR_SYSTEM_ERROR;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+API int package_manager_request_res_create_dir_with_cb(
+               package_manager_request_h request,
+               package_manager_request_res_event_cb callback,
+               void *user_data, int *id)
+{
+       int ret;
+       int req_id = 0;
+
+       if (package_manager_client_validate_handle(request)
+                       || callback == NULL || id == NULL) {
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+       }
+
+       if (request->request_cb_table == NULL)
+               __initialize_request_cb_table(request);
+
+       ret = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               return ret;
+
+       ret = __request_res_create_dir(request, internal_res_request_callback, &req_id);
+
+       if (req_id > 0) {
+               ret = __insert_res_request_cb_info(request, req_id,
+                               callback, user_data);
+               if (ret < 0)
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                                       __FUNCTION__, "failed to create request cb info");
+               if (id)
+                       *id = req_id;
+       }
+
+       return ret;
+}
+
+API int package_manager_request_add_res_remove_path(
+               package_manager_request_h request, const char *res_path)
+{
+       int retval = 0;
+
+       if (package_manager_client_validate_handle(request)
+                       || res_path == NULL) {
+               return
+                       package_manager_error
+                       (PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__,
+                        NULL);
+       }
+
+       retval = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (retval != PACKAGE_MANAGER_ERROR_NONE)
+               return retval;
+
+       if (pkgmgr_client_add_res_remove_path(request->pc, res_path))
+               return PACKAGE_MANAGER_ERROR_SYSTEM_ERROR;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+API int package_manager_request_res_remove_with_cb(
+               package_manager_request_h request,
+               package_manager_request_res_event_cb callback,
+               void *user_data, int *id)
+{
+       int ret;
+       int req_id = 0;
+
+       if (package_manager_client_validate_handle(request)
+                       || callback == NULL || id == NULL) {
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+       }
+
+       ret = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               return ret;
+
+       if (request->request_cb_table == NULL)
+               __initialize_request_cb_table(request);
+
+       ret = __request_res_remove(request, internal_res_request_callback, &req_id);
+
+       if (req_id > 0) {
+               ret = __insert_res_request_cb_info(request, req_id,
+                               callback, user_data);
+               if (ret < 0)
+                       return package_manager_error(PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                                       __FUNCTION__, "failed to create request cb info");
+               if (id)
+                       *id = req_id;
+       }
+
+       return ret;
+}
+
+API int package_manager_res_event_info_get_error_code(
+               package_manager_res_event_info_h handle,
+               package_manager_error_e *error)
+{
+       int ret;
+       int error_code = 0;
+
+       ret = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               return ret;
+
+       if (handle == NULL || error == NULL)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+
+       struct package_manager_res_event_info_s *event_info =
+                       (struct package_manager_res_event_info_s *)handle;
+
+       if (event_info->res_event_info_handle == NULL)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+
+       if (pkgmgr_res_event_info_get_error_code(
+                       event_info->res_event_info_handle, &error_code))
+                       return package_manager_error(
+                                       PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                                       __FUNCTION__, NULL);
+
+       *error = __convert_to_error(error_code);
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+typedef struct _foreach_res_event_path_context_ {
+       package_manager_res_event_path_cb callback;
+       void *user_data;
+} foreach_res_event_path_context_s;
+
+static int package_res_event_info_foreach_path_cb(const char *path,
+               pkgmgr_res_event_path_state state, void *user_data)
+{
+       foreach_res_event_path_context_s *foreach_context = user_data;
+       package_manager_res_event_path_state_e path_state =
+                       PACKAGE_MANAGER_RES_EVENT_PATH_STATE_NONE;
+       bool r = false;
+
+       if (foreach_context == NULL) {
+               package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+               return -1;
+       }
+
+       if (state == PM_RES_EVENT_PATH_STATE_NONE) {
+               path_state = PACKAGE_MANAGER_RES_EVENT_PATH_STATE_NONE;
+       } else if (state == PM_RES_EVENT_PATH_STATE_OK) {
+               path_state = PACKAGE_MANAGER_RES_EVENT_PATH_STATE_OK;
+       } else if (state == PM_RES_EVENT_PATH_STATE_FAILED) {
+               path_state = PACKAGE_MANAGER_RES_EVENT_PATH_STATE_FAILED;
+       } else {
+               package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+               return -1;
+       }
+
+       r = foreach_context->callback(path, path_state,
+                       foreach_context->user_data);
+       if (r == false)
+               return -1;
+
+       return 0;
+}
+
+API int package_manager_res_event_info_foreach_path(
+               package_manager_res_event_info_h handle,
+               package_manager_res_event_path_cb callback, void *user_data)
+{
+       int ret;
+       foreach_res_event_path_context_s foreach_res_event_path_context = {
+               .callback = callback,
+               .user_data = user_data,
+       };
+
+       ret = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               return ret;
+
+       if (handle == NULL || callback == NULL)
+               return package_manager_error(PACKAGE_MANAGER_ERROR_INVALID_PARAMETER, __FUNCTION__, NULL);
+
+       struct package_manager_res_event_info_s *event_info =
+                       (struct package_manager_res_event_info_s *)handle;
+
+       if (event_info->res_event_info_handle == NULL)
+               return package_manager_error(
+                               PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                               __FUNCTION__, NULL);
+
+       ret = pkgmgr_res_event_info_foreach_path(
+                       event_info->res_event_info_handle,
+                       package_res_event_info_foreach_path_cb,
+                       &foreach_res_event_path_context);
+       if (ret != PKGMGR_R_OK) {
+               return package_manager_error(PACKAGE_MANAGER_ERROR_SYSTEM_ERROR,
+                               __FUNCTION__, NULL);
+       }
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}
+
+API int package_manager_get_priv_shared_res_path(const char *package_id, char **path)
+{
+       int ret;
+       char *path_dup;
+       char buf[PATH_MAX];
+
+       ret = check_privilege(PRIVILEGE_PACKAGE_MANAGER_ADMIN);
+       if (ret != PACKAGE_MANAGER_ERROR_NONE)
+               return ret;
+
+       if (package_id == NULL || path == NULL)
+               return package_manager_error(
+                       PACKAGE_MANAGER_ERROR_INVALID_PARAMETER,
+                       __FUNCTION__, NULL);
+
+       snprintf(buf, sizeof(buf), "%s/%s/%s", USER_HOME,
+                       PRIV_SHARED_RES, package_id);
+
+       path_dup = strdup(buf);
+       if (path_dup == NULL)
+               return package_manager_error(
+                       PACKAGE_MANAGER_ERROR_OUT_OF_MEMORY,
+                       __FUNCTION__, NULL);
+       *path = path_dup;
+
+       return PACKAGE_MANAGER_ERROR_NONE;
+}