#include "log.h"
#include "utils.h"
-#ifdef LOG_TAG
-#undef LOG_TAG
-#endif
-#define LOG_TAG "NETCORE_INSTALLER_PLUGIN"
-
#include <cstring>
#include <vector>
#include <sstream>
#include <glib.h>
+#include <pkgmgr_installer_info.h>
+
+#ifdef LOG_TAG
+#undef LOG_TAG
+#endif
+#define LOG_TAG "DOTNET_INSTALLER_PLUGIN"
-typedef struct Metadata {
- const char *key;
- const char *value;
-} Metadata;
+bool aotPluginInstalled = false;
extern "C" int PKGMGR_MDPARSER_PLUGIN_INSTALL(const char *pkgId, const char *appId, GList *list)
{
- GList *tag = NULL;
- bool mdValue = false;
- Metadata *mdInfo = NULL;
- tag = g_list_first(list);
- while (tag) {
- mdInfo = (Metadata*)tag->data;
- if (strcmp(mdInfo->key, AOT_METADATA_KEY) == 0 && strcmp(mdInfo->value, AOT_METADATA_VALUE) == 0) {
- _DBG("Prefer dotnet application AOT set TRUE");
- mdValue = true;
+ // Can be multiple apps in one package
+ if (aotPluginInstalled) {
+ _INFO("AOT plugin already installed");
+ return 0;
+ }
+ aotPluginInstalled = true;
+
+ int skipOpt = false;
+ if (!pkgmgr_installer_info_get_skip_optimization(&skipOpt)) {
+ if (skipOpt) {
+ _DBG("Skip dotnet AOT");
+ return 0;
}
- tag = g_list_next(tag);
}
- if (mdValue) {
- NiCommonOption option = {std::string(), std::string(), std::string()};
+ std::string metaValue = getMetadataValue(std::string(pkgId), AOT_METADATA_KEY);
+ if (metaValue.empty()) {
+ _ERR("Failed to get metadata from [%s]", pkgId);
+ return 0;
+ }
+
+ if (metaValue == METADATA_VALUE) {
+ _DBG("Prefer dotnet application AOT set TRUE");
+
+ NICommonOption option = {std::string(), std::string(), std::string()};
if (initNICommon(&option) < 0) {
_ERR("Fail to initialize NI Common");
return -1;
}
- if (createNiUnderPkgRoot(pkgId, false) != 0) {
+ if (createNIUnderPkgRoot(pkgId, 0) != NI_ERROR_NONE) {
_ERR("Failed to get root path from [%s]", pkgId);
return -1;
} else {
_INFO("Complete make application to native image");
}
+
+ std::string rootPath = getRootPath(std::string(pkgId));
+ if (rootPath.empty()) {
+ _ERR("Failed to get root path from [%s]", pkgId);
+ return -1;
+ }
+
+ std::string binDir = concatPath(rootPath, "bin");
+ std::string tacDir = concatPath(binDir, TAC_SYMLINK_SUB_DIR);
+ if (bf::exists(tacDir)) {
+ uid_t g_uid = 0;
+ gid_t g_gid = 0;
+ if (pkgmgr_installer_info_get_target_uid(&g_uid) < 0) {
+ _ERR("Failed to get UID");
+ return -1;
+ }
+ try {
+ for (auto& symlinkAssembly : bf::recursive_directory_iterator(tacDir)) {
+ std::string symPath = symlinkAssembly.path().string();
+ if (!isNativeImage(symPath)) {
+ std::string originPath = bf::read_symlink(symPath).string();
+ std::string originNIPath = originPath.substr(0, originPath.rfind(".dll")) + ".ni.dll";
+ if (!bf::exists(originNIPath)) {
+ if (createNIDllUnderPkgRoot(pkgId, originPath, 0) != NI_ERROR_NONE) {
+ _ERR("Failed to create NI file [%s]", originPath.c_str());
+ return -1;
+ }
+ }
+ std::string setNIPath = symPath.substr(0, symPath.rfind(".dll")) + ".ni.dll";
+ if (!bf::exists(setNIPath)) {
+ bf::create_symlink(originNIPath, setNIPath);
+ _INFO("%s symbolic link file generated successfully.", setNIPath.c_str());
+ if (lchown(setNIPath.c_str(), g_uid, g_gid)) {
+ _ERR("Failed to change owner of: %s", setNIPath.c_str());
+ return -1;
+ }
+ }
+ }
+ }
+ } catch (const bf::filesystem_error& error) {
+ _ERR("File system error while interating files: %s", error.what());
+ return -1;
+ }
+ }
}
return 0;
}