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