Merge "DPM: Add basic code for device policy manager for BT." into tizen
[platform/core/connectivity/bluetooth-frwk.git] / bt-service / bt-service-device.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 <glib.h>
19 #include <gio/gio.h>
20 #include <dlog.h>
21 #include <string.h>
22 #if !defined(LIBNOTIFY_SUPPORT) && !defined(LIBNOTIFICATION_SUPPORT)
23 #include <syspopup_caller.h>
24 #endif
25 #include <bundle_internal.h>
26
27 #include "bluetooth-api.h"
28 #include "bt-internal-types.h"
29
30 #include "bt-service-common.h"
31 #include "bt-service-event.h"
32 #include "bt-service-device.h"
33 #include "bt-service-adapter-le.h"
34 #include "bt-service-rfcomm-client.h"
35 #include "bt-service-util.h"
36 #include "bt-service-agent.h"
37 #include "bt-service-network.h"
38 #include "bt-service-adapter.h"
39 #include "bt-service-gap-agent.h"
40
41 #define BT_SYSPOPUP_IPC_RESPONSE_OBJECT "/org/projectx/bt_syspopup_res"
42 #define BT_SYSPOPUP_INTERFACE "User.Bluetooth.syspopup"
43 #define BT_SYSPOPUP_METHOD_RESPONSE "Response"
44
45 #define BT_LE_CONN_INTERVAL_MIN 7.5 /* msec */
46 #define BT_LE_CONN_INTERVAL_MAX 4000 /* msec */
47 #define BT_LE_CONN_SUPER_TO_MIN 100 /* msec */
48 #define BT_LE_CONN_SUPER_TO_MAX 32000 /* msec */
49 #define BT_LE_CONN_SLAVE_LATENCY_MAX 499
50 #define BT_LE_CONN_INTERVAL_SPLIT 1.25 /* msec */
51 #define BT_LE_CONN_TO_SPLIT 10 /* msec */
52 #define BT_DEVICE_PIN_CODE_SLOT_MAX 10
53
54 #define BT_LE_CONN_PARAM_DEFAULT_SUPERVISION_TIMEOUT    20000   /* msec */
55
56 #define BT_LE_CONN_PARAM_BALANCED_MIN_INTERVAL  30      /* msec */
57 #define BT_LE_CONN_PARAM_BALANCED_MAX_INTERVAL  50      /* msec */
58 #define BT_LE_CONN_PARAM_BALANCED_SLAVE_LATENCY 0       /* event */
59
60 #define BT_LE_CONN_PARAM_LOW_LATENCY_MIN_INTERVAL       7.5     /* msec */
61 #define BT_LE_CONN_PARAM_LOW_LATENCY_MAX_INTERVAL       10      /* msec */
62 #define BT_LE_CONN_PARAM_LOW_LATENCY_SLAVE_LATENCY      0       /* event */
63
64 #define BT_LE_CONN_PARAM_LOW_POWER_MIN_INTERVAL         80      /* msec */
65 #define BT_LE_CONN_PARAM_LOW_POWER_MAX_INTERVAL         100     /* msec */
66 #define BT_LE_CONN_PARAM_LOW_POWER_SLAVE_LATENCY        2       /* event */
67
68 typedef struct {
69         int req_id;
70         int result;
71         char *addr;
72         gboolean is_autopair;
73         GDBusProxy *device_proxy;
74         GDBusProxy *adapter_proxy;
75         void *agent;
76         unsigned short conn_type;
77 } bt_funcion_data_t;
78
79 typedef struct {
80         char *address;
81         char *pin_code;
82 } bt_pin_code_info_t;
83
84 gboolean is_device_creating;
85 bt_funcion_data_t *bonding_info;
86 bt_funcion_data_t *searching_info;
87 bt_funcion_data_t *le_connection_info;
88
89 static GSList *pin_info_list = NULL;
90
91 /* This HID Mouse does not support pairing precedure. need to skip it. */
92 #define SMB_MOUSE_LAP_ADDR "00:12:A1"
93
94 static void __bt_bond_device_cb(GDBusProxy *proxy, GAsyncResult *res,
95                                         gpointer user_data);
96
97 static int __bt_retry_bond(void);
98
99
100 /*static void __bt_decline_pair_request()
101 {
102         GVariant *out_param1;
103         GVariant *out_param2;
104         request_info_t *req_info;
105         bluetooth_device_info_t dev_info;
106         bt_remote_dev_info_t *remote_dev_info;
107         GVariant *uuid_list, *manufacture_data;
108         GVariant *param;
109
110         BT_DBG("+");
111         if (bonding_info) {
112                 req_info = _bt_get_request_info(bonding_info->req_id);
113                 if (req_info == NULL) {
114                         BT_ERR("req_info == NULL");
115                         goto done;
116                 }
117                 remote_dev_info = _bt_get_remote_device_info(bonding_info->addr);
118         } else {
119                 BT_DBG("bonding_info is NULL");
120                 BT_DBG("-");
121                 return;
122         }
123
124         uuid_list =  g_variant_new_from_data((const GVariantType *)"as",
125                                                 remote_dev_info->uuids, remote_dev_info->uuid_count,
126                                                 TRUE, NULL, NULL);
127
128         manufacture_data = g_variant_new_from_data((const GVariantType *)"ay",
129                                                 remote_dev_info->manufacturer_data, remote_dev_info->manufacturer_data_len,
130                                                 TRUE, NULL, NULL);
131
132         param = g_variant_new("isunsbuba{s}na{y})",
133                         bonding_info->result,
134                         bonding_info->addr,
135                         remote_dev_info->class,
136                         remote_dev_info->rssi,
137                         remote_dev_info->name,
138                         remote_dev_info->paired,
139                         remote_dev_info->connected,
140                         remote_dev_info->trust,
141                         uuid_list,
142                         remote_dev_info->manufacturer_data_len,
143                         manufacture_data);
144
145
146         //Send the event to application
147         if (remote_dev_info != NULL) {
148                 _bt_send_event(BT_ADAPTER_EVENT,
149                         BLUETOOTH_EVENT_BONDING_FINISHED,
150                         param);
151
152                 _bt_free_device_info(remote_dev_info);
153         }
154
155         if (req_info->context == NULL)
156                 goto done;
157
158         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
159         _bt_convert_addr_string_to_type(dev_info.device_address.addr,
160                                         bonding_info->addr);
161
162         out_param1 = g_variant_new_from_data((const GVariantType *)"ay",
163                 &dev_info, sizeof(bluetooth_device_info_t), TRUE, NULL, NULL);
164
165         out_param2 = g_variant_new_from_data((const GVariantType *)"i",
166                 &bonding_info->result, sizeof(int), TRUE, NULL, NULL);
167
168
169         g_dbus_method_invocation_return_value(req_info->context,
170                         g_variant_new("@ayi", out_param1, out_param2));
171
172
173         _bt_delete_request_list(req_info->req_id);
174 done:
175
176         g_free(bonding_info->addr);
177         g_free(bonding_info);
178         bonding_info = NULL;
179
180         BT_DBG("-");
181 } */
182
183 #ifdef TIZEN_WEARABLE
184 static gboolean __bt_syspopup_timer_cb(gpointer user_data)
185 {
186         int ret;
187         bundle *b;
188         retv_if(user_data == NULL, FALSE);
189
190         b = (bundle *)user_data;
191
192 #if !defined(LIBNOTIFY_SUPPORT) && !defined(LIBNOTIFICATION_SUPPORT)
193         ret = syspopup_launch("bt-syspopup", b);
194 #endif
195         if (ret < 0) {
196                 BT_ERR("Sorry!! Cannot launch popup return = %d, Retrying...", ret);
197         } else {
198                 BT_DBG("Hurray!!! Finally Popup launched");
199                 bundle_free(b);
200         }
201         return (ret < 0) ? TRUE : FALSE;
202 }
203
204 static gboolean __bt_launch_unable_to_pairing_syspopup(int result)
205 {
206         BT_DBG("+");
207         int ret = 0;
208         bundle *b = NULL;
209         GDBusConnection *conn;
210
211         conn = _bt_get_system_gconn();
212         if (conn == NULL)
213                 return FALSE;
214
215         b = bundle_create();
216         if (b == NULL)
217                 return FALSE;
218
219         bundle_add(b, "event-type", "unable-to-pairing");
220
221         if (result == BLUETOOTH_ERROR_TIMEOUT )
222                 bundle_add(b, "error", "timeout");
223         else if (result == BLUETOOTH_ERROR_AUTHENTICATION_FAILED)
224                 bundle_add(b, "error", "authfailed");
225         else
226                 bundle_add(b, "error", "error");
227
228 #if !defined(LIBNOTIFY_SUPPORT) && !defined(LIBNOTIFICATION_SUPPORT)
229         ret = syspopup_launch("bt-syspopup", b);
230 #endif
231         if (0 > ret) {
232                 BT_ERR("Popup launch failed...retry %d \n", ret);
233                 g_timeout_add(200, (GSourceFunc) __bt_syspopup_timer_cb,
234                                 b);
235         } else {
236                 bundle_free(b);
237         }
238
239         BT_DBG("-");
240         return TRUE;
241 }
242 #endif
243
244 gboolean _bt_is_device_creating(void)
245 {
246         return is_device_creating;
247 }
248
249 gboolean _bt_is_bonding_device_address(const char *address)
250 {
251         if (bonding_info == NULL || bonding_info->addr == NULL)
252                 return FALSE;
253
254         if (g_strcmp0(bonding_info->addr, address) == 0) {
255                 BT_DBG("[%s]  is bonding device", address);
256                 return TRUE;
257         }
258
259         BT_DBG("[%s]  is NOT bonding device", address);
260         return FALSE;
261 }
262
263 void _bt_set_autopair_status_in_bonding_info(gboolean is_autopair)
264 {
265         ret_if(bonding_info == NULL);
266         bonding_info->is_autopair = is_autopair;
267 }
268
269 void _bt_device_path_to_address(const char *device_path,
270                                         char *device_address)
271 {
272         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
273         char *dev_addr;
274         char *pos;
275
276         ret_if(device_path == NULL);
277         ret_if(device_address == NULL);
278
279         dev_addr = strstr(device_path, "dev_");
280         ret_if(dev_addr == NULL);
281
282         dev_addr += 4;
283         g_strlcpy(address, dev_addr, sizeof(address));
284
285         while ((pos = strchr(address, '_')) != NULL) {
286                 *pos = ':';
287         }
288
289         g_strlcpy(device_address, address, BT_ADDRESS_STRING_SIZE);
290 }
291
292 void __bt_cancel_search_service_done(void)
293 {
294         int result = BLUETOOTH_ERROR_CANCEL_BY_USER;
295         request_info_t *req_info;
296         bluetooth_device_info_t dev_info;
297         GVariant *out_param1;
298
299         ret_if(searching_info == NULL);
300
301         req_info = _bt_get_request_info(searching_info->req_id);
302         if (req_info == NULL) {
303                 BT_ERR("req_info == NULL");
304                 goto done;
305         }
306
307         if (req_info->context == NULL)
308                 goto done;
309
310         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
311         _bt_convert_addr_string_to_type(dev_info.device_address.addr,
312                                         searching_info->addr);
313
314         out_param1 = g_variant_new_from_data((const GVariantType *)"ay",
315                 &dev_info, sizeof(bluetooth_device_info_t), TRUE, NULL, NULL);
316
317
318         g_dbus_method_invocation_return_value(req_info->context,
319                         g_variant_new("(iv)", result, out_param1));
320
321         _bt_delete_request_list(req_info->req_id);
322
323 done:
324
325         g_free(searching_info->addr);
326         g_free(searching_info);
327         searching_info = NULL;
328 }
329
330 static void __bt_get_uuids(GVariant *value, bt_remote_dev_info_t *info)
331 {
332         ret_if(value == NULL);
333         ret_if(info == NULL);
334
335         info->uuid_count = g_variant_get_size(value);
336         info->uuids = g_variant_dup_strv(value, &info->uuid_count);
337 }
338
339 bt_remote_dev_info_t *_bt_get_remote_device_info(char *address)
340 {
341         bt_remote_dev_info_t *dev_info;
342         char *object_path = NULL;
343         GDBusProxy *adapter_proxy;
344         GDBusProxy *device_proxy;
345         GVariant *value;
346         GVariant *tmp_value;
347         gchar *name;
348         gchar *manufacturer_data = NULL;
349         GDBusConnection *conn;
350         GError *error = NULL;
351         GVariant *result = NULL;
352
353         retv_if(address == NULL, NULL);
354
355         adapter_proxy = _bt_get_adapter_proxy();
356         retv_if(adapter_proxy == NULL, NULL);
357
358
359         object_path = _bt_get_device_object_path(address);
360
361         retv_if(object_path == NULL, NULL);
362
363         conn = _bt_get_system_gconn();
364         if (conn == NULL) {
365                 BT_ERR("conn == NULL");
366                 g_free(object_path);
367                 return NULL;
368         }
369
370         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
371                                                                 NULL, BT_BLUEZ_NAME,
372                                                                 object_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
373
374         g_free(object_path);
375         retv_if(device_proxy == NULL, NULL);
376
377         result = g_dbus_proxy_call_sync(device_proxy, "GetAll",
378                                 g_variant_new("(s)", BT_DEVICE_INTERFACE),
379                                 G_DBUS_CALL_FLAGS_NONE,
380                                 -1,
381                                 NULL,
382                                 &error);
383
384         g_object_unref(device_proxy);
385
386         dev_info = g_malloc0(sizeof(bt_remote_dev_info_t));
387
388         if (result != NULL) {
389                 g_variant_get(result , "(@a{sv})", &value);
390                 g_variant_unref(result);
391
392                 tmp_value = g_variant_lookup_value (value, "Alias", G_VARIANT_TYPE_STRING);
393
394                 g_variant_get(tmp_value, "s", &name);
395                 g_variant_unref(tmp_value);
396                 if (name != NULL)
397                         DBG_SECURE("Alias Name [%s]", name);
398                 else {
399                         tmp_value = g_variant_lookup_value(value, "Name", G_VARIANT_TYPE_STRING);
400                         g_variant_get(tmp_value, "s", &name);
401                         g_variant_unref(tmp_value);
402                 }
403
404                 tmp_value = g_variant_lookup_value(value, "Class", G_VARIANT_TYPE_UINT32);
405                 dev_info->class = tmp_value ? g_variant_get_uint32(tmp_value) : 0;
406                 g_variant_unref(tmp_value);
407
408                 tmp_value = g_variant_lookup_value(value, "Connected",  G_VARIANT_TYPE_BOOLEAN);
409                 dev_info->connected = tmp_value ? g_variant_get_boolean(tmp_value) : BLUETOOTH_CONNECTED_LINK_NONE;
410                 g_variant_unref(tmp_value);
411
412                 tmp_value = g_variant_lookup_value(value, "Trusted",  G_VARIANT_TYPE_BOOLEAN);
413                 dev_info->trust = tmp_value ? g_variant_get_boolean(tmp_value) : FALSE;
414                 g_variant_unref(tmp_value);
415
416                 tmp_value = g_variant_lookup_value(value, "Paired",  G_VARIANT_TYPE_BOOLEAN);
417                 dev_info->paired = tmp_value ? g_variant_get_boolean(tmp_value) : FALSE;
418                 g_variant_unref(tmp_value);
419
420                 BT_DBG("Paired %d", dev_info->paired );
421
422                 tmp_value = g_variant_lookup_value(value, "RSSI", G_VARIANT_TYPE_INT32);
423                 dev_info->rssi = tmp_value ? g_variant_get_int32(tmp_value) : 0;
424                 g_variant_unref(tmp_value);
425
426                 tmp_value = g_variant_lookup_value(value, "LastAddrType", G_VARIANT_TYPE_UINT32);
427                 dev_info->addr_type = tmp_value ? g_variant_get_uint32(tmp_value) : 0;
428                 g_variant_unref(tmp_value);
429
430                 tmp_value = g_variant_lookup_value(value, "UUIDs", G_VARIANT_TYPE_STRING_ARRAY);
431                 __bt_get_uuids(tmp_value, dev_info);
432                 g_variant_unref(tmp_value);
433
434                 tmp_value = g_variant_lookup_value(value, "ManufacturerDataLen", G_VARIANT_TYPE_UINT32);
435                 dev_info->manufacturer_data_len = tmp_value ? g_variant_get_uint32(tmp_value) : 0;
436                 if (dev_info->manufacturer_data_len > BLUETOOTH_MANUFACTURER_DATA_LENGTH_MAX) {
437                         BT_ERR("manufacturer_data_len is too long(len = %d)", dev_info->manufacturer_data_len);
438                         dev_info->manufacturer_data_len = BLUETOOTH_MANUFACTURER_DATA_LENGTH_MAX;
439                 }
440                 g_variant_unref(tmp_value);
441
442                 tmp_value = g_variant_lookup_value(value, "ManufacturerData", G_VARIANT_TYPE_BYTESTRING);
443                 manufacturer_data = value ? (gchar *)g_variant_get_bytestring(tmp_value) : NULL;
444                 if (manufacturer_data) {
445                         if (dev_info->manufacturer_data_len > 0) {
446                                 dev_info->manufacturer_data = g_malloc0(dev_info->manufacturer_data_len);
447                                 memcpy(dev_info->manufacturer_data, manufacturer_data, dev_info->manufacturer_data_len);
448                         }
449                 }
450                 g_variant_unref(tmp_value);
451
452                 dev_info->address = g_strdup(address);
453                 dev_info->name = g_strdup(name);
454                 g_free(name);
455                 g_variant_unref(value);
456         } else {
457                 BT_ERR("result  is NULL\n");
458                 g_free(dev_info);
459                 dev_info = NULL;
460         }
461
462         return dev_info;
463 }
464
465 char *_bt_get_bonded_device_name(char *address)
466 {
467         bluetooth_device_address_t device_address = { {0} };
468         bluetooth_device_info_t dev_info;
469
470         retv_if(address == NULL, strdup(""));
471
472         _bt_convert_addr_string_to_type(device_address.addr, address);
473
474         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
475
476         _bt_get_bonded_device_info(&device_address, &dev_info);
477
478         return g_strdup(dev_info.device_name.name);
479 }
480
481 static gboolean __ignore_auto_pairing_request(const char *address)
482 {
483         gchar *buffer;
484         char **lines;
485         int i;
486         char lap_address[BT_LOWER_ADDRESS_LENGTH + 1] = {0,};
487         char *temp_buffer;
488         FILE *fp;
489         long size;
490         size_t result;
491
492         BT_DBG("+\n");
493
494         if (address == NULL)
495                 return FALSE;
496
497         /* Get the LAP(Lower Address part) */
498         /* User BT_LOWER_ADDRESS_LENGTH+1 for lap_address to accomodate
499              a "," */
500         snprintf(lap_address, sizeof(lap_address), ",%s", address);
501
502         fp = fopen(BT_AGENT_AUTO_PAIR_BLACKLIST_FILE, "r");
503
504         if (fp == NULL) {
505                 BT_ERR("fopen failed \n");
506                 return FALSE;
507         }
508
509         fseek(fp, 0, SEEK_END);
510         size = ftell(fp);
511         rewind(fp);
512
513         if (size < 0) {
514                 BT_ERR("Get file size failed \n");
515                 fclose(fp);
516                 return FALSE;
517         }
518
519         buffer = g_malloc0(sizeof(char) * size);
520         /* Fix : NULL_RETURNS */
521         if (buffer == NULL) {
522                 BT_ERR("Memory allocation error\n");
523                 fclose(fp);
524                 return FALSE;
525         }
526         result = fread((char *)buffer, 1, size, fp);
527         fclose(fp);
528         if (result != size) {
529                 BT_ERR("Read Error\n");
530                 g_free(buffer);
531                 return FALSE;
532         }
533
534         BT_DBG("Buffer = %s\n", buffer);
535
536         lines = g_strsplit_set(buffer, BT_AGENT_NEW_LINE, 0);
537         g_free(buffer);
538
539         if (lines == NULL)
540                 return FALSE;
541
542         /* Write the data and insert new device data */
543         for (i = 0; lines[i] != NULL; i++) {
544                 if (g_str_has_prefix(lines[i], "AddressBlacklist")) {
545                         temp_buffer = g_strconcat(lines[i], lap_address, NULL);
546                         g_free(lines[i]);
547                         lines[i] = temp_buffer;
548                 }
549         }
550         buffer = g_strjoinv(BT_AGENT_NEW_LINE, lines);
551         g_strfreev(lines);
552         /* Fix : NULL_RETURNS */
553         retv_if(buffer == NULL, FALSE);
554
555         fp = fopen(BT_AGENT_AUTO_PAIR_BLACKLIST_FILE, "w");
556
557         if (fp == NULL) {
558                 BT_ERR("fopen failed \n");
559                 g_free(buffer);
560                 return FALSE;
561         }
562
563         BT_DBG("Buffer = %s\n", buffer);
564         fwrite(buffer, 1, strlen(buffer), fp);
565         fclose(fp);
566
567         g_free(buffer);
568
569         BT_DBG("-\n");
570
571         return FALSE;
572 }
573
574 static int __bt_retry_bond(void)
575 {
576         BT_CHECK_PARAMETER(bonding_info, return);
577         BT_CHECK_PARAMETER(bonding_info->addr, return);
578
579         g_dbus_proxy_call(bonding_info->device_proxy, "Pair",
580                                 g_variant_new("(y)", bonding_info->conn_type),
581                                 G_DBUS_CALL_FLAGS_NONE,
582                                 BT_MAX_DBUS_TIMEOUT,
583                                 NULL,
584                                 (GAsyncReadyCallback)__bt_bond_device_cb,
585                                 NULL);
586
587         return BLUETOOTH_ERROR_NONE;
588 }
589
590
591 static int __bt_remove_and_bond(char *device_path)
592 {
593         GDBusProxy *adapter_proxy;
594         GVariant *result = NULL;
595         GError *err = NULL;
596
597         BT_CHECK_PARAMETER(bonding_info, return);
598         BT_CHECK_PARAMETER(bonding_info->addr, return);
599
600         retv_if(device_path == NULL, BLUETOOTH_ERROR_INTERNAL);
601
602         adapter_proxy = _bt_get_adapter_proxy();
603         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
604
605         result = g_dbus_proxy_call_sync(adapter_proxy, "UnpairDevice",
606                                 g_variant_new("(o)", device_path),
607                                 G_DBUS_CALL_FLAGS_NONE,
608                                 -1,
609                                 NULL,
610                                 &err);
611
612         if (err != NULL) {
613                 BT_ERR("UnpairDevice Fail: %s", err->message);
614                 g_error_free(err);
615                 return BLUETOOTH_ERROR_INTERNAL;
616         }
617
618         return __bt_retry_bond();
619 }
620
621 static int __bt_cancel_and_bond(void)
622 {
623         int ret = BLUETOOTH_ERROR_NONE;
624
625         ret = _bt_agent_reply_cancellation();
626         if (ret != BLUETOOTH_ERROR_NONE){
627                 BT_ERR("Fail to call reply cancellation");
628                 return ret;
629         }
630
631         return __bt_retry_bond();
632 }
633
634
635 static void __bt_bond_device_cb(GDBusProxy *proxy, GAsyncResult *res,
636                                         gpointer user_data)
637 {
638         int result = BLUETOOTH_ERROR_NONE;
639         GError *err = NULL;
640         GVariant *out_param1;
641         request_info_t *req_info;
642         bluetooth_device_info_t dev_info;
643         bt_remote_dev_info_t *remote_dev_info;
644         GVariant *manufacture_data;
645         GVariant *param;
646         const char *device_path;
647
648 #if !defined(LIBNOTIFY_SUPPORT) && !defined(LIBNOTIFICATION_SUPPORT)
649         /* Terminate ALL system popup */
650         syspopup_destroy_all();
651 #endif
652
653          g_dbus_proxy_call_finish(proxy, res, &err);
654
655         is_device_creating = FALSE;
656
657         if (bonding_info == NULL) {
658                 /* Send reply */
659                 BT_ERR("bonding_info == NULL");
660                 if (err)
661                         g_error_free(err);
662                 return;
663         }
664
665         req_info = _bt_get_request_info(bonding_info->req_id);
666         if (req_info == NULL) {
667                 BT_ERR("req_info == NULL");
668                 goto done;
669         }
670
671         device_path = g_dbus_proxy_get_object_path(proxy);
672
673         BT_DBG("device path: %s", device_path);
674
675         if (err != NULL) {
676                 g_dbus_error_strip_remote_error(err);
677                 BT_ERR("Error occured in CreateBonding [%s]", err->message);
678
679                 if (g_strrstr(err->message, "Already Exists")) {
680                         BT_INFO("Existing Bond, remove and retry");
681                         ret_if(__bt_remove_and_bond(device_path) == BLUETOOTH_ERROR_NONE);
682
683                         BT_INFO("Fail to retry bonding");
684
685                         result = BLUETOOTH_ERROR_PARING_FAILED;
686                 } else if (_bt_agent_is_canceled() ||
687                         g_strrstr(err->message, "Authentication Canceled")) {
688                         BT_INFO("Cancelled by USER");
689                         result = BLUETOOTH_ERROR_CANCEL_BY_USER;
690                 } else if (g_strrstr(err->message, "Authentication Rejected")) {
691                         BT_INFO("REJECTED");
692                         result = BLUETOOTH_ERROR_ACCESS_DENIED;
693                 } else if (g_strrstr(err->message, "In Progress")) {
694                         BT_INFO("Bond in progress, cancel and retry");
695                         ret_if(__bt_cancel_and_bond() == BLUETOOTH_ERROR_NONE);
696
697                         result = BLUETOOTH_ERROR_PARING_FAILED;
698                 } else if (g_strrstr(err->message, "Authentication Failed")) {
699                         BT_INFO("Authentication Failed");
700                         if (bonding_info->is_autopair == TRUE) {
701                                 _bt_set_autopair_status_in_bonding_info(FALSE);
702                                 __ignore_auto_pairing_request(bonding_info->addr);
703                         }
704                         result = BLUETOOTH_ERROR_AUTHENTICATION_FAILED;
705                 } else if (g_strrstr(err->message, "Page Timeout")) {
706                         BT_INFO("Page Timeout");
707                         /* This is the special case
708                              As soon as call bluetooth_bond_device, try to cancel bonding.
709                              In this case, before completing to call 'CreatePairedDevice' method
710                              the procedure is stopped. So 'Cancle' error is not return.
711                         */
712                         result = BLUETOOTH_ERROR_HOST_DOWN;
713                 } else if (g_strrstr(err->message, BT_TIMEOUT_MESSAGE)) {
714                         g_dbus_proxy_call_sync(proxy, "CancelDeviceCreation",
715                                                 g_variant_new("(s)", bonding_info->addr),
716                                                 G_DBUS_CALL_FLAGS_NONE,
717                                                 -1,
718                                                 NULL,
719                                                 NULL);
720
721                         result = BLUETOOTH_ERROR_INTERNAL;
722                 } else if (g_strrstr(err->message, "Connection Timeout")) {
723                         /* Pairing request timeout */
724                         result = BLUETOOTH_ERROR_TIMEOUT;
725                 } else if (g_strrstr(err->message, "Authentication Timeout")) {
726                         /* Pairing request timeout */
727                         result = BLUETOOTH_ERROR_TIMEOUT;
728                 } else {
729                         BT_DBG("Default case");
730                         result = BLUETOOTH_ERROR_PARING_FAILED;
731                 }
732         }
733
734         if (result == BLUETOOTH_ERROR_PARING_FAILED ||
735                         result == BLUETOOTH_ERROR_AUTHENTICATION_FAILED ||
736                         result == BLUETOOTH_ERROR_TIMEOUT ||
737                         result == BLUETOOTH_ERROR_HOST_DOWN) {
738                 bonding_info->result = result;
739 #ifdef TIZEN_WEARABLE
740                 __bt_launch_unable_to_pairing_syspopup(result);
741 #endif
742         }
743
744         g_object_unref(proxy);
745         bonding_info->device_proxy = NULL;
746
747         if (result != BLUETOOTH_ERROR_NONE)
748                 goto dbus_return;
749
750         remote_dev_info = _bt_get_remote_device_info(bonding_info->addr);
751         if (remote_dev_info == NULL)
752                 goto dbus_return;
753
754         GVariant *uuids = NULL;
755         GVariantBuilder *builder = NULL;
756         int i = 0;
757         builder = g_variant_builder_new(G_VARIANT_TYPE("as"));
758         for (i=0; i < remote_dev_info->uuid_count; i++) {
759                 g_variant_builder_add(builder, "s",
760                         remote_dev_info->uuids[i]);
761         }
762         uuids = g_variant_new("as", builder);
763         g_variant_builder_unref(builder);
764         manufacture_data = g_variant_new_from_data((const GVariantType *)"ay",
765                                                 remote_dev_info->manufacturer_data, remote_dev_info->manufacturer_data_len,
766                                                 TRUE, NULL, NULL);
767
768         param = g_variant_new("(isunsbub@asn@ay)",
769                         result,
770                         bonding_info->addr,
771                         remote_dev_info->class,
772                         remote_dev_info->rssi,
773                         remote_dev_info->name,
774                         remote_dev_info->paired,
775                         remote_dev_info->connected,
776                         remote_dev_info->trust,
777                         uuids,
778                         remote_dev_info->manufacturer_data_len,
779                         manufacture_data);
780
781
782         /* Send the event to application */
783         _bt_send_event(BT_ADAPTER_EVENT,
784                 BLUETOOTH_EVENT_BONDING_FINISHED,
785                 param);
786
787         _bt_free_device_info(remote_dev_info);
788
789 dbus_return:
790         if (req_info->context == NULL)
791                 goto done;
792
793         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
794         _bt_convert_addr_string_to_type(dev_info.device_address.addr,
795                                         bonding_info->addr);
796
797         if (_bt_adapter_get_status() != BT_ACTIVATED)
798                 result = BLUETOOTH_ERROR_NOT_IN_OPERATION;
799
800         out_param1 = g_variant_new_from_data((const GVariantType *)"ay",
801                 &dev_info, sizeof(bluetooth_device_info_t), TRUE, NULL, NULL);
802
803         g_dbus_method_invocation_return_value(req_info->context,
804                         g_variant_new("(iv)", result, out_param1));
805
806         g_variant_unref(out_param1);
807 //      g_variant_unref(out_param2);
808
809         _bt_delete_request_list(req_info->req_id);
810 done:
811         if (err)
812                 g_error_free(err);
813
814         _bt_agent_set_canceled(FALSE);
815
816
817         g_free(bonding_info->addr);
818         g_free(bonding_info);
819         bonding_info = NULL;
820 }
821
822 int _bt_bond_device(int request_id,
823                 bluetooth_device_address_t *device_address,
824                 unsigned short conn_type, GArray **out_param1)
825 {
826         GDBusProxy *proxy;
827         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
828         bluetooth_device_info_t dev_info;
829
830         GDBusConnection *conn;
831         char *device_path = NULL;
832         GDBusProxy *adapter_proxy;
833         GError *error = NULL;
834
835         BT_CHECK_PARAMETER(device_address, return);
836
837         if (bonding_info) {
838                 BT_ERR("Bonding in progress");
839
840                 memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
841                 memcpy(dev_info.device_address.addr, device_address->addr,
842                                 BLUETOOTH_ADDRESS_LENGTH);
843
844                 g_array_append_vals(*out_param1, &dev_info,
845                                 sizeof(bluetooth_device_info_t));
846
847                 return BLUETOOTH_ERROR_DEVICE_BUSY;
848         }
849
850         conn = _bt_get_system_gconn();
851         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
852
853         _bt_convert_addr_type_to_string(address, device_address->addr);
854
855         device_path = _bt_get_device_object_path(address);
856
857         if (device_path == NULL) {
858                 BT_ERR("No searched device");
859                 GVariant *ret = NULL;
860                 adapter_proxy = _bt_get_adapter_proxy();
861                 retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
862
863                 ret = g_dbus_proxy_call_sync(adapter_proxy, "CreateDevice",
864                                         g_variant_new("(s)", address),
865                                         G_DBUS_CALL_FLAGS_NONE,
866                                         -1,
867                                         NULL,
868                                         &error);
869
870                 if (error != NULL) {
871                         BT_ERR("CreateDevice Fail: %s", error->message);
872                         g_clear_error(&error);
873                 }
874                 if (ret)
875                         g_variant_unref(ret);
876                 device_path = _bt_get_device_object_path(address);
877                 if (device_path == NULL) {
878                         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
879                         memcpy(dev_info.device_address.addr, device_address->addr,
880                                         BLUETOOTH_ADDRESS_LENGTH);
881
882                         g_array_append_vals(*out_param1, &dev_info,
883                                         sizeof(bluetooth_device_info_t));
884
885                         return BLUETOOTH_ERROR_NOT_PAIRED;
886                 } else {
887                         BT_INFO("device_path is created[%s]", device_path);
888                 }
889         }
890
891         proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
892                                                                 NULL, BT_BLUEZ_NAME,
893                                                                 device_path, BT_DEVICE_INTERFACE,  NULL, NULL);
894
895         g_free(device_path);
896         retv_if(proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
897
898         bonding_info = g_malloc0(sizeof(bt_funcion_data_t));
899         bonding_info->addr = g_strdup(address);
900         bonding_info->req_id = request_id;
901
902         bonding_info->device_proxy = proxy;
903         bonding_info->conn_type = conn_type;
904
905         is_device_creating = TRUE;
906
907         g_dbus_proxy_call(proxy, "Pair",
908                                 g_variant_new("(y)", conn_type),
909                                 G_DBUS_CALL_FLAGS_NONE,
910                                 BT_MAX_DBUS_TIMEOUT,
911                                 NULL,
912                                 (GAsyncReadyCallback)__bt_bond_device_cb,
913                                 NULL);
914
915 /* TODO: We need to check if we can pair the specific device using 'pair' API of bluez 5.x */
916
917         return BLUETOOTH_ERROR_NONE;
918 /*fail:
919         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
920         _bt_convert_addr_string_to_type(dev_info.device_address.addr,
921                                         bonding_info->addr);
922
923         g_array_append_vals(*out_param1, &dev_info,
924                                 sizeof(bluetooth_device_info_t));
925
926         is_device_creating = FALSE;
927
928         g_free(bonding_info->addr);
929         g_free(bonding_info);
930         bonding_info = NULL;
931
932         return BLUETOOTH_ERROR_INTERNAL;*/
933 }
934
935 int _bt_cancel_bonding(void)
936 {
937         int ret = BLUETOOTH_ERROR_NONE;
938
939         retv_if(bonding_info == NULL, BLUETOOTH_ERROR_NOT_IN_OPERATION);
940
941         ret = _bt_agent_reply_cancellation();
942         if (ret != BLUETOOTH_ERROR_NONE){
943                 BT_ERR("Fail to call reply cancellation");
944                 return ret;
945         }
946
947         _bt_agent_set_canceled(TRUE);
948
949         return BLUETOOTH_ERROR_NONE;
950 }
951
952 static void __bt_unbond_cb(GDBusProxy *proxy, GAsyncResult *res,
953                                         gpointer user_data)
954 {
955         GError *err = NULL;
956         GVariant *out_param1;
957         int result = BLUETOOTH_ERROR_NONE;
958         bt_funcion_data_t *unbonding_info;
959         bluetooth_device_info_t dev_info;
960         request_info_t *req_info;
961
962         g_dbus_proxy_call_finish(proxy, res, &err);
963
964         unbonding_info = user_data;
965
966         if (unbonding_info == NULL) {
967                 /* Send reply */
968                 BT_ERR("unbonding_info == NULL");
969                 goto done;
970         }
971
972         req_info = _bt_get_request_info(unbonding_info->req_id);
973         if (req_info == NULL) {
974                 BT_ERR("req_info == NULL");
975                 goto done;
976         }
977
978         if (err != NULL) {
979                 BT_ERR("Error occured in RemoveBonding [%s]\n", err->message);
980                 result = BLUETOOTH_ERROR_INTERNAL;
981         }
982
983         if (req_info->context == NULL)
984                 goto done;
985
986         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
987         _bt_convert_addr_string_to_type(dev_info.device_address.addr,
988                                         unbonding_info->addr);
989
990         out_param1 = g_variant_new_from_data((const GVariantType *)"ay",
991                 &dev_info, sizeof(bluetooth_device_info_t), TRUE, NULL, NULL);
992
993         g_dbus_method_invocation_return_value(req_info->context,
994                         g_variant_new("(iv)", result, out_param1));
995
996
997         _bt_delete_request_list(req_info->req_id);
998
999 done:
1000         if (err)
1001                 g_error_free(err);
1002
1003         if (unbonding_info) {
1004                 g_free(unbonding_info->addr);
1005                 g_free(unbonding_info);
1006         }
1007 }
1008
1009 int _bt_unbond_device(int request_id,
1010                         bluetooth_device_address_t *device_address,
1011                         GArray **out_param1)
1012 {
1013         char *device_path = NULL;
1014         bt_funcion_data_t *unbonding_info;
1015         GDBusProxy *adapter_proxy = NULL;
1016         GDBusProxy *device_proxy = NULL;
1017         GDBusConnection *conn;
1018         int result = BLUETOOTH_ERROR_INTERNAL;
1019         bluetooth_device_info_t dev_info;
1020         GError *error = NULL;
1021         GVariant *ret = NULL;
1022
1023         BT_CHECK_PARAMETER(device_address, return);
1024
1025         adapter_proxy = _bt_get_adapter_proxy();
1026         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1027
1028         /* allocate user data so that it can be retrieved in callback */
1029         unbonding_info = g_malloc0(sizeof(bt_funcion_data_t));
1030         /* Fix : NULL_RETURNS */
1031         if (unbonding_info == NULL) {
1032                 BT_ERR("Memory not allocated !");
1033                 return BLUETOOTH_ERROR_MEMORY_ALLOCATION;
1034         }
1035
1036         unbonding_info->addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1037         unbonding_info->req_id = request_id;
1038
1039         _bt_convert_addr_type_to_string(unbonding_info->addr,
1040                                         device_address->addr);
1041
1042         device_path = _bt_get_device_object_path(unbonding_info->addr);
1043
1044         if (device_path == NULL) {
1045                 BT_ERR("No paired device");
1046                 result = BLUETOOTH_ERROR_NOT_PAIRED;
1047                 goto fail;
1048         }
1049
1050         conn = _bt_get_system_gconn();
1051         if (conn == NULL) {
1052                 BT_ERR("conn is NULL");
1053                 result = BLUETOOTH_ERROR_INTERNAL;
1054                 goto fail;
1055         }
1056
1057         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1058                                                                 NULL, BT_BLUEZ_NAME,
1059                                                                 device_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
1060
1061         if (device_proxy != NULL) {
1062
1063                 ret = g_dbus_proxy_call_sync(device_proxy, "Get",
1064                                         g_variant_new("(ss)", BT_DEVICE_INTERFACE, "Paired"),
1065                                         G_DBUS_CALL_FLAGS_NONE,
1066                                         -1,
1067                                         NULL,
1068                                         &error);
1069                 if (error) {
1070                         BT_ERR("Getting property failed: [%s]\n", error->message);
1071                         g_error_free(error);
1072                         result = BLUETOOTH_ERROR_NOT_PAIRED;
1073                         goto fail;
1074                 } else {
1075                         if (!ret) {
1076                                 BT_ERR("No paired device");
1077                                 g_object_unref(device_proxy);
1078                                 result = BLUETOOTH_ERROR_NOT_PAIRED;
1079                                 goto fail;
1080                         }
1081                         g_variant_unref(ret);
1082                 }
1083                 g_object_unref(device_proxy);
1084         }
1085
1086         g_dbus_proxy_call(adapter_proxy, "UnpairDevice",
1087                                 g_variant_new("(o)", device_path),
1088                                 G_DBUS_CALL_FLAGS_NONE,
1089                                 BT_MAX_DBUS_TIMEOUT,
1090                                 NULL,
1091                                 (GAsyncReadyCallback)__bt_unbond_cb,
1092                                 NULL);
1093
1094         g_free(device_path);
1095         return BLUETOOTH_ERROR_NONE;
1096
1097 fail:
1098         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
1099         _bt_convert_addr_string_to_type(dev_info.device_address.addr,
1100                                         unbonding_info->addr);
1101
1102         g_array_append_vals(*out_param1, &dev_info,
1103                                 sizeof(bluetooth_device_info_t));
1104         g_free(device_path);
1105         g_free(unbonding_info->addr);
1106         g_free(unbonding_info);
1107         return result;
1108 }
1109
1110 static void __bt_discover_cb(GDBusProxy *proxy, GAsyncResult *res,
1111                                         gpointer user_data)
1112 {
1113         GError *err = NULL;
1114         GVariant *out_param1;
1115         int result = BLUETOOTH_ERROR_NONE;
1116         bluetooth_device_info_t dev_info;
1117         bt_remote_dev_info_t *remote_dev_info;
1118         request_info_t *req_info;
1119         GVariant *uuid_list, *manufacture_data;
1120         GVariant *param;
1121         GVariantBuilder *builder = NULL;
1122         int i = 0;
1123
1124         g_dbus_proxy_call_finish(proxy, res, &err);
1125
1126         g_object_unref(proxy);
1127
1128         if (searching_info == NULL) {
1129                 /* Send reply */
1130                 BT_ERR("unbonding_info == NULL");
1131                 goto done;
1132         }
1133
1134         req_info = _bt_get_request_info(searching_info->req_id);
1135         if (req_info == NULL) {
1136                 BT_ERR("req_info == NULL");
1137                 goto done;
1138         }
1139
1140         if (err != NULL) {
1141                 g_dbus_error_strip_remote_error(err);
1142                 BT_ERR("Error occured in Proxy call [%s]\n", err->message);
1143
1144                 if (g_strrstr("Operation canceled", err->message)) {
1145                         result = BLUETOOTH_ERROR_CANCEL_BY_USER;
1146                 } else if (g_strrstr("In Progress", err->message)) {
1147                         result = BLUETOOTH_ERROR_IN_PROGRESS;
1148                 } else if (g_strrstr("Host is down", err->message)) {
1149                         result = BLUETOOTH_ERROR_HOST_DOWN;
1150                 } else {
1151                         result = BLUETOOTH_ERROR_CONNECTION_ERROR;
1152                 }
1153
1154                 if (result == BLUETOOTH_ERROR_HOST_DOWN ||
1155                      result == BLUETOOTH_ERROR_CONNECTION_ERROR) {
1156                         remote_dev_info = _bt_get_remote_device_info(searching_info->addr);
1157                         if (remote_dev_info && remote_dev_info->uuids != NULL &&
1158                              remote_dev_info->uuid_count > 0) {
1159                                 result = BLUETOOTH_ERROR_NONE;
1160                                 goto event;
1161                         }
1162                         _bt_free_device_info(remote_dev_info);
1163                 }
1164                 goto dbus_return;
1165         }
1166
1167         remote_dev_info = _bt_get_remote_device_info(searching_info->addr);
1168         if (remote_dev_info == NULL)
1169                 goto dbus_return;
1170
1171 event:
1172         builder = g_variant_builder_new(G_VARIANT_TYPE("as"));
1173         for (i=0; i < remote_dev_info->uuid_count; i++) {
1174                 g_variant_builder_add(builder, "s",
1175                         remote_dev_info->uuids[i]);
1176         }
1177         uuid_list = g_variant_new("as", builder);
1178         g_variant_builder_unref(builder);
1179         manufacture_data = g_variant_new_from_data((const GVariantType *)"ay",
1180                                                 remote_dev_info->manufacturer_data, remote_dev_info->manufacturer_data_len,
1181                                                 TRUE, NULL, NULL);
1182
1183         param = g_variant_new("(isunsbub@asn@ay)",
1184                         result,
1185                         searching_info->addr,
1186                         remote_dev_info->class,
1187                         remote_dev_info->rssi,
1188                         remote_dev_info->name,
1189                         remote_dev_info->paired,
1190                         remote_dev_info->connected,
1191                         remote_dev_info->trust,
1192                         uuid_list,
1193                         remote_dev_info->manufacturer_data_len,
1194                         manufacture_data);
1195
1196         /* Send the event to application */
1197         _bt_send_event(BT_ADAPTER_EVENT,
1198                 BLUETOOTH_EVENT_SERVICE_SEARCHED,
1199                 param);
1200
1201         _bt_free_device_info(remote_dev_info);
1202
1203 dbus_return:
1204         if (req_info->context == NULL)
1205                 goto done;
1206
1207         memset(&dev_info, 0x00, sizeof(bluetooth_device_info_t));
1208         _bt_convert_addr_string_to_type(dev_info.device_address.addr,
1209                                         searching_info->addr);
1210
1211         out_param1 = g_variant_new_from_data((const GVariantType *)"ay",
1212                 &dev_info, sizeof(bluetooth_device_info_t), TRUE, NULL, NULL);
1213
1214         g_dbus_method_invocation_return_value(req_info->context,
1215                         g_variant_new("(iv)", result, out_param1));
1216
1217
1218         _bt_delete_request_list(req_info->req_id);
1219 done:
1220         if (err)
1221                 g_error_free(err);
1222
1223         if (searching_info) {
1224                 g_free(searching_info->addr);
1225                 g_free(searching_info);
1226                 searching_info = NULL;
1227         }
1228 }
1229
1230 int _bt_search_device(int request_id,
1231                         bluetooth_device_address_t *device_address)
1232 {
1233         char *device_path = NULL;
1234         GDBusProxy *device_proxy = NULL;
1235         GDBusConnection *conn;
1236
1237         GDBusProxy *adapter_proxy;
1238         int result = BLUETOOTH_ERROR_INTERNAL;
1239
1240         BT_CHECK_PARAMETER(device_address, return);
1241
1242         if (bonding_info) {
1243                 BT_ERR("Bonding in progress");
1244                 return BLUETOOTH_ERROR_DEVICE_BUSY;
1245         }
1246
1247         if (searching_info) {
1248                 BT_ERR("Service searching in progress");
1249                 return BLUETOOTH_ERROR_DEVICE_BUSY;
1250         }
1251
1252         adapter_proxy = _bt_get_adapter_proxy();
1253         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1254
1255         /* allocate user data so that it can be retrieved in callback */
1256         searching_info = g_malloc0(sizeof(bt_funcion_data_t));
1257         searching_info->addr = g_malloc0(BT_ADDRESS_STRING_SIZE);
1258         searching_info->req_id = request_id;
1259
1260         _bt_convert_addr_type_to_string(searching_info->addr,
1261                                         device_address->addr);
1262
1263         conn = _bt_get_system_gconn();
1264         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1265
1266
1267         device_path = _bt_get_device_object_path(searching_info->addr);
1268
1269         if (device_path == NULL) {
1270                 BT_ERR("No paired device");
1271                 result = BLUETOOTH_ERROR_NOT_PAIRED;
1272                 goto fail;
1273         }
1274
1275         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1276                                                                 NULL, BT_BLUEZ_NAME,
1277                                                                 device_path, BT_DEVICE_INTERFACE,  NULL, NULL);
1278         g_free(device_path);
1279         if (device_proxy == NULL) {
1280                 result = BLUETOOTH_ERROR_INTERNAL;
1281                 goto fail;
1282         }
1283
1284         g_dbus_proxy_call(device_proxy, "DiscoverServices",
1285                         g_variant_new("(s)", ""),
1286                         G_DBUS_CALL_FLAGS_NONE,
1287                         BT_MAX_DBUS_TIMEOUT,
1288                         NULL,
1289                         (GAsyncReadyCallback)__bt_discover_cb,
1290                         searching_info);
1291
1292         searching_info->device_proxy = device_proxy;
1293
1294         return BLUETOOTH_ERROR_NONE;
1295 fail:
1296         g_free(searching_info->addr);
1297         g_free(searching_info);
1298         searching_info = NULL;
1299         return result;
1300 }
1301
1302 int _bt_cancel_search_device(void)
1303 {
1304         GError *err = NULL;
1305
1306         retv_if(searching_info == NULL, BLUETOOTH_ERROR_NOT_IN_OPERATION);
1307
1308         if (searching_info->device_proxy) {
1309                 g_dbus_proxy_call_sync(searching_info->device_proxy, "CancelDiscovery",
1310                                 NULL,
1311                                 G_DBUS_CALL_FLAGS_NONE,
1312                                 -1,
1313                                 NULL,
1314                                 &err);
1315         }
1316         __bt_cancel_search_service_done();
1317
1318         return BLUETOOTH_ERROR_NONE;
1319 }
1320
1321 int _bt_set_alias(bluetooth_device_address_t *device_address,
1322                                       const char *alias)
1323 {
1324         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
1325         gchar *device_path = NULL;
1326         GDBusProxy *adapter_proxy;
1327         GDBusProxy *device_proxy;
1328         GError *error = NULL;
1329         GDBusConnection *conn;
1330
1331         BT_CHECK_PARAMETER(device_address, return);
1332         BT_CHECK_PARAMETER(alias, return);
1333
1334         adapter_proxy = _bt_get_adapter_proxy();
1335         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1336
1337         conn = _bt_get_system_gconn();
1338         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1339
1340         _bt_convert_addr_type_to_string(address, device_address->addr);
1341
1342         device_path = _bt_get_device_object_path(address);
1343
1344         if (device_path == NULL) {
1345                 BT_ERR("No paired device");
1346                 return BLUETOOTH_ERROR_NOT_PAIRED;
1347         }
1348
1349         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1350                                                                 NULL, BT_BLUEZ_NAME,
1351                                                                 device_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
1352
1353         g_free(device_path);
1354         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1355
1356         g_dbus_proxy_call_sync(device_proxy, "Set",
1357                                 g_variant_new("(ssv)", BT_DEVICE_INTERFACE,  "Alias", g_variant_new("s", alias)),
1358                                 G_DBUS_CALL_FLAGS_NONE,
1359                                 -1,
1360                                 NULL,
1361                                 &error);
1362
1363         g_object_unref(device_proxy);
1364
1365         if (error) {
1366                  BT_ERR("SetProperty error: [%s]", error->message);
1367                  g_error_free(error);
1368                  return BLUETOOTH_ERROR_INTERNAL;
1369         }
1370
1371         return BLUETOOTH_ERROR_NONE;
1372 }
1373
1374 int _bt_set_authorization(bluetooth_device_address_t *device_address,
1375                                       gboolean authorize)
1376 {
1377         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
1378         gchar *device_path = NULL;
1379         GDBusProxy *device_proxy;
1380         gboolean previous_value;
1381         GError *error = NULL;
1382         GDBusConnection *conn;
1383         GVariant *result = NULL;
1384         int ret = BLUETOOTH_ERROR_NONE;
1385
1386         BT_CHECK_PARAMETER(device_address, return);
1387
1388         conn = _bt_get_system_gconn();
1389         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1390
1391         _bt_convert_addr_type_to_string(address, device_address->addr);
1392
1393         device_path = _bt_get_device_object_path(address);
1394
1395         if (device_path == NULL) {
1396                 BT_ERR("No paired device");
1397                 return BLUETOOTH_ERROR_NOT_PAIRED;
1398         }
1399
1400         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1401                                                                 NULL, BT_BLUEZ_NAME,
1402                                                                 device_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
1403
1404         g_free(device_path);
1405         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1406
1407         result = g_dbus_proxy_call_sync(device_proxy, "Get",
1408                                 g_variant_new("(ss)", BT_DEVICE_INTERFACE, "Trusted" ),
1409                                 G_DBUS_CALL_FLAGS_NONE,
1410                                 -1,
1411                                 NULL,
1412                                 &error);
1413         if (error != NULL) {
1414                 BT_ERR("Getting property failed: [%s]\n", error->message);
1415                 g_error_free(error);
1416                 g_object_unref(device_proxy);
1417                 return BLUETOOTH_ERROR_INTERNAL;
1418         }
1419
1420         previous_value = g_variant_get_boolean(result);
1421         g_variant_unref(result);
1422         /* If the input is same with previous value, return error. */
1423         if (previous_value == authorize) {
1424                 BT_ERR("Same value: %d", previous_value);
1425                 g_object_unref(device_proxy);
1426                 ret = BLUETOOTH_ERROR_INVALID_PARAM;
1427                 goto done;
1428         }
1429
1430         g_dbus_proxy_call_sync(device_proxy, "Set",
1431                                  g_variant_new("(ssv)", BT_DEVICE_INTERFACE, "Trusted", g_variant_new("b",authorize)),
1432                                  G_DBUS_CALL_FLAGS_NONE,
1433                                  -1,
1434                                  NULL,
1435                                  &error);
1436
1437         g_object_unref(device_proxy);
1438         if (error) {
1439                  BT_ERR("SetProperty error: [%s]", error->message);
1440                  g_error_free(error);
1441                  ret = BLUETOOTH_ERROR_INTERNAL;
1442         }
1443 done:
1444         return ret;
1445 }
1446
1447 int _bt_is_gatt_connected(bluetooth_device_address_t *device_address,
1448                         gboolean *is_connected)
1449 {
1450         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
1451         char *object_path = NULL;
1452
1453         GDBusProxy *device_proxy;
1454         GError *error = NULL;
1455         GVariant *value;
1456         GVariant *tmp_value;
1457         GDBusConnection *conn;
1458         GVariant *result = NULL;
1459         int ret = BLUETOOTH_ERROR_NONE;
1460
1461         BT_CHECK_PARAMETER(device_address, return);
1462
1463         conn = _bt_get_system_gconn();
1464         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1465
1466         _bt_convert_addr_type_to_string(address, device_address->addr);
1467
1468         object_path = _bt_get_device_object_path(address);
1469         retv_if(object_path == NULL, BLUETOOTH_ERROR_NOT_PAIRED);
1470
1471         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1472                                                                 NULL, BT_BLUEZ_NAME,
1473                                                                 object_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
1474         g_free(object_path);
1475         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1476
1477         result = g_dbus_proxy_call_sync(device_proxy, "GetAll",
1478                           g_variant_new("(s)", BT_DEVICE_INTERFACE),
1479                                 G_DBUS_CALL_FLAGS_NONE,
1480                                 -1,
1481                                 NULL,
1482                                 &error);
1483         if (error != NULL || result == NULL) {
1484                 if (error != NULL) {
1485                         BT_ERR("Error occured in Proxy call [%s]\n", error->message);
1486                         g_error_free(error);
1487                 }
1488                 g_object_unref(device_proxy);
1489                 return BLUETOOTH_ERROR_INTERNAL;
1490         }
1491
1492         g_variant_get(result , "(@a{sv})", &value);
1493         g_variant_unref(result);
1494
1495         tmp_value = g_variant_lookup_value (value, "GattConnected", G_VARIANT_TYPE_BOOLEAN);
1496
1497         if (tmp_value == NULL) {
1498                 g_object_unref(device_proxy);
1499                 return BLUETOOTH_ERROR_INTERNAL;
1500         }
1501
1502         *is_connected = g_variant_get_boolean (tmp_value);
1503
1504         BT_DBG("gatt is connected : %d", *is_connected);
1505         g_variant_unref(tmp_value);
1506         g_variant_unref(value);
1507         g_object_unref(device_proxy);
1508
1509         return ret;
1510 }
1511
1512 int _bt_is_device_connected(bluetooth_device_address_t *device_address,
1513                         int connection_type, gboolean *is_connected)
1514 {
1515         char *object_path = NULL;
1516         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
1517         GDBusProxy *device_proxy = NULL;
1518         GDBusProxy *adapter_proxy = NULL;
1519         GDBusConnection *conn;
1520         GError *error = NULL;
1521         GVariant *tmp_value = NULL;
1522         GVariant *value = NULL;
1523         GVariant *result = NULL;
1524         char *uuid = NULL;
1525
1526         retv_if(device_address == NULL, BLUETOOTH_ERROR_INVALID_PARAM);
1527         retv_if(is_connected == NULL, BLUETOOTH_ERROR_INVALID_PARAM);
1528
1529         *is_connected = FALSE;
1530         BT_DBG("connection_type: %d", connection_type);
1531         if (connection_type == BLUETOOTH_RFCOMM_SERVICE)
1532                 return _bt_rfcomm_is_device_connected(device_address,
1533                                                 is_connected);
1534         else if (connection_type == BLUETOOTH_GATT_SERVICE)
1535                 return _bt_is_gatt_connected(device_address, is_connected);
1536
1537         adapter_proxy = _bt_get_adapter_proxy();
1538         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1539
1540         conn = _bt_get_system_gconn();
1541         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1542
1543         _bt_convert_addr_type_to_string(address, device_address->addr);
1544
1545         if(connection_type == BLUETOOTH_NAP_SERVER_SERVICE)     {
1546                 object_path = _bt_get_adapter_path();
1547                 device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1548                                                                         NULL, BT_BLUEZ_NAME,
1549                                                                         object_path, BT_NETWORK_SERVER_INTERFACE,  NULL, NULL);
1550                 g_free(object_path);
1551                 if (device_proxy == NULL) {
1552                         BT_DBG("Device don't have this service");
1553                         return BLUETOOTH_ERROR_NONE;
1554                 }
1555
1556                 result = g_dbus_proxy_call_sync(device_proxy, "GetProperties",
1557                                         g_variant_new("(s)", address),
1558                                         G_DBUS_CALL_FLAGS_NONE,
1559                                         -1,
1560                                         NULL,
1561                                         &error);
1562
1563                 if (result == NULL) {
1564                         BT_ERR("Error occured in Proxy call");
1565                         if (error) {
1566                                 BT_ERR("Error occured in Proxy call [%s]\n", error->message);
1567                                 g_error_free(error);
1568                         }
1569                         g_object_unref(device_proxy);
1570                         return BLUETOOTH_ERROR_NONE;
1571                 }
1572                 g_variant_get(result , "(@a{sv})", &value);
1573                 g_variant_unref(result);
1574
1575                 if (value) {
1576                         tmp_value = g_variant_lookup_value(value,
1577                                                         "Connected",
1578                                                         G_VARIANT_TYPE_BOOLEAN);
1579                         if (tmp_value) {
1580                                 *is_connected = g_variant_get_boolean(tmp_value);
1581                                 g_variant_unref(tmp_value);
1582                         }
1583                         g_variant_unref(value);
1584                 }
1585         } else if(connection_type == BLUETOOTH_NAP_SERVICE) {
1586                 return _bt_is_network_connected(_bt_get_net_conn(),
1587                                                 device_address->addr, is_connected);
1588         } else {
1589                 uuid = _bt_get_profile_uuid128(connection_type);
1590                 if (uuid == NULL) {
1591                         BT_ERR("uuid is NULL");
1592                         return BLUETOOTH_ERROR_NONE;
1593                 }
1594
1595                 BT_DBG("uuid: %s", uuid);
1596
1597                 object_path = _bt_get_device_object_path(address);
1598                 retv_if(object_path == NULL, BLUETOOTH_ERROR_NOT_PAIRED);
1599                 BT_DBG("object_path: %s", object_path);
1600                 device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1601                                                                         NULL, BT_BLUEZ_NAME,
1602                                                                         object_path, BT_DEVICE_INTERFACE,  NULL, NULL);
1603                 g_free(object_path);
1604                 if (device_proxy == NULL) {
1605                         BT_DBG("Device don't have this service");
1606                         g_free(uuid);
1607                         return BLUETOOTH_ERROR_NONE;
1608                 }
1609
1610                 result = g_dbus_proxy_call_sync(device_proxy, "IsConnectedProfile",
1611                                         g_variant_new("(s)", uuid),
1612                                         G_DBUS_CALL_FLAGS_NONE,
1613                                         -1,
1614                                         NULL,
1615                                         &error);
1616
1617                 if (result == NULL) {
1618                         BT_ERR("Error occured in Proxy call");
1619                         if (error) {
1620                                 BT_ERR("Error occured in Proxy call [%s]\n", error->message);
1621                                 g_error_free(error);
1622                         }
1623                 } else {
1624                         g_variant_get(result, "(b)", is_connected);
1625                         g_free(uuid);
1626                         g_variant_unref(result);
1627                 }
1628         }
1629
1630         g_object_unref(device_proxy);
1631         return BLUETOOTH_ERROR_NONE;
1632 }
1633
1634 int _bt_get_connected_link(bluetooth_device_address_t *device_address,
1635                         bluetooth_connected_link_t *connected)
1636 {
1637         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
1638         char *object_path = NULL;
1639
1640         GDBusProxy *device_proxy;
1641         GError *error = NULL;
1642         GDBusConnection *conn;
1643         GVariant *tmp_value = NULL;
1644         GVariant *value = NULL;
1645         GVariant *result = NULL;
1646
1647         int ret = BLUETOOTH_ERROR_NONE;
1648
1649         BT_CHECK_PARAMETER(device_address, return);
1650
1651         conn = _bt_get_system_gconn();
1652         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1653
1654         _bt_convert_addr_type_to_string(address, device_address->addr);
1655
1656         object_path = _bt_get_device_object_path(address);
1657         retv_if(object_path == NULL, BLUETOOTH_ERROR_NOT_PAIRED);
1658
1659         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1660                                                                 NULL, BT_BLUEZ_NAME,
1661                                                                 object_path, BT_PROPERTIES_INTERFACE,  NULL, NULL);
1662         g_free(object_path);
1663         if (device_proxy == NULL) {
1664                 *connected = BLUETOOTH_CONNECTED_LINK_NONE;
1665                 return BLUETOOTH_ERROR_NONE;
1666         }
1667
1668         result = g_dbus_proxy_call_sync(device_proxy, "GetAll",
1669                                         g_variant_new("(s)", BT_DEVICE_INTERFACE),
1670                                         G_DBUS_CALL_FLAGS_NONE,
1671                                         -1,
1672                                         NULL,
1673                                         &error);
1674
1675         if (error != NULL) {
1676                 BT_ERR("Error occured in Proxy call [%s]\n", error->message);
1677                 g_error_free(error);
1678                 g_object_unref(device_proxy);
1679                 return BLUETOOTH_ERROR_INTERNAL;
1680         }
1681
1682         g_variant_get(result , "(@a{sv})", &value);
1683         g_variant_unref(result);
1684
1685         tmp_value = g_variant_lookup_value (value, "Connected", G_VARIANT_TYPE_BOOLEAN);
1686         if (tmp_value != NULL) {
1687                 g_object_unref(device_proxy);
1688                 g_variant_unref(value);
1689                 return BLUETOOTH_ERROR_INTERNAL;
1690         }
1691         *connected = g_variant_get_boolean (tmp_value);
1692         g_variant_unref(tmp_value);
1693         g_variant_unref(value);
1694         g_object_unref(device_proxy);
1695
1696         return ret;
1697 }
1698
1699 static void __bt_connect_le_device_cb(GDBusProxy *proxy, GAsyncResult *res,
1700                                         gpointer user_data)
1701 {
1702         GError *err = NULL;
1703         GVariant *out_param1;
1704         request_info_t *req_info;
1705         bluetooth_device_address_t device_addr = { {0} };
1706         int result = BLUETOOTH_ERROR_NONE;
1707
1708         BT_DBG("+");
1709         g_dbus_proxy_call_finish(proxy, res, &err);
1710
1711         /* When cb datas of lescan are received, back to parameta values for Web TCT */
1712         if ( _bt_is_set_scan_parameter() == FALSE) {
1713                 bluetooth_le_scan_params_t scan_params;
1714                 BT_ERR("set parameter of lescan when receive cb data");
1715                 scan_params.type = BT_LE_ACTIVE_SCAN;
1716                 scan_params.interval = 5000;
1717                 scan_params.window = 500;
1718                 _bt_set_scan_parameters(&scan_params);
1719         }
1720
1721         req_info = _bt_get_request_info(le_connection_info->req_id);
1722         if (req_info == NULL) {
1723                 BT_ERR("req_info == NULL");
1724                 g_object_unref(proxy);
1725                 le_connection_info->device_proxy = NULL;
1726                 goto done;
1727         }
1728
1729         if (err != NULL) {
1730                 BT_ERR("Error occured in ConnectLE [%s]", err->message);
1731
1732                 if (g_strrstr(err->message, "NotSupported")) {
1733                         BT_INFO("Connection Not Supported");
1734                         result = BLUETOOTH_ERROR_CONNECTION_ERROR;
1735                 } else if (g_strrstr(err->message, "AlreadyConnected")) {
1736                         BT_INFO("Connection already exists");
1737                         result = BLUETOOTH_ERROR_ALREADY_CONNECT;
1738                 } else if (g_strrstr(err->message, "Connection Timeout")) {
1739                         BT_INFO("Connection Timeout");
1740                         result = BLUETOOTH_ERROR_TIMEOUT;
1741                 } else {
1742                         BT_DBG("Default case");
1743                         result = BLUETOOTH_ERROR_CONNECTION_ERROR;
1744                 }
1745         }
1746
1747         g_object_unref(proxy);
1748         le_connection_info->device_proxy = NULL;
1749
1750         _bt_convert_addr_string_to_type(device_addr.addr,
1751                                         le_connection_info->addr);
1752
1753         if (req_info->context == NULL)
1754                 goto done;
1755
1756         out_param1 = g_variant_new_from_data((const GVariantType *)"ay",
1757                         &device_addr, sizeof(bluetooth_device_address_t), TRUE, NULL, NULL);
1758         g_dbus_method_invocation_return_value(req_info->context,
1759                         g_variant_new("(iv)", result, out_param1));
1760
1761         g_variant_unref(out_param1);
1762
1763         _bt_delete_request_list(req_info->req_id);
1764 done:
1765         if (err)
1766                 g_error_free(err);
1767
1768         g_free(le_connection_info->addr);
1769         g_free(le_connection_info);
1770         le_connection_info = NULL;
1771
1772         BT_DBG("-");
1773 }
1774
1775 int _bt_connect_le_device(int request_id,
1776                 const bluetooth_device_address_t *bd_addr,
1777                 gboolean auto_connect)
1778 {
1779         char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
1780         gchar *device_path = NULL;
1781         GDBusProxy *device_proxy = NULL;
1782         GDBusProxy *adapter_proxy;
1783         GDBusConnection *conn;
1784         int ret = BLUETOOTH_ERROR_NONE;
1785
1786         BT_CHECK_PARAMETER(bd_addr, return);
1787
1788         _bt_convert_addr_type_to_string(device_address,
1789                         (unsigned char *)bd_addr->addr);
1790
1791         if (le_connection_info) {
1792                 BT_ERR("LE Connection in progress");
1793                 return BLUETOOTH_ERROR_DEVICE_BUSY;
1794         }
1795
1796 /* When auto_connect is true, Web TCT fail. It need to be checked */
1797         auto_connect = FALSE;
1798
1799         conn = _bt_get_system_gconn();
1800         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1801
1802         adapter_proxy = _bt_get_adapter_proxy();
1803         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1804
1805         device_path = _bt_get_device_object_path(device_address);
1806         if (device_path == NULL) {
1807                 BT_DBG("device_path NULL");
1808                 ret = BLUETOOTH_ERROR_INTERNAL;
1809                 return ret;
1810         }
1811
1812         retv_if(device_path == NULL, BLUETOOTH_ERROR_INTERNAL);
1813
1814         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1815                                                                 NULL, BT_BLUEZ_NAME,
1816                                                                 device_path, BT_DEVICE_INTERFACE,  NULL, NULL);
1817         g_free(device_path);
1818         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1819
1820
1821         le_connection_info = g_malloc0(sizeof(bt_funcion_data_t));
1822         le_connection_info->addr = g_strdup(device_address);
1823         le_connection_info->req_id = request_id;
1824         le_connection_info->device_proxy = device_proxy;
1825
1826 /* The connection between Ble device and TM1 often fail. So It need to be set for Web TCT*/
1827         if ( _bt_is_set_scan_parameter() == FALSE) {
1828                 BT_ERR("set parameter of le scan when connect device");
1829                 bluetooth_le_scan_params_t scan_params;
1830                 scan_params.type = BT_LE_ACTIVE_SCAN;
1831                 scan_params.interval = 60;
1832                 scan_params.window = 60;
1833                 _bt_set_scan_parameters(&scan_params);
1834         }
1835
1836         g_dbus_proxy_call(device_proxy, "ConnectLE",
1837                                  g_variant_new("(b)", auto_connect),
1838                                  G_DBUS_CALL_FLAGS_NONE,
1839                                  BT_MAX_DBUS_TIMEOUT,
1840                                  NULL,
1841                                  (GAsyncReadyCallback)__bt_connect_le_device_cb,
1842                                  NULL);
1843
1844
1845         return ret;
1846 }
1847
1848 static void __bt_disconnect_le_device_cb(GDBusProxy *proxy, GAsyncResult *res,
1849                                         gpointer user_data)
1850 {
1851         GError *err = NULL;
1852         GVariant *out_param1;
1853         request_info_t *req_info;
1854         bt_funcion_data_t *le_disconnection_info = user_data;
1855         bluetooth_device_address_t device_addr = { {0} };
1856         int result = BLUETOOTH_ERROR_NONE;
1857
1858         BT_DBG("+");
1859         g_dbus_proxy_call_finish(proxy, res, &err);
1860
1861         req_info = _bt_get_request_info(le_disconnection_info->req_id);
1862         if (req_info == NULL) {
1863                 BT_ERR("req_info == NULL");
1864                 g_object_unref(proxy);
1865                 le_disconnection_info->device_proxy = NULL;
1866                 goto done;
1867         }
1868
1869         if (err != NULL) {
1870                 BT_ERR("Error occured in DisconnectLE [%s]", err->message);
1871
1872                 if (g_strrstr(err->message, "NotSupported")) {
1873                         BT_INFO("Connection Not Supported");
1874                         result = BLUETOOTH_ERROR_CONNECTION_ERROR;
1875                 } else if (g_strrstr(err->message, "NotConnected")) {
1876                         BT_INFO("Connection does not exists");
1877                         result = BLUETOOTH_ERROR_NOT_CONNECTED;
1878                 } else if (g_strrstr(err->message, "Cancelled")) {
1879                         BT_INFO("User Cancelled");
1880                         result = BLUETOOTH_ERROR_CANCEL_BY_USER;
1881                 } else {
1882                         BT_DBG("Default case");
1883                         result = BLUETOOTH_ERROR_CONNECTION_ERROR;
1884                 }
1885         }
1886
1887         g_object_unref(proxy);
1888         le_disconnection_info->device_proxy = NULL;
1889
1890         _bt_convert_addr_string_to_type(device_addr.addr,
1891                                         le_disconnection_info->addr);
1892
1893         if (req_info->context == NULL)
1894                 goto done;
1895
1896         out_param1 = g_variant_new_from_data((const GVariantType *)"ay",
1897                 &device_addr, sizeof(bluetooth_device_address_t), TRUE, NULL, NULL);
1898
1899         g_dbus_method_invocation_return_value(req_info->context,
1900                         g_variant_new("(iv)", result, out_param1));
1901
1902         g_variant_unref(out_param1);
1903
1904         _bt_delete_request_list(req_info->req_id);
1905 done:
1906         if (err)
1907                 g_error_free(err);
1908
1909         g_free(le_disconnection_info->addr);
1910         g_free(le_disconnection_info);
1911         le_disconnection_info = NULL;
1912
1913         BT_DBG("-");
1914 }
1915
1916 int _bt_disconnect_le_device(int request_id,
1917                 const bluetooth_device_address_t *bd_addr)
1918 {
1919         char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
1920         gchar *device_path = NULL;
1921         GDBusProxy *device_proxy = NULL;
1922         GDBusProxy *adapter_proxy;
1923         GDBusConnection *conn;
1924         int ret = BLUETOOTH_ERROR_NONE;
1925         bt_funcion_data_t *le_disconnection_info = NULL;
1926
1927         BT_CHECK_PARAMETER(bd_addr, return);
1928
1929         _bt_convert_addr_type_to_string(device_address,
1930                         (unsigned char *)bd_addr->addr);
1931
1932         conn = _bt_get_system_gconn();
1933         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1934
1935         adapter_proxy = _bt_get_adapter_proxy();
1936         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1937
1938         device_path = _bt_get_device_object_path(device_address);
1939         if (device_path == NULL) {
1940                 BT_DBG("device_path NULL");
1941                 ret = BLUETOOTH_ERROR_INTERNAL;
1942                 return ret;
1943         }
1944
1945         retv_if(device_path == NULL, BLUETOOTH_ERROR_INTERNAL);
1946
1947         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
1948                                                                 NULL, BT_BLUEZ_NAME,
1949                                                                 device_path, BT_DEVICE_INTERFACE,  NULL, NULL);
1950         g_free(device_path);
1951         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1952
1953         le_disconnection_info = g_malloc0(sizeof(bt_funcion_data_t));
1954         le_disconnection_info->addr = g_strdup(device_address);
1955         le_disconnection_info->req_id = request_id;
1956         le_disconnection_info->device_proxy = device_proxy;
1957
1958         g_dbus_proxy_call(device_proxy, "DisconnectLE",
1959                                  NULL,
1960                                  G_DBUS_CALL_FLAGS_NONE,
1961                                  BT_MAX_DBUS_TIMEOUT,
1962                                  NULL,
1963                                  (GAsyncReadyCallback)__bt_disconnect_le_device_cb,
1964                                  le_disconnection_info);
1965
1966         return ret;
1967 }
1968
1969 int _bt_connect_le_ipsp_device(const bluetooth_device_address_t *bd_addr)
1970 {
1971         char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
1972         gchar *device_path = NULL;
1973         GError *error = NULL;
1974         GDBusProxy *device_proxy = NULL;
1975         GDBusProxy *adapter_proxy;
1976         GDBusConnection *conn;
1977         int ret = BLUETOOTH_ERROR_NONE;
1978
1979         BT_CHECK_PARAMETER(bd_addr, return);
1980
1981         _bt_convert_addr_type_to_string(device_address,
1982                         (unsigned char *)bd_addr->addr);
1983
1984         conn = _bt_get_system_gconn();
1985         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
1986
1987         adapter_proxy = _bt_get_adapter_proxy();
1988         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
1989
1990         device_path = _bt_get_device_object_path(device_address);
1991         if (device_path == NULL) {
1992                 BT_DBG("device_path NULL");
1993                 ret = BLUETOOTH_ERROR_INTERNAL;
1994                 return ret;
1995         }
1996
1997         retv_if(device_path == NULL, BLUETOOTH_ERROR_INTERNAL);
1998
1999         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
2000                                                         NULL, BT_BLUEZ_NAME,
2001                                                         device_path, BT_DEVICE_INTERFACE,  NULL, NULL);
2002         g_free(device_path);
2003         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2004
2005         g_dbus_proxy_call_sync(device_proxy, "ConnectIpsp",
2006                                 NULL,
2007                                 G_DBUS_CALL_FLAGS_NONE,
2008                                 -1,
2009                                 NULL,
2010                                 &error);
2011         if (error) {
2012                 BT_ERR("ConnectIpsp Call Error %s[%s]", error->message, device_address);
2013                 g_error_free(error);
2014                 g_object_unref(device_proxy);
2015                 return BLUETOOTH_ERROR_INTERNAL;
2016         }
2017
2018         g_object_unref(device_proxy);
2019
2020         return ret;
2021 }
2022
2023 int _bt_disconnect_le_ipsp_device(const bluetooth_device_address_t *bd_addr)
2024 {
2025         char device_address[BT_ADDRESS_STRING_SIZE] = { 0 };
2026         gchar *device_path = NULL;
2027         GError *error = NULL;
2028         GDBusProxy *device_proxy = NULL;
2029         GDBusProxy *adapter_proxy;
2030         GDBusConnection *conn;
2031         int ret = BLUETOOTH_ERROR_NONE;
2032
2033         BT_CHECK_PARAMETER(bd_addr, return);
2034
2035         _bt_convert_addr_type_to_string(device_address,
2036                         (unsigned char *)bd_addr->addr);
2037
2038         conn = _bt_get_system_gconn();
2039         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
2040
2041         adapter_proxy = _bt_get_adapter_proxy();
2042         retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2043
2044         device_path = _bt_get_device_object_path(device_address);
2045         if (device_path == NULL) {
2046                 BT_DBG("device_path NULL");
2047                 ret = BLUETOOTH_ERROR_INTERNAL;
2048                 return ret;
2049         }
2050
2051         retv_if(device_path == NULL, BLUETOOTH_ERROR_INTERNAL);
2052
2053         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
2054                                                         NULL, BT_BLUEZ_NAME,
2055                                                         device_path, BT_DEVICE_INTERFACE,  NULL, NULL);
2056         g_free(device_path);
2057         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2058
2059         g_dbus_proxy_call_sync(device_proxy, "DisconnectIpsp",
2060                                 NULL,
2061                                 G_DBUS_CALL_FLAGS_NONE,
2062                                 -1,
2063                                 NULL,
2064                                 &error);
2065         if (error) {
2066                 BT_ERR("DisconnectIpsp Call Error %s[%s]", error->message, device_address);
2067                 g_error_free(error);
2068                 g_object_unref(device_proxy);
2069                 return BLUETOOTH_ERROR_INTERNAL;
2070         }
2071
2072         g_object_unref(device_proxy);
2073
2074         return ret;
2075 }
2076
2077 int _bt_connect_profile(char *address, char *uuid,
2078                                                 void *cb, gpointer func_data)
2079 {
2080         char *object_path;
2081         GDBusProxy *proxy;
2082         GDBusConnection *conn;
2083         GDBusProxy *adapter_proxy;
2084         GError *error = NULL;
2085
2086         conn = _bt_get_system_gconn();
2087         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
2088
2089         object_path = _bt_get_device_object_path(address);
2090         if (object_path == NULL) {
2091                 BT_ERR("No searched device");
2092
2093                 adapter_proxy = _bt_get_adapter_proxy();
2094                 retv_if(adapter_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2095
2096                 g_dbus_proxy_call_sync(adapter_proxy, "CreateDevice",
2097                                          g_variant_new("(s)", address),
2098                                          G_DBUS_CALL_FLAGS_NONE,
2099                                          -1,
2100                                          NULL,
2101                                          &error);
2102
2103                 if (error != NULL) {
2104                         BT_ERR("CreateDevice Fail: %s", error->message);
2105                         g_error_free(error);
2106                 }
2107
2108                 object_path = _bt_get_device_object_path(address);
2109         }
2110         retv_if(object_path == NULL, BLUETOOTH_ERROR_INTERNAL);
2111
2112         proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
2113                                                                 NULL, BT_BLUEZ_NAME,
2114                                                                 object_path, BT_DEVICE_INTERFACE,  NULL, NULL);
2115         g_free(object_path);
2116         retv_if(proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2117
2118         g_dbus_proxy_call(proxy, "ConnectProfile",
2119                                 g_variant_new("(s)", uuid),
2120                                 G_DBUS_CALL_FLAGS_NONE,
2121                                 BT_MAX_DBUS_TIMEOUT,
2122                                 NULL,
2123                                 (GAsyncReadyCallback)cb,
2124                                 func_data);
2125
2126         return BLUETOOTH_ERROR_NONE;
2127 }
2128
2129 int _bt_disconnect_profile(char *address, char *uuid,
2130                                                 void *cb, gpointer func_data)
2131 {
2132         char *object_path;
2133         GDBusProxy *proxy;
2134         GDBusConnection *conn;
2135
2136         conn = _bt_get_system_gconn();
2137         retv_if(conn == NULL, BLUETOOTH_ERROR_INTERNAL);
2138
2139         object_path = _bt_get_device_object_path(address);
2140         retv_if(object_path == NULL, BLUETOOTH_ERROR_INTERNAL);
2141
2142         proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
2143                                                                 NULL, BT_BLUEZ_NAME,
2144                                                                 object_path, BT_DEVICE_INTERFACE,  NULL, NULL);
2145         g_free(object_path);
2146         retv_if(proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2147
2148         g_dbus_proxy_call(proxy, "DisconnectProfile",
2149                                         g_variant_new("(s)", uuid),
2150                                         G_DBUS_CALL_FLAGS_NONE,
2151                                         BT_MAX_DBUS_TIMEOUT,
2152                                         NULL,
2153                                         (GAsyncReadyCallback)cb,
2154                                         func_data);
2155
2156         return BLUETOOTH_ERROR_NONE;
2157 }
2158
2159 int _bt_enable_rssi(bluetooth_device_address_t *bd_addr, int link_type,
2160                 int low_threshold, int in_range_threshold, int high_threshold)
2161 {
2162         int ret = BLUETOOTH_ERROR_NONE;
2163         GDBusProxy *proxy;
2164         GError *error = NULL;
2165         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
2166
2167         BT_CHECK_PARAMETER(bd_addr, return);
2168         BT_DBG("BD Address [%2.2X %2.2X %2.2X %2.2X %2.2X %2.2X] Link Type[%d]",
2169                         bd_addr->addr[0], bd_addr->addr[1],
2170                         bd_addr->addr[2], bd_addr->addr[3],
2171                         bd_addr->addr[4], bd_addr->addr[5],
2172                         link_type);
2173         BT_DBG("Enable RSSI: [Threshold %d %d %d]", low_threshold,
2174                         in_range_threshold, high_threshold);
2175
2176         _bt_convert_addr_type_to_string(address, bd_addr->addr);
2177
2178         proxy = _bt_get_adapter_proxy();
2179         retv_if(proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2180
2181         g_dbus_proxy_call_sync(proxy, "EnableRssi",
2182                                 g_variant_new("(siiii)", address, link_type, low_threshold, in_range_threshold, high_threshold),
2183                                 G_DBUS_CALL_FLAGS_NONE,
2184                                 -1,
2185                                 NULL,
2186                                 &error);
2187         if (error != NULL) {
2188                         BT_ERR("Dbus Call Error:[%s]", error->message);
2189                         g_error_free(error);
2190                         ret = BLUETOOTH_ERROR_INTERNAL;
2191         }
2192         return ret;
2193 }
2194
2195 int _bt_get_rssi_strength(bluetooth_device_address_t *bd_addr,
2196                                         int link_type)
2197 {
2198         int ret = BLUETOOTH_ERROR_NONE;
2199         GDBusProxy *proxy;
2200         GError *error = NULL;
2201         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
2202
2203         BT_CHECK_PARAMETER(bd_addr, return);
2204         BT_DBG("BD Address [%2.2X:%2.2X:%2.2X:%2.2X:%2.2X:%2.2X] Link Type[%d]",
2205                         bd_addr->addr[0], bd_addr->addr[1],
2206                         bd_addr->addr[2], bd_addr->addr[3],
2207                         bd_addr->addr[4], bd_addr->addr[5],
2208                         link_type);
2209
2210         _bt_convert_addr_type_to_string(address, bd_addr->addr);
2211
2212         proxy = _bt_get_adapter_proxy();
2213         retv_if(proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2214
2215         g_dbus_proxy_call_sync(proxy, "GetRssiStrength",
2216                                 g_variant_new("(si)", address, link_type),
2217                                 G_DBUS_CALL_FLAGS_NONE,
2218                                 -1,
2219                                 NULL,
2220                                 &error);
2221
2222         if (error != NULL) {
2223                         BT_ERR("Dbus Call Error:[%s]", error->message);
2224                         g_error_free(error);
2225                         ret = BLUETOOTH_ERROR_INTERNAL;
2226         }
2227         return ret;
2228 }
2229
2230 int _bt_le_conn_update(unsigned char *device_address,
2231                                 guint16 interval_min, guint16 interval_max,
2232                                 guint16 latency, guint16 time_out)
2233 {
2234         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
2235         gchar *device_path = NULL;
2236         GError *error = NULL;
2237         GDBusProxy *device_proxy = NULL;
2238         GDBusConnection *conn;
2239         GVariant *reply;
2240         guint32 min, max, to;
2241         guint32 min_supervision_to;
2242         int ret = BLUETOOTH_ERROR_NONE;
2243
2244         BT_DBG("+");
2245
2246         BT_CHECK_PARAMETER(device_address, return);
2247
2248         BT_DBG("Min interval: %u, Max interval: %u, Latency: %u, Supervision timeout: %u",
2249                         interval_min, interval_max, latency, time_out);
2250
2251         if (interval_min > interval_max ||
2252                         interval_min < BT_LE_CONN_INTERVAL_MIN ||
2253                         interval_max > BT_LE_CONN_INTERVAL_MAX) {
2254                 ret = BLUETOOTH_ERROR_INVALID_PARAM;
2255                 goto fail;
2256         }
2257
2258         if (time_out < BT_LE_CONN_SUPER_TO_MIN ||
2259                         time_out > BT_LE_CONN_SUPER_TO_MAX) {
2260                 ret = BLUETOOTH_ERROR_INVALID_PARAM;
2261                 goto fail;
2262         }
2263
2264         if (latency > BT_LE_CONN_SLAVE_LATENCY_MAX) {
2265                 ret = BLUETOOTH_ERROR_INVALID_PARAM;
2266                 goto fail;
2267         }
2268
2269         /*
2270          * The Supervision_Timeout in milliseconds shall be larger than
2271          * (1 + Conn_Latency) * Conn_Interval_Max * 2,
2272          * where Conn_Interval_Max is given in milliseconds.
2273          */
2274         min_supervision_to = (1 + latency) * interval_max * 2;
2275         if (time_out <= min_supervision_to) {
2276                 ret = BLUETOOTH_ERROR_INVALID_PARAM;
2277                 goto fail;
2278         }
2279
2280         _bt_convert_addr_type_to_string(address, device_address);
2281
2282         BT_DBG("Remote device address: %s", address);
2283
2284         device_path = _bt_get_device_object_path(address);
2285
2286         if (device_path == NULL) {
2287                 BT_DBG("device_path NULL");
2288                 ret = BLUETOOTH_ERROR_INTERNAL;
2289                 goto fail;
2290         }
2291
2292         conn = _bt_get_system_gconn();
2293         if (conn == NULL) {
2294                 BT_DBG("conn NULL");
2295                 ret = BLUETOOTH_ERROR_INTERNAL;
2296                 goto fail;
2297         }
2298
2299         device_proxy = g_dbus_proxy_new_sync(conn, G_DBUS_PROXY_FLAGS_NONE,
2300                                                                 NULL, BT_BLUEZ_NAME,
2301                                                                 device_path, BT_DEVICE_INTERFACE,  NULL, NULL);
2302
2303         g_free(device_path);
2304         retv_if(device_proxy == NULL, BLUETOOTH_ERROR_INTERNAL);
2305
2306         min = interval_min / BT_LE_CONN_INTERVAL_SPLIT;
2307         max = interval_max / BT_LE_CONN_INTERVAL_SPLIT;
2308         to = time_out / BT_LE_CONN_TO_SPLIT;
2309
2310         reply = g_dbus_proxy_call_sync(device_proxy, "LeConnUpdate",
2311                                 g_variant_new("(uuuu)", min, max, latency, to),
2312                                 G_DBUS_CALL_FLAGS_NONE,
2313                                 -1,
2314                                 NULL,
2315                                 &error);
2316
2317         g_object_unref(device_proxy);
2318         BT_ERR("LeConnUpdate Call Error for %s", address);
2319         if (reply == NULL) {
2320                 if (error) {
2321                         BT_ERR("Error %s[%s]", error->message, address);
2322                         g_error_free(error);
2323                         return BLUETOOTH_ERROR_INTERNAL;
2324                 }
2325         }
2326         g_variant_unref(reply);
2327         BT_DBG("-");
2328
2329 fail:
2330         return ret;
2331 }
2332
2333 int _bt_set_pin_code(bluetooth_device_address_t *device_address,
2334                                 bluetooth_device_pin_code_t *pin_code)
2335 {
2336         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
2337         GSList *l = NULL;
2338         bt_pin_code_info_t *pin_info = NULL;
2339
2340         BT_CHECK_PARAMETER(device_address, return);
2341         BT_CHECK_PARAMETER(pin_code, return);
2342         retv_if(g_slist_length(pin_info_list) >= BT_DEVICE_PIN_CODE_SLOT_MAX,
2343                         BLUETOOTH_ERROR_NO_RESOURCES);
2344
2345         _bt_convert_addr_type_to_string(address, device_address->addr);
2346
2347         for (l = pin_info_list; l != NULL; l = l->next) {
2348                 pin_info = l->data;
2349
2350                 if (g_strcmp0(pin_info->address, address) == 0) {
2351                         g_free(pin_info->pin_code);
2352                         pin_info->pin_code = g_strdup(pin_code->pin_code);
2353                         return BLUETOOTH_ERROR_NONE;
2354                 }
2355         }
2356
2357         pin_info = g_malloc0(sizeof(bt_pin_code_info_t));
2358         if (pin_info != NULL) {
2359                 pin_info->address = g_strdup(address);
2360                 pin_info->pin_code = g_strdup(pin_code->pin_code);
2361                 pin_info_list = g_slist_append(pin_info_list, pin_info);
2362                 return BLUETOOTH_ERROR_NONE;
2363         }
2364
2365         return BLUETOOTH_ERROR_INTERNAL;
2366 }
2367
2368 gint __bt_compare_address(gpointer *a, gpointer *b)
2369 {
2370         bt_pin_code_info_t *pin_info = (bt_pin_code_info_t *)a;
2371         char *address = (char *)b;
2372         return g_strcmp0(pin_info->address, address);
2373 }
2374
2375 int _bt_unset_pin_code(bluetooth_device_address_t *device_address)
2376 {
2377         char address[BT_ADDRESS_STRING_SIZE] = { 0 };
2378         GSList *l = NULL;
2379         bt_pin_code_info_t *pin_info = NULL;
2380
2381         BT_CHECK_PARAMETER(device_address, return);
2382
2383         _bt_convert_addr_type_to_string(address, device_address->addr);
2384
2385         l = g_slist_find_custom(pin_info_list, address,
2386                 (GCompareFunc)__bt_compare_address);
2387         if (l)
2388                 pin_info = l->data;
2389         if (pin_info) {
2390                 pin_info_list = g_slist_remove(pin_info_list, pin_info);
2391                 g_free(pin_info->address);
2392                 g_free(pin_info->pin_code);
2393                 g_free(pin_info);
2394         }
2395
2396         return BLUETOOTH_ERROR_NONE;
2397 }
2398
2399 int _bt_get_device_pin_code(const char *address, char *pin_code)
2400 {
2401         GSList *l = NULL;
2402
2403         BT_CHECK_PARAMETER(address, return);
2404         BT_CHECK_PARAMETER(pin_code, return);
2405
2406         for (l = pin_info_list; l != NULL; l = l->next) {
2407                 bt_pin_code_info_t *pin_info = l->data;
2408
2409                 if (g_strcmp0(pin_info->address, address) == 0) {
2410                         g_strlcpy(pin_code, pin_info->pin_code,
2411                                         BLUETOOTH_PIN_CODE_MAX_LENGTH + 1);
2412
2413                         return BLUETOOTH_ERROR_NONE;
2414                 }
2415         }
2416
2417         return BLUETOOTH_ERROR_NOT_FOUND;
2418 }
2419
2420 int _bt_get_le_connection_parameter(bluetooth_le_connection_mode_t mode,
2421                 bluetooth_le_connection_param_t *param)
2422 {
2423         if (param == NULL)
2424                 return BLUETOOTH_ERROR_INVALID_PARAM;
2425
2426         if (mode < BLUETOOTH_LE_CONNECTION_MODE_BALANCED ||
2427             mode > BLUETOOTH_LE_CONNECTION_MODE_LOW_POWER)
2428                 return BLUETOOTH_ERROR_INVALID_PARAM;
2429
2430         memset(param, 0x00, sizeof(bluetooth_le_connection_param_t));
2431
2432         switch (mode) {
2433         case BLUETOOTH_LE_CONNECTION_MODE_BALANCED:
2434                 param->interval_min = BT_LE_CONN_PARAM_BALANCED_MIN_INTERVAL;
2435                 param->interval_max = BT_LE_CONN_PARAM_BALANCED_MAX_INTERVAL;
2436                 param->latency = BT_LE_CONN_PARAM_BALANCED_SLAVE_LATENCY;
2437                 param->timeout = BT_LE_CONN_PARAM_DEFAULT_SUPERVISION_TIMEOUT;
2438                 break;
2439
2440         case BLUETOOTH_LE_CONNECTION_MODE_LOW_LATENCY:
2441                 param->interval_min = BT_LE_CONN_PARAM_LOW_LATENCY_MIN_INTERVAL;
2442                 param->interval_max = BT_LE_CONN_PARAM_LOW_LATENCY_MAX_INTERVAL;
2443                 param->latency = BT_LE_CONN_PARAM_LOW_LATENCY_SLAVE_LATENCY;
2444                 param->timeout = BT_LE_CONN_PARAM_DEFAULT_SUPERVISION_TIMEOUT;
2445                 break;
2446
2447         case BLUETOOTH_LE_CONNECTION_MODE_LOW_POWER:
2448                 param->interval_min = BT_LE_CONN_PARAM_LOW_POWER_MIN_INTERVAL;
2449                 param->interval_max = BT_LE_CONN_PARAM_LOW_POWER_MAX_INTERVAL;
2450                 param->latency = BT_LE_CONN_PARAM_LOW_POWER_SLAVE_LATENCY;
2451                 param->timeout = BT_LE_CONN_PARAM_DEFAULT_SUPERVISION_TIMEOUT;
2452                 break;
2453
2454         default:
2455                 BT_ERR("Unhandled mode : %d", mode);
2456                 break;
2457         }
2458
2459         return BLUETOOTH_ERROR_NONE;
2460 }
2461
2462 int _bt_passkey_reply(const char *passkey, gboolean authentication_reply)
2463 {
2464         GapAgentPrivate *agent = _bt_get_adapter_agent();
2465         retv_if(!agent, BLUETOOTH_ERROR_INTERNAL);
2466
2467         if (authentication_reply)
2468                 gap_agent_reply_pin_code(agent, GAP_AGENT_ACCEPT, passkey, NULL);
2469         else
2470                 gap_agent_reply_pin_code(agent, GAP_AGENT_REJECT, passkey, NULL);
2471
2472         BT_DBG("BT_PASSKEY_REPLY");
2473         return BLUETOOTH_ERROR_NONE;
2474 }
2475
2476 int _bt_passkey_confirmation_reply(gboolean confirmation_reply)
2477 {
2478         GapAgentPrivate *agent = _bt_get_adapter_agent();
2479         retv_if(!agent, BLUETOOTH_ERROR_INTERNAL);
2480
2481         if (confirmation_reply)
2482                 gap_agent_reply_confirmation(agent, GAP_AGENT_ACCEPT, NULL);
2483         else
2484                 gap_agent_reply_confirmation(agent, GAP_AGENT_REJECT, NULL);
2485
2486         BT_DBG("BT_PASSKEY_CONFIRMATION_REPLY");
2487         return BLUETOOTH_ERROR_NONE;
2488 }