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