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