Revert "Use Trusted Profiles instead of Restricted Profiles"
[platform/core/connectivity/bluetooth-frwk.git] / bt-service / bt-request-handler.c
index ba982f6..2de10c7 100644 (file)
@@ -45,6 +45,7 @@
 #include "bt-service-dpm.h"
 #include "bt-service-agent.h"
 #include "bt-service-proximity.h"
+#include "bt-service-tds.h"
 
 static GDBusConnection *bt_service_conn;
 static guint owner_id = 0;
@@ -71,7 +72,7 @@ static const gchar bt_service_introspection_xml[] =
 "      </interface>"
 "</node>";
 
-GDBusNodeInfo *node_info = NULL;
+static gboolean name_acquired = FALSE;
 
 static char *current_sender_playing = NULL;
 
@@ -181,15 +182,14 @@ static void __bt_service_method(GDBusConnection *connection,
 
                sender = g_dbus_method_invocation_get_sender(invocation);
 
-               // TODO map - privileges should be checked, just debugging purposes
-               /*if (service_type == BT_CORE_SERVICE) {
+               if (service_type == BT_CORE_SERVICE) {
                        BT_DBG("No need to check privilege from bt-core");
                } else if (__bt_service_check_privilege(service_function,
                                        service_type, (const char *)sender) == FALSE) {
                        BT_ERR("Client don't have the privilege to excute this function");
                        result = BLUETOOTH_ERROR_PERMISSION_DEINED;
                        goto fail;
-               }*/
+               }
 
                if (request_type == BT_ASYNC_REQ
                                || service_function == BT_OBEX_SERVER_ACCEPT_CONNECTION) {
@@ -205,8 +205,9 @@ static void __bt_service_method(GDBusConnection *connection,
                        }
                }
 
-               BT_DBG("SERVICE TYPE [%d] SERVICE FUNC [%d]",
-                               service_type, service_function);
+               BT_DBG("Service type = %d, fn = %s (0x%x)",
+                               service_type, _bt_convert_service_function_to_string(service_function),
+                               service_function);
                switch (service_type) {
                case BT_BLUEZ_SERVICE:
                        result = __bt_bluez_request(service_function,
@@ -277,7 +278,7 @@ static void __bt_service_method(GDBusConnection *connection,
                FN_END;
                return;
 fail:
-               BT_ERR_C("Request is failed [%s] [%x]",
+               BT_ERR_C("Request is failed [%s] [0x%x]",
                                _bt_convert_error_to_string(result), result);
 
                out_var = g_variant_new_from_data((const GVariantType *)"ay",
@@ -713,15 +714,19 @@ int __bt_bluez_request(int function_name,
                break;
        }
        case BT_LE_CONN_UPDATE: {
+               char *sender = NULL;
                bluetooth_device_address_t local_address = { {0} };
                bluetooth_le_connection_param_t parameters = {0};
 
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
                __bt_service_get_parameters(in_param1, &local_address,
                                sizeof(bluetooth_device_address_t));
                __bt_service_get_parameters(in_param2, &parameters,
                                sizeof(bluetooth_le_connection_param_t));
 
-               result =  _bt_le_conn_update(local_address.addr,
+               result =  _bt_le_conn_update(sender,
+                                       local_address.addr,
                                        parameters.interval_min,
                                        parameters.interval_max,
                                        parameters.latency,
@@ -966,6 +971,7 @@ int __bt_bluez_request(int function_name,
                break;
        }
        case BT_UPDATE_LE_CONNECTION_MODE: {
+               char *sender = NULL;
                bluetooth_device_address_t remote_address = { { 0 } };
                bluetooth_le_connection_param_t param = { 0 };
                bluetooth_le_connection_mode_t mode = BLUETOOTH_LE_CONNECTION_MODE_BALANCED;
@@ -979,7 +985,10 @@ int __bt_bluez_request(int function_name,
                if (result != BLUETOOTH_ERROR_NONE)
                        break;
 
-               result = _bt_le_conn_update(remote_address.addr,
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
+               result = _bt_le_conn_update(sender,
+                               remote_address.addr,
                                param.interval_min,
                                param.interval_max,
                                param.latency,
@@ -1727,26 +1736,6 @@ int __bt_bluez_request(int function_name,
        case BT_HID_DEVICE_SEND_REPLY_TO_REPORT:
                /* Just call to check the privilege */
                break;
-#ifndef GATT_NO_RELAY
-       case BT_GATT_WATCH_CHARACTERISTIC: {
-               char *sender = NULL;
-
-               sender = (char *)g_dbus_method_invocation_get_sender(context);
-
-               result = _bt_insert_gatt_client_sender(sender);
-
-               break;
-       }
-       case BT_GATT_UNWATCH_CHARACTERISTIC: {
-               char *sender = NULL;
-
-               sender = (char *)g_dbus_method_invocation_get_sender(context);
-
-               result = _bt_delete_gatt_client_sender(sender);
-
-               break;
-       }
-#endif
        case BT_LE_IPSP_INIT:
                result = _bt_initialize_ipsp();
                break;
@@ -2167,6 +2156,192 @@ int __bt_bluez_request(int function_name,
                }
                break;
        }
+       case BT_TDS_PROVIDER_REGISTER: {
+               char *sender = NULL;
+
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+               result = _bt_tds_provider_register(sender);
+
+               break;
+       }
+       case BT_TDS_PROVIDER_UNREGISTER: {
+               char *sender = NULL;
+
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+               result = _bt_tds_provider_unregister(sender);
+
+               break;
+       }
+       case BT_TDS_PROVIDER_SET_MANUF_DATA: {
+               char *sender = NULL;
+               unsigned int length = 0;
+               bluetooth_advertising_data_t manuf_data;
+
+               __bt_service_get_parameters(in_param1,
+                               &length, sizeof(unsigned int));
+               __bt_service_get_parameters(in_param2,
+                               &manuf_data, sizeof(bluetooth_advertising_data_t));
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
+               result = _bt_tds_provider_set_manuf_data(sender, manuf_data.data, length);
+               break;
+       }
+       case BT_TDS_PROVIDER_CREATE: {
+               char *sender = NULL;
+               unsigned int tds_handle = 0;
+               int transport;
+
+               __bt_service_get_parameters(in_param1,
+                               &tds_handle, sizeof(unsigned int));
+               __bt_service_get_parameters(in_param2,
+                               &transport, sizeof(int));
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+               result = _bt_tds_provider_transport_create(sender, transport, tds_handle);
+
+               break;
+       }
+       case BT_TDS_PROVIDER_DESTROY: {
+               char *sender = NULL;
+               unsigned int tds_handle = 0;
+
+               __bt_service_get_parameters(in_param1,
+                               &tds_handle, sizeof(unsigned int));
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+               result = _bt_tds_provider_transport_remove(sender, tds_handle);
+
+               break;
+       }
+       case BT_TDS_PROVIDER_SET_TRANSPORT_DATA: {
+               char *sender = NULL;
+               unsigned int tds_handle = 0;
+               int transport_state = 0;
+               bluetooth_tds_data_t tds_data;
+
+               __bt_service_get_parameters(in_param1,
+                               &tds_handle, sizeof(unsigned int));
+               __bt_service_get_parameters(in_param2,
+                               &transport_state, sizeof(int));
+               __bt_service_get_parameters(in_param3,
+                               &tds_data, sizeof(bluetooth_tds_data_t));
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
+               result = _bt_tds_provider_set_transport_data(sender, tds_handle,
+                               transport_state, tds_data.data, tds_data.length);
+               break;
+       }
+       case BT_TDS_SEND_ACTIVATION_RESPONSE: {
+               bluetooth_device_address_t address = { {0} };
+               bluetooth_tds_data_t tds_data;
+               char *sender = NULL;
+               unsigned int tds_handle = 0;
+               int response;
+
+               __bt_service_get_parameters(in_param1,
+                               &tds_handle, sizeof(unsigned int));
+               __bt_service_get_parameters(in_param2,
+                               &response, sizeof(int));
+               __bt_service_get_parameters(in_param3, &address,
+                       sizeof(bluetooth_device_address_t));
+               __bt_service_get_parameters(in_param4,
+                               &tds_data, sizeof(bluetooth_tds_data_t));
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
+               result = _bt_tds_provider_send_activation_response(sender, tds_handle,
+                               &address, response, tds_data.data, tds_data.length);
+               break;
+       }
+       case BT_TDS_READ_TRANSPORT_DATA: {
+               char *handle;
+               char *data = NULL;
+               guint data_len = 0;
+
+               char *sender = NULL;
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
+               bluetooth_device_address_t address = { {0} };
+               __bt_service_get_parameters(in_param2,
+                       &address, sizeof(bluetooth_device_address_t));
+
+               data_len = g_variant_get_size(in_param1);
+               data = (char *)g_variant_get_data(in_param1);
+
+               handle = g_strndup(data, data_len);
+               BT_DBG("Read TDS Transport Block [%s]", handle);
+
+               result = _bt_tds_read_transport_data(request_id, sender, &address, handle);
+
+               if (result != BLUETOOTH_ERROR_NONE) {
+                       BT_ERR("Reading TDS Transport data failed result [%d]", result);
+                       g_array_append_vals(*out_param1, &address,
+                                       sizeof(bluetooth_device_address_t));
+               }
+               if (handle)
+                       g_free(handle);
+               break;
+       }
+       case BT_TDS_ENABLE_CONTROL_POINT: {
+               char *handle;
+               char *data = NULL;
+               guint data_len = 0;
+               bluetooth_device_address_t address = { {0} };
+
+               char *sender = NULL;
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
+               data_len = g_variant_get_size(in_param1);
+               data = (char *)g_variant_get_data(in_param1);
+               __bt_service_get_parameters(in_param2,
+                       &address, sizeof(bluetooth_device_address_t));
+
+               handle = g_strndup(data, data_len);
+               BT_DBG("TDS Control point CCCD handle [%s]", handle);
+
+               result = _bt_tds_enable_control_point(request_id, sender, &address, handle);
+
+               if (result != BLUETOOTH_ERROR_NONE) {
+                       BT_ERR("Enabling TDS CCCD failed result [%d]", result);
+                       g_array_append_vals(*out_param1, &address,
+                                       sizeof(bluetooth_device_address_t));
+               }
+               if (handle)
+                       g_free(handle);
+               break;
+       }
+       case BT_TDS_ACTIVATE_CONTROL_POINT: {
+               char *handle;
+               char *data = NULL;
+               guint data_len = 0;
+               bluetooth_control_point_data_t tds_data;
+               char *sender = NULL;
+
+               sender = (char *)g_dbus_method_invocation_get_sender(context);
+
+               bluetooth_device_address_t address = { {0} };
+
+               data_len = g_variant_get_size(in_param1);
+               data = (char *)g_variant_get_data(in_param1);
+
+                __bt_service_get_parameters(in_param2,
+                       &address, sizeof(bluetooth_device_address_t));
+
+               __bt_service_get_parameters(in_param3,
+                       &tds_data, sizeof(bluetooth_control_point_data_t));
+
+               handle = g_strndup(data, data_len);
+               BT_DBG("TDS Activate Control point handle [%s]", handle);
+
+               result = _bt_tds_activate_control_point(request_id, sender, &address, handle,
+                                                               tds_data.data, tds_data.length);
+
+               if (result != BLUETOOTH_ERROR_NONE) {
+                       BT_ERR("Activating TDS Control Point request failed result [%d]", result);
+                       g_array_append_vals(*out_param1, &address,
+                                       sizeof(bluetooth_device_address_t));
+               }
+               if (handle)
+                       g_free(handle);
+               break;
+       }
        default:
                result = BLUETOOTH_ERROR_INTERNAL;
                break;
@@ -2267,9 +2442,8 @@ int __bt_obexd_request(int function_name,
                char *address = (char *)g_variant_get_data(in_param1);
                char *session_id = NULL;
                result = _bt_create_session_sync(address, &session_id);
-               if (result == BLUETOOTH_ERROR_NONE) {
+               if (result == BLUETOOTH_ERROR_NONE)
                        g_array_append_vals(*out_param1, session_id, strlen(session_id)+1);
-               }
                break;
        }
 
@@ -2277,9 +2451,8 @@ int __bt_obexd_request(int function_name,
                BT_DBG("BT_MAP_DESTROY_SESSION");
                char* session_id = (char *)g_variant_get_data(in_param1);
                result = _bt_destroy_session_sync(session_id);
-               if (result == BLUETOOTH_ERROR_NONE) {
+               if (result == BLUETOOTH_ERROR_NONE)
                        BT_DBG("successfully destroyed session");
-               }
                break;
        }
 
@@ -2293,19 +2466,14 @@ int __bt_obexd_request(int function_name,
 
        case BT_MAP_LIST_FOLDERS: {
                BT_DBG("BT_MAP_LIST_FOLDERS");
-               // TODO MAP add filter handling
-               GVariant *filter = g_variant_new("()");
 
                char* session_id = (char *)g_variant_get_data(in_param1);
-               int offset = 0;
-               int maxcount = 0;
-               __bt_service_get_parameters(in_param2, &offset, sizeof(int));
-               __bt_service_get_parameters(in_param3, &maxcount, sizeof(int));
+               char* filter_serialized = (char*)g_variant_get_data(in_param2);
 
-               result = _bt_map_client_list_folders(request_id, context, session_id, offset, maxcount);
-               if (result == BLUETOOTH_ERROR_NONE) {
+               result = _bt_map_client_list_folders(request_id, context, session_id, filter_serialized);
+               if (result == BLUETOOTH_ERROR_NONE)
                        BT_DBG("_bt_map_client_list_folders succeed");
-               }
+
                break;
        }
 
@@ -2315,18 +2483,25 @@ int __bt_obexd_request(int function_name,
                char* session_id = (char *)g_variant_get_data(in_param1);
 
                result = _bt_map_client_list_filter_fields(request_id, context, session_id);
-               if (result == BLUETOOTH_ERROR_NONE) {
+               if (result == BLUETOOTH_ERROR_NONE)
                        BT_DBG("_bt_map_client_list_filter_fields succeed");
-               }
+
                break;
        }
 
        case BT_MAP_LIST_MESSAGES: {
                BT_DBG("BT_MAP_LIST_MESSAGES");
 
-               /* TODO: MAP */
+               char* session_id = (char*)g_variant_get_data(in_param1);
+               char* folder = (char*)g_variant_get_data(in_param2);
+               char* filter_serialized = (char*)g_variant_get_data(in_param3);
+
+               result = _bt_map_client_list_messages(request_id, context, session_id, folder, filter_serialized);
+               if (result == BLUETOOTH_ERROR_NONE)
+                       BT_DBG("_bt_map_client_list_messages succeed");
+               else
+                       BT_DBG("_bt_map_client_list_messages failed");
 
-               result = BLUETOOTH_ERROR_NOT_SUPPORT;
                break;
        }
 
@@ -2340,18 +2515,35 @@ int __bt_obexd_request(int function_name,
        case BT_MAP_PUSH_MESSAGE: {
                BT_DBG("BT_MAP_PUSH_MESSAGE");
 
-               /* TODO: MAP */
+               char* session_id = (char *)g_variant_get_data(in_param1);
+               char* source_file = (char *)g_variant_get_data(in_param2);
+               char* folder = (char *)g_variant_get_data(in_param3);
+               char* args_serialized = (char *)g_variant_get_data(in_param4);
+
+               result = _bt_map_client_push_message(
+                               request_id, context, session_id, source_file, folder, args_serialized);
+               if (result == BLUETOOTH_ERROR_NONE)
+                       BT_DBG("_bt_map_client_push_message succeed");
+               else
+                       BT_ERR("_bt_map_client_push_message failed");
 
-               result = BLUETOOTH_ERROR_NOT_SUPPORT;
                break;
        }
 
        case BT_MAP_GET_MESSAGE: {
                BT_DBG("BT_MAP_GET_MESSAGE");
+               // TODO session currently is not used, but should be valid
+               //char* session_id = (char *)g_variant_get_data(in_param1);
+               char* message_object = (char *)g_variant_get_data(in_param2);
+               char* target_file = (char *)g_variant_get_data(in_param3);
+               bool attachment = false;
+               __bt_service_get_parameters(in_param4, &attachment, sizeof(bool));
+
+               result = _bt_map_client_get_message(request_id, context, message_object,
+                               target_file, attachment);
+               if (result == BLUETOOTH_ERROR_NONE)
+                       BT_DBG("_bt_map_client_get_message succeed");
 
-               /* TODO: MAP */
-
-               result = BLUETOOTH_ERROR_NOT_SUPPORT;
                break;
        }
 
@@ -2900,6 +3092,7 @@ gboolean __bt_service_check_privilege(int function_name,
        case BT_GATT_REGISTER_APPLICATION:
        case BT_GATT_REGISTER_SERVICE:
        case BT_GATT_SEND_RESPONSE:
+
        case BT_PBAP_CONNECT:
        case BT_PBAP_DISCONNECT:
        case BT_PBAP_GET_PHONEBOOK_SIZE:
@@ -2950,13 +3143,19 @@ gboolean __bt_service_check_privilege(int function_name,
        case BT_RFCOMM_REJECT_CONNECTION:
        case BT_RFCOMM_LISTEN:
 
+       case BT_HID_ENABLE_BARCODE_FEATURE:
+
        case BT_AVRCP_CONTROL_GET_PROPERTY:
        case BT_AVRCP_GET_TRACK_INFO:
 
        case BT_SET_CONTENT_PROTECT:
        case BT_BOND_DEVICE_BY_TYPE:
        case BT_SET_LE_PRIVACY:
+       case BT_SET_LE_STATIC_RANDOM_ADDRESS:
        case BT_LE_CONN_UPDATE:
+       case BT_UPDATE_LE_CONNECTION_MODE:
+       case BT_REQ_ATT_MTU:
+       case BT_GET_DEVICE_IDA:
        case BT_LE_READ_MAXIMUM_DATA_LENGTH:
        case BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH:
        case BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH:
@@ -2974,6 +3173,29 @@ gboolean __bt_service_check_privilege(int function_name,
        case BT_PXP_REPORTER_REGISTER:
        case BT_PXP_REPORTER_UNREGISTER:
        case BT_PXP_REPORTER_GET_PROPERTY:
+
+       /* TDS */
+       case BT_TDS_PROVIDER_REGISTER:
+       case BT_TDS_PROVIDER_UNREGISTER:
+       case BT_TDS_PROVIDER_SET_MANUF_DATA:
+       case BT_TDS_PROVIDER_CREATE:
+       case BT_TDS_PROVIDER_DESTROY:
+       case BT_TDS_PROVIDER_SET_TRANSPORT_DATA:
+       case BT_TDS_SEND_ACTIVATION_RESPONSE:
+       case BT_TDS_READ_TRANSPORT_DATA:
+       case BT_TDS_ENABLE_CONTROL_POINT:
+       case BT_TDS_ACTIVATE_CONTROL_POINT:
+
+       case BT_MAP_CREATE_SESSION:
+       case BT_MAP_DESTROY_SESSION:
+       case BT_MAP_SET_FOLDER:
+       case BT_MAP_LIST_FOLDERS:
+       case BT_MAP_LIST_FILTER_FIELDS:
+       case BT_MAP_LIST_MESSAGES:
+       case BT_MAP_UPDATE_INBOX:
+       case BT_MAP_PUSH_MESSAGE:
+       case BT_MAP_GET_MESSAGE:
+
        ret_val = cynara_check(p_cynara, client_creds, client_session, user_creds,
                                BT_PRIVILEGE_PLATFORM);
 
@@ -2996,9 +3218,13 @@ gboolean __bt_service_check_privilege(int function_name,
        case BT_IS_LE_DISCOVERYING:
        case BT_IS_CONNECTABLE:
        case BT_GET_BONDED_DEVICES:
+       case BT_GET_PROFILE_CONNECTED_DEVICES:
        case BT_GET_BONDED_DEVICE:
        case BT_GET_IS_ALIAS_SET:
        case BT_IS_DEVICE_CONNECTED:
+       case BT_GET_CONNECTED_LINK_TYPE:
+       case BT_SET_PROFILE_TRUSTED:
+       case BT_GET_PROFILE_TRUSTED:
        case BT_GET_SPEAKER_GAIN:
        case BT_SET_SPEAKER_GAIN:
        case BT_OOB_READ_LOCAL_DATA:
@@ -3008,9 +3234,15 @@ gboolean __bt_service_check_privilege(int function_name,
        case BT_GET_SCAN_RESPONSE_DATA:
        case BT_IS_ADVERTISING:
        case BT_GET_PROFILE_RESTRICTED:
+       case BT_REGISTER_SCAN_FILTER:
+       case BT_UNREGISTER_SCAN_FILTER:
+       case BT_UNREGISTER_ALL_SCAN_FILTERS:
+       case BT_IS_SCAN_FILTER_SUPPORTED:
 
        case BT_OBEX_SERVER_ALLOCATE:
        case BT_OBEX_SERVER_DEALLOCATE:
+       case BT_OBEX_SERVER_IS_ACTIVATED:
+       case BT_OPP_GET_TRANSFER_PROGRESS:
                /* Non-privilege control */
                break;
        default:
@@ -3076,39 +3308,64 @@ int __bt_service_register_object(GDBusConnection *conn,
        return 0;
 }
 
+static void __bt_service_bus_acquired_handler(GDBusConnection *connection,
+               const gchar *name, gpointer user_data)
+{
+       GDBusNodeInfo *node_info = NULL;
+
+       BT_INFO("bus acquired");
+
+       ret_if(connection == NULL);
+
+       node_info = __bt_service_create_method_node_info(
+                       bt_service_introspection_xml);
+       ret_if(node_info == NULL);
+
+       __bt_service_register_object(connection, node_info, TRUE);
+       g_dbus_node_info_unref(node_info);
+
+       bt_service_conn = connection;
+}
+
+static void __bt_service_name_acquired_handler(GDBusConnection *connection,
+               const gchar *name, gpointer user_data)
+{
+       BT_INFO("name acquired");
+       name_acquired = TRUE;
+}
+
+static void __bt_service_name_lost_handler(GDBusConnection *connection,
+               const gchar *name, gpointer user_data)
+{
+       BT_INFO("name lost");
+       name_acquired = FALSE;
+}
+
+gboolean _is_name_acquired(void)
+{
+       return name_acquired;
+}
+
 int _bt_service_register(void)
 {
        GDBusConnection *conn;
        GError *err = NULL;
-       int result;
 
        conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &err);
        retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
+       bt_service_conn = conn;
 
        owner_id = g_bus_own_name(G_BUS_TYPE_SYSTEM,
                                BT_SERVICE_NAME,
                                G_BUS_NAME_OWNER_FLAGS_NONE,
-                               NULL, NULL, NULL,
+                               __bt_service_bus_acquired_handler,
+                               __bt_service_name_acquired_handler,
+                               __bt_service_name_lost_handler,
                                NULL, NULL);
        BT_DBG("owner_id is [%d]", owner_id);
        if (owner_id == 0)
                goto fail;
 
-       node_info = __bt_service_create_method_node_info(
-                       bt_service_introspection_xml);
-
-       if (node_info == NULL)
-               goto fail;
-
-       result = __bt_service_register_object(conn, node_info, TRUE);
-       g_dbus_node_info_unref(node_info);
-       node_info = NULL;
-
-       if (result != BLUETOOTH_ERROR_NONE)
-               goto fail;
-
-       bt_service_conn = conn;
-
        return BLUETOOTH_ERROR_NONE;
 
 fail:
@@ -3128,10 +3385,6 @@ void _bt_service_unregister(void)
                        g_object_unref(bt_service_conn);
                        bt_service_conn = NULL;
                }
-               if (node_info) {
-                       g_dbus_node_info_unref(node_info);
-                       node_info = NULL;
-               }
                if (owner_id > 0) {
                        g_bus_unown_name(owner_id);
                        owner_id = 0;