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