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