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