6 #include <security-manager.h>
11 SECURITY_MANAGER_SUCCESS,
12 SECURITY_MANAGER_ERROR_INPUT_PARAM,
13 SECURITY_MANAGER_ERROR_MEMORY,
14 SECURITY_MANAGER_ERROR_REQ_NOT_COMPLETE,
15 SECURITY_MANAGER_ERROR_AUTHENTICATION_FAILED,
16 SECURITY_MANAGER_ERROR_ACCESS_DENIED
18 enum app_install_path_type {
19 SECURITY_MANAGER_PATH_PUBLIC_RO,
20 SECURITY_MANAGER_PATH_RO,
21 SECURITY_MANAGER_PATH_RW
23 typedef void app_inst_req;
25 #define security_manager_app_inst_req_free(r) \
26 (printf("security_manager_app_inst_req_free(%p)\n",r),(void)0)
28 #define security_manager_app_inst_req_new(pr) \
29 (*(pr)=(void*)(intptr_t)(++diese), printf("security_manager_app_inst_req_new(%p)\n",*pr), SECURITY_MANAGER_SUCCESS)
31 #define security_manager_app_inst_req_set_pkg_id(r,i) \
32 (printf("security_manager_app_inst_req_set_pkg_id(%p,\"%s\")\n",r,i), SECURITY_MANAGER_SUCCESS)
34 #define security_manager_app_inst_req_set_app_id(r,i) \
35 (printf("security_manager_app_inst_req_set_app_id(%p,\"%s\")\n",r,i), SECURITY_MANAGER_SUCCESS)
37 #define security_manager_app_inst_req_add_privilege(r,p) \
38 (printf("security_manager_app_inst_req_add_privilege(%p,\"%s\")\n",r,p), SECURITY_MANAGER_SUCCESS)
40 #define security_manager_app_inst_req_add_path(r,p,t) \
41 (printf("security_manager_app_inst_req_add_path(%p,\"%s\",%d)\n",r,p,t), SECURITY_MANAGER_SUCCESS)
44 static app_inst_req *request = NULL;
46 static int retcode(enum lib_retcode rc)
49 case SECURITY_MANAGER_SUCCESS: return 0;
50 case SECURITY_MANAGER_ERROR_INPUT_PARAM: errno = EINVAL; break;
51 case SECURITY_MANAGER_ERROR_MEMORY: errno = ENOMEM; break;
52 case SECURITY_MANAGER_ERROR_REQ_NOT_COMPLETE: errno = EBADMSG; break;
53 case SECURITY_MANAGER_ERROR_AUTHENTICATION_FAILED: errno = EPERM; break;
54 case SECURITY_MANAGER_ERROR_ACCESS_DENIED: errno = EACCES; break;
55 default: errno = 0; break;
62 security_manager_app_inst_req_free(request);
66 int secmgr_init(const char *pkgid, const char *appid)
68 int rc = security_manager_app_inst_req_new(&request);
69 if (rc == SECURITY_MANAGER_SUCCESS) {
70 rc = security_manager_app_inst_req_set_pkg_id(request, pkgid);
71 if (rc == SECURITY_MANAGER_SUCCESS)
72 rc = security_manager_app_inst_req_set_app_id(request, appid);
74 if (rc != SECURITY_MANAGER_SUCCESS)
79 int secmgr_permit(const char *permission)
81 int rc = security_manager_app_inst_req_add_privilege(request, permission);
85 static int addpath(const char *pathname, enum app_install_path_type type)
87 int rc = security_manager_app_inst_req_add_path(request, pathname, type);
91 int secmgr_path_public_read_only(const char *pathname)
93 return addpath(pathname, SECURITY_MANAGER_PATH_PUBLIC_RO);
96 int secmgr_path_read_only(const char *pathname)
98 return addpath(pathname, SECURITY_MANAGER_PATH_RO);
101 int secmgr_path_read_write(const char *pathname)
103 return addpath(pathname, SECURITY_MANAGER_PATH_RW);