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