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