/*
- Copyright 2015 IoT.bzh
+ Copyright 2015, 2016, 2017 IoT.bzh
+
+ author: José Bollo <jose.bollo@iot.bzh>
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
#include <string.h>
#include <errno.h>
#include <assert.h>
-#include <syslog.h>
+#if SIMULATE_SECURITY_MANAGER
+#include "simulation/security-manager.h"
+#else
#include <security-manager.h>
+#endif
+#include "verbose.h"
#include "secmgr-wrap.h"
static app_inst_req *request = NULL;
case SECURITY_MANAGER_ERROR_REQ_NOT_COMPLETE: errno = EBADMSG; break;
case SECURITY_MANAGER_ERROR_AUTHENTICATION_FAILED: errno = EPERM; break;
case SECURITY_MANAGER_ERROR_ACCESS_DENIED: errno = EACCES; break;
- default: errno = 0; break;
+ default: errno = ECANCELED; break;
}
return -1;
}
assert(request == NULL);
rc = security_manager_app_inst_req_new(&request);
if (rc != SECURITY_MANAGER_SUCCESS)
- syslog(LOG_ERR, "security_manager_app_inst_req_new failed");
+ ERROR("security_manager_app_inst_req_new failed");
else {
rc = security_manager_app_inst_req_set_pkg_id(request, id);
if (rc != SECURITY_MANAGER_SUCCESS)
- syslog(LOG_ERR, "security_manager_app_inst_req_set_pkg_id failed");
+ ERROR("security_manager_app_inst_req_set_pkg_id failed");
else {
rc = security_manager_app_inst_req_set_app_id(request, id);
if (rc != SECURITY_MANAGER_SUCCESS)
- syslog(LOG_ERR, "security_manager_app_inst_req_set_app_id failed");
+ ERROR("security_manager_app_inst_req_set_app_id failed");
}
}
if (rc != SECURITY_MANAGER_SUCCESS)
assert(request != NULL);
rc = security_manager_app_install(request);
if (rc != SECURITY_MANAGER_SUCCESS)
- syslog(LOG_ERR, "security_manager_app_install failed");
- security_manager_app_inst_req_free(request);
+ ERROR("security_manager_app_install failed");
+ secmgr_cancel();
+ return retcode(rc);
+}
+
+int secmgr_uninstall()
+{
+ int rc;
+ assert(request != NULL);
+ rc = security_manager_app_uninstall(request);
+ if (rc != SECURITY_MANAGER_SUCCESS)
+ ERROR("security_manager_app_uninstall failed");
+ secmgr_cancel();
return retcode(rc);
}
assert(request != NULL);
rc = security_manager_app_inst_req_add_privilege(request, permission);
if (rc != SECURITY_MANAGER_SUCCESS)
- syslog(LOG_ERR, "security_manager_app_inst_add_privilege %s failed", permission);
+ ERROR("security_manager_app_inst_add_privilege %s failed", permission);
return retcode(rc);
}
assert(request != NULL);
rc = security_manager_app_inst_req_add_path(request, pathname, type);
if (rc != SECURITY_MANAGER_SUCCESS)
- syslog(LOG_ERR, "security_manager_app_inst_add_path %s failed", pathname);
+ ERROR("security_manager_app_inst_add_path %s failed", pathname);
return retcode(rc);
}
int secmgr_path_public_read_only(const char *pathname)
{
- return addpath(pathname, SECURITY_MANAGER_PATH_PUBLIC_RO);
+ return addpath(pathname, SECURITY_MANAGER_PATH_RO);
}
int secmgr_path_read_only(const char *pathname)
return addpath(pathname, SECURITY_MANAGER_PATH_RW);
}
+int secmgr_prepare_exec(const char *appid)
+{
+ return retcode(security_manager_prepare_app(appid));
+}
+