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