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