+ return 0;
+
+}
+
+EXPORT_API
+int PKGMGR_MDPARSER_PLUGIN_INSTALL(const char *pkgid, const char *appid, GList *list)
+{
+ LOGD("METADATA INSTALL");
+ LOGD("pkgid(%s) appid(%s) list(%d)", pkgid, appid, g_list_length(list));
+
+ int ret = -1;
+ ret = pkgmgr_installer_info_get_target_uid(&g_uid);
+ if (ret < 0) {
+ LOGE("[ERROR] Fail to get target uid");
+ return 0;
+ } else {
+ LOGD("uid(%d)", g_uid);
+ printf("[Parser Debug][DEBUG] uid(%d)", g_uid);
+ }
+
+ uid_t globalapp_uid = tzplatform_getuid(TZ_SYS_GLOBALAPP_USER);
+ if (globalapp_uid == g_uid) {
+ g_user_type = g_strdup("admin");
+ } else {
+ g_guser = gum_user_get_sync(g_uid, FALSE);
+ if (NULL == g_guser) {
+ LOGE("[ERROR] g_guser is NULL");
+ return -1;
+ }
+
+ g_object_get(G_OBJECT(g_guser), "usertype", &g_ut, NULL);
+ g_user_type = g_strdup(gum_user_type_to_string(g_ut));
+ }
+
+ if (NULL == g_user_type) {
+ LOGE("[ERROR] Fail to allocate memory");
+ if (NULL != g_guser) {
+ g_object_unref(g_guser);
+ g_guser = NULL;
+ }
+ return -1;
+ }
+
+ if (0 == strcmp(g_user_type, "none")) {
+ /* GUM_USERTYPE_NONE */
+ LOGE("[ERROR] Fail to get target uid");
+ g_object_unref(g_guser);
+ g_guser = NULL;
+ g_free(g_user_type);
+ return -1;
+ }
+
+ if (globalapp_uid == g_uid) {
+ /* global directory */
+ LOGD("[DEBUG] usertype: %s", g_user_type);
+ if (0 >= g_list_length(list)) {
+ LOGE("[ERROR] No Engine Metadata");
+ g_free(g_user_type);
+ return 0;
+ }
+
+ if (0 != __write_metadata_inxml(pkgid, appid, list)) {
+ LOGE("[ERROR] Fail to write metadata in the xml");
+ xmlFreeDoc(g_doc);
+ g_free(g_user_type);
+ return -1;
+ }
+
+ /* Get user data by using libgum */
+
+ GumUserService *gus = NULL;
+ GumUserList *users = NULL;
+ GumUserList *iter = NULL;
+ GumUser *user = NULL;
+ gchar **query;
+ GumUserType gumut = GUM_USERTYPE_NONE;
+ gchar *user_type = NULL;
+
+ uid_t uid;
+ gchar *home_dir = NULL;
+
+ gus = gum_user_service_create_sync(TRUE);
+ if (!gus) {
+ LOGE("Failed to create gum user service");
+ g_free(g_user_type);
+ return -1;
+ }
+
+ query = g_strsplit("admin,normal", ",", -1);
+
+ users = gum_user_service_get_user_list_sync(gus, (const gchar *const *)query);
+ g_strfreev(query);
+
+ if (!users) {
+ LOGE("Failed to get gum user list");
+ g_object_unref(gus);
+ gus = NULL;
+ g_free(g_user_type);
+ return -1;
+ }
+
+ /* Make new user list */
+
+ iter = users;
+ while (iter != NULL) {
+ user = (GumUser*) iter->data;
+ g_object_get(G_OBJECT(user), "uid", &uid, NULL);
+ if (NULL != home_dir) {
+ free(home_dir);
+ home_dir = NULL;
+ }
+ g_object_get(G_OBJECT(user), "homedir", &home_dir, NULL);
+ g_object_get(G_OBJECT(user), "usertype", &gumut, NULL);
+ user_type = g_strdup(gum_user_type_to_string(gumut));
+ if (NULL == user_type) {
+ gum_user_service_list_free(users);
+ g_object_unref(gus);
+ gus = NULL;
+ return -1;
+ }
+
+ LOGD("[DEBUG] user info");
+ if (NULL != home_dir) {
+ LOGD("[DEBUG] uid(%d), user_type(%s), home_dir(%s)", uid, user_type, home_dir);
+
+ g_dir_config_base = (char*)calloc(strlen(home_dir) + 14, sizeof(char));
+ g_dir_home = (char*)calloc(strlen(home_dir) + 18, sizeof(char));
+ g_dir_engine_base = (char*)calloc(strlen(home_dir) + 22, sizeof(char));
+ g_dir_engine_info = (char*)calloc(strlen(home_dir) + 34, sizeof(char));
+
+ if (NULL == g_dir_config_base || NULL == g_dir_home || NULL == g_dir_engine_base || NULL == g_dir_engine_info) {
+ LOGE("[ERROR] Fail to allocate memory");
+ if (NULL != g_dir_config_base) {
+ free(g_dir_config_base);
+ g_dir_config_base = NULL;
+ }
+ if (NULL != g_dir_home) {
+ free(g_dir_home);
+ g_dir_home = NULL;
+ }
+ if (NULL != g_dir_engine_base) {
+ free(g_dir_engine_base);
+ g_dir_engine_base = NULL;
+ }
+ if (NULL != g_dir_engine_info) {
+ free(g_dir_engine_info);
+ g_dir_engine_info = NULL;
+ }
+ gum_user_service_list_free(users);
+ g_object_unref(gus);
+ gus = NULL;
+ return -1;
+ }
+ snprintf(g_dir_config_base, strlen(home_dir) + 14, "%s/share/.voice", home_dir);
+ snprintf(g_dir_home, strlen(home_dir) + 18, "%s/share/.voice/tts", home_dir);
+ snprintf(g_dir_engine_base, strlen(home_dir) + 22, "%s/share/.voice/tts/1.0", home_dir);
+ snprintf(g_dir_engine_info, strlen(home_dir) + 34, "%s/share/.voice/tts/1.0/engine-info", home_dir);
+
+ LOGD("[DEBUG] g_dir_engine_info(%s)", g_dir_engine_info);
+
+ if (0 != __save_engine_info_xml(pkgid, user_type, uid)) {
+ LOGE("[ERROR] Fail to make engine info file");
+ }
+
+ free(g_dir_config_base);
+ g_dir_config_base = NULL;
+ free(g_dir_home);
+ g_dir_home = NULL;
+ free(g_dir_engine_base);
+ g_dir_engine_base = NULL;
+ free(g_dir_engine_info);
+ g_dir_engine_info = NULL;
+
+ g_free(user_type);
+ user_type = NULL;
+ free(home_dir);
+ home_dir = NULL;
+
+ iter = g_list_next(iter);
+ } else {
+ iter = g_list_next(iter);
+ }
+
+ if (NULL != user_type) {
+ g_free(user_type);
+ user_type = NULL;
+ }
+ }
+
+ gum_user_service_list_free(users);
+ g_object_unref(gus);
+ gus = NULL;
+ } else {
+ /* user directory */
+ LOGD("[DEBUG] usertype: %s", g_user_type);
+
+ ret = tzplatform_set_user(g_uid);
+ if (ret < 0) {
+ LOGE("[ERROR] Invalid uid");
+ g_object_unref(g_guser);
+ g_guser = NULL;
+ g_free(g_user_type);
+ return 0;
+ } else {
+ LOGD("TZ_USER_HOME: %s", tzplatform_mkstr(TZ_USER_HOME, "/"));
+ printf("[Parser Debug][DEBUG] TZ_USER_HOME: %s", tzplatform_mkstr(TZ_USER_HOME, "/"));
+ }
+
+ if (0 >= g_list_length(list)) {
+ LOGE("[ERROR] No Engine Metadata");
+ g_object_unref(g_guser);
+ g_guser = NULL;
+ g_free(g_user_type);
+ return 0;
+ }
+
+ if (0 != __write_metadata_inxml(pkgid, appid, list)) {
+ LOGE("[ERROR] Fail to write metadata in the xml");
+ xmlFreeDoc(g_doc);
+ g_object_unref(g_guser);
+ g_guser = NULL;
+ g_free(g_user_type);
+ return -1;
+ }
+
+ g_dir_config_base = strdup(TTS_CONFIG_BASE);
+ g_dir_home = strdup(TTS_HOME);
+ g_dir_engine_base = strdup(TTS_ENGINE_BASE);
+ g_dir_engine_info = strdup(TTS_ENGINE_INFO);
+
+ if (NULL == g_dir_config_base || NULL == g_dir_home || NULL == g_dir_engine_base || NULL == g_dir_engine_info) {
+ LOGE("[ERROR] Fail to allocate memory");
+ if (NULL != g_dir_config_base) {
+ free(g_dir_config_base);
+ g_dir_config_base = NULL;
+ }
+ if (NULL != g_dir_home) {
+ free(g_dir_home);
+ g_dir_home = NULL;
+ }
+ if (NULL != g_dir_engine_base) {
+ free(g_dir_engine_base);
+ g_dir_engine_base = NULL;
+ }
+ if (NULL != g_dir_engine_info) {
+ free(g_dir_engine_info);
+ g_dir_engine_info = NULL;
+ }
+ xmlFreeDoc(g_doc);
+ g_object_unref(g_guser);
+ g_guser = NULL;
+ g_free(g_user_type);
+ return -1;
+ }
+
+ if (0 != __save_engine_info_xml(pkgid, g_user_type, g_uid)) {
+ LOGE("[ERROR] Fail to make engine info file");
+ xmlFreeDoc(g_doc);
+ if (NULL != g_guser) {
+ g_object_unref(g_guser);
+ g_guser = NULL;
+ }
+ g_free(g_user_type);
+ return -1;
+ }
+ }
+