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