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