Restore media_info_delete_from_db to product API
[platform/core/api/media-content.git] / src / media_info.c
index 4441e69..f9084ab 100644 (file)
 */
 
 #include <media_info.h>
-#include <media-thumbnail.h>
 #include <media-util-dcm.h>
 #include <media_info_private.h>
 #include <media_util_private.h>
 #include <system_info.h>
 
 static void __media_info_insert_completed_cb(media_request_result_s *result, void *user_data);
-static void __media_info_thumbnail_completed_cb(int error, const char *path, void *user_data);
 static void __media_info_face_completed_cb(int error, const int face_count, void *user_data);
 static int __media_info_insert_batch(const char **path_array, unsigned int array_length, media_insert_completed_cb completed_cb, void *user_data);
 static int __media_info_check_file_validity(const char *path);
 
-static int __media_info_get_media_path_by_id_from_db(const char *media_id, char **path)
-{
-       int ret = MEDIA_CONTENT_ERROR_NONE;
-       sqlite3_stmt *stmt = NULL;
-       char *select_query = NULL;
-
-       content_retip_if_fail(STRING_VALID(media_id));
-
-       select_query = sqlite3_mprintf(SELECT_MEDIA_PATH_BY_ID, media_id);
-
-       ret = _content_get_result(select_query, &stmt);
-       SQLITE3_SAFE_FREE(select_query);
-       content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
-
-       if (sqlite3_step(stmt) == SQLITE_ROW) {
-               *path = g_strdup((const char *)sqlite3_column_text(stmt, 0));
-       } else {
-               content_error("There's no media with this ID : %s", media_id);
-               *path = NULL;
-               ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
-       }
-
-       SQLITE3_FINALIZE(stmt);
-
-       return ret;
-}
-
 static void __media_info_insert_completed_cb(media_request_result_s *result, void *user_data)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
@@ -80,36 +51,6 @@ static void __media_info_insert_completed_cb(media_request_result_s *result, voi
        return;
 }
 
-static void __media_info_thumbnail_completed_cb(int error, const char *path, void *user_data)
-{
-       int error_value = MEDIA_CONTENT_ERROR_NONE;
-
-       media_thumbnail_cb_s *_thumb_cb = (media_thumbnail_cb_s *)user_data;
-       media_info_s *media = NULL;
-
-       if (_thumb_cb != NULL) {
-               media = _thumb_cb->handle;
-
-               if (media != NULL) {
-                       g_free(media->thumbnail_path);
-
-                       if (STRING_VALID(path))
-                               media->thumbnail_path = g_strdup(path);
-                       else
-                               media->thumbnail_path = g_strdup(MEDIA_CONTENT_EMPTY_STRING);
-               }
-
-               content_debug("error [%d], thumbnail_path [%s]", error, path);
-               error_value = _content_error_capi(error);
-               if (_thumb_cb->thumbnail_completed_cb)
-                       _thumb_cb->thumbnail_completed_cb(error_value, path, _thumb_cb->user_data);
-       }
-
-       g_free(_thumb_cb);
-
-       return;
-}
-
 static bool __media_info_isFaceRecognition_feature_supported(void)
 {
        bool isFaceRecognitionSupported = false;
@@ -149,15 +90,15 @@ static int __media_info_insert_batch(const char **path_array,
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
        FILE *fp = NULL;
-       char list_path[255] = {0, };
+       char list_path[BATCH_REQUEST_FILE_LEN] = {0, };
        unsigned int idx = 0;
        int nwrites = 0;
 
        for (idx = 0; idx < BATCH_REQUEST_MAX; idx++) {
-               snprintf(list_path, sizeof(list_path), "%s/request-%ld-%d", MEDIA_CONTENT_INSERT_FILES_PATH, media_content_gettid(), idx);
+               snprintf(list_path, BATCH_REQUEST_FILE_LEN, "%s/request-%ld-%d", MEDIA_CONTENT_INSERT_FILES_PATH, media_content_gettid(), idx);
 
-               if (g_file_test(list_path, G_FILE_TEST_EXISTS | G_FILE_TEST_IS_REGULAR)) {
-                       memset(list_path, 0x00, sizeof(list_path));
+               if (g_file_test(list_path, G_FILE_TEST_EXISTS)) {
+                       memset(list_path, 0x00, BATCH_REQUEST_FILE_LEN);
                        continue;
                } else {
                        content_sec_debug("The request file list path : %s", list_path);
@@ -513,14 +454,39 @@ int media_info_get_media_info_by_path_from_db(const char* path, media_info_h* me
 
        return ret;
 }
-#endif
+
+static int __media_info_get_media_path_by_id_from_db(const char *media_id, char **path)
+{
+       int ret = MEDIA_CONTENT_ERROR_NONE;
+       sqlite3_stmt *stmt = NULL;
+       char *select_query = NULL;
+
+       content_retip_if_fail(STRING_VALID(media_id));
+
+       select_query = sqlite3_mprintf(SELECT_MEDIA_PATH_BY_ID, media_id);
+
+       ret = _content_get_result(select_query, &stmt);
+       SQLITE3_SAFE_FREE(select_query);
+       content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
+
+       if (sqlite3_step(stmt) == SQLITE_ROW) {
+               *path = g_strdup((const char *)sqlite3_column_text(stmt, 0));
+       } else {
+               content_error("There's no media with this ID : %s", media_id);
+               *path = NULL;
+               ret = MEDIA_CONTENT_ERROR_INVALID_PARAMETER;
+       }
+
+       SQLITE3_FINALIZE(stmt);
+
+       return ret;
+}
 
 int media_info_delete_from_db(const char *media_id)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
        char *path = NULL;
        char *storage_id = NULL;
-       content_warn("DEPRECATION WARNING: media_info_delete_from_db() is deprecated and will be removed from next release. Use media_content_scan_file() instead.");
 
        content_retip_if_fail(STRING_VALID(media_id));
 
@@ -544,6 +510,7 @@ int media_info_delete_from_db(const char *media_id)
 
        return _content_error_capi(ret);
 }
+#endif
 
 int media_info_destroy(media_info_h media)
 {
@@ -1111,19 +1078,6 @@ int media_info_get_favorite(media_info_h media, bool* favorite)
        return MEDIA_CONTENT_ERROR_NONE;
 }
 
-int media_info_get_storage_id(media_info_h media, char **storage_id)
-{
-       content_warn("DEPRECATION WARNING: media_info_get_storage_id() is deprecated and will be removed from next release.");
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-       content_retip_if_fail(storage_id);
-
-       *storage_id = g_strdup(_media->storage_uuid);
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
 int media_info_is_drm(media_info_h media, bool *is_drm)
 {
        media_info_s *_media = (media_info_s*)media;
@@ -1148,19 +1102,6 @@ int media_info_is_360_content(media_info_h media, bool *is_360)
        return MEDIA_CONTENT_ERROR_NONE;
 }
 
-int media_info_get_storage_type(media_info_h media, media_content_storage_e *storage_type)
-{
-       content_warn("DEPRECATION WARNING: media_info_get_storage_type() is deprecated and will be removed from next release. Use storage_get_type_dev() instead.");
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-       content_retip_if_fail(storage_type);
-
-       *storage_type = _media->storage_type;
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
 #ifdef _USE_TVPD_MODE
 int media_info_get_played_count(media_info_h media, int *played_count)
 {
@@ -1299,10 +1240,10 @@ int media_info_get_media_from_db(const char *media_id, media_info_h *media)
 
        ret = _media_db_get_storage_id_by_media_id(media_id, &storage_id);
        content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
-       snprintf(select_query, sizeof(select_query), SELECT_MEDIA_FROM_MEDIA, storage_id, media_id);
+       snprintf(select_query, DEFAULT_QUERY_SIZE, SELECT_MEDIA_FROM_MEDIA, storage_id, media_id);
        g_free(storage_id);
 #else
-       snprintf(select_query, sizeof(select_query), SELECT_MEDIA_FROM_MEDIA, media_id);
+       snprintf(select_query, DEFAULT_QUERY_SIZE, SELECT_MEDIA_FROM_MEDIA, media_id);
 #endif
        ret = _content_get_result(select_query, &stmt);
        content_retv_if(ret != MEDIA_CONTENT_ERROR_NONE, ret);
@@ -1379,48 +1320,19 @@ int media_info_update_to_db(media_info_h media)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
        media_info_s *_media = (media_info_s*)media;
-       char *set_sql = NULL;
        char *sql = NULL;
 
        content_retip_if_fail(media);
        content_retip_if_fail(STRING_VALID(_media->media_id));
 
-       /* This sql is due to sqlite3_mprintf's wrong operation when using floating point in the text format */
-       /* This code will be removed when sqlite3_mprintf works clearly */
-       char *test_sql = sqlite3_mprintf("%f, %f, %f", _media->longitude, _media->latitude, _media->altitude);
-       SQLITE3_SAFE_FREE(test_sql);
-
-       /*Update Pinyin If Support Pinyin*/
-       char *file_name_pinyin = NULL;
-       char *description_pinyin = NULL;
-       bool pinyin_support = FALSE;
-
-       /*Update Pinyin If Support Pinyin*/
-       media_svc_check_pinyin_support(&pinyin_support);
-       if (pinyin_support) {
-               if (STRING_VALID(_media->display_name))
-                       media_svc_get_pinyin(_media->display_name, &file_name_pinyin);
-               if (STRING_VALID(_media->description))
-                       media_svc_get_pinyin(_media->description, &description_pinyin);
-       }
-#ifdef _USE_TVPD_MODE
-       set_sql = sqlite3_mprintf("media_display_name=%Q, media_description=%Q, media_longitude=%f, media_latitude=%f, media_file_name_pinyin=%Q, media_description_pinyin=%Q, played_count=%d, last_played_time=%d, last_played_position=%d, media_rating=%d, media_favourite=%d",
-                       _media->display_name, _media->description, _media->longitude, _media->latitude, file_name_pinyin, description_pinyin, _media->played_count, _media->played_time, _media->played_position, _media->rating, _media->favourite);
-#else
-       set_sql = sqlite3_mprintf("media_display_name=%Q, media_description=%Q, media_longitude=%f, media_latitude=%f, media_file_name_pinyin=%Q, media_description_pinyin=%Q, media_rating=%d, media_favourite=%d", _media->display_name, _media->description, _media->longitude, _media->latitude, file_name_pinyin, description_pinyin, _media->rating, _media->favourite);
-#endif
 #ifdef _USE_TVPD_MODE
-       sql = sqlite3_mprintf("UPDATE %Q SET %s WHERE media_id=%Q", _media->storage_uuid, set_sql, _media->media_id);
+       sql = sqlite3_mprintf("UPDATE %Q SET played_count=%d, last_played_time=%d, last_played_position=%d, media_favourite=%d WHERE media_id=%Q", _media->storage_uuid, _media->played_count, _media->played_time, _media->played_position, _media->favourite, _media->media_id);
 #else
-       sql = sqlite3_mprintf("UPDATE %q SET %s WHERE media_id=%Q", DB_TABLE_MEDIA, set_sql, _media->media_id);
+       sql = sqlite3_mprintf("UPDATE %q SET media_favourite=%d WHERE media_id=%Q", DB_TABLE_MEDIA, _media->favourite, _media->media_id);
 #endif
        ret = _content_query_sql(sql);
-       SQLITE3_SAFE_FREE(set_sql);
        SQLITE3_SAFE_FREE(sql);
 
-       SAFE_FREE(file_name_pinyin);
-       SAFE_FREE(description_pinyin);
-
        if (ret == MEDIA_CONTENT_ERROR_NONE) {
                /* Send notification for this update */
                content_debug("Update is successful. Send notification for this");
@@ -1448,13 +1360,13 @@ int media_info_move_to_db(media_info_h media, const char* dst_path)
        media_info_s *_media = (media_info_s*)media;
 
        /* If dst_path is folder, append file_name */
-       SAFE_STRLCPY(repl_path, dst_path, sizeof(repl_path));
+       SAFE_STRLCPY(repl_path, dst_path, MAX_PATH_LEN);
 
        if (g_file_test(repl_path, G_FILE_TEST_IS_DIR)) {
                if (repl_path[strlen(repl_path) - 1] != '/')
-                       SAFE_STRLCAT(repl_path, "/", sizeof(repl_path));
+                       SAFE_STRLCAT(repl_path, "/", MAX_PATH_LEN);
 
-               SAFE_STRLCAT(repl_path, _media->display_name, sizeof(repl_path));
+               SAFE_STRLCAT(repl_path, _media->display_name, MAX_PATH_LEN);
        }
 
        /* If the two paths are the same, do nothing */
@@ -1494,33 +1406,6 @@ int media_info_move_to_db(media_info_h media, const char* dst_path)
        return ret;
 }
 
-int media_info_create_thumbnail(media_info_h media, media_thumbnail_completed_cb callback, void *user_data)
-{
-       content_warn("DEPRECATION WARNING: media_info_create_thumbnail() is deprecated and will be removed from next release. Use media_info_generate_thumbnail() instead.");
-       int ret = MEDIA_CONTENT_ERROR_NONE;
-       static unsigned int req_id = 0;
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-       content_retip_if_fail(callback);
-       content_retip_if_fail(STRING_VALID(_media->media_id));
-       content_retip_if_fail(_media->file_path);
-
-       media_thumbnail_cb_s *_thumb_cb = g_new0(media_thumbnail_cb_s, 1);
-
-       req_id++;
-       _media->request_id = req_id;
-
-       _thumb_cb->handle = _media;
-       _thumb_cb->user_data = user_data;
-       _thumb_cb->thumbnail_completed_cb = callback;
-
-       ret = thumbnail_request_from_db_async(_media->request_id, _media->file_path, (ThumbFunc)__media_info_thumbnail_completed_cb, (void *)_thumb_cb, _content_get_uid());
-       ret = _content_error_capi(ret);
-
-       return ret;
-}
-
 int media_info_generate_thumbnail(media_info_h media)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
@@ -1549,20 +1434,6 @@ int media_info_generate_thumbnail(media_info_h media)
        return ret;
 }
 
-int media_info_cancel_thumbnail(media_info_h media)
-{
-       int ret = MEDIA_CONTENT_ERROR_NONE;
-       content_warn("DEPRECATION WARNING: media_info_cancel_thumbnail() is deprecated and will be removed from next release.");
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-       content_retip_if_fail(STRING_VALID(_media->media_id));
-       content_retip_if_fail(_media->request_id > 0);
-
-       ret = thumbnail_request_cancel_media(_media->request_id);
-       return _content_error_capi(ret);
-}
-
 int media_info_start_face_detection(media_info_h media, media_face_detection_completed_cb callback, void *user_data)
 {
        int ret = MEDIA_CONTENT_ERROR_NONE;
@@ -1615,89 +1486,3 @@ int media_info_cancel_face_detection(media_info_h media)
        ret = dcm_request_cancel_face(_media->face_request_id);
        return _content_error_capi(ret);
 }
-
-int media_info_set_description(media_info_h media, const char *description)
-{
-       content_warn("DEPRECATION WARNING: media_info_set_description() is deprecated and will be removed from next release.");
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-
-       g_free(_media->description);
-       _media->description = g_strdup(description);
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-int media_info_set_longitude(media_info_h media, double longitude)
-{
-       content_warn("DEPRECATION WARNING: media_info_set_longitude() is deprecated and will be removed from next release.");
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-
-       _media->longitude = longitude;
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-int media_info_set_latitude(media_info_h media, double latitude)
-{
-       content_warn("DEPRECATION WARNING: media_info_set_latitude() is deprecated and will be removed from next release.");
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-
-       _media->latitude = latitude;
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-int media_info_set_rating(media_info_h media, int rating)
-{
-       content_warn("DEPRECATION WARNING: media_info_set_rating() is deprecated and will be removed from next release.");
-       media_info_s *_media = (media_info_s*)media;
-
-       content_retip_if_fail(media);
-
-       _media->rating = rating;
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-#ifdef TIZEN_FEATURE_COMPATIBILITY
-int media_info_set_added_time(media_info_h media, time_t added_time)
-{
-       content_warn("DEPRECATION WARNING: media_info_set_added_time() is removed from 5.5.");
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-int media_info_delete_batch_from_db(filter_h filter)
-{
-       content_warn("DEPRECATION WARNING: media_info_delete_batch_from_db() is removed from 5.5.");
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-int media_info_create(const char *path, media_info_h *media)
-{
-       content_warn("DEPRECATION WARNING: media_info_create() is removed from 5.5.");
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-int media_info_refresh_metadata_to_db(const char *media_id)
-{
-       content_warn("DEPRECATION WARNING: media_info_refresh_metadata_to_db() is removed from 5.5.");
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-
-int media_info_set_display_name(media_info_h media, const char *display_name)
-{
-       content_warn("DEPRECATION WARNING: media_info_set_display_name() is removed from 5.5.");
-
-       return MEDIA_CONTENT_ERROR_NONE;
-}
-#endif