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