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