Implement app signal related with app splash screen display
[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 fint cb_info for req_id:%s", req_id);
398                 return;
399         }
400
401         /* call callback */
402         if (appid != NULL && strlen(appid) != 0) {
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 {
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 inline int __pkgmgr_find_pid_by_cmdline(const char *dname,
524                                       const char *cmdline, const char *apppath)
525 {
526         int pid = 0;
527
528         if (strncmp(cmdline, apppath, PKG_STRING_LEN_MAX-1) == 0) {
529                 pid = atoi(dname);
530                 if (pid != getpgid(pid))
531                         pid = 0;
532         }
533
534         return pid;
535 }
536
537 static int __sync_process(const char *req_key)
538 {
539         int ret;
540         char info_file[PKG_STRING_LEN_MAX] = {'\0', };
541         int result = -1;
542         int check_cnt = 0;
543         FILE *fp;
544         char buf[PKG_STRING_LEN_MAX] = {0, };
545
546         snprintf(info_file, PKG_STRING_LEN_MAX, "%s/%s", PKG_SIZE_INFO_PATH, req_key);
547         while(1)
548         {
549                 check_cnt++;
550
551                 if (access(info_file, F_OK) == 0) {
552                         fp = fopen(info_file, "r");
553                         if (fp == NULL) {
554                                 DBG("file is not generated yet.... wait\n");
555                                 usleep(100 * 1000);     /* 100ms sleep*/
556                                 continue;
557                         }
558
559                         if (fgets(buf, PKG_STRING_LEN_MAX, fp) == NULL) {
560                                 ERR("failed to read info file");
561                                 fclose(fp);
562                                 break;
563                         }
564                         fclose(fp);
565
566                         DBG("info_file file is generated, result = %s. \n", buf);
567                         result = atoi(buf);
568                         break;
569                 }
570
571                 DBG("file is not generated yet.... wait\n");
572                 usleep(100 * 1000);     /* 100ms sleep*/
573
574                 if (check_cnt > 6000) { /* 60s * 10 time over*/
575                         ERR("wait time over!!\n");
576                         break;
577                 }
578         }
579
580         ret = remove(info_file);
581         if (ret < 0)
582                 ERR("file is can not remove[%s, %d]\n", info_file, ret);
583
584         return result;
585 }
586
587 static int __csc_process(const char *csc_path, char *result_path)
588 {
589         int ret = 0;
590         int cnt = 0;
591         int count = 0;
592         int csc_fail = 0;
593         int fd = 0;
594         char *pkgtype = NULL;
595         char *des = NULL;
596         char buf[PKG_STRING_LEN_MAX] = {0,};
597         char type_buf[1024] = { 0 };
598         char des_buf[1024] = { 0 };
599         dictionary *csc = NULL;
600         FILE* file = NULL;
601
602         csc = iniparser_load(csc_path);
603         retvm_if(csc == NULL, PKGMGR_R_EINVAL, "cannot open parse file [%s]", csc_path);
604
605         file = fopen(result_path, "w");
606         tryvm_if(file == NULL, ret = PKGMGR_R_EINVAL, "cannot open result file [%s]", result_path);
607
608         count = iniparser_getint(csc, "csc packages:count", -1);
609         tryvm_if(count == 0, ret = PKGMGR_R_ERROR, "csc [%s] dont have packages", csc_path);
610
611         snprintf(buf, PKG_STRING_LEN_MAX, "[result]\n");
612         fwrite(buf, 1, strlen(buf), file);
613         snprintf(buf, PKG_STRING_LEN_MAX, "count = %d\n", count);
614         fwrite(buf, 1, strlen(buf), file);
615
616         for(cnt = 1 ; cnt <= count ; cnt++)
617         {
618                 snprintf(type_buf, PKG_STRING_LEN_MAX - 1, "csc packages:type_%03d", cnt);
619                 snprintf(des_buf, PKG_STRING_LEN_MAX - 1, "csc packages:description_%03d", cnt);
620
621                 pkgtype = iniparser_getstring(csc, type_buf, NULL);
622                 des = iniparser_getstring(csc, des_buf, NULL);
623                 ret = 0;
624
625                 if (pkgtype == NULL) {
626                         csc_fail++;
627                         snprintf(buf, PKG_STRING_LEN_MAX, "%s = Fail to get pkgtype\n", type_buf);
628                         fwrite(buf, 1, strlen(buf), file);
629                         continue;
630                 } else if (des == NULL) {
631                         csc_fail++;
632                         snprintf(buf, PKG_STRING_LEN_MAX, "%s = Fail to get description\n", des_buf);
633                         fwrite(buf, 1, strlen(buf), file);
634                         continue;
635                 }
636
637                 snprintf(buf, PKG_STRING_LEN_MAX, "type_%03d = %s\n", cnt, pkgtype);
638                 fwrite(buf, 1, strlen(buf), file);
639                 snprintf(buf, PKG_STRING_LEN_MAX, "description_%03d = %s\n", cnt, des);
640                 fwrite(buf, 1, strlen(buf), file);
641
642                 if (strcmp(pkgtype, "tpk") == 0) {
643                         const char *ospinstaller_argv[] = { "/usr/bin/osp-installer", "-c", des, NULL };
644                         ret = __xsystem(ospinstaller_argv);
645                 } else if (strcmp(pkgtype, "wgt")== 0) {
646                         const char *wrtinstaller_argv[] = { "/usr/bin/wrt-installer", "-c", des, NULL };
647                         ret = __xsystem(wrtinstaller_argv);
648                 } else {
649                         csc_fail++;
650                         ret = -1;
651                 }
652
653                 if (ret != 0) {
654                         char *errstr = NULL;
655                         __error_to_string(ret, &errstr);
656                         snprintf(buf, PKG_STRING_LEN_MAX, "result_%03d = fail[%s]\n", cnt, errstr);
657                 }
658                 else
659                         snprintf(buf, PKG_STRING_LEN_MAX, "result_%03d = success\n", cnt);
660
661                 fwrite(buf, 1, strlen(buf), file);
662         }
663
664 catch:
665         iniparser_freedict(csc);
666         if (file != NULL) {
667                 fflush(file);
668                 fd = fileno(file);
669                 fsync(fd);
670                 fclose(file);
671         }
672         return ret;
673 }
674
675 static int __get_size_process(pkgmgr_client * pc, const char *pkgid, uid_t uid,
676                 pkgmgr_getsize_type get_type, pkgmgr_handler event_cb,
677                 void *data)
678 {
679         GVariant *result;
680         int ret = PKGMGR_R_ECOMM;
681         char *req_key = NULL;
682         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
683
684         if (pc == NULL || pkgid == NULL) {
685                 ERR("invalid parameter");
686                 return PKGMGR_R_EINVAL;
687         }
688
689         if (mpc->ctype != PC_REQUEST) {
690                 ERR("mpc->ctype is not PC_REQUEST");
691                 return PKGMGR_R_EINVAL;
692         }
693
694         ret = comm_client_request(mpc->info.request.cc, "getsize",
695                         g_variant_new("(usi)", uid, pkgid, get_type), &result);
696         if (ret != PKGMGR_R_OK) {
697                 ERR("request failed: %d", ret);
698                 return ret;
699         }
700
701         g_variant_get(result, "(i&s)", &ret, &req_key);
702         if (req_key == NULL) {
703                 g_variant_unref(result);
704                 return PKGMGR_R_ECOMM;
705         }
706         if (ret != PKGMGR_R_OK) {
707                 g_variant_unref(result);
708                 return ret;
709         }
710
711         ret = __sync_process(req_key);
712         if (ret < 0)
713                 ERR("get size failed, ret=%d\n", ret);
714
715         g_variant_unref(result);
716
717         return ret;
718 }
719
720 static int __move_pkg_process(pkgmgr_client *pc, const char *pkgid,
721                 const char *pkg_type, uid_t uid, pkgmgr_move_type move_type,
722                 pkgmgr_handler event_cb, void *data)
723 {
724         int ret;
725
726         ret = pkgmgr_client_usr_move(pc, pkg_type, pkgid, move_type, 0, uid);
727         if (ret < 0) {
728                 ERR("move request failed");
729                 return ret;
730         }
731
732         return ret;
733 }
734
735 static int __check_app_process(pkgmgr_request_service_type service_type,
736                 pkgmgr_client *pc, const char *pkgid, uid_t uid, void *data)
737 {
738         GVariant *result;
739         int ret = PKGMGR_R_ECOMM;
740         pkgmgrinfo_pkginfo_h handle;
741         int pid = -1;
742         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
743
744         retvm_if(mpc->ctype != PC_REQUEST, PKGMGR_R_EINVAL, "mpc->ctype is not PC_REQUEST\n");
745
746         if (uid != GLOBAL_USER)
747                 ret = pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, uid, &handle);
748         else
749                 ret = pkgmgrinfo_pkginfo_get_pkginfo(pkgid, &handle);
750         retvm_if(ret < 0, PKGMGR_R_ERROR, "pkgmgrinfo_pkginfo_get_pkginfo failed");
751
752         if (service_type == PM_REQUEST_KILL_APP)
753                 ret = comm_client_request(mpc->info.request.cc, "kill",
754                                 g_variant_new("(us)", uid, pkgid), &result);
755         else if (service_type == PM_REQUEST_CHECK_APP)
756                 ret = comm_client_request(mpc->info.request.cc, "check",
757                                 g_variant_new("(us)", uid, pkgid), &result);
758         if (ret != PKGMGR_R_OK) {
759                 ERR("request failed: %d", ret);
760                 return ret;
761         }
762
763         g_variant_get(result, "(i)", &ret);
764         g_variant_unref(result);
765         if (ret != PKGMGR_R_OK) {
766                 ERR("request failed, ret=%d", ret);
767                 return ret;
768         }
769
770         /* FIXME */
771         pid  = __sync_process(pkgid);
772         *(int *)data = pid;
773
774         pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
775
776         return ret;
777
778 }
779
780 static int __request_size_info(pkgmgr_client *pc, uid_t uid)
781 {
782         GVariant *result;
783         int ret = PKGMGR_R_ECOMM;
784         char *req_key = NULL;
785         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
786
787         if (pc == NULL) {
788                 ERR("invalid parameter");
789                 return PKGMGR_R_EINVAL;
790         }
791
792         if (mpc->ctype != PC_REQUEST) {
793                 ERR("mpc->ctype is not PC_REQUEST");
794                 return PKGMGR_R_EINVAL;
795         }
796
797         ret = comm_client_request(mpc->info.request.cc, "getsize",
798                         g_variant_new("(usi)", uid, "size_info",
799                                 PM_GET_SIZE_INFO),
800                         &result);
801         if (ret != PKGMGR_R_OK) {
802                 ERR("request failed: %d", ret);
803                 return ret;
804         }
805
806         g_variant_get(result, "(i&s)", &ret, &req_key);
807         if (req_key == NULL) {
808                 g_variant_unref(result);
809                 return PKGMGR_R_ECOMM;
810         }
811
812         g_variant_unref(result);
813
814         return ret;
815 }
816
817 static int __change_op_cb_for_getsize(pkgmgr_client *pc)
818 {
819         int ret = -1;
820
821         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
822         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
823
824         /*  free listening head */
825         req_cb_info *tmp = NULL;
826         req_cb_info *prev = NULL;
827         for (tmp = mpc->info.request.rhead; tmp;) {
828                 prev = tmp;
829                 tmp = tmp->next;
830                 free(prev);
831         }
832
833         /* free dbus connection */
834         ret = comm_client_free(mpc->info.request.cc);
835         retvm_if(ret < 0, PKGMGR_R_ERROR, "comm_client_free() failed - %d", ret);
836
837         /* Manage pc for seperated event */
838         mpc->ctype = PC_REQUEST;
839         mpc->status_type = PKGMGR_CLIENT_STATUS_GET_SIZE;
840
841
842         mpc->info.request.cc = comm_client_new();
843         retvm_if(mpc->info.request.cc == NULL, PKGMGR_R_ERROR, "client creation failed");
844
845         ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_GET_SIZE, mpc->info.request.cc, __operation_callback, pc);
846         retvm_if(ret < 0, PKGMGR_R_ERROR, "set_status_callback() failed - %d", ret);
847
848         return PKGMGR_R_OK;
849 }
850
851 static int __change_op_cb_for_enable_disable(pkgmgr_client *pc, bool is_disable)
852 {
853         int ret = -1;
854
855         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
856         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
857
858         /*  free listening head */
859         req_cb_info *tmp = NULL;
860         req_cb_info *prev = NULL;
861         for (tmp = mpc->info.request.rhead; tmp;) {
862                 prev = tmp;
863                 tmp = tmp->next;
864                 free(prev);
865         }
866
867         /* free dbus connection */
868         ret = comm_client_free(mpc->info.request.cc);
869         retvm_if(ret < 0, PKGMGR_R_ERROR, "comm_client_free() failed - %d", ret);
870
871         /* Manage pc for seperated event */
872         mpc->ctype = PC_REQUEST;
873         if (is_disable)
874                 mpc->status_type = PKGMGR_CLIENT_STATUS_DISABLE_APP;
875         else
876                 mpc->status_type = PKGMGR_CLIENT_STATUS_ENABLE_APP;
877
878
879         mpc->info.request.cc = comm_client_new();
880         retvm_if(mpc->info.request.cc == NULL, PKGMGR_R_ERROR, "client creation failed");
881
882         if (is_disable)
883                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_DISABLE_APP, mpc->info.request.cc, __operation_callback, pc);
884         else
885                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ENABLE_APP, mpc->info.request.cc, __operation_callback, pc);
886         retvm_if(ret < 0, PKGMGR_R_ERROR, "set_status_callback() failed - %d", ret);
887
888         return PKGMGR_R_OK;
889 }
890
891 static int __get_pkg_size_info_cb(uid_t target_uid, int req_id, const char *req_type,
892                 const char *pkgid, const char *key,
893                 const char *value, const void *pc, void *user_data)
894 {
895         int ret = 0;
896         DBG("target_uid: %u, reqid: %d, req type: %s, pkgid: %s, unused key: %s, size info: %s",
897                         target_uid, req_id, req_type, pkgid, key, value);
898
899         pkg_size_info_t *size_info = (pkg_size_info_t *)malloc(sizeof(pkg_size_info_t));
900         retvm_if(size_info == NULL, -1, "The memory is insufficient.");
901
902         char *save_ptr = NULL;
903         char *token = strtok_r((char*)value, ":", &save_ptr);
904         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
905         size_info->data_size = atoll(token);
906         token = strtok_r(NULL, ":", &save_ptr);
907         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
908         size_info->cache_size = atoll(token);
909         token = strtok_r(NULL, ":", &save_ptr);
910         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
911         size_info->app_size = atoll(token);
912         token = strtok_r(NULL, ":", &save_ptr);
913         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
914         size_info->ext_data_size = atoll(token);
915         token = strtok_r(NULL, ":", &save_ptr);
916         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
917         size_info->ext_cache_size = atoll(token);
918         token = strtok_r(NULL, ":", &save_ptr);
919         tryvm_if(token == NULL, ret = -1, "failed to parse sizeinfo");
920         size_info->ext_app_size = atoll(token);
921
922         DBG("data: %lld, cache: %lld, app: %lld, ext_data: %lld, ext_cache: %lld, ext_app: %lld",
923                         size_info->data_size, size_info->cache_size, size_info->app_size,
924                         size_info->ext_data_size, size_info->ext_cache_size, size_info->ext_app_size);
925
926         pkgmgr_client_t *pmc = (pkgmgr_client_t *)pc;
927         tryvm_if(pmc == NULL, ret = -1, "pkgmgr_client instance is null.");
928
929         if (strcmp(pkgid, PKG_SIZE_INFO_TOTAL) == 0)
930         {       // total package size info
931                 pkgmgr_total_pkg_size_info_receive_cb callback = (pkgmgr_total_pkg_size_info_receive_cb)(pmc->new_event_cb);
932                 callback((pkgmgr_client *)pc, size_info, user_data);
933         }
934         else
935         {
936                 pkgmgr_pkg_size_info_receive_cb callback = (pkgmgr_pkg_size_info_receive_cb)(pmc->new_event_cb);
937                 callback((pkgmgr_client *)pc, pkgid, size_info, user_data);
938         }
939
940 catch:
941
942         if(size_info){
943                 free(size_info);
944                 size_info = NULL;
945         }
946         return ret;
947 }
948
949 API pkgmgr_client *pkgmgr_client_new(client_type ctype)
950 {
951         pkgmgr_client_t *pc = NULL;
952         int ret = -1;
953
954         retvm_if(ctype == PC_BROADCAST, NULL, "broadcast type is not supported");
955         retvm_if(ctype != PC_REQUEST && ctype != PC_LISTENING, NULL, "ctype is not client_type");
956
957         /* Allocate memory for ADT:pkgmgr_client */
958         pc = calloc(1, sizeof(pkgmgr_client_t));
959         retvm_if(pc == NULL, NULL, "No memory");
960
961         /* Manage pc */
962         pc->ctype = ctype;
963         pc->status_type = PKGMGR_CLIENT_STATUS_ALL;
964         pc->tep_path = NULL;
965
966         if (pc->ctype == PC_REQUEST) {
967                 pc->info.request.cc = comm_client_new();
968                 trym_if(pc->info.request.cc == NULL, "client creation failed");
969
970                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ALL, pc->info.request.cc, __operation_callback, pc);
971                 trym_if(ret < 0L, "comm_client_set_status_callback() failed - %d", ret);
972         } else if (pc->ctype == PC_LISTENING) {
973                 pc->info.listening.cc = comm_client_new();
974                 trym_if(pc->info.listening.cc == NULL, "client creation failed");
975
976                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ALL, pc->info.listening.cc, __status_callback, pc);
977                 trym_if(ret < 0L, "comm_client_set_status_callback() failed - %d", ret);
978         }
979
980         return (pkgmgr_client *) pc;
981
982  catch:
983         if (pc)
984                 free(pc);
985         return NULL;
986 }
987
988 API int pkgmgr_client_free(pkgmgr_client *pc)
989 {
990         int ret = -1;
991         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
992         retvm_if(mpc == NULL, PKGMGR_R_EINVAL, "Invalid argument");
993
994         if (mpc->ctype == PC_REQUEST) {
995                 req_cb_info *tmp;
996                 req_cb_info *prev;
997                 for (tmp = mpc->info.request.rhead; tmp;) {
998                         prev = tmp;
999                         tmp = tmp->next;
1000                         free(prev);
1001                 }
1002
1003                 ret = comm_client_free(mpc->info.request.cc);
1004                 tryvm_if(ret < 0, ret = PKGMGR_R_ERROR, "comm_client_free() failed");
1005         } else if (mpc->ctype == PC_LISTENING) {
1006                         listen_cb_info *tmp;
1007                         listen_cb_info *prev;
1008                         for (tmp = mpc->info.listening.lhead; tmp;) {
1009                                 prev = tmp;
1010                                 tmp = tmp->next;
1011                                 free(prev);
1012                         }
1013
1014                         ret = comm_client_free(mpc->info.listening.cc);
1015                         tryvm_if(ret < 0, ret = PKGMGR_R_ERROR, "comm_client_free() failed");
1016         } else if (mpc->ctype == PC_BROADCAST) {
1017                 ret = 0;
1018         } else {
1019                 ERR("Invalid client type\n");
1020                 return PKGMGR_R_EINVAL;
1021         }
1022
1023         if (mpc->tep_path) {
1024                 free(mpc->tep_path);
1025                 mpc->tep_path = NULL;
1026         }
1027
1028         if (mpc->tep_move) {
1029                 free(mpc->tep_move);
1030                 mpc->tep_move = NULL;
1031         }
1032
1033         free(mpc);
1034         mpc = NULL;
1035         return PKGMGR_R_OK;
1036
1037  catch:
1038         if (mpc) {
1039                 free(mpc);
1040                 mpc = NULL;
1041         }
1042         return PKGMGR_R_ERROR;
1043 }
1044
1045 static char *__get_type_from_path(const char *pkg_path)
1046 {
1047         int ret;
1048         char mimetype[255] = { '\0', };
1049         char extlist[256] = { '\0', };
1050         char *pkg_type;
1051
1052         ret = _get_mime_from_file(pkg_path, mimetype, sizeof(mimetype));
1053         if (ret) {
1054                 ERR("_get_mime_from_file() failed - error code[%d]\n", ret);
1055                 return NULL;
1056         }
1057
1058         ret = _get_mime_extension(mimetype, extlist, sizeof(extlist));
1059         if (ret) {
1060                 ERR("_get_mime_extension() failed - error code[%d]\n", ret);
1061                 return NULL;
1062         }
1063
1064         if (strlen(extlist) == 0)
1065                 return NULL;
1066
1067         if (strchr(extlist, ','))
1068                 extlist[strlen(extlist) - strlen(strchr(extlist, ','))] = '\0';
1069
1070         pkg_type = strchr(extlist, '.') + 1;
1071         return strdup(pkg_type);
1072 }
1073
1074 static int __change_op_cb_for_enable_disable_splash_screen(pkgmgr_client *pc,
1075                 bool is_enable)
1076 {
1077         int ret;
1078         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1079         req_cb_info *tmp;
1080         req_cb_info *prev;
1081
1082         if (mpc == NULL) {
1083                 ERR("package mananger client pc is NULL");
1084                 return PKGMGR_R_EINVAL;
1085         }
1086
1087         for (tmp = mpc->info.request.rhead; tmp;) {
1088                 prev = tmp;
1089                 tmp = tmp->next;
1090                 free(prev);
1091         }
1092
1093         ret = comm_client_free(mpc->info.request.cc);
1094         if (ret < 0) {
1095                 ERR("comm_client_free() failed - %d", ret);
1096                 return PKGMGR_R_ERROR;
1097         }
1098
1099         mpc->ctype = PC_REQUEST;
1100         if (is_enable)
1101                 mpc->status_type = PKGMGR_CLIENT_STATUS_ENABLE_APP_SPLASH_SCREEN;
1102         else
1103                 mpc->status_type = PKGMGR_CLIENT_STATUS_DISABLE_APP_SPLASH_SCREEN;
1104
1105         mpc->info.request.cc = comm_client_new();
1106         if (mpc->info.request.cc == NULL) {
1107                 ERR("client creation failed");
1108                 return PKGMGR_R_ENOMEM;
1109         }
1110
1111         if (is_enable)
1112                 ret = comm_client_set_status_callback(
1113                                 COMM_STATUS_BROADCAST_ENABLE_APP_SPLASH_SCREEN,
1114                                 mpc->info.request.cc, __operation_callback, pc);
1115         else
1116                 ret = comm_client_set_status_callback(
1117                                 COMM_STATUS_BROADCAST_DISABLE_APP_SPLASH_SCREEN,
1118                                 mpc->info.request.cc, __operation_callback, pc);
1119
1120         if (ret < 0) {
1121                 ERR("set_status_callback() failed - %d", ret);
1122                 return PKGMGR_R_ERROR;
1123         }
1124
1125         return PKGMGR_R_OK;
1126 }
1127
1128 API int pkgmgr_client_set_tep_path(pkgmgr_client *pc, char *tep_path, char *tep_move)
1129 {
1130         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1131         retvm_if(tep_path == NULL, PKGMGR_R_EINVAL, "tep path is NULL");
1132         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1133
1134         mpc->tep_path = strdup(tep_path);
1135         mpc->tep_move = strdup(tep_move);
1136
1137         return PKGMGR_R_OK;
1138 }
1139
1140 API int pkgmgr_client_usr_install(pkgmgr_client *pc, const char *pkg_type,
1141                 const char *descriptor_path, const char *pkg_path,
1142                 const char *optional_data, pkgmgr_mode mode,
1143                 pkgmgr_handler event_cb, void *data, uid_t uid)
1144 {
1145         GVariant *result;
1146         int ret = PKGMGR_R_ECOMM;
1147         char *req_key = NULL;
1148         GVariantBuilder *builder = NULL;
1149         GVariant *args = NULL;
1150         int req_id;
1151         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1152         char *pkgtype;
1153
1154         if (pc == NULL || pkg_path == NULL) {
1155                 ERR("invalid parameter");
1156                 return PKGMGR_R_EINVAL;
1157         }
1158
1159         if (mpc->ctype != PC_REQUEST) {
1160                 ERR("mpc->ctype is not PC_REQUEST");
1161                 return PKGMGR_R_EINVAL;
1162         }
1163
1164         if (access(pkg_path, F_OK) != 0) {
1165                 ERR("failed to access: %s", pkg_path);
1166                 return PKGMGR_R_EINVAL;
1167         }
1168
1169         if (mpc->tep_path != NULL && access(mpc->tep_path, F_OK) != 0) {
1170                 ERR("failed to access: %s", mpc->tep_path);
1171                 return PKGMGR_R_EINVAL;
1172         }
1173
1174         /* TODO: check pkg's type on server-side */
1175         if (pkg_type == NULL)
1176                 pkgtype = __get_type_from_path(pkg_path);
1177         else
1178                 pkgtype = strdup(pkg_type);
1179
1180         /* build arguments */
1181         builder = g_variant_builder_new(G_VARIANT_TYPE("as"));
1182         if (mpc->tep_path) {
1183                 g_variant_builder_add(builder, "s", "-e");
1184                 g_variant_builder_add(builder, "s", mpc->tep_path);
1185                 g_variant_builder_add(builder, "s", "-M");
1186                 g_variant_builder_add(builder, "s", mpc->tep_move);
1187         }
1188
1189         args = g_variant_new("as", builder);
1190         g_variant_builder_unref(builder);
1191
1192         ret = comm_client_request(mpc->info.request.cc, "install",
1193                         g_variant_new("(uss@as)", uid, pkgtype, pkg_path, args),
1194                         &result);
1195         if (ret != PKGMGR_R_OK) {
1196                 ERR("request failed: %d", ret);
1197                 return ret;
1198         }
1199
1200         g_variant_get(result, "(i&s)", &ret, &req_key);
1201         if (req_key == NULL) {
1202                 g_variant_unref(result);
1203                 return PKGMGR_R_ECOMM;
1204         }
1205         if (ret != PKGMGR_R_OK) {
1206                 g_variant_unref(result);
1207                 return ret;
1208         }
1209
1210         req_id = _get_request_id();
1211         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1212
1213         g_variant_unref(result);
1214
1215         return req_id;
1216 }
1217
1218 API int pkgmgr_client_install(pkgmgr_client *pc, const char *pkg_type,
1219                 const char *descriptor_path, const char *pkg_path,
1220                 const char *optional_data, pkgmgr_mode mode,
1221                 pkgmgr_handler event_cb, void *data)
1222 {
1223         return pkgmgr_client_usr_install(pc, pkg_type, descriptor_path,
1224                         pkg_path, optional_data, mode, event_cb,data,
1225                         _getuid());
1226 }
1227
1228 API int pkgmgr_client_reinstall(pkgmgr_client *pc, const char *pkg_type,
1229                 const char *pkgid, const char *optional_data, pkgmgr_mode mode,
1230                 pkgmgr_handler event_cb, void *data)
1231 {
1232         return pkgmgr_client_usr_reinstall(pc, pkg_type, pkgid, optional_data,
1233                         mode, event_cb, data, _getuid());
1234 }
1235
1236 API int pkgmgr_client_usr_reinstall(pkgmgr_client * pc, const char *pkg_type,
1237                 const char *pkgid, const char *optional_data, pkgmgr_mode mode,
1238                 pkgmgr_handler event_cb, void *data, uid_t uid)
1239 {
1240         GVariant *result;
1241         int ret = PKGMGR_R_ECOMM;
1242         char *req_key = NULL;
1243         int req_id;
1244         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1245         char *pkgtype;
1246         pkgmgrinfo_pkginfo_h handle;
1247
1248         if (pc == NULL || pkgid == NULL) {
1249                 ERR("invalid parameter");
1250                 return PKGMGR_R_EINVAL;
1251         }
1252
1253         if (mpc->ctype != PC_REQUEST) {
1254                 ERR("mpc->ctype is not PC_REQUEST");
1255                 return PKGMGR_R_EINVAL;
1256         }
1257
1258         ret = pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, uid, &handle);
1259         if (ret < 0)
1260                 return PKGMGR_R_EINVAL;
1261
1262         ret = pkgmgrinfo_pkginfo_get_type(handle, &pkgtype);
1263         if (ret < 0) {
1264                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1265                 return PKGMGR_R_ERROR;
1266         }
1267
1268         ret = comm_client_request(mpc->info.request.cc, "reinstall",
1269                         g_variant_new("(uss)", uid, pkgtype, pkgid), &result);
1270         pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1271         if (ret != PKGMGR_R_OK) {
1272                 ERR("request failed: %d", ret);
1273                 return ret;
1274         }
1275
1276         g_variant_get(result, "(i&s)", &ret, &req_key);
1277         if (req_key == NULL) {
1278                 g_variant_unref(result);
1279                 return PKGMGR_R_ECOMM;
1280         }
1281         if (ret != PKGMGR_R_OK) {
1282                 g_variant_unref(result);
1283                 return ret;
1284         }
1285
1286         req_id = _get_request_id();
1287         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1288
1289         g_variant_unref(result);
1290
1291         return req_id;
1292 }
1293
1294 API int pkgmgr_client_uninstall(pkgmgr_client *pc, const char *pkg_type,
1295                 const char *pkgid, pkgmgr_mode mode, pkgmgr_handler event_cb,
1296                 void *data)
1297 {
1298         return pkgmgr_client_usr_uninstall(pc, pkg_type,pkgid, mode, event_cb,
1299                         data, _getuid());
1300 }
1301
1302 API int pkgmgr_client_usr_uninstall(pkgmgr_client *pc, const char *pkg_type,
1303                 const char *pkgid, pkgmgr_mode mode, pkgmgr_handler event_cb,
1304                 void *data, uid_t uid)
1305 {
1306         GVariant *result;
1307         int ret = PKGMGR_R_ECOMM;
1308         char *req_key = NULL;
1309         int req_id;
1310         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1311         char *pkgtype;
1312         pkgmgrinfo_pkginfo_h handle;
1313
1314         if (pc == NULL || pkgid == NULL) {
1315                 ERR("invalid parameter");
1316                 return PKGMGR_R_EINVAL;
1317         }
1318
1319         if (mpc->ctype != PC_REQUEST) {
1320                 ERR("mpc->ctype is not PC_REQUEST");
1321                 return PKGMGR_R_EINVAL;
1322         }
1323
1324         ret = pkgmgrinfo_pkginfo_get_usr_pkginfo(pkgid, uid, &handle);
1325         if (ret < 0)
1326                 return PKGMGR_R_EINVAL;
1327
1328         ret = pkgmgrinfo_pkginfo_get_type(handle, &pkgtype);
1329         if (ret < 0) {
1330                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1331                 return PKGMGR_R_ERROR;
1332         }
1333
1334         ret = comm_client_request(mpc->info.request.cc, "uninstall",
1335                         g_variant_new("(uss)", uid, pkgtype, pkgid), &result);
1336         if (ret != PKGMGR_R_OK) {
1337                 ERR("request failed: %d", ret);
1338                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1339                 return ret;
1340         }
1341
1342         g_variant_get(result, "(i&s)", &ret, &req_key);
1343         if (req_key == NULL) {
1344                 g_variant_unref(result);
1345                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1346                 return PKGMGR_R_ECOMM;
1347         }
1348         if (ret != PKGMGR_R_OK) {
1349                 g_variant_unref(result);
1350                 pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1351                 return ret;
1352         }
1353
1354         req_id = _get_request_id();
1355         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
1356
1357         g_variant_unref(result);
1358         pkgmgrinfo_pkginfo_destroy_pkginfo(handle);
1359
1360         return req_id;
1361 }
1362
1363 API int pkgmgr_client_move(pkgmgr_client *pc, const char *pkg_type,
1364                 const char *pkgid, pkgmgr_move_type move_type, pkgmgr_mode mode)
1365 {
1366         return pkgmgr_client_usr_move(pc, pkg_type, pkgid, move_type, mode,
1367                         _getuid());
1368 }
1369 API int pkgmgr_client_usr_move(pkgmgr_client *pc, const char *pkg_type,
1370                 const char *pkgid, pkgmgr_move_type move_type,
1371                 pkgmgr_mode mode, uid_t uid)
1372 {
1373         GVariant *result;
1374         int ret = PKGMGR_R_ECOMM;
1375         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1376
1377         if (pc == NULL || pkg_type == NULL || pkgid == NULL) {
1378                 ERR("invalid parameter");
1379                 return PKGMGR_R_EINVAL;
1380         }
1381
1382         if ((move_type < PM_MOVE_TO_INTERNAL) || (move_type > PM_MOVE_TO_SDCARD))
1383                 return PKGMGR_R_EINVAL;
1384
1385         if (mpc->ctype != PC_REQUEST) {
1386                 ERR("mpc->ctype is not PC_REQUEST");
1387                 return PKGMGR_R_EINVAL;
1388         }
1389
1390         ret = comm_client_request(mpc->info.request.cc, "move",
1391                         g_variant_new("(ussi)", uid, pkg_type, pkgid, move_type), &result);
1392         if (ret != PKGMGR_R_OK) {
1393                 ERR("request failed: %d", ret);
1394                 return ret;
1395         }
1396
1397         g_variant_get(result, "(i)", &ret);
1398         g_variant_unref(result);
1399
1400         return ret;
1401 }
1402
1403 API int pkgmgr_client_usr_activate(pkgmgr_client *pc, const char *pkg_type,
1404                 const char *pkgid, uid_t uid)
1405 {
1406         GVariant *result;
1407         int ret = PKGMGR_R_ECOMM;
1408         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1409
1410         if (pc == NULL || pkgid == NULL || pkg_type == NULL) {
1411                 ERR("invalid parameter");
1412                 return PKGMGR_R_EINVAL;
1413         }
1414
1415         ret = comm_client_request(mpc->info.request.cc, "enable_pkg",
1416                         g_variant_new("(uss)", uid, pkg_type, pkgid), &result);
1417         if (ret != PKGMGR_R_OK) {
1418                 ERR("request failed: %d", ret);
1419                 return ret;
1420         }
1421
1422         g_variant_get(result, "(i)", &ret);
1423         g_variant_unref(result);
1424
1425         return ret;
1426 }
1427
1428 API int pkgmgr_client_activate(pkgmgr_client *pc, const char *pkg_type,
1429                 const char *pkgid)
1430 {
1431         return pkgmgr_client_usr_activate(pc, pkg_type, pkgid, _getuid());
1432 }
1433
1434 API int pkgmgr_client_usr_deactivate(pkgmgr_client *pc, const char *pkg_type,
1435                                  const char *pkgid, uid_t uid)
1436 {
1437         GVariant *result;
1438         int ret = PKGMGR_R_ECOMM;
1439         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1440
1441         if (pc == NULL || pkgid == NULL || pkg_type == NULL) {
1442                 ERR("invalid parameter");
1443                 return PKGMGR_R_EINVAL;
1444         }
1445
1446         ret = comm_client_request(mpc->info.request.cc, "disable_pkg",
1447                         g_variant_new("(uss)", uid, pkg_type, pkgid), &result);
1448         if (ret != PKGMGR_R_OK) {
1449                 ERR("request failed: %d", ret);
1450                 return ret;
1451         }
1452
1453         g_variant_get(result, "(i)", &ret);
1454         g_variant_unref(result);
1455
1456         return ret;
1457 }
1458
1459 API int pkgmgr_client_deactivate(pkgmgr_client *pc, const char *pkg_type,
1460                                  const char *pkgid)
1461 {
1462         return pkgmgr_client_usr_deactivate(pc, pkg_type, pkgid, _getuid());
1463 }
1464
1465 /* TODO: deprecate? */
1466 API int pkgmgr_client_usr_activate_appv(pkgmgr_client *pc, const char *appid,
1467                 char *const argv[], uid_t uid)
1468 {
1469         return pkgmgr_client_usr_activate_app(pc, appid, NULL, uid);
1470 }
1471
1472 API int pkgmgr_client_activate_appv(pkgmgr_client *pc, const char *appid,
1473                 char *const argv[])
1474 {
1475         return pkgmgr_client_usr_activate_app(pc, appid, NULL, _getuid());
1476 }
1477
1478 API int pkgmgr_client_usr_activate_app(pkgmgr_client *pc, const char *appid,
1479                 pkgmgr_app_handler app_event_cb, uid_t uid)
1480 {
1481         GVariant *result;
1482         int ret = PKGMGR_R_ECOMM;
1483         int req_id;
1484         char *req_key = NULL;
1485         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1486
1487         if (pc == NULL || appid == NULL) {
1488                 ERR("invalid parameter");
1489                 return PKGMGR_R_EINVAL;
1490         }
1491
1492         if (__change_op_cb_for_enable_disable(mpc, false) < 0) {
1493                 ERR("__change_op_cb_for_enable_disable failed");
1494                 return PKGMGR_R_ESYSTEM;
1495         }
1496
1497         ret = comm_client_request(mpc->info.request.cc, "enable_app",
1498                         g_variant_new("(us)", uid, appid), &result);
1499         if (ret != PKGMGR_R_OK) {
1500                 ERR("request failed: %d", ret);
1501                 return ret;
1502         }
1503
1504         g_variant_get(result, "(i&s)", &ret, &req_key);
1505         if (req_key == NULL) {
1506                 g_variant_unref(result);
1507                 return PKGMGR_R_ECOMM;
1508         }
1509         if (ret != PKGMGR_R_OK) {
1510                 g_variant_unref(result);
1511                 return ret;
1512         }
1513
1514         req_id = _get_request_id();
1515         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1516         g_variant_unref(result);
1517         return ret;
1518 }
1519
1520 API int pkgmgr_client_activate_app(pkgmgr_client * pc, const char *appid, pkgmgr_app_handler app_event_cb)
1521 {
1522         return pkgmgr_client_usr_activate_app(pc, appid, app_event_cb, _getuid());
1523 }
1524
1525 API int pkgmgr_client_activate_global_app_for_uid(pkgmgr_client *pc,
1526                                  const char *appid, pkgmgr_app_handler app_event_cb, uid_t uid)
1527 {
1528         GVariant *result;
1529         int ret = PKGMGR_R_ECOMM;
1530         int req_id;
1531         char *req_key = NULL;
1532         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1533
1534         if (pc == NULL || appid == NULL) {
1535                 ERR("invalid parameter");
1536                 return PKGMGR_R_EINVAL;
1537         }
1538
1539         if (__change_op_cb_for_enable_disable(mpc, false) < 0) {
1540                 ERR("__change_op_cb_for_enable_disable failed");
1541                 return PKGMGR_R_ESYSTEM;
1542         }
1543
1544         ret = comm_client_request(mpc->info.request.cc, "enable_global_app_for_uid",
1545                         g_variant_new("(us)", uid, appid), &result);
1546         if (ret != PKGMGR_R_OK) {
1547                 ERR("request failed: %d", ret);
1548                 return ret;
1549         }
1550
1551         g_variant_get(result, "(i&s)", &ret, &req_key);
1552         if (req_key == NULL) {
1553                 g_variant_unref(result);
1554                 return PKGMGR_R_ECOMM;
1555         }
1556         if (ret != PKGMGR_R_OK) {
1557                 g_variant_unref(result);
1558                 return ret;
1559         }
1560
1561         req_id = _get_request_id();
1562         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1563
1564         return ret;
1565 }
1566
1567 API int pkgmgr_client_usr_deactivate_app(pkgmgr_client *pc, const char *appid,
1568                 pkgmgr_app_handler app_event_cb, uid_t uid)
1569 {
1570         GVariant *result;
1571         int ret = PKGMGR_R_ECOMM;
1572         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1573         int req_id;
1574         char *req_key = NULL;
1575
1576         if (pc == NULL || appid == NULL) {
1577                 ERR("invalid parameter");
1578                 return PKGMGR_R_EINVAL;
1579         }
1580
1581         /* FIXME */
1582         if (__change_op_cb_for_enable_disable(mpc, true) < 0) {
1583                 ERR("__change_op_cb_for_enable_disable failed");
1584                 return PKGMGR_R_ESYSTEM;
1585         }
1586
1587         ret = comm_client_request(mpc->info.request.cc, "disable_app",
1588                         g_variant_new("(us)", uid, appid), &result);
1589         if (ret != PKGMGR_R_OK) {
1590                 ERR("request failed: %d", ret);
1591                 return ret;
1592         }
1593
1594         g_variant_get(result, "(i&s)", &ret, &req_key);
1595         if (req_key == NULL) {
1596                 g_variant_unref(result);
1597                 return PKGMGR_R_ECOMM;
1598         }
1599         if (ret != PKGMGR_R_OK) {
1600                 g_variant_unref(result);
1601                 return ret;
1602         }
1603
1604         req_id = _get_request_id();
1605         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1606
1607         g_variant_unref(result);
1608         return ret;
1609 }
1610
1611 API int pkgmgr_client_deactivate_app(pkgmgr_client *pc, const char *appid, pkgmgr_app_handler app_event_cb)
1612 {
1613         return pkgmgr_client_usr_deactivate_app(pc, appid, app_event_cb, _getuid());
1614 }
1615
1616 API int pkgmgr_client_deactivate_global_app_for_uid(pkgmgr_client *pc,
1617                                  const char *appid, pkgmgr_app_handler app_event_cb, uid_t uid)
1618 {
1619         GVariant *result;
1620         int ret = PKGMGR_R_ECOMM;
1621         int req_id;
1622         char *req_key = NULL;
1623         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1624
1625         if (pc == NULL || appid == NULL) {
1626                 ERR("invalid parameter");
1627                 return PKGMGR_R_EINVAL;
1628         }
1629
1630         if (__change_op_cb_for_enable_disable(mpc, true) < 0) {
1631                 ERR("__change_op_cb_for_enable_disable failed");
1632                 return PKGMGR_R_ESYSTEM;
1633         }
1634
1635         ret = comm_client_request(mpc->info.request.cc, "disable_global_app_for_uid",
1636                         g_variant_new("(us)", uid, appid), &result);
1637         if (ret != PKGMGR_R_OK) {
1638                 ERR("request failed: %d", ret);
1639                 return ret;
1640         }
1641
1642         g_variant_get(result, "(i&s)", &ret, &req_key);
1643         if (req_key == NULL) {
1644                 g_variant_unref(result);
1645                 return PKGMGR_R_ECOMM;
1646         }
1647         if (ret != PKGMGR_R_OK) {
1648                 g_variant_unref(result);
1649                 return ret;
1650         }
1651
1652         req_id = _get_request_id();
1653         __add_op_app_cbinfo(pc, req_id, req_key, app_event_cb, NULL);
1654         return ret;
1655 }
1656
1657 API int pkgmgr_client_usr_clear_user_data(pkgmgr_client *pc,
1658                 const char *pkg_type, const char *appid, pkgmgr_mode mode,
1659                 uid_t uid)
1660 {
1661         GVariant *result;
1662         int ret = PKGMGR_R_ECOMM;
1663         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1664
1665         if (pc == NULL || pkg_type == NULL || appid == NULL) {
1666                 ERR("invalid parameter");
1667                 return PKGMGR_R_EINVAL;
1668         }
1669
1670         if (mpc->ctype != PC_REQUEST) {
1671                 ERR("mpc->ctype is not PC_REQUEST");
1672                 return PKGMGR_R_EINVAL;
1673         }
1674
1675         ret = comm_client_request(mpc->info.request.cc, "cleardata",
1676                         g_variant_new("(uss)", uid, pkg_type, appid), &result);
1677         if (ret == PKGMGR_R_OK) {
1678                 ERR("request failed: %d", ret);
1679                 return ret;
1680         }
1681
1682         g_variant_get(result, "(i)", &ret);
1683         g_variant_unref(result);
1684
1685         return ret;
1686 }
1687
1688 API int pkgmgr_client_clear_user_data(pkgmgr_client *pc, const char *pkg_type,
1689                 const char *appid, pkgmgr_mode mode)
1690 {
1691         return pkgmgr_client_usr_clear_user_data(pc, pkg_type, appid, mode,
1692                         _getuid());
1693 }
1694
1695 API int pkgmgr_client_set_status_type(pkgmgr_client *pc, int status_type)
1696 {
1697         int ret = -1;
1698
1699         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1700         retvm_if(status_type == PKGMGR_CLIENT_STATUS_ALL, PKGMGR_R_OK, "status_type is PKGMGR_CLIENT_STATUS_ALL");
1701         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1702
1703         /*  free listening head */
1704         listen_cb_info *tmp = NULL;
1705         listen_cb_info *prev = NULL;
1706         for (tmp = mpc->info.listening.lhead; tmp;) {
1707                 prev = tmp;
1708                 tmp = tmp->next;
1709                 free(prev);
1710         }
1711
1712         /* free dbus connection */
1713         ret = comm_client_free(mpc->info.listening.cc);
1714         retvm_if(ret < 0, PKGMGR_R_ERROR, "comm_client_free() failed - %d", ret);
1715
1716         /* Manage pc for seperated event */
1717         mpc->ctype = PC_LISTENING;
1718         mpc->status_type = status_type;
1719
1720         mpc->info.listening.cc = comm_client_new();
1721         retvm_if(mpc->info.listening.cc == NULL, PKGMGR_R_EINVAL, "client creation failed");
1722
1723         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_INSTALL) == PKGMGR_CLIENT_STATUS_INSTALL) {
1724                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_INSTALL, mpc->info.listening.cc, __status_callback, pc);
1725                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "PKGMGR_CLIENT_STATUS_INSTALL failed - %d", ret);
1726         }
1727
1728         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_UNINSTALL) == PKGMGR_CLIENT_STATUS_UNINSTALL) {
1729                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_UNINSTALL, mpc->info.listening.cc, __status_callback, pc);
1730                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_UNINSTALL failed - %d", ret);
1731         }
1732
1733         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_MOVE) == PKGMGR_CLIENT_STATUS_MOVE) {
1734                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_MOVE, mpc->info.listening.cc, __status_callback, pc);
1735                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_MOVE failed - %d", ret);
1736         }
1737
1738         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_INSTALL_PROGRESS) == PKGMGR_CLIENT_STATUS_INSTALL_PROGRESS) {
1739                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_INSTALL_PROGRESS, mpc->info.listening.cc, __status_callback, pc);
1740                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_INSTALL_PROGRESS failed - %d", ret);
1741         }
1742
1743         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_UPGRADE) == PKGMGR_CLIENT_STATUS_UPGRADE) {
1744                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_UPGRADE, mpc->info.listening.cc, __status_callback, pc);
1745                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_UPGRADE failed - %d", ret);
1746         }
1747
1748         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_ENABLE_APP) == PKGMGR_CLIENT_STATUS_ENABLE_APP) {
1749                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ENABLE_APP, mpc->info.listening.cc, __status_callback, pc);
1750                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_ENABLE_APP failed - %d", ret);
1751         }
1752
1753         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_DISABLE_APP) == PKGMGR_CLIENT_STATUS_DISABLE_APP) {
1754                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_DISABLE_APP, mpc->info.listening.cc, __status_callback, pc);
1755                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_DISABLE_APP failed - %d", ret);
1756         }
1757
1758         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_ENABLE_APP_SPLASH_SCREEN) == PKGMGR_CLIENT_STATUS_ENABLE_APP_SPLASH_SCREEN) {
1759                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_ENABLE_APP_SPLASH_SCREEN, mpc->info.listening.cc, __status_callback, pc);
1760                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_ENABLE_APP_SPLASH_SCREEN failed - %d", ret);
1761         }
1762
1763         if ((mpc->status_type & PKGMGR_CLIENT_STATUS_DISABLE_APP_SPLASH_SCREEN) == PKGMGR_CLIENT_STATUS_DISABLE_APP_SPLASH_SCREEN) {
1764                 ret = comm_client_set_status_callback(COMM_STATUS_BROADCAST_DISABLE_APP_SPLASH_SCREEN, mpc->info.listening.cc, __status_callback, pc);
1765                 retvm_if(ret < 0, PKGMGR_R_ECOMM, "COMM_STATUS_BROADCAST_DISABLE_APP_SPLASH_SCREEN failed - %d", ret);
1766         }
1767
1768         return PKGMGR_R_OK;
1769 }
1770
1771 API int pkgmgr_client_listen_status(pkgmgr_client *pc, pkgmgr_handler event_cb,
1772                                     void *data)
1773 {
1774         int req_id;
1775         /* Check for NULL value of pc */
1776         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1777         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1778
1779         /* 0. check input */
1780         retvm_if(mpc->ctype != PC_LISTENING, PKGMGR_R_EINVAL, "ctype is not PC_LISTENING");
1781         retvm_if(event_cb == NULL, PKGMGR_R_EINVAL, "event_cb is NULL");
1782
1783         /* 1. get id */
1784         req_id = _get_request_id();
1785
1786         /* 2. add callback info to pkgmgr_client */
1787         __add_stat_cbinfo(mpc, req_id, event_cb, data);
1788         return req_id;
1789 }
1790
1791 API int pkgmgr_client_listen_app_status(pkgmgr_client *pc, pkgmgr_app_handler event_cb,
1792                                     void *data)
1793 {
1794         int req_id;
1795         /* Check for NULL value of pc */
1796         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1797         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1798
1799         /* 0. check input */
1800         retvm_if(mpc->ctype != PC_LISTENING, PKGMGR_R_EINVAL, "ctype is not PC_LISTENING");
1801         retvm_if(event_cb == NULL, PKGMGR_R_EINVAL, "event_cb is NULL");
1802
1803         /* 1. get id */
1804         req_id = _get_request_id();
1805
1806         /* 2. add app callback info to pkgmgr_client */
1807         __add_app_stat_cbinfo(mpc, req_id, event_cb, data);
1808         return req_id;
1809 }
1810
1811 API int pkgmgr_client_remove_listen_status(pkgmgr_client *pc)
1812 {
1813         int ret = -1;
1814
1815         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "package manager client pc is NULL");
1816         pkgmgr_client_t *mpc = (pkgmgr_client_t *) pc;
1817
1818         ret = __remove_stat_cbinfo(mpc);
1819         if (ret != 0) {
1820                 ERR("failed to remove status callback");
1821                 return PKGMGR_R_ERROR;
1822         }
1823
1824         return PKGMGR_R_OK;
1825 }
1826
1827 API int pkgmgr_client_broadcast_status(pkgmgr_client *pc, const char *pkg_type,
1828                                        const char *pkgid, const char *key,
1829                                        const char *val)
1830 {
1831         /* client cannot broadcast signal */
1832         return PKGMGR_R_OK;
1833 }
1834
1835 API int pkgmgr_client_request_service(pkgmgr_request_service_type service_type, int service_mode,
1836                                   pkgmgr_client * pc, const char *pkg_type, const char *pkgid,
1837                               const char *custom_info, pkgmgr_handler event_cb, void *data)
1838 {
1839         return pkgmgr_client_usr_request_service(service_type, service_mode, pc, pkg_type, pkgid, _getuid(), custom_info, event_cb, data);
1840 }
1841
1842 API int pkgmgr_client_usr_request_service(pkgmgr_request_service_type service_type, int service_mode,
1843                                   pkgmgr_client * pc, const char *pkg_type, const char *pkgid, uid_t uid,
1844                               const char *custom_info, pkgmgr_handler event_cb, void *data)
1845 {
1846         int ret =0;
1847
1848         /* Check for NULL value of service type */
1849         retvm_if(service_type > PM_REQUEST_MAX, PKGMGR_R_EINVAL, "service type is not defined\n");
1850         retvm_if(service_type < 0, PKGMGR_R_EINVAL, "service type is error\n");
1851
1852         switch (service_type) {
1853         case PM_REQUEST_CSC:
1854                 tryvm_if(custom_info == NULL, ret = PKGMGR_R_EINVAL, "custom_info is NULL\n");
1855                 tryvm_if(strlen(custom_info) >= PKG_STRING_LEN_MAX, ret = PKGMGR_R_EINVAL, "custom_info over PKG_STRING_LEN_MAX");
1856                 tryvm_if(data == NULL, ret = PKGMGR_R_EINVAL, "data is NULL\n");
1857
1858                 ret = __csc_process(custom_info, (char *)data);
1859                 if (ret < 0)
1860                         ERR("__csc_process fail \n");
1861                 else
1862                         ret = PKGMGR_R_OK;
1863
1864                 break;
1865
1866         case PM_REQUEST_MOVE:
1867                 tryvm_if(pkgid == NULL, ret = PKGMGR_R_EINVAL, "pkgid is NULL\n");
1868                 tryvm_if(pc == NULL, ret = PKGMGR_R_EINVAL, "pc is NULL\n");
1869                 tryvm_if((service_mode < PM_MOVE_TO_INTERNAL) || (service_mode > PM_MOVE_TO_SDCARD), ret = PKGMGR_R_EINVAL, "service_mode is wrong\n");
1870
1871                 ret = __move_pkg_process(pc, pkgid, pkg_type, uid, (pkgmgr_move_type)service_mode, event_cb, data);
1872                 break;
1873
1874         case PM_REQUEST_GET_SIZE:
1875                 tryvm_if(pkgid == NULL, ret = PKGMGR_R_EINVAL, "pkgid is NULL\n");
1876                 tryvm_if(pc == NULL, ret = PKGMGR_R_EINVAL, "pc is NULL\n");
1877                 tryvm_if((service_mode < PM_GET_TOTAL_SIZE) || (service_mode >= PM_GET_MAX), ret = PKGMGR_R_EINVAL, "service_mode is wrong\n");
1878
1879                 ret = __get_size_process(pc, pkgid, uid, (pkgmgr_getsize_type)service_mode, event_cb, data);
1880                 break;
1881
1882         case PM_REQUEST_KILL_APP:
1883         case PM_REQUEST_CHECK_APP:
1884                 tryvm_if(pkgid == NULL, ret = PKGMGR_R_EINVAL, "pkgid is NULL\n");
1885                 tryvm_if(pc == NULL, ret = PKGMGR_R_EINVAL, "pc is NULL\n");
1886
1887                 ret = __check_app_process(service_type, pc, pkgid, uid, data);
1888                 if (ret < 0)
1889                         ERR("__check_app_process fail \n");
1890                 else
1891                         ret = PKGMGR_R_OK;
1892
1893                 break;
1894
1895         default:
1896                 ERR("Wrong Request\n");
1897                 ret = -1;
1898                 break;
1899         }
1900
1901 catch:
1902
1903         return ret;
1904 }
1905
1906
1907 API int pkgmgr_client_usr_request_size_info(uid_t uid)
1908 {
1909         int ret = 0;
1910         pkgmgr_client *pc = NULL;
1911
1912         pc = pkgmgr_client_new(PC_REQUEST);
1913         retvm_if(pc == NULL, PKGMGR_R_EINVAL, "request pc is null\n");
1914
1915         ret = __request_size_info(pc, uid);
1916         if (ret < 0) {
1917                 ERR("__request_size_info fail \n");
1918         }
1919
1920         pkgmgr_client_free(pc);
1921         return ret;
1922 }
1923
1924 API int pkgmgr_client_request_size_info(void) // get all package size (data, total)
1925 {
1926         return pkgmgr_client_usr_request_size_info(_getuid());
1927 }
1928
1929 API int pkgmgr_client_usr_clear_cache_dir(const char *pkgid, uid_t uid)
1930 {
1931         GVariant *result;
1932         int ret = PKGMGR_R_ECOMM;
1933         pkgmgr_client_t *pc;
1934
1935         if (pkgid == NULL) {
1936                 ERR("invalid parameter");
1937                 return PKGMGR_R_EINVAL;
1938         }
1939
1940         pc = pkgmgr_client_new(PC_REQUEST);
1941         if (pc == NULL) {
1942                 ERR("out of memory");
1943                 return PKGMGR_R_ESYSTEM;
1944         }
1945
1946         ret = comm_client_request(pc->info.request.cc, "clearcache",
1947                         g_variant_new("(us)", uid, pkgid), &result);
1948         if (ret != PKGMGR_R_OK) {
1949                 ERR("request failed: %d", ret);
1950                 return ret;
1951         }
1952
1953         g_variant_get(result, "(i)", &ret);
1954         g_variant_unref(result);
1955
1956         return ret;
1957 }
1958
1959 API int pkgmgr_client_clear_cache_dir(const char *pkgid)
1960 {
1961         return pkgmgr_client_usr_clear_cache_dir(pkgid, _getuid());
1962 }
1963
1964 API int pkgmgr_client_clear_usr_all_cache_dir(uid_t uid)
1965 {
1966         return pkgmgr_client_usr_clear_cache_dir(PKG_CLEAR_ALL_CACHE, uid);
1967 }
1968
1969 API int pkgmgr_client_clear_all_cache_dir(void)
1970 {
1971         return pkgmgr_client_usr_clear_cache_dir(PKG_CLEAR_ALL_CACHE, _getuid());
1972 }
1973
1974 API int pkgmgr_client_get_size(pkgmgr_client * pc, const char *pkgid,
1975                 pkgmgr_getsize_type get_type, pkgmgr_handler event_cb,
1976                 void *data)
1977 {
1978         return pkgmgr_client_usr_get_size(pc, pkgid, get_type, event_cb, data,
1979                         _getuid());
1980 }
1981
1982 API int pkgmgr_client_usr_get_size(pkgmgr_client * pc, const char *pkgid,
1983                 pkgmgr_getsize_type get_type, pkgmgr_handler event_cb,
1984                 void *data, uid_t uid)
1985 {
1986         GVariant *result;
1987         int ret = PKGMGR_R_ECOMM;
1988         char *req_key = NULL;
1989         int req_id;
1990         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
1991
1992         if (pc == NULL || pkgid == NULL || event_cb == NULL) {
1993                 ERR("invalid parameter");
1994                 return PKGMGR_R_EINVAL;
1995         }
1996
1997         if (mpc->ctype != PC_REQUEST) {
1998                 ERR("mpc->ctype is not PC_REQUEST");
1999                 return PKGMGR_R_EINVAL;
2000         }
2001
2002         /* FIXME */
2003         if (strcmp(pkgid, PKG_SIZE_INFO_TOTAL) == 0)
2004                 get_type = PM_GET_TOTAL_PKG_SIZE_INFO;
2005         else
2006                 get_type = PM_GET_PKG_SIZE_INFO;
2007
2008         ret = comm_client_request(mpc->info.request.cc, "getsize",
2009                         g_variant_new("(usi)", uid, pkgid, get_type), &result);
2010         if (ret != PKGMGR_R_OK) {
2011                 ERR("request failed: %d", ret);
2012                 return ret;
2013         }
2014
2015         g_variant_get(result, "(i&s)", &ret, &req_key);
2016         if (req_key == NULL) {
2017                 g_variant_unref(result);
2018                 return PKGMGR_R_ECOMM;
2019         }
2020         if (ret != PKGMGR_R_OK) {
2021                 g_variant_unref(result);
2022                 return ret;
2023         }
2024
2025         req_id = _get_request_id();
2026         __add_op_cbinfo(mpc, req_id, req_key, event_cb, NULL, data);
2027
2028         g_variant_unref(result);
2029
2030         return PKGMGR_R_OK;
2031 }
2032
2033 API int pkgmgr_client_usr_get_package_size_info(pkgmgr_client *pc,
2034                 const char *pkgid, pkgmgr_pkg_size_info_receive_cb event_cb,
2035                 void *user_data, uid_t uid)
2036 {
2037         GVariant *result;
2038         int ret = PKGMGR_R_ECOMM;
2039         char *req_key = NULL;
2040         int req_id;
2041         int get_type;
2042         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2043
2044         if (pc == NULL || pkgid == NULL || event_cb == NULL) {
2045                 ERR("invalid parameter");
2046                 return PKGMGR_R_EINVAL;
2047         }
2048
2049         if (mpc->ctype != PC_REQUEST) {
2050                 ERR("mpc->ctype is not PC_REQUEST");
2051                 return PKGMGR_R_EINVAL;
2052         }
2053
2054         /* FIXME */
2055         if (__change_op_cb_for_getsize(mpc) < 0) {
2056                 ERR("__change_op_cb_for_getsize failed");
2057                 return PKGMGR_R_ESYSTEM;
2058         }
2059
2060         if (strcmp(pkgid, PKG_SIZE_INFO_TOTAL) == 0)
2061                 get_type = PM_GET_TOTAL_PKG_SIZE_INFO;
2062         else
2063                 get_type = PM_GET_PKG_SIZE_INFO;
2064
2065         ret = comm_client_request(mpc->info.request.cc, "getsize",
2066                         g_variant_new("(usi)", uid, pkgid, get_type), &result);
2067         if (ret != PKGMGR_R_OK) {
2068                 ERR("request failed: %d", ret);
2069                 return ret;
2070         }
2071
2072         g_variant_get(result, "(i&s)", &ret, &req_key);
2073         if (req_key == NULL) {
2074                 g_variant_unref(result);
2075                 return PKGMGR_R_ECOMM;
2076         }
2077         if (ret != PKGMGR_R_OK) {
2078                 g_variant_unref(result);
2079                 return ret;
2080         }
2081
2082         req_id = _get_request_id();
2083         __add_op_cbinfo(mpc, req_id, req_key, __get_pkg_size_info_cb, event_cb,
2084                         user_data);
2085
2086         g_variant_unref(result);
2087
2088         return PKGMGR_R_OK;
2089 }
2090
2091 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)
2092 {
2093         return pkgmgr_client_usr_get_package_size_info(pc, pkgid, event_cb, user_data, _getuid());
2094 }
2095
2096 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)
2097 {       // total package size info
2098         return pkgmgr_client_usr_get_package_size_info(pc, PKG_SIZE_INFO_TOTAL, (pkgmgr_pkg_size_info_receive_cb)event_cb, user_data, uid);
2099 }
2100
2101 API int pkgmgr_client_get_total_package_size_info(pkgmgr_client *pc, pkgmgr_total_pkg_size_info_receive_cb event_cb, void *user_data)
2102 {
2103         return pkgmgr_client_usr_get_package_size_info(pc, PKG_SIZE_INFO_TOTAL, (pkgmgr_pkg_size_info_receive_cb)event_cb, user_data, _getuid());
2104 }
2105
2106 API int pkgmgr_client_generate_license_request(pkgmgr_client *pc,
2107                 const char *resp_data, char **req_data, char **license_url)
2108 {
2109         GVariant *result;
2110         int ret;
2111         char *data;
2112         char *url;
2113         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2114
2115         if (pc == NULL || resp_data == NULL || req_data == NULL ||
2116                         license_url == NULL) {
2117                 ERR("invalid parameter");
2118                 return PKGMGR_R_EINVAL;
2119         }
2120
2121         if (mpc->ctype != PC_REQUEST) {
2122                 ERR("mpc->ctype is not PC_REQUEST");
2123                 return PKGMGR_R_EINVAL;
2124         }
2125
2126         ret = comm_client_request(mpc->info.request.cc,
2127                         "generate_license_request",
2128                         g_variant_new("(s)", resp_data), &result);
2129         if (ret != PKGMGR_R_OK) {
2130                 ERR("request failed: %d", ret);
2131                 return ret;
2132         }
2133
2134         g_variant_get(result, "(i&s&s)", &ret, &data, &url);
2135         if (ret != PKGMGR_R_OK) {
2136                 ERR("generate_license_request failed: %d", ret);
2137                 g_variant_unref(result);
2138                 return ret;
2139         }
2140
2141         *req_data = strdup(data);
2142         *license_url = strdup(url);
2143
2144         g_variant_unref(result);
2145
2146         return PKGMGR_R_OK;
2147 }
2148
2149 API int pkgmgr_client_register_license(pkgmgr_client *pc, const char *resp_data)
2150 {
2151         GVariant *result;
2152         int ret;
2153         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2154
2155         if (pc == NULL || resp_data == NULL) {
2156                 ERR("invalid parameter");
2157                 return PKGMGR_R_EINVAL;
2158         }
2159
2160         if (mpc->ctype != PC_REQUEST) {
2161                 ERR("mpc->ctype is not PC_REQUEST");
2162                 return PKGMGR_R_EINVAL;
2163         }
2164
2165         ret = comm_client_request(mpc->info.request.cc,
2166                         "register_license", g_variant_new("(s)", resp_data),
2167                         &result);
2168         if (ret != PKGMGR_R_OK) {
2169                 ERR("request failed: %d", ret);
2170                 return ret;
2171         }
2172
2173         g_variant_get(result, "(i)", &ret);
2174         g_variant_unref(result);
2175         if (ret != PKGMGR_R_OK) {
2176                 ERR("register license failed: %d", ret);
2177                 return ret;
2178         }
2179
2180         return PKGMGR_R_OK;
2181 }
2182
2183 API int pkgmgr_client_decrypt_package(pkgmgr_client *pc,
2184                 const char *drm_file_path, const char *decrypted_file_path)
2185 {
2186         GVariant *result;
2187         int ret;
2188         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2189
2190         if (pc == NULL || drm_file_path == NULL ||
2191                         decrypted_file_path == NULL) {
2192                 ERR("invalid parameter");
2193                 return PKGMGR_R_EINVAL;
2194         }
2195
2196         if (mpc->ctype != PC_REQUEST) {
2197                 ERR("mpc->ctype is not PC_REQUEST");
2198                 return PKGMGR_R_EINVAL;
2199         }
2200
2201         ret = comm_client_request(mpc->info.request.cc,
2202                         "decrypt_package",
2203                         g_variant_new("(ss)", drm_file_path,
2204                                 decrypted_file_path),
2205                         &result);
2206         if (ret != PKGMGR_R_OK) {
2207                 ERR("request failed: %d", ret);
2208                 return ret;
2209         }
2210
2211         g_variant_get(result, "(i)", &ret);
2212         g_variant_unref(result);
2213         if (ret != PKGMGR_R_OK) {
2214                 ERR("decrypt_package failed: %d", ret);
2215                 return ret;
2216         }
2217
2218         return PKGMGR_R_OK;
2219 }
2220
2221 API int pkgmgr_client_usr_add_blacklist(pkgmgr_client *pc, const char *pkgid,
2222                 uid_t uid)
2223 {
2224         GVariant *result;
2225         int ret = PKGMGR_R_ECOMM;
2226         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2227
2228         if (pc == NULL || pkgid == NULL) {
2229                 ERR("invalid parameter");
2230                 return PKGMGR_R_EINVAL;
2231         }
2232
2233         ret = comm_client_request(mpc->info.request.cc, "add_blacklist",
2234                         g_variant_new("(us)", uid, pkgid), &result);
2235         if (ret != PKGMGR_R_OK) {
2236                 ERR("request failed: %d", ret);
2237                 return ret;
2238         }
2239
2240         g_variant_get(result, "(i)", &ret);
2241         g_variant_unref(result);
2242
2243         return ret;
2244 }
2245
2246 API int pkgmgr_client_add_blacklist(pkgmgr_client *pc, const char *pkgid)
2247 {
2248         return pkgmgr_client_usr_add_blacklist(pc, pkgid, _getuid());
2249 }
2250
2251 API int pkgmgr_client_usr_remove_blacklist(pkgmgr_client *pc,
2252                 const char *pkgid, uid_t uid)
2253 {
2254         GVariant *result;
2255         int ret = PKGMGR_R_ECOMM;
2256         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2257
2258         if (pc == NULL || pkgid == NULL) {
2259                 ERR("invalid parameter");
2260                 return PKGMGR_R_EINVAL;
2261         }
2262
2263         ret = comm_client_request(mpc->info.request.cc, "remove_blacklist",
2264                         g_variant_new("(us)", uid, pkgid), &result);
2265         if (ret != PKGMGR_R_OK) {
2266                 ERR("request failed: %d", ret);
2267                 return ret;
2268         }
2269
2270         g_variant_get(result, "(i)", &ret);
2271         g_variant_unref(result);
2272
2273         return ret;
2274 }
2275
2276 API int pkgmgr_client_remove_blacklist(pkgmgr_client *pc,
2277                 const char *pkgid)
2278 {
2279         return pkgmgr_client_usr_remove_blacklist(pc, pkgid, _getuid());
2280 }
2281
2282 API int pkgmgr_client_usr_check_blacklist(pkgmgr_client *pc, const char *pkgid,
2283                 bool *blacklist, uid_t uid)
2284 {
2285         GVariant *result;
2286         int ret = PKGMGR_R_ECOMM;
2287         gint b;
2288         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2289
2290         if (pc == NULL || pkgid == NULL) {
2291                 ERR("invalid parameter");
2292                 return PKGMGR_R_EINVAL;
2293         }
2294
2295         ret = comm_client_request(mpc->info.request.cc, "check_blacklist",
2296                         g_variant_new("(us)", uid, pkgid), &result);
2297         if (ret != PKGMGR_R_OK) {
2298                 ERR("request failed: %d", ret);
2299                 return ret;
2300         }
2301
2302         g_variant_get(result, "(ii)", &b, &ret);
2303         g_variant_unref(result);
2304         if (ret != PKGMGR_R_OK)
2305                 return ret;
2306
2307         if (b)
2308                 *blacklist = true;
2309         else
2310                 *blacklist = false;
2311
2312         return PKGMGR_R_OK;
2313 }
2314
2315 API int pkgmgr_client_check_blacklist(pkgmgr_client *pc, const char *pkgid,
2316                 bool *blacklist)
2317 {
2318         return pkgmgr_client_usr_check_blacklist(pc, pkgid, blacklist,
2319                         _getuid());
2320 }
2321
2322 API int pkgmgr_client_enable_splash_screen(pkgmgr_client *pc, const char *appid)
2323 {
2324         return pkgmgr_client_usr_enable_splash_screen(pc, appid, _getuid());
2325 }
2326
2327 API int pkgmgr_client_usr_enable_splash_screen(pkgmgr_client *pc,
2328                 const char *appid, uid_t uid)
2329 {
2330         int ret;
2331         GVariant *result;
2332         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2333
2334         if (pc == NULL || appid == NULL) {
2335                 ERR("Invalid parameter");
2336                 return PKGMGR_R_EINVAL;
2337         }
2338
2339         ret = __change_op_cb_for_enable_disable_splash_screen(mpc, true);
2340         if (ret < 0) {
2341                 ERR("__change_op_cb_for_enable_disable_splash_screen failed");
2342                 return PKGMGR_R_ESYSTEM;
2343         }
2344
2345         ret = comm_client_request(mpc->info.request.cc,
2346                         "enable_app_splash_screen",
2347                         g_variant_new("(us)", uid, appid), &result);
2348         if (ret != PKGMGR_R_OK) {
2349                 ERR("request failed: %d", ret);
2350                 return ret;
2351         }
2352
2353         g_variant_get(result, "(i)", &ret);
2354         if (ret != PKGMGR_R_OK) {
2355                 g_variant_unref(result);
2356                 return ret;
2357         }
2358
2359         g_variant_unref(result);
2360
2361         return ret;
2362 }
2363
2364 API int pkgmgr_client_disable_splash_screen(pkgmgr_client *pc,
2365                 const char *appid)
2366 {
2367         return pkgmgr_client_usr_disable_splash_screen(pc, appid,
2368                         _getuid());
2369 }
2370
2371 API int pkgmgr_client_usr_disable_splash_screen(pkgmgr_client *pc,
2372                 const char *appid, uid_t uid)
2373 {
2374         int ret;
2375         GVariant *result;
2376         pkgmgr_client_t *mpc = (pkgmgr_client_t *)pc;
2377
2378         if (pc == NULL || appid == NULL) {
2379                 ERR("Invalid parameter");
2380                 return PKGMGR_R_EINVAL;
2381         }
2382
2383         ret = __change_op_cb_for_enable_disable_splash_screen(mpc, false);
2384         if (ret < 0) {
2385                 ERR("__change_op_cb_for_enable_disable_splash_screen failed");
2386                 return ret;
2387         }
2388
2389         ret = comm_client_request(mpc->info.request.cc,
2390                         "disable_app_splash_screen",
2391                         g_variant_new("(us)", uid, appid), &result);
2392         if (ret != PKGMGR_R_OK) {
2393                 ERR("request failed: %d", ret);
2394                 return ret;
2395         }
2396
2397         g_variant_get(result, "(i)", &ret);
2398         if (ret != PKGMGR_R_OK) {
2399                 g_variant_unref(result);
2400                 return ret;
2401         }
2402
2403         g_variant_unref(result);
2404
2405         return ret;
2406 }
2407