Support ogg loop playback
[platform/core/multimedia/libmm-sound.git] / mm_sound_proxy.c
index e0b67cc..552614a 100644 (file)
@@ -1,3 +1,4 @@
+#include <stdint.h>
 #include <glib.h>
 
 #include <mm_error.h>
 #include "include/mm_sound_dbus.h"
 #include "include/mm_sound_intf.h"
 
-#ifdef USE_SECURITY
-#include <security-server.h>
-#define COOKIE_SIZE 20
-#endif
-
-
 struct callback_data {
        void *user_cb;
        void *user_data;
-       void *extra_data;
        mm_sound_proxy_userdata_free free_func;
+       uint32_t subs_id;
 };
 
-#define GET_CB_DATA(_cb_data, _func, _userdata, _freefunc, _extradata) \
+#define CB_DATA_NEW(_cb_data, _func, _userdata, _freefunc) \
        do { \
                _cb_data = (struct callback_data*) g_malloc0(sizeof(struct callback_data)); \
                _cb_data->user_cb = _func; \
                _cb_data->user_data = _userdata; \
                _cb_data->free_func = _freefunc; \
-               _cb_data->extra_data = _extradata; \
+               _cb_data->subs_id = 0; \
        } while (0)
 
+/* subscribe is true when add callback,
+ * false when remove callback */
+static int _notify_subscription(audio_event_t event, uint32_t subs_id, gboolean subscribe)
+{
+       int ret = MM_ERROR_NONE;
+       GVariant *params = NULL;
+       const char *event_name = NULL;
+
+       debug_fenter();
+
+       if ((ret = mm_sound_dbus_get_event_name(event, &event_name) != MM_ERROR_NONE)) {
+               debug_error("Failed to get event name");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if (!(params = g_variant_new("(sub)", event_name, subs_id, subscribe))) {
+               debug_error("Construct Param failed");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_SUBSCRIBED, params))) {
+               debug_error("dbus send signal for client subscribed failed");
+       }
+
+       debug_fleave();
+       return ret;
+}
+
+static int _notify_signal_handled(audio_event_t event, uint32_t event_id, uint32_t subs_id, GVariant *signal_params)
+{
+       int ret = MM_ERROR_NONE;
+       GVariant *params = NULL;
+       const char *event_name = NULL;
+
+       debug_fenter();
+
+       if ((ret = mm_sound_dbus_get_event_name(event, &event_name) != MM_ERROR_NONE)) {
+               debug_error("Failed to get event name");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if (!(params = g_variant_new("(usuv)", event_id, event_name, subs_id, signal_params))) {
+               debug_error("Construct Param failed");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_CLIENT_HANDLED, params))) {
+               debug_error("dbus send signal for client handled failed");
+       }
+
+       debug_fleave();
+       return ret;
+}
+
+static int parse_device_variant(GVariant *v, int *device_id, const char **device_type, int *direction, int *state,
+                                                               const char **device_name, int *stream_id, int *stream_num)
+{
+       const char *v_type;
+       GVariant *array_v;
+       GVariantIter iter, array_iter;
+       int i = 0;
+       int ret = MM_ERROR_NONE;
+
+       if (v == NULL) {
+               debug_error("Variant NULL");
+               return MM_ERROR_NONE;
+       }
+
+       v_type = g_variant_get_type_string(v);
+       if (g_variant_type_equal(v_type, "(isiisai)") == FALSE) {
+               debug_error("device variant type not matching '%s'", v_type);
+               return MM_ERROR_NONE;
+       }
+
+       g_variant_iter_init(&iter, v);
+       g_variant_iter_next(&iter, "i", device_id);
+       g_variant_iter_next(&iter, "&s", device_type);
+       g_variant_iter_next(&iter, "i", direction);
+       g_variant_iter_next(&iter, "i", state);
+       g_variant_iter_next(&iter, "&s", device_name);
+
+       array_v = g_variant_iter_next_value(&iter);
+       *stream_num = g_variant_iter_init(&array_iter, array_v);
+       if (*stream_num > MAX_STREAM_ON_DEVICE) {
+               debug_error("too many streams on device %d", *stream_num);
+               ret = MM_ERROR_SOUND_INTERNAL;
+               goto finish;
+       }
+
+       while (g_variant_iter_loop(&array_iter, "i", &stream_id[i++])) ;
+finish:
+       g_variant_unref(array_v);
+
+       return ret;
+}
 
 /* This callback unmarshall general-formed paramters to subject specific parameters,
  * and call proper callback */
 static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
 {
        struct callback_data *cb_data  = (struct callback_data*) userdata;
+       uint32_t event_id;
+       const char *name = NULL, *device_type = NULL;
+       int device_id, direction, state;
+       const gchar *v_type;
+       GVariantIter iter;
+       GVariant *device_v;
+       int stream_id[MAX_STREAM_ON_DEVICE];
+       int stream_num;
+
+       v_type = g_variant_get_type_string(params);
 
-       if (event == AUDIO_EVENT_VOLUME_CHANGED) {
+       if (event == AUDIO_EVENT_VOLUME_CHANGED) {
                char *volume_type_str = NULL, *direction = NULL;
                unsigned volume_level;
 
                g_variant_get(params, "(&s&su)", &direction, &volume_type_str, &volume_level);
                ((mm_sound_volume_changed_wrapper_cb)(cb_data->user_cb))(direction, volume_type_str, volume_level, cb_data->user_data);
        } else if (event == AUDIO_EVENT_DEVICE_CONNECTED) {
-               const char *name = NULL, *device_type = NULL;
                gboolean is_connected = FALSE;
-               int device_id, io_direction, state;
 
-               g_variant_get(params, "((i&sii&s)b)", &device_id, &device_type, &io_direction,
-                                       &state, &name, &is_connected);
-               ((mm_sound_device_connected_wrapper_cb)(cb_data->user_cb))(device_id, device_type, io_direction, state, name, is_connected, cb_data->user_data);
+               if (g_variant_type_equal(v_type, "(u(isiisai)b)") == FALSE) {
+                       debug_error("Device connection changed signature not matching : %s", v_type);
+                       return ;
+               }
+               g_variant_iter_init(&iter, params);
+               g_variant_iter_next(&iter, "u", &event_id);
+               device_v = g_variant_iter_next_value(&iter);
+               if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
+                                                       &name, stream_id, &stream_num) < 0) {
+                       debug_error("Failed to parse device variant");
+                       return ;
+               }
+               g_variant_iter_next(&iter, "b", &is_connected);
+
+               ((mm_sound_device_connected_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
+                       state, name, stream_id, stream_num, is_connected, cb_data->user_data);
+               _notify_signal_handled(event, event_id, cb_data->subs_id, g_variant_new("(ib)", device_id, is_connected));
        } else if (event == AUDIO_EVENT_DEVICE_INFO_CHANGED) {
-               const char *name = NULL, *device_type = NULL;
                int changed_device_info_type = 0;
-               int device_id, io_direction, state;
 
-               g_variant_get(params, "((i&sii&s)i)", &device_id, &device_type, &io_direction,
-                                       &state, &name, &changed_device_info_type);
-               ((mm_sound_device_info_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, io_direction, state, name, changed_device_info_type, cb_data->user_data);
+               if (g_variant_type_equal(v_type, "(u(isiisai)i)") == FALSE) {
+                       debug_error("Device information changed signature not matching : %s", v_type);
+                       return ;
+               }
+
+               g_variant_iter_init(&iter, params);
+               g_variant_iter_next(&iter, "u", &event_id);
+               device_v = g_variant_iter_next_value(&iter);
+               if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
+                                                       &name, stream_id, &stream_num) < 0) {
+                       debug_error("Failed to parse device variant");
+                       return ;
+               }
+               g_variant_iter_next(&iter, "i", &changed_device_info_type);
+
+               ((mm_sound_device_info_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
+                       state, name, stream_id, stream_num, changed_device_info_type, cb_data->user_data);
+       } else if (event == AUDIO_EVENT_DEVICE_STATE_CHANGED) {
+
+               if (g_variant_type_equal(v_type, "(u(isiisai))") == FALSE) {
+                       debug_error("Device state changed signature not matching : %s", v_type);
+                       return ;
+               }
+
+               g_variant_iter_init(&iter, params);
+               g_variant_iter_next(&iter, "u", &event_id);
+               device_v = g_variant_iter_next_value(&iter);
+               if (parse_device_variant(device_v, &device_id, &device_type, &direction, &state,
+                                                       &name, stream_id, &stream_num) < 0) {
+                       debug_error("Failed to parse device variant");
+                       return ;
+               }
+
+               ((mm_sound_device_state_changed_wrapper_cb)(cb_data->user_cb))(device_id, device_type, direction,
+                       state, name, stream_id, stream_num, cb_data->user_data);
        } else if (event == AUDIO_EVENT_FOCUS_CHANGED) {
        } else if (event == AUDIO_EVENT_FOCUS_WATCH) {
        } else if (event == AUDIO_EVENT_TEST) {
@@ -74,12 +216,13 @@ static void dbus_callback(audio_event_t event, GVariant *params, void *userdata)
 
 static void simple_callback_data_free_func(void *data)
 {
-    struct callback_data *cb_data = (struct callback_data*) data;
+       struct callback_data *cb_data = (struct callback_data*) data;
 
-    if (cb_data->free_func)
-       cb_data->free_func(cb_data->user_data);
-
-    g_free(cb_data);
+       if (cb_data) {
+               if (cb_data->free_func)
+                       cb_data->free_func(cb_data->user_data);
+               g_free(cb_data);
+       }
 }
 
 int mm_sound_proxy_add_test_callback(mm_sound_test_cb func, void *userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
@@ -89,11 +232,12 @@ int mm_sound_proxy_add_test_callback(mm_sound_test_cb func, void *userdata, mm_s
 
        debug_fenter();
 
-       GET_CB_DATA(cb_data, func, userdata, freefunc, NULL);
+       CB_DATA_NEW(cb_data, func, userdata, freefunc);
 
-       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_EVENT_TEST, dbus_callback, cb_data, simple_callback_data_free_func, subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_EVENT_TEST, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
                debug_error("add test callback failed");
-       }
+       else
+               *subs_id = cb_data->subs_id;
 
        debug_fleave();
        return ret;
@@ -147,11 +291,53 @@ cleanup:
        return ret;
 }
 
+int mm_sound_proxy_is_stream_on_device(int stream_id, int device_id, bool *is_on)
+{
+       int ret = MM_ERROR_NONE;
+       GVariant *params, *result;
+       gboolean _is_on;
+
+       debug_fenter();
+
+       if (!is_on) {
+               debug_error("Invalid Parameter, is_on null");
+               return MM_ERROR_INVALID_ARGUMENT;
+       }
+
+       if ((params = g_variant_new("(ii)", stream_id, device_id)) == NULL) {
+               debug_error("Construct Param for query is stream on device failed");
+               return MM_ERROR_SOUND_INTERNAL;
+       }
+
+       if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_METHOD_IS_STREAM_ON_DEVICE, params, &result)) != MM_ERROR_NONE) {
+               debug_error("is stream on device failed");
+               goto cleanup;
+       }
+
+       if (result) {
+               g_variant_get(result, "(b)",  &_is_on);
+               debug_log("is_on : %d", _is_on);
+               *is_on = (bool)_is_on;
+       } else {
+               debug_error("reply null");
+               ret = MM_ERROR_SOUND_INTERNAL;
+       }
+
+cleanup:
+       if (params)
+               g_variant_unref(params);
+       if (result)
+               g_variant_unref(result);
+
+       debug_fleave();
+       return ret;
+}
+
 int mm_sound_proxy_get_current_connected_device_list(int device_flags, GList** device_list)
 {
        int ret = MM_ERROR_NONE;
        GVariant *result = NULL, *child = NULL;
-       GVariant *params;
+       GVariant *params = NULL;
        GVariantIter iter;
        mm_sound_device_t* device_item;
        const gchar *device_name_tmp = NULL, *device_type_tmp = NULL;
@@ -180,11 +366,16 @@ int mm_sound_proxy_get_current_connected_device_list(int device_flags, GList** d
        g_variant_iter_init(&iter, child);
        while (1) {
                device_item = g_malloc0(sizeof(mm_sound_device_t));
-               if (device_item && g_variant_iter_loop(&iter, "(i&sii&s)", &device_item->id, &device_type_tmp, &device_item->io_direction, &device_item->state, &device_name_tmp)) {
+               if (device_item && g_variant_iter_loop(&iter, "(i&sii&s)",
+                                       &device_item->id, &device_type_tmp, &device_item->io_direction, &device_item->state,
+                                       &device_name_tmp)) {
                        MMSOUND_STRNCPY(device_item->name, device_name_tmp, MAX_DEVICE_NAME_NUM);
                        MMSOUND_STRNCPY(device_item->type, device_type_tmp, MAX_DEVICE_TYPE_STR_LEN);
                        *device_list = g_list_append(*device_list, device_item);
-                       debug_log("Added device id(%d) type(%17s) direction(%d) state(%d) name(%s)", device_item->id, device_item->type,device_item->io_direction, device_item->state, device_item->name);
+                       debug_log("Added device id(%d) type(%17s) direction(%d) state(%d) name(%s)",
+                                       device_item->id, device_item->type,device_item->io_direction, device_item->state,
+                                       device_item->name);
+                       device_item->stream_num = -1;
                } else {
                        if (device_item)
                                g_free(device_item);
@@ -207,12 +398,21 @@ int mm_sound_proxy_add_device_connected_callback(int device_flags, mm_sound_devi
 
        debug_fenter();
 
-       GET_CB_DATA(cb_data, func, userdata, freefunc, NULL);
+       CB_DATA_NEW(cb_data, func, userdata, freefunc);
 
-       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_CONNECTED, dbus_callback, cb_data, simple_callback_data_free_func, subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_CONNECTED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE) {
                debug_error("add device connected callback failed");
+               goto finish;
        }
 
+       if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, cb_data->subs_id, TRUE)) != MM_ERROR_NONE) {
+               debug_error("failed to notify subscription of device connected event");
+               goto finish;
+       }
+
+       *subs_id = cb_data->subs_id;
+
+finish:
        debug_fleave();
        return ret;
 }
@@ -224,8 +424,13 @@ int mm_sound_proxy_remove_device_connected_callback(unsigned subs_id)
 
        if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
                debug_error("remove device connected callback failed");
+               goto finish;
        }
 
+       if ((ret = _notify_subscription(AUDIO_EVENT_DEVICE_CONNECTED, subs_id, FALSE)) != MM_ERROR_NONE)
+               debug_error("failed to notify unsubscription of device connected event");
+
+finish:
        debug_fleave();
        return ret;
 }
@@ -237,11 +442,12 @@ int mm_sound_proxy_add_device_info_changed_callback(int device_flags, mm_sound_d
 
        debug_fenter();
 
-       GET_CB_DATA(cb_data, func, userdata, freefunc, NULL);
+       CB_DATA_NEW(cb_data, func, userdata, freefunc);
 
-       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_INFO_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_INFO_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
                debug_error("Add device info changed callback failed");
-       }
+       else
+               *subs_id = cb_data->subs_id;
 
        debug_fleave();
        return ret;
@@ -260,6 +466,37 @@ int mm_sound_proxy_remove_device_info_changed_callback(unsigned subs_id)
        return ret;
 }
 
+int mm_sound_proxy_add_device_state_changed_callback(int device_flags, mm_sound_device_state_changed_wrapper_cb func, void* userdata, mm_sound_proxy_userdata_free freefunc, unsigned *subs_id)
+{
+       int ret = MM_ERROR_NONE;
+       struct callback_data *cb_data;
+
+       debug_fenter();
+
+       CB_DATA_NEW(cb_data, func, userdata, freefunc);
+
+       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_DEVICE_MANAGER, AUDIO_EVENT_DEVICE_STATE_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
+               debug_error("Add device state changed callback failed");
+       else
+               *subs_id = cb_data->subs_id;
+
+       debug_fleave();
+       return ret;
+}
+
+int mm_sound_proxy_remove_device_state_changed_callback(unsigned subs_id)
+{
+       int ret = MM_ERROR_NONE;
+       debug_fenter();
+
+       if ((ret = mm_sound_dbus_signal_unsubscribe(subs_id)) != MM_ERROR_NONE) {
+               debug_error("remove device state changed callback failed");
+       }
+
+       debug_fleave();
+       return ret;
+}
+
 int mm_sound_proxy_set_volume_by_type(const char *volume_type, const unsigned volume_level)
 {
        int ret = MM_ERROR_NONE;
@@ -303,11 +540,13 @@ int mm_sound_proxy_add_volume_changed_callback(mm_sound_volume_changed_wrapper_c
 
        debug_fenter();
 
-       GET_CB_DATA(cb_data, func, userdata, freefunc, NULL);
+       CB_DATA_NEW(cb_data, func, userdata, freefunc);
 
-       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_EVENT_VOLUME_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_STREAM_MANAGER, AUDIO_EVENT_VOLUME_CHANGED, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
                debug_error("Add Volume changed callback failed");
-       }
+       else
+               *subs_id = cb_data->subs_id;
+
 
        debug_fleave();
 
@@ -333,7 +572,7 @@ int mm_sound_proxy_play_tone(int tone, int repeat, int volume, int volume_config
 {
        int ret = MM_ERROR_NONE;
        int handle = 0;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
        gboolean _enable_session = enable_session;
 
        if (!codechandle) {
@@ -343,8 +582,8 @@ int mm_sound_proxy_play_tone(int tone, int repeat, int volume, int volume_config
 
        debug_fenter();
 
-       params = g_variant_new("(iiiiiiibsi)", tone, repeat, volume,
-                     volume_config, session_type, session_options, client_pid , _enable_session, stream_type, stream_index);
+       params = g_variant_new("(iiiiiiibsi)", tone, repeat, volume, volume_config, session_type,
+                     session_options, client_pid , _enable_session, stream_type, stream_index);
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_DTMF, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus play tone failed");
@@ -368,15 +607,13 @@ cleanup:
 
        debug_fleave();
        return ret;
-
-
 }
 
 int mm_sound_proxy_play_tone_with_stream_info(int client_pid, int tone, char *stream_type, int stream_index, int volume, int repeat, int *codechandle)
 {
        int ret = MM_ERROR_NONE;
        int handle = 0;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
@@ -409,17 +646,15 @@ cleanup:
 
        debug_fleave();
        return ret;
-
-
 }
 
 int mm_sound_proxy_play_sound(const char* filename, int tone, int repeat, int volume, int volume_config,
-                          int priority, int session_type, int session_options, int client_pid, int handle_route,
-                          bool enable_session, int *codechandle, char *stream_type, int stream_index)
+                          int session_type, int session_options, int client_pid, bool enable_session, int *codechandle,
+                          char *stream_type, int stream_index)
 {
        int ret = MM_ERROR_NONE;
        int handle = 0;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
        gboolean _enable_session = enable_session;
 
        if (!filename || !codechandle) {
@@ -429,8 +664,8 @@ int mm_sound_proxy_play_sound(const char* filename, int tone, int repeat, int vo
 
        debug_fenter();
 
-       params = g_variant_new("(siiiiiiiiibsi)", filename, tone, repeat, volume,
-                     volume_config, priority, session_type, session_options, client_pid, handle_route, _enable_session, stream_type, stream_index);
+       params = g_variant_new("(siiiiiiibsi)", filename, tone, repeat, volume,
+                     volume_config, session_type, session_options, client_pid, _enable_session, stream_type, stream_index);
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_START, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus play file failed");
@@ -457,11 +692,11 @@ cleanup:
 }
 
 int mm_sound_proxy_play_sound_with_stream_info(const char* filename, int repeat, int volume,
-                               int priority, int client_pid, int handle_route, int *codechandle, char *stream_type, int stream_index)
+                               int client_pid, int *codechandle, char *stream_type, int stream_index)
 {
        int ret = MM_ERROR_NONE;
        int handle = 0;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        if (!filename || !codechandle) {
                debug_error("Param for play is null");
@@ -470,8 +705,7 @@ int mm_sound_proxy_play_sound_with_stream_info(const char* filename, int repeat,
 
        debug_fenter();
 
-       params = g_variant_new("(siiiiisi)", filename, repeat, volume,
-                       priority, client_pid, handle_route, stream_type, stream_index);
+       params = g_variant_new("(siiisi)", filename, repeat, volume, client_pid, stream_type, stream_index);
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_METHOD_PLAY_FILE_START_WITH_STREAM_INFO, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus play file failed");
@@ -499,7 +733,6 @@ cleanup:
 
 }
 
-
 int mm_sound_proxy_stop_sound(int handle)
 {
        int ret = MM_ERROR_NONE;
@@ -545,11 +778,12 @@ int mm_sound_proxy_add_play_sound_end_callback(mm_sound_stop_callback_wrapper_fu
 
        debug_fenter();
 
-       GET_CB_DATA(cb_data, func, userdata, freefunc, NULL);
+       CB_DATA_NEW(cb_data, func, userdata, freefunc);
 
-       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_EVENT_PLAY_FILE_END, dbus_callback, cb_data, simple_callback_data_free_func, subs_id)) != MM_ERROR_NONE) {
+       if ((ret = mm_sound_dbus_signal_subscribe_to(AUDIO_PROVIDER_SOUND_SERVER, AUDIO_EVENT_PLAY_FILE_END, dbus_callback, cb_data, simple_callback_data_free_func, &cb_data->subs_id)) != MM_ERROR_NONE)
                debug_error("add play sound end callback failed");
-       }
+       else
+               *subs_id = cb_data->subs_id;
 
        debug_fleave();
 
@@ -572,13 +806,13 @@ int mm_sound_proxy_remove_play_sound_end_callback(unsigned subs_id)
 int mm_sound_proxy_emergent_exit(int exit_pid)
 {
        int ret = MM_ERROR_NONE;
-       GVariantparams = NULL;
+       GVariant *params = NULL;
 
        debug_fenter();
 
        params = g_variant_new("(i)", exit_pid);
        if (params) {
-           if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_EMERGENT_EXIT, params)) != MM_ERROR_NONE) {
+               if ((ret = mm_sound_dbus_emit_signal(AUDIO_PROVIDER_AUDIO_CLIENT, AUDIO_EVENT_EMERGENT_EXIT, params)) != MM_ERROR_NONE) {
                        debug_error("dbus emergent exit failed");
                        goto cleanup;
                }
@@ -596,52 +830,6 @@ cleanup:
 /*------------------------------------------ FOCUS --------------------------------------------------*/
 #ifdef USE_FOCUS
 
-#ifdef SUPPORT_CONTAINER
-#ifdef USE_SECURITY
-char* _get_cookie(int cookie_size)
-{
-       int retval = -1;
-       char* cookie = NULL;
-
-       if (security_server_get_cookie_size() != cookie_size) {
-               debug_error ("[Security] security_server_get_cookie_size() != COOKIE_SIZE(%d)\n", cookie_size);
-               return false;
-       }
-
-       cookie = (char*)malloc (cookie_size);
-
-       retval = security_server_request_cookie (cookie, cookie_size);
-       if (retval == SECURITY_SERVER_API_SUCCESS) {
-               debug_msg ("[Security] security_server_request_cookie() returns [%d]\n", retval);
-       } else {
-               debug_error ("[Security] security_server_request_cookie() returns [%d]\n", retval);
-       }
-
-       return cookie;
-}
-
-static GVariant* _get_cookie_variant ()
-{
-       int i;
-       GVariantBuilder builder;
-       char* cookie = NULL;
-
-       cookie = _get_cookie(COOKIE_SIZE);
-
-       if (cookie == NULL)
-               return NULL;
-
-       g_variant_builder_init(&builder, G_VARIANT_TYPE_ARRAY);
-       for (i = 0; i < COOKIE_SIZE; i++)
-               g_variant_builder_add(&builder, "y", cookie[i]);
-
-       free (cookie);
-       return g_variant_builder_end(&builder);
-}
-
-#endif /* USE_SECURITY */
-#endif /* SUPPORT_CONTAINER */
-
 int mm_sound_proxy_get_unique_id(int *id)
 {
        int ret = MM_ERROR_NONE;
@@ -669,27 +857,11 @@ int mm_sound_proxy_get_unique_id(int *id)
 int mm_sound_proxy_register_focus(int id, int instance, const char *stream_type, mm_sound_focus_changed_cb callback, bool is_for_session, void* userdata)
 {
        int ret = MM_ERROR_NONE;
-       GVariant* params = NULL, *result = NULL;
-#ifdef SUPPORT_CONTAINER
-       char container[128];
-#endif
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
-#ifdef SUPPORT_CONTAINER
-#ifdef USE_SECURITY
-       params = g_variant_new("(@ayiisb)", _get_cookie_variant(), instance, id, stream_type, is_for_session);
-#else /* USE_SECURITY */
-       gethostname(container, sizeof(container));
-       debug_error("container = %s", container);
-       params = g_variant_new("(siisb)", container, instance, id, stream_type, is_for_session);
-#endif /* USE_SECURITY */
-
-#else /* SUPPORT_CONTAINER */
        params = g_variant_new("(iisb)", instance, id, stream_type, is_for_session);
-
-#endif /* SUPPORT_CONTAINER */
-
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_REGISTER_FOCUS, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus register focus failed");
@@ -698,7 +870,7 @@ int mm_sound_proxy_register_focus(int id, int instance, const char *stream_type,
                debug_error("Construct Param for method call failed");
        }
 
-       if(ret != MM_ERROR_NONE)
+       if (ret != MM_ERROR_NONE)
                g_variant_get(result, "(i)",  &ret);
        if (result)
                g_variant_unref(result);
@@ -712,7 +884,7 @@ int mm_sound_proxy_register_focus(int id, int instance, const char *stream_type,
 int mm_sound_proxy_unregister_focus(int instance, int id, bool is_for_session)
 {
        int ret = MM_ERROR_NONE;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
@@ -738,7 +910,7 @@ int mm_sound_proxy_unregister_focus(int instance, int id, bool is_for_session)
 int mm_sound_proxy_set_foucs_reacquisition(int instance, int id, bool reacquisition)
 {
        int ret = MM_ERROR_NONE;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
@@ -760,10 +932,10 @@ int mm_sound_proxy_set_foucs_reacquisition(int instance, int id, bool reacquisit
        return ret;
 }
 
-int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_type, char **additional_info)
+int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_type, int *option, char **ext_info)
 {
        int ret = MM_ERROR_NONE;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
@@ -774,7 +946,7 @@ int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_
 
        if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_GET_ACQUIRED_FOCUS_STREAM_TYPE, params, &result)) == MM_ERROR_NONE) {
                if (result) {
-                       g_variant_get(result, "(ss)", stream_type, additional_info);
+                       g_variant_get(result, "(sis)", stream_type, option, ext_info);
                        g_variant_unref(result);
                }
        } else {
@@ -785,14 +957,14 @@ int mm_sound_proxy_get_acquired_focus_stream_type(int focus_type, char **stream_
        return ret;
 }
 
-int mm_sound_proxy_acquire_focus(int instance, int id, mm_sound_focus_type_e type, const char *option, bool is_for_session)
+int mm_sound_proxy_acquire_focus(int instance, int id, mm_sound_focus_type_e type, int option, const char *ext_info, bool is_for_session)
 {
        int ret = MM_ERROR_NONE;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
-       params = g_variant_new("(iiisb)", instance, id, type, option, is_for_session);
+       params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_ACQUIRE_FOCUS, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus acquire focus failed");
@@ -810,14 +982,14 @@ int mm_sound_proxy_acquire_focus(int instance, int id, mm_sound_focus_type_e typ
        return ret;
 }
 
-int mm_sound_proxy_release_focus(int instance, int id, mm_sound_focus_type_e type, const char *option, bool is_for_session)
+int mm_sound_proxy_release_focus(int instance, int id, mm_sound_focus_type_e type, int option, const char *ext_info, bool is_for_session)
 {
        int ret = MM_ERROR_NONE;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
 
-       params = g_variant_new("(iiisb)", instance, id, type, option, is_for_session);
+       params = g_variant_new("(iiiisb)", instance, id, type, option, ext_info ? ext_info : "", is_for_session);
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_RELEASE_FOCUS, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus release focus failed");
@@ -838,25 +1010,11 @@ int mm_sound_proxy_release_focus(int instance, int id, mm_sound_focus_type_e typ
 int mm_sound_proxy_set_focus_watch_callback(int instance, int handle, mm_sound_focus_type_e type, mm_sound_focus_changed_watch_cb callback, bool is_for_session, void* userdata)
 {
        int ret = MM_ERROR_NONE;
-       GVariant* params = NULL, *result = NULL;
-#ifdef SUPPORT_CONTAINER
-       char container[128];
-#endif
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();
-#ifdef SUPPORT_CONTAINER
-#ifdef USE_SECURITY
-       params = g_variant_new("(@ayiiib)", _get_cookie_variant(), instance, handle, type, is_for_session);
-#else /* USE_SECURITY */
-       gethostname(container, sizeof(container));
-       debug_error("container = %s", container);
-       params = g_variant_new("(siiib)", container, instance, handle, type, is_for_session);
-#endif /* USE_SECURITY */
 
-#else /* SUPPORT_CONTAINER */
        params = g_variant_new("(iiib)", instance, handle, type, is_for_session);
-#endif /* SUPPORT_CONTAINER */
-
        if (params) {
                if ((ret = mm_sound_dbus_method_call_to(AUDIO_PROVIDER_FOCUS_SERVER, AUDIO_METHOD_WATCH_FOCUS, params, &result)) != MM_ERROR_NONE) {
                        debug_error("dbus set watch focus failed");
@@ -878,7 +1036,7 @@ int mm_sound_proxy_set_focus_watch_callback(int instance, int handle, mm_sound_f
 int mm_sound_proxy_unset_focus_watch_callback(int focus_tid, int handle, bool is_for_session)
 {
        int ret = MM_ERROR_NONE;
-       GVariantparams = NULL, *result = NULL;
+       GVariant *params = NULL, *result = NULL;
 
        debug_fenter();