Merge function for getting thumbnail folder
[platform/core/multimedia/libmedia-thumbnail.git] / server / thumb-server-internal.c
index 83f3186..1b8bac3 100755 (executable)
  */
 
 #include "thumb-server-internal.h"
+#include "media-thumb-util.h"
+#include "media-thumb-debug.h"
 
+#include <fcntl.h>
 #include <unistd.h>
 #include <dirent.h>
 #include <stdio.h>
 #include <string.h>
 #include <Ecore_Evas.h>
-#include <vconf.h>
+#include <tzplatform_config.h>
 
 #ifdef LOG_TAG
 #undef LOG_TAG
 #endif
 
 #define LOG_TAG "MEDIA_THUMBNAIL_SERVER"
-
-static __thread char **arr_path;
-static __thread int g_idx = 0;
-static __thread int g_cur_idx = 0;
+#define THUMB_DEFAULT_WIDTH 320
+#define THUMB_DEFAULT_HEIGHT 240
+#define THUMB_BLOCK_SIZE 512
+#define THUMB_COMM_SOCK_PATH tzplatform_mkpath(TZ_SYS_RUN, "media-server/media_ipc_thumbcomm.socket")
+#define THUMB_EMPTY_STR ""
 
 GMainLoop *g_thumb_server_mainloop; // defined in thumb-server.c as extern
 
-#ifdef _USE_MEDIA_UTIL_
-gboolean _thumb_server_send_msg_to_agent(int msg_type);
-#endif
-void _thumb_daemon_stop_job();
+static gboolean __thumb_server_send_msg_to_agent(int msg_type);
+static gboolean _thumb_server_send_deny_message(int sockfd);
 
 gboolean _thumb_daemon_start_jobs(gpointer data)
 {
@@ -51,451 +53,463 @@ gboolean _thumb_daemon_start_jobs(gpointer data)
        /* Initialize ecore-evas to use evas library */
        ecore_evas_init();
 
-#ifdef _USE_MEDIA_UTIL_
-       _thumb_server_send_msg_to_agent(MS_MSG_THUMB_SERVER_READY);
-#endif
+       __thumb_server_send_msg_to_agent(MS_MSG_THUMB_SERVER_READY);
+
        return FALSE;
 }
 
-void _thumb_daemon_finish_jobs()
+void _thumb_daemon_finish_jobs(void)
 {
-       sqlite3 *sqlite_db_handle = _media_thumb_db_get_handle();
-
-       if (sqlite_db_handle != NULL) {
-               _media_thumb_db_disconnect();
-               thumb_dbg("sqlite3 handle is alive. So disconnect to sqlite3");
-       }
-
        /* Shutdown ecore-evas */
        ecore_evas_shutdown();
+       g_main_loop_quit(g_thumb_server_mainloop);
 
        return;
 }
 
-int _thumb_daemon_mmc_status()
+int _thumb_daemon_process_job(thumbMsg *req_msg, thumbMsg *res_msg)
 {
-       int err = -1;
-       int status = -1;
-
-       err = vconf_get_int(VCONFKEY_SYSMAN_MMC_STATUS, &status);
-       if (err == 0) {
-               return status;
-       } else if (err == -1) {
-               thumb_err("vconf_get_int failed : %d", err);
-       } else {
-               thumb_err("vconf_get_int Unexpected error code: %d", err);
+       int err = MS_MEDIA_ERR_NONE;
+
+       if (req_msg->msg_type == THUMB_REQUEST_RAW_DATA) {
+               err = _media_thumb_process_raw(req_msg, res_msg);
+               if (err != MS_MEDIA_ERR_NONE)
+                       thumb_warn("_media_thumb_process_raw is failed: %d", err);
+       } else if (req_msg->msg_type == THUMB_REQUEST_DB_INSERT) {
+               err = _media_thumb_process(req_msg, res_msg);
+               if (err != MS_MEDIA_ERR_NONE)
+                       thumb_warn("_media_thumb_process is failed: %d", err);
        }
 
-       return status;
+       return err;
 }
 
-void _thumb_daemon_mmc_eject_vconf_cb(void *data)
+gboolean _thumb_server_read_socket(GIOChannel *src, GIOCondition condition, gpointer data)
 {
-       int err = -1;
-       int status = 0;
+       struct sockaddr_un client_addr;
+       unsigned int client_addr_len;
+       thumbMsg recv_msg;
+       thumbMsg res_msg;
+       ms_peer_credentials credentials;
 
-       thumb_warn("_thumb_daemon_vconf_cb called");
+       int sock = -1;
+       int client_sock = -1;
 
-       err = vconf_get_int(VCONFKEY_SYSMAN_MMC_STATUS, &status);
-       if (err == 0) {
-               if (status == VCONFKEY_SYSMAN_MMC_REMOVED || status == VCONFKEY_SYSMAN_MMC_INSERTED_NOT_MOUNTED) {
-                       thumb_warn("SD card is ejected or not mounted. So media-thumbnail-server stops jobs to extract all thumbnails");
+       memset((void *)&recv_msg, 0, sizeof(recv_msg));
+       memset((void *)&res_msg, 0, sizeof(res_msg));
+       memset((void *)&credentials, 0, sizeof(credentials));
 
-                       _thumb_daemon_stop_job();
-               }
-       } else if (err == -1) {
-               thumb_err("vconf_get_int failed : %d", err);
-       } else {
-               thumb_err("vconf_get_int Unexpected error code: %d", err);
+       sock = g_io_channel_unix_get_fd(src);
+       if (sock < 0) {
+               thumb_err("sock fd is invalid!");
+               return TRUE;
        }
 
-       return;
-}
-
-void _thumb_daemon_vconf_cb(void *data)
-{
-       int err = -1;
-       int status = 0;
+       client_addr_len = sizeof(client_addr);
 
-       thumb_warn("_thumb_daemon_vconf_cb called");
-
-       err = vconf_get_int(VCONFKEY_SYSMAN_MMC_FORMAT, &status);
-       if (err == 0) {
-               if (status == VCONFKEY_SYSMAN_MMC_FORMAT_COMPLETED) {
-                       thumb_warn("SD card format is completed. So media-thumbnail-server stops jobs to extract all thumbnails");
-
-                       _thumb_daemon_stop_job();
-               } else {
-                       thumb_dbg("not completed");
-               }
-       } else if (err == -1) {
-               thumb_err("vconf_get_int failed : %d", err);
-       } else {
-               thumb_err("vconf_get_int Unexpected error code: %d", err);
+       if ((client_sock = accept(sock, (struct sockaddr*)&client_addr, &client_addr_len)) < 0) {
+               thumb_stderror("accept failed");
+               return TRUE;
        }
 
-       return;
-}
-
-void _thumb_daemon_stop_job()
-{
-       int i = 0;
-       char *path = NULL;
-
-       thumb_warn("There are %d jobs in the queue. But all jobs will be stopped", g_idx - g_cur_idx);
-
-       for (i = g_cur_idx; i < g_idx; i++) {
-               path = arr_path[g_cur_idx++];
-               SAFE_FREE(path);
+       if (ms_cynara_receive_untrusted_message_thumb(client_sock, &recv_msg, &credentials) != MS_MEDIA_ERR_NONE) {
+               thumb_err("ms_cynara_receive_untrusted_message_thumb failed");
+               close(client_sock);
+               return FALSE;
        }
 
-       return;
-}
-
-int _thumb_daemon_process_job(thumbMsg *req_msg, thumbMsg *res_msg)
-{
-       int err = -1;
-
-       err = _media_thumb_process(req_msg, res_msg);
-       if (err < 0) {
-               if (req_msg->msg_type == THUMB_REQUEST_SAVE_FILE) {
-                       thumb_err("_media_thumb_process is failed: %d", err);
-                       res_msg->status = THUMB_FAIL;
-               } else {
-                       thumb_warn("_media_thumb_process is failed: %d, So use default thumb", err);
-                       res_msg->status = THUMB_SUCCESS;
+       if (recv_msg.msg_type != THUMB_REQUEST_KILL_SERVER) {
+               if (ms_cynara_check(&credentials, MEDIA_STORAGE_PRIVILEGE) != MS_MEDIA_ERR_NONE) {
+                       thumb_err("Cynara denied access to process request");
+                       _thumb_server_send_deny_message(client_sock);
+                       close(client_sock);
+                       return TRUE;
                }
-       } else {
-               res_msg->status = THUMB_SUCCESS;
        }
 
-       return err;
-}
+       SAFE_FREE(credentials.smack);
+       SAFE_FREE(credentials.uid);
 
-int _thumb_daemon_all_extract()
-{
-       int err = -1;
-       int count = 0;
-       char query_string[MAX_PATH_SIZE + 1] = { 0, };
-       char path[MAX_PATH_SIZE + 1] = { 0, };
-       sqlite3 *sqlite_db_handle = NULL;
-       sqlite3_stmt *sqlite_stmt = NULL;
-
-       err = _media_thumb_db_connect();
-       if (err < 0) {
-               thumb_err("_media_thumb_db_connect failed: %d", err);
-               return MEDIA_THUMB_ERROR_DB;
-       }
+       thumb_warn_slog("Received [%d] %s(%d) from PID(%d)", recv_msg.msg_type, recv_msg.org_path, strlen(recv_msg.org_path), recv_msg.pid);
 
-       sqlite_db_handle = _media_thumb_db_get_handle();
-       if (sqlite_db_handle == NULL) {
-               thumb_err("sqlite handle is NULL");
-               return MEDIA_THUMB_ERROR_DB;
-       }
+       if (recv_msg.msg_type != THUMB_REQUEST_KILL_SERVER)
+               _thumb_daemon_process_job(&recv_msg, &res_msg);
 
-       if (_thumb_daemon_mmc_status() == VCONFKEY_SYSMAN_MMC_MOUNTED) {
-               snprintf(query_string, sizeof(query_string), SELECT_PATH_FROM_UNEXTRACTED_THUMB_MEDIA);
+       if (res_msg.msg_type == 0)
+               res_msg.msg_type = recv_msg.msg_type;
+       res_msg.request_id = recv_msg.request_id;
+       SAFE_STRLCPY(res_msg.org_path, recv_msg.org_path, sizeof(res_msg.org_path));
+       res_msg.origin_path_size = recv_msg.origin_path_size;
+       if (res_msg.msg_type != THUMB_RESPONSE_RAW_DATA) {
+               res_msg.dest_path_size = strlen(res_msg.dst_path)+1;
+               res_msg.thumb_size = 0;
        } else {
-               snprintf(query_string, sizeof(query_string), SELECT_PATH_FROM_UNEXTRACTED_THUMB_INTERNAL_MEDIA);
-       }
-       
-       thumb_warn("Query: %s", query_string);
-
-       err = sqlite3_prepare_v2(sqlite_db_handle, query_string, strlen(query_string), &sqlite_stmt, NULL);
-       if (SQLITE_OK != err) {
-               thumb_err("prepare error [%s]\n", sqlite3_errmsg(sqlite_db_handle));
-               _media_thumb_db_disconnect();
-               return MEDIA_THUMB_ERROR_DB;
+               res_msg.dest_path_size = 1;
+               res_msg.dst_path[0] = '\0';
        }
 
-       while(1) {
-               err = sqlite3_step(sqlite_stmt);
-               if (err != SQLITE_ROW) {
-                       thumb_dbg("end of row [%s]\n", sqlite3_errmsg(sqlite_db_handle));
-                       break;
-               }
+       int buf_size = 0;
+       int sending_block = 0;
+       int block_size = sizeof(res_msg) - MAX_FILEPATH_LEN*2 - sizeof(unsigned char *);
+       unsigned char *buf = NULL;
+       _media_thumb_set_buffer(&res_msg, &buf, &buf_size);
 
-               strncpy(path, (const char *)sqlite3_column_text(sqlite_stmt, 0), sizeof(path));
-               path[sizeof(path) - 1] = '\0';
-               count = sqlite3_column_int(sqlite_stmt, 1);
+       while (buf_size > 0) {
+               if (buf_size < THUMB_BLOCK_SIZE) {
+                       block_size = buf_size;
+               }
+               if (send(client_sock, buf+sending_block, block_size, 0) != block_size) {
+                       thumb_stderror("sendto failed");
+               }
+               sending_block += block_size;
+               buf_size -= block_size;
+               if (block_size < THUMB_BLOCK_SIZE) {
+                       block_size = THUMB_BLOCK_SIZE;
+               }
+       }
 
-               thumb_dbg("Path : %s", path);
+       thumb_dbg_slog("Sent data(%d) from %s", res_msg.thumb_size, res_msg.org_path);
 
-               if (g_idx == 0) {
-                       arr_path = (char**)malloc(sizeof(char*));
-               } else {
-                       arr_path = (char**)realloc(arr_path, (g_idx + 1) * sizeof(char*));
-               }
+       SAFE_FREE(buf);
+       SAFE_FREE(res_msg.thumb_data);
 
-               arr_path[g_idx++] = strdup(path);
+       if (recv_msg.msg_type == THUMB_REQUEST_KILL_SERVER) {
+               thumb_warn("Shutting down...");
+               g_main_loop_quit(g_thumb_server_mainloop);
        }
 
-       sqlite3_finalize(sqlite_stmt);
-       _media_thumb_db_disconnect();
+       close(client_sock);
 
-       return MEDIA_THUMB_ERROR_NONE;
+       return TRUE;
 }
 
-int _thumb_daemon_process_queue_jobs(gpointer data)
+static gboolean __thumb_server_send_msg_to_agent(int msg_type)
 {
-       int err = -1;
-       char *path = NULL;
-
-       if (g_cur_idx < g_idx) {
-               thumb_dbg("There are %d jobs in the queue", g_idx - g_cur_idx);
-               thumb_dbg("Current idx : [%d]", g_cur_idx);
-               path = arr_path[g_cur_idx++];
-
-               thumbMsg recv_msg, res_msg;
-               memset(&recv_msg, 0x00, sizeof(thumbMsg));
-               memset(&res_msg, 0x00, sizeof(thumbMsg));
-
-               recv_msg.msg_type = THUMB_REQUEST_DB_INSERT;
-               recv_msg.thumb_type = MEDIA_THUMB_LARGE;
-               strncpy(recv_msg.org_path, path, sizeof(recv_msg.org_path));
-               recv_msg.org_path[sizeof(recv_msg.org_path) - 1] = '\0';
-
-               _thumb_daemon_process_job(&recv_msg, &res_msg);
+       int sock;
+       struct sockaddr_un serv_addr;
+       ms_thumb_server_msg send_msg;
 
-               if (res_msg.status == THUMB_SUCCESS) {
+       if (ms_ipc_create_client_socket(MS_TIMEOUT_SEC_10, &sock) < 0) {
+               thumb_err("ms_ipc_create_server_socket failed");
+               return FALSE;
+       }
 
-                       err = _media_thumb_db_connect();
-                       if (err < 0) {
-                               thumb_err("_media_thumb_mb_svc_connect failed: %d", err);
-                               return TRUE;
-                       }
+       memset(&serv_addr, 0, sizeof(serv_addr));
 
-                       /* Need to update DB once generating thumb is done */
-                       err = _media_thumb_update_db(recv_msg.org_path,
-                                                                               res_msg.dst_path,
-                                                                               res_msg.origin_width,
-                                                                               res_msg.origin_height);
-                       if (err < 0) {
-                               thumb_err("_media_thumb_update_db failed : %d", err);
-                       }
+       serv_addr.sun_family = AF_UNIX;
+       SAFE_STRLCPY(serv_addr.sun_path, THUMB_COMM_SOCK_PATH, sizeof(serv_addr.sun_path));
 
-                       _media_thumb_db_disconnect();
-               }
 
-               SAFE_FREE(path);
-       } else {
-               g_cur_idx = 0;
-               g_idx = 0;
-               thumb_warn("Deleting array");
-               SAFE_FREE(arr_path);
-               //_media_thumb_db_disconnect();
+       /* Connecting to the thumbnail server */
+       if (connect(sock, (struct sockaddr*)&serv_addr, sizeof(serv_addr)) < 0) {
+               thumb_stderror("connect");
+               close(sock);
+               return MS_MEDIA_ERR_SOCKET_CONN;
+       }
 
-               _thumb_server_send_msg_to_agent(MS_MSG_THUMB_EXTRACT_ALL_DONE); // MS_MSG_THUMB_EXTRACT_ALL_DONE
+       send_msg.msg_type = msg_type;
 
+       if (send(sock, &send_msg, sizeof(ms_thumb_server_msg), 0) != sizeof(ms_thumb_server_msg)) {
+               thumb_stderror("sendto failed");
+               close(sock);
                return FALSE;
        }
 
+       thumb_dbg("Sending msg to thumbnail agent[%d] is successful", send_msg.msg_type);
+       close(sock);
+
        return TRUE;
 }
 
-gboolean _thumb_server_read_socket(GIOChannel *src,
-                                                                       GIOCondition condition,
-                                                                       gpointer data)
+static gboolean _thumb_server_send_deny_message(int sockfd)
 {
-       struct sockaddr_in client_addr;
-       unsigned int client_addr_len;
-#ifndef _USE_MEDIA_UTIL_
-       int client_sock;
-#endif
+       thumbMsg msg = {0};
+       int bytes_to_send = sizeof(msg) - sizeof(msg.org_path) - sizeof(msg.dst_path);
 
-       thumbMsg recv_msg;
-       thumbMsg res_msg;
-
-       int sock = -1;
-       int header_size = 0;
+       msg.msg_type = THUMB_RESPONSE;
+       msg.status = MS_MEDIA_ERR_PERMISSION_DENIED;
 
-       memset((void *)&recv_msg, 0, sizeof(recv_msg));
-       memset((void *)&res_msg, 0, sizeof(res_msg));
-
-       sock = g_io_channel_unix_get_fd(src);
-       if (sock < 0) {
-               thumb_err("sock fd is invalid!");
-               return TRUE;
+       if (send(sockfd, &msg, bytes_to_send, 0) != bytes_to_send) {
+               thumb_stderror("send failed");
+               return FALSE;
        }
 
-       header_size = sizeof(thumbMsg) - MAX_PATH_SIZE*2;
-
-#ifndef _USE_MEDIA_UTIL_
-       if ((client_sock = accept(sock, (struct sockaddr*)&client_addr, &client_addr_len)) < 0) {
-               thumb_err("accept failed : %s", strerror(errno));
-               return TRUE;
-       }
-       thumb_dbg("Client[%d] is accepted", client_sock);
+       return TRUE;
+}
 
+gboolean _thumb_server_prepare_socket(int *sock_fd)
+{
+       int sock;
 
-       if (_media_thumb_recv_msg(client_sock, header_size, &recv_msg) < 0) {
-               thumb_err("_media_thumb_recv_msg failed ");
-               close(client_sock);
-               return TRUE;
+       if (ms_ipc_create_server_socket(MS_THUMB_DAEMON_PORT, &sock) < 0) {
+               thumb_err("ms_ipc_create_server_socket failed");
+               return FALSE;
        }
-#else
 
-       if (_media_thumb_recv_udp_msg(sock, header_size, &recv_msg, &client_addr, &client_addr_len) < 0) {
-               thumb_err("_media_thumb_recv_udp_msg failed");
+       if (ms_cynara_enable_credentials_passing(sock) != MS_MEDIA_ERR_NONE) {
+               thumb_err("ms_cynara_enable_credentials_passing failed");
+               close(sock);
                return FALSE;
        }
-#endif
 
-       thumb_warn("Received [%d] %s(%d) from PID(%d) \n", recv_msg.msg_type, recv_msg.org_path, strlen(recv_msg.org_path), recv_msg.pid);
+       *sock_fd = sock;
 
-       if (recv_msg.msg_type == THUMB_REQUEST_ALL_MEDIA) {
-               thumb_dbg("All thumbnails are being extracted now");
-               _thumb_daemon_all_extract();
-               g_idle_add(_thumb_daemon_process_queue_jobs, NULL);
-       } else if(recv_msg.msg_type == THUMB_REQUEST_KILL_SERVER) {
-               thumb_warn("received KILL msg from thumbnail agent.");
-       } else {
-               long start = thumb_get_debug_time();
+       return TRUE;
+}
 
-               _thumb_daemon_process_job(&recv_msg, &res_msg);
+int _thumbnail_get_data(const char *origin_path,
+                                               char *thumb_path,
+                                               unsigned char **data,
+                                               int *width,
+                                               int *height,
+                                               int *alpha,
+                                               bool *is_saved)
+{
+       int err = MS_MEDIA_ERR_NONE;
 
-               long end = thumb_get_debug_time();
-               thumb_dbg("Time : %f (%s)", ((double)(end - start) / (double)CLOCKS_PER_SEC), recv_msg.org_path);
+       if (origin_path == NULL || width == NULL || height == NULL) {
+               thumb_err("Invalid parameter");
+               return MS_MEDIA_ERR_INVALID_PARAMETER;
        }
 
-       res_msg.msg_type = recv_msg.msg_type;
-       strncpy(res_msg.org_path, recv_msg.org_path, recv_msg.origin_path_size);
-       res_msg.origin_path_size = recv_msg.origin_path_size;
-       res_msg.dest_path_size = strlen(res_msg.dst_path) + 1;
+       if (!g_file_test(origin_path, G_FILE_TEST_EXISTS | G_FILE_TEST_IS_REGULAR)) {
+               thumb_err("Original path (%s) does not exist", origin_path);
+               return MS_MEDIA_ERR_INVALID_PARAMETER;
+       }
 
-       int buf_size = 0;
-       unsigned char *buf = NULL;
-       _media_thumb_set_buffer(&res_msg, &buf, &buf_size);
+       thumb_dbg("Origin path : %s", origin_path);
 
-       //thumb_dbg("buffer size : %d", buf_size);
+       int file_type = THUMB_NONE_TYPE;
+       media_thumb_info thumb_info = {0,};
+       file_type = _media_thumb_get_file_type(origin_path);
+       thumb_info.is_raw = FALSE;
 
-#ifndef _USE_MEDIA_UTIL_
-       if (send(client_sock, buf, buf_size, 0) != buf_size) {
-               thumb_err("sendto failed : %s", strerror(errno));
+       if (file_type == THUMB_IMAGE_TYPE) {
+               err = _media_thumb_image(origin_path, thumb_path, THUMB_DEFAULT_WIDTH, THUMB_DEFAULT_HEIGHT, &thumb_info);
+               thumb_retvm_if(err != MS_MEDIA_ERR_NONE, err, "_media_thumb_image failed");
+       } else if (file_type == THUMB_VIDEO_TYPE) {
+               err = _media_thumb_video(origin_path, THUMB_DEFAULT_WIDTH, THUMB_DEFAULT_HEIGHT, &thumb_info);
+               thumb_retvm_if(err != MS_MEDIA_ERR_NONE, err, "_media_thumb_video failed");
        } else {
-               thumb_dbg("Sent %s(%d) \n", res_msg.dst_path, strlen(res_msg.dst_path));
+               thumb_err("invalid file type");
+               return MS_MEDIA_ERR_THUMB_UNSUPPORTED;
        }
 
-       close(client_sock);
-#else
-       if (sendto(sock, buf, buf_size, 0, (struct sockaddr *)&client_addr, sizeof(client_addr)) != buf_size) {
-               thumb_err("sendto failed: %s\n", strerror(errno));
-               SAFE_FREE(buf);
-               return FALSE;
-       }
-#endif
+       if (width) *width = thumb_info.width;
+       if (height) *height = thumb_info.height;
+       *data = thumb_info.data;
+       if (alpha) *alpha = thumb_info.alpha;
+       if (is_saved) *is_saved = thumb_info.is_saved;
 
-       thumb_warn("Sent %s(%d)", res_msg.dst_path, strlen(res_msg.dst_path));
+       thumb_dbg("Thumb data is generated successfully (Size:%d, W:%d, H:%d) %p", thumb_info.size, *width, *height, *data);
 
-       SAFE_FREE(buf);
-
-       if(recv_msg.msg_type == THUMB_REQUEST_KILL_SERVER) {
-               thumb_warn("Shutting down...");
-               g_main_loop_quit(g_thumb_server_mainloop);
-       }
-
-       return TRUE;
+       return MS_MEDIA_ERR_NONE;
 }
 
-#ifdef _USE_MEDIA_UTIL_
-gboolean _thumb_server_send_msg_to_agent(int msg_type)
+int _thumbnail_get_raw_data(const char *origin_path, int *width, int *height, unsigned char **data, int *size)
 {
-       int sock;
-       const char *serv_ip = "127.0.0.1";
-       struct sockaddr_in serv_addr;
-       ms_thumb_server_msg send_msg;
-#if 0
-       /* Creaete a UDP socket */
-       if (_media_thumb_create_udp_socket(&sock) < 0) {
-               thumb_err("_media_thumb_create_udp_socket failed");
-               return FALSE;
-       }
-#endif
-       if (ms_ipc_create_client_socket(MS_PROTOCOL_UDP, MS_TIMEOUT_SEC_10, &sock) < 0) {
-               thumb_err("ms_ipc_create_server_socket failed");
-               return FALSE;
+       int err = MS_MEDIA_ERR_NONE;
+       int thumb_width = -1;
+       int thumb_height = -1;
+       const char * thumb_path = NULL;
+
+       if (origin_path == NULL || *width <= 0 || *height <= 0) {
+               thumb_err("Invalid parameter");
+               return MS_MEDIA_ERR_INVALID_PARAMETER;
        }
 
-       memset(&serv_addr, 0, sizeof(serv_addr));
-       serv_addr.sin_family = AF_INET;
-       serv_addr.sin_addr.s_addr = inet_addr(serv_ip);
-       serv_addr.sin_port = htons(MS_THUMB_COMM_PORT);
-
-       send_msg.msg_type = msg_type;
+       if (!g_file_test(origin_path, G_FILE_TEST_EXISTS | G_FILE_TEST_IS_REGULAR)) {
+               thumb_err("Original path (%s) does not exist", origin_path);
+               return MS_MEDIA_ERR_INVALID_PARAMETER;
+       }
 
-       if (sendto(sock, &send_msg, sizeof(ms_thumb_server_msg), 0, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) != sizeof(ms_thumb_server_msg)) {
-               thumb_err("sendto failed: %s\n", strerror(errno));
-               close(sock);
-               return FALSE;
+       int file_type = THUMB_NONE_TYPE;
+       media_thumb_info thumb_info = {0,};
+       file_type = _media_thumb_get_file_type(origin_path);
+       thumb_width = *width;
+       thumb_height = *height;
+       thumb_info.is_raw = TRUE;
+
+       if (file_type == THUMB_IMAGE_TYPE) {
+               err = _media_thumb_image(origin_path, thumb_path, thumb_width, thumb_height, &thumb_info);
+               thumb_retvm_if(err != MS_MEDIA_ERR_NONE, err, "_media_thumb_image failed");
+       } else if (file_type == THUMB_VIDEO_TYPE) {
+               err = _media_thumb_video(origin_path, thumb_width, thumb_height, &thumb_info);
+               thumb_retvm_if(err != MS_MEDIA_ERR_NONE, err, "_media_thumb_video failed");
+       } else {
+               thumb_err("invalid file type");
+               return MS_MEDIA_ERR_THUMB_UNSUPPORTED;
        }
 
-       thumb_dbg("Sending msg to thumbnail agent[%d] is successful", send_msg.msg_type);
+       if (size) *size = thumb_info.size;
+       *data = thumb_info.data;
+       *width = thumb_info.width;
+       *height = thumb_info.height;
 
-       close(sock);
-       return TRUE;
+       return MS_MEDIA_ERR_NONE;
 }
-#endif
 
-gboolean _thumb_server_prepare_socket(int *sock_fd)
+int _media_thumb_process(thumbMsg *req_msg, thumbMsg *res_msg)
 {
-       int sock;
-       unsigned short serv_port;
+       int err = MS_MEDIA_ERR_NONE;
+       unsigned char *data = NULL;
+       int thumb_w = 0;
+       int thumb_h = 0;
+       char *thumb_path = NULL;
+       int alpha = 0;
+       bool is_saved = FALSE;
+
+       thumb_retvm_if(req_msg == NULL || res_msg == NULL, MS_MEDIA_ERR_INVALID_PARAMETER, "Invalid msg");
+
+       const char *origin_path = req_msg->org_path;
+       memset(res_msg->dst_path, 0, MAX_FILEPATH_LEN);
+       thumb_path = res_msg->dst_path;
+       res_msg->status = MS_MEDIA_ERR_NONE;
+
+       if (!g_file_test(origin_path, G_FILE_TEST_EXISTS | G_FILE_TEST_IS_REGULAR)) {
+               thumb_err("origin_path does not exist in file system.");
+               res_msg->status = MS_MEDIA_ERR_FILE_NOT_EXIST;
+               return MS_MEDIA_ERR_FILE_NOT_EXIST;
+       }
 
-       thumbMsg recv_msg;
-       thumbMsg res_msg;
+       err = _media_thumb_get_thumb_from_db(origin_path, thumb_path, MAX_FILEPATH_LEN, req_msg->uid);
+       if (err == MS_MEDIA_ERR_NONE) {
+               thumb_dbg_slog("Thumb path : %s", thumb_path);
+               return MS_MEDIA_ERR_NONE;
+       } else {
+               if (strlen(thumb_path) == 0) {
+                       err = _media_thumb_get_hash_name(origin_path, thumb_path, MAX_FILEPATH_LEN, req_msg->uid);
+                       if (err != MS_MEDIA_ERR_NONE) {
+                               thumb_err("_media_thumb_get_hash_name failed - %d", err);
+                               SAFE_STRLCPY(thumb_path, THUMB_EMPTY_STR, MAX_FILEPATH_LEN);
+                               res_msg->status = err;
+                               return err;
+                       }
+               }
+       }
 
-       memset((void *)&recv_msg, 0, sizeof(recv_msg));
-       memset((void *)&res_msg, 0, sizeof(res_msg));
-#ifdef _USE_MEDIA_UTIL_
-       serv_port = MS_THUMB_DAEMON_PORT;
+       thumb_dbg_slog("Thumb path : %s", thumb_path);
 
-       if (ms_ipc_create_server_socket(MS_PROTOCOL_UDP, serv_port, &sock) < 0) {
-               thumb_err("ms_ipc_create_server_socket failed");
-               return FALSE;
+       if (g_file_test(thumb_path, G_FILE_TEST_EXISTS | G_FILE_TEST_IS_REGULAR)) {
+               thumb_warn("thumb path already exists in file system.. remove the existed file");
+               _media_thumb_remove_file(thumb_path);
        }
-#if 0
-       /* Creaete a UDP socket */
-       if (_media_thumb_create_udp_socket(&sock) < 0) {
-               thumb_err("_media_thumb_create_udp_socket failed");
-               return FALSE;
+
+       err = _thumbnail_get_data(origin_path, thumb_path, &data, &thumb_w, &thumb_h, &alpha, &is_saved);
+       if (err != MS_MEDIA_ERR_NONE) {
+               thumb_err("_thumbnail_get_data failed - %d", err);
+               SAFE_FREE(data);
+               SAFE_STRLCPY(thumb_path, THUMB_EMPTY_STR, MAX_FILEPATH_LEN);
+               res_msg->status = err;
+
+               goto DB_UPDATE;
        }
-#endif
-#else
-       char thumb_path[MAX_PATH_SIZE + 1];
-       struct sockaddr_in serv_addr;
-       serv_port = THUMB_DAEMON_PORT;
-
-       /* Creaete a TCP socket */
-       if (_media_thumb_create_socket(SERVER_SOCKET, &sock) < 0) {
-               thumb_err("_media_thumb_create_socket failed");
-               return FALSE;
+
+       res_msg->msg_type = THUMB_RESPONSE;
+
+       /* If the image is transparent PNG format, make png file as thumbnail of this image */
+       if (alpha) {
+               char file_ext[10];
+               err = _media_thumb_get_file_ext(origin_path, file_ext, sizeof(file_ext));
+               if (strncasecmp(file_ext, "png", 3) == 0) {
+                       int len = strlen(thumb_path);
+                       thumb_path[len - 3] = 'p';
+                       thumb_path[len - 2] = 'n';
+                       thumb_path[len - 1] = 'g';
+               }
+               thumb_dbg_slog("Thumb path is changed : %s", thumb_path);
        }
 
-       memset(thumb_path, 0, sizeof(thumb_path));
-       memset(&serv_addr, 0, sizeof(serv_addr));
-       serv_addr.sin_family = AF_INET;
-       serv_addr.sin_addr.s_addr = htonl(INADDR_ANY);
-       serv_addr.sin_port = htons(serv_port);
+       if (is_saved == FALSE && data != NULL) {
+               err = _media_thumb_save_to_file_with_evas(data, thumb_w, thumb_h, alpha, thumb_path);
+               if (err != MS_MEDIA_ERR_NONE) {
+                       thumb_err("save_to_file_with_evas failed - %d", err);
+                       SAFE_FREE(data);
 
-       /* Bind to the local address */
-       if (bind(sock, (struct sockaddr *)&serv_addr, sizeof(serv_addr)) < 0) {
-               thumb_err("bind failed : %s", strerror(errno));
-               return FALSE;
+                       SAFE_STRLCPY(thumb_path, THUMB_EMPTY_STR, MAX_FILEPATH_LEN);
+                       res_msg->status = err;
+                       return err;
+               } else {
+                       thumb_dbg("file save success");
+               }
+       } else {
+               thumb_dbg("file is already saved");
        }
 
-       thumb_dbg("bind success");
+       /* fsync */
+       int fd = 0;
+       fd = open(thumb_path, O_WRONLY);
+       if (fd < 0) {
+               thumb_warn("open failed");
+       } else {
+               err = fsync(fd);
+               if (err == -1) {
+                       thumb_warn("fsync failed");
+                       res_msg->status = MS_MEDIA_ERR_INTERNAL;
+               }
 
-       /* Listening */
-       if (listen(sock, SOMAXCONN) < 0) {
-               thumb_err("listen failed : %s", strerror(errno));
+               close(fd);
+       }
+       /* End of fsync */
+
+       SAFE_FREE(data);
+DB_UPDATE:
+       err = _media_thumb_update_db(origin_path, thumb_path, req_msg->uid);
+       if (err != MS_MEDIA_ERR_NONE) {
+               thumb_err("_media_thumb_update_db failed : %d", err);
+               res_msg->status = err;
        }
 
-       thumb_dbg("Listening...");
-#endif
+       return err;
+}
 
-       *sock_fd = sock;
+int
+_media_thumb_process_raw(thumbMsg *req_msg, thumbMsg *res_msg)
+{
+       int err = MS_MEDIA_ERR_NONE;
+       unsigned char *data = NULL;
+       int thumb_size = 0;
+       int thumb_w = 0;
+       int thumb_h = 0;
+
+       thumb_retvm_if(req_msg == NULL || res_msg == NULL, MS_MEDIA_ERR_INVALID_PARAMETER, "Invalid msg");
+
+       const char *origin_path = req_msg->org_path;
+       if (req_msg->thumb_width > 0)
+               thumb_w = req_msg->thumb_width;
+       else
+               thumb_w = THUMB_DEFAULT_WIDTH;
+
+       if (req_msg->thumb_height > 0)
+               thumb_h = req_msg->thumb_height;
+       else
+               thumb_h = THUMB_DEFAULT_HEIGHT;
+
+       res_msg->status = MS_MEDIA_ERR_NONE;
+       res_msg->msg_type = THUMB_RESPONSE_RAW_DATA;
+
+       err = _thumbnail_get_raw_data(origin_path, &thumb_w, &thumb_h, &data, &thumb_size);
+       if (err != MS_MEDIA_ERR_NONE) {
+               thumb_err("_thumbnail_get_data failed - %d", err);
+               res_msg->status = err;
+               res_msg->thumb_size = 0;
+               SAFE_FREE(data);
+
+               return err;
+       }
 
-       return TRUE;
-}
+       res_msg->thumb_width = thumb_w;
+       res_msg->thumb_height = thumb_h;
+       res_msg->thumb_size = thumb_size;
+       res_msg->thumb_data = malloc(thumb_size * sizeof(unsigned char));
+       if (res_msg->thumb_data != NULL) {
+               memcpy(res_msg->thumb_data, data, thumb_size);
+       } else {
+               thumb_err("Allocation failed");
+               err = MS_MEDIA_ERR_OUT_OF_MEMORY;
+       }
 
+       SAFE_FREE(data);
+
+       return err;
+}