Adapt the device update connection mode functionality into BT-HAL framework.
[platform/core/connectivity/bluetooth-frwk.git] / bt-service-adaptation / services / bt-request-handler.c
1 /*
2  * Copyright (c) 2011 Samsung Electronics Co., Ltd All Rights Reserved
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *              http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17
18 #include <string.h>
19 #include <stdio.h>
20 #include <glib.h>
21 #include <dlog.h>
22 #include <gio/gio.h>
23 #include <gio/gunixfdlist.h>
24 #include <cynara-client.h>
25 #include <cynara-creds-gdbus.h>
26
27 #include "bluetooth-api.h"
28 #include "bluetooth-audio-api.h"
29 #include "bluetooth-gatt-server-api.h"
30 #include "bt-request-handler.h"
31 #include "bt-service-common.h"
32 #include "bt-service-util.h"
33
34 #include "bt-service-core-adapter.h"
35 #include "bt-service-core-adapter-le.h"
36 #include "bt-service-core-device.h"
37
38 #include "bt-service-audio-common.h"
39 #include "bt-service-avrcp-tg.h"
40 #include "bt-service-avrcp-ctrl.h"
41 #include "bt-service-gatt.h"
42
43 #ifdef TIZEN_FEATURE_BT_DPM
44 #include "bt-service-dpm.h"
45 #endif
46 #include "bt-service-hidhost.h"
47 #include "bt-service-rfcomm.h"
48 #include "bt-service-hdp.h"
49
50 /*Obex*/
51 #include "bt-service-obex-server.h"
52 #include "bt-service-opp-client.h"
53 #include "bt-service-map-client.h"
54 #include "bt-service-pbap.h"
55 #include "bt-service-oob.h"
56
57 #include "bt-service-battery-monitor.h"
58
59 #ifdef TIZEN_FEATURE_BT_PAN_NAP
60 #include "bt-service-network.h"
61 #endif
62
63 #ifdef TIZEN_FEATURE_BT_IPSP
64 #include "bt-service-ipsp.h"
65 #endif
66 /* For maintaining Application Sync API call requests */
67 GSList *invocation_list = NULL;
68
69 static GDBusConnection *bt_service_conn;
70 static guint owner_id = 0;
71 static guint owner_sig_id = 0;
72 static gboolean is_le_intended = FALSE;
73
74 static cynara *p_cynara;
75 static cynara_configuration *conf;
76
77 static const gchar bt_service_introspection_xml[] =
78 "<node name='/org/projectx/bt_service'>"
79 "       <interface name='org.projectx.bt'>"
80 "               <method name='service_request'>"
81                         /* Input Parameters */
82 "                       <arg type='i' name='service_type' direction='in' />"
83 "                       <arg type='i' name='service_function' direction='in' />"
84 "                       <arg type='i' name='request_type' direction='in' />"
85 "                       <arg type='ay' name='input_param1' direction='in' />"
86 "                       <arg type='ay' name='input_param2' direction='in' />"
87 "                       <arg type='ay' name='input_param3' direction='in' />"
88 "                       <arg type='ay' name='input_param4' direction='in' />"
89 "                       <arg type='ay' name='input_param5' direction='in' />"
90                         /* Return Parameters */
91 "                       <arg type='i' name='output_param1' direction='out' />"
92 "                       <arg type='v' name='output_param2' direction='out' />"
93 "               </method>"
94 "       </interface>"
95 "</node>";
96
97 static gboolean name_acquired = FALSE;
98
99 static char *current_sender_playing = NULL;
100
101 GDBusNodeInfo *node_info_g = NULL;
102
103 static void __bt_service_method(GDBusConnection *connection,
104                 const gchar *sender,
105                 const gchar *object_path,
106                 const gchar *interface_name,
107                 const gchar *method_name,
108                 GVariant *parameters,
109                 GDBusMethodInvocation *invocation,
110                 gpointer user_data);
111
112 int __bt_bluez_request(int function_name,
113                 int request_type,
114                 int request_id,
115                 GDBusMethodInvocation *context,
116                 GVariant *in_param1,
117                 GVariant *in_param2,
118                 GVariant *in_param3,
119                 GVariant *in_param4,
120                 GArray **out_param1);
121 int __bt_obexd_request(int function_name,
122                 int request_type,
123                 int request_id,
124                 GDBusMethodInvocation *context,
125                 GVariant *in_param1,
126                 GVariant *in_param2,
127                 GVariant *in_param3,
128                 GVariant *in_param4,
129                 GArray **out_param1);
130 int __bt_agent_request(int function_name,
131                 int request_type,
132                 int request_id,
133                 GDBusMethodInvocation *context,
134                 GVariant *in_param1,
135                 GVariant *in_param2,
136                 GVariant *in_param3,
137                 GVariant *in_param4,
138                 GArray **out_param1);
139 int __bt_core_request(int function_name,
140                 int request_type,
141                 int request_id,
142                 GDBusMethodInvocation *context,
143                 GVariant *in_param1);
144
145 gboolean __bt_service_check_privilege(int function_name,
146                                         int service_type,
147                                         const char *unique_name);
148
149 /* Function definitions*/
150 GSList *_bt_get_invocation_list(void)
151 {
152         return invocation_list;
153 }
154
155 void _bt_free_info_from_invocation_list(invocation_info_t *req_info)
156 {
157         GSList *l;
158         invocation_info_t *info;
159         ret_if(NULL == req_info);
160         ret_if(NULL == req_info->sender);
161
162         for (l = invocation_list; l != NULL; l = g_slist_next(l)) {
163                 info = l->data;
164                 if (NULL == info || NULL == info->sender)
165                         continue;
166
167                 /* No two same sync requests from same application can exist */
168                 if ((strcasecmp(info->sender, req_info->sender) == 0) &&
169                                 req_info->service_function == info->service_function) {
170
171                         invocation_list = g_slist_remove(invocation_list, req_info);
172                         g_free(req_info->sender);
173                         g_free(req_info);
174                         break;
175                 }
176         }
177
178 }
179
180 void _bt_set_le_intended_status(gboolean value)
181 {
182         is_le_intended = value;
183 }
184
185 static void __bt_service_get_parameters(GVariant *in_param,
186                 void *value, int size)
187 {
188         void *buf = NULL;
189         buf = (void *)g_variant_get_data(in_param);
190         memcpy(value, buf, size);
191 }
192
193 static gboolean __bt_is_sync_function(int service_function)
194 {
195         /*TODO: Keep adding sync methods with expect replies from bluetooth service */
196         if (service_function == BT_ENABLE_ADAPTER
197                         || service_function == BT_DISABLE_ADAPTER
198                         || service_function == BT_GET_LOCAL_ADDRESS
199                         || service_function == BT_GET_LOCAL_NAME
200                         || service_function == BT_GET_LOCAL_VERSION
201                         || service_function == BT_GET_BONDED_DEVICES
202                         || service_function == BT_GET_BONDED_DEVICE
203                         || service_function == BT_GET_IS_ALIAS_SET
204                         || service_function == BT_GET_CONNECTED_LINK_TYPE
205                         || service_function == BT_IS_SERVICE_USED
206                         || service_function == BT_RFCOMM_LISTEN_AND_ACCEPT
207                         || service_function == BT_RFCOMM_LISTEN
208                         || service_function == BT_HDP_REGISTER_SINK_APP
209                         || service_function == BT_HDP_UNREGISTER_SINK_APP
210                         || service_function == BT_HDP_GET_FD
211                         || service_function == BT_AVRCP_GET_TRACK_INFO
212                         || service_function == BT_AVRCP_CONTROL_GET_PROPERTY
213                         || service_function == BT_SET_ADVERTISING_DATA
214                         || service_function == BT_SET_SCAN_RESPONSE_DATA
215                         || service_function == BT_SET_ADVERTISING
216                         || service_function == BT_SET_CUSTOM_ADVERTISING
217                         || service_function == BT_GATT_SERVER_REGISTER
218                         || service_function == BT_GATT_SERVER_ADD_SERVICE
219                         || service_function == BT_GATT_SERVER_ADD_CHARACTERISTIC
220                         || service_function == BT_GATT_SERVER_ADD_DESCRIPTOR
221                         || service_function == BT_GATT_SERVER_START_SERVICE
222                         || service_function == BT_GATT_SERVER_STOP_SERVICE
223                         || service_function == BT_GATT_SERVER_DELETE_SERVICE
224                         || service_function == BT_START_LE_DISCOVERY
225                         || service_function == BT_STOP_LE_DISCOVERY
226 #ifdef TIZEN_GATT_CLIENT
227                         || service_function == BT_GATT_CLIENT_REGISTER
228                         || service_function == BT_GATT_GET_PRIMARY_SERVICES
229                         || service_function == BT_GATT_GET_SERVICE_PROPERTIES
230                         || service_function == BT_GATT_GET_INCLUDED_SERVICES
231                         || service_function == BT_GATT_GET_CHARACTERISTIC_PROPERTIES
232                         || service_function == BT_GATT_WATCH_CHARACTERISTIC
233                         || service_function == BT_GATT_ACQUIRE_WRITE
234 #endif
235                         || service_function == BT_AUDIO_SELECT_ROLE)
236                 return TRUE;
237         else
238                 return FALSE;
239 }
240
241 void _bt_save_invocation_context(GDBusMethodInvocation *invocation, int result,
242                 char *sender, int service_function,
243                 gpointer invocation_data)
244 {
245         BT_DBG("Saving the invocation context: service_function [%d]", service_function);
246         invocation_info_t *info;
247         info = g_malloc0(sizeof(invocation_info_t));
248         info->context = invocation;
249         info->result = result;
250         info->sender = g_strdup(sender);
251         info->service_function = service_function;
252         info->user_data = invocation_data;
253         invocation_list = g_slist_append(invocation_list, info);
254
255 }
256
257 static int __bt_bm_request_data(_bt_battery_data_t *latest)
258 {
259         int ret = _bt_bm_read_data(latest);
260         if (ret == BLUETOOTH_ERROR_NONE) {
261                 BT_DBG("Received data from bluetooth battery monitor: %ld %ld %d %d",
262                         latest->session_start_time, latest->session_end_time,
263                                 latest->session_scan_time, latest->session_connected_time);
264
265                 if (latest->atm_list == NULL) {
266                         BT_DBG("No app data transaction for this session");
267                         return ret;
268                 }
269
270                 for (GSList *l = latest->atm_list; l != NULL; l = g_slist_next(l)) {
271                         _bt_battery_app_data_t *t = (_bt_battery_app_data_t *)(l->data);
272                         BT_DBG("%ld %ld %d %d", (long int)(t->uid), (long int)(t->pid), t->rx_bytes, t->tx_bytes);
273                 }
274         }
275         else
276                 BT_ERR("Error encountered");
277         return ret;
278 }
279
280 static void __bt_service_method(GDBusConnection *connection,
281                 const gchar *sender,
282                 const gchar *object_path,
283                 const gchar *interface_name,
284                 const gchar *method_name,
285                 GVariant *parameters,
286                 GDBusMethodInvocation *invocation,
287                 gpointer user_data)
288 {
289         FN_START;
290
291         BT_DBG("Method[%s] Object Path[%s] Interface Name[%s]",
292                         method_name, object_path, interface_name);
293
294         if (g_strcmp0(method_name, "service_request") == 0) {
295                 int service_type;
296                 int service_function;
297                 int request_type;
298                 GVariant *param1 = NULL;
299                 GVariant *param2 = NULL;
300                 GVariant *param3 = NULL;
301                 GVariant *param4 = NULL;
302                 GVariant *param5 = NULL;
303                 GArray *out_param1 = NULL;
304                 GVariant *out_var = NULL;
305                 GVariant *temp = NULL;
306                 int result = 0;
307                 int request_id = -1;
308
309                 g_variant_get(parameters, "(iii@ay@ay@ay@ay@ay)", &service_type,
310                                 &service_function, &request_type,
311                                 &param1, &param2, &param3, &param4, &param5);
312
313                 out_param1 = g_array_new(FALSE, FALSE, sizeof(gchar));
314
315                 if (service_type == BT_CORE_SERVICE) {
316                         BT_DBG("No need to check privilege from bt-core");
317                 } else if (__bt_service_check_privilege(service_function,
318                                         service_type, (const char *)sender) == FALSE) {
319                         BT_ERR("Client don't have the privilege to excute this function");
320                         result = BLUETOOTH_ERROR_PERMISSION_DEINED;
321                         goto fail;
322                 }
323
324                 BT_DBG("SERVICE TYPE [%d] SERVICE FUNC [%d]",
325                                 service_type, service_function);
326                 switch (service_type) {
327                 case BT_BLUEZ_SERVICE:
328                         result = __bt_bluez_request(service_function,
329                                         request_type, request_id,
330                                         invocation, param1, param2,
331                                         param3, param4, &out_param1);
332                         break;
333                 case BT_OBEX_SERVICE:
334                         result = __bt_obexd_request(service_function,
335                                         request_type, request_id,
336                                         invocation, param1,
337                                         param2, param3,
338                                         param4, &out_param1);
339                         break;
340                 case BT_AGENT_SERVICE:
341                         result = __bt_agent_request(service_function,
342                                         request_type, request_id,
343                                         invocation, param1,
344                                         param2, param3,
345                                         param4, &out_param1);
346                         break;
347                 case BT_CORE_SERVICE:
348                         result = __bt_core_request(service_function,
349                                         request_type, request_id,
350                                         invocation, param1);
351                         break;
352                 case BT_CHECK_PRIVILEGE:
353                         result = BLUETOOTH_ERROR_NONE;
354                         break;
355                 default:
356                         BT_ERR("Unknown service type");
357                         result = BLUETOOTH_ERROR_INTERNAL;
358                         goto fail;
359                 }
360
361                 if (result != BLUETOOTH_ERROR_NONE)
362                         goto fail;
363
364                 if (service_type == BT_CHECK_PRIVILEGE)
365                         goto send_reply;
366
367                 if (service_function == BT_OPP_PUSH_FILES)
368                         goto done;
369
370                 if (request_type == BT_ASYNC_REQ ||
371                                 __bt_is_sync_function(service_function)) {
372                         BT_INFO("Do not send reply to bt-api over dbus,"
373                                 " Invocation context is already saved in service_function");
374                         goto done;
375                 }
376
377 send_reply:
378                 out_var = g_variant_new_from_data((const GVariantType *)"ay",
379                                 out_param1->data, out_param1->len,
380                                 TRUE, NULL, NULL);
381
382                 temp = g_variant_new("(iv)", result, out_var);
383                 g_dbus_method_invocation_return_value(invocation, temp);
384                 g_array_free(out_param1, TRUE);
385                 out_param1 = NULL;
386
387 done:
388                 g_variant_unref(param1);
389                 g_variant_unref(param2);
390                 g_variant_unref(param3);
391                 g_variant_unref(param4);
392                 g_variant_unref(param5);
393                 FN_END;
394                 return;
395 fail:
396                 BT_ERR_C("Request is failed [%s] [0x%x]",
397                                 _bt_convert_error_to_string(result), result);
398
399                 out_var = g_variant_new_from_data((const GVariantType *)"ay",
400                                 out_param1->data, out_param1->len,
401                                 TRUE, NULL, NULL);
402
403                 temp = g_variant_new("(iv)", result, out_var);
404                 g_dbus_method_invocation_return_value(invocation, temp);
405
406                 g_array_free(out_param1, TRUE);
407                 out_param1 = NULL;
408
409                 g_variant_unref(param1);
410                 g_variant_unref(param2);
411                 g_variant_unref(param3);
412                 g_variant_unref(param4);
413                 g_variant_unref(param5);
414         }
415
416         FN_END;
417         return;
418 }
419
420
421 static const GDBusInterfaceVTable method_table = {
422         __bt_service_method,
423         NULL,
424         NULL,
425         {0}
426 };
427
428 int __bt_bluez_request(int function_name,
429                 int request_type,
430                 int request_id,
431                 GDBusMethodInvocation *context,
432                 GVariant *in_param1,
433                 GVariant *in_param2,
434                 GVariant *in_param3,
435                 GVariant *in_param4,
436                 GArray **out_param1)
437 {
438         int result = BLUETOOTH_ERROR_NONE;
439         char *sender = NULL;
440
441         switch (function_name) {
442         case BT_ENABLE_ADAPTER: {
443                 result = _bt_enable_adapter();
444                 /* Save invocation */
445                 if (result == BLUETOOTH_ERROR_NONE) {
446                         BT_DBG("_bt_enable_adapter scheduled successfully! save invocation context");
447                         sender = (char*)g_dbus_method_invocation_get_sender(context);
448                         _bt_save_invocation_context(context, result, sender,
449                                         function_name, NULL);
450                 }
451                 break;
452         }
453         case BT_DISABLE_ADAPTER: {
454                 result = _bt_disable_adapter();
455                 /* Save invocation */
456                 if (result == BLUETOOTH_ERROR_NONE) {
457                         BT_DBG("_bt_disable_adapter scheduled successfully! save invocation context");
458                         sender = (char*)g_dbus_method_invocation_get_sender(context);
459                         _bt_save_invocation_context(context, result, sender,
460                                         function_name, NULL);
461                 }
462                 break;
463         }
464         case BT_RECOVER_ADAPTER:
465                  result = _bt_recover_adapter();
466                  break;
467         case BT_RESET_ADAPTER:
468                 result = _bt_reset_adapter();
469                 break;
470         case BT_BATTERY_READ_DATA: {
471                 _bt_battery_data_t *data = NULL;
472                 data = g_malloc0(sizeof(_bt_battery_data_t));
473                 result = __bt_bm_request_data(data);
474
475                 bt_battery_dbus_data_t dbus_data;
476                 memset(&dbus_data, 0, sizeof(bt_battery_dbus_data_t));
477                 dbus_data.session_start_time = data->session_start_time;
478                 dbus_data.session_end_time = data->session_end_time;
479                 dbus_data.session_scan_time = data->session_scan_time;
480                 dbus_data.session_connected_time = data->session_connected_time;
481
482                 /*Populating app data*/
483                 int n = 0;
484                 for (GSList *l = data->atm_list; l != NULL; l = g_slist_next(l)) {
485                         bt_battery_app_data *t = (bt_battery_app_data *)(l->data);
486                         memcpy(&dbus_data.app_data[n], t, sizeof(bt_battery_app_data));
487                         n++;
488                 }
489                 dbus_data.num_app = n;
490                 g_array_append_vals(*out_param1, &dbus_data, sizeof(bt_battery_dbus_data_t));
491                 g_slist_free(data->atm_list);
492                 g_free(data);
493                 data = NULL;
494                 break;
495         }
496         case BT_CHECK_ADAPTER: {
497                 int enabled = BT_ADAPTER_DISABLED;
498                 result = _bt_check_adapter(&enabled);
499
500                 g_array_append_vals(*out_param1, &enabled,
501                                 sizeof(int));
502                 break;
503         }
504         case BT_ENABLE_ADAPTER_LE:
505                 _bt_set_le_intended_status(TRUE);
506                 result = _bt_enable_adapter_le();
507                 break;
508         case BT_DISABLE_ADAPTER_LE:
509                 _bt_set_le_intended_status(FALSE);
510                 result = _bt_disable_adapter_le();
511                 break;
512         case BT_START_DISCOVERY: {
513                 unsigned short max_response;
514                 unsigned short discovery_duration;
515                 unsigned int classOfDeviceMask;
516
517                 __bt_service_get_parameters(in_param1,
518                                 &max_response, sizeof(unsigned short));
519                 __bt_service_get_parameters(in_param2,
520                                 &discovery_duration, sizeof(unsigned short));
521                 __bt_service_get_parameters(in_param3,
522                                 &classOfDeviceMask, sizeof(unsigned int));
523
524                 result = _bt_start_discovery(max_response, discovery_duration, classOfDeviceMask);
525                 break;
526         }
527         case BT_START_CUSTOM_DISCOVERY: {
528                 bt_discovery_role_type_t role;
529
530                 __bt_service_get_parameters(in_param1,
531                                 &role, sizeof(bt_discovery_role_type_t));
532                 result = _bt_start_custom_discovery(role);
533
534                 break;
535         }
536         case BT_CANCEL_DISCOVERY:
537                 result = _bt_cancel_discovery();
538                 break;
539         case BT_IS_DISCOVERYING: {
540                 gboolean discovering = FALSE;
541                 discovering = _bt_is_discovering();
542                 g_array_append_vals(*out_param1,
543                                 &discovering, sizeof(gboolean));
544                 break;
545         }
546         case BT_GET_LOCAL_ADDRESS: {
547                 result = _bt_get_local_address();
548
549                 /* Save invocation */
550                 if (result == BLUETOOTH_ERROR_NONE) {
551                         sender = (char*)g_dbus_method_invocation_get_sender(context);
552                         _bt_save_invocation_context(context, result, sender,
553                                         function_name, NULL);
554                 }
555                 break;
556         }
557         case BT_GET_LOCAL_VERSION: {
558                 result = _bt_get_local_version();
559
560                 /* Save invocation */
561                 if (result == BLUETOOTH_ERROR_NONE) {
562                         sender = (char*)g_dbus_method_invocation_get_sender(context);
563                         _bt_save_invocation_context(context, result, sender,
564                                         function_name, NULL);
565                 }
566                 break;
567         }
568         case BT_GET_LOCAL_NAME: {
569                 result = _bt_get_local_name();
570
571                 /* Save invocation */
572                 if (result == BLUETOOTH_ERROR_NONE) {
573                         sender = (char*)g_dbus_method_invocation_get_sender(context);
574                         _bt_save_invocation_context(context, result, sender,
575                                         function_name, NULL);
576                 }
577                 break;
578         }
579         case BT_SET_LOCAL_NAME: {
580                 bluetooth_device_name_t local_name = { {0} };
581                 __bt_service_get_parameters(in_param1,
582                                 &local_name, sizeof(bluetooth_device_name_t));
583                 result = _bt_set_local_name(local_name.name);
584                 break;
585         }
586         case BT_GET_DISCOVERABLE_MODE: {
587                 int discoverable_mode = BLUETOOTH_DISCOVERABLE_MODE_CONNECTABLE;
588                 result = _bt_get_discoverable_mode(&discoverable_mode);
589                 g_array_append_vals(*out_param1, &discoverable_mode, sizeof(int));
590                 break;
591         }
592         case BT_GET_DISCOVERABLE_TIME: {
593                 int timeout = 0;
594
595                 result = _bt_get_timeout_value(&timeout);
596                 g_array_append_vals(*out_param1, &timeout, sizeof(int));
597                 break;
598         }
599         case BT_SET_DISCOVERABLE_MODE: {
600                 int mode = BLUETOOTH_DISCOVERABLE_MODE_CONNECTABLE;
601                 int time = 0;
602
603                 __bt_service_get_parameters(in_param1, &mode, sizeof(int));
604                 __bt_service_get_parameters(in_param2, &time, sizeof(int));
605
606                 result = _bt_set_discoverable_mode(mode, time);
607                 break;
608         }
609         case BT_IS_CONNECTABLE: {
610                 gboolean is_connectable = FALSE;
611
612                 is_connectable = _bt_is_connectable();
613                 g_array_append_vals(*out_param1, &is_connectable, sizeof(gboolean));
614                 break;
615         }
616         case BT_SET_CONNECTABLE: {
617                 gboolean is_connectable;
618
619                 __bt_service_get_parameters(in_param1,
620                                 &is_connectable, sizeof(gboolean));
621                 result = _bt_set_connectable(is_connectable);
622                 break;
623         }
624         case BT_IS_SERVICE_USED: {
625                 char *uuid = NULL;
626
627                 uuid = (char *)g_variant_get_data(in_param1);
628                 BT_INFO("UUID to be searched [%s]", uuid);
629                 result = _bt_is_service_used();
630
631                 /* Save invocation */
632                 if (result == BLUETOOTH_ERROR_NONE) {
633                         sender = (char*)g_dbus_method_invocation_get_sender(context);
634                         _bt_save_invocation_context(context, result, sender,
635                                         function_name, (gpointer)uuid);
636                 }
637                 break;
638         }
639         case BT_GET_BONDED_DEVICES: {
640                 result = _bt_get_bonded_devices();
641                 /* Save invocation */
642                 if (result == BLUETOOTH_ERROR_NONE) {
643                         sender = (char*)g_dbus_method_invocation_get_sender(context);
644                         _bt_save_invocation_context(context, result, sender,
645                                         function_name, NULL);
646                 }
647                 break;
648         }
649         case BT_GET_BONDED_DEVICE: {
650                 bluetooth_device_address_t address = { {0} };
651
652                 __bt_service_get_parameters(in_param1,
653                                 &address, sizeof(bluetooth_device_address_t));
654
655                 result = _bt_get_bonded_device_info(&address);
656                 /* Save invocation */
657                 if (result == BLUETOOTH_ERROR_NONE) {
658                         char *addr = g_malloc0(sizeof(char) * BT_ADDRESS_STRING_SIZE);
659                         if (!addr) {
660                                 result = BLUETOOTH_ERROR_MEMORY_ALLOCATION;
661                                 break;
662                         }
663
664                         _bt_convert_addr_type_to_string(addr, address.addr);
665                         sender = (char*)g_dbus_method_invocation_get_sender(context);
666                         _bt_save_invocation_context(context, result, sender,
667                                         function_name, addr);
668                 }
669                 break;
670         }
671         case BT_GET_PROFILE_CONNECTED_DEVICES: {
672                 char *uuid;
673                 uuid = (char *)g_variant_get_data(in_param1);
674                 result = _bt_get_profile_connected_devices(uuid, out_param1);
675                 break;
676         }
677         case BT_SET_ALIAS: {
678                 bluetooth_device_address_t address = { {0} };
679                 const char *local_name;
680
681                 __bt_service_get_parameters(in_param1,
682                                 &address, sizeof(bluetooth_device_address_t));
683                 local_name = (const char *)g_variant_get_data(in_param2);
684
685                 result = _bt_set_alias(&address, local_name);
686                 break;
687         }
688         case BT_BOND_DEVICE: {
689                 bluetooth_device_address_t address = { {0} };
690
691                 __bt_service_get_parameters(in_param1,
692                                 &address, sizeof(bluetooth_device_address_t));
693                 result = _bt_bond_device(&address, BLUETOOTH_DEV_CONN_DEFAULT, out_param1);
694
695                 /* Save invocation */
696                 if (result == BLUETOOTH_ERROR_NONE) {
697                         char * addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
698                         _bt_convert_addr_type_to_string(addr, address.addr);
699                         BT_DBG("_bt_bond_device scheduled successfully! save invocation context");
700                         sender = (char*)g_dbus_method_invocation_get_sender(context);
701                         _bt_save_invocation_context(context, result, sender,
702                                         function_name, (gpointer)addr);
703                 } else {
704                         bluetooth_device_info_t dev_info;
705
706                         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
707                         memcpy(&dev_info.device_address, &address,
708                                         sizeof(bluetooth_device_address_t));
709                         g_array_append_vals(*out_param1, &dev_info,
710                                         sizeof(bluetooth_device_info_t));
711                 }
712                 break;
713         }
714         case BT_BOND_DEVICE_BY_TYPE: {
715                 bluetooth_device_address_t address = { {0} };
716                 unsigned short conn_type = 0;
717
718                 __bt_service_get_parameters(in_param1,
719                                 &address, sizeof(bluetooth_device_address_t));
720                 __bt_service_get_parameters(in_param2,
721                                 &conn_type, sizeof(unsigned short));
722
723                 result = _bt_bond_device(&address, conn_type, out_param1);
724                 /* Save invocation */
725                 if (result == BLUETOOTH_ERROR_NONE) {
726                         char * addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
727                         _bt_convert_addr_type_to_string(addr, address.addr);
728                         BT_DBG("_bt_bond_device_by_type invoked successfully! save invocation context");
729                         sender = (char*)g_dbus_method_invocation_get_sender(context);
730                         _bt_save_invocation_context(context, result, sender,
731                                         function_name, (gpointer)addr);
732                 } else {
733                         bluetooth_device_info_t dev_info;
734
735                         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
736                         memcpy(&dev_info.device_address, &address,
737                                         sizeof(bluetooth_device_address_t));
738                         g_array_append_vals(*out_param1, &dev_info,
739                                         sizeof(bluetooth_device_info_t));
740                 }
741                 break;
742         }
743         case BT_UNBOND_DEVICE: {
744                 bluetooth_device_address_t address = { {0} };
745
746                 __bt_service_get_parameters(in_param1,
747                                 &address, sizeof(bluetooth_device_address_t));
748                 result = _bt_unbond_device(&address, out_param1);
749
750                 /* Save invocation */
751                 if (result == BLUETOOTH_ERROR_NONE) {
752                         char * addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
753                         _bt_convert_addr_type_to_string(addr, address.addr);
754                         BT_DBG("_bt_unbond_device scheduled successfully! save invocation context");
755                         sender = (char*)g_dbus_method_invocation_get_sender(context);
756                         _bt_save_invocation_context(context, result, sender,
757                                         function_name, (gpointer)addr);
758                 } else {
759                         g_array_append_vals(*out_param1, &address,
760                                         sizeof(bluetooth_device_address_t));
761                 }
762                 break;
763         }
764         case BT_CANCEL_BONDING:{
765                 result = _bt_cancel_bonding();
766                 break;
767         }
768         case BT_SEARCH_SERVICE: {
769                 bluetooth_device_address_t address = { {0} };
770                 __bt_service_get_parameters(in_param1,
771                                 &address, sizeof(bluetooth_device_address_t));
772                 result = _bt_search_device(&address);
773                 /* Save invocation */
774                 if (result == BLUETOOTH_ERROR_NONE) {
775                         char * addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
776                         _bt_convert_addr_type_to_string(addr, address.addr);
777                         BT_DBG("BT Device Service Search Request scheduled successfully! save invocation context");
778                         sender = (char*)g_dbus_method_invocation_get_sender(context);
779                         _bt_save_invocation_context(context, result, sender,
780                                         function_name, (gpointer)addr);
781                 } else {
782                         bt_sdp_info_t sdp_info;
783
784                         memset(&sdp_info, 0x00, sizeof(bt_sdp_info_t));
785                         memcpy(&sdp_info.device_addr, &address,
786                                         sizeof(bluetooth_device_address_t));
787                         g_array_append_vals(*out_param1, &sdp_info, sizeof(bt_sdp_info_t));
788                 }
789                 break;
790         }
791         case BT_CANCEL_SEARCH_SERVICE: {
792                 result = _bt_cancel_search_device();
793                 break;
794         }
795         case BT_SET_PASSKEY_NOTIFICATION: {
796                 char *sender = NULL;
797                 gboolean enable;
798
799                 sender = (char *)g_dbus_method_invocation_get_sender(context);
800                 __bt_service_get_parameters(in_param1,
801                                 &enable, sizeof(gboolean));
802
803                 result = _bt_set_passkey_notification(sender, enable);
804                 break;
805         }
806         case BT_SET_PIN_CODE: {
807                 bluetooth_device_address_t address = { {0} };
808                 bluetooth_device_pin_code_t pin_code = { {0} };
809
810                 __bt_service_get_parameters(in_param1,
811                                 &address, sizeof(bluetooth_device_address_t));
812                 __bt_service_get_parameters(in_param2,
813                                 &pin_code, sizeof(bluetooth_device_pin_code_t));
814
815                 result = _bt_set_pin_code(&address, &pin_code);
816                 break;
817         }
818         case BT_UNSET_PIN_CODE: {
819                 bluetooth_device_address_t address = { {0} };
820
821                 __bt_service_get_parameters(in_param1,
822                                 &address, sizeof(bluetooth_device_address_t));
823
824                 result = _bt_unset_pin_code(&address);
825                 break;
826         }
827         case BT_PASSKEY_REPLY: {
828                 const char *passkey = NULL;
829                 gboolean authentication_reply = FALSE;
830                 passkey = g_variant_get_data(in_param1);
831                 __bt_service_get_parameters(in_param2,
832                                 &authentication_reply, sizeof(gboolean));
833                 result = _bt_passkey_reply(passkey, authentication_reply);
834                 break;
835         }
836         case BT_PASSKEY_CONFIRMATION_REPLY: {
837                 gboolean confirmation_reply = FALSE;
838                 __bt_service_get_parameters(in_param1,
839                                 &confirmation_reply, sizeof(gboolean));
840                 result = _bt_passkey_confirmation_reply(confirmation_reply);
841                 break;
842         }
843         case BT_GET_IS_ALIAS_SET: {
844                 bluetooth_device_address_t address = { {0} };
845
846                 __bt_service_get_parameters(in_param1,
847                                 &address, sizeof(bluetooth_device_address_t));
848
849                 result = _bt_is_alias_set(&address);
850                 if (result == BLUETOOTH_ERROR_NONE) {
851                         char *addr = g_malloc0(sizeof(char) * BT_ADDRESS_STRING_SIZE);
852                         if (!addr) {
853                                 result = BLUETOOTH_ERROR_MEMORY_ALLOCATION;
854                                 break;
855                         }
856
857                         _bt_convert_addr_type_to_string(addr, address.addr);
858                         sender = (char*)g_dbus_method_invocation_get_sender(context);
859                         _bt_save_invocation_context(context, result, sender,
860                                         function_name, addr);
861                 }
862                 break;
863         }
864         case BT_SET_AUTHORIZATION: {
865                 bluetooth_device_address_t address = { {0} };
866                 gboolean authorize;
867                 __bt_service_get_parameters(in_param1,
868                                 &address, sizeof(bluetooth_device_address_t));
869                 __bt_service_get_parameters(in_param2,
870                                 &authorize, sizeof(gboolean));
871                 result = _bt_set_authorization(&address, authorize);
872                 break;
873         }
874         case BT_SET_LE_PRIVACY: {
875                gboolean set_privacy;
876                __bt_service_get_parameters(in_param1, &set_privacy,
877                                 sizeof(gboolean));
878                result = _bt_set_le_privacy(set_privacy);
879                break;
880         }
881         case BT_ADD_WHITE_LIST: {
882                 bluetooth_device_address_t address = { {0} };
883                 int address_type = 0;
884                 bool is_add = true;
885                 __bt_service_get_parameters(in_param1,
886                                 &address, sizeof(bluetooth_device_address_t));
887                 __bt_service_get_parameters(in_param2,
888                                 &address_type, sizeof(int));
889                 result = _bt_set_white_list(&address, address_type, is_add);
890                 break;
891         }
892         case BT_REMOVE_WHITE_LIST: {
893                 bluetooth_device_address_t address = { {0} };
894                 int address_type = 0;
895                 bool is_add = false;
896                 __bt_service_get_parameters(in_param1,
897                                 &address, sizeof(bluetooth_device_address_t));
898                 __bt_service_get_parameters(in_param2,
899                                 &address_type, sizeof(int));
900                 result = _bt_set_white_list(&address, address_type, is_add);
901                 break;
902         }
903         case BT_UPDATE_LE_CONNECTION_MODE: {
904                 char *sender = NULL;
905                 bluetooth_device_address_t remote_address = { { 0 } };
906                 bluetooth_le_connection_param_t parameters = { 0 };
907                 bluetooth_le_connection_mode_t mode = BLUETOOTH_LE_CONNECTION_MODE_BALANCED;
908
909                 __bt_service_get_parameters(in_param1, &remote_address,
910                                 sizeof(bluetooth_device_address_t));
911                 __bt_service_get_parameters(in_param2, &mode,
912                                 sizeof(bluetooth_le_connection_mode_t));
913
914                 result = _bt_get_le_connection_parameter(mode, &parameters);
915                 if (result != BLUETOOTH_ERROR_NONE)
916                         break;
917
918                 sender = (char *)g_dbus_method_invocation_get_sender(context);
919
920                 result = _bt_le_connection_update(sender,
921                                 remote_address.addr,
922                                 parameters.interval_min,
923                                 parameters.interval_max,
924                                 parameters.latency,
925                                 parameters.timeout);
926                 break;
927         }
928         case BT_SET_MANUFACTURER_DATA: {
929                 bluetooth_manufacturer_data_t m_data = { 0 };
930                 __bt_service_get_parameters(in_param1,
931                                 &m_data, sizeof(bluetooth_manufacturer_data_t));
932                 result = _bt_set_manufacturer_data(&m_data);
933                 break;
934         }
935
936         case BT_IS_DEVICE_CONNECTED: {
937                 bluetooth_device_address_t address = { {0} };
938                 gboolean connected = FALSE;
939                 int service_type;
940
941                 __bt_service_get_parameters(in_param1,
942                                 &address, sizeof(bluetooth_device_address_t));
943                 __bt_service_get_parameters(in_param2,
944                                 &service_type, sizeof(int));
945
946 #if defined(TIZEN_FEATURE_BT_PAN_NAP)
947                 if ((service_type == BLUETOOTH_NAP_SERVICE) || (service_type == BLUETOOTH_NAP_SERVER_SERVICE))
948                         connected = _bt_is_nap_panu_device_connected(&address, service_type);
949                 else
950                         connected = _bt_is_device_connected(&address, service_type);
951 #else
952                 connected = _bt_is_device_connected(&address, service_type);
953 #endif
954                 BT_INFO("is_connected: %d", connected);
955                 g_array_append_vals(*out_param1, &connected, sizeof(gboolean));
956                 break;
957         }
958         case BT_GET_CONNECTED_LINK_TYPE: {
959                 bluetooth_device_address_t address = { {0} };
960
961                 __bt_service_get_parameters(in_param1,
962                                 &address, sizeof(bluetooth_device_address_t));
963
964                 result = _bt_get_connected_link(&address);
965                 if (result == BLUETOOTH_ERROR_NONE) {
966                         char *addr = g_malloc0(sizeof(char) * BT_ADDRESS_STRING_SIZE);
967                         if (!addr) {
968                                 result = BLUETOOTH_ERROR_MEMORY_ALLOCATION;
969                                 break;
970                         }
971
972                         _bt_convert_addr_type_to_string(addr, address.addr);
973                         sender = (char*)g_dbus_method_invocation_get_sender(context);
974                         _bt_save_invocation_context(context, result, sender,
975                                         function_name, addr);
976                 }
977                 break;
978         }
979         case BT_IS_SCAN_FILTER_SUPPORTED:{
980                 int is_supported = 0;
981
982                 if (_bt_is_scan_filter_supported() == TRUE)
983                         is_supported = 1;
984
985                 g_array_append_vals(*out_param1,
986                                 &is_supported, sizeof(int));
987
988                 break;
989         }
990         case BT_ENABLE_RSSI: {
991                 bluetooth_device_address_t bd_addr;
992                 int link_type;
993                 bt_rssi_threshold_t rssi_threshold;
994                 int low_threshold;
995                 int in_range_threshold;
996                 int high_threshold;
997
998                 BT_DBG("Enable RSSI");
999
1000                 __bt_service_get_parameters(in_param1,
1001                                 &bd_addr, sizeof(bluetooth_device_address_t));
1002                 __bt_service_get_parameters(in_param2,
1003                                 &link_type, sizeof(int));
1004                 __bt_service_get_parameters(in_param3,
1005                                 &rssi_threshold, sizeof(bt_rssi_threshold_t));
1006
1007                 low_threshold = rssi_threshold.low_threshold;
1008                 in_range_threshold = rssi_threshold.in_range_threshold;
1009                 high_threshold = rssi_threshold.high_threshold;
1010
1011                 result = _bt_enable_rssi(&bd_addr, link_type, low_threshold,
1012                                 in_range_threshold, high_threshold);
1013                 break;
1014         }
1015         case BT_GET_RSSI: {
1016                 int link_type;
1017                 bluetooth_device_address_t bd_addr;
1018
1019                 BT_DBG("Get RSSI Strength");
1020
1021                 __bt_service_get_parameters(in_param1,
1022                                 &bd_addr, sizeof(bluetooth_device_address_t));
1023                 __bt_service_get_parameters(in_param2,
1024                                 &link_type, sizeof(int));
1025
1026                 result = _bt_get_rssi_strength(&bd_addr, link_type);
1027                 break;
1028         }
1029         case BT_SET_PROFILE_TRUSTED: {
1030                 bluetooth_device_address_t bd_addr = { {0} };
1031                 int profile;
1032                 int trust;
1033
1034                 __bt_service_get_parameters(in_param1, &bd_addr,
1035                                 sizeof(bluetooth_device_address_t));
1036                 __bt_service_get_parameters(in_param2, &profile, sizeof(int));
1037                 __bt_service_get_parameters(in_param3, &trust, sizeof(int));
1038
1039                 result = _bt_set_trust_profile(&bd_addr, profile, trust);
1040                 break;
1041         }
1042         case BT_GET_PROFILE_TRUSTED: {
1043                 bluetooth_device_address_t bd_addr = { {0} };
1044                 int profile;
1045                 guint trusted_profile = 0;
1046
1047                 __bt_service_get_parameters(in_param1, &bd_addr,
1048                                 sizeof(bluetooth_device_address_t));
1049                 __bt_service_get_parameters(in_param2, &profile, sizeof(int));
1050
1051                 result = _bt_get_trust_profile(&bd_addr, profile, &trusted_profile);
1052                 BT_DBG("TRUST %d", trusted_profile);
1053                 if (result == BLUETOOTH_ERROR_NONE) {
1054                         g_array_append_vals(*out_param1, &trusted_profile,
1055                                         sizeof(guint));
1056                 }
1057
1058                 break;
1059         }
1060         case BT_HID_CONNECT: {
1061                 bluetooth_device_address_t address = { {0} };
1062
1063                 __bt_service_get_parameters(in_param1,
1064                                 &address, sizeof(bluetooth_device_address_t));
1065
1066                 result = _bt_hid_connect(&address);
1067                 if (result != BLUETOOTH_ERROR_NONE) {
1068                         g_array_append_vals(*out_param1, &address,
1069                                         sizeof(bluetooth_device_address_t));
1070                 } else {
1071                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1072                         _bt_convert_addr_type_to_string(addr, address.addr);
1073                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1074                         _bt_save_invocation_context(context, result, sender,
1075                                         function_name, (gpointer)addr);
1076                 }
1077                 break;
1078         }
1079         case BT_HID_DISCONNECT: {
1080                 bluetooth_device_address_t address = { {0} };
1081
1082                 __bt_service_get_parameters(in_param1,
1083                                 &address, sizeof(bluetooth_device_address_t));
1084
1085                 result = _bt_hid_disconnect(&address);
1086                 if (result != BLUETOOTH_ERROR_NONE) {
1087                         g_array_append_vals(*out_param1, &address,
1088                                         sizeof(bluetooth_device_address_t));
1089                 } else {
1090                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1091                         _bt_convert_addr_type_to_string(addr, address.addr);
1092                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1093                         _bt_save_invocation_context(context, result, sender,
1094                                         function_name, (gpointer)addr);
1095                 }
1096                 break;
1097         }
1098 #ifdef TIZEN_FEATURE_BT_DPM
1099         case BT_DPM_SET_ALLOW_BT_MODE: {
1100                 dpm_bt_allow_t value = DPM_BT_ERROR;
1101
1102                 __bt_service_get_parameters(in_param1, &value,
1103                                 sizeof(int));
1104
1105                 result = _bt_dpm_set_allow_bluetooth_mode(value);
1106                 break;
1107         }
1108         case BT_DPM_GET_ALLOW_BT_MODE: {
1109                 int value = DPM_BT_ERROR;
1110
1111                 result = _bt_dpm_get_allow_bluetooth_mode(&value);
1112                 g_array_append_vals(*out_param1, &value, sizeof(int));
1113                 break;
1114         }
1115         case BT_DPM_SET_DEVICE_RESTRITION: {
1116                 dpm_status_t value = DPM_STATUS_ERROR;
1117
1118                 __bt_service_get_parameters(in_param1, &value,
1119                                 sizeof(int));
1120
1121                 result = _bt_dpm_activate_bluetooth_device_restriction(value);
1122                 break;
1123         }
1124         case BT_DPM_GET_DEVICE_RESTRITION: {
1125                 int value = DPM_STATUS_ERROR;
1126
1127                 result = _bt_dpm_is_bluetooth_device_restriction_active(&value);
1128                 g_array_append_vals(*out_param1, &value, sizeof(int));
1129                 break;
1130         }
1131         case BT_DPM_SET_UUID_RESTRITION: {
1132                 dpm_status_t value = DPM_STATUS_ERROR;
1133
1134                 __bt_service_get_parameters(in_param1, &value,
1135                                 sizeof(int));
1136
1137                 result = _bt_dpm_activate_bluetoooth_uuid_restriction(value);
1138                 break;
1139         }
1140         case BT_DPM_GET_UUID_RESTRITION: {
1141                 int value = DPM_STATUS_ERROR;
1142
1143                 result = _bt_dpm_is_bluetooth_uuid_restriction_active(&value);
1144                 g_array_append_vals(*out_param1, &value, sizeof(int));
1145                 break;
1146         }
1147         case BT_DPM_ADD_DEVICES_BLACKLIST: {
1148                 bluetooth_device_address_t address = { {0} };
1149
1150                 __bt_service_get_parameters(in_param1, &address,
1151                         sizeof(bluetooth_device_address_t));
1152
1153                 result = _bt_dpm_add_bluetooth_devices_to_blacklist(&address);
1154                 break;
1155         }
1156         case BT_DPM_ADD_DEVICES_WHITELIST: {
1157                 bluetooth_device_address_t address = { {0} };
1158
1159                 __bt_service_get_parameters(in_param1, &address,
1160                         sizeof(bluetooth_device_address_t));
1161
1162                 result = _bt_dpm_add_bluetooth_devices_to_whitelist(&address);
1163                 break;
1164         }
1165         case BT_DPM_ADD_UUIDS_BLACKLIST: {
1166                 const char *uuid = NULL;
1167
1168                 uuid = g_variant_get_data(in_param1);
1169
1170                 result = _bt_dpm_add_bluetooth_uuids_to_blacklist(uuid);
1171                 break;
1172         }
1173         case BT_DPM_ADD_UUIDS_WHITELIST: {
1174                 const char *uuid = NULL;
1175
1176                 uuid = g_variant_get_data(in_param1);
1177
1178                 result = _bt_dpm_add_bluetooth_uuids_to_whitelist(uuid);
1179                 break;
1180         }
1181         case BT_DPM_CLEAR_DEVICES_BLACKLIST: {
1182                 result = _bt_dpm_clear_bluetooth_devices_from_blacklist();
1183                 break;
1184         }
1185         case BT_DPM_CLEAR_DEVICES_WHITELIST: {
1186                 result = _bt_dpm_clear_bluetooth_devices_from_whitelist();
1187                 break;
1188         }
1189         case BT_DPM_CLEAR_UUIDS_BLACKLIST: {
1190                 result = _bt_dpm_clear_bluetooth_uuids_from_blacklist();
1191                 break;
1192         }
1193         case BT_DPM_CLEAR_UUIDS_WHITELIST: {
1194                 result = _bt_dpm_clear_bluetooth_uuids_from_whitelist();
1195                 break;
1196         }
1197         case BT_DPM_REMOVE_DEVICE_BLACKLIST: {
1198                 bluetooth_device_address_t address = { {0} };
1199
1200                 __bt_service_get_parameters(in_param1, &address,
1201                         sizeof(bluetooth_device_address_t));
1202
1203                 result = _bt_dpm_remove_bluetooth_devices_from_blacklist(&address);
1204                 break;
1205         }
1206         case BT_DPM_REMOVE_DEVICE_WHITELIST: {
1207                 bluetooth_device_address_t address = { {0} };
1208
1209                 __bt_service_get_parameters(in_param1, &address,
1210                         sizeof(bluetooth_device_address_t));
1211
1212                 result = _bt_dpm_remove_bluetooth_devices_from_whitelist(&address);
1213                 break;
1214         }
1215         case BT_DPM_REMOVE_UUID_BLACKLIST: {
1216                 const char *uuid = NULL;
1217
1218                 uuid = g_variant_get_data(in_param1);
1219
1220                 result = _bt_dpm_remove_bluetooth_uuids_from_blacklist(uuid);
1221                 break;
1222         }
1223         case BT_DPM_REMOVE_UUID_WHITELIST: {
1224                 const char *uuid = NULL;
1225
1226                 uuid = g_variant_get_data(in_param1);
1227
1228                 result = _bt_dpm_remove_bluetooth_uuids_from_whitelist(uuid);
1229
1230                 break;
1231         }
1232         case BT_DPM_GET_DEVICES_BLACKLIST: {
1233                 result = _bt_dpm_get_bluetooth_devices_from_blacklist(out_param1);
1234                 break;
1235         }
1236         case BT_DPM_GET_DEVICES_WHITELIST: {
1237                 result = _bt_dpm_get_bluetooth_devices_from_whitelist(out_param1);
1238                 break;
1239         }
1240         case BT_DPM_GET_UUIDS_BLACKLIST: {
1241                 result = _bt_dpm_get_bluetooth_uuids_from_blacklist(out_param1);
1242                 break;
1243         }
1244         case BT_DPM_GET_UUIDS_WHITELIST: {
1245                 result = _bt_dpm_get_bluetooth_uuids_from_whitelist(out_param1);
1246                 break;
1247         }
1248         case BT_DPM_SET_ALLOW_OUTGOING_CALL: {
1249                 dpm_status_t value = DPM_STATUS_ERROR;
1250
1251                 __bt_service_get_parameters(in_param1, &value,
1252                                 sizeof(int));
1253
1254                 result = _bt_dpm_set_allow_bluetooth_outgoing_call(value);
1255
1256                 break;
1257         }
1258         case BT_DPM_GET_ALLOW_OUTGOING_CALL: {
1259                 int value = DPM_STATUS_ERROR;
1260
1261                 result = _bt_dpm_get_allow_bluetooth_outgoing_call(&value);
1262                 g_array_append_vals(*out_param1, &value, sizeof(int));
1263                 break;
1264         }
1265         case BT_DPM_SET_PAIRING_STATE: {
1266                 dpm_status_t value = DPM_STATUS_ERROR;
1267
1268                 __bt_service_get_parameters(in_param1, &value,
1269                                 sizeof(int));
1270
1271                 result = _bt_dpm_set_bluetooth_pairing_state(value);
1272
1273                 break;
1274         }
1275         case BT_DPM_GET_PAIRING_STATE: {
1276                 int value = DPM_STATUS_ERROR;
1277
1278                 result = _bt_dpm_get_bluetooth_pairing_state(&value);
1279                 g_array_append_vals(*out_param1, &value, sizeof(int));
1280                 break;
1281         }
1282         case BT_DPM_SET_PROFILE_STATE: {
1283                 int value = DPM_STATUS_ERROR;
1284                 int profile = DPM_PROFILE_NONE;
1285
1286                 __bt_service_get_parameters(in_param1, &profile,
1287                                 sizeof(int));
1288                 __bt_service_get_parameters(in_param2, &value,
1289                                 sizeof(int));
1290
1291                 result = _bt_dpm_set_bluetooth_profile_state(profile, value);
1292
1293                 break;
1294         }
1295         case BT_DPM_GET_PROFILE_STATE: {
1296                 int value = DPM_STATUS_ERROR;
1297                 int profile = DPM_PROFILE_NONE;
1298
1299                 __bt_service_get_parameters(in_param1, &profile,
1300                                 sizeof(int));
1301
1302                 result = _bt_dpm_get_bluetooth_profile_state(profile, &value);
1303                 g_array_append_vals(*out_param1, &value, sizeof(int));
1304                 break;
1305         }
1306         case BT_DPM_SET_DESKROP_CONNECTIVITY_STATE: {
1307                 int value = DPM_BT_ERROR;
1308
1309                 __bt_service_get_parameters(in_param1, &value,
1310                                 sizeof(int));
1311
1312                 result = _bt_dpm_set_bluetooth_desktop_connectivity_state(value);
1313
1314                 break;
1315         }
1316         case BT_DPM_GET_DESKROP_CONNECTIVITY_STATE: {
1317                 int value = DPM_STATUS_ERROR;
1318
1319                 result = _bt_dpm_get_bluetooth_desktop_connectivity_state(&value);
1320                 g_array_append_vals(*out_param1, &value, sizeof(int));
1321                 break;
1322         }
1323         case BT_DPM_SET_DISCOVERABLE_STATE: {
1324                 int value = DPM_STATUS_ERROR;
1325
1326                 __bt_service_get_parameters(in_param1, &value,
1327                                 sizeof(int));
1328
1329                 result = _bt_dpm_set_bluetooth_discoverable_state(value);
1330
1331                 break;
1332         }
1333         case BT_DPM_GET_DISCOVERABLE_STATE: {
1334                 int value = DPM_STATUS_ERROR;
1335
1336                 result = _bt_dpm_get_bluetooth_discoverable_state(&value);
1337                 g_array_append_vals(*out_param1, &value, sizeof(int));
1338                 break;
1339         }
1340         case BT_DPM_SET_LIMITED_DISCOVERABLE_STATE: {
1341                 int value = DPM_STATUS_ERROR;
1342
1343                 __bt_service_get_parameters(in_param1, &value,
1344                                 sizeof(int));
1345
1346                 result = _bt_dpm_set_bluetooth_limited_discoverable_state(value);
1347
1348                 break;
1349         }
1350         case BT_DPM_GET_LIMITED_DISCOVERABLE_STATE: {
1351                 int value = DPM_STATUS_ERROR;
1352
1353                 result = _bt_dpm_get_bluetooth_limited_discoverable_state(&value);
1354                 g_array_append_vals(*out_param1, &value, sizeof(int));
1355                 break;
1356         }
1357         case BT_DPM_SET_DATA_TRANSFER_STATE: {
1358                 int value = DPM_STATUS_ERROR;
1359
1360                 __bt_service_get_parameters(in_param1, &value,
1361                                 sizeof(int));
1362
1363                 result = _bt_dpm_set_bluetooth_data_transfer_state(value);
1364
1365                 break;
1366         }
1367         case BT_DPM_GET_DATA_TRANSFER_STATE: {
1368                 int value = DPM_STATUS_ERROR;
1369
1370                 result = _bt_dpm_get_allow_bluetooth_data_transfer_state(&value);
1371                 g_array_append_vals(*out_param1, &value, sizeof(int));
1372                 break;
1373         }
1374 #endif
1375         case BT_RFCOMM_CLIENT_CONNECT: {
1376                 bluetooth_device_address_t address = { {0} };
1377                 char *input_string;
1378                 int connect_type;
1379
1380                 __bt_service_get_parameters(in_param1,
1381                                 &address, sizeof(bluetooth_device_address_t));
1382                 input_string = (char *)g_variant_get_data(in_param2);
1383                 __bt_service_get_parameters(in_param3, &connect_type, sizeof(int));
1384
1385                 if (connect_type == BT_RFCOMM_UUID)
1386                         result = _bt_rfcomm_connect_using_uuid(&address, input_string);
1387                 else
1388                         result = _bt_rfcomm_connect_using_channel(&address, input_string);
1389
1390                 if (result != BLUETOOTH_ERROR_NONE) {
1391                         bluetooth_rfcomm_connection_t conn_info;
1392
1393                         BT_ERR("BT_RFCOMM_CLIENT_CONNECT failed, send error");
1394                         memset(&conn_info, 0x00, sizeof(bluetooth_rfcomm_connection_t));
1395                         if (connect_type == BT_RFCOMM_UUID)
1396                                 g_strlcpy(conn_info.uuid, input_string, BLUETOOTH_UUID_STRING_MAX);
1397                         else
1398                                 g_strlcpy(conn_info.uuid, "not_used", BLUETOOTH_UUID_STRING_MAX);
1399
1400                         conn_info.device_role = RFCOMM_ROLE_CLIENT;
1401                         conn_info.socket_fd = -1;
1402                         g_array_append_vals(*out_param1, &conn_info,
1403                                         sizeof(bluetooth_rfcomm_connection_t));
1404                 } else {
1405                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1406                         BT_ERR("BT_RFCOMM_CLIENT_CONNECT success, save context");
1407                         _bt_convert_addr_type_to_string(addr, address.addr);
1408                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1409                         _bt_save_invocation_context(context, result, sender, function_name, addr);
1410                 }
1411                 break;
1412         }
1413         case BT_RFCOMM_SOCKET_DISCONNECT: {
1414                 /*
1415                  * Bluetooth RFCOMM socket disconnection will be done from bt-api, call to bt-service
1416                  * is only used for privilege check, so return BLUETOOTH_ERROR_NONE from here.
1417                  */
1418                 result = BLUETOOTH_ERROR_NONE;
1419                 break;
1420         }
1421         case BT_RFCOMM_SOCKET_WRITE: {
1422                 /*
1423                  * This call to bt-service is only used for privilege check, so return
1424                  * BLUETOOTH_ERROR_NONE from here.
1425                  */
1426                 result = BLUETOOTH_ERROR_NONE;
1427                 break;
1428         }
1429         case BT_RFCOMM_CREATE_SOCKET: {
1430                 /*
1431                  * This call to bt-service is only used for privilege check, so return
1432                  * BLUETOOTH_ERROR_NONE from here.
1433                  */
1434                 result = BLUETOOTH_ERROR_NONE;
1435                 break;
1436         }
1437         case BT_RFCOMM_LISTEN_AND_ACCEPT: {
1438                 char *uuid;
1439                 int socket_fd = -1;
1440
1441                 sender = (char *)g_dbus_method_invocation_get_sender(context);
1442                 uuid = (char *)g_variant_get_data(in_param1);
1443
1444                 result = _bt_rfcomm_socket_listen(sender, uuid, true);
1445                 if (result > 0) {
1446                         BT_ERR("BT_RFCOMM_LISTEN_AND_ACCEPT success, save context");
1447
1448                         result = BLUETOOTH_ERROR_NONE;
1449                         _bt_save_invocation_context(context,
1450                                         result, sender, function_name, NULL);
1451                 } else {
1452                         g_array_append_vals(*out_param1, &socket_fd, sizeof(int));
1453                 }
1454                 break;
1455         }
1456         case BT_RFCOMM_LISTEN: {
1457                 char *uuid;
1458                 int socket_fd = -1;
1459
1460                 sender = (char *)g_dbus_method_invocation_get_sender(context);
1461                 uuid = (char *)g_variant_get_data(in_param1);
1462
1463                 result = _bt_rfcomm_socket_listen(sender, uuid, false);
1464                 if (result > 0) {
1465                         BT_ERR("BT_RFCOMM_LISTEN success, save context");
1466
1467                         result = BLUETOOTH_ERROR_NONE;
1468                         _bt_save_invocation_context(context,
1469                                         result, sender, function_name, NULL);
1470                 } else {
1471                         g_array_append_vals(*out_param1, &socket_fd, sizeof(int));
1472                 }
1473                 break;
1474         }
1475         case BT_RFCOMM_ACCEPT_CONNECTION: {
1476                 char *address;
1477
1478                 address = (char *)g_variant_get_data(in_param1);
1479                 result = _bt_rfcomm_reply_conn_authorization(address, TRUE);
1480                 break;
1481         }
1482         case BT_RFCOMM_REJECT_CONNECTION: {
1483                 char *address;
1484
1485                 address = (char *)g_variant_get_data(in_param1);
1486                 result = _bt_rfcomm_reply_conn_authorization(address, FALSE);
1487                 break;
1488         }
1489         case BT_RFCOMM_REMOVE_SOCKET: {
1490                 /*
1491                  * This call to bt-service is only used for privilege check, so return
1492                  * BLUETOOTH_ERROR_NONE from here.
1493                  */
1494                 result = BLUETOOTH_ERROR_NONE;
1495                 break;
1496         }
1497         case BT_RFCOMM_SEND_RX_DETAILS: {
1498                 uid_t uid;
1499                 pid_t pid;
1500                 int size;
1501                 __bt_service_get_parameters(in_param1, &uid, sizeof(uid_t));
1502                 __bt_service_get_parameters(in_param2, &pid, sizeof(pid_t));
1503                 __bt_service_get_parameters(in_param3, &size, sizeof(int));
1504                 BT_DBG("Sending details to bluetooth battery monitor: %ld, %ld, %d", (long int)uid, (long int)pid, size);
1505                 _bt_bm_add_transaction_details(uid, pid, size, RX_DATA);
1506                 break;
1507         }
1508         case BT_RFCOMM_SEND_TX_DETAILS: {
1509                 uid_t uid;
1510                 pid_t pid;
1511                 int size;
1512                 __bt_service_get_parameters(in_param1, &uid, sizeof(uid_t));
1513                 __bt_service_get_parameters(in_param2, &pid, sizeof(pid_t));
1514                 __bt_service_get_parameters(in_param3, &size, sizeof(int));
1515                 BT_DBG("Sending details to bluetooth battery monitor: %ld, %ld, %d", (long int)uid, (long int)pid, size);
1516                 _bt_bm_add_transaction_details(uid, pid, size, TX_DATA);
1517                 break;
1518         }
1519         case BT_AUDIO_SELECT_ROLE: {
1520                 bluetooth_audio_role_t role;
1521
1522                 __bt_service_get_parameters(in_param1,
1523                                 &role, sizeof(bluetooth_audio_role_t));
1524
1525                 result = _bt_audio_select_role(role);
1526                 if (result == BLUETOOTH_ERROR_NONE) {
1527                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1528                         _bt_save_invocation_context(context, result, sender,
1529                                         function_name, NULL);
1530                 }
1531                 break;
1532         }
1533         case BT_AV_CONNECT: {
1534                 bluetooth_device_address_t address = { {0} };
1535                 __bt_service_get_parameters(in_param1,
1536                                 &address, sizeof(bluetooth_device_address_t));
1537
1538                 result = _bt_audio_connect(BT_AUDIO_A2DP, &address);
1539
1540                 if (result != BLUETOOTH_ERROR_NONE) {
1541                         char addr[BT_ADDRESS_STRING_SIZE];
1542                         _bt_convert_addr_type_to_string(addr, address.addr);
1543                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1544                 } else {
1545                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1546                         _bt_convert_addr_type_to_string(addr, address.addr);
1547                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1548                         _bt_save_invocation_context(context, result, sender,
1549                                         function_name, (gpointer)addr);
1550                 }
1551                 break;
1552         }
1553         case BT_AUDIO_CONNECT: {
1554                 bluetooth_device_address_t address = { {0} };
1555                 __bt_service_get_parameters(in_param1,
1556                                 &address, sizeof(bluetooth_device_address_t));
1557
1558                 result = _bt_audio_connect(BT_AUDIO_ALL, &address);
1559
1560                 if (result != BLUETOOTH_ERROR_NONE) {
1561                         char addr[BT_ADDRESS_STRING_SIZE];
1562                         _bt_convert_addr_type_to_string(addr, address.addr);
1563                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1564                 } else {
1565                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1566                         _bt_convert_addr_type_to_string(addr, address.addr);
1567                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1568                         _bt_save_invocation_context(context, result, sender,
1569                                         function_name, (gpointer)addr);
1570                 }
1571                 break;
1572         }
1573         case BT_AUDIO_DISCONNECT: {
1574                 bluetooth_device_address_t address = { {0} };
1575                 __bt_service_get_parameters(in_param1,
1576                                 &address, sizeof(bluetooth_device_address_t));
1577
1578                 result = _bt_audio_disconnect(BT_AUDIO_ALL, &address);
1579
1580                 if (result != BLUETOOTH_ERROR_NONE) {
1581                         char addr[BT_ADDRESS_STRING_SIZE];
1582                         _bt_convert_addr_type_to_string(addr, address.addr);
1583                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1584                 } else {
1585                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1586                         _bt_convert_addr_type_to_string(addr, address.addr);
1587                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1588                         _bt_save_invocation_context(context, result, sender,
1589                                         function_name, (gpointer)addr);
1590                 }
1591                 break;
1592         }
1593         case BT_AV_DISCONNECT: {
1594                 bluetooth_device_address_t address = { {0} };
1595                 __bt_service_get_parameters(in_param1,
1596                                 &address, sizeof(bluetooth_device_address_t));
1597
1598                 result = _bt_audio_disconnect(BT_AUDIO_A2DP, &address);
1599
1600                 if (result != BLUETOOTH_ERROR_NONE) {
1601                         char addr[BT_ADDRESS_STRING_SIZE];
1602                         _bt_convert_addr_type_to_string(addr, address.addr);
1603                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1604                 } else {
1605                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1606                         _bt_convert_addr_type_to_string(addr, address.addr);
1607                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1608                         _bt_save_invocation_context(context, result, sender,
1609                                         function_name, (gpointer)addr);
1610                 }
1611                 break;
1612         }
1613         case BT_AG_CONNECT: {
1614                 bluetooth_device_address_t address = { {0} };
1615                 __bt_service_get_parameters(in_param1,
1616                                 &address, sizeof(bluetooth_device_address_t));
1617
1618                 result = _bt_audio_connect(BT_AUDIO_HSP, &address);
1619
1620                 if (result != BLUETOOTH_ERROR_NONE) {
1621                         char addr[BT_ADDRESS_STRING_SIZE];
1622                         _bt_convert_addr_type_to_string(addr, address.addr);
1623                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1624                 } else {
1625                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1626                         _bt_convert_addr_type_to_string(addr, address.addr);
1627                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1628                         _bt_save_invocation_context(context, result, sender,
1629                                         function_name, (gpointer)addr);
1630                 }
1631                 break;
1632         }
1633         case BT_AG_DISCONNECT: {
1634                 bluetooth_device_address_t address = { {0} };
1635
1636                 __bt_service_get_parameters(in_param1,
1637                                 &address, sizeof(bluetooth_device_address_t));
1638
1639                 result = _bt_audio_disconnect(BT_AUDIO_HSP, &address);
1640
1641                 if (result != BLUETOOTH_ERROR_NONE) {
1642                         char addr[BT_ADDRESS_STRING_SIZE];
1643                         _bt_convert_addr_type_to_string(addr, address.addr);
1644                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1645                 } else {
1646                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1647                         _bt_convert_addr_type_to_string(addr, address.addr);
1648                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1649                         _bt_save_invocation_context(context, result, sender,
1650                                         function_name, (gpointer)addr);
1651                 }
1652                 break;
1653         }
1654         case BT_AV_SOURCE_CONNECT: {
1655                 bluetooth_device_address_t address = { {0} };
1656
1657                 __bt_service_get_parameters(in_param1,
1658                                 &address, sizeof(bluetooth_device_address_t));
1659
1660                 result = _bt_audio_connect(BT_AUDIO_A2DP_SOURCE, &address);
1661                 if (result != BLUETOOTH_ERROR_NONE) {
1662                         char addr[BT_ADDRESS_STRING_SIZE];
1663                         _bt_convert_addr_type_to_string(addr, address.addr);
1664                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1665                 } else {
1666                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1667                         _bt_convert_addr_type_to_string(addr, address.addr);
1668                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1669                         _bt_save_invocation_context(context, result, sender,
1670                                         function_name, (gpointer)addr);
1671                 }
1672                 break;
1673         }
1674         case BT_AV_SOURCE_DISCONNECT: {
1675                 bluetooth_device_address_t address = { {0} };
1676
1677                 __bt_service_get_parameters(in_param1,
1678                                 &address, sizeof(bluetooth_device_address_t));
1679
1680                 result = _bt_audio_disconnect(BT_AUDIO_A2DP_SOURCE, &address);
1681                 if (result != BLUETOOTH_ERROR_NONE) {
1682                         char addr[BT_ADDRESS_STRING_SIZE];
1683                         _bt_convert_addr_type_to_string(addr, address.addr);
1684                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1685                 } else {
1686                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1687                         _bt_convert_addr_type_to_string(addr, address.addr);
1688                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1689                         _bt_save_invocation_context(context, result, sender,
1690                                         function_name, (gpointer)addr);
1691                 }
1692                 break;
1693         }
1694         case BT_HF_CONNECT: {
1695                 bluetooth_device_address_t address = { {0} };
1696
1697                 __bt_service_get_parameters(in_param1,
1698                                 &address, sizeof(bluetooth_device_address_t));
1699
1700                 result = _bt_hf_connect(&address);
1701                 if (result != BLUETOOTH_ERROR_NONE) {
1702                         char addr[BT_ADDRESS_STRING_SIZE];
1703                         _bt_convert_addr_type_to_string(addr, address.addr);
1704                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1705                 } else {
1706                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1707                         _bt_convert_addr_type_to_string(addr, address.addr);
1708                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1709                         _bt_save_invocation_context(context, result, sender,
1710                                         function_name, (gpointer)addr);
1711                 }
1712                 break;
1713         }
1714         case BT_HF_DISCONNECT: {
1715                 bluetooth_device_address_t address = { {0} };
1716
1717                 __bt_service_get_parameters(in_param1,
1718                                 &address, sizeof(bluetooth_device_address_t));
1719
1720                 result = _bt_hf_disconnect(&address);
1721                 if (result != BLUETOOTH_ERROR_NONE) {
1722                         char addr[BT_ADDRESS_STRING_SIZE];
1723                         _bt_convert_addr_type_to_string(addr, address.addr);
1724                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1725                 } else {
1726                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1727                         _bt_convert_addr_type_to_string(addr, address.addr);
1728                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1729                         _bt_save_invocation_context(context, result, sender,
1730                                         function_name, (gpointer)addr);
1731                 }
1732                 break;
1733         }
1734         case BT_AVRCP_TARGET_CONNECT: {
1735                 bluetooth_device_address_t address = { {0} };
1736
1737                 __bt_service_get_parameters(in_param1,
1738                                 &address, sizeof(bluetooth_device_address_t));
1739
1740                 result = _bt_audio_connect(BT_AVRCP_TARGET, &address);
1741                 if (result != BLUETOOTH_ERROR_NONE) {
1742                         char addr[BT_ADDRESS_STRING_SIZE];
1743                         _bt_convert_addr_type_to_string(addr, address.addr);
1744                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1745                 } else {
1746                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1747                         _bt_convert_addr_type_to_string(addr, address.addr);
1748                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1749                         _bt_save_invocation_context(context, result, sender,
1750                                         function_name, (gpointer)addr);
1751                 }
1752                 break;
1753         }
1754         case BT_AVRCP_TARGET_DISCONNECT: {
1755                 bluetooth_device_address_t address = { {0} };
1756
1757                 __bt_service_get_parameters(in_param1,
1758                                 &address, sizeof(bluetooth_device_address_t));
1759
1760                 result = _bt_audio_disconnect(BT_AVRCP_TARGET, &address);
1761                 if (result != BLUETOOTH_ERROR_NONE) {
1762                         char addr[BT_ADDRESS_STRING_SIZE];
1763                         _bt_convert_addr_type_to_string(addr, address.addr);
1764                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1765                 } else {
1766                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1767                         _bt_convert_addr_type_to_string(addr, address.addr);
1768                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1769                         _bt_save_invocation_context(context, result, sender,
1770                                         function_name, (gpointer)addr);
1771                 }
1772                 break;
1773         }
1774         case BT_AVRCP_CONTROL_CONNECT: {
1775                 bluetooth_device_address_t address = { {0} };
1776
1777                 __bt_service_get_parameters(in_param1,
1778                                 &address, sizeof(bluetooth_device_address_t));
1779
1780                 result = _bt_audio_connect(BT_AVRCP, &address);
1781                 if (result != BLUETOOTH_ERROR_NONE) {
1782                         char addr[BT_ADDRESS_STRING_SIZE];
1783                         _bt_convert_addr_type_to_string(addr, address.addr);
1784                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1785                 } else {
1786                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1787                         _bt_convert_addr_type_to_string(addr, address.addr);
1788                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1789                         _bt_save_invocation_context(context, result, sender,
1790                                         function_name, (gpointer)addr);
1791                 }
1792                 break;
1793         }
1794         case BT_AVRCP_CONTROL_DISCONNECT: {
1795                 bluetooth_device_address_t address = { {0} };
1796
1797                 __bt_service_get_parameters(in_param1,
1798                                 &address, sizeof(bluetooth_device_address_t));
1799
1800                 result = _bt_audio_disconnect(BT_AVRCP, &address);
1801                 if (result != BLUETOOTH_ERROR_NONE) {
1802                         char addr[BT_ADDRESS_STRING_SIZE];
1803                         _bt_convert_addr_type_to_string(addr, address.addr);
1804                         g_array_append_vals(*out_param1, addr, BT_ADDRESS_STRING_SIZE);
1805                 } else {
1806                         char *addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1807                         _bt_convert_addr_type_to_string(addr, address.addr);
1808                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1809                         _bt_save_invocation_context(context, result, sender,
1810                                         function_name, (gpointer)addr);
1811                 }
1812                 break;
1813         }
1814         case BT_AVRCP_HANDLE_CONTROL: {
1815                 int key_code;
1816                 __bt_service_get_parameters(in_param1, &key_code, sizeof(int));
1817                 result = _bt_avrcp_control_cmd(key_code);
1818                 break;
1819         }
1820         case BT_AVRCP_HANDLE_CONTROL_TO_DEST: {
1821                 int key_code;
1822                 bluetooth_device_address_t address = { { 0 } };
1823
1824                 __bt_service_get_parameters(in_param1, &key_code, sizeof(int));
1825                 __bt_service_get_parameters(in_param2,
1826                                                 &address, sizeof(bluetooth_device_address_t));
1827
1828                 result = _bt_avrcp_control_cmd_to_dest(key_code, &address);
1829                 break;
1830         }
1831         case BT_AVRCP_CONTROL_SET_PROPERTY: {
1832                 int type;
1833                 unsigned int value;
1834
1835                 __bt_service_get_parameters(in_param1,
1836                                 &type, sizeof(int));
1837                 __bt_service_get_parameters(in_param2,
1838                                 &value, sizeof(unsigned int));
1839
1840                 result = _bt_avrcp_control_set_property(type, value);
1841                 break;
1842         }
1843         case BT_AVRCP_TRANSPORT_SET_PROPERTY: {
1844                 int type;
1845                 unsigned int value;
1846                 BT_DBG("+");
1847
1848                 __bt_service_get_parameters(in_param1,
1849                                 &type, sizeof(int));
1850                 __bt_service_get_parameters(in_param2,
1851                                 &value, sizeof(unsigned int));
1852
1853                 result = _bt_avrcp_transport_set_property(type, value);
1854                 BT_DBG("-");
1855                 break;
1856         }
1857         case BT_AVRCP_CONTROL_GET_PROPERTY: {
1858                 int type;
1859
1860                 __bt_service_get_parameters(in_param1, &type, sizeof(int));
1861
1862                 result = _bt_avrcp_control_get_property(type);
1863                 /* Save invocation */
1864                 if (result == BLUETOOTH_ERROR_NONE) {
1865                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1866                         _bt_save_invocation_context(context, result, sender,
1867                                         function_name, g_memdup(&type, sizeof(int)));
1868                 }
1869                 break;
1870         }
1871         case BT_AVRCP_GET_TRACK_INFO: {
1872                 result = _bt_avrcp_control_get_track_info();
1873                 /* Save invocation */
1874                 if (result == BLUETOOTH_ERROR_NONE) {
1875                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1876                         _bt_save_invocation_context(context, result, sender,
1877                                         function_name, NULL);
1878                 }
1879                 break;
1880         }
1881         case BT_HDP_REGISTER_SINK_APP: {
1882                 unsigned short data_type;
1883                 bt_hdp_role_type_t role;
1884                 bt_hdp_qos_type_t channel_type;
1885                 int *app_id = g_new0(int, 1);
1886
1887                 __bt_service_get_parameters(in_param1,
1888                                 &data_type, sizeof(short));
1889                 __bt_service_get_parameters(in_param2,
1890                                 &role, sizeof(bt_hdp_role_type_t));
1891                 __bt_service_get_parameters(in_param3,
1892                                 &channel_type, sizeof(bt_hdp_qos_type_t));
1893                 sender = (char*)g_dbus_method_invocation_get_sender(context);
1894
1895                 result = _bt_hdp_app_register(role,
1896                                 channel_type, data_type, sender, app_id);
1897                 if (result != BLUETOOTH_ERROR_NONE) {
1898                         g_array_append_vals(*out_param1, &app_id, sizeof(app_id));
1899                         g_free(app_id);
1900                 } else {
1901                         _bt_save_invocation_context(context, result, sender,
1902                                         function_name, (gpointer)app_id);
1903                 }
1904                 break;
1905         }
1906         case BT_HDP_UNREGISTER_SINK_APP: {
1907                 char *app_handle;
1908                 int *app_id = g_new0(int, 1);
1909
1910                 app_handle = (char *)g_variant_get_data(in_param1);
1911                 sscanf(app_handle, "health_app_%d", app_id);
1912                 result = _bt_hdp_app_unregister(*app_id);
1913                 if (result != BLUETOOTH_ERROR_NONE) {
1914                         g_free(app_id);
1915                 } else {
1916                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1917                         _bt_save_invocation_context(context, result, sender,
1918                                         function_name, (gpointer)app_id);
1919                 }
1920                 break;
1921         }
1922         case BT_HDP_CONNECT: {
1923                 int app_id = -1;
1924                 char *app_handle;
1925
1926                 bt_hdp_connected_t *conn_info = NULL;
1927
1928                 conn_info = g_malloc0(sizeof(bt_hdp_connected_t));
1929
1930                 app_handle = (char *)g_variant_get_data(in_param1);
1931                 conn_info->app_handle = app_handle;
1932                 sscanf(app_handle, "health_app_%d", &app_id);
1933
1934                 __bt_service_get_parameters(in_param2,
1935                                 &(conn_info->type), sizeof(bt_hdp_qos_type_t));
1936                 __bt_service_get_parameters(in_param3,
1937                                 &(conn_info->device_address),
1938                                 sizeof(bluetooth_device_address_t));
1939
1940                 result = _bt_hdp_connect(app_id, &(conn_info->device_address),
1941                                 conn_info->type, (int *)(&(conn_info->channel_id)));
1942                 if (result != BLUETOOTH_ERROR_NONE) {
1943                         g_array_append_vals(*out_param1, conn_info,
1944                                         sizeof(bt_hdp_connected_t));
1945                         g_free(conn_info);
1946                 } else {
1947                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1948                         _bt_save_invocation_context(context, result, sender,
1949                                         function_name, (gpointer)conn_info);
1950                 }
1951                 break;
1952         }
1953         case BT_HDP_DISCONNECT: {
1954                 bt_hdp_disconnected_t *hdp_disconn_info = NULL;
1955
1956                 hdp_disconn_info = g_malloc0(sizeof(bt_hdp_disconnected_t));
1957
1958                 __bt_service_get_parameters(in_param1,
1959                                 &(hdp_disconn_info->channel_id), sizeof(int));
1960                 __bt_service_get_parameters(in_param2,
1961                                 &(hdp_disconn_info->device_address),
1962                                 sizeof(bluetooth_device_address_t));
1963
1964                 result = _bt_hdp_disconnect(hdp_disconn_info->channel_id);
1965                 if (result != BLUETOOTH_ERROR_NONE) {
1966                         g_array_append_vals(*out_param1, hdp_disconn_info,
1967                                         sizeof(bt_hdp_disconnected_t));
1968                         g_free(hdp_disconn_info);
1969                 } else {
1970                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1971                         _bt_save_invocation_context(context, result, sender,
1972                                         function_name, (gpointer)hdp_disconn_info);
1973                 }
1974                 break;
1975         }
1976         case BT_HDP_GET_FD: {
1977                 int *channel_id = g_new0(int, 1);
1978
1979                 __bt_service_get_parameters(in_param1, channel_id, sizeof(int));
1980
1981                 result = _bt_hdp_get_fd(*channel_id);
1982                 if (result != BLUETOOTH_ERROR_NONE) {
1983                         g_free(channel_id);
1984                 } else {
1985                         sender = (char*)g_dbus_method_invocation_get_sender(context);
1986                         _bt_save_invocation_context(context, result, sender,
1987                                         function_name, (gpointer)channel_id);
1988                 }
1989                 break;
1990         }
1991         case BT_HDP_SEND_DATA: {
1992                 /*
1993                  * This call to bt-service is only used for privilege check, so return
1994                  * BLUETOOTH_ERROR_NONE from here.
1995                  */
1996                 result = BLUETOOTH_ERROR_NONE;
1997                 break;
1998         }
1999         case BT_OOB_READ_LOCAL_DATA: {  //208
2000                 bt_oob_data_t local_oob_data;
2001
2002                 memset(&local_oob_data, 0x00, sizeof(bt_oob_data_t));
2003                 result = _bt_oob_read_local_data(&local_oob_data);
2004
2005                 g_array_append_vals(*out_param1, &local_oob_data,
2006                                 sizeof(bt_oob_data_t));
2007
2008                 break;
2009         }
2010         case BT_OOB_ADD_REMOTE_DATA: {   //209
2011                 bluetooth_device_address_t address = { {0} };
2012                 unsigned short address_type;
2013                 bt_oob_data_t remote_oob_data;
2014
2015                 __bt_service_get_parameters(in_param1,
2016                                 &address, sizeof(bluetooth_device_address_t));
2017                 __bt_service_get_parameters(in_param2,
2018                                 &address_type, sizeof(unsigned short));
2019                 __bt_service_get_parameters(in_param3,
2020                                 &remote_oob_data, sizeof(bt_oob_data_t));
2021
2022                 result = _bt_oob_add_remote_data(&address, address_type, &remote_oob_data);
2023
2024                 break;
2025         }
2026         case BT_OOB_REMOVE_REMOTE_DATA: {       //210
2027                 bluetooth_device_address_t address = { {0} };
2028
2029                 __bt_service_get_parameters(in_param1,
2030                                 &address, sizeof(bluetooth_device_address_t));
2031
2032                 result = _bt_oob_remove_remote_data(&address);
2033
2034                 break;
2035         }
2036         case BT_LE_OOB_READ_LOCAL_DATA: {
2037                 bt_oob_data_t local_oob_data;
2038
2039                 memset(&local_oob_data, 0x00, sizeof(bt_oob_data_t));
2040                 result = _bt_le_oob_read_local_data(&local_oob_data);
2041
2042                 g_array_append_vals(*out_param1, &local_oob_data,
2043                                 sizeof(bt_oob_data_t));
2044
2045                 break;
2046         }
2047         case BT_LE_OOB_ADD_REMOTE_DATA: {
2048                 bluetooth_device_address_t address = { {0} };
2049                 unsigned short address_type;
2050                 bt_oob_data_t remote_oob_data;
2051
2052                 __bt_service_get_parameters(in_param1,
2053                                 &address, sizeof(bluetooth_device_address_t));
2054                 __bt_service_get_parameters(in_param2,
2055                                 &address_type, sizeof(unsigned short));
2056                 __bt_service_get_parameters(in_param3,
2057                                 &remote_oob_data, sizeof(bt_oob_data_t));
2058
2059                 result = _bt_oob_add_remote_data(&address, address_type, &remote_oob_data);
2060
2061                 break;
2062         }
2063         case BT_AVRCP_SET_TRACK_INFO: {
2064                 media_metadata_t data;
2065                 media_metadata_attributes_t meta_data;
2066
2067                 memset(&data, 0x00, sizeof(media_metadata_t));
2068                 memset(&meta_data, 0x00, sizeof(media_metadata_attributes_t));
2069
2070                 __bt_service_get_parameters(in_param1,
2071                                 &data, sizeof(media_metadata_t));
2072
2073                 meta_data.title = g_strdup(data.title);
2074                 meta_data.artist = g_strdup(data.artist);
2075                 meta_data.album = g_strdup(data.album);
2076                 meta_data.genre = g_strdup(data.genre);
2077                 meta_data.total_tracks = data.total_tracks;
2078                 meta_data.number = data.number;
2079                 meta_data.duration = (int64_t) data.duration;
2080
2081                 result = _bt_avrcp_set_track_info(&meta_data);
2082
2083                 g_free((gpointer)meta_data.title);
2084                 g_free((gpointer)meta_data.artist);
2085                 g_free((gpointer)meta_data.album);
2086                 g_free((gpointer)meta_data.genre);
2087
2088                 break;
2089         }
2090         case BT_AVRCP_SET_PROPERTY: {
2091                 int type;
2092                 unsigned int value;
2093
2094                 sender = (char *)g_dbus_method_invocation_get_sender(context);
2095                 BT_INFO("Sender %s", sender);
2096
2097                 __bt_service_get_parameters(in_param1,
2098                                 &type, sizeof(int));
2099                 __bt_service_get_parameters(in_param2,
2100                                 &value, sizeof(unsigned int));
2101
2102                 if (value == STATUS_PLAYING) {
2103                         if (current_sender_playing)
2104                                 g_free(current_sender_playing);
2105                         current_sender_playing = g_strdup(sender);
2106                 }
2107                 if (g_strcmp0(sender, current_sender_playing) == 0 ||
2108                         current_sender_playing == NULL) {
2109                         BT_INFO("Current Player Status %d type %d", value, type);
2110                 } else {
2111                         BT_INFO("Current Player and this sender are different");
2112                         result = BLUETOOTH_ERROR_NONE;
2113                         break;
2114                 }
2115                 result = _bt_avrcp_set_property(type, value);
2116
2117                 break;
2118         }
2119         case BT_AVRCP_SET_PROPERTIES: {
2120                 media_player_settings_t properties;
2121
2122                 memset(&properties, 0x00, sizeof(media_player_settings_t));
2123                 __bt_service_get_parameters(in_param1,
2124                                 &properties, sizeof(media_player_settings_t));
2125
2126                 result = _bt_avrcp_set_properties(&properties);
2127
2128                 break;
2129         }
2130         case BT_SET_ADVERTISING_DATA: {
2131                 char *app = NULL;
2132                 int *adv_handle;
2133                 bluetooth_advertising_data_t adv = { {0} };
2134                 int length;
2135                 gboolean use_reserved_slot = FALSE;
2136
2137                 app = (char *)g_dbus_method_invocation_get_sender(context);
2138                 adv_handle = g_malloc0(sizeof(int));
2139
2140                 __bt_service_get_parameters(in_param1,
2141                                 adv_handle, sizeof(int));
2142                 __bt_service_get_parameters(in_param3,
2143                                 &length, sizeof(int));
2144                 __bt_service_get_parameters(in_param2,
2145                                 &adv, length);
2146                 __bt_service_get_parameters(in_param4,
2147                                 &use_reserved_slot, sizeof(gboolean));
2148                 result = _bt_set_advertising_data(app, *adv_handle,
2149                                 &adv, length, use_reserved_slot);
2150                 if (result != BLUETOOTH_ERROR_NONE) {
2151                         BT_ERR("Set Advertising data failed!!");
2152                         g_free(adv_handle);
2153                 } else {
2154                         _bt_save_invocation_context(context, result, app,
2155                                         function_name, (gpointer)adv_handle);
2156                 }
2157                 break;
2158         }
2159         case BT_SET_SCAN_RESPONSE_DATA: {
2160                 char *app = NULL;
2161                 int *adv_handle;
2162                 bluetooth_scan_resp_data_t rsp = { {0} };
2163                 int length;
2164                 gboolean use_reserved_slot = FALSE;
2165
2166                 app = (char *)g_dbus_method_invocation_get_sender(context);
2167                 adv_handle = g_malloc0(sizeof(int));
2168
2169                 __bt_service_get_parameters(in_param1,
2170                                 adv_handle, sizeof(int));
2171                 __bt_service_get_parameters(in_param3,
2172                                 &length, sizeof(int));
2173                 __bt_service_get_parameters(in_param2,
2174                                 &rsp, length);
2175                 __bt_service_get_parameters(in_param4,
2176                                 &use_reserved_slot, sizeof(gboolean));
2177
2178                 result = _bt_set_scan_response_data(app, *adv_handle,
2179                                 &rsp, length, use_reserved_slot);
2180
2181                 if (result != BLUETOOTH_ERROR_NONE) {
2182                         BT_ERR("Set Scan Response Data failed!!");
2183                         g_free(adv_handle);
2184                 } else {
2185                         _bt_save_invocation_context(context, result, app,
2186                                         function_name, (gpointer)adv_handle);
2187                 }
2188                 break;
2189         }
2190         case BT_SET_ADVERTISING: {
2191                 char *app = NULL;
2192                 int *adv_handle;
2193                 gboolean enable = FALSE;
2194                 gboolean use_reserved_slot = FALSE;
2195
2196                 adv_handle = g_malloc0(sizeof(int));
2197                 __bt_service_get_parameters(in_param1,
2198                                 adv_handle, sizeof(int));
2199                 __bt_service_get_parameters(in_param2,
2200                                 &enable, sizeof(gboolean));
2201                 __bt_service_get_parameters(in_param3,
2202                                 &use_reserved_slot, sizeof(gboolean));
2203
2204                 app = (char *)g_dbus_method_invocation_get_sender(context);
2205
2206                 result = _bt_set_advertising(app, *adv_handle,
2207                                 enable, use_reserved_slot);
2208                 if (result != BLUETOOTH_ERROR_NONE) {
2209                         BT_ERR("Start Advertising failed!!");
2210                         g_free(adv_handle);
2211                 } else {
2212                         _bt_save_invocation_context(context, result, app,
2213                                         function_name, (gpointer)adv_handle);
2214                 }
2215                 break;
2216         }
2217         case BT_SET_CUSTOM_ADVERTISING: {
2218                 char *app = NULL;
2219                 int *adv_handle;
2220                 gboolean enable = FALSE;
2221                 bluetooth_advertising_params_t adv_params;
2222                 gboolean use_reserved_slot = FALSE;
2223
2224                 app = (char *)g_dbus_method_invocation_get_sender(context);
2225                 adv_handle = g_malloc0(sizeof(int));
2226
2227                 __bt_service_get_parameters(in_param1, adv_handle,
2228                                 sizeof(int));
2229                 __bt_service_get_parameters(in_param2, &enable,
2230                                 sizeof(gboolean));
2231                 __bt_service_get_parameters(in_param3, &adv_params,
2232                                 sizeof(bluetooth_advertising_params_t));
2233                 __bt_service_get_parameters(in_param4, &use_reserved_slot,
2234                                 sizeof(gboolean));
2235
2236                 BT_DBG("bluetooth_advertising_params_t [%f %f %d %d %d]",
2237                                 adv_params.interval_min, adv_params.interval_max,
2238                                 adv_params.filter_policy, adv_params.type, adv_params.tx_power_level);
2239                 result = _bt_set_custom_advertising(app, *adv_handle,
2240                                 enable, &adv_params, use_reserved_slot);
2241                 if (result != BLUETOOTH_ERROR_NONE) {
2242                         BT_ERR("Start Custom Advertising failed!!");
2243                         g_free(adv_handle);
2244                 } else {
2245                         _bt_save_invocation_context(context, result, app,
2246                                         function_name, (gpointer)adv_handle);
2247                 }
2248                 break;
2249         }
2250         case BT_GET_SCAN_RESPONSE_DATA: {
2251                 bluetooth_scan_resp_data_t rsp = { {0} };
2252                 char *app = NULL;
2253                 int length = 0;
2254                 int adv_handle;
2255                 app = (char *)g_dbus_method_invocation_get_sender(context);
2256
2257                 __bt_service_get_parameters(in_param1, &adv_handle,
2258                                 sizeof(int));
2259
2260                 result = _bt_get_scan_response_data(app, adv_handle, &rsp, &length);
2261                 if (result == BLUETOOTH_ERROR_NONE)
2262                         g_array_append_vals(*out_param1, rsp.data, length);
2263
2264                 break;
2265         }
2266         case BT_GET_ADVERTISING_DATA: {
2267                 bluetooth_advertising_data_t adv = { {0} };
2268                 char *app = NULL;
2269                 int length = 0;
2270                 int adv_handle;
2271                 app = (char *)g_dbus_method_invocation_get_sender(context);
2272
2273                 __bt_service_get_parameters(in_param1, &adv_handle,
2274                                 sizeof(int));
2275
2276                 result = _bt_get_advertising_data(app, adv_handle, &adv, &length);
2277                 if (result == BLUETOOTH_ERROR_NONE)
2278                         g_array_append_vals(*out_param1, adv.data, length);
2279
2280                 break;
2281         }
2282         case BT_GATT_REGISTER_APPLICATION: {
2283                 BT_DBG("Register GATT application:Unhandled!!");
2284                 break;
2285         }
2286         case BT_GATT_SERVER_REGISTER: {
2287                 BT_DBG("GATT Server instance initialization");
2288                 char *app;
2289
2290                 app = (char *)g_dbus_method_invocation_get_sender(context);
2291                 BT_INFO("GATT Server Unique Name [%s]", app);
2292
2293                 /* No ADV handle: Set 0 */
2294                 result = _bt_register_server_instance(app, 0);
2295                 BT_INFO("GATT Server: Register Server result [%d]", result);
2296
2297                 if (result != BLUETOOTH_ERROR_NONE) {
2298                         BT_ERR("GATT Server registration failed!!");
2299                 } else {
2300                         _bt_save_invocation_context(context, result, app,
2301                                         function_name, NULL);
2302                 }
2303                 break;
2304         }
2305         case BT_GATT_SERVER_DEREGISTER: {
2306                 char *app;
2307                 app = (char*)g_dbus_method_invocation_get_sender(context);
2308
2309                 result = _bt_unregister_server_instance(app, 0/* Adv Handle*/);
2310                 break;
2311         }
2312         case BT_GATT_SERVER_ADD_SERVICE: {
2313                 BT_DBG("GATT Server Add Service");
2314                 int service_type;
2315                 int num_handles;
2316                 char *svc_uuid;
2317                 int instance_id;
2318                 char *app;
2319                 int *tmp_inst_id = NULL;
2320
2321                 app = (char *)g_dbus_method_invocation_get_sender(context);
2322
2323                 __bt_service_get_parameters(in_param1, &service_type,
2324                                 sizeof(int));
2325                 __bt_service_get_parameters(in_param2, &num_handles,
2326                                 sizeof(int));
2327                 svc_uuid = (char *)g_variant_get_data(in_param3);
2328                 __bt_service_get_parameters(in_param4, &instance_id,
2329                                 sizeof(int));
2330
2331                 BT_INFO("GATT Server Service UUID [%s]", svc_uuid);
2332                 result = _bt_gatt_server_add_service(app, service_type, num_handles, svc_uuid, instance_id);
2333                 if (result != BLUETOOTH_ERROR_NONE) {
2334                         BT_ERR("GATT Server Add Service failed!!");
2335                 } else {
2336                         tmp_inst_id = g_malloc0(sizeof(int));
2337                         *tmp_inst_id = instance_id;
2338                         BT_INFO("GATT Server: Save Instance ID in request Inst id [%d] request_id [%d]",
2339                                         *tmp_inst_id, instance_id);
2340                         _bt_save_invocation_context(context, result, app,
2341                                         function_name, (gpointer)tmp_inst_id);
2342                 }
2343                 break;
2344         }
2345         case BT_GATT_SERVER_ADD_CHARACTERISTIC: {
2346                 BT_DBG("GATT Server Add Characteristic");
2347                 char *char_uuid;
2348                 char *app;
2349                 int *tmp_inst_id = NULL;
2350                 bluetooth_gatt_server_attribute_params_t param;
2351                 memset(&param, 0, sizeof(bluetooth_gatt_server_attribute_params_t));
2352
2353                 app = (char*)g_dbus_method_invocation_get_sender(context);
2354
2355                 __bt_service_get_parameters(in_param1, &param,
2356                                 sizeof(bluetooth_gatt_server_attribute_params_t));
2357                 char_uuid = (char *)g_variant_get_data(in_param2);
2358
2359                 BT_INFO("GATT Server Characteristic UUID [%s]", char_uuid);
2360
2361                 result = _bt_gatt_server_add_characteristic(app, char_uuid, &param);
2362                 if (result != BLUETOOTH_ERROR_NONE) {
2363                         BT_ERR("GATT Server Add Service failed!!");
2364                 } else {
2365                         tmp_inst_id = g_malloc0(sizeof(int));
2366                         *tmp_inst_id = param.instance_id;
2367                         BT_INFO("GATT Server: Save Instance ID in request Inst id [%d] request_id [%d]",
2368                                         *tmp_inst_id, param.instance_id);
2369                         _bt_save_invocation_context(context, result, app,
2370                                         function_name, (gpointer)tmp_inst_id);
2371                 }
2372                 break;
2373         }
2374         case BT_GATT_SERVER_ADD_DESCRIPTOR: {
2375                 BT_DBG("GATT Server Add Descriptor");
2376                 char *desc_uuid;
2377                 int instance_id;
2378                 int service_handle;
2379                 bt_gatt_permission_t perm;
2380                 char *app;
2381                 int *tmp_inst_id = NULL;
2382                 memset(&perm, 0, sizeof(bt_gatt_permission_t));
2383
2384                 app = (char *)g_dbus_method_invocation_get_sender(context);
2385
2386                 __bt_service_get_parameters(in_param1, &service_handle,
2387                                 sizeof(int));
2388                 __bt_service_get_parameters(in_param2, &instance_id,
2389                                 sizeof(int));
2390                 desc_uuid = (char *)g_variant_get_data(in_param4);
2391                 __bt_service_get_parameters(in_param3, &perm,
2392                                 sizeof(bt_gatt_permission_t));
2393
2394                 BT_INFO("GATT Server Descriptor UUID [%s]", desc_uuid);
2395
2396                 result = _bt_gatt_server_add_descriptor(app, desc_uuid, &perm, service_handle, instance_id);
2397                 if (result != BLUETOOTH_ERROR_NONE) {
2398                         BT_ERR("GATT Server Add Service failed!!");
2399                 } else {
2400                         tmp_inst_id = g_malloc0(sizeof(int));
2401                         *tmp_inst_id = instance_id;
2402                         BT_INFO("GATT Server: Save Instance ID in request Inst id [%d] request_id [%d]",
2403                                         *tmp_inst_id, instance_id);
2404                         _bt_save_invocation_context(context, result, app,
2405                                         function_name, (gpointer)tmp_inst_id);
2406                 }
2407                 break;
2408         }
2409         case BT_GATT_SERVER_START_SERVICE: {
2410                 int service_handle;
2411                 int instance_id;
2412
2413                 char *app;
2414                 int *tmp_inst_id = NULL;
2415                 app = (char*)g_dbus_method_invocation_get_sender(context);
2416
2417                 __bt_service_get_parameters(in_param1, &service_handle,
2418                                 sizeof(int));
2419                 __bt_service_get_parameters(in_param2, &instance_id,
2420                                 sizeof(int));
2421
2422                 result = _bt_gatt_server_start_service(app, service_handle, instance_id);
2423
2424                 if (BLUETOOTH_ERROR_NONE == result) {
2425                         tmp_inst_id = g_malloc0(sizeof(int));
2426                         *tmp_inst_id = instance_id;
2427                         BT_INFO("GATT Server: Save Instance ID in request Inst id [%d] request_id [%d]",
2428                                         *tmp_inst_id, instance_id);
2429                         _bt_save_invocation_context(context, result, app,
2430                                         function_name, (gpointer)tmp_inst_id);
2431                 }
2432                 break;
2433         }
2434         case BT_GATT_SERVER_STOP_SERVICE: {
2435                 int service_handle;
2436                 int instance_id;
2437                 char *app;
2438                 int *tmp_inst_id = NULL;
2439                 app = (char*)g_dbus_method_invocation_get_sender(context);
2440
2441                 __bt_service_get_parameters(in_param1, &service_handle,
2442                                 sizeof(int));
2443                 __bt_service_get_parameters(in_param2, &instance_id,
2444                                 sizeof(int));
2445
2446                 result = _bt_gatt_server_stop_service(app, service_handle, instance_id);
2447
2448                 if (BLUETOOTH_ERROR_NONE == result) {
2449                         tmp_inst_id = g_malloc0(sizeof(int));
2450                         *tmp_inst_id = instance_id;
2451                         BT_INFO("GATT Server: Save Instance ID in request Inst id [%d] request_id [%d]",
2452                                         *tmp_inst_id, instance_id);
2453                         _bt_save_invocation_context(context, result, app,
2454                                         function_name, (gpointer)tmp_inst_id);
2455                 }
2456                 break;
2457         }
2458         case BT_GATT_SERVER_DELETE_SERVICE: {
2459                 int service_handle;
2460                 int instance_id;
2461                 int *tmp_inst_id = NULL;
2462                 char *app;
2463                 app = (char*)g_dbus_method_invocation_get_sender(context);
2464
2465                 __bt_service_get_parameters(in_param1, &service_handle,
2466                                 sizeof(int));
2467                 __bt_service_get_parameters(in_param2, &instance_id,
2468                                 sizeof(int));
2469
2470                 result = _bt_gatt_server_delete_service(app, service_handle, instance_id);
2471
2472                 if (BLUETOOTH_ERROR_NONE == result) {
2473                         tmp_inst_id = g_malloc0(sizeof(int));
2474                         *tmp_inst_id = instance_id;
2475                         BT_INFO("GATT Server: Save Instance ID in request Inst id [%d] request_id [%d]",
2476                                         *tmp_inst_id, instance_id);
2477                         _bt_save_invocation_context(context, result, app,
2478                                         function_name, (gpointer)tmp_inst_id);
2479                 }
2480                 break;
2481         }
2482         case BT_GATT_SERVER_SEND_RESPONSE: {
2483                 bluetooth_gatt_server_response_params_t param;
2484                 bluetooth_gatt_att_data_t data;
2485                 char *app;
2486
2487                 memset(&param, 0x00, sizeof(bluetooth_gatt_server_response_params_t));
2488                 memset(&data, 0x00, sizeof(bluetooth_gatt_att_data_t));
2489
2490                 app = (char*)g_dbus_method_invocation_get_sender(context);
2491
2492                 __bt_service_get_parameters(in_param1, &data,
2493                                 sizeof(bluetooth_gatt_att_data_t));
2494                 __bt_service_get_parameters(in_param2, &param,
2495                                 sizeof(bluetooth_gatt_server_response_params_t));
2496
2497                 result = _bt_gatt_server_send_response(app, &data, &param);
2498
2499                 break;
2500         }
2501         case BT_GATT_SERVER_ACQURE_WRITE_RESPONSE: {
2502
2503                 bluetooth_gatt_server_acquire_response_params_t param;
2504                 char *app;
2505                 GDBusMessage *msg;
2506                 msg = g_dbus_method_invocation_get_message(context);
2507                 GUnixFDList *fd_list;
2508                 int fd  = -1;;
2509                 int *fd_list_array;
2510                 int len;
2511
2512                 BT_ERR("sending acquire write  respose \n");
2513
2514                 fd_list = g_dbus_message_get_unix_fd_list(msg);
2515
2516                 memset(&param, 0x00, sizeof(bluetooth_gatt_server_acquire_response_params_t));
2517
2518                 app = (char*)g_dbus_method_invocation_get_sender(context);
2519
2520                 __bt_service_get_parameters(in_param1, &param,
2521                                 sizeof(bluetooth_gatt_server_acquire_response_params_t));
2522
2523                 BT_ERR("sending acquire write  respose sent \n  ");
2524
2525                 fd_list_array = (int *)g_unix_fd_list_peek_fds(fd_list, &len);
2526                 BT_INFO("Num fds in fd_list is : %d, fd_list[0]: %d", len, fd_list_array[0]);
2527                 fd = fd_list_array[0];
2528
2529                 param.fd = fd;
2530                 result = _bt_gatt_server_acquire_send_response(app, &param, fd_list);
2531
2532                 break;
2533         }
2534         case BT_GATT_SERVER_ACQUIRE_NOTIFY_RESPONSE: {
2535
2536                 bluetooth_gatt_server_acquire_response_params_t param;
2537                 char *app;
2538                 GDBusMessage *msg;
2539                 msg = g_dbus_method_invocation_get_message(context);
2540                 GUnixFDList *fd_list;
2541                 int fd  = -1;
2542                 int *fd_list_array;
2543                 int len;
2544
2545                 BT_ERR("sending acquire write  respose \n");
2546
2547                 fd_list = g_dbus_message_get_unix_fd_list(msg);
2548
2549                 memset(&param, 0x00, sizeof(bluetooth_gatt_server_acquire_response_params_t));
2550
2551                 app = (char*)g_dbus_method_invocation_get_sender(context);
2552
2553                 __bt_service_get_parameters(in_param1, &param,
2554                                 sizeof(bluetooth_gatt_server_acquire_response_params_t));
2555
2556                 BT_ERR("sending acquire write  respose sent \n  ");
2557
2558                 fd_list_array = (int *)g_unix_fd_list_peek_fds(fd_list, &len);
2559                 BT_INFO("Num fds in fd_list is : %d, fd_list[0]: %d", len, fd_list_array[0]);
2560                 fd = fd_list_array[0];
2561
2562                 param.fd = fd;
2563                 result = _bt_gatt_server_acquire_send_response(app, &param, fd_list);
2564
2565                 break;
2566         }
2567         case BT_GATT_SERVER_SEND_INDICATION: {
2568                 bluetooth_gatt_server_indication_params_t param;
2569                 bluetooth_gatt_att_data_t data;
2570                 bluetooth_device_address_t address;
2571
2572                 char *app;
2573                 app = (char*)g_dbus_method_invocation_get_sender(context);
2574
2575                 memset(&param, 0x00, sizeof(bluetooth_gatt_server_indication_params_t));
2576                 memset(&data, 0x00, sizeof(bluetooth_gatt_att_data_t));
2577                 memset(&address, 0x00, sizeof(bluetooth_device_address_t));
2578
2579                 __bt_service_get_parameters(in_param1, &data,
2580                                 sizeof(bluetooth_gatt_att_data_t));
2581                 __bt_service_get_parameters(in_param2, &param,
2582                                 sizeof(bluetooth_gatt_server_indication_params_t));
2583                 __bt_service_get_parameters(in_param3, &address,
2584                                 sizeof(bluetooth_device_address_t));
2585
2586                 result = _bt_gatt_server_send_indication(app, &address, &data, &param);
2587
2588                 break;
2589         }
2590         case BT_GATT_SERVER_UPDATE_VALUE: {
2591                 bluetooth_gatt_server_update_value_t param;
2592                 int instance_id;
2593                 char *app;
2594
2595                 memset(&param, 0x00, sizeof(bluetooth_gatt_server_update_value_t));
2596
2597                 app = (char*)g_dbus_method_invocation_get_sender(context);
2598
2599                 __bt_service_get_parameters(in_param1, &instance_id,
2600                                 sizeof(int));
2601                 __bt_service_get_parameters(in_param2, &param,
2602                                 sizeof(bluetooth_gatt_server_update_value_t));
2603
2604                 result = _bt_gatt_server_update_attribute_value(app, instance_id, &param);
2605                 break;
2606         }
2607         case BT_GET_ATT_MTU: {
2608                 bluetooth_device_address_t address = { {0} };
2609                 unsigned int mtu = 0;
2610
2611                 __bt_service_get_parameters(in_param1,
2612                                 &address, sizeof(bluetooth_device_address_t));
2613                 result = _bt_get_att_mtu(&address, &mtu);
2614                 BT_DBG("MTU: %d", mtu);
2615
2616                 if (result == BLUETOOTH_ERROR_NONE) {
2617                         g_array_append_vals(*out_param1, &mtu,
2618                                         sizeof(unsigned int));
2619                 }
2620                 break;
2621         }
2622         case BT_SET_LE_STATIC_RANDOM_ADDRESS: {
2623                 gboolean is_enable;
2624
2625                 __bt_service_get_parameters(in_param1, &is_enable,
2626                                 sizeof(gboolean));
2627
2628                 result = _bt_set_le_static_random_address(is_enable);
2629
2630                 break;
2631         }
2632 #ifdef TIZEN_GATT_CLIENT
2633         /* Local Async */
2634         case BT_GATT_CLIENT_REGISTER: {
2635                 bluetooth_device_address_t address = { {0} };
2636                 char *addr;
2637
2638                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2639
2640                 __bt_service_get_parameters(in_param1,
2641                                 &address, sizeof(bluetooth_device_address_t));
2642
2643                 result = _bt_register_gatt_client_instance(sender, &address);
2644                 if (BLUETOOTH_ERROR_NONE == result) {
2645                         addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
2646
2647                         _bt_convert_addr_type_to_string(addr, address.addr);
2648                         BT_INFO("GATT Client: Save Invocation data GATT CLient Register app[%s] address [%s]", sender, addr);
2649
2650                         /* Save the informations to invocation */
2651                         _bt_save_invocation_context(context, result, sender,
2652                                         function_name, (gpointer)addr);
2653                 }
2654                 break;
2655         }
2656         /* Sync */
2657         case BT_GATT_CLIENT_UNREGISTER: {
2658                 int client_id;
2659
2660                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2661                 __bt_service_get_parameters(in_param1,
2662                                 &client_id, sizeof(int));
2663
2664                 result = _bt_unregister_gatt_client_instance(sender, client_id);
2665                 break;
2666         }
2667
2668         /* Async: Remote Interaction  */
2669         case BT_GATT_ACQUIRE_WRITE: {
2670
2671                 int fd = -1;
2672                 int mtu = -1;
2673                 bluetooth_gatt_client_char_prop_info_t param;
2674
2675                 BT_INFO("GATT Client ACQUIRE WRITE recived");
2676
2677                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2678
2679                 __bt_service_get_parameters(in_param1, &param,
2680                                         sizeof(bluetooth_gatt_client_char_prop_info_t));
2681
2682
2683                 result   = _bt_gatt_acquire_write(&param , &fd, &mtu);
2684
2685                 g_array_append_vals(*out_param1, &mtu, sizeof(int));
2686
2687                 if (BLUETOOTH_ERROR_NONE == result)
2688                         BT_INFO("GATT Client: Save Invocation data for characteristic props app[%s] fd[ %d]", sender, fd);
2689                 else {
2690                         BT_ERR("Gatt Client Acqure Write");
2691                         break;
2692                 }
2693
2694                 GUnixFDList *fd_list = NULL;
2695                 GError *error = NULL;
2696
2697                 /* Add socket fd to unix_fd_list */
2698                 fd_list = g_unix_fd_list_new();
2699                 g_unix_fd_list_append(fd_list, fd, &error);
2700                 g_assert_no_error(error);
2701
2702                 _bt_service_method_return_with_unix_fd_list(
2703                                 context, *out_param1, result, fd_list);
2704
2705                 close(fd);
2706                 g_object_unref(fd_list);
2707
2708                 break;
2709         }
2710         /* Async: Remote Interaction  */
2711         case BT_CONNECT_LE: {
2712                 bluetooth_device_address_t address = { {0} };
2713                 gboolean auto_connect;
2714                 char *addr;
2715                 int client_id;
2716
2717                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2718
2719                 __bt_service_get_parameters(in_param1,
2720                                 &address, sizeof(bluetooth_device_address_t));
2721                 __bt_service_get_parameters(in_param2,
2722                                 &auto_connect, sizeof(gboolean));
2723                 __bt_service_get_parameters(in_param3,
2724                                 &client_id, sizeof(int));
2725
2726                 BT_INFO("GATT Client: client_id[%d]", client_id);
2727                 result = _bt_connect_le_device(&address, auto_connect, client_id);
2728                 if (BLUETOOTH_ERROR_NONE == result) {
2729
2730                         addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
2731                         BT_INFO("GATT Client: Save Invocation data Connect LE app[%s]", sender);
2732
2733                         _bt_convert_addr_type_to_string(addr, address.addr);
2734
2735                         /* Save the informations to invocation */
2736                         _bt_save_invocation_context(context, result, sender,
2737                                         function_name, (gpointer)addr);
2738                 } else {
2739                         BT_INFO("GATT Client: gatt connect failed");
2740                         g_array_append_vals(*out_param1, &address,
2741                                         sizeof(bluetooth_device_address_t));
2742                 }
2743                 break;
2744         }
2745         /* Async: Remote Interaction  */
2746         case BT_DISCONNECT_LE: {
2747                 bluetooth_device_address_t address = { {0} };
2748                 char *addr;
2749                 int client_id;
2750
2751                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2752
2753                 __bt_service_get_parameters(in_param1,
2754                                 &address, sizeof(bluetooth_device_address_t));
2755                 __bt_service_get_parameters(in_param2,
2756                                 &client_id, sizeof(int));
2757
2758                 BT_INFO("GATT Disconnect using client Interface [%d]", client_id);
2759                 result = _bt_disconnect_le_device(&address, client_id);
2760                 if (BLUETOOTH_ERROR_NONE == result) {
2761                         addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
2762                         BT_INFO("GATT Client: Save Invocation data DisConnect LE app[%s]", sender);
2763
2764                         _bt_convert_addr_type_to_string(addr, address.addr);
2765
2766                         /* Save the informations to invocation */
2767                         _bt_save_invocation_context(context, result, sender,
2768                                         function_name, (gpointer)addr);
2769                 } else {
2770                         g_array_append_vals(*out_param1, &address,
2771                                         sizeof(bluetooth_device_address_t));
2772                 }
2773                 break;
2774         }
2775         case BT_GATT_GET_PRIMARY_SERVICES: {
2776                 char *addr;
2777
2778                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2779                 bluetooth_device_address_t address = { {0} };
2780
2781                 __bt_service_get_parameters(in_param1, &address,
2782                                 sizeof(bluetooth_device_address_t));
2783
2784                 addr = g_malloc0(sizeof(char) * BT_ADDRESS_STRING_SIZE);
2785                 _bt_convert_addr_type_to_string(addr, address.addr);
2786
2787                 result = _bt_gatt_get_primary_services(addr);
2788                 if (BLUETOOTH_ERROR_NONE == result) {
2789                         BT_INFO("GATT Client: Save Remote GATT Server address addr [%s] app[%s]",
2790                                         addr, sender);
2791                         _bt_save_invocation_context(context, result, sender,
2792                                         function_name, (gpointer)addr);
2793                 } else
2794                         g_free(addr);
2795                 break;
2796         }
2797         /* Local Async */
2798         case BT_GATT_GET_SERVICE_PROPERTIES: {
2799                 bluetooth_gatt_client_svc_prop_info_t param;
2800
2801                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2802                 memset(&param, 0x00, sizeof(bluetooth_gatt_client_svc_prop_info_t));
2803
2804                 __bt_service_get_parameters(in_param1, &param,
2805                                 sizeof(bluetooth_gatt_client_svc_prop_info_t));
2806
2807                 result = _bt_gatt_get_all_characteristic(&param);
2808                 if (BLUETOOTH_ERROR_NONE == result) {
2809                         BT_INFO("GATT Client: Save Invocation data for Service props app[%s]", sender);
2810
2811                         /* Save the informations to invocation */
2812                         _bt_save_invocation_context(context, result, sender,
2813                                         function_name,
2814                                         (gpointer)g_memdup(&param, sizeof(bluetooth_gatt_client_svc_prop_info_t)));
2815                 }
2816                 break;
2817         }
2818         case BT_GATT_GET_CHARACTERISTIC_PROPERTIES: {
2819                 bluetooth_gatt_client_char_prop_info_t param;
2820
2821                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2822                 memset(&param, 0x00, sizeof(bluetooth_gatt_client_char_prop_info_t));
2823
2824                 __bt_service_get_parameters(in_param1, &param,
2825                                 sizeof(bluetooth_gatt_client_char_prop_info_t));
2826
2827                 result = _bt_gatt_get_all_characteristic_properties(&param);
2828                 if (BLUETOOTH_ERROR_NONE == result) {
2829                         BT_INFO("GATT Client: Save Invocation data for characteristic props app[%s]", sender);
2830
2831                         /* Save the informations to invocation */
2832                         _bt_save_invocation_context(context, result, sender,
2833                                         function_name,
2834                                         (gpointer)g_memdup(&param, sizeof(bluetooth_gatt_client_char_prop_info_t)));
2835                 }
2836                 break;
2837         }
2838         /* Async: Remote Interaction  */
2839         case BT_GATT_READ_CHARACTERISTIC: {
2840                 bluetooth_gatt_client_char_prop_info_t param;
2841
2842                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2843                 memset(&param, 0x00, sizeof(bluetooth_gatt_client_char_prop_info_t));
2844
2845                 __bt_service_get_parameters(in_param1, &param,
2846                                 sizeof(bluetooth_gatt_client_char_prop_info_t));
2847
2848                 result = _bt_gatt_read_characteristic_value(&param);
2849                 if (BLUETOOTH_ERROR_NONE == result) {
2850                         BT_INFO("GATT Client: Save Invocation data for characteristic props app[%s]", sender);
2851
2852                         /* Save the informations to invocation */
2853                         _bt_save_invocation_context(context, result, sender,
2854                                         function_name,
2855                                         (gpointer)g_memdup(&param, sizeof(bluetooth_gatt_client_char_prop_info_t)));
2856                 }
2857                 break;
2858         }
2859         /* Async: Remote Interaction  */
2860         case BT_GATT_READ_DESCRIPTOR_VALUE: {
2861                 bluetooth_gatt_client_desc_prop_info_t param;
2862
2863                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2864                 memset(&param, 0x00, sizeof(bluetooth_gatt_client_desc_prop_info_t));
2865
2866                 __bt_service_get_parameters(in_param1, &param,
2867                                 sizeof(bluetooth_gatt_client_desc_prop_info_t));
2868
2869                 result = _bt_gatt_read_descriptor_value(&param);
2870                 if (BLUETOOTH_ERROR_NONE == result) {
2871                         BT_INFO("GATT Client: Save Invocation data for Descriptor's props app[%s]", sender);
2872
2873                         /* Save the informations to invocation */
2874                         _bt_save_invocation_context(context, result, sender,
2875                                         function_name,
2876                                         (gpointer)g_memdup(&param, sizeof(bluetooth_gatt_client_desc_prop_info_t)));
2877                 }
2878                 break;
2879         }
2880         /* Async: Remote Interaction  */
2881         case BT_GATT_WRITE_CHARACTERISTIC_VALUE_BY_TYPE: {
2882                 bluetooth_gatt_client_char_prop_info_t param;
2883                 bluetooth_gatt_att_data_t data;
2884                 bluetooth_gatt_write_type_e write_type;
2885
2886                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2887
2888                 memset(&data, 0x00, sizeof(bluetooth_gatt_att_data_t));
2889                 memset(&param, 0x00, sizeof(bluetooth_gatt_client_char_prop_info_t));
2890
2891                 __bt_service_get_parameters(in_param1, &param,
2892                                 sizeof(bluetooth_gatt_client_char_prop_info_t));
2893                 __bt_service_get_parameters(in_param2, &data,
2894                                 sizeof(bluetooth_gatt_att_data_t));
2895                 __bt_service_get_parameters(in_param3, &write_type,
2896                                 sizeof(bluetooth_gatt_write_type_e));
2897
2898                 result = _bt_gatt_write_characteristic_value_by_type(&param , &data, write_type);
2899                 if (BLUETOOTH_ERROR_NONE == result) {
2900                         BT_INFO("GATT Client: Save Invocation data for characteristic props app[%s]", sender);
2901
2902                         /* Save the informations to invocation */
2903                         _bt_save_invocation_context(context, result, sender,
2904                                         function_name,
2905                                         (gpointer)g_memdup(&param, sizeof(bluetooth_gatt_client_char_prop_info_t)));
2906                 }
2907                 break;
2908         }
2909         /* Async: Remote Interaction  */
2910         case BT_GATT_WRITE_DESCRIPTOR_VALUE: {
2911                 bluetooth_gatt_client_desc_prop_info_t param;
2912                 bluetooth_gatt_att_data_t data;
2913                 bluetooth_gatt_write_type_e write_type;
2914
2915                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2916                 memset(&data, 0x00, sizeof(bluetooth_gatt_att_data_t));
2917                 memset(&param, 0x00, sizeof(bluetooth_gatt_client_desc_prop_info_t));
2918
2919                 __bt_service_get_parameters(in_param1, &param,
2920                                 sizeof(bluetooth_gatt_client_desc_prop_info_t));
2921                 __bt_service_get_parameters(in_param2, &data,
2922                                 sizeof(bluetooth_gatt_att_data_t));
2923                 __bt_service_get_parameters(in_param3, &write_type,
2924                                 sizeof(bluetooth_gatt_write_type_e));
2925
2926                 result = _bt_gatt_write_descriptor_value_by_type(&param, &data, write_type);
2927                 if (BLUETOOTH_ERROR_NONE == result) {
2928                         BT_INFO("GATT Client: Save Invocation data for descriptor props app[%s]", sender);
2929
2930                         /* Save the informations to invocation */
2931                         _bt_save_invocation_context(context, result, sender,
2932                                         function_name,
2933                                         (gpointer)g_memdup(&param, sizeof(bluetooth_gatt_client_desc_prop_info_t)));
2934                 }
2935                 break;
2936         }
2937         /* Local Async */
2938         case BT_GATT_WATCH_CHARACTERISTIC: {
2939                 bluetooth_gatt_client_char_prop_info_t param;
2940                 int client_id;
2941                 gboolean is_notify;
2942                 int fd = -1;
2943                 int mtu = 0;
2944                 gboolean is_indicate;
2945
2946
2947                 memset(&param, 0x00, sizeof(bluetooth_gatt_client_char_prop_info_t));
2948
2949                 sender = (char*)g_dbus_method_invocation_get_sender(context);
2950
2951                 __bt_service_get_parameters(in_param1, &param,
2952                                 sizeof(bluetooth_gatt_client_char_prop_info_t));
2953                 __bt_service_get_parameters(in_param2, &client_id,
2954                                 sizeof(int));
2955                 __bt_service_get_parameters(in_param3, &is_notify,
2956                                 sizeof(gboolean));
2957                 __bt_service_get_parameters(in_param4, &is_indicate,
2958                                 sizeof(gboolean));
2959
2960 #ifdef TIZEN_FEATURE_BT_GATT_CLIENT_FD_DISABLE
2961                 goto normal;
2962 #endif
2963
2964                 if (is_indicate == false) {
2965                         result   = _bt_gatt_acquire_notify(&param , &fd, &mtu);
2966                         if (BLUETOOTH_ERROR_NONE == result && fd > -1) {
2967                                 BT_INFO("GATT Client: Save Invocation data for characteristic props app[%s] fd[ %d]", sender, fd);
2968
2969                                 GUnixFDList *fd_list = NULL;
2970                                 GError *error = NULL;
2971
2972                                 g_array_append_vals(*out_param1, &mtu, sizeof(int));
2973                                 /* Add socket fd to unix_fd_list */
2974                                 fd_list = g_unix_fd_list_new();
2975                                 g_unix_fd_list_append(fd_list, fd, &error);
2976                                 g_assert_no_error(error);
2977                                 close(fd);
2978                                 _bt_service_method_return_with_unix_fd_list(
2979                                 context, *out_param1, result, fd_list);
2980
2981                                 g_object_unref(fd_list);
2982                         } else
2983                                 goto normal;
2984                 } else {
2985
2986 normal:
2987                         result = _bt_gatt_watch_characteristic(&param , client_id, is_notify);
2988                         if (BLUETOOTH_ERROR_NONE == result) {
2989                                 BT_INFO("GATT Client: Save Invocation data for characteristic props app[%s]", sender);
2990
2991                                 /* Save the informations to invocation */
2992                                 _bt_save_invocation_context(context, result, sender, function_name,
2993                                          (gpointer)g_memdup(&param, sizeof(bluetooth_gatt_client_char_prop_info_t)));
2994                         }
2995                 }
2996                 break;
2997         }
2998         case BT_GATT_WATCH_SERVICE_CHANGED_INDICATION: {
2999                 gboolean is_enabled;
3000                 bluetooth_device_address_t address;
3001
3002                 sender = (char*)g_dbus_method_invocation_get_sender(context);
3003
3004                 __bt_service_get_parameters(in_param1,
3005                                 &address, sizeof(bluetooth_device_address_t));
3006                 __bt_service_get_parameters(in_param2, &is_enabled,
3007                                 sizeof(gboolean));
3008                 result = _bt_gatt_watch_service_changed_indication(sender, &address, is_enabled);
3009                 BT_INFO("Service changed indication from app [%s]", sender);
3010
3011                 break;
3012         }
3013         case BT_LE_CONN_UPDATE: {
3014                 char *sender = NULL;
3015                 bluetooth_device_address_t local_address = { {0} };
3016                 bluetooth_le_connection_param_t parameters = {0};
3017
3018                 sender = (char *)g_dbus_method_invocation_get_sender(context);
3019
3020                 __bt_service_get_parameters(in_param1, &local_address,
3021                                 sizeof(bluetooth_device_address_t));
3022                 __bt_service_get_parameters(in_param2, &parameters,
3023                                 sizeof(bluetooth_le_connection_param_t));
3024
3025                 result = _bt_le_connection_update(sender,
3026                                         local_address.addr,
3027                                         parameters.interval_min,
3028                                         parameters.interval_max,
3029                                         parameters.latency,
3030                                         parameters.timeout);
3031                 break;
3032         }
3033 #endif
3034         case BT_START_LE_DISCOVERY: {
3035                 sender = (char *)g_dbus_method_invocation_get_sender(context);
3036                 result = _bt_start_le_scan(sender);
3037                 if (result == BLUETOOTH_ERROR_NONE) {
3038                         _bt_save_invocation_context(context, result, sender,
3039                                         function_name, NULL);
3040                 }
3041                 break;
3042         }
3043         case BT_STOP_LE_DISCOVERY: {
3044                 sender = (char *)g_dbus_method_invocation_get_sender(context);
3045                 result = _bt_stop_le_scan(sender);
3046                 if (result == BLUETOOTH_ERROR_NONE) {
3047                         _bt_save_invocation_context(context, result, sender,
3048                                         function_name, NULL);
3049                 }
3050                 break;
3051         }
3052         case BT_IS_LE_DISCOVERYING: {
3053                 gboolean le_discovering = FALSE;
3054
3055                 le_discovering = _bt_is_le_scanning();
3056                 g_array_append_vals(*out_param1,
3057                                 &le_discovering, sizeof(gboolean));
3058                 break;
3059         }
3060         case BT_SET_SCAN_PARAMETERS: {
3061                 bluetooth_le_scan_params_t scan_params;
3062                 __bt_service_get_parameters(in_param1, &scan_params,
3063                                 sizeof(bluetooth_le_scan_params_t));
3064
3065                 BT_DBG("bluetooth_le_scan_params_t [%f %f %d]",
3066                                 scan_params.interval, scan_params.window,
3067                                 scan_params.type);
3068
3069                 result = _bt_prepare_scan_parameters(&scan_params, 0);
3070                 break;
3071         }
3072         case BT_SET_SCAN_TYPE: {
3073                 int scan_type = 0;
3074                 __bt_service_get_parameters(in_param1, &scan_type, sizeof(int));
3075
3076                 BT_DBG("bluetooth_le_scan_type [%d]", scan_type);
3077                 result = _bt_prepare_scan_parameters(NULL, scan_type);
3078                 break;
3079         }
3080 #ifdef TIZEN_FEATURE_BT_PAN_NAP
3081         case BT_NETWORK_ACTIVATE:
3082                 BT_DBG("BT_NETWORK_ACTIVATE Request recieved Request Handler ");
3083                 result = _bt_network_activate();
3084                 break;
3085         case BT_NETWORK_DEACTIVATE:
3086                 result = _bt_network_deactivate();
3087                 break;
3088         case BT_NETWORK_CONNECT: {
3089                 bluetooth_device_address_t address = { {0} };
3090                 int role;
3091
3092                 __bt_service_get_parameters(in_param1,
3093                                 &address, sizeof(bluetooth_device_address_t));
3094                 __bt_service_get_parameters(in_param2,
3095                                 &role, sizeof(int));
3096
3097                 result = _bt_network_connect(request_id, role, &address);
3098                 if (result != BLUETOOTH_ERROR_NONE) {
3099                         g_array_append_vals(*out_param1, &address,
3100                                         sizeof(bluetooth_device_address_t));
3101                 }
3102                 break;
3103         }
3104         case BT_NETWORK_DISCONNECT: {
3105                 bluetooth_device_address_t address = { {0} };
3106
3107                 __bt_service_get_parameters(in_param1,
3108                                 &address, sizeof(bluetooth_device_address_t));
3109
3110                 result = _bt_network_disconnect(request_id, &address);
3111                 if (result != BLUETOOTH_ERROR_NONE) {
3112                         g_array_append_vals(*out_param1, &address,
3113                                         sizeof(bluetooth_device_address_t));
3114                 }
3115                 break;
3116         }
3117         case BT_NETWORK_SERVER_DISCONNECT: {
3118                 bluetooth_device_address_t address = { {0} };
3119
3120                 __bt_service_get_parameters(in_param1,
3121                                 &address, sizeof(bluetooth_device_address_t));
3122
3123                 result = _bt_network_server_disconnect(request_id, &address);
3124                 if (result != BLUETOOTH_ERROR_NONE) {
3125                         g_array_append_vals(*out_param1, &address,
3126                                         sizeof(bluetooth_device_address_t));
3127                 }
3128                 break;
3129         }
3130
3131 #endif
3132 #ifdef TIZEN_FEATURE_BT_IPSP
3133         case BT_LE_IPSP_INIT:
3134                 result = _bt_initialize_ipsp();
3135                 break;
3136         case BT_LE_IPSP_DEINIT:
3137                 result = _bt_deinitialize_ipsp();
3138                 break;
3139         case BT_LE_IPSP_CONNECT: {
3140                 bluetooth_device_address_t address = { {0} };
3141                 __bt_service_get_parameters(in_param1, &address,
3142                                 sizeof(bluetooth_device_address_t));
3143                 result = _bt_connect_le_ipsp_device(&address);
3144                 break;
3145         }
3146         case BT_LE_IPSP_DISCONNECT: {
3147                 bluetooth_device_address_t address = { {0} };
3148                 __bt_service_get_parameters(in_param1, &address,
3149                                 sizeof(bluetooth_device_address_t));
3150                 result = _bt_disconnect_le_ipsp_device(&address);
3151                 break;
3152         }
3153 #endif
3154         case BT_IS_ADVERTISING: {
3155                 gboolean advertising = FALSE;
3156                 advertising = _bt_is_advertising();
3157                 g_array_append_vals(*out_param1, &advertising,
3158                                 sizeof(gboolean));
3159                 break;
3160         }
3161         case BT_IS_LE_2M_PHY_SUPPORTED: {
3162                 gboolean is_2m_phy_supported = FALSE;
3163
3164                 is_2m_phy_supported = _bt_is_le_2m_phy_supported();
3165                 g_array_append_vals(*out_param1, &is_2m_phy_supported, sizeof(gboolean));
3166                 break;
3167         }
3168         case BT_IS_LE_CODED_PHY_SUPPORTED: {
3169                 gboolean is_coded_phy_supported = FALSE;
3170
3171                 is_coded_phy_supported = _bt_is_le_coded_phy_supported();
3172                 g_array_append_vals(*out_param1, &is_coded_phy_supported, sizeof(gboolean));
3173                 break;
3174         }
3175         case BT_DISCONNECT_DEVICE: {
3176                 bluetooth_device_address_t address = { {0} };
3177
3178                 __bt_service_get_parameters(in_param1,
3179                                 &address, sizeof(bluetooth_device_address_t));
3180
3181                 result = _bt_disconnect_device(&address);
3182                 break;
3183         }
3184         case BT_REGISTER_SCAN_FILTER: {
3185                 bluetooth_le_scan_filter_t scan_filter;
3186
3187                 sender = (char*)g_dbus_method_invocation_get_sender(context);
3188                 __bt_service_get_parameters(in_param1, &scan_filter,
3189                                 sizeof(bluetooth_le_scan_filter_t));
3190
3191                 BT_DBG("bluetooth_le_scan_filter_t [features : 0x%.2x]",
3192                                 scan_filter.added_features);
3193
3194                 result = _bt_register_scan_filter(sender, &scan_filter);
3195
3196                 break;
3197         }
3198         default:
3199                 BT_INFO("UnSupported function [%d]", function_name);
3200                 result = BLUETOOTH_ERROR_NOT_SUPPORT;
3201                 break;
3202         }
3203
3204         return result;
3205 }
3206 #ifdef TIZEN_FEATURE_BT_OBEX
3207 /* Function definitions*/
3208 static void __bt_fill_garray_from_variant(GVariant *var, GArray *param)
3209 {
3210         char *data;
3211         int size;
3212
3213         size = g_variant_get_size(var);
3214         if (size > 0) {
3215                 data = (char *)g_variant_get_data(var);
3216                 if (data)
3217                         param = g_array_append_vals(param, data, size);
3218
3219         }
3220 }
3221 #endif
3222
3223 int __bt_obexd_request(int function_name,
3224                 int request_type,
3225                 int request_id,
3226                 GDBusMethodInvocation *context,
3227                 GVariant *in_param1,
3228                 GVariant *in_param2,
3229                 GVariant *in_param3,
3230                 GVariant *in_param4,
3231                 GArray **out_param1)
3232 {
3233         BT_DBG("+");
3234
3235         int result = BLUETOOTH_ERROR_NONE;
3236
3237         BT_DBG("function_name : %x", function_name);
3238
3239         switch (function_name) {
3240         case BT_OPP_PUSH_FILES: {
3241                 BT_DBG("BT_OPP_PUSH_FILES");
3242                 int i;
3243                 bluetooth_device_address_t address = { {0} };
3244                 bt_file_path_t *path;
3245                 char **file_path;
3246                 int file_count;
3247                 GArray *param2;
3248
3249                 __bt_service_get_parameters(in_param1, &address,
3250                                 sizeof(bluetooth_device_address_t));
3251                 __bt_service_get_parameters(in_param3, &file_count,
3252                                 sizeof(int));
3253
3254                 file_path = g_new0(char *, file_count + 1);
3255
3256                 param2 = g_array_new(TRUE, TRUE, sizeof(gchar));
3257                 __bt_fill_garray_from_variant(in_param2, param2);
3258
3259                 for (i = 0; i < file_count; i++) {
3260                         path = &g_array_index(param2, bt_file_path_t, i);
3261                         file_path[i] = g_strdup(path->path);
3262                 }
3263                 BT_DBG("_bt_opp_client_push_files");
3264                 result = _bt_opp_client_push_files(request_id, context,
3265                                                 &address, file_path,
3266                                                 file_count);
3267
3268                 for (i = 0; i < file_count; i++)
3269                         g_free(file_path[i]);
3270
3271                 g_free(file_path);
3272                 g_array_free(param2, TRUE);
3273
3274                 break;
3275         }
3276         case BT_OPP_CANCEL_PUSH: {
3277                 result = _bt_opp_client_cancel_push();
3278
3279                 break;
3280         }
3281         case BT_OPP_IS_PUSHING_FILES: {
3282                 gboolean is_sending = FALSE;
3283
3284                 result = _bt_opp_client_is_sending(&is_sending);
3285
3286                 g_array_append_vals(*out_param1, &is_sending,
3287                                 sizeof(gboolean));
3288                 break;
3289         }
3290         case BT_OPP_GET_TRANSFER_PROGRESS: {
3291                 int direction;
3292                 int transfer_id;
3293                 guint8 progress = 0;
3294
3295                 __bt_service_get_parameters(in_param1, &direction,
3296                                 sizeof(int));
3297                 __bt_service_get_parameters(in_param2, &transfer_id,
3298                                 sizeof(int));
3299                 if (direction)
3300                         result = _bt_opp_get_client_progress(&progress);
3301                 else
3302                         result = _bt_opp_get_server_progress(transfer_id, &progress);
3303
3304                 g_array_append_vals(*out_param1, &progress,
3305                                 sizeof(guint8));
3306
3307                 break;
3308         }
3309
3310         case BT_MAP_CREATE_SESSION: {
3311                 BT_DBG("BT_MAP_CREATE_SESSION");
3312                 char *address = (char *)g_variant_get_data(in_param1);
3313                 char *session_id = NULL;
3314                 result = _bt_create_session_sync(address, &session_id);
3315                 if (result == BLUETOOTH_ERROR_NONE)
3316                         g_array_append_vals(*out_param1, session_id, strlen(session_id)+1);
3317                 break;
3318         }
3319
3320         case BT_MAP_DESTROY_SESSION: {
3321                 BT_DBG("BT_MAP_DESTROY_SESSION");
3322                 char* session_id = (char *)g_variant_get_data(in_param1);
3323                 result = _bt_destroy_session_sync(session_id);
3324                 if (result == BLUETOOTH_ERROR_NONE)
3325                         BT_DBG("successfully destroyed session");
3326                 break;
3327         }
3328
3329         case BT_MAP_SET_FOLDER: {
3330                 BT_DBG("BT_MAP_SET_FOLDER");
3331                 char *session_id = (char *)g_variant_get_data(in_param1);
3332                 char *name = (char *)g_variant_get_data(in_param2);
3333                 result = _bt_map_client_set_folder(session_id, name);
3334                 break;
3335         }
3336
3337         case BT_MAP_LIST_FOLDERS: {
3338                 BT_DBG("BT_MAP_LIST_FOLDERS");
3339
3340                 char* session_id = (char *)g_variant_get_data(in_param1);
3341                 char* filter_serialized = (char*)g_variant_get_data(in_param2);
3342
3343                 result = _bt_map_client_list_folders(request_id, context, session_id, filter_serialized);
3344                 if (result == BLUETOOTH_ERROR_NONE)
3345                         BT_DBG("_bt_map_client_list_folders succeed");
3346
3347                 break;
3348         }
3349
3350         case BT_MAP_LIST_FILTER_FIELDS: {
3351                 BT_DBG("BT_MAP_LIST_FILTER_FIELDS");
3352
3353                 char* session_id = (char *)g_variant_get_data(in_param1);
3354
3355                 result = _bt_map_client_list_filter_fields(request_id, context, session_id);
3356                 if (result == BLUETOOTH_ERROR_NONE)
3357                         BT_DBG("_bt_map_client_list_filter_fields succeed");
3358
3359                 break;
3360         }
3361
3362         case BT_MAP_LIST_MESSAGES: {
3363                 BT_DBG("BT_MAP_LIST_MESSAGES");
3364
3365                 char* session_id = (char*)g_variant_get_data(in_param1);
3366                 char* folder = (char*)g_variant_get_data(in_param2);
3367                 char* filter_serialized = (char*)g_variant_get_data(in_param3);
3368
3369                 result = _bt_map_client_list_messages(request_id, context, session_id, folder, filter_serialized);
3370                 if (result == BLUETOOTH_ERROR_NONE)
3371                         BT_DBG("_bt_map_client_list_messages succeed");
3372                 else
3373                         BT_DBG("_bt_map_client_list_messages failed");
3374
3375                 break;
3376         }
3377
3378         case BT_MAP_UPDATE_INBOX: {
3379                 BT_DBG("BT_MAP_UPDATE_INBOX");
3380                 char* session_id = (char *)g_variant_get_data(in_param1);
3381                 result = _bt_map_client_update_inbox(session_id);
3382                 break;
3383         }
3384
3385         case BT_MAP_PUSH_MESSAGE: {
3386                 BT_DBG("BT_MAP_PUSH_MESSAGE");
3387
3388                 char* session_id = (char *)g_variant_get_data(in_param1);
3389                 char* source_file = (char *)g_variant_get_data(in_param2);
3390                 char* folder = (char *)g_variant_get_data(in_param3);
3391                 char* args_serialized = (char *)g_variant_get_data(in_param4);
3392
3393                 result = _bt_map_client_push_message(
3394                                 request_id, context, session_id, source_file, folder, args_serialized);
3395                 if (result == BLUETOOTH_ERROR_NONE)
3396                         BT_DBG("_bt_map_client_push_message succeed");
3397                 else
3398                         BT_ERR("_bt_map_client_push_message failed");
3399
3400                 break;
3401         }
3402
3403         case BT_MAP_GET_MESSAGE: {
3404                 BT_DBG("BT_MAP_GET_MESSAGE");
3405                 // TODO session currently is not used, but should be valid
3406                 //char* session_id = (char *)g_variant_get_data(in_param1);
3407                 char* message_object = (char *)g_variant_get_data(in_param2);
3408                 char* target_file = (char *)g_variant_get_data(in_param3);
3409                 bool attachment = false;
3410                 __bt_service_get_parameters(in_param4, &attachment, sizeof(bool));
3411
3412                 result = _bt_map_client_get_message(request_id, context, message_object,
3413                                 target_file, attachment);
3414                 if (result == BLUETOOTH_ERROR_NONE)
3415                         BT_DBG("_bt_map_client_get_message succeed");
3416
3417                 break;
3418         }
3419
3420         case BT_OBEX_SERVER_ALLOCATE: {
3421                 int app_pid;
3422                 gboolean is_native;
3423                 char *path;
3424                 char *sender;
3425
3426                 sender = (char *)g_dbus_method_invocation_get_sender(context);
3427
3428                 path = (char *)g_variant_get_data(in_param1);
3429                 __bt_service_get_parameters(in_param2, &is_native,
3430                                 sizeof(gboolean));
3431                 __bt_service_get_parameters(in_param3, &app_pid,
3432                                 sizeof(int));
3433
3434                 result = _bt_obex_server_allocate(sender,
3435                                 path, app_pid, is_native);
3436
3437                 break;
3438         }
3439         case BT_OBEX_SERVER_DEALLOCATE: {
3440                 int app_pid;
3441                 gboolean is_native;
3442
3443                 __bt_service_get_parameters(in_param1, &is_native,
3444                                 sizeof(gboolean));
3445                 __bt_service_get_parameters(in_param2, &app_pid,
3446                                 sizeof(int));
3447
3448                 result = _bt_obex_server_deallocate(app_pid, is_native);
3449                 break;
3450         }
3451         case BT_OBEX_SERVER_IS_ACTIVATED: {
3452                 gboolean is_activated = FALSE;
3453
3454                 result = _bt_obex_server_is_activated(&is_activated);
3455
3456                 g_array_append_vals(*out_param1, &is_activated,
3457                                 sizeof(gboolean));
3458
3459                 break;
3460         }
3461         case BT_OBEX_SERVER_ACCEPT_CONNECTION: {
3462                 result = _bt_obex_server_accept_connection(request_id);
3463
3464                 break;
3465         }
3466         case BT_OBEX_SERVER_REJECT_CONNECTION: {
3467                 result = _bt_obex_server_reject_connection();
3468
3469                 break;
3470         }
3471         case BT_OBEX_SERVER_ACCEPT_FILE: {
3472                 char *file_name;
3473
3474                 file_name = (char *)g_variant_get_data(in_param1);
3475
3476                 result = _bt_obex_server_accept_authorize(file_name, TRUE);
3477
3478                 break;
3479         }
3480         case BT_OBEX_SERVER_REJECT_FILE: {
3481                 result = _bt_obex_server_reject_authorize();
3482
3483                 break;
3484         }
3485         case BT_OBEX_SERVER_SET_PATH: {
3486                 gboolean is_native;
3487                 char *destination_path;
3488
3489                 destination_path = (char *)g_variant_get_data(in_param1);
3490                 __bt_service_get_parameters(in_param2, &is_native,
3491                                 sizeof(gboolean));
3492
3493                 result = _bt_obex_server_set_destination_path(destination_path,
3494                                                         is_native);
3495
3496                 break;
3497         }
3498         case BT_OBEX_SERVER_SET_ROOT: {
3499                 char *root;
3500
3501                 root = (char *)g_variant_get_data(in_param1);
3502
3503                 result = _bt_obex_server_set_root(root);
3504
3505                 break;
3506         }
3507         case BT_OBEX_SERVER_CANCEL_TRANSFER: {
3508                 int transfer_id;
3509
3510                 __bt_service_get_parameters(in_param1, &transfer_id,
3511                                 sizeof(int));
3512
3513                 result = _bt_obex_server_cancel_transfer(transfer_id);
3514
3515                 break;
3516         }
3517         case BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS: {
3518                 result = _bt_obex_server_cancel_all_transfers();
3519
3520                 break;
3521         }
3522         case BT_OBEX_SERVER_IS_RECEIVING: {
3523                 gboolean is_receiving = FALSE;
3524
3525                 result = _bt_obex_server_is_receiving(&is_receiving);
3526
3527                 g_array_append_vals(*out_param1, &is_receiving,
3528                                 sizeof(gboolean));
3529                 break;
3530         }
3531         case BT_PBAP_CONNECT: {
3532                 bluetooth_device_address_t address = { {0} };
3533
3534                 __bt_service_get_parameters(in_param1, &address,
3535                                 sizeof(bluetooth_device_address_t));
3536
3537                 result = _bt_pbap_connect(&address);
3538                 break;
3539         }
3540         case BT_PBAP_DISCONNECT: {
3541                 bluetooth_device_address_t address = { {0} };
3542
3543                 __bt_service_get_parameters(in_param1, &address,
3544                                 sizeof(bluetooth_device_address_t));
3545
3546                 result = _bt_pbap_disconnect(&address);
3547                 break;
3548         }
3549         case BT_PBAP_GET_PHONEBOOK_SIZE: {
3550                 bluetooth_device_address_t address = { {0} };
3551                 bt_pbap_folder_t folder = { 0, };
3552
3553                 __bt_service_get_parameters(in_param1, &address,
3554                                 sizeof(bluetooth_device_address_t));
3555                 __bt_service_get_parameters(in_param2, &folder,
3556                                 sizeof(bt_pbap_folder_t));
3557
3558                 result = _bt_pbap_get_phonebook_size(&address,
3559                                 folder.addressbook, folder.folder_type);
3560                 break;
3561         }
3562         case BT_PBAP_GET_PHONEBOOK: {
3563                 bluetooth_device_address_t address = { {0} };
3564                 bt_pbap_folder_t folder = { 0, };
3565                 bt_pbap_pull_parameters_t app_param = { 0, };
3566
3567                 __bt_service_get_parameters(in_param1, &address,
3568                                 sizeof(bluetooth_device_address_t));
3569                 __bt_service_get_parameters(in_param2, &folder,
3570                                 sizeof(bt_pbap_folder_t));
3571                 __bt_service_get_parameters(in_param3, &app_param,
3572                                 sizeof(bt_pbap_pull_parameters_t));
3573
3574                 result = _bt_pbap_get_phonebook(&address, folder.addressbook,
3575                                 folder.folder_type, &app_param);
3576                 break;
3577         }
3578         case BT_PBAP_GET_LIST: {
3579                 bluetooth_device_address_t address = { {0} };
3580                 bt_pbap_folder_t folder = { 0, };
3581                 bt_pbap_list_parameters_t app_param = { 0, };
3582
3583                 __bt_service_get_parameters(in_param1, &address,
3584                                 sizeof(bluetooth_device_address_t));
3585                 __bt_service_get_parameters(in_param2, &folder,
3586                                 sizeof(bt_pbap_folder_t));
3587                 __bt_service_get_parameters(in_param3, &app_param,
3588                                 sizeof(bt_pbap_list_parameters_t));
3589
3590                 result = _bt_pbap_get_list(&address, folder.addressbook,
3591                                 folder.folder_type, &app_param);
3592                 break;
3593         }
3594         case BT_PBAP_PULL_VCARD: {
3595                 bluetooth_device_address_t address = { {0} };
3596                 bt_pbap_folder_t folder = { 0, };
3597                 bt_pbap_pull_vcard_parameters_t app_param = { 0, };
3598
3599                 __bt_service_get_parameters(in_param1, &address,
3600                                 sizeof(bluetooth_device_address_t));
3601                 __bt_service_get_parameters(in_param2, &folder,
3602                                 sizeof(bt_pbap_folder_t));
3603                 __bt_service_get_parameters(in_param3, &app_param,
3604                                 sizeof(bt_pbap_pull_vcard_parameters_t));
3605
3606                 result = _bt_pbap_pull_vcard(&address, folder.addressbook,
3607                                 folder.folder_type, &app_param);
3608                 break;
3609         }
3610         case BT_PBAP_PHONEBOOK_SEARCH: {
3611                 bluetooth_device_address_t address = { {0} };
3612                 bt_pbap_folder_t folder = { 0, };
3613                 bt_pbap_search_parameters_t app_param = { 0, };
3614
3615                 __bt_service_get_parameters(in_param1, &address,
3616                                 sizeof(bluetooth_device_address_t));
3617                 __bt_service_get_parameters(in_param2, &folder,
3618                                 sizeof(bt_pbap_folder_t));
3619                 __bt_service_get_parameters(in_param3, &app_param,
3620                                 sizeof(bt_pbap_search_parameters_t));
3621
3622                 result = _bt_pbap_phonebook_search(&address, folder.addressbook,
3623                                 folder.folder_type, &app_param);
3624                 break;
3625         }
3626
3627         default:
3628                 BT_ERR("Unknown function!");
3629                 result = BLUETOOTH_ERROR_INTERNAL;
3630                 break;
3631         }
3632
3633         FN_END;
3634
3635         return result;
3636 }
3637
3638 int __bt_agent_request(int function_name,
3639                 int request_type,
3640                 int request_id,
3641                 GDBusMethodInvocation *context,
3642                 GVariant *in_param1,
3643                 GVariant *in_param2,
3644                 GVariant *in_param3,
3645                 GVariant *in_param4,
3646                 GArray **out_param1)
3647 {
3648         int result;
3649         switch (function_name) {
3650         case BT_SET_AUTHORIZATION: {
3651                 int type;
3652                 char *uuid;
3653                 char *path;
3654                 int fd;
3655
3656                 __bt_service_get_parameters(in_param1, &type, sizeof(int));
3657                 uuid = (char *)g_variant_get_data(in_param2);
3658                 path = (char *)g_variant_get_data(in_param3);
3659                 __bt_service_get_parameters(in_param4, &fd, sizeof(int));
3660
3661                 result = _bt_register_osp_server_in_agent(type, uuid, path, fd);
3662                 break;
3663         }
3664         case BT_UNSET_AUTHORIZATION: {
3665                 int type;
3666                 char *uuid;
3667
3668                 __bt_service_get_parameters(in_param1, &type, sizeof(int));
3669                 uuid = (char *)g_variant_get_data(in_param2);
3670
3671                 result = _bt_unregister_osp_server_in_agent(type, uuid);
3672                 break;
3673         }
3674         default:
3675                 BT_ERR("Unknown function!");
3676                 result = BLUETOOTH_ERROR_INTERNAL;
3677                 break;
3678         }
3679
3680         return result;
3681 }
3682
3683 int __bt_core_request(int function_name,
3684                 int request_type,
3685                 int request_id,
3686                 GDBusMethodInvocation *context,
3687                 GVariant *in_param1)
3688 {
3689         int result;
3690
3691         switch (function_name) {
3692         case BT_ENABLE_ADAPTER:
3693         {
3694                 bt_status_t status;
3695                 _bt_set_adapter_request_state(TRUE);
3696                 status = _bt_adapter_get_status();
3697
3698                 if (status == BT_ACTIVATING) {
3699                         BT_DBG("Enabling in progress");
3700                         result = BLUETOOTH_ERROR_IN_PROGRESS;
3701                 } else if (status == BT_ACTIVATED) {
3702                         BT_DBG("Already enabled");
3703                         result = BLUETOOTH_ERROR_DEVICE_ALREADY_ENABLED;
3704                 } else {
3705                         _bt_adapter_set_status(BT_ACTIVATING);
3706                         result = BLUETOOTH_ERROR_NONE;
3707                 }
3708
3709                 break;
3710         }
3711         case BT_DISABLE_ADAPTER:
3712         {
3713                 bt_status_t status;
3714                 status = _bt_adapter_get_status();
3715                 if (status == BT_DEACTIVATING) {
3716                                 BT_DBG("Disabling in progress");
3717                                 result = BLUETOOTH_ERROR_IN_PROGRESS;
3718                 } else if (status == BT_DEACTIVATED) {
3719                                 BT_DBG("Already disabled");
3720                                 result = BLUETOOTH_ERROR_DEVICE_NOT_ENABLED;
3721                 } else {
3722                         _bt_adapter_set_status(BT_DEACTIVATING);
3723                         result = BLUETOOTH_ERROR_NONE;
3724                 }
3725
3726                 break;
3727         }
3728         case BT_ENABLE_ADAPTER_LE:
3729         {
3730                 bt_le_status_t le_status;
3731                 _bt_set_le_request_state(TRUE);
3732                 le_status = _bt_adapter_get_le_status();
3733                 if (le_status == BT_LE_ACTIVATING) {
3734                         BT_DBG("Enabling in progress");
3735                         result = BLUETOOTH_ERROR_IN_PROGRESS;
3736                 } else if (le_status == BT_LE_ACTIVATED) {
3737                         BT_DBG("Already enabled");
3738                         result = BLUETOOTH_ERROR_DEVICE_ALREADY_ENABLED;
3739                 } else {
3740                         _bt_adapter_set_le_status(BT_LE_ACTIVATING);
3741                         result = BLUETOOTH_ERROR_NONE;
3742                 }
3743
3744                 break;
3745         }
3746         case BT_DISABLE_ADAPTER_LE:
3747         {
3748                 bt_le_status_t le_status;
3749
3750                 le_status = _bt_adapter_get_le_status();
3751                 if (le_status == BT_LE_DEACTIVATING) {
3752                                 BT_DBG("Disabling in progress");
3753                                 result = BLUETOOTH_ERROR_IN_PROGRESS;
3754                 } else if (le_status == BT_LE_DEACTIVATED) {
3755                                 BT_DBG("Already disabled");
3756                                 result = BLUETOOTH_ERROR_DEVICE_NOT_ENABLED;
3757                 } else {
3758                         _bt_adapter_set_le_status(BT_LE_DEACTIVATING);
3759                         result = BLUETOOTH_ERROR_NONE;
3760                 }
3761
3762                 break;
3763         }
3764         default:
3765                 BT_ERR("Unknown function!");
3766                 result = BLUETOOTH_ERROR_INTERNAL;
3767                 break;
3768         }
3769
3770         return result;
3771 }
3772
3773 gboolean __bt_service_check_privilege(int function_name,
3774                                         int service_type,
3775                                         const char *unique_name)
3776 {
3777         int ret_val;
3778         gboolean result = TRUE;
3779         char *client_creds = NULL;
3780         char *user_creds = NULL;
3781         char *client_session = "";
3782         enum cynara_client_creds client_creds_method = CLIENT_METHOD_SMACK;
3783         enum cynara_user_creds user_creds_method = USER_METHOD_UID;
3784         char err_msg[256] = {0, };
3785
3786         retv_if(unique_name == NULL, FALSE);
3787         retv_if(bt_service_conn == NULL, FALSE);
3788
3789         ret_val = cynara_creds_get_default_client_method(&client_creds_method);
3790         if (ret_val != CYNARA_API_SUCCESS) {
3791                 cynara_strerror(ret_val, err_msg, sizeof(err_msg));
3792                 BT_ERR("Fail to get default client method: %s", err_msg);
3793                 return FALSE;
3794         }
3795
3796         ret_val = cynara_creds_get_default_user_method(&user_creds_method);
3797         if (ret_val != CYNARA_API_SUCCESS) {
3798                 cynara_strerror(ret_val, err_msg, sizeof(err_msg));
3799                 BT_ERR("Fail to get default user method: %s", err_msg);
3800                 return FALSE;
3801         }
3802
3803         ret_val = cynara_creds_gdbus_get_client(bt_service_conn, unique_name, client_creds_method, &client_creds);
3804         if (ret_val != CYNARA_API_SUCCESS) {
3805                 cynara_strerror(ret_val, err_msg, sizeof(err_msg));
3806                 BT_ERR("Fail to get client credential: %s", err_msg);
3807                 return FALSE;
3808         }
3809
3810         ret_val = cynara_creds_gdbus_get_user(bt_service_conn, unique_name, user_creds_method, &user_creds);
3811         if (ret_val != CYNARA_API_SUCCESS) {
3812                 cynara_strerror(ret_val, err_msg, sizeof(err_msg));
3813                 BT_ERR("Fail to get user credential: %s", err_msg);
3814                 if (client_creds)
3815                         free(client_creds);
3816                 return FALSE;
3817         }
3818
3819         BT_DBG("%s, %s, %s", unique_name, client_creds, user_creds);
3820
3821         switch (function_name) {
3822         case BT_SET_LOCAL_NAME:
3823         case BT_START_DISCOVERY:
3824         case BT_START_CUSTOM_DISCOVERY:
3825         case BT_CANCEL_DISCOVERY:
3826         case BT_OOB_ADD_REMOTE_DATA:
3827         case BT_OOB_REMOVE_REMOTE_DATA:
3828         case BT_OOB_READ_LOCAL_DATA:
3829         case BT_SET_ADVERTISING:
3830         case BT_SET_CUSTOM_ADVERTISING:
3831         case BT_SET_ADVERTISING_PARAMETERS:
3832         case BT_START_LE_DISCOVERY:
3833         case BT_STOP_LE_DISCOVERY:
3834         case BT_SET_SCAN_PARAMETERS:
3835         case BT_SET_SCAN_TYPE:
3836
3837         case BT_BOND_DEVICE:
3838         case BT_CANCEL_BONDING:
3839         case BT_UNBOND_DEVICE:
3840         case BT_SET_ALIAS:
3841         case BT_SET_AUTHORIZATION:
3842         case BT_UNSET_AUTHORIZATION:
3843         case BT_SEARCH_SERVICE:
3844
3845         case BT_RFCOMM_CLIENT_CONNECT:
3846         case BT_RFCOMM_CLIENT_CANCEL_CONNECT:
3847         case BT_RFCOMM_SOCKET_DISCONNECT:
3848         case BT_RFCOMM_SOCKET_WRITE:
3849         case BT_RFCOMM_CREATE_SOCKET:
3850         case BT_RFCOMM_REMOVE_SOCKET:
3851
3852         case BT_OPP_PUSH_FILES:
3853         case BT_OPP_CANCEL_PUSH:
3854         /* TODO: MAP? MAP functions, see above */
3855
3856         case BT_OBEX_SERVER_ACCEPT_CONNECTION:
3857         case BT_OBEX_SERVER_REJECT_CONNECTION:
3858         case BT_OBEX_SERVER_ACCEPT_FILE:
3859         case BT_OBEX_SERVER_REJECT_FILE:
3860         case BT_OBEX_SERVER_SET_PATH:
3861         case BT_OBEX_SERVER_SET_ROOT:
3862         case BT_OBEX_SERVER_CANCEL_TRANSFER:
3863         case BT_OBEX_SERVER_CANCEL_ALL_TRANSFERS:
3864
3865         case BT_AUDIO_SELECT_ROLE:
3866         case BT_AUDIO_CONNECT:
3867         case BT_AUDIO_DISCONNECT:
3868         case BT_AG_CONNECT:
3869         case BT_AG_DISCONNECT:
3870         case BT_AV_CONNECT:
3871         case BT_AV_DISCONNECT:
3872         case BT_AV_SOURCE_CONNECT:
3873         case BT_AV_SOURCE_DISCONNECT:
3874         case BT_AVRCP_TARGET_CONNECT:
3875         case BT_AVRCP_TARGET_DISCONNECT:
3876         case BT_AVRCP_CONTROL_CONNECT:
3877         case BT_AVRCP_CONTROL_DISCONNECT:
3878         case BT_AVRCP_HANDLE_CONTROL:
3879         case BT_AVRCP_SET_TRACK_INFO:
3880         case BT_AVRCP_SET_PROPERTY:
3881         case BT_AVRCP_SET_PROPERTIES:
3882         case BT_AVRCP_CONTROL_SET_PROPERTY:
3883
3884         case BT_HF_CONNECT:
3885         case BT_HF_DISCONNECT:
3886
3887         case BT_HID_CONNECT:
3888         case BT_HID_DISCONNECT:
3889
3890         case BT_HID_DEVICE_ACTIVATE:
3891         case BT_HID_DEVICE_DEACTIVATE:
3892         case BT_HID_DEVICE_CONNECT:
3893         case BT_HID_DEVICE_DISCONNECT:
3894         case BT_HID_DEVICE_SEND_MOUSE_EVENT:
3895         case BT_HID_DEVICE_SEND_KEY_EVENT:
3896         case BT_HID_DEVICE_SEND_REPLY_TO_REPORT:
3897         case BT_HID_DEVICE_SEND_CUSTOM_EVENT:
3898
3899         case BT_CONNECT_LE:
3900         case BT_DISCONNECT_LE:
3901
3902         case BT_SET_ADVERTISING_DATA:
3903         case BT_SET_SCAN_RESPONSE_DATA:
3904
3905         case BT_HDP_CONNECT:
3906         case BT_HDP_DISCONNECT:
3907         case BT_HDP_SEND_DATA:
3908         case BT_HDP_REGISTER_SINK_APP:
3909         case BT_HDP_UNREGISTER_SINK_APP:
3910         case BT_HDP_GET_FD:
3911
3912         case BT_DPM_SET_ALLOW_BT_MODE:
3913         case BT_DPM_GET_ALLOW_BT_MODE:
3914         case BT_DPM_SET_DEVICE_RESTRITION:
3915         case BT_DPM_GET_DEVICE_RESTRITION:
3916         case BT_DPM_SET_UUID_RESTRITION:
3917         case BT_DPM_GET_UUID_RESTRITION:
3918         case BT_DPM_ADD_DEVICES_BLACKLIST:
3919         case BT_DPM_ADD_DEVICES_WHITELIST:
3920         case BT_DPM_ADD_UUIDS_BLACKLIST:
3921         case BT_DPM_ADD_UUIDS_WHITELIST:
3922         case BT_DPM_CLEAR_DEVICES_BLACKLIST:
3923         case BT_DPM_CLEAR_DEVICES_WHITELIST:
3924         case BT_DPM_CLEAR_UUIDS_BLACKLIST:
3925         case BT_DPM_CLEAR_UUIDS_WHITELIST:
3926         case BT_DPM_REMOVE_DEVICE_BLACKLIST:
3927         case BT_DPM_REMOVE_DEVICE_WHITELIST:
3928         case BT_DPM_REMOVE_UUID_BLACKLIST:
3929         case BT_DPM_REMOVE_UUID_WHITELIST:
3930         case BT_DPM_GET_DEVICES_BLACKLIST:
3931         case BT_DPM_GET_DEVICES_WHITELIST:
3932         case BT_DPM_GET_UUIDS_BLACKLIST:
3933         case BT_DPM_GET_UUIDS_WHITELIST:
3934         case BT_DPM_SET_ALLOW_OUTGOING_CALL:
3935         case BT_DPM_GET_ALLOW_OUTGOING_CALL:
3936         case BT_DPM_SET_PAIRING_STATE:
3937         case BT_DPM_GET_PAIRING_STATE:
3938         case BT_DPM_SET_PROFILE_STATE:
3939         case BT_DPM_GET_PROFILE_STATE:
3940         case BT_DPM_SET_DESKROP_CONNECTIVITY_STATE:
3941         case BT_DPM_GET_DESKROP_CONNECTIVITY_STATE:
3942         case BT_DPM_SET_DISCOVERABLE_STATE:
3943         case BT_DPM_GET_DISCOVERABLE_STATE:
3944         case BT_DPM_SET_LIMITED_DISCOVERABLE_STATE:
3945         case BT_DPM_GET_LIMITED_DISCOVERABLE_STATE:
3946         case BT_DPM_SET_DATA_TRANSFER_STATE:
3947         case BT_DPM_GET_DATA_TRANSFER_STATE:
3948
3949         case BT_NETWORK_ACTIVATE:
3950         case BT_NETWORK_DEACTIVATE:
3951         case BT_NETWORK_CONNECT:
3952         case BT_NETWORK_DISCONNECT:
3953         case BT_NETWORK_SERVER_DISCONNECT:
3954
3955         case BT_GATT_GET_PRIMARY_SERVICES:
3956 #ifdef TIZEN_GATT_CLIENT
3957         case BT_GATT_GET_SERVICE_PROPERTIES:             /* GATT Client */
3958         case BT_GATT_GET_CHARACTERISTIC_PROPERTIES:      /* GATT Client */
3959         case BT_GATT_WATCH_SERVICE_CHANGED_INDICATION:   /* GATT Client */
3960 #endif
3961         case BT_GATT_DISCOVER_CHARACTERISTICS:
3962         case BT_GATT_SET_PROPERTY_REQUEST:
3963         case BT_GATT_READ_CHARACTERISTIC:
3964 #ifdef TIZEN_GATT_CLIENT
3965         case BT_GATT_READ_DESCRIPTOR_VALUE:              /* GATT Client */
3966         case BT_GATT_WRITE_CHARACTERISTIC_VALUE_BY_TYPE: /* GATT Client */
3967         case BT_GATT_ACQUIRE_WRITE:
3968         case BT_GATT_WRITE_DESCRIPTOR_VALUE:             /* GATT Client */
3969         case BT_GATT_WATCH_CHARACTERISTIC:               /* GATT Client */
3970         case BT_GATT_CLIENT_REGISTER:                    /* GATT Client */
3971         case BT_GATT_CLIENT_UNREGISTER:                   /* GATT Client */
3972 #endif
3973         case BT_GATT_DISCOVER_CHARACTERISTICS_DESCRIPTOR:
3974         case BT_GATT_REGISTER_APPLICATION:
3975         case BT_GATT_REGISTER_SERVICE:
3976         case BT_GATT_SEND_RESPONSE:
3977 #ifndef GATT_DIRECT
3978         case BT_GATT_SERVER_REGISTER:
3979         case BT_GATT_SERVER_ADD_SERVICE:
3980         case BT_GATT_SERVER_ADD_CHARACTERISTIC:
3981         case BT_GATT_SERVER_ADD_DESCRIPTOR:
3982         case BT_GATT_SERVER_START_SERVICE:
3983         case BT_GATT_SERVER_STOP_SERVICE:
3984         case BT_GATT_SERVER_DELETE_SERVICE:
3985         case BT_GATT_SERVER_SEND_RESPONSE:
3986         case BT_GATT_SERVER_ACQURE_WRITE_RESPONSE:
3987         case BT_GATT_SERVER_ACQUIRE_NOTIFY_RESPONSE:
3988         case BT_GATT_SERVER_SEND_INDICATION:
3989         case BT_GATT_SERVER_UPDATE_VALUE:
3990         case BT_GATT_SERVER_DEREGISTER:
3991 #endif
3992         case BT_REQ_ATT_MTU:
3993         case BT_PBAP_CONNECT:
3994         case BT_PBAP_DISCONNECT:
3995         case BT_PBAP_GET_PHONEBOOK_SIZE:
3996         case BT_PBAP_GET_PHONEBOOK:
3997         case BT_PBAP_GET_LIST:
3998         case BT_PBAP_PULL_VCARD:
3999         case BT_PBAP_PHONEBOOK_SEARCH:
4000
4001         case BT_RFCOMM_LISTEN_AND_ACCEPT:
4002
4003         ret_val = cynara_check(p_cynara, client_creds, client_session, user_creds,
4004                                                 BT_PRIVILEGE_PUBLIC);
4005
4006         if (ret_val != CYNARA_API_ACCESS_ALLOWED) {
4007                 BT_ERR("Fail to access: %s", BT_PRIVILEGE_PUBLIC);
4008                 result = FALSE;
4009         }
4010
4011         /* Need to check mediastorage privilege */
4012         if (function_name == BT_PBAP_GET_PHONEBOOK ||
4013                 function_name == BT_PBAP_PULL_VCARD) {
4014                 ret_val = cynara_check(p_cynara, client_creds, client_session, user_creds,
4015                                                         MEDIASTORAGE_PRIVILEGE);
4016
4017                 if (ret_val != CYNARA_API_ACCESS_ALLOWED) {
4018                 BT_ERR("Fail to access: %s", MEDIASTORAGE_PRIVILEGE);
4019                 result = FALSE;
4020                 }
4021         }
4022         break;
4023
4024         case BT_RFCOMM_SEND_RX_DETAILS:
4025         case BT_RFCOMM_SEND_TX_DETAILS:
4026         case BT_ENABLE_ADAPTER:
4027         case BT_DISABLE_ADAPTER:
4028         case BT_RESET_ADAPTER:
4029         case BT_RECOVER_ADAPTER:
4030         case BT_BATTERY_READ_DATA:
4031         case BT_ENABLE_ADAPTER_LE:
4032         case BT_DISABLE_ADAPTER_LE:
4033         case BT_SET_CONNECTABLE:
4034         case BT_SET_DISCOVERABLE_MODE:
4035         case BT_ADD_WHITE_LIST:
4036         case BT_REMOVE_WHITE_LIST:
4037         case BT_CLEAR_WHITE_LIST:
4038         case BT_SET_MANUFACTURER_DATA:
4039
4040         case BT_CANCEL_SEARCH_SERVICE:
4041         case BT_ENABLE_RSSI:
4042         case BT_DISCONNECT_DEVICE:
4043
4044         case BT_RFCOMM_ACCEPT_CONNECTION:
4045         case BT_RFCOMM_REJECT_CONNECTION:
4046         case BT_RFCOMM_LISTEN:
4047
4048         case BT_HID_ENABLE_BARCODE_FEATURE:
4049
4050         case BT_AVRCP_CONTROL_GET_PROPERTY:
4051         case BT_AVRCP_GET_TRACK_INFO:
4052         case BT_AVRCP_TRANSPORT_SET_PROPERTY:
4053         case BT_AVRCP_HANDLE_CONTROL_TO_DEST:
4054
4055         case BT_SET_CONTENT_PROTECT:
4056         case BT_BOND_DEVICE_BY_TYPE:
4057         case BT_SET_LE_PRIVACY:
4058         case BT_SET_LE_STATIC_RANDOM_ADDRESS:
4059         case BT_LE_CONN_UPDATE:
4060         case BT_UPDATE_LE_CONNECTION_MODE:
4061         case BT_GET_DEVICE_IDA:
4062         case BT_LE_READ_MAXIMUM_DATA_LENGTH:
4063         case BT_LE_WRITE_HOST_SUGGESTED_DATA_LENGTH:
4064         case BT_LE_READ_HOST_SUGGESTED_DATA_LENGTH:
4065         case BT_LE_SET_DATA_LENGTH:
4066         case BT_LE_OOB_READ_LOCAL_DATA:
4067         case BT_LE_OOB_ADD_REMOTE_DATA:
4068
4069         case BT_LE_IPSP_INIT:
4070         case BT_LE_IPSP_DEINIT:
4071         case BT_LE_IPSP_CONNECT:
4072         case BT_LE_IPSP_DISCONNECT:
4073         case BT_PXP_MONITOR_SET_PROPERTY:
4074         case BT_PXP_MONITOR_GET_PROPERTY:
4075         case BT_PXP_MONITOR_GET_SUPPORTED_SERIVCES:
4076         case BT_PXP_REPORTER_REGISTER:
4077         case BT_PXP_REPORTER_UNREGISTER:
4078         case BT_PXP_REPORTER_GET_PROPERTY:
4079
4080         /* TDS */
4081         case BT_TDS_PROVIDER_REGISTER:
4082         case BT_TDS_PROVIDER_UNREGISTER:
4083         case BT_TDS_PROVIDER_SET_MANUF_DATA:
4084         case BT_TDS_PROVIDER_CREATE:
4085         case BT_TDS_PROVIDER_DESTROY:
4086         case BT_TDS_PROVIDER_SET_TRANSPORT_DATA:
4087         case BT_TDS_SEND_ACTIVATION_RESPONSE:
4088         case BT_TDS_READ_TRANSPORT_DATA:
4089         case BT_TDS_ENABLE_CONTROL_POINT:
4090         case BT_TDS_ACTIVATE_CONTROL_POINT:
4091
4092         /* OTP Server */
4093         case BT_OTP_SERVER_INIT:
4094         case BT_OTP_SERVER_DEINIT:
4095         case BT_OTP_READ_VALUE:
4096         case BT_OTP_ENABLE_NOTIFICATION:
4097         case BT_OTP_WRITE_VALUE:
4098         case BT_LE_OTC_CONNECT:
4099         case BT_LE_OTC_DISCONNECT:
4100
4101         case BT_MAP_CREATE_SESSION:
4102         case BT_MAP_DESTROY_SESSION:
4103         case BT_MAP_SET_FOLDER:
4104         case BT_MAP_LIST_FOLDERS:
4105         case BT_MAP_LIST_FILTER_FIELDS:
4106         case BT_MAP_LIST_MESSAGES:
4107         case BT_MAP_UPDATE_INBOX:
4108         case BT_MAP_PUSH_MESSAGE:
4109         case BT_MAP_GET_MESSAGE:
4110
4111         ret_val = cynara_check(p_cynara, client_creds, client_session, user_creds,
4112                                 BT_PRIVILEGE_PLATFORM);
4113
4114         if (ret_val != CYNARA_API_ACCESS_ALLOWED) {
4115                 BT_ERR("Fail to access: %s", BT_PRIVILEGE_PLATFORM);
4116                 result = FALSE;
4117         }
4118         break;
4119
4120         case BT_CHECK_ADAPTER:
4121         case BT_GET_RSSI:
4122
4123         case BT_GET_LOCAL_NAME:
4124         case BT_GET_LOCAL_ADDRESS:
4125         case BT_GET_LOCAL_VERSION:
4126         case BT_IS_SERVICE_USED:
4127         case BT_GET_DISCOVERABLE_MODE:
4128         case BT_GET_DISCOVERABLE_TIME:
4129         case BT_IS_DISCOVERYING:
4130         case BT_IS_LE_DISCOVERYING:
4131         case BT_IS_CONNECTABLE:
4132         case BT_GET_BONDED_DEVICES:
4133         case BT_GET_PROFILE_CONNECTED_DEVICES:
4134         case BT_GET_BONDED_DEVICE:
4135         case BT_PASSKEY_REPLY:
4136         case BT_PASSKEY_CONFIRMATION_REPLY:
4137         case BT_GET_IS_ALIAS_SET:
4138         case BT_IS_DEVICE_CONNECTED:
4139         case BT_GET_CONNECTED_LINK_TYPE:
4140         case BT_SET_PROFILE_TRUSTED:
4141         case BT_GET_PROFILE_TRUSTED:
4142         case BT_GET_SPEAKER_GAIN:
4143         case BT_SET_SPEAKER_GAIN:
4144         case BT_RFCOMM_CLIENT_IS_CONNECTED:
4145         case BT_RFCOMM_IS_UUID_AVAILABLE:
4146         case BT_GET_ADVERTISING_DATA:
4147         case BT_GET_SCAN_RESPONSE_DATA:
4148         case BT_IS_ADVERTISING:
4149         case BT_IS_LE_2M_PHY_SUPPORTED:
4150         case BT_IS_LE_CODED_PHY_SUPPORTED:
4151         case BT_REGISTER_SCAN_FILTER:
4152         case BT_IS_SCAN_FILTER_SUPPORTED:
4153         case BT_GET_ATT_MTU:
4154
4155         case BT_OBEX_SERVER_ALLOCATE:
4156         case BT_OBEX_SERVER_DEALLOCATE:
4157         case BT_OBEX_SERVER_IS_ACTIVATED:
4158         case BT_OPP_GET_TRANSFER_PROGRESS:
4159                 /* Non-privilege control */
4160                 break;
4161         default:
4162                 BT_ERR("Unknown function!");
4163                 result = FALSE;
4164                 break;
4165         }
4166
4167         if (client_creds)
4168                 free(client_creds);
4169
4170         if (user_creds)
4171                 free(user_creds);
4172
4173         return result;
4174 }
4175
4176 GDBusNodeInfo *__bt_service_create_method_node_info
4177                                         (const gchar *introspection_data)
4178 {
4179         GError *err = NULL;
4180         GDBusNodeInfo *node_info = NULL;
4181
4182         if (introspection_data == NULL) {
4183                 BT_ERR("Introspection XML not present");
4184                 return NULL;
4185         }
4186
4187         node_info = g_dbus_node_info_new_for_xml(introspection_data, &err);
4188
4189         if (err) {
4190                 BT_ERR("Unable to create node: %s", err->message);
4191                 g_clear_error(&err);
4192         }
4193         return node_info;
4194 }
4195
4196 int __bt_service_register_object(GDBusConnection *conn,
4197                 GDBusNodeInfo *node_info, gboolean reg)
4198 {
4199         static guint service_id = 0;
4200         GError *error = NULL;
4201
4202         if (reg) {
4203                 if (node_info == NULL)
4204                         return -1;
4205
4206                 service_id = g_dbus_connection_register_object(conn,
4207                                 BT_SERVICE_PATH,
4208                                 node_info->interfaces[0],
4209                                 &method_table,
4210                                 NULL, NULL, &error);
4211                 if (service_id == 0)
4212                         return -1;
4213         } else {
4214                 if (service_id > 0) {
4215                         g_dbus_connection_unregister_object(conn,
4216                                         service_id);
4217                         service_id = 0;
4218                 }
4219         }
4220
4221         return 0;
4222 }
4223
4224 static void __name_owner_changed(GDBusConnection *connection,
4225                 const gchar *sender_name,
4226                 const gchar *object_path,
4227                 const gchar *interface_name,
4228                 const gchar *signal_name,
4229                 GVariant *parameters,
4230                 gpointer user_data)
4231 {
4232         const char *name = NULL;
4233         const char *old_owner = NULL;
4234         const char *new_owner = NULL;
4235
4236         g_variant_get(parameters, "(&s&s&s)", &name, &old_owner, &new_owner);
4237         if (*new_owner != '\0')
4238                 return;
4239
4240         _bt_check_hdp_app_termination(name);
4241
4242         /* Advertising App Termination */
4243         _bt_check_adv_app_termination(name);
4244
4245         /* Check if le_scanning app is terminated */
4246         _bt_check_le_scanner_app_termination(name);
4247 }
4248
4249 static void __bt_service_bus_acquired_handler(GDBusConnection *connection,
4250                 const gchar *name, gpointer user_data)
4251 {
4252         GDBusNodeInfo *node_info = NULL;
4253
4254         BT_INFO("bus acquired");
4255
4256         ret_if(connection == NULL);
4257
4258         node_info = __bt_service_create_method_node_info(
4259                         bt_service_introspection_xml);
4260         ret_if(node_info == NULL);
4261
4262         __bt_service_register_object(connection, node_info, TRUE);
4263         g_dbus_node_info_unref(node_info);
4264
4265         bt_service_conn = connection;
4266 }
4267
4268 static void __bt_service_name_acquired_handler(GDBusConnection *connection,
4269                 const gchar *name, gpointer user_data)
4270 {
4271         BT_INFO("name acquired");
4272         name_acquired = TRUE;
4273 }
4274
4275 static void __bt_service_name_lost_handler(GDBusConnection *connection,
4276                 const gchar *name, gpointer user_data)
4277 {
4278         BT_INFO("name lost");
4279         name_acquired = FALSE;
4280 }
4281
4282 gboolean _is_name_acquired(void)
4283 {
4284         return name_acquired;
4285 }
4286
4287 int _bt_service_register(void)
4288 {
4289         GDBusConnection *conn;
4290         GError *err = NULL;
4291
4292         conn = g_bus_get_sync(G_BUS_TYPE_SYSTEM, NULL, &err);
4293         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
4294         bt_service_conn = conn;
4295
4296         owner_id = g_bus_own_name(G_BUS_TYPE_SYSTEM,
4297                                 BT_SERVICE_NAME,
4298                                 G_BUS_NAME_OWNER_FLAGS_NONE,
4299                                 __bt_service_bus_acquired_handler,
4300                                 __bt_service_name_acquired_handler,
4301                                 __bt_service_name_lost_handler,
4302                                 NULL, NULL);
4303         BT_DBG("owner_id is [%d]", owner_id);
4304         if (owner_id == 0)
4305                 goto fail;
4306
4307         /* Subscribe for name owner changed signal */
4308         owner_sig_id = g_dbus_connection_signal_subscribe(conn,
4309                         BT_FREEDESKTOP_SERVICE, BT_FREEDESKTOP_INTERFACE,
4310                         BT_NAME_OWNER_CHANGED, NULL, NULL, G_DBUS_SIGNAL_FLAGS_NONE,
4311                         __name_owner_changed, NULL, NULL);
4312         BT_INFO("owner_sig_id: %d", owner_sig_id);
4313
4314         return BLUETOOTH_ERROR_NONE;
4315
4316 fail:
4317         if (bt_service_conn) {
4318                 g_object_unref(bt_service_conn);
4319                 bt_service_conn = NULL;
4320         }
4321
4322         return BLUETOOTH_ERROR_INTERNAL;
4323 }
4324
4325 void _bt_service_unregister(void)
4326 {
4327         if (bt_service_conn) {
4328                 if (owner_sig_id > 0) {
4329                         g_dbus_connection_signal_unsubscribe(
4330                                         bt_service_conn, owner_sig_id);
4331                         owner_sig_id = 0;
4332                 }
4333
4334                 __bt_service_register_object(bt_service_conn, NULL, FALSE);
4335                 if (bt_service_conn) {
4336                         g_object_unref(bt_service_conn);
4337                         bt_service_conn = NULL;
4338                 }
4339                 if (owner_id > 0) {
4340                         g_bus_unown_name(owner_id);
4341                         owner_id = 0;
4342                 }
4343         }
4344 }
4345
4346 int _bt_service_cynara_init(void)
4347 {
4348         int result;
4349         char err_msg[256] = {0, };
4350
4351         retv_if(p_cynara != NULL, BLUETOOTH_ERROR_ALREADY_INITIALIZED);
4352
4353         result = cynara_initialize(&p_cynara, conf);
4354
4355         if (result != CYNARA_API_SUCCESS) {
4356                 cynara_strerror(result, err_msg, sizeof(err_msg));
4357                 BT_ERR("Fail to initialize cynara: [%s]", err_msg);
4358                 return BLUETOOTH_ERROR_INTERNAL;
4359         }
4360
4361         return BLUETOOTH_ERROR_NONE;
4362 }
4363
4364 void _bt_service_cynara_deinit(void)
4365 {
4366         int result;
4367         char err_msg[256] = {0, };
4368
4369         ret_if(p_cynara == NULL);
4370
4371         result = cynara_finish(p_cynara);
4372
4373         if (result != CYNARA_API_SUCCESS) {
4374                 cynara_strerror(result, err_msg, sizeof(err_msg));
4375                 BT_ERR("Fail to finish cynara: [%s]", err_msg);
4376                 return;
4377         }
4378
4379         p_cynara = NULL;
4380         conf = NULL;
4381 }
4382
4383 void _bt_service_method_return(GDBusMethodInvocation *invocation,
4384                 GArray *out_param, int result)
4385 {
4386         GVariant *out_var;
4387         BT_DBG("+");
4388         out_var = g_variant_new_from_data((const GVariantType *)"ay",
4389                         out_param->data, out_param->len, TRUE, NULL, NULL);
4390
4391         g_dbus_method_invocation_return_value(invocation,
4392                         g_variant_new("(iv)", result, out_var));
4393         BT_DBG("-");
4394 }
4395
4396 void _bt_service_method_return_with_unix_fd_list(GDBusMethodInvocation *invocation,
4397                 GArray *out_param, int result, GUnixFDList *fd_list)
4398 {
4399         GVariant *out_var;
4400         BT_DBG("+");
4401         out_var = g_variant_new_from_data((const GVariantType *)"ay",
4402                         out_param->data, out_param->len, TRUE, NULL, NULL);
4403
4404         g_dbus_method_invocation_return_value_with_unix_fd_list(invocation,
4405                         g_variant_new("(iv)", result, out_var), fd_list);
4406         BT_DBG("-");
4407 }