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