Remove dlog from pc_dependents
[platform/core/api/media-content.git] / src / media_folder.c
index 8089a7a..f431eae 100755 (executable)
@@ -17,6 +17,9 @@
 
 #include <media_info_private.h>
 #include <media_util_private.h>
+#ifdef _USE_TVPD_MODE
+#include <media_content_type_product.h>
+#endif
 
 static char *g_src_path = NULL;
 
@@ -28,9 +31,17 @@ int media_folder_get_folder_count_from_db(filter_h filter, int *folder_count)
                media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
                return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
        }
+#ifdef _USE_TVPD_MODE
+       g_mutex_lock(_content_get_db_mutex());
+#endif
 
        ret = _media_db_get_group_count(filter, MEDIA_GROUP_FOLDER, folder_count);
 
+#ifdef _USE_TVPD_MODE
+       g_mutex_unlock(_content_get_db_mutex());
+#endif
+
+
        return ret;
 }
 
@@ -61,7 +72,16 @@ int media_folder_get_media_count_from_db(const char *folder_id, filter_h filter,
        int ret = MEDIA_CONTENT_ERROR_NONE;
 
        if (STRING_VALID(folder_id) && media_count) {
+#ifdef _USE_TVPD_MODE
+               g_mutex_lock(_content_get_db_mutex());
+#endif
+
                ret = _media_db_get_group_item_count(folder_id, filter, MEDIA_GROUP_FOLDER, media_count);
+
+#ifdef _USE_TVPD_MODE
+               g_mutex_unlock(_content_get_db_mutex());
+#endif
+
        } else {
                media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
                return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
@@ -75,7 +95,16 @@ int media_folder_foreach_media_from_db(const char *folder_id, filter_h filter, m
        int ret = MEDIA_CONTENT_ERROR_NONE;
 
        if ((callback != NULL) && STRING_VALID(folder_id)) {
+#ifdef _USE_TVPD_MODE
+               g_mutex_lock(_content_get_db_mutex());
+#endif
+
                ret = _media_db_get_group_item(folder_id, filter, callback, user_data, MEDIA_GROUP_FOLDER);
+
+#ifdef _USE_TVPD_MODE
+               g_mutex_unlock(_content_get_db_mutex());
+#endif
+
        } else {
                media_content_error("INVALID_PARAMETER(0x%08x)", MEDIA_CONTENT_ERROR_INVALID_PARAMETER);
                return MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
@@ -209,7 +238,7 @@ int media_folder_get_parent_folder_id(media_folder_h folder, char **parent_folde
        char *parent_path = NULL;
        char select_query[MAX_QUERY_SIZE] = {0, };
 
-       /* Usage is low. So, DB access when this fuction is called */
+       /* Usage is low. So, DB access when this function is called */
        if (_folder) {
                memset(tmp_path, 0x00, sizeof(tmp_path));
                memset(select_query, 0x00, sizeof(select_query));
@@ -304,6 +333,7 @@ int media_folder_get_modified_time(media_folder_h folder, time_t* time)
 int media_folder_get_storage_type(media_folder_h folder, media_content_storage_e* storage_type)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
+       media_content_warn("DEPRECATION WARNING: media_folder_get_storage_type() is deprecated and will be removed from next release. Use storage_get_type_dev() instead.");
        media_folder_s *_folder = (media_folder_s*)folder;
 
        if (_folder) {
@@ -320,6 +350,7 @@ int media_folder_get_storage_type(media_folder_h folder, media_content_storage_e
 int media_folder_get_storage_id(media_folder_h folder, char **storage_id)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
+       media_content_warn("DEPRECATION WARNING: media_folder_get_storage_id() is deprecated and will be removed from next release.");
        media_folder_s *_folder = (media_folder_s*)folder;
 
        if (_folder) {
@@ -362,8 +393,6 @@ int media_folder_get_folder_from_db(const char *folder_id, media_folder_h *folde
        int ret = MEDIA_CONTENT_ERROR_NONE;
        sqlite3_stmt *stmt = NULL;
        char select_query[DEFAULT_QUERY_SIZE];
-       char *tmp_path = NULL;
-       char repl_path[MAX_PATH_LEN] = {0, };
        media_folder_s *_folder = NULL;
 
        if (!STRING_VALID(folder_id)) {
@@ -386,12 +415,7 @@ int media_folder_get_folder_from_db(const char *folder_id, media_folder_h *folde
                }
 
                _folder->folder_id = g_strdup((const char *)sqlite3_column_text(stmt, 0));
-
-               tmp_path = g_strdup((const char *)sqlite3_column_text(stmt, 1));
-               _media_content_rollback_path(tmp_path, repl_path);
-               _folder->path = g_strdup(repl_path);
-               SAFE_FREE(tmp_path);
-
+               _folder->path = g_strdup((const char *)sqlite3_column_text(stmt, 1));
                _folder->name = g_strdup((const char *)sqlite3_column_text(stmt, 2));
                _folder->modified_time = (int)sqlite3_column_int(stmt, 3);
                _folder->storage_type = (int)sqlite3_column_int(stmt, 5);
@@ -467,11 +491,8 @@ int media_folder_set_name(media_folder_h folder, const char *name)
                        SAFE_FREE(_folder->path);
                        SAFE_FREE(_folder->name);
                        SAFE_FREE(folder_path);
-                       memset(repl_path, 0, sizeof(repl_path));
-                       ret = _media_content_rollback_path(new_folder_path, repl_path);
-                       media_content_retvm_if(!STRING_VALID(repl_path), MEDIA_CONTENT_ERROR_INVALID_OPERATION, "path replacement failed");
 
-                       _folder->path = strdup(repl_path);
+                       _folder->path = strdup(new_folder_path);
                        media_content_retvm_if(_folder->path == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
                        _folder->name = strdup(name);
                        media_content_retvm_if(_folder->name == NULL, MEDIA_CONTENT_ERROR_OUT_OF_MEMORY, "OUT_OF_MEMORY");
@@ -503,6 +524,67 @@ int media_folder_set_order(media_folder_h folder, int order)
        return ret;
 }
 #ifdef _USE_TVPD_MODE
+int media_folder_insert_to_db(const char *path)
+{
+       char repl_path[MAX_PATH_LEN] = {0, };
+       int ret = MEDIA_CONTENT_ERROR_NONE;
+       char storage_id[MEDIA_CONTENT_UUID_SIZE+1] = {0, };
+       bool ignore_dir = FALSE;
+
+       media_content_retvm_if(!STRING_VALID(path), MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "invalid path");
+       memset(repl_path, 0, sizeof(repl_path));
+       ret = _media_content_replace_path(path, repl_path);
+       media_content_retvm_if(!STRING_VALID(repl_path), MEDIA_CONTENT_ERROR_INVALID_OPERATION, "path replacement failed");
+
+       ret = _media_util_check_ignore_dir(repl_path, &ignore_dir);
+       media_content_retvm_if(ignore_dir, MEDIA_CONTENT_ERROR_INVALID_PARAMETER, "Invalid folder path");
+
+       ret = _media_content_check_dir(repl_path);
+       media_content_retvm_if(ret == MEDIA_CONTENT_ERROR_PERMISSION_DENIED, ret, "Permission Denied");
+       media_content_retvm_if(ret == MEDIA_CONTENT_ERROR_INVALID_PARAMETER, ret, "invalid path[%s]", path);
+
+       ret = media_svc_get_storage_id(_content_get_db_handle(), repl_path, storage_id, _content_get_uid());
+       if (ret != MS_MEDIA_ERR_NONE) {
+               media_content_error("media_svc_get_storage_id failed : %d", ret);
+               return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
+       }
+
+       ret = media_svc_check_folder_exist_by_path(_content_get_db_handle(), storage_id, repl_path);
+       if (ret == MS_MEDIA_ERR_DB_NO_RECORD) {
+               media_content_sec_debug("media_svc_check_folder_exist_by_path : no record : %s", repl_path);
+               media_svc_storage_type_e storage_type = 0;
+
+               ret = media_svc_get_storage_type(repl_path, &storage_type, _content_get_uid());
+               if (ret != MS_MEDIA_ERR_NONE) {
+                       media_content_sec_error("media_svc_get_storage_type failed : %d", ret);
+                       return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
+               }
+
+               ret = media_svc_insert_folder(_content_get_db_handle(), storage_id, storage_type, repl_path, _content_get_uid());
+               if (ret != MS_MEDIA_ERR_NONE) {
+                       if (ret == MS_MEDIA_ERR_DB_CONSTRAINT_FAIL) {
+                               media_content_sec_error("This item is already inserted. This may be normal operation because other process already did this (%s)", repl_path);
+                               ret = MEDIA_CONTENT_ERROR_NONE;
+                       } else {
+                               media_content_sec_error("media_svc_insert_folder failed : %d (%s)", ret, repl_path);
+                       }
+
+                       return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
+               }
+
+               ret = media_svc_set_folder_scan_status(storage_id, repl_path, MEDIA_DIR_SCAN_DONE, _content_get_uid());
+               if (ret != MS_MEDIA_ERR_NONE) {
+                       media_content_sec_error("ms_set_folder_scan_status failed : %d", ret);
+                       return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
+               }
+       } else if (ret != MS_MEDIA_ERR_NONE) {
+               media_content_sec_error("media_svc_check_folder_exist_by_path failed : %d (%s)", ret, repl_path);
+               return _content_error_capi(MEDIA_CONTENT_TYPE, ret);
+       }
+
+       return ret;
+}
+
 int media_folder_get_scan_status(const char *storage_uuid, char* path, media_folder_scan_status_e *scan_status)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;