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