fix style
[platform/core/appfw/slp-pkgmgr.git] / client / src / pkgmgr.c
1 /*
2  * slp-pkgmgr
3  *
4  * Copyright (c) 2000 - 2011 Samsung Electronics Co., Ltd. All rights reserved.
5  *
6  * Contact: Jayoun Lee <airjany@samsung.com>, Sewook Park <sewook7.park@samsung.com>,
7  * Jaeho Lee <jaeho81.lee@samsung.com>, Shobhit Srivastava <shobhit.s@samsung.com>
8  *
9  * Licensed under the Apache License, Version 2.0 (the "License");
10  * you may not use this file except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  * http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  */
22
23 #include <stdio.h>
24 #include <stdlib.h>
25 #include <string.h>
26 #include <unistd.h>
27 #include <dlfcn.h>
28 #include <dirent.h>
29 #include <fcntl.h>
30 #include <sys/wait.h>
31 #include <sys/time.h>
32
33 #include <glib.h>
34
35 #include <pkgmgr-info.h>
36 #include <iniparser.h>
37 /* For multi-user support */
38 #include <tzplatform_config.h>
39
40 #include "package-manager.h"
41 #include "pkgmgr-internal.h"
42 #include "pkgmgr-debug.h"
43 #include "comm_client.h"
44 #include "comm_config.h"
45
46 /* API export macro */
47 #ifndef API
48 #define API __attribute__ ((visibility("default")))
49 #endif
50
51 #define PKG_TMP_PATH tzplatform_mkpath(TZ_USER_APP, "tmp")
52
53 #define BINSH_NAME      "/bin/sh"
54 #define BINSH_SIZE      7
55
56 #define GLOBAL_USER tzplatform_getuid(TZ_SYS_GLOBALAPP_USER)
57 #define REGULAR_USER 5000
58
59 static inline uid_t _getuid(void)
60 {
61         uid_t uid = getuid();
62
63         if (uid < REGULAR_USER)
64                 return GLOBAL_USER;
65         else
66                 return uid;
67 }
68
69 static int _get_request_id()
70 {
71         static int internal_req_id = 1;
72
73         return internal_req_id++;
74 }
75
76 typedef struct _req_cb_info {
77         int request_id;
78         char *req_key;
79         pkgmgr_handler event_cb;
80         pkgmgr_app_handler app_event_cb;
81         void *data;
82         struct _req_cb_info *next;
83 } req_cb_info;
84
85 typedef struct _listen_cb_info {
86         int request_id;
87         pkgmgr_handler event_cb;
88         pkgmgr_app_handler app_event_cb;
89         void *data;
90         struct _listen_cb_info *next;
91 } listen_cb_info;
92
93 typedef struct _pkgmgr_client_t {
94         client_type ctype;
95         int status_type;
96         union {
97                 struct _request {
98                         comm_client *cc;
99                         req_cb_info *rhead;
100                 } request;
101                 struct _listening {
102                         comm_client *cc;
103                         listen_cb_info *lhead;
104                 } listening;
105         } info;
106         void *new_event_cb;
107         char *tep_path;
108         char *tep_move;
109 } pkgmgr_client_t;
110
111 typedef struct _iter_data {
112         pkgmgr_iter_fn iter_fn;
113         void *data;
114 } iter_data;
115
116 static int __xsystem(const char *argv[])
117 {
118         int status = 0;
119         pid_t pid;
120         pid = fork();
121         switch (pid) {
122         case -1:
123                 perror("fork failed");
124                 return -1;
125         case 0:
126                 /* child */
127                 execvp(argv[0], (char *const *)argv);
128                 _exit(-1);
129         default:
130                 /* parent */
131                 break;
132         }
133         if (waitpid(pid, &status, 0) == -1) {
134                 perror("waitpid failed");
135                 return -1;
136         }
137         if (WIFSIGNALED(status)) {
138                 perror("signal");
139                 return -1;
140         }
141         if (!WIFEXITED(status)) {
142                 /* shouldn't happen */
143                 perror("should not happen");
144                 return -1;
145         }
146         return WEXITSTATUS(status);
147 }
148
149 static void __error_to_string(int errnumber, char **errstr)
150 {
151         if (errstr == NULL)
152                 return;
153         switch (errnumber) {
154         case PKGCMD_ERR_PACKAGE_NOT_FOUND:
155                 *errstr = PKGCMD_ERR_PACKAGE_NOT_FOUND_STR;
156                 break;
157         case PKGCMD_ERR_PACKAGE_INVALID:
158                 *errstr = PKGCMD_ERR_PACKAGE_INVALID_STR;
159                 break;
160         case PKGCMD_ERR_PACKAGE_LOWER_VERSION:
161                 *errstr = PKGCMD_ERR_PACKAGE_LOWER_VERSION_STR;
162                 break;
163         case PKGCMD_ERR_PACKAGE_EXECUTABLE_NOT_FOUND:
164                 *errstr = PKGCMD_ERR_PACKAGE_EXECUTABLE_NOT_FOUND_STR;
165                 break;
166         case PKGCMD_ERR_MANIFEST_INVALID:
167                 *errstr = PKGCMD_ERR_MANIFEST_INVALID_STR;
168                 break;
169         case PKGCMD_ERR_CONFIG_NOT_FOUND:
170                 *errstr = PKGCMD_ERR_CONFIG_NOT_FOUND_STR;
171                 break;
172         case PKGCMD_ERR_CONFIG_INVALID:
173                 *errstr = PKGCMD_ERR_CONFIG_INVALID_STR;
174                 break;
175         case PKGCMD_ERR_SIGNATURE_NOT_FOUND:
176                 *errstr = PKGCMD_ERR_SIGNATURE_NOT_FOUND_STR;
177                 break;
178         case PKGCMD_ERR_SIGNATURE_INVALID:
179                 *errstr = PKGCMD_ERR_SIGNATURE_INVALID_STR;
180                 break;
181         case PKGCMD_ERR_SIGNATURE_VERIFICATION_FAILED:
182                 *errstr = PKGCMD_ERR_SIGNATURE_VERIFICATION_FAILED_STR;
183                 break;
184         case PKGCMD_ERR_ROOT_CERTIFICATE_NOT_FOUND:
185                 *errstr = PKGCMD_ERR_ROOT_CERTIFICATE_NOT_FOUND_STR;
186                 break;
187         case PKGCMD_ERR_CERTIFICATE_INVALID:
188                 *errstr = PKGCMD_ERR_CERTIFICATE_INVALID_STR;
189                 break;
190         case PKGCMD_ERR_CERTIFICATE_CHAIN_VERIFICATION_FAILED:
191                 *errstr = PKGCMD_ERR_CERTIFICATE_CHAIN_VERIFICATION_FAILED_STR;
192                 break;
193         case PKGCMD_ERR_CERTIFICATE_EXPIRED:
194                 *errstr = PKGCMD_ERR_CERTIFICATE_EXPIRED_STR;
195                 break;
196         case PKGCMD_ERR_INVALID_PRIVILEGE:
197                 *errstr = PKGCMD_ERR_INVALID_PRIVILEGE_STR;
198                 break;
199         case PKGCMD_ERR_MENU_ICON_NOT_FOUND:
200                 *errstr = PKGCMD_ERR_MENU_ICON_NOT_FOUND_STR;
201                 break;
202         case PKGCMD_ERR_FATAL_ERROR:
203                 *errstr = PKGCMD_ERR_FATAL_ERROR_STR;
204                 break;
205         case PKGCMD_ERR_OUT_OF_STORAGE:
206                 *errstr = PKGCMD_ERR_OUT_OF_STORAGE_STR;
207                 break;
208         case PKGCMD_ERR_OUT_OF_MEMORY:
209                 *errstr = PKGCMD_ERR_OUT_OF_MEMORY_STR;
210                 break;
211         case PKGCMD_ERR_ARGUMENT_INVALID:
212                 *errstr = PKGCMD_ERR_ARGUMENT_INVALID_STR;
213                 break;
214         default:
215                 *errstr = PKGCMD_ERR_UNKNOWN_STR;
216                 break;
217         }
218 }
219
220 static void __add_op_cbinfo(pkgmgr_client_t *pc, int request_id,
221                             const char *req_key, pkgmgr_handler event_cb, void *new_event_cb,
222                             void *data)
223 {
224         req_cb_info *cb_info;
225         req_cb_info *current;
226         req_cb_info *prev;
227
228         cb_info = (req_cb_info *) calloc(1, sizeof(req_cb_info));
229         if (cb_info == NULL) {
230                 DBG("calloc failed");
231                 return;
232         }
233         cb_info->request_id = request_id;
234         cb_info->req_key = strdup(req_key);
235         cb_info->event_cb = event_cb;
236         cb_info->data = data;
237         cb_info->next = NULL;
238         cb_info->app_event_cb = NULL;
239         pc->new_event_cb = new_event_cb;
240
241         if (pc->info.request.rhead == NULL)
242                 pc->info.request.rhead = cb_info;
243         else {
244                 current = prev = pc->info.request.rhead;
245                 while (current) {
246                         prev = current;
247                         current = current->next;
248                 }
249
250                 prev->next = cb_info;
251         }
252 }
253
254 static void __add_op_app_cbinfo(pkgmgr_client_t *pc, int request_id,
255                             const char *req_key, pkgmgr_app_handler app_event_cb, void *data)
256 {
257         req_cb_info *cb_info;
258         req_cb_info *current;
259         req_cb_info *prev;
260
261         cb_info = (req_cb_info *) calloc(1, sizeof(req_cb_info));
262         if (cb_info == NULL) {
263                 DBG("calloc failed");
264                 return;
265         }
266         cb_info->request_id = request_id;
267         cb_info->req_key = strdup(req_key);
268         cb_info->event_cb = NULL;
269         cb_info->app_event_cb = app_event_cb;
270         cb_info->data = data;
271         cb_info->next = NULL;
272         pc->new_event_cb = NULL;
273
274         if (pc->info.request.rhead == NULL)
275                 pc->info.request.rhead = cb_info;
276         else {
277                 current = prev = pc->info.request.rhead;
278                 while (current) {
279                         prev = current;
280                         current = current->next;
281                 }
282
283                 prev->next = cb_info;
284         }
285 }
286
287 static req_cb_info *__find_op_cbinfo(pkgmgr_client_t *pc, const char *req_key)
288 {
289         req_cb_info *tmp;
290
291         tmp = pc->info.request.rhead;
292
293         if (tmp == NULL) {
294                 ERR("tmp is NULL");
295                 return NULL;
296         }
297
298         DBG("tmp->req_key %s, req_key %s", tmp->req_key, req_key);
299
300         while (tmp) {
301                 if (strncmp(tmp->req_key, req_key, strlen(tmp->req_key)) == 0)
302                         return tmp;
303                 tmp = tmp->next;
304         }
305         return NULL;
306 }
307
308 static int __remove_stat_cbinfo(pkgmgr_client_t *pc)
309 {
310         listen_cb_info *info = pc->info.listening.lhead;
311         listen_cb_info *next = NULL;
312
313         while (info != NULL) {
314                 next = info->next;
315                 free(info);
316                 info = next;
317         }
318
319         pc->info.listening.lhead = NULL;
320         return 0;
321 }
322
323 static void __add_app_stat_cbinfo(pkgmgr_client_t *pc, int request_id,
324                               pkgmgr_app_handler event_cb, void *data)
325 {
326         listen_cb_info *cb_info;
327         listen_cb_info *current;
328         listen_cb_info *prev;
329
330         cb_info = (listen_cb_info *) calloc(1, sizeof(listen_cb_info));
331         if (cb_info == NULL) {
332                 DBG("calloc failed");
333                 return;
334         }
335         cb_info->request_id = request_id;
336         cb_info->app_event_cb = event_cb;
337         cb_info->data = data;
338         cb_info->next = NULL;
339
340         if (pc->info.listening.lhead == NULL)
341                 pc->info.listening.lhead = cb_info;
342         else {
343                 current = prev = pc->info.listening.lhead;
344                 while (current) {
345                         prev = current;
346                         current = current->next;
347                 }
348
349                 prev->next = cb_info;
350         }
351 }
352
353 static void __add_stat_cbinfo(pkgmgr_client_t *pc, int request_id,
354                               pkgmgr_handler event_cb, void *data)
355 {
356         listen_cb_info *cb_info;
357         listen_cb_info *current;
358         listen_cb_info *prev;
359
360         cb_info = (listen_cb_info *) calloc(1, sizeof(listen_cb_info));
361         if (cb_info == NULL) {
362                 DBG("calloc failed");
363                 return;
364         }
365         cb_info->request_id = request_id;
366         cb_info->event_cb = event_cb;
367         cb_info->data = data;
368         cb_info->next = NULL;
369
370         /* TODO - check the order of callback - FIFO or LIFO => Should be changed to LIFO */
371         if (pc->info.listening.lhead == NULL)
372                 pc->info.listening.lhead = cb_info;
373         else {
374                 current = prev = pc->info.listening.lhead;
375                 while (current) {
376                         prev = current;
377                         current = current->next;
378                 }
379
380                 prev->next = cb_info;
381         }
382 }
383
384 static void __operation_callback(void *cb_data, uid_t target_uid,
385                                  const char *req_id, const char *pkg_type,
386                                  const char *pkgid,  const char *appid,
387                                  const char *key,    const char *val)
388 {
389         pkgmgr_client_t *pc;
390         req_cb_info *cb_info;
391
392         pc = (pkgmgr_client_t *) cb_data;
393
394         /* find callback info */
395         cb_info = __find_op_cbinfo(pc, req_id);
396         if (cb_info == NULL) {
397                 ERR("cannot find cb_info for req_id:%s", req_id);
398                 return;
399         }
400
401         /* call callback */
402         if (appid != NULL && strlen(appid) != 0 && cb_info->app_event_cb) {
403                 /* run app callback */
404                 if (pc->new_event_cb)
405                         cb_info->app_event_cb(target_uid, cb_info->request_id,
406                                         pkg_type, pkgid, appid, key, val, pc,
407                                         cb_info->data);
408                 else
409                         cb_info->app_event_cb(target_uid, cb_info->request_id,
410                                         pkg_type, pkgid, appid, key, val, NULL,
411                                         cb_info->data);
412         } else if (cb_info->event_cb) {
413                 /* run pkg callback */
414                 if (pc->new_event_cb)
415                         cb_info->event_cb(target_uid, cb_info->request_id,
416                                         pkg_type, pkgid, key, val, pc,
417                                         cb_info->data);
418                 else
419                         cb_info->event_cb(target_uid, cb_info->request_id,
420                                         pkg_type, pkgid, key, val, NULL,
421                                         cb_info->data);
422         }
423
424         return;
425 }
426
427 static void __status_callback(void *cb_data, uid_t target_uid,
428                               const char *req_id, const char *pkg_type,
429                               const char *pkgid,  const char *appid,
430                               const char *key,    const char *val)
431 {
432         pkgmgr_client_t *pc;
433         listen_cb_info *tmp;
434
435         pc = (pkgmgr_client_t *) cb_data;
436
437         tmp = pc->info.listening.lhead;
438         while (tmp) {
439                 if (appid != NULL && strlen(appid) != 0) {
440                         /* run app callback */
441                         if (tmp->app_event_cb && tmp->app_event_cb(
442                                         target_uid, tmp->request_id, pkg_type, pkgid,
443                                         appid, key, val, NULL, tmp->data) != 0)
444                                 break;
445                 } else {
446                         /* run pkg callback */
447                         if (tmp->event_cb && tmp->event_cb(
448                                 target_uid, tmp->request_id, pkg_type, pkgid,
449                                 key, val, NULL, tmp->data) != 0)
450                                 break;
451                 }
452                 tmp = tmp->next;
453         }
454
455         return;
456 }
457
458 static inline int __read_proc(const char *path, char *buf, int size)
459 {
460         int fd = 0;
461         int ret = 0;
462
463         if (buf == NULL || path == NULL)
464                 return -1;
465
466         fd = open(path, O_RDONLY);
467         if (fd < 0)
468                 return -1;
469
470         ret = read(fd, buf, size - 1);
471         if (ret <= 0) {
472                 close(fd);
473                 return -1;
474         } else
475                 buf[ret] = 0;
476
477         close(fd);
478
479         return ret;
480 }
481
482 char *__proc_get_cmdline_bypid(int pid)
483 {
484         char buf[PKG_STRING_LEN_MAX] = {'\0', };
485         int ret = 0;
486
487         snprintf(buf, sizeof(buf), "/proc/%d/cmdline", pid);
488         ret = __read_proc(buf, buf, sizeof(buf));
489         if (ret <= 0)
490                 return NULL;
491
492         /* support app launched by shell script*/
493         if (strncmp(buf, BINSH_NAME, BINSH_SIZE) == 0)
494                 return strdup(&buf[BINSH_SIZE + 1]);
495         else
496                 return strdup(buf);
497 }
498
499 static inline int __pkgmgr_read_proc(const char *path, char *buf, int size)
500 {
501         int fd;
502         int ret;
503
504         if (buf == NULL || path == NULL)
505                 return -1;
506
507         fd = open(path, O_RDONLY);
508         if (fd < 0)
509                 return -1;
510
511         ret = read(fd, buf, size - 1);
512         if (ret <= 0) {
513                 close(fd);
514                 return -1;
515         } else
516                 buf[ret] = 0;
517
518         close(fd);
519
520         return ret;
521 }
522
523 static int __sync_process(const char *req_key)
524 {
525         int ret;
526         char info_file[PKG_STRING_LEN_MAX] = {'\0', };
527         int result = -1;
528         int check_cnt = 0;
529         FILE *fp;
530         char buf[PKG_STRING_LEN_MAX] = {0, };
531
532         snprintf(info_file, PKG_STRING_LEN_MAX, "%s/%s", PKG_SIZE_INFO_PATH, req_key);
533         while (1) {
534                 check_cnt++;
535
536                 if (access(info_file, F_OK) == 0) {
537                         fp = fopen(info_file, "r");
538                         if (fp == NULL) {
539                                 DBG("file is not generated yet.... wait\n");
540                                 usleep(100 * 1000);     /* 100ms sleep*/
541                                 continue;
542                         }
543
544                         if (fgets(buf, PKG_STRING_LEN_MAX, fp) == NULL) {
545                                 ERR("failed to read info file");
546                                 fclose(fp);
547                                 break;
548                         }
549                         fclose(fp);
550
551                         DBG("info_file file is generated, result = %s. \n", buf);
552                         result = atoi(buf);
553                         break;
554                 }
555
556                 DBG("file is not generated yet.... wait\n");
557                 usleep(100 * 1000);     /* 100ms sleep*/
558
559                 if (check_cnt > 6000) { /* 60s * 10 time over*/
560                         ERR("wait time over!!\n");
561                         break;
562                 }
563         }
564
565         ret = remove(info_file);
566         if (ret < 0)
567                 ERR("file is can not remove[%s, %d]\n", info_file, ret);
568
569         return result;
570 }
571
572 static int __csc_process(const char *csc_path, char *result_path)
573 {
574         int ret = 0;
575         int cnt = 0;
576         int count = 0;
577         int csc_fail = 0;
578         int fd = 0;
579         char *pkgtype = NULL;
580         char *des = NULL;
581         char buf[PKG_STRING_LEN_MAX] = {0,};
582         char type_buf[1024] = { 0 };
583         char des_buf[1024] = { 0 };
584         dictionary *csc = NULL;
585         FILE *file = NULL;
586
587         csc = iniparser_load(csc_path);
588         retvm_if(csc == NULL, PKGMGR_R_EINVAL, "cannot open parse file [%s]", csc_path);
589
590         file = fopen(result_path, "w");
591         tryvm_if(file == NULL, ret = PKGMGR_R_EINVAL, "cannot open result file [%s]", result_path);
592
593         count = iniparser_getint(csc, "csc packages:count", -1);
594         tryvm_if(count == 0, ret = PKGMGR_R_ERROR, "csc [%s] dont have packages", csc_path);
595
596         snprintf(buf, PKG_STRING_LEN_MAX, "[result]\n");
597         fwrite(buf, 1, strlen(buf), file);
598         snprintf(buf, PKG_STRING_LEN_MAX, "count = %d\n", count);
599         fwrite(buf, 1, strlen(buf), file);
600
601         for (cnt = 1 ; cnt <= count ; cnt++) {
602                 snprintf(type_buf, PKG_STRING_LEN_MAX - 1, "csc packages:type_%03d", cnt);
603                 snprintf(des_buf, PKG_STRING_LEN_MAX - 1, "csc packages:description_%03d", cnt);
604
605                 pkgtype = iniparser_getstring(csc, type_buf, NULL);
606                 des = iniparser_getstring(csc, des_buf, NULL);
607                 ret = 0;
608
609                 if (pkgtype == NULL) {
610                         csc_fail++;
611                         snprintf(buf, PKG_STRING_LEN_MAX, "%s = Fail to get pkgtype\n", type_buf);
612                         fwrite(buf, 1, strlen(buf), file);
613                         continue;
614                 } else if (des == NULL) {
615                         csc_fail++;
616                         snprintf(buf, PKG_STRING_LEN_MAX, "%s = Fail to get description\n", des_buf);
617                         fwrite(buf, 1, strlen(buf), file);
618                         continue;
619                 }
620
621                 snprintf(buf, PKG_STRING_LEN_MAX, "type_%03d = %s\n", cnt, pkgtype);
622                 fwrite(buf, 1, strlen(buf), file);
623                 snprintf(buf, PKG_STRING_LEN_MAX, "description_%03d = %s\n", cnt, des);
624                 fwrite(buf, 1, strlen(buf), file);
625
626                 if (strcmp(pkgtype, "tpk") == 0) {
627                         const char *ospinstaller_argv[] = { "/usr/bin/osp-installer", "-c", des, NULL };
628                         ret = __xsystem(ospinstaller_argv);
629                 } else if (strcmp(pkgtype, "wgt") == 0) {
630                         const char *wrtinstaller_argv[] = { "/usr/bin/wrt-installer", "-c", des, NULL };
631                         ret = __xsystem(wrtinstaller_argv);
632                 } else {
633                         csc_fail++;
634                         ret = -1;
635                 }
636
637                 if (ret != 0) {
638                         char *errstr = NULL;
639                         __error_to_string(ret, &errstr);
640                         snprintf(buf, PKG_STRING_LEN_MAX, "result_%03d = fail[%s]\n", cnt, errstr);
641                 } else {
642                         snprintf(buf, PKG_STRING_LEN_MAX, "result_%03d = success\n", cnt);
643                 }
644
645                 fwrite(buf, 1, strlen(buf), file);
646         }
647
648 catch:
649         iniparser_freedict(csc);
650         if (file != NULL) {
651                 fflush(file);
652                 fd = fileno(file);
653                 fsync(fd);
654                 fclose(file);
655         }
656         return ret;
657 }
658
659 static int __get_size_process(pkgmgr_client *pc, const char *pkgid, uid_t uid,
660                 pkgmgr_getsize_type get_type, pkgmgr_handler event_cb,
661                 void *data)
662 {
663         GVariant *result;
664         int ret = PKGMGR_R_ECOMM;
665         char *req_key = NULL;
666         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
667
668         if (pc == NULL || pkgid == NULL) {
669                 ERR("invalid parameter");
670                 return PKGMGR_R_EINVAL;
671         }
672
673         if (mpc->ctype != PC_REQUEST) {
674                 ERR("mpc->ctype is not PC_REQUEST");
675                 return PKGMGR_R_EINVAL;
676         }
677
678         ret = comm_client_request(mpc->info.request.cc, "getsize",
679                         g_variant_new("(usi)", uid, pkgid, get_type), &result);
680         if (ret != PKGMGR_R_OK) {
681                 ERR("request failed: %d", ret);
682                 return ret;
683         }
684
685         g_variant_get(result, "(i&s)", &ret, &req_key);
686         if (req_key == NULL) {
687                 g_variant_unref(result);
688                 return PKGMGR_R_ECOMM;
689         }
690         if (ret != PKGMGR_R_OK) {
691                 g_variant_unref(result);
692                 return ret;
693         }
694
695         ret = __sync_process(req_key);
696         if (ret < 0)
697                 ERR("get size failed, ret=%d\n", ret);
698
699         g_variant_unref(result);
700
701         return ret;
702 }
703
704 static int __move_pkg_process(pkgmgr_client *pc, const char *pkgid,
705                 const char *pkg_type, uid_t uid, pkgmgr_move_type move_type,
706                 pkgmgr_handler event_cb, void *data)
707 {
708         int ret;
709
710         ret = pkgmgr_client_usr_move(pc, pkg_type, pkgid, move_type, event_cb, data, uid);
711         if (ret < 0) {
712                 ERR("move request failed");
713                 return ret;
714         }
715
716         return ret;
717 }
718
719 static int __check_app_process(pkgmgr_request_service_type service_type,
720                 pkgmgr_client *pc, const char *pkgid, uid_t uid, void *data)
721 {
722         GVariant *result;
723         int ret = PKGMGR_R_ECOMM;
724         pkgmgrinfo_pkginfo_h handle;
725         int pid = -1;
726         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
727
728         retvm_if(mpc->ctype != PC_REQUEST, PKGMGR_R_EINVAL, "mpc->ctype is not PC_REQUEST\n");
729
730         if (uid != GLOBAL_USER)
731                 ret = pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, uid, &handle);
732         else
733                 ret = pkgmgrinfo_pkginfo_get_pkginfo(pkgid, &handle);
734         retvm_if(ret < 0, PKGMGR_R_ERROR, "pkgmgrinfo_pkginfo_get_pkginfo failed");
735
736         if (service_type == PM_REQUEST_KILL_APP)
737                 ret = comm_client_request(mpc->info.request.cc, "kill",
738                                 g_variant_new("(us)", uid, pkgid), &result);
739         else if (service_type == PM_REQUEST_CHECK_APP)
740                 ret = comm_client_request(mpc->info.request.cc, "check",
741                                 g_variant_new("(us)", uid, pkgid), &result);
742         if (ret != PKGMGR_R_OK) {
743                 ERR("request failed: %d", ret);
744                 return ret;
745         }
746
747         g_variant_get(result, "(i)", &ret);
748         g_variant_unref(result);
749         if (ret != PKGMGR_R_OK) {
750                 ERR("request failed, ret=%d", ret);
751                 return ret;
752         }
753
754         /* FIXME */
755         pid  = __sync_process(pkgid);
756         *(int *)data = pid;
757
758         pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
759
760         return ret;
761
762 }
763
764 static int __request_size_info(pkgmgr_client *pc, uid_t uid)
765 {
766         GVariant *result;
767         int ret = PKGMGR_R_ECOMM;
768         char *req_key = NULL;
769         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
770
771         if (pc == NULL) {
772                 ERR("invalid parameter");
773                 return PKGMGR_R_EINVAL;
774         }
775
776         if (mpc->ctype != PC_REQUEST) {
777                 ERR("mpc->ctype is not PC_REQUEST");
778                 return PKGMGR_R_EINVAL;
779         }
780
781         ret = comm_client_request(mpc->info.request.cc, "getsize",
782                         g_variant_new("(usi)", uid, "size_info",
783                                 PM_GET_SIZE_INFO),
784                         &result);
785         if (ret != PKGMGR_R_OK) {
786                 ERR("request failed: %d", ret);
787                 return ret;
788         }
789
790         g_variant_get(result, "(i&s)", &ret, &req_key);
791         if (req_key == NULL) {
792                 g_variant_unref(result);
793                 return PKGMGR_R_ECOMM;
794         }
795
796         g_variant_unref(result);
797
798         return ret;
799 }
800
801 static int __change_op_cb_for_getsize(pkgmgr_client *pc)
802 {
803         int ret = -1;
804
805         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
806         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
807
808         /*  free listening head */
809         req_cb_info *tmp = NULL;
810         req_cb_info *prev = NULL;
811         for (tmp = mpc->info.request.rhead; tmp;) {
812                 prev = tmp;
813                 tmp = tmp->next;
814                 free(prev);
815         }
816
817         /* free dbus connection */
818         ret = comm_client_free(mpc->info.request.cc);
819         retvm_if(ret < 0, PKGMGR_R_ERROR, "comm_client_free() failed - %d", ret);
820
821         /* Manage pc for seperated event */
822         mpc->ctype = PC_REQUEST;
823         mpc->status_type = PKGMGR_CLIENT_STATUS_GET_SIZE;
824
825
826         mpc->info.request.cc = comm_client_new();
827         retvm_if(mpc->info.request.cc == NULL, PKGMGR_R_ERROR, "client creation failed");
828
829         ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_GET_SIZE, mpc->info.request.cc, __operation_callback, pc);
830         retvm_if(ret < 0, PKGMGR_R_ERROR, "set_status_callback() failed - %d", ret);
831
832         return PKGMGR_R_OK;
833 }
834
835 static int __change_op_cb_for_enable_disable(pkgmgr_client *pc, bool is_disable)
836 {
837         int ret = -1;
838
839         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
840         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
841
842         /*  free listening head */
843         req_cb_info *tmp = NULL;
844         req_cb_info *prev = NULL;
845         for (tmp = mpc->info.request.rhead; tmp;) {
846                 prev = tmp;
847                 tmp = tmp->next;
848                 free(prev);
849         }
850
851         /* free dbus connection */
852         ret = comm_client_free(mpc->info.request.cc);
853         retvm_if(ret < 0, PKGMGR_R_ERROR, "comm_client_free() failed - %d", ret);
854
855         /* Manage pc for seperated event */
856         mpc->ctype = PC_REQUEST;
857         if (is_disable)
858                 mpc->status_type = PKGMGR_CLIENT_STATUS_DISABLE_APP;
859         else
860                 mpc->status_type = PKGMGR_CLIENT_STATUS_ENABLE_APP;
861
862
863         mpc->info.request.cc = comm_client_new();
864         retvm_if(mpc->info.request.cc == NULL, PKGMGR_R_ERROR, "client creation failed");
865
866         if (is_disable)
867                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_DISABLE_APP, mpc->info.request.cc, __operation_callback, pc);
868         else
869                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ENABLE_APP, mpc->info.request.cc, __operation_callback, pc);
870         retvm_if(ret < 0, PKGMGR_R_ERROR, "set_status_callback() failed - %d", ret);
871
872         return PKGMGR_R_OK;
873 }
874
875 static int __get_pkg_size_info_cb(uid_t target_uid, int req_id, const char *req_type,
876                 const char *pkgid, const char *key,
877                 const char *value, const void *pc, void *user_data)
878 {
879         int ret = 0;
880         DBG("target_uid: %u, reqid: %d, req type: %s, pkgid: %s, unused key: %s, size info: %s",
881                         target_uid, req_id, req_type, pkgid, key, value);
882
883         pkg_size_info_t *size_info = (pkg_size_info_t *)malloc(sizeof(pkg_size_info_t));
884         retvm_if(size_info == NULL, -1, "The memory is insufficient.");
885
886         char *save_ptr = NULL;
887         char *token = strtok_r((char *)value, ":", &save_ptr);
888         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
889         size_info->data_size = atoll(token);
890         token = strtok_r(NULL, ":", &save_ptr);
891         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
892         size_info->cache_size = atoll(token);
893         token = strtok_r(NULL, ":", &save_ptr);
894         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
895         size_info->app_size = atoll(token);
896         token = strtok_r(NULL, ":", &save_ptr);
897         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
898         size_info->ext_data_size = atoll(token);
899         token = strtok_r(NULL, ":", &save_ptr);
900         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
901         size_info->ext_cache_size = atoll(token);
902         token = strtok_r(NULL, ":", &save_ptr);
903         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
904         size_info->ext_app_size = atoll(token);
905
906         DBG("data: %lld, cache: %lld, app: %lld, ext_data: %lld, ext_cache: %lld, ext_app: %lld",
907                         size_info->data_size, size_info->cache_size, size_info->app_size,
908                         size_info->ext_data_size, size_info->ext_cache_size, size_info->ext_app_size);
909
910         pkgmgr_client_t *pmc = (pkgmgr_client_t *)pc;
911         tryvm_if(pmc == NULL, ret = -1, "pkgmgr_client instance is null.");
912
913         if (strcmp(pkgid, PKG_SIZE_INFO_TOTAL) == 0) {  /* total package size info */
914                 pkgmgr_total_pkg_size_info_receive_cb callback = (pkgmgr_total_pkg_size_info_receive_cb)(pmc->new_event_cb);
915                 callback((pkgmgr_client *)pc, size_info, user_data);
916         } else {
917                 pkgmgr_pkg_size_info_receive_cb callback = (pkgmgr_pkg_size_info_receive_cb)(pmc->new_event_cb);
918                 callback((pkgmgr_client *)pc, pkgid, size_info, user_data);
919         }
920
921 catch:
922
923         if (size_info) {
924                 free(size_info);
925                 size_info = NULL;
926         }
927         return ret;
928 }
929
930 API pkgmgr_client *pkgmgr_client_new(client_type ctype)
931 {
932         pkgmgr_client_t *pc = NULL;
933         int ret = -1;
934
935         retvm_if(ctype == PC_BROADCAST, NULL, "broadcast type is not supported");
936         retvm_if(ctype != PC_REQUEST && ctype != PC_LISTENING, NULL, "ctype is not client_type");
937
938         /* Allocate memory for ADT:pkgmgr_client */
939         pc = calloc(1, sizeof(pkgmgr_client_t));
940         retvm_if(pc == NULL, NULL, "No memory");
941
942         /* Manage pc */
943         pc->ctype = ctype;
944         pc->status_type = PKGMGR_CLIENT_STATUS_ALL;
945         pc->tep_path = NULL;
946
947         if (pc->ctype == PC_REQUEST) {
948                 pc->info.request.cc = comm_client_new();
949                 trym_if(pc->info.request.cc == NULL, "client creation failed");
950
951                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ALL, pc->info.request.cc, __operation_callback, pc);
952                 trym_if(ret < 0L, "comm_client_set_status_callback() failed - %d", ret);
953         } else if (pc->ctype == PC_LISTENING) {
954                 pc->info.listening.cc = comm_client_new();
955                 trym_if(pc->info.listening.cc == NULL, "client creation failed");
956
957                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ALL, pc->info.listening.cc, __status_callback, pc);
958                 trym_if(ret < 0L, "comm_client_set_status_callback() failed - %d", ret);
959         }
960
961         return (pkgmgr_client *)pc;
962
963  catch:
964         if (pc)
965                 free(pc);
966         return NULL;
967 }
968
969 API int pkgmgr_client_free(pkgmgr_client *pc)
970 {
971         int ret = -1;
972         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
973         retvm_if(mpc == NULL, PKGMGR_R_EINVAL, "Invalid argument");
974
975         if (mpc->ctype == PC_REQUEST) {
976                 req_cb_info *tmp;
977                 req_cb_info *prev;
978                 for (tmp = mpc->info.request.rhead; tmp;) {
979                         prev = tmp;
980                         tmp = tmp->next;
981                         free(prev);
982                 }
983
984                 ret = comm_client_free(mpc->info.request.cc);
985                 tryvm_if(ret < 0, ret = PKGMGR_R_ERROR, "comm_client_free() failed");
986         } else if (mpc->ctype == PC_LISTENING) {
987                         listen_cb_info *tmp;
988                         listen_cb_info *prev;
989                         for (tmp = mpc->info.listening.lhead; tmp;) {
990                                 prev = tmp;
991                                 tmp = tmp->next;
992                                 free(prev);
993                         }
994
995                         ret = comm_client_free(mpc->info.listening.cc);
996                         tryvm_if(ret < 0, ret = PKGMGR_R_ERROR, "comm_client_free() failed");
997         } else if (mpc->ctype == PC_BROADCAST) {
998                 ret = 0;
999         } else {
1000                 ERR("Invalid client type\n");
1001                 return PKGMGR_R_EINVAL;
1002         }
1003
1004         if (mpc->tep_path) {
1005                 free(mpc->tep_path);
1006                 mpc->tep_path = NULL;
1007         }
1008
1009         if (mpc->tep_move) {
1010                 free(mpc->tep_move);
1011                 mpc->tep_move = NULL;
1012         }
1013
1014         free(mpc);
1015         mpc = NULL;
1016         return PKGMGR_R_OK;
1017
1018  catch:
1019         if (mpc) {
1020                 free(mpc);
1021                 mpc = NULL;
1022         }
1023         return PKGMGR_R_ERROR;
1024 }
1025
1026 static char *__get_type_from_path(const char *pkg_path)
1027 {
1028         int ret;
1029         char mimetype[255] = { '\0', };
1030         char extlist[256] = { '\0', };
1031         char *pkg_type;
1032
1033         ret = _get_mime_from_file(pkg_path, mimetype, sizeof(mimetype));
1034         if (ret) {
1035                 ERR("_get_mime_from_file() failed - error code[%d]\n", ret);
1036                 return NULL;
1037         }
1038
1039         ret = _get_mime_extension(mimetype, extlist, sizeof(extlist));
1040         if (ret) {
1041                 ERR("_get_mime_extension() failed - error code[%d]\n", ret);
1042                 return NULL;
1043         }
1044
1045         if (strlen(extlist) == 0)
1046                 return NULL;
1047
1048         if (strchr(extlist, ','))
1049                 extlist[strlen(extlist) - strlen(strchr(extlist, ','))] = '\0';
1050
1051         pkg_type = strchr(extlist, '.') + 1;
1052         return strdup(pkg_type);
1053 }
1054
1055 static int __change_op_cb_for_enable_disable_splash_screen(pkgmgr_client *pc,
1056                 bool is_enable)
1057 {
1058         int ret;
1059         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1060         req_cb_info *tmp;
1061         req_cb_info *prev;
1062
1063         if (mpc == NULL) {
1064                 ERR("package mananger client pc is NULL");
1065                 return PKGMGR_R_EINVAL;
1066         }
1067
1068         for (tmp = mpc->info.request.rhead; tmp;) {
1069                 prev = tmp;
1070                 tmp = tmp->next;
1071                 free(prev);
1072         }
1073
1074         ret = comm_client_free(mpc->info.request.cc);
1075         if (ret < 0) {
1076                 ERR("comm_client_free() failed - %d", ret);
1077                 return PKGMGR_R_ERROR;
1078         }
1079
1080         mpc->ctype = PC_REQUEST;
1081         if (is_enable)
1082                 mpc->status_type = PKGMGR_CLIENT_STATUS_ENABLE_APP_SPLASH_SCREEN;
1083         else
1084                 mpc->status_type = PKGMGR_CLIENT_STATUS_DISABLE_APP_SPLASH_SCREEN;
1085
1086         mpc->info.request.cc = comm_client_new();
1087         if (mpc->info.request.cc == NULL) {
1088                 ERR("client creation failed");
1089                 return PKGMGR_R_ENOMEM;
1090         }
1091
1092         if (is_enable)
1093                 ret = comm_client_set_status_callback(
1094                                 COMM_STATUS_BROADCAST_ENABLE_APP_SPLASH_SCREEN,
1095                                 mpc->info.request.cc, __operation_callback, pc);
1096         else
1097                 ret = comm_client_set_status_callback(
1098                                 COMM_STATUS_BROADCAST_DISABLE_APP_SPLASH_SCREEN,
1099                                 mpc->info.request.cc, __operation_callback, pc);
1100
1101         if (ret < 0) {
1102                 ERR("set_status_callback() failed - %d", ret);
1103                 return PKGMGR_R_ERROR;
1104         }
1105
1106         return PKGMGR_R_OK;
1107 }
1108
1109 API int pkgmgr_client_set_tep_path(pkgmgr_client *pc, char *tep_path, char *tep_move)
1110 {
1111         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1112         retvm_if(tep_path == NULL, PKGMGR_R_EINVAL, "tep path is NULL");
1113         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1114
1115         mpc->tep_path = strdup(tep_path);
1116         mpc->tep_move = strdup(tep_move);
1117
1118         return PKGMGR_R_OK;
1119 }
1120
1121 API int pkgmgr_client_usr_install(pkgmgr_client *pc, const char *pkg_type,
1122                 const char *descriptor_path, const char *pkg_path,
1123                 const char *optional_data, pkgmgr_mode mode,
1124                 pkgmgr_handler event_cb, void *data, uid_t uid)
1125 {
1126         GVariant *result;
1127         int ret = PKGMGR_R_ECOMM;
1128         char *req_key = NULL;
1129         GVariantBuilder *builder = NULL;
1130         GVariant *args = NULL;
1131         int req_id;
1132         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1133         char *pkgtype;
1134
1135         if (pc == NULL || pkg_path == NULL) {
1136                 ERR("invalid parameter");
1137                 return PKGMGR_R_EINVAL;
1138         }
1139
1140         if (mpc->ctype != PC_REQUEST) {
1141                 ERR("mpc->ctype is not PC_REQUEST");
1142                 return PKGMGR_R_EINVAL;
1143         }
1144
1145         if (access(pkg_path, F_OK) != 0) {
1146                 ERR("failed to access: %s", pkg_path);
1147                 return PKGMGR_R_EINVAL;
1148         }
1149
1150         if (mpc->tep_path != NULL && access(mpc->tep_path, F_OK) != 0) {
1151                 ERR("failed to access: %s", mpc->tep_path);
1152                 return PKGMGR_R_EINVAL;
1153         }
1154
1155         /* TODO: check pkg's type on server-side */
1156         if (pkg_type == NULL)
1157                 pkgtype = __get_type_from_path(pkg_path);
1158         else
1159                 pkgtype = strdup(pkg_type);
1160
1161         /* build arguments */
1162         builder = g_variant_builder_new(G_VARIANT_TYPE("as"));
1163         if (mpc->tep_path) {
1164                 g_variant_builder_add(builder, "s", "-e");
1165                 g_variant_builder_add(builder, "s", mpc->tep_path);
1166                 g_variant_builder_add(builder, "s", "-M");
1167                 g_variant_builder_add(builder, "s", mpc->tep_move);
1168         }
1169
1170         args = g_variant_new("as", builder);
1171         g_variant_builder_unref(builder);
1172
1173         ret = comm_client_request(mpc->info.request.cc, "install",
1174                         g_variant_new("(uss@as)", uid, pkgtype, pkg_path, args),
1175                         &result);
1176         if (ret != PKGMGR_R_OK) {
1177                 ERR("request failed: %d", ret);
1178                 return ret;
1179         }
1180
1181         g_variant_get(result, "(i&s)", &ret, &req_key);
1182         if (req_key == NULL) {
1183                 g_variant_unref(result);
1184                 return PKGMGR_R_ECOMM;
1185         }
1186         if (ret != PKGMGR_R_OK) {
1187                 g_variant_unref(result);
1188                 return ret;
1189         }
1190
1191         req_id = _get_request_id();
1192         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1193
1194         g_variant_unref(result);
1195
1196         return req_id;
1197 }
1198
1199 API int pkgmgr_client_install(pkgmgr_client *pc, const char *pkg_type,
1200                 const char *descriptor_path, const char *pkg_path,
1201                 const char *optional_data, pkgmgr_mode mode,
1202                 pkgmgr_handler event_cb, void *data)
1203 {
1204         return pkgmgr_client_usr_install(pc, pkg_type, descriptor_path,
1205                         pkg_path, optional_data, mode, event_cb, data,
1206                         _getuid());
1207 }
1208
1209 API int pkgmgr_client_reinstall(pkgmgr_client *pc, const char *pkg_type,
1210                 const char *pkgid, const char *optional_data, pkgmgr_mode mode,
1211                 pkgmgr_handler event_cb, void *data)
1212 {
1213         return pkgmgr_client_usr_reinstall(pc, pkg_type, pkgid, optional_data,
1214                         mode, event_cb, data, _getuid());
1215 }
1216
1217 API int pkgmgr_client_usr_reinstall(pkgmgr_client *pc, const char *pkg_type,
1218                 const char *pkgid, const char *optional_data, pkgmgr_mode mode,
1219                 pkgmgr_handler event_cb, void *data, uid_t uid)
1220 {
1221         GVariant *result;
1222         int ret = PKGMGR_R_ECOMM;
1223         char *req_key = NULL;
1224         int req_id;
1225         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1226         char *pkgtype;
1227         pkgmgrinfo_pkginfo_h handle;
1228
1229         if (pc == NULL || pkgid == NULL) {
1230                 ERR("invalid parameter");
1231                 return PKGMGR_R_EINVAL;
1232         }
1233
1234         if (mpc->ctype != PC_REQUEST) {
1235                 ERR("mpc->ctype is not PC_REQUEST");
1236                 return PKGMGR_R_EINVAL;
1237         }
1238
1239         ret = pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, uid, &handle);
1240         if (ret < 0)
1241                 return PKGMGR_R_EINVAL;
1242
1243         ret = pkgmgrinfo_pkginfo_get_type(handle, &pkgtype);
1244         if (ret < 0) {
1245                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1246                 return PKGMGR_R_ERROR;
1247         }
1248
1249         ret = comm_client_request(mpc->info.request.cc, "reinstall",
1250                         g_variant_new("(uss)", uid, pkgtype, pkgid), &result);
1251         pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1252         if (ret != PKGMGR_R_OK) {
1253                 ERR("request failed: %d", ret);
1254                 return ret;
1255         }
1256
1257         g_variant_get(result, "(i&s)", &ret, &req_key);
1258         if (req_key == NULL) {
1259                 g_variant_unref(result);
1260                 return PKGMGR_R_ECOMM;
1261         }
1262         if (ret != PKGMGR_R_OK) {
1263                 g_variant_unref(result);
1264                 return ret;
1265         }
1266
1267         req_id = _get_request_id();
1268         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1269
1270         g_variant_unref(result);
1271
1272         return req_id;
1273 }
1274
1275 API int pkgmgr_client_usr_mount_install(pkgmgr_client *pc, const char *pkg_type,
1276                 const char *descriptor_path, const char *pkg_path,
1277                 const char *optional_data, pkgmgr_mode mode,
1278                 pkgmgr_handler event_cb, void *data, uid_t uid)
1279 {
1280         GVariant *result;
1281         int ret = PKGMGR_R_ECOMM;
1282         char *req_key = NULL;
1283         GVariantBuilder *builder = NULL;
1284         GVariant *args = NULL;
1285         int req_id;
1286         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1287         char *pkgtype;
1288
1289         if (pc == NULL || pkg_path == NULL) {
1290                 ERR("invalid parameter");
1291                 return PKGMGR_R_EINVAL;
1292         }
1293
1294         if (mpc->ctype != PC_REQUEST) {
1295                 ERR("mpc->ctype is not PC_REQUEST");
1296                 return PKGMGR_R_EINVAL;
1297         }
1298
1299         if (access(pkg_path, F_OK) != 0) {
1300                 ERR("failed to access: %s", pkg_path);
1301                 return PKGMGR_R_EINVAL;
1302         }
1303
1304         if (mpc->tep_path != NULL && access(mpc->tep_path, F_OK) != 0) {
1305                 ERR("failed to access: %s", mpc->tep_path);
1306                 return PKGMGR_R_EINVAL;
1307         }
1308
1309         /* TODO: check pkg's type on server-side */
1310         if (pkg_type == NULL)
1311                 pkgtype = __get_type_from_path(pkg_path);
1312         else
1313                 pkgtype = strdup(pkg_type);
1314
1315         /* build arguments */
1316         builder = g_variant_builder_new(G_VARIANT_TYPE("as"));
1317         if (mpc->tep_path) {
1318                 g_variant_builder_add(builder, "s", "-e");
1319                 g_variant_builder_add(builder, "s", mpc->tep_path);
1320                 g_variant_builder_add(builder, "s", "-M");
1321                 g_variant_builder_add(builder, "s", mpc->tep_move);
1322         }
1323
1324         args = g_variant_new("as", builder);
1325         g_variant_builder_unref(builder);
1326
1327         ret = comm_client_request(mpc->info.request.cc, "mount_install",
1328                         g_variant_new("(uss@as)", uid, pkgtype, pkg_path, args),
1329                         &result);
1330         if (ret != PKGMGR_R_OK) {
1331                 ERR("request failed: %d", ret);
1332                 return ret;
1333         }
1334
1335         g_variant_get(result, "(i&s)", &ret, &req_key);
1336         if (req_key == NULL) {
1337                 g_variant_unref(result);
1338                 return PKGMGR_R_ECOMM;
1339         }
1340         if (ret != PKGMGR_R_OK) {
1341                 g_variant_unref(result);
1342                 return ret;
1343         }
1344
1345         req_id = _get_request_id();
1346         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1347
1348         g_variant_unref(result);
1349
1350         return req_id;
1351 }
1352
1353 API int pkgmgr_client_mount_install(pkgmgr_client *pc, const char *pkg_type,
1354                 const char *descriptor_path, const char *pkg_path,
1355                 const char *optional_data, pkgmgr_mode mode,
1356                 pkgmgr_handler event_cb, void *data)
1357 {
1358         return pkgmgr_client_usr_mount_install(pc, pkg_type, descriptor_path,
1359                         pkg_path, optional_data, mode, event_cb, data,
1360                         _getuid());
1361 }
1362
1363 API int pkgmgr_client_uninstall(pkgmgr_client *pc, const char *pkg_type,
1364                 const char *pkgid, pkgmgr_mode mode, pkgmgr_handler event_cb,
1365                 void *data)
1366 {
1367         return pkgmgr_client_usr_uninstall(pc, pkg_type, pkgid, mode, event_cb,
1368                         data, _getuid());
1369 }
1370
1371 API int pkgmgr_client_usr_uninstall(pkgmgr_client *pc, const char *pkg_type,
1372                 const char *pkgid, pkgmgr_mode mode, pkgmgr_handler event_cb,
1373                 void *data, uid_t uid)
1374 {
1375         GVariant *result;
1376         int ret = PKGMGR_R_ECOMM;
1377         char *req_key = NULL;
1378         int req_id;
1379         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1380         char *pkgtype;
1381         pkgmgrinfo_pkginfo_h handle;
1382
1383         if (pc == NULL || pkgid == NULL) {
1384                 ERR("invalid parameter");
1385                 return PKGMGR_R_EINVAL;
1386         }
1387
1388         if (mpc->ctype != PC_REQUEST) {
1389                 ERR("mpc->ctype is not PC_REQUEST");
1390                 return PKGMGR_R_EINVAL;
1391         }
1392
1393         ret = pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, uid, &handle);
1394         if (ret < 0)
1395                 return PKGMGR_R_EINVAL;
1396
1397         ret = pkgmgrinfo_pkginfo_get_type(handle, &pkgtype);
1398         if (ret < 0) {
1399                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1400                 return PKGMGR_R_ERROR;
1401         }
1402
1403         ret = comm_client_request(mpc->info.request.cc, "uninstall",
1404                         g_variant_new("(uss)", uid, pkgtype, pkgid), &result);
1405         if (ret != PKGMGR_R_OK) {
1406                 ERR("request failed: %d", ret);
1407                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1408                 return ret;
1409         }
1410
1411         g_variant_get(result, "(i&s)", &ret, &req_key);
1412         if (req_key == NULL) {
1413                 g_variant_unref(result);
1414                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1415                 return PKGMGR_R_ECOMM;
1416         }
1417         if (ret != PKGMGR_R_OK) {
1418                 g_variant_unref(result);
1419                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1420                 return ret;
1421         }
1422
1423         req_id = _get_request_id();
1424         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1425
1426         g_variant_unref(result);
1427         pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1428
1429         return req_id;
1430 }
1431
1432 API int pkgmgr_client_move(pkgmgr_client *pc, const char *pkg_type,
1433                 const char *pkgid, pkgmgr_move_type move_type,
1434                 pkgmgr_handler event_cb, void *data)
1435 {
1436         return pkgmgr_client_usr_move(pc, pkg_type, pkgid, move_type,
1437                         event_cb, data, _getuid());
1438 }
1439 API int pkgmgr_client_usr_move(pkgmgr_client *pc, const char *pkg_type,
1440                 const char *pkgid, pkgmgr_move_type move_type,
1441                 pkgmgr_handler event_cb, void *data, uid_t uid)
1442 {
1443         GVariant *result;
1444         int ret = PKGMGR_R_ECOMM;
1445         int req_id;
1446         char *req_key = NULL;
1447         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1448
1449         if (pc == NULL || pkg_type == NULL || pkgid == NULL) {
1450                 ERR("invalid parameter");
1451                 return PKGMGR_R_EINVAL;
1452         }
1453
1454         if ((move_type < PM_MOVE_TO_INTERNAL) || (move_type > PM_MOVE_TO_SDCARD))
1455                 return PKGMGR_R_EINVAL;
1456
1457         if (mpc->ctype != PC_REQUEST) {
1458                 ERR("mpc->ctype is not PC_REQUEST");
1459                 return PKGMGR_R_EINVAL;
1460         }
1461
1462         ret = comm_client_request(mpc->info.request.cc, "move",
1463                         g_variant_new("(ussi)", uid, pkg_type, pkgid, move_type), &result);
1464         if (ret != PKGMGR_R_OK) {
1465                 ERR("request failed: %d", ret);
1466                 return ret;
1467         }
1468
1469         g_variant_get(result, "(i&s)", &ret, &req_key);
1470         if (req_key == NULL) {
1471                 g_variant_unref(result);
1472                 return PKGMGR_R_ECOMM;
1473         }
1474         if (ret != PKGMGR_R_OK) {
1475                 g_variant_unref(result);
1476                 return ret;
1477         }
1478
1479         req_id = _get_request_id();
1480         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1481         g_variant_unref(result);
1482
1483         return ret;
1484 }
1485
1486 API int pkgmgr_client_usr_activate(pkgmgr_client *pc, const char *pkg_type,
1487                 const char *pkgid, uid_t uid)
1488 {
1489         GVariant *result;
1490         int ret = PKGMGR_R_ECOMM;
1491         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1492
1493         if (pc == NULL || pkgid == NULL || pkg_type == NULL) {
1494                 ERR("invalid parameter");
1495                 return PKGMGR_R_EINVAL;
1496         }
1497
1498         ret = comm_client_request(mpc->info.request.cc, "enable_pkg",
1499                         g_variant_new("(uss)", uid, pkg_type, pkgid), &result);
1500         if (ret != PKGMGR_R_OK) {
1501                 ERR("request failed: %d", ret);
1502                 return ret;
1503         }
1504
1505         g_variant_get(result, "(i)", &ret);
1506         g_variant_unref(result);
1507
1508         return ret;
1509 }
1510
1511 API int pkgmgr_client_activate(pkgmgr_client *pc, const char *pkg_type,
1512                 const char *pkgid)
1513 {
1514         return pkgmgr_client_usr_activate(pc, pkg_type, pkgid, _getuid());
1515 }
1516
1517 API int pkgmgr_client_usr_deactivate(pkgmgr_client *pc, const char *pkg_type,
1518                                  const char *pkgid, uid_t uid)
1519 {
1520         GVariant *result;
1521         int ret = PKGMGR_R_ECOMM;
1522         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1523
1524         if (pc == NULL || pkgid == NULL || pkg_type == NULL) {
1525                 ERR("invalid parameter");
1526                 return PKGMGR_R_EINVAL;
1527         }
1528
1529         ret = comm_client_request(mpc->info.request.cc, "disable_pkg",
1530                         g_variant_new("(uss)", uid, pkg_type, pkgid), &result);
1531         if (ret != PKGMGR_R_OK) {
1532                 ERR("request failed: %d", ret);
1533                 return ret;
1534         }
1535
1536         g_variant_get(result, "(i)", &ret);
1537         g_variant_unref(result);
1538
1539         return ret;
1540 }
1541
1542 API int pkgmgr_client_deactivate(pkgmgr_client *pc, const char *pkg_type,
1543                                  const char *pkgid)
1544 {
1545         return pkgmgr_client_usr_deactivate(pc, pkg_type, pkgid, _getuid());
1546 }
1547
1548 /* TODO: deprecate? */
1549 API int pkgmgr_client_usr_activate_appv(pkgmgr_client *pc, const char *appid,
1550                 char *const argv[], uid_t uid)
1551 {
1552         return pkgmgr_client_usr_activate_app(pc, appid, NULL, uid);
1553 }
1554
1555 API int pkgmgr_client_activate_appv(pkgmgr_client *pc, const char *appid,
1556                 char *const argv[])
1557 {
1558         return pkgmgr_client_usr_activate_app(pc, appid, NULL, _getuid());
1559 }
1560
1561 API int pkgmgr_client_usr_activate_app(pkgmgr_client *pc, const char *appid,
1562                 pkgmgr_app_handler app_event_cb, uid_t uid)
1563 {
1564         GVariant *result;
1565         int ret = PKGMGR_R_ECOMM;
1566         int req_id;
1567         char *req_key = NULL;
1568         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1569
1570         if (pc == NULL || appid == NULL) {
1571                 ERR("invalid parameter");
1572                 return PKGMGR_R_EINVAL;
1573         }
1574
1575         if (__change_op_cb_for_enable_disable(mpc, false) < 0) {
1576                 ERR("__change_op_cb_for_enable_disable failed");
1577                 return PKGMGR_R_ESYSTEM;
1578         }
1579
1580         ret = comm_client_request(mpc->info.request.cc, "enable_app",
1581                         g_variant_new("(us)", uid, appid), &result);
1582         if (ret != PKGMGR_R_OK) {
1583                 ERR("request failed: %d", ret);
1584                 return ret;
1585         }
1586
1587         g_variant_get(result, "(i&s)", &ret, &req_key);
1588         if (req_key == NULL) {
1589                 g_variant_unref(result);
1590                 return PKGMGR_R_ECOMM;
1591         }
1592         if (ret != PKGMGR_R_OK) {
1593                 g_variant_unref(result);
1594                 return ret;
1595         }
1596
1597         req_id = _get_request_id();
1598         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1599         g_variant_unref(result);
1600         return ret;
1601 }
1602
1603 API int pkgmgr_client_activate_app(pkgmgr_client *pc, const char *appid, pkgmgr_app_handler app_event_cb)
1604 {
1605         return pkgmgr_client_usr_activate_app(pc, appid, app_event_cb, _getuid());
1606 }
1607
1608 API int pkgmgr_client_activate_global_app_for_uid(pkgmgr_client *pc,
1609                                  const char *appid, pkgmgr_app_handler app_event_cb, uid_t uid)
1610 {
1611         GVariant *result;
1612         int ret = PKGMGR_R_ECOMM;
1613         int req_id;
1614         char *req_key = NULL;
1615         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1616
1617         if (pc == NULL || appid == NULL) {
1618                 ERR("invalid parameter");
1619                 return PKGMGR_R_EINVAL;
1620         }
1621
1622         if (__change_op_cb_for_enable_disable(mpc, false) < 0) {
1623                 ERR("__change_op_cb_for_enable_disable failed");
1624                 return PKGMGR_R_ESYSTEM;
1625         }
1626
1627         ret = comm_client_request(mpc->info.request.cc, "enable_global_app_for_uid",
1628                         g_variant_new("(us)", uid, appid), &result);
1629         if (ret != PKGMGR_R_OK) {
1630                 ERR("request failed: %d", ret);
1631                 return ret;
1632         }
1633
1634         g_variant_get(result, "(i&s)", &ret, &req_key);
1635         if (req_key == NULL) {
1636                 g_variant_unref(result);
1637                 return PKGMGR_R_ECOMM;
1638         }
1639         if (ret != PKGMGR_R_OK) {
1640                 g_variant_unref(result);
1641                 return ret;
1642         }
1643
1644         req_id = _get_request_id();
1645         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1646
1647         return ret;
1648 }
1649
1650 API int pkgmgr_client_usr_deactivate_app(pkgmgr_client *pc, const char *appid,
1651                 pkgmgr_app_handler app_event_cb, uid_t uid)
1652 {
1653         GVariant *result;
1654         int ret = PKGMGR_R_ECOMM;
1655         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1656         int req_id;
1657         char *req_key = NULL;
1658
1659         if (pc == NULL || appid == NULL) {
1660                 ERR("invalid parameter");
1661                 return PKGMGR_R_EINVAL;
1662         }
1663
1664         /* FIXME */
1665         if (__change_op_cb_for_enable_disable(mpc, true) < 0) {
1666                 ERR("__change_op_cb_for_enable_disable failed");
1667                 return PKGMGR_R_ESYSTEM;
1668         }
1669
1670         ret = comm_client_request(mpc->info.request.cc, "disable_app",
1671                         g_variant_new("(us)", uid, appid), &result);
1672         if (ret != PKGMGR_R_OK) {
1673                 ERR("request failed: %d", ret);
1674                 return ret;
1675         }
1676
1677         g_variant_get(result, "(i&s)", &ret, &req_key);
1678         if (req_key == NULL) {
1679                 g_variant_unref(result);
1680                 return PKGMGR_R_ECOMM;
1681         }
1682         if (ret != PKGMGR_R_OK) {
1683                 g_variant_unref(result);
1684                 return ret;
1685         }
1686
1687         req_id = _get_request_id();
1688         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1689
1690         g_variant_unref(result);
1691         return ret;
1692 }
1693
1694 API int pkgmgr_client_deactivate_app(pkgmgr_client *pc, const char *appid, pkgmgr_app_handler app_event_cb)
1695 {
1696         return pkgmgr_client_usr_deactivate_app(pc, appid, app_event_cb, _getuid());
1697 }
1698
1699 API int pkgmgr_client_deactivate_global_app_for_uid(pkgmgr_client *pc,
1700                                  const char *appid, pkgmgr_app_handler app_event_cb, uid_t uid)
1701 {
1702         GVariant *result;
1703         int ret = PKGMGR_R_ECOMM;
1704         int req_id;
1705         char *req_key = NULL;
1706         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1707
1708         if (pc == NULL || appid == NULL) {
1709                 ERR("invalid parameter");
1710                 return PKGMGR_R_EINVAL;
1711         }
1712
1713         if (__change_op_cb_for_enable_disable(mpc, true) < 0) {
1714                 ERR("__change_op_cb_for_enable_disable failed");
1715                 return PKGMGR_R_ESYSTEM;
1716         }
1717
1718         ret = comm_client_request(mpc->info.request.cc, "disable_global_app_for_uid",
1719                         g_variant_new("(us)", uid, appid), &result);
1720         if (ret != PKGMGR_R_OK) {
1721                 ERR("request failed: %d", ret);
1722                 return ret;
1723         }
1724
1725         g_variant_get(result, "(i&s)", &ret, &req_key);
1726         if (req_key == NULL) {
1727                 g_variant_unref(result);
1728                 return PKGMGR_R_ECOMM;
1729         }
1730         if (ret != PKGMGR_R_OK) {
1731                 g_variant_unref(result);
1732                 return ret;
1733         }
1734
1735         req_id = _get_request_id();
1736         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1737         return ret;
1738 }
1739
1740 API int pkgmgr_client_usr_clear_user_data(pkgmgr_client *pc,
1741                 const char *pkg_type, const char *appid, pkgmgr_mode mode,
1742                 uid_t uid)
1743 {
1744         GVariant *result;
1745         int ret = PKGMGR_R_ECOMM;
1746         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1747
1748         if (pc == NULL || pkg_type == NULL || appid == NULL) {
1749                 ERR("invalid parameter");
1750                 return PKGMGR_R_EINVAL;
1751         }
1752
1753         if (mpc->ctype != PC_REQUEST) {
1754                 ERR("mpc->ctype is not PC_REQUEST");
1755                 return PKGMGR_R_EINVAL;
1756         }
1757
1758         ret = comm_client_request(mpc->info.request.cc, "cleardata",
1759                         g_variant_new("(uss)", uid, pkg_type, appid), &result);
1760         if (ret == PKGMGR_R_OK) {
1761                 ERR("request failed: %d", ret);
1762                 return ret;
1763         }
1764
1765         g_variant_get(result, "(i)", &ret);
1766         g_variant_unref(result);
1767
1768         return ret;
1769 }
1770
1771 API int pkgmgr_client_clear_user_data(pkgmgr_client *pc, const char *pkg_type,
1772                 const char *appid, pkgmgr_mode mode)
1773 {
1774         return pkgmgr_client_usr_clear_user_data(pc, pkg_type, appid, mode,
1775                         _getuid());
1776 }
1777
1778 API int pkgmgr_client_set_status_type(pkgmgr_client *pc, int status_type)
1779 {
1780         int ret = -1;
1781
1782         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1783         retvm_if(status_type == PKGMGR_CLIENT_STATUS_ALL, PKGMGR_R_OK, "status_type is PKGMGR_CLIENT_STATUS_ALL");
1784         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1785
1786         /*  free listening head */
1787         listen_cb_info *tmp = NULL;
1788         listen_cb_info *prev = NULL;
1789         for (tmp = mpc->info.listening.lhead; tmp;) {
1790                 prev = tmp;
1791                 tmp = tmp->next;
1792                 free(prev);
1793         }
1794
1795         /* free dbus connection */
1796         ret = comm_client_free(mpc->info.listening.cc);
1797         retvm_if(ret < 0, PKGMGR_R_ERROR, "comm_client_free() failed - %d", ret);
1798
1799         /* Manage pc for seperated event */
1800         mpc->ctype = PC_LISTENING;
1801         mpc->status_type = status_type;
1802
1803         mpc->info.listening.cc = comm_client_new();
1804         retvm_if(mpc->info.listening.cc == NULL, PKGMGR_R_EINVAL, "client creation failed");
1805
1806         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_INSTALL) == PKGMGR_CLIENT_STATUS_INSTALL) {
1807                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_INSTALL, mpc->info.listening.cc, __status_callback, pc);
1808                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "PKGMGR_CLIENT_STATUS_INSTALL failed - %d", ret);
1809         }
1810
1811         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_UNINSTALL) == PKGMGR_CLIENT_STATUS_UNINSTALL) {
1812                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_UNINSTALL, mpc->info.listening.cc, __status_callback, pc);
1813                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_UNINSTALL failed - %d", ret);
1814         }
1815
1816         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_MOVE) == PKGMGR_CLIENT_STATUS_MOVE) {
1817                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_MOVE, mpc->info.listening.cc, __status_callback, pc);
1818                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_MOVE failed - %d", ret);
1819         }
1820
1821         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_INSTALL_PROGRESS) == PKGMGR_CLIENT_STATUS_INSTALL_PROGRESS) {
1822                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_INSTALL_PROGRESS, mpc->info.listening.cc, __status_callback, pc);
1823                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_INSTALL_PROGRESS failed - %d", ret);
1824         }
1825
1826         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_UPGRADE) == PKGMGR_CLIENT_STATUS_UPGRADE) {
1827                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_UPGRADE, mpc->info.listening.cc, __status_callback, pc);
1828                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_UPGRADE failed - %d", ret);
1829         }
1830
1831         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_ENABLE_APP) == PKGMGR_CLIENT_STATUS_ENABLE_APP) {
1832                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ENABLE_APP, mpc->info.listening.cc, __status_callback, pc);
1833                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_ENABLE_APP failed - %d", ret);
1834         }
1835
1836         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_DISABLE_APP) == PKGMGR_CLIENT_STATUS_DISABLE_APP) {
1837                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_DISABLE_APP, mpc->info.listening.cc, __status_callback, pc);
1838                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_DISABLE_APP failed - %d", ret);
1839         }
1840
1841         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_ENABLE_APP_SPLASH_SCREEN) == PKGMGR_CLIENT_STATUS_ENABLE_APP_SPLASH_SCREEN) {
1842                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ENABLE_APP_SPLASH_SCREEN, mpc->info.listening.cc, __status_callback, pc);
1843                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_ENABLE_APP_SPLASH_SCREEN failed - %d", ret);
1844         }
1845
1846         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_DISABLE_APP_SPLASH_SCREEN) == PKGMGR_CLIENT_STATUS_DISABLE_APP_SPLASH_SCREEN) {
1847                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_DISABLE_APP_SPLASH_SCREEN, mpc->info.listening.cc, __status_callback, pc);
1848                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_DISABLE_APP_SPLASH_SCREEN failed - %d", ret);
1849         }
1850
1851         return PKGMGR_R_OK;
1852 }
1853
1854 API int pkgmgr_client_listen_status(pkgmgr_client *pc, pkgmgr_handler event_cb,
1855                                     void *data)
1856 {
1857         int req_id;
1858         /* Check for NULL value of pc */
1859         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1860         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1861
1862         /* 0. check input */
1863         retvm_if(mpc->ctype != PC_LISTENING, PKGMGR_R_EINVAL, "ctype is not PC_LISTENING");
1864         retvm_if(event_cb == NULL, PKGMGR_R_EINVAL, "event_cb is NULL");
1865
1866         /* 1. get id */
1867         req_id = _get_request_id();
1868
1869         /* 2. add callback info to pkgmgr_client */
1870         __add_stat_cbinfo(mpc, req_id, event_cb, data);
1871         return req_id;
1872 }
1873
1874 API int pkgmgr_client_listen_app_status(pkgmgr_client *pc, pkgmgr_app_handler event_cb,
1875                                     void *data)
1876 {
1877         int req_id;
1878         /* Check for NULL value of pc */
1879         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1880         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1881
1882         /* 0. check input */
1883         retvm_if(mpc->ctype != PC_LISTENING, PKGMGR_R_EINVAL, "ctype is not PC_LISTENING");
1884         retvm_if(event_cb == NULL, PKGMGR_R_EINVAL, "event_cb is NULL");
1885
1886         /* 1. get id */
1887         req_id = _get_request_id();
1888
1889         /* 2. add app callback info to pkgmgr_client */
1890         __add_app_stat_cbinfo(mpc, req_id, event_cb, data);
1891         return req_id;
1892 }
1893
1894 API int pkgmgr_client_remove_listen_status(pkgmgr_client *pc)
1895 {
1896         int ret = -1;
1897
1898         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1899         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1900
1901         ret = __remove_stat_cbinfo(mpc);
1902         if (ret != 0) {
1903                 ERR("failed to remove status callback");
1904                 return PKGMGR_R_ERROR;
1905         }
1906
1907         return PKGMGR_R_OK;
1908 }
1909
1910 API int pkgmgr_client_broadcast_status(pkgmgr_client *pc, const char *pkg_type,
1911                                        const char *pkgid, const char *key,
1912                                        const char *val)
1913 {
1914         /* client cannot broadcast signal */
1915         return PKGMGR_R_OK;
1916 }
1917
1918 API int pkgmgr_client_request_service(pkgmgr_request_service_type service_type, int service_mode,
1919                                   pkgmgr_client *pc, const char *pkg_type, const char *pkgid,
1920                               const char *custom_info, pkgmgr_handler event_cb, void *data)
1921 {
1922         return pkgmgr_client_usr_request_service(service_type, service_mode, pc, pkg_type, pkgid, _getuid(), custom_info, event_cb, data);
1923 }
1924
1925 API int pkgmgr_client_usr_request_service(pkgmgr_request_service_type service_type, int service_mode,
1926                                   pkgmgr_client *pc, const char *pkg_type, const char *pkgid, uid_t uid,
1927                               const char *custom_info, pkgmgr_handler event_cb, void *data)
1928 {
1929         int ret = 0;
1930
1931         /* Check for NULL value of service type */
1932         retvm_if(service_type > PM_REQUEST_MAX, PKGMGR_R_EINVAL, "service type is not defined\n");
1933         retvm_if(service_type < 0, PKGMGR_R_EINVAL, "service type is error\n");
1934
1935         switch (service_type) {
1936         case PM_REQUEST_CSC:
1937                 tryvm_if(custom_info == NULL, ret = PKGMGR_R_EINVAL, "custom_info is NULL\n");
1938                 tryvm_if(strlen(custom_info) >= PKG_STRING_LEN_MAX, ret = PKGMGR_R_EINVAL, "custom_info over PKG_STRING_LEN_MAX");
1939                 tryvm_if(data == NULL, ret = PKGMGR_R_EINVAL, "data is NULL\n");
1940
1941                 ret = __csc_process(custom_info, (char *)data);
1942                 if (ret < 0)
1943                         ERR("__csc_process fail \n");
1944                 else
1945                         ret = PKGMGR_R_OK;
1946
1947                 break;
1948
1949         case PM_REQUEST_MOVE:
1950                 tryvm_if(pkgid == NULL, ret = PKGMGR_R_EINVAL, "pkgid is NULL\n");
1951                 tryvm_if(pc == NULL, ret = PKGMGR_R_EINVAL, "pc is NULL\n");
1952                 tryvm_if((service_mode < PM_MOVE_TO_INTERNAL) || (service_mode > PM_MOVE_TO_SDCARD), ret = PKGMGR_R_EINVAL, "service_mode is wrong\n");
1953
1954                 ret = __move_pkg_process(pc, pkgid, pkg_type, uid, (pkgmgr_move_type)service_mode, event_cb, data);
1955                 break;
1956
1957         case PM_REQUEST_GET_SIZE:
1958                 tryvm_if(pkgid == NULL, ret = PKGMGR_R_EINVAL, "pkgid is NULL\n");
1959                 tryvm_if(pc == NULL, ret = PKGMGR_R_EINVAL, "pc is NULL\n");
1960                 tryvm_if((service_mode < PM_GET_TOTAL_SIZE) || (service_mode >= PM_GET_MAX), ret = PKGMGR_R_EINVAL, "service_mode is wrong\n");
1961
1962                 ret = __get_size_process(pc, pkgid, uid, (pkgmgr_getsize_type)service_mode, event_cb, data);
1963                 break;
1964
1965         case PM_REQUEST_KILL_APP:
1966         case PM_REQUEST_CHECK_APP:
1967                 tryvm_if(pkgid == NULL, ret = PKGMGR_R_EINVAL, "pkgid is NULL\n");
1968                 tryvm_if(pc == NULL, ret = PKGMGR_R_EINVAL, "pc is NULL\n");
1969
1970                 ret = __check_app_process(service_type, pc, pkgid, uid, data);
1971                 if (ret < 0)
1972                         ERR("__check_app_process fail \n");
1973                 else
1974                         ret = PKGMGR_R_OK;
1975
1976                 break;
1977
1978         default:
1979                 ERR("Wrong Request\n");
1980                 ret = -1;
1981                 break;
1982         }
1983
1984 catch:
1985
1986         return ret;
1987 }
1988
1989
1990 API int pkgmgr_client_usr_request_size_info(uid_t uid)
1991 {
1992         int ret = 0;
1993         pkgmgr_client *pc = NULL;
1994
1995         pc = pkgmgr_client_new(PC_REQUEST);
1996         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "request pc is null\n");
1997
1998         ret = __request_size_info(pc, uid);
1999         if (ret < 0)
2000                 ERR("__request_size_info fail \n");
2001
2002         pkgmgr_client_free(pc);
2003         return ret;
2004 }
2005
2006 API int pkgmgr_client_request_size_info(void) /* get all package size (data, total) */
2007 {
2008         return pkgmgr_client_usr_request_size_info(_getuid());
2009 }
2010
2011 API int pkgmgr_client_usr_clear_cache_dir(const char *pkgid, uid_t uid)
2012 {
2013         GVariant *result;
2014         int ret = PKGMGR_R_ECOMM;
2015         pkgmgr_client_t *pc;
2016
2017         if (pkgid == NULL) {
2018                 ERR("invalid parameter");
2019                 return PKGMGR_R_EINVAL;
2020         }
2021
2022         pc = pkgmgr_client_new(PC_REQUEST);
2023         if (pc == NULL) {
2024                 ERR("out of memory");
2025                 return PKGMGR_R_ESYSTEM;
2026         }
2027
2028         ret = comm_client_request(pc->info.request.cc, "clearcache",
2029                         g_variant_new("(us)", uid, pkgid), &result);
2030         if (ret != PKGMGR_R_OK) {
2031                 ERR("request failed: %d", ret);
2032                 return ret;
2033         }
2034
2035         g_variant_get(result, "(i)", &ret);
2036         g_variant_unref(result);
2037
2038         return ret;
2039 }
2040
2041 API int pkgmgr_client_clear_cache_dir(const char *pkgid)
2042 {
2043         return pkgmgr_client_usr_clear_cache_dir(pkgid, _getuid());
2044 }
2045
2046 API int pkgmgr_client_clear_usr_all_cache_dir(uid_t uid)
2047 {
2048         return pkgmgr_client_usr_clear_cache_dir(PKG_CLEAR_ALL_CACHE, uid);
2049 }
2050
2051 API int pkgmgr_client_clear_all_cache_dir(void)
2052 {
2053         return pkgmgr_client_usr_clear_cache_dir(PKG_CLEAR_ALL_CACHE, _getuid());
2054 }
2055
2056 API int pkgmgr_client_get_size(pkgmgr_client *pc, const char *pkgid,
2057                 pkgmgr_getsize_type get_type, pkgmgr_handler event_cb,
2058                 void *data)
2059 {
2060         return pkgmgr_client_usr_get_size(pc, pkgid, get_type, event_cb, data,
2061                         _getuid());
2062 }
2063
2064 API int pkgmgr_client_usr_get_size(pkgmgr_client *pc, const char *pkgid,
2065                 pkgmgr_getsize_type get_type, pkgmgr_handler event_cb,
2066                 void *data, uid_t uid)
2067 {
2068         GVariant *result;
2069         int ret = PKGMGR_R_ECOMM;
2070         char *req_key = NULL;
2071         int req_id;
2072         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2073
2074         if (pc == NULL || pkgid == NULL || event_cb == NULL) {
2075                 ERR("invalid parameter");
2076                 return PKGMGR_R_EINVAL;
2077         }
2078
2079         if (mpc->ctype != PC_REQUEST) {
2080                 ERR("mpc->ctype is not PC_REQUEST");
2081                 return PKGMGR_R_EINVAL;
2082         }
2083
2084         /* FIXME */
2085         if (strcmp(pkgid, PKG_SIZE_INFO_TOTAL) == 0)
2086                 get_type = PM_GET_TOTAL_PKG_SIZE_INFO;
2087         else
2088                 get_type = PM_GET_PKG_SIZE_INFO;
2089
2090         ret = comm_client_request(mpc->info.request.cc, "getsize",
2091                         g_variant_new("(usi)", uid, pkgid, get_type), &result);
2092         if (ret != PKGMGR_R_OK) {
2093                 ERR("request failed: %d", ret);
2094                 return ret;
2095         }
2096
2097         g_variant_get(result, "(i&s)", &ret, &req_key);
2098         if (req_key == NULL) {
2099                 g_variant_unref(result);
2100                 return PKGMGR_R_ECOMM;
2101         }
2102         if (ret != PKGMGR_R_OK) {
2103                 g_variant_unref(result);
2104                 return ret;
2105         }
2106
2107         req_id = _get_request_id();
2108         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
2109
2110         g_variant_unref(result);
2111
2112         return PKGMGR_R_OK;
2113 }
2114
2115 API int pkgmgr_client_usr_get_package_size_info(pkgmgr_client *pc,
2116                 const char *pkgid, pkgmgr_pkg_size_info_receive_cb event_cb,
2117                 void *user_data, uid_t uid)
2118 {
2119         GVariant *result;
2120         int ret = PKGMGR_R_ECOMM;
2121         char *req_key = NULL;
2122         int req_id;
2123         int get_type;
2124         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2125
2126         if (pc == NULL || pkgid == NULL || event_cb == NULL) {
2127                 ERR("invalid parameter");
2128                 return PKGMGR_R_EINVAL;
2129         }
2130
2131         if (mpc->ctype != PC_REQUEST) {
2132                 ERR("mpc->ctype is not PC_REQUEST");
2133                 return PKGMGR_R_EINVAL;
2134         }
2135
2136         /* FIXME */
2137         if (__change_op_cb_for_getsize(mpc) < 0) {
2138                 ERR("__change_op_cb_for_getsize failed");
2139                 return PKGMGR_R_ESYSTEM;
2140         }
2141
2142         if (strcmp(pkgid, PKG_SIZE_INFO_TOTAL) == 0)
2143                 get_type = PM_GET_TOTAL_PKG_SIZE_INFO;
2144         else
2145                 get_type = PM_GET_PKG_SIZE_INFO;
2146
2147         ret = comm_client_request(mpc->info.request.cc, "getsize",
2148                         g_variant_new("(usi)", uid, pkgid, get_type), &result);
2149         if (ret != PKGMGR_R_OK) {
2150                 ERR("request failed: %d", ret);
2151                 return ret;
2152         }
2153
2154         g_variant_get(result, "(i&s)", &ret, &req_key);
2155         if (req_key == NULL) {
2156                 g_variant_unref(result);
2157                 return PKGMGR_R_ECOMM;
2158         }
2159         if (ret != PKGMGR_R_OK) {
2160                 g_variant_unref(result);
2161                 return ret;
2162         }
2163
2164         req_id = _get_request_id();
2165         __add_op_cbinfo(mpc, req_id, req_key, __get_pkg_size_info_cb, event_cb,
2166                         user_data);
2167
2168         g_variant_unref(result);
2169
2170         return PKGMGR_R_OK;
2171 }
2172
2173 API int pkgmgr_client_get_package_size_info(pkgmgr_client *pc, const char *pkgid, pkgmgr_pkg_size_info_receive_cb event_cb, void *user_data)
2174 {
2175         return pkgmgr_client_usr_get_package_size_info(pc, pkgid, event_cb, user_data, _getuid());
2176 }
2177
2178 API int pkgmgr_client_usr_get_total_package_size_info(pkgmgr_client *pc, pkgmgr_total_pkg_size_info_receive_cb event_cb, void *user_data, uid_t uid)
2179 {       /* total package size info */
2180         return pkgmgr_client_usr_get_package_size_info(pc, PKG_SIZE_INFO_TOTAL, (pkgmgr_pkg_size_info_receive_cb)event_cb, user_data, uid);
2181 }
2182
2183 API int pkgmgr_client_get_total_package_size_info(pkgmgr_client *pc, pkgmgr_total_pkg_size_info_receive_cb event_cb, void *user_data)
2184 {
2185         return pkgmgr_client_usr_get_package_size_info(pc, PKG_SIZE_INFO_TOTAL, (pkgmgr_pkg_size_info_receive_cb)event_cb, user_data, _getuid());
2186 }
2187
2188 API int pkgmgr_client_generate_license_request(pkgmgr_client *pc,
2189                 const char *resp_data, char **req_data, char **license_url)
2190 {
2191         GVariant *result;
2192         int ret;
2193         char *data;
2194         char *url;
2195         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2196
2197         if (pc == NULL || resp_data == NULL || req_data == NULL ||
2198                         license_url == NULL) {
2199                 ERR("invalid parameter");
2200                 return PKGMGR_R_EINVAL;
2201         }
2202
2203         if (mpc->ctype != PC_REQUEST) {
2204                 ERR("mpc->ctype is not PC_REQUEST");
2205                 return PKGMGR_R_EINVAL;
2206         }
2207
2208         ret = comm_client_request(mpc->info.request.cc,
2209                         "generate_license_request",
2210                         g_variant_new("(s)", resp_data), &result);
2211         if (ret != PKGMGR_R_OK) {
2212                 ERR("request failed: %d", ret);
2213                 return ret;
2214         }
2215
2216         g_variant_get(result, "(i&s&s)", &ret, &data, &url);
2217         if (ret != PKGMGR_R_OK) {
2218                 ERR("generate_license_request failed: %d", ret);
2219                 g_variant_unref(result);
2220                 return ret;
2221         }
2222
2223         *req_data = strdup(data);
2224         *license_url = strdup(url);
2225
2226         g_variant_unref(result);
2227
2228         return PKGMGR_R_OK;
2229 }
2230
2231 API int pkgmgr_client_register_license(pkgmgr_client *pc, const char *resp_data)
2232 {
2233         GVariant *result;
2234         int ret;
2235         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2236
2237         if (pc == NULL || resp_data == NULL) {
2238                 ERR("invalid parameter");
2239                 return PKGMGR_R_EINVAL;
2240         }
2241
2242         if (mpc->ctype != PC_REQUEST) {
2243                 ERR("mpc->ctype is not PC_REQUEST");
2244                 return PKGMGR_R_EINVAL;
2245         }
2246
2247         ret = comm_client_request(mpc->info.request.cc,
2248                         "register_license", g_variant_new("(s)", resp_data),
2249                         &result);
2250         if (ret != PKGMGR_R_OK) {
2251                 ERR("request failed: %d", ret);
2252                 return ret;
2253         }
2254
2255         g_variant_get(result, "(i)", &ret);
2256         g_variant_unref(result);
2257         if (ret != PKGMGR_R_OK) {
2258                 ERR("register license failed: %d", ret);
2259                 return ret;
2260         }
2261
2262         return PKGMGR_R_OK;
2263 }
2264
2265 API int pkgmgr_client_decrypt_package(pkgmgr_client *pc,
2266                 const char *drm_file_path, const char *decrypted_file_path)
2267 {
2268         GVariant *result;
2269         int ret;
2270         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2271
2272         if (pc == NULL || drm_file_path == NULL ||
2273                         decrypted_file_path == NULL) {
2274                 ERR("invalid parameter");
2275                 return PKGMGR_R_EINVAL;
2276         }
2277
2278         if (mpc->ctype != PC_REQUEST) {
2279                 ERR("mpc->ctype is not PC_REQUEST");
2280                 return PKGMGR_R_EINVAL;
2281         }
2282
2283         ret = comm_client_request(mpc->info.request.cc,
2284                         "decrypt_package",
2285                         g_variant_new("(ss)", drm_file_path,
2286                                 decrypted_file_path),
2287                         &result);
2288         if (ret != PKGMGR_R_OK) {
2289                 ERR("request failed: %d", ret);
2290                 return ret;
2291         }
2292
2293         g_variant_get(result, "(i)", &ret);
2294         g_variant_unref(result);
2295         if (ret != PKGMGR_R_OK) {
2296                 ERR("decrypt_package failed: %d", ret);
2297                 return ret;
2298         }
2299
2300         return PKGMGR_R_OK;
2301 }
2302
2303 API int pkgmgr_client_enable_splash_screen(pkgmgr_client *pc, const char *appid)
2304 {
2305         return pkgmgr_client_usr_enable_splash_screen(pc, appid, _getuid());
2306 }
2307
2308 API int pkgmgr_client_usr_enable_splash_screen(pkgmgr_client *pc,
2309                 const char *appid, uid_t uid)
2310 {
2311         int ret;
2312         GVariant *result;
2313         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2314
2315         if (pc == NULL || appid == NULL) {
2316                 ERR("Invalid parameter");
2317                 return PKGMGR_R_EINVAL;
2318         }
2319
2320         ret = __change_op_cb_for_enable_disable_splash_screen(mpc, true);
2321         if (ret < 0) {
2322                 ERR("__change_op_cb_for_enable_disable_splash_screen failed");
2323                 return PKGMGR_R_ESYSTEM;
2324         }
2325
2326         ret = comm_client_request(mpc->info.request.cc,
2327                         "enable_app_splash_screen",
2328                         g_variant_new("(us)", uid, appid), &result);
2329         if (ret != PKGMGR_R_OK) {
2330                 ERR("request failed: %d", ret);
2331                 return ret;
2332         }
2333
2334         g_variant_get(result, "(i)", &ret);
2335         if (ret != PKGMGR_R_OK) {
2336                 g_variant_unref(result);
2337                 return ret;
2338         }
2339
2340         g_variant_unref(result);
2341
2342         return ret;
2343 }
2344
2345 API int pkgmgr_client_disable_splash_screen(pkgmgr_client *pc,
2346                 const char *appid)
2347 {
2348         return pkgmgr_client_usr_disable_splash_screen(pc, appid,
2349                         _getuid());
2350 }
2351
2352 API int pkgmgr_client_usr_disable_splash_screen(pkgmgr_client *pc,
2353                 const char *appid, uid_t uid)
2354 {
2355         int ret;
2356         GVariant *result;
2357         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2358
2359         if (pc == NULL || appid == NULL) {
2360                 ERR("Invalid parameter");
2361                 return PKGMGR_R_EINVAL;
2362         }
2363
2364         ret = __change_op_cb_for_enable_disable_splash_screen(mpc, false);
2365         if (ret < 0) {
2366                 ERR("__change_op_cb_for_enable_disable_splash_screen failed");
2367                 return ret;
2368         }
2369
2370         ret = comm_client_request(mpc->info.request.cc,
2371                         "disable_app_splash_screen",
2372                         g_variant_new("(us)", uid, appid), &result);
2373         if (ret != PKGMGR_R_OK) {
2374                 ERR("request failed: %d", ret);
2375                 return ret;
2376         }
2377
2378         g_variant_get(result, "(i)", &ret);
2379         if (ret != PKGMGR_R_OK) {
2380                 g_variant_unref(result);
2381                 return ret;
2382         }
2383
2384         g_variant_unref(result);
2385
2386         return ret;
2387 }
2388
2389 static int __set_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int mode, uid_t uid)
2390 {
2391         GVariant *result;
2392         int ret = PKGMGR_R_ECOMM;
2393         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2394
2395         if (pc == NULL || pkgid == NULL || strlen(pkgid) == 0 || mode <= 0) {
2396                 ERR("invalid parameter");
2397                 return PKGMGR_R_EINVAL;
2398         }
2399
2400         ret = comm_client_request(mpc->info.request.cc, "set_restriction_mode",
2401                         g_variant_new("(usi)", uid, pkgid, mode), &result);
2402         if (ret != PKGMGR_R_OK) {
2403                 ERR("request failed: %d", ret);
2404                 return ret;
2405         }
2406
2407         g_variant_get(result, "(i)", &ret);
2408         g_variant_unref(result);
2409
2410         return ret;
2411 }
2412
2413 API int pkgmgr_client_usr_set_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int mode, uid_t uid)
2414 {
2415         return __set_pkg_restriction_mode(pc, pkgid, mode, uid);
2416 }
2417
2418 API int pkgmgr_client_set_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int mode)
2419 {
2420         return pkgmgr_client_usr_set_pkg_restriction_mode(pc, pkgid, mode, _getuid());
2421 }
2422
2423 static int __unset_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int mode, uid_t uid)
2424 {
2425         GVariant *result;
2426         int ret = PKGMGR_R_ECOMM;
2427         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2428
2429         if (pc == NULL || pkgid == NULL || strlen(pkgid) == 0 || mode <= 0) {
2430                 ERR("invalid parameter");
2431                 return PKGMGR_R_EINVAL;
2432         }
2433
2434         ret = comm_client_request(mpc->info.request.cc,
2435                         "unset_restriction_mode",
2436                         g_variant_new("(usi)", uid, pkgid, mode), &result);
2437         if (ret != PKGMGR_R_OK) {
2438                 ERR("request failed: %d", ret);
2439                 return ret;
2440         }
2441
2442         g_variant_get(result, "(i)", &ret);
2443         g_variant_unref(result);
2444
2445         return ret;
2446
2447 }
2448
2449 API int pkgmgr_client_usr_unset_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int mode, uid_t uid)
2450 {
2451         return __unset_pkg_restriction_mode(pc, pkgid, mode, uid);
2452 }
2453
2454 API int pkgmgr_client_unset_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int mode)
2455 {
2456         return pkgmgr_client_usr_unset_pkg_restriction_mode(pc, pkgid, mode, _getuid());
2457 }
2458
2459 static int __get_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int *mode, uid_t uid)
2460 {
2461         GVariant *result;
2462         int ret = PKGMGR_R_ECOMM;
2463         gint m;
2464         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2465
2466         if (pc == NULL || pkgid == NULL || strlen(pkgid) == 0) {
2467                 ERR("invalid parameter");
2468                 return PKGMGR_R_EINVAL;
2469         }
2470
2471         ret = comm_client_request(mpc->info.request.cc,
2472                         "get_restriction_mode",
2473                         g_variant_new("(us)", uid, pkgid), &result);
2474         if (ret != PKGMGR_R_OK) {
2475                 ERR("request failed: %d", ret);
2476                 return ret;
2477         }
2478
2479         g_variant_get(result, "(ii)", &m, &ret);
2480         g_variant_unref(result);
2481         if (ret != PKGMGR_R_OK)
2482                 return ret;
2483
2484         *mode = m;
2485
2486         return PKGMGR_R_OK;
2487 }
2488
2489 API int pkgmgr_client_usr_get_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int *mode, uid_t uid)
2490 {
2491         return __get_pkg_restriction_mode(pc, pkgid, mode, uid);
2492 }
2493
2494 API int pkgmgr_client_get_pkg_restriction_mode(pkgmgr_client *pc, const char *pkgid, int *mode)
2495 {
2496         return pkgmgr_client_usr_get_pkg_restriction_mode(pc, pkgid, mode, _getuid());
2497 }
2498
2499 API int pkgmgr_client_usr_set_restriction_mode(pkgmgr_client *pc, int mode,
2500                 uid_t uid)
2501 {
2502         GVariant *result;
2503         int ret = PKGMGR_R_ECOMM;
2504         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2505
2506         if (pc == NULL) {
2507                 ERR("invalid parameter");
2508                 return PKGMGR_R_EINVAL;
2509         }
2510
2511         ret = comm_client_request(mpc->info.request.cc, "set_restriction_mode",
2512                         g_variant_new("(usi)", uid, "", mode), &result);
2513         if (ret != PKGMGR_R_OK) {
2514                 ERR("request failed: %d", ret);
2515                 return ret;
2516         }
2517
2518         g_variant_get(result, "(i)", &ret);
2519         g_variant_unref(result);
2520
2521         return ret;
2522 }
2523
2524 API int pkgmgr_client_set_restriction_mode(pkgmgr_client *pc, int mode)
2525 {
2526         return pkgmgr_client_usr_set_restriction_mode(pc, mode, _getuid());
2527 }
2528
2529 API int pkgmgr_client_usr_unset_restriction_mode(pkgmgr_client *pc, int mode,
2530                 uid_t uid)
2531 {
2532         GVariant *result;
2533         int ret = PKGMGR_R_ECOMM;
2534         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2535
2536         if (pc == NULL) {
2537                 ERR("invalid parameter");
2538                 return PKGMGR_R_EINVAL;
2539         }
2540
2541         ret = comm_client_request(mpc->info.request.cc,
2542                         "unset_restriction_mode",
2543                         g_variant_new("(usi)", uid, "", mode), &result);
2544         if (ret != PKGMGR_R_OK) {
2545                 ERR("request failed: %d", ret);
2546                 return ret;
2547         }
2548
2549         g_variant_get(result, "(i)", &ret);
2550         g_variant_unref(result);
2551
2552         return ret;
2553 }
2554
2555 API int pkgmgr_client_unset_restriction_mode(pkgmgr_client *pc, int mode)
2556 {
2557         return pkgmgr_client_usr_unset_restriction_mode(pc, mode, _getuid());
2558 }
2559
2560 API int pkgmgr_client_usr_get_restriction_mode(pkgmgr_client *pc,
2561                 int *mode, uid_t uid)
2562 {
2563         GVariant *result;
2564         int ret = PKGMGR_R_ECOMM;
2565         gint m;
2566         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2567
2568         if (pc == NULL) {
2569                 ERR("invalid parameter");
2570                 return PKGMGR_R_EINVAL;
2571         }
2572
2573         ret = comm_client_request(mpc->info.request.cc,
2574                         "get_restriction_mode",
2575                         g_variant_new("(us)", uid, ""), &result);
2576         if (ret != PKGMGR_R_OK) {
2577                 ERR("request failed: %d", ret);
2578                 return ret;
2579         }
2580
2581         g_variant_get(result, "(ii)", &m, &ret);
2582         g_variant_unref(result);
2583         if (ret != PKGMGR_R_OK)
2584                 return ret;
2585
2586         *mode = m;
2587
2588         return PKGMGR_R_OK;
2589 }
2590
2591 API int pkgmgr_client_get_restriction_mode(pkgmgr_client *pc,
2592                 int *mode)
2593 {
2594         return pkgmgr_client_usr_get_restriction_mode(pc, mode, _getuid());
2595 }