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