SM: Use TzPlatformConfig for global app dir
[platform/core/test/security-tests.git] / src / security-manager-tests / common / sm_commons.h
index d137f84..efd0b40 100644 (file)
 
 #pragma once
 
+#include <ftw.h>
 #include <string>
 #include <sys/capability.h>
+#include <sys/stat.h>
 #include <sys/types.h>
 #include <vector>
 
@@ -27,6 +29,7 @@
 #include <memory.h>
 #include <sm_db.h>
 #include <temp_test_user.h>
+#include <tzplatform.h>
 
 DEFINE_SMARTPTR(cap_free, _cap_struct, CapsSetsUniquePtr);
 
@@ -41,7 +44,8 @@ extern const privileges_t SM_ALLOWED_PRIVILEGES;
 extern const privileges_t SM_DENIED_PRIVILEGES;
 extern const privileges_t SM_NO_PRIVILEGES;
 extern const std::vector<std::string> SM_ALLOWED_GROUPS;
-static const char *const SM_RW_PATH = "/opt/usr/apps/sm_test_02_pkg_id_full/app_dir";
+const std::string SM_RW_PATH =
+        TzPlatformConfig::globalAppDir() + "/sm_test_02_pkg_id_full/app_dir";
 
 const std::string uidToStr(const uid_t uid);
 
@@ -69,6 +73,11 @@ void check_app_after_uninstall(const char *const app_id, const char *const pkg_i
 void check_app_after_uninstall(const char *const app_id, const char *const pkg_id,
                                const privileges_t &privileges, const bool is_pkg_removed);
 
+std::string access_opposite(std::string &access);
+void check_exact_smack_accesses(const std::string &subject,
+                                const std::string &object,
+                                const std::string &access);
+
 CapsSetsUniquePtr setCaps(const char *cap_string);
 void prepare_app_env(int app_num, bool others_enabled = false);
 void install_app(const char *app_id, const char *pkg_id, uid_t uid = 0,