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