#include <gum/gum-user.h>
#include <gum/common/gum-user-types.h>
-#include "pm-queue.h"
+#include "queue.h"
#include "pkgmgr-server.h"
#include "package-manager.h"
+#define RETRY_MAX 5
+#define RETRY_WAIT_USEC (1000000 / 2) /* 0.5 sec */
#define PKGMGR_DBUS_SERVICE "org.tizen.pkgmgr"
#define PKGMGR_DBUS_OBJECT_PATH "/org/tizen/pkgmgr"
" <interface name='org.tizen.pkgmgr'>"
" <method name='install'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
" <arg type='s' name='pkgpath' direction='in'/>"
" <arg type='as' name='args' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
" </method>"
" <method name='reinstall'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
" <arg type='s' name='pkgid' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
" <arg type='s' name='reqkey' direction='out'/>"
" </method>"
" <method name='mount_install'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
" <arg type='s' name='pkgpath' direction='in'/>"
" <arg type='as' name='args' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
" </method>"
" <method name='uninstall'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
" <arg type='s' name='pkgid' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
" <arg type='s' name='reqkey' direction='out'/>"
" </method>"
" <method name='move'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
" <arg type='s' name='pkgid' direction='in'/>"
" <arg type='i' name='movetype' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
" <arg type='s' name='reqkey' direction='out'/>"
" </method>"
- " <method name='enable_pkg'>"
+ " <method name='enable_pkgs'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
- " <arg type='s' name='pkgid' direction='in'/>"
+ " <arg type='as' name='pkgids' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
+ " <arg type='s' name='reqkey' direction='out'/>"
" </method>"
- " <method name='disable_pkg'>"
+ " <method name='disable_pkgs'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
- " <arg type='s' name='pkgid' direction='in'/>"
+ " <arg type='as' name='pkgids' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
+ " <arg type='s' name='reqkey' direction='out'/>"
" </method>"
" <method name='enable_app'>"
" <arg type='u' name='uid' direction='in'/>"
" </method>"
" <method name='cleardata'>"
" <arg type='u' name='uid' direction='in'/>"
- " <arg type='s' name='pkgtype' direction='in'/>"
" <arg type='s' name='pkgid' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
" </method>"
" <arg type='u' name='uid' direction='in'/>"
" <arg type='s' name='pkgid' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
+ " <arg type='i' name='pid' direction='out'/>"
" </method>"
" <method name='check'>"
" <arg type='u' name='uid' direction='in'/>"
" <arg type='s' name='pkgid' direction='in'/>"
" <arg type='i' name='ret' direction='out'/>"
+ " <arg type='i' name='pid' direction='out'/>"
" </method>"
" <method name='generate_license_request'>"
" <arg type='s' name='resp_data' direction='in'/>"
{
GumUser *guser;
GumUserType ut = GUM_USERTYPE_NONE;
+ int retry_cnt = 0;
+
+ do {
+ guser = gum_user_get_sync(uid, FALSE);
+ if (guser == NULL) {
+ ERR("cannot get user information from gumd, retry");
+ retry_cnt++;
+ usleep(RETRY_WAIT_USEC);
+ continue;
+ }
+ break;
+ } while (retry_cnt <= RETRY_MAX);
- guser = gum_user_get_sync(uid, FALSE);
if (guser == NULL) {
- ERR("cannot get user information from gumd");
+ ERR("cannot get user information from gumd, failed");
return -1;
}
return 0;
}
-static int __handle_request_install(uid_t uid,
+static int __handle_request_install(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
+ const char *pkgtype;
char *pkgpath = NULL;
char *args = NULL;
char *reqkey = NULL;
int i = 0;
int len = 0;
- g_variant_get(parameters, "(u&s&s@as)", &target_uid, &pkgtype, &pkgpath, &value);
+ g_variant_get(parameters, "(u&s@as)", &target_uid, &pkgpath, &value);
tmp_args = (gchar **)g_variant_get_strv(value, &args_count);
for (i = 0; i < args_count; i++)
args = (char *)calloc(len, sizeof(char));
if (args == NULL) {
ERR("calloc failed");
- ret = -1;
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
+ ret = -1;
goto catch;
}
strncat(args, " ", strlen(" "));
}
- if (target_uid == (uid_t)-1 || pkgtype == NULL) {
+ if (target_uid == (uid_t)-1 || pkgpath == NULL) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
ret = -1;
goto catch;
}
- if (pkgpath == NULL) {
+ pkgtype = _get_pkgtype_from_file(pkgpath);
+ if (pkgtype == NULL) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
ret = -1;
reqkey = __generate_reqkey(pkgpath);
if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
ret = -1;
goto catch;
}
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_INSTALL, pkgtype,
- pkgpath, args)) {
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_INSTALL,
+ pkgtype, pkgpath, args)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
ret = -1;
if (args)
free(args);
+ if (tmp_args)
+ g_free(tmp_args);
+
return ret;
}
-static int __handle_request_mount_install(uid_t uid,
+static int __handle_request_mount_install(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
+ const char *pkgtype;
char *pkgpath = NULL;
char *args = NULL;
char *reqkey = NULL;
int i = 0;
int len = 0;
- g_variant_get(parameters, "(u&s&s@as)", &target_uid, &pkgtype, &pkgpath, &value);
+ g_variant_get(parameters, "(u&s@as)", &target_uid, &pkgpath, &value);
tmp_args = (gchar **)g_variant_get_strv(value, &args_count);
for (i = 0; i < args_count; i++)
args = (char *)calloc(len, sizeof(char));
if (args == NULL) {
ERR("calloc failed");
- ret = -1;
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
+ ret = -1;
goto catch;
}
strncat(args, " ", strlen(" "));
}
- if (target_uid == (uid_t)-1 || pkgtype == NULL) {
+ if (target_uid == (uid_t)-1 || pkgpath == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(is)",
- PKGMGR_R_ECOMM, ""));
+ g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
ret = -1;
goto catch;
}
- if (pkgpath == NULL) {
+ pkgtype = _get_pkgtype_from_file(pkgpath);
+ if (pkgtype == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(is)",
- PKGMGR_R_ECOMM, ""));
+ g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
ret = -1;
goto catch;
}
reqkey = __generate_reqkey(pkgpath);
if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
ret = -1;
goto catch;
}
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_MOUNT_INSTALL,
- pkgtype, pkgpath, args)) {
- g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(is)",
- PKGMGR_R_ESYSTEM, ""));
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_MOUNT_INSTALL,
+ pkgtype, pkgpath, args)) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
ret = -1;
goto catch;
}
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(is)",
- PKGMGR_R_OK,
- reqkey));
+ g_variant_new("(is)", PKGMGR_R_OK, reqkey));
ret = 0;
- catch:
+catch:
if (reqkey)
free(reqkey);
if (args)
free(args);
+ if (tmp_args)
+ g_free(tmp_args);
+
return ret;
}
-static int __handle_request_reinstall(uid_t uid,
+static int __handle_request_reinstall(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
+ char *pkgtype;
char *pkgid = NULL;
char *reqkey;
- g_variant_get(parameters, "(u&s&s)", &target_uid, &pkgtype, &pkgid);
- if (target_uid == (uid_t)-1 || pkgtype == NULL || pkgid == NULL) {
+ g_variant_get(parameters, "(u&s)", &target_uid, &pkgid);
+ if (target_uid == (uid_t)-1 || pkgid == NULL) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
return -1;
}
+ pkgtype = _get_pkgtype_from_pkgid(pkgid, target_uid);
+ if (pkgtype == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
+ return -1;
+ }
+
reqkey = __generate_reqkey(pkgid);
- if (reqkey == NULL)
+ if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
+ free(pkgtype);
return -1;
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_REINSTALL, pkgtype,
- pkgid, "")) {
+ }
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_REINSTALL,
+ pkgtype, pkgid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
free(reqkey);
+ free(pkgtype);
return -1;
}
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_OK, reqkey));
free(reqkey);
+ free(pkgtype);
return 0;
}
-static int __handle_request_uninstall(uid_t uid,
+static int __handle_request_uninstall(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
+ char *pkgtype;
char *pkgid = NULL;
char *reqkey;
- g_variant_get(parameters, "(u&s&s)", &target_uid, &pkgtype, &pkgid);
- if (target_uid == (uid_t)-1 || pkgtype == NULL || pkgid == NULL) {
+ g_variant_get(parameters, "(u&s)", &target_uid, &pkgid);
+ if (target_uid == (uid_t)-1 || pkgid == NULL) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
return -1;
}
+ pkgtype = _get_pkgtype_from_pkgid(pkgid, target_uid);
+ if (pkgtype == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
+ return -1;
+ }
+
reqkey = __generate_reqkey(pkgid);
- if (reqkey == NULL)
+ if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
+ free(pkgtype);
return -1;
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_UNINSTALL, pkgtype,
- pkgid, "")) {
+ }
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_UNINSTALL,
+ pkgtype, pkgid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
free(reqkey);
+ free(pkgtype);
return -1;
}
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_OK, reqkey));
free(reqkey);
+ free(pkgtype);
return 0;
}
-static int __handle_request_move(uid_t uid,
+static int __handle_request_move(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
+ char *pkgtype;
char *pkgid = NULL;
char *reqkey;
int move_type = -1;
char buf[4] = { '\0' };
- g_variant_get(parameters, "(u&s&si)", &target_uid, &pkgtype, &pkgid, &move_type);
- if (target_uid == (uid_t)-1 || pkgtype == NULL || pkgid == NULL) {
+ g_variant_get(parameters, "(u&si)", &target_uid, &pkgid, &move_type);
+ if (target_uid == (uid_t)-1 || pkgid == NULL) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
return -1;
}
+ pkgtype = _get_pkgtype_from_pkgid(pkgid, target_uid);
+ if (pkgtype == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
+ return -1;
+ }
+
reqkey = __generate_reqkey(pkgid);
- if (reqkey == NULL)
+ if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
+ free(pkgtype);
return -1;
+ }
snprintf(buf, sizeof(buf), "%d", move_type);
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_MOVE, pkgtype,
- pkgid, buf)) {
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_MOVE,
+ pkgtype, pkgid, buf)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
free(reqkey);
+ free(pkgtype);
return -1;
}
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_OK, reqkey));
free(reqkey);
+ free(pkgtype);
return 0;
}
-static int __handle_request_enable_pkg(uid_t uid,
+static int __handle_request_enable_pkgs(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
- char *pkgid = NULL;
+ char *pkgtype;
+ char *pkgid;
+ char *reqkey;
+ GVariantIter *iter;
- g_variant_get(parameters, "(u&s&s)", &target_uid, &pkgtype, &pkgid);
- if (target_uid == (uid_t)-1 || pkgid == NULL) {
+ g_variant_get(parameters, "(uas)", &target_uid, &iter);
+ if (target_uid == (uid_t)-1 || iter == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ECOMM));
+ g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
return -1;
}
- if (_pm_queue_push(target_uid, "", PKGMGR_REQUEST_TYPE_ENABLE_PKG, pkgtype,
- pkgid, "")) {
+ reqkey = __generate_reqkey("enable_pkgs");
+ if (reqkey == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ESYSTEM));
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
return -1;
}
+ while (g_variant_iter_next(iter, "&s", &pkgid)) {
+ pkgtype = _get_pkgtype_from_pkgid(pkgid, target_uid);
+ if (pkgtype == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)",
+ PKGMGR_R_ESYSTEM, ""));
+ free(reqkey);
+ return -1;
+ }
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_ENABLE_PKG,
+ pkgtype, pkgid, NULL)) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)",
+ PKGMGR_R_ESYSTEM, ""));
+ free(pkgtype);
+ free(reqkey);
+ return -1;
+ }
+ free(pkgtype);
+ }
+
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_OK));
+ g_variant_new("(is)", PKGMGR_R_OK, reqkey));
+ free(reqkey);
return 0;
}
-static int __handle_request_disable_pkg(uid_t uid,
+static int __handle_request_disable_pkgs(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
- char *pkgid = NULL;
+ char *pkgtype;
+ char *pkgid;
+ char *reqkey;
+ GVariantIter *iter;
- g_variant_get(parameters, "(u&s&s)", &target_uid, &pkgtype, &pkgid);
- if (target_uid == (uid_t)-1 || pkgid == NULL) {
+ g_variant_get(parameters, "(uas)", &target_uid, &iter);
+ if (target_uid == (uid_t)-1 || iter == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ECOMM));
+ g_variant_new("(is)", PKGMGR_R_ECOMM, ""));
return -1;
}
- if (_pm_queue_push(target_uid, "", PKGMGR_REQUEST_TYPE_DISABLE_PKG, pkgtype,
- pkgid, "")) {
+ reqkey = __generate_reqkey("disable_pkgs");
+ if (reqkey == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ESYSTEM));
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
return -1;
}
+ while (g_variant_iter_next(iter, "&s", &pkgid)) {
+ pkgtype = _get_pkgtype_from_pkgid(pkgid, target_uid);
+ if (pkgtype == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)",
+ PKGMGR_R_ESYSTEM, ""));
+ free(reqkey);
+ return -1;
+ }
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_DISABLE_PKG,
+ pkgtype, pkgid, NULL)) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)",
+ PKGMGR_R_ESYSTEM, ""));
+ free(pkgtype);
+ free(reqkey);
+ return -1;
+ }
+ free(pkgtype);
+ }
+
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_OK));
+ g_variant_new("(is)", PKGMGR_R_OK, reqkey));
+ free(reqkey);
return 0;
}
-static int __handle_request_enable_app(uid_t uid,
+static int __handle_request_enable_app(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
reqkey = __generate_reqkey(appid);
if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
ret = -1;
goto catch;
}
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_ENABLE_APP, "default",
- appid, "")) {
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_ENABLE_APP, "default",
+ appid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
ret = -1;
ret = 0;
catch:
- if(reqkey)
+ if (reqkey)
free(reqkey);
return ret;
}
-static int __handle_request_disable_app(uid_t uid,
+static int __handle_request_disable_app(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
reqkey = __generate_reqkey(appid);
if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
ret = -1;
goto catch;
}
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_DISABLE_APP, "default",
- appid, "")) {
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_DISABLE_APP, "default",
+ appid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
ret = -1;
return ret;
}
-static int __handle_request_enable_global_app_for_uid(uid_t uid,
+static int __handle_request_enable_global_app_for_uid(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
reqkey = __generate_reqkey(appid);
if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
ret = -1;
goto catch;
}
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_ENABLE_GLOBAL_APP_FOR_UID, "default",
- appid, "")) {
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_ENABLE_GLOBAL_APP_FOR_UID,
+ "default", appid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
ret = -1;
return ret;
}
-static int __handle_request_disable_global_app_for_uid(uid_t uid,
+static int __handle_request_disable_global_app_for_uid(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
reqkey = __generate_reqkey(appid);
if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
ret = -1;
goto catch;
}
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_DISABLE_GLOBAL_APP_FOR_UID, "default",
- appid, "")) {
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_DISABLE_GLOBAL_APP_FOR_UID,
+ "default", appid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
ret = -1;
return ret;
}
-static int __handle_request_getsize(uid_t uid,
+static int __handle_request_getsize(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
}
reqkey = __generate_reqkey(pkgid);
- if (reqkey == NULL)
+ if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(is)", PKGMGR_R_ENOMEM, ""));
return -1;
+ }
snprintf(buf, sizeof(buf), "%d", get_type);
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_GETSIZE, "pkgtool",
- pkgid, buf)) {
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_GETSIZE,
+ "pkgtool", pkgid, buf)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(is)", PKGMGR_R_ESYSTEM, ""));
free(reqkey);
return 0;
}
-static int __handle_request_cleardata(uid_t uid,
+static int __handle_request_cleardata(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
- char *pkgtype = NULL;
+ char *pkgtype;
char *pkgid = NULL;
char *reqkey = NULL;
- g_variant_get(parameters, "(u&s&s)", &target_uid, &pkgtype, &pkgid);
- if (target_uid == (uid_t)-1 || pkgtype == NULL || pkgid == NULL) {
+ g_variant_get(parameters, "(u&s)", &target_uid, &pkgid);
+ if (target_uid == (uid_t)-1 || pkgid == NULL) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ECOMM));
return -1;
}
+ pkgtype = _get_pkgtype_from_pkgid(pkgid, target_uid);
+ if (pkgtype == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(i)", PKGMGR_R_ESYSTEM));
+ return -1;
+ }
+
reqkey = __generate_reqkey(pkgid);
- if (reqkey == NULL)
+ if (reqkey == NULL) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(i)", PKGMGR_R_ENOMEM));
+ free(pkgtype);
return -1;
+ }
- if (_pm_queue_push(target_uid, reqkey, PKGMGR_REQUEST_TYPE_CLEARDATA, pkgtype,
- pkgid, "")) {
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_CLEARDATA,
+ pkgtype, pkgid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ESYSTEM));
free(reqkey);
+ free(pkgtype);
return -1;
}
g_variant_new("(i)", PKGMGR_R_OK));
free(reqkey);
+ free(pkgtype);
return 0;
}
-static int __handle_request_clearcache(uid_t uid,
+static int __handle_request_clearcache(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
return -1;
}
- if (_pm_queue_push(target_uid, "", PKGMGR_REQUEST_TYPE_CLEARCACHE,
- "pkgtool", pkgid, "")) {
+ if (_push_queue(target_uid, caller_uid, NULL, REQUEST_TYPE_CLEARCACHE,
+ "pkgtool", pkgid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ESYSTEM));
return -1;
return 0;
}
-static int __handle_request_kill(uid_t uid,
+static int __handle_request_kill(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
char *pkgid = NULL;
+ char *reqkey = NULL;
g_variant_get(parameters, "(u&s)", &target_uid, &pkgid);
if (target_uid == (uid_t)-1 || pkgid == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ECOMM));
+ g_variant_new("(ii)", PKGMGR_R_ECOMM, 0));
return -1;
}
- if (_pm_queue_push(target_uid, "", PKGMGR_REQUEST_TYPE_KILL, "default",
- pkgid, "")) {
+ reqkey = __generate_reqkey(pkgid);
+ if (reqkey == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ESYSTEM));
+ g_variant_new("(ii)", PKGMGR_R_ENOMEM, 0));
return -1;
}
- g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_OK));
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_KILL,
+ "default", pkgid, NULL)) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(ii)", PKGMGR_R_ESYSTEM, 0));
+ free(reqkey);
+ return -1;
+ }
+
+ if (!g_hash_table_insert(req_table, (gpointer)reqkey,
+ (gpointer)invocation))
+ ERR("reqkey already exists");
return 0;
}
-static int __handle_request_check(uid_t uid,
+static int __handle_request_check(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
char *pkgid = NULL;
+ char *reqkey = NULL;
g_variant_get(parameters, "(u&s)", &target_uid, &pkgid);
if (target_uid == (uid_t)-1 || pkgid == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ECOMM));
+ g_variant_new("(ii)", PKGMGR_R_ECOMM, 0));
return -1;
}
- if (_pm_queue_push(target_uid, "", PKGMGR_REQUEST_TYPE_CHECK, "default",
- pkgid, "")) {
+ reqkey = __generate_reqkey(pkgid);
+ if (reqkey == NULL) {
g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_ESYSTEM));
+ g_variant_new("(ii)", PKGMGR_R_ENOMEM, 0));
return -1;
}
- g_dbus_method_invocation_return_value(invocation,
- g_variant_new("(i)", PKGMGR_R_OK));
+ if (_push_queue(target_uid, caller_uid, reqkey, REQUEST_TYPE_CHECK,
+ "default", pkgid, NULL)) {
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(ii)", PKGMGR_R_ESYSTEM, 0));
+ free(reqkey);
+ return -1;
+ }
+
+ if (!g_hash_table_insert(req_table, (gpointer)reqkey,
+ (gpointer)invocation))
+ ERR("reqkey already exists");
return 0;
}
-static int __handle_request_generate_license_request(uid_t uid,
+static int __handle_request_generate_license_request(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
char *reqkey;
return -1;
}
- if (_pm_queue_push(uid, reqkey,
- PKGMGR_REQUEST_TYPE_GENERATE_LICENSE_REQUEST,
- "default", "", resp_data)) {
+ if (_push_queue(caller_uid, caller_uid, reqkey,
+ REQUEST_TYPE_GENERATE_LICENSE_REQUEST,
+ "default", NULL, resp_data)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(iss)", PKGMGR_R_ESYSTEM, "",
""));
return 0;
}
-static int __handle_request_register_license(uid_t uid,
+static int __handle_request_register_license(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
char *reqkey;
return -1;
}
- if (_pm_queue_push(uid, reqkey, PKGMGR_REQUEST_TYPE_REGISTER_LICENSE,
- "default", "", resp_data)) {
+ if (_push_queue(caller_uid, caller_uid, reqkey,
+ REQUEST_TYPE_REGISTER_LICENSE,
+ "default", NULL, resp_data)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ESYSTEM));
free(reqkey);
return 0;
}
-static int __handle_request_decrypt_package(uid_t uid,
+static int __handle_request_decrypt_package(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
char *reqkey;
return -1;
}
- if (_pm_queue_push(uid, reqkey, PKGMGR_REQUEST_TYPE_DECRYPT_PACKAGE,
- "default", drm_file_path, decrypted_file_path)) {
+ if (_push_queue(caller_uid, caller_uid, reqkey,
+ REQUEST_TYPE_DECRYPT_PACKAGE,
+ "default", drm_file_path,
+ decrypted_file_path)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ESYSTEM));
free(reqkey);
return 0;
}
-static int __update_app_splash_screen(uid_t uid,
+static int __update_app_splash_screen(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters,
int req_type)
{
reqkey = __generate_reqkey(appid);
if (reqkey == NULL) {
ERR("Failed to generate request key");
+ g_dbus_method_invocation_return_value(invocation,
+ g_variant_new("(i)", PKGMGR_R_ENOMEM));
return -1;
}
- if (_pm_queue_push(target_uid, reqkey, req_type, "default",
- appid, "")) {
+ if (_push_queue(target_uid, caller_uid, reqkey, req_type, "default",
+ appid, NULL)) {
ERR("Failed to push request");
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ESYSTEM));
return 0;
}
-static int __handle_request_enable_app_splash_screen(uid_t uid,
+static int __handle_request_enable_app_splash_screen(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
- return __update_app_splash_screen(uid, invocation, parameters,
- PKGMGR_REQUEST_TYPE_ENABLE_APP_SPLASH_SCREEN);
+ return __update_app_splash_screen(caller_uid, invocation, parameters,
+ REQUEST_TYPE_ENABLE_APP_SPLASH_SCREEN);
}
-static int __handle_request_disable_app_splash_screen(uid_t uid,
+static int __handle_request_disable_app_splash_screen(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
- return __update_app_splash_screen(uid, invocation, parameters,
- PKGMGR_REQUEST_TYPE_DISABLE_APP_SPLASH_SCREEN);
+ return __update_app_splash_screen(caller_uid, invocation, parameters,
+ REQUEST_TYPE_DISABLE_APP_SPLASH_SCREEN);
}
-static int __handle_request_set_restriction_mode(uid_t uid,
+static int __handle_request_set_restriction_mode(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
}
snprintf(buf, sizeof(buf), "%d", mode);
- if (_pm_queue_push(target_uid, reqkey,
- PKGMGR_REQUEST_TYPE_SET_RESTRICTION_MODE,
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_SET_RESTRICTION_MODE,
"default", pkgid, buf)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ESYSTEM));
return 0;
}
-static int __handle_request_unset_restriction_mode(uid_t uid,
+static int __handle_request_unset_restriction_mode(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
}
snprintf(buf, sizeof(buf), "%d", mode);
- if (_pm_queue_push(target_uid, reqkey,
- PKGMGR_REQUEST_TYPE_UNSET_RESTRICTION_MODE,
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_UNSET_RESTRICTION_MODE,
"default", pkgid, buf)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(i)", PKGMGR_R_ESYSTEM));
return 0;
}
-static int __handle_request_get_restriction_mode(uid_t uid,
+static int __handle_request_get_restriction_mode(uid_t caller_uid,
GDBusMethodInvocation *invocation, GVariant *parameters)
{
uid_t target_uid = (uid_t)-1;
return -1;
}
- if (_pm_queue_push(target_uid, reqkey,
- PKGMGR_REQUEST_TYPE_GET_RESTRICTION_MODE,
- "default", pkgid, "")) {
+ if (_push_queue(target_uid, caller_uid, reqkey,
+ REQUEST_TYPE_GET_RESTRICTION_MODE,
+ "default", pkgid, NULL)) {
g_dbus_method_invocation_return_value(invocation,
g_variant_new("(ii)", -1, PKGMGR_R_ESYSTEM));
free(reqkey);
if (g_strcmp0(method_name, "install") == 0)
ret = __handle_request_install(uid, invocation, parameters);
else if (g_strcmp0(method_name, "mount_install") == 0)
- ret = __handle_request_mount_install(uid, invocation, parameters);
+ ret = __handle_request_mount_install(uid, invocation,
+ parameters);
else if (g_strcmp0(method_name, "reinstall") == 0)
ret = __handle_request_reinstall(uid, invocation, parameters);
else if (g_strcmp0(method_name, "uninstall") == 0)
ret = __handle_request_cleardata(uid, invocation, parameters);
else if (g_strcmp0(method_name, "move") == 0)
ret = __handle_request_move(uid, invocation, parameters);
- else if (g_strcmp0(method_name, "enable_pkg") == 0)
- ret = __handle_request_enable_pkg(uid, invocation, parameters);
- else if (g_strcmp0(method_name, "disable_pkg") == 0)
- ret = __handle_request_disable_pkg(uid, invocation, parameters);
+ else if (g_strcmp0(method_name, "enable_pkgs") == 0)
+ ret = __handle_request_enable_pkgs(uid, invocation, parameters);
+ else if (g_strcmp0(method_name, "disable_pkgs") == 0)
+ ret = __handle_request_disable_pkgs(uid, invocation, parameters);
else if (g_strcmp0(method_name, "getsize") == 0)
ret = __handle_request_getsize(uid, invocation, parameters);
else if (g_strcmp0(method_name, "clearcache") == 0)
else if (g_strcmp0(method_name, "disable_app") == 0)
ret = __handle_request_disable_app(uid, invocation, parameters);
else if (g_strcmp0(method_name, "enable_global_app_for_uid") == 0)
- ret = __handle_request_enable_global_app_for_uid(uid, invocation, parameters);
+ ret = __handle_request_enable_global_app_for_uid(uid,
+ invocation, parameters);
else if (g_strcmp0(method_name, "disable_global_app_for_uid") == 0)
- ret = __handle_request_disable_global_app_for_uid(uid, invocation, parameters);
+ ret = __handle_request_disable_global_app_for_uid(uid,
+ invocation, parameters);
else if (g_strcmp0(method_name, "kill") == 0)
ret = __handle_request_kill(uid, invocation, parameters);
else if (g_strcmp0(method_name, "check") == 0)
g_idle_add(queue_job, NULL);
}
-int __return_value_to_caller(const char *req_key, GVariant *result)
+int _return_value_to_caller(const char *req_key, GVariant *result)
{
GDBusMethodInvocation *invocation;
return 0;
}
-static const GDBusInterfaceVTable interface_vtable =
-{
+static const GDBusInterfaceVTable interface_vtable = {
__handle_method_call,
NULL,
NULL,
DBG("on name lost: %s", name);
}
-int __init_request_handler(void)
+int _init_request_handler(void)
{
- instropection_data = g_dbus_node_info_new_for_xml(instropection_xml, NULL);
+ instropection_data = g_dbus_node_info_new_for_xml(instropection_xml,
+ NULL);
owner_id = g_bus_own_name(G_BUS_TYPE_SYSTEM, PKGMGR_DBUS_SERVICE,
G_BUS_NAME_OWNER_FLAGS_NONE, __on_bus_acquired,
return 0;
}
-void __fini_request_handler(void)
+void _fini_request_handler(void)
{
g_hash_table_destroy(req_table);
g_bus_unown_name(owner_id);