#include "bt-request-sender.h"
#include "bt-event-handler.h"
+/* Avoid the build error related to vconf.h's dependency */
+#ifndef VCONFKEY_BATTERY_MONITOR_STATUS
+#define VCONFKEY_BATTERY_MONITOR_STATUS "db/bluetooth/bmstatus"
+#endif
+
+
+typedef enum {
+ BT_MONITOR_NONE = -1,
+ BT_MONITOR_OFF = 0,
+ BT_MONITOR_ON = 1,
+} bt_battery_monitor_state_t;
+
+static int battery_monitor_state = BT_MONITOR_NONE;
+
static int __bt_fill_device_list(GArray *out_param2, GPtrArray **dev_list)
{
int i;
guint size;
- bluetooth_device_info_t info;
+ bluetooth_device_info_t *info;
BT_CHECK_PARAMETER(out_param2, return);
BT_CHECK_PARAMETER(dev_list, return);
for (i = 0; i < size; i++) {
bluetooth_device_info_t *dev_info = NULL;
- info = g_array_index(out_param2,
+ info = &g_array_index(out_param2,
bluetooth_device_info_t, i);
- dev_info = g_memdup(&info, sizeof(bluetooth_device_info_t));
+ dev_info = g_memdup(info, sizeof(bluetooth_device_info_t));
- if (dev_info) {
+ if (dev_info)
g_ptr_array_add(*dev_list, (gpointer)dev_info);
- }
}
return BLUETOOTH_ERROR_NONE;
BT_EXPORT_API int bluetooth_check_adapter(void)
{
+ int value = VCONFKEY_BT_STATUS_OFF;
int ret;
- int value;
- ret = _bt_get_adapter_path(_bt_gdbus_get_system_gconn(), NULL);
+ ret = _bt_get_adapter_path(_bt_get_system_common_conn(), NULL);
- if (ret != BLUETOOTH_ERROR_NONE) {
+ if (ret != BLUETOOTH_ERROR_NONE)
return BLUETOOTH_ADAPTER_DISABLED;
- }
/* check VCONFKEY_BT_STATUS */
if (vconf_get_int(VCONFKEY_BT_STATUS, &value) != 0) {
BT_EXPORT_API int bluetooth_enable_adapter(void)
{
int result;
- bt_user_info_t *user_info;
- BT_INFO("");
+ BT_INFO_C("### Enable adapter");
+ _bt_print_api_caller_name();
retv_if(bluetooth_check_adapter() == BLUETOOTH_ADAPTER_ENABLED,
BLUETOOTH_ERROR_DEVICE_ALREADY_ENABLED);
-
-#ifdef TIZEN_DPM_VCONF_ENABLE
- retv_if(bluetooth_dpm_is_mode_allowed() == BLUETOOTH_DPM_RESULT_ACCESS_DENIED,
+ retv_if(bluetooth_dpm_is_mode_allowed() == BLUETOOTH_ERROR_PERMISSION_DEINED,
BLUETOOTH_ERROR_PERMISSION_DEINED);
-#endif
- user_info = _bt_get_user_data(BT_COMMON);
- retv_if(user_info->cb == NULL, BLUETOOTH_ERROR_INTERNAL);
+ BT_INIT_PARAMS();
+ BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+
+ result = _bt_send_request(BT_BLUEZ_SERVICE, BT_ENABLE_ADAPTER,
+ in_param1, in_param2, in_param3, in_param4, &out_param);
+
+ BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+
+ return result;
+}
+
+BT_EXPORT_API int bluetooth_set_battery_monitor_state(bool state)
+{
+ if (vconf_set_bool(VCONFKEY_BATTERY_MONITOR_STATUS, state) != 0)
+ {
+ BT_ERR("vconf_set_bool failed");
+ return BLUETOOTH_ERROR_INTERNAL;
+ }
+
+ battery_monitor_state = (state == false) ? BT_MONITOR_OFF : BT_MONITOR_ON;
+
+ return BLUETOOTH_ERROR_NONE;
+}
+
+static void __bt_battery_monitor_status_changed_cb(keynode_t *node, void *data)
+{
+ gboolean status = FALSE;
+ int type;
+
+ type = vconf_keynode_get_type(node);
+ if (type == VCONF_TYPE_BOOL) {
+ status = vconf_keynode_get_bool(node);
+
+ BT_DBG("Update the monitor state to %d", status);
+
+ battery_monitor_state = (status == FALSE) ? BT_MONITOR_OFF : BT_MONITOR_ON;
+ } else {
+ BT_ERR("Invaild vconf key type : %d", type);
+ return;
+ }
+}
+
+void _bt_reset_battery_monitor_info(void)
+{
+ vconf_ignore_key_changed(VCONFKEY_BATTERY_MONITOR_STATUS,
+ (vconf_callback_fn)__bt_battery_monitor_status_changed_cb);
+
+ _bt_rfcomm_server_reset_timer();
+ _bt_rfcomm_client_reset_timer();
+
+ battery_monitor_state = BT_MONITOR_NONE;
+}
+
+BT_EXPORT_API int bluetooth_get_battery_monitor_state()
+{
+ int state = 0;
+
+ if (battery_monitor_state != BT_MONITOR_NONE)
+ return battery_monitor_state;
+
+ if (vconf_get_bool(VCONFKEY_BATTERY_MONITOR_STATUS, &state) != 0)
+ BT_ERR("vconf_get_bool failed");
+
+ battery_monitor_state = state;
+
+ if (vconf_notify_key_changed(VCONFKEY_BATTERY_MONITOR_STATUS,
+ (vconf_callback_fn)__bt_battery_monitor_status_changed_cb, NULL) < 0)
+ BT_ERR("Unable to register key handler");
+
+ return state;
+}
+
+BT_EXPORT_API int bluetooth_read_battery_data(bt_battery_data *data)
+{
+ int result;
+ bt_battery_dbus_data_t *info = NULL;
+
+ BT_CHECK_PARAMETER(data, return);
+
+ retv_if(bluetooth_check_adapter() != BLUETOOTH_ADAPTER_ENABLED,
+ BLUETOOTH_ADAPTER_DISABLED);
+
+ retv_if(bluetooth_get_battery_monitor_state() == FALSE,
+ BLUETOOTH_ERROR_NOT_SUPPORT);
+
+ retv_if(bluetooth_dpm_is_mode_allowed() == BLUETOOTH_ERROR_PERMISSION_DEINED,
+ BLUETOOTH_ERROR_PERMISSION_DEINED);
BT_INIT_PARAMS();
BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
- result = _bt_send_request_async(BT_BLUEZ_SERVICE, BT_ENABLE_ADAPTER,
- in_param1, in_param2, in_param3, in_param4,
- user_info->cb, user_info->user_data);
+ result = _bt_send_request(BT_BLUEZ_SERVICE, BT_BATTERY_READ_DATA,
+ in_param1, in_param2, in_param3, in_param4, &out_param);
+
+ if (result != BLUETOOTH_ERROR_NONE) {
+ BT_ERR("Error encountered");
+ BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+ return result;
+ }
+
+ info = &g_array_index(out_param, bt_battery_dbus_data_t, 0);
+
+ data->session_start_time = info->session_start_time;
+ data->session_end_time = info->session_end_time;
+ data->session_scan_time = info->session_scan_time;
+ data->session_connected_time = info->session_connected_time;
+ data->tx_time = info->tx_time;
+ data->rx_time = info->rx_time;
+ data->idle_time = info->idle_time;
+ data->atm_list = NULL;
+
+ BT_DBG("Received battery data in bt-api: %ld %ld %d %d.",
+ data->session_start_time, data->session_end_time,
+ data->session_scan_time, data->session_connected_time);
+
+ /*Copying app wise details*/
+ int n = NUM_APP_MAX < info->num_app ? NUM_APP_MAX : info->num_app; //Maximum NUM_APP_MAX details will be fetched
+
+ for (int i = 0; i < n; i++) {
+ bt_battery_app_data *app_data = NULL;
+ app_data = g_malloc0(sizeof(bt_battery_app_data));
+ memcpy(app_data, &(info->app_data[i]), sizeof(bt_battery_app_data));
+ data->atm_list = g_slist_append(data->atm_list, app_data);
+ }
+
+ if (data->atm_list == NULL) {
+ BT_DBG("No app data transaction in this session");
+ BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+ return result;
+ }
+
+ BT_DBG("App-wise data transaction details:");
+ for (GSList *l = data->atm_list; l != NULL; l = g_slist_next(l)) {
+ bt_battery_app_data *t = (bt_battery_app_data *)(l->data);
+ BT_DBG("%ld %ld %d %d %u", (long int)(t->uid), (long int)(t->pid), t->rx_bytes, t->tx_bytes, t->time);
+ }
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
BT_EXPORT_API int bluetooth_disable_adapter(void)
{
int result;
- bt_user_info_t *user_info;
- BT_INFO("");
+ BT_INFO_C("### Disable adapter");
+ _bt_print_api_caller_name();
BT_CHECK_ENABLED(return);
- user_info = _bt_get_user_data(BT_COMMON);
- retv_if(user_info->cb == NULL, BLUETOOTH_ERROR_INTERNAL);
-
BT_INIT_PARAMS();
BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
- result = _bt_send_request_async(BT_BLUEZ_SERVICE, BT_DISABLE_ADAPTER,
- in_param1, in_param2, in_param3, in_param4,
- user_info->cb, user_info->user_data);
+ result = _bt_send_request(BT_BLUEZ_SERVICE, BT_DISABLE_ADAPTER,
+ in_param1, in_param2, in_param3, in_param4, &out_param);
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
{
int result;
- BT_INFO("");
+ BT_INFO_C("### Recover adapter");
BT_CHECK_ENABLED(return);
BT_INIT_PARAMS();
result = _bt_send_request(BT_BLUEZ_SERVICE, BT_GET_LOCAL_VERSION,
in_param1, in_param2, in_param3, in_param4, &out_param);
- if (result == BLUETOOTH_ERROR_NONE) {
+ if (result == BLUETOOTH_ERROR_NONE)
*local_version = g_array_index(out_param, bluetooth_version_t, 0);
- }
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
result = _bt_send_request(BT_BLUEZ_SERVICE, BT_IS_SERVICE_USED,
in_param1, in_param2, in_param3, in_param4, &out_param);
- if (result == BLUETOOTH_ERROR_NONE) {
+ if (result == BLUETOOTH_ERROR_NONE)
*used = g_array_index(out_param, gboolean, 0);
- }
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
BT_CHECK_PARAMETER(discoverable_mode_ptr, return);
-#ifndef TIZEN_WEARABLE
- int timeout = 0;
- /* Requirement in OSP */
- if (bluetooth_check_adapter() == BLUETOOTH_ADAPTER_DISABLED) {
- if (vconf_get_int(BT_FILE_VISIBLE_TIME, &timeout) != 0) {
- BT_ERR("Fail to get the timeout value");
- return BLUETOOTH_ERROR_DEVICE_NOT_ENABLED;
+ if (!TIZEN_PROFILE_WEARABLE) {
+ int timeout = 0;
+ /* Requirement in OSP */
+ if (bluetooth_check_adapter() == BLUETOOTH_ADAPTER_DISABLED) {
+ if (vconf_get_int(BT_FILE_VISIBLE_TIME, &timeout) != 0) {
+ BT_ERR("Fail to get the timeout value");
+ return BLUETOOTH_ERROR_DEVICE_NOT_ENABLED;
+ }
+
+ if (timeout == -1)
+ *discoverable_mode_ptr = BLUETOOTH_DISCOVERABLE_MODE_GENERAL_DISCOVERABLE;
+ else
+ *discoverable_mode_ptr = BLUETOOTH_DISCOVERABLE_MODE_CONNECTABLE;
+
+ return BLUETOOTH_ERROR_NONE;
}
-
- if (timeout == -1) {
- *discoverable_mode_ptr = BLUETOOTH_DISCOVERABLE_MODE_GENERAL_DISCOVERABLE;
- } else {
- *discoverable_mode_ptr = BLUETOOTH_DISCOVERABLE_MODE_CONNECTABLE;
- }
-
- return BLUETOOTH_ERROR_NONE;
+ } else {
+ BT_CHECK_ENABLED(return);
}
-#else
- BT_CHECK_ENABLED(return);
-#endif
BT_INIT_PARAMS();
BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
result = _bt_send_request(BT_BLUEZ_SERVICE, BT_GET_DISCOVERABLE_MODE,
in_param1, in_param2, in_param3, in_param4, &out_param);
- if (result == BLUETOOTH_ERROR_NONE) {
+ if (result == BLUETOOTH_ERROR_NONE)
*discoverable_mode_ptr = g_array_index(out_param, int, 0);
- }
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
result = _bt_send_request(BT_BLUEZ_SERVICE, BT_GET_DISCOVERABLE_TIME,
in_param1, in_param2, in_param3, in_param4, &out_param);
- if (result == BLUETOOTH_ERROR_NONE) {
+ if (result == BLUETOOTH_ERROR_NONE)
*timeout = g_array_index(out_param, int, 0);
- }
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
unsigned int classOfDeviceMask)
{
int result;
+ uid_t uid = getuid();
BT_CHECK_ENABLED(return);
BT_INIT_PARAMS();
BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+ g_array_append_vals(in_param1, &max_response, sizeof(unsigned short));
+ g_array_append_vals(in_param2, &discovery_duration, sizeof(unsigned short));
+ g_array_append_vals(in_param3, &classOfDeviceMask, sizeof(unsigned int));
+ g_array_append_vals(in_param4, &uid, sizeof(uid_t));
+
result = _bt_send_request(BT_BLUEZ_SERVICE, BT_START_DISCOVERY,
in_param1, in_param2, in_param3, in_param4, &out_param);
int, 0);
} else {
BT_ERR("Fail to send request");
+ is_discovering = result;
}
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
BT_INIT_PARAMS();
BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
- result = _bt_send_request(BT_BLUEZ_SERVICE, BT_IS_CONNECTABLE,
+ result = _bt_send_request(BT_BLUEZ_SERVICE, BT_GET_CONNECTABLE,
in_param1, in_param2, in_param3, in_param4, &out_param);
- if (result == BLUETOOTH_ERROR_NONE) {
+ if (result == BLUETOOTH_ERROR_NONE)
*is_connectable = g_array_index(out_param, int, 0);
- } else {
+ else
BT_ERR("Fail to send request");
- }
BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
return result;
}
+BT_EXPORT_API int bluetooth_get_profile_connected_device_list(
+ const char *profile_uuid, GPtrArray **addr_list)
+{
+ char uuid[BLUETOOTH_UUID_STRING_MAX];
+ int result;
+ guint size;
+ int i;
+
+ BT_CHECK_PARAMETER(profile_uuid, return);
+ BT_CHECK_PARAMETER(addr_list, return);
+ BT_CHECK_ENABLED(return);
+
+ BT_INIT_PARAMS();
+ BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+
+ g_strlcpy(uuid, profile_uuid, sizeof(uuid));
+ g_array_append_vals(in_param1, uuid, BLUETOOTH_UUID_STRING_MAX);
+
+ result = _bt_send_request(BT_BLUEZ_SERVICE, BT_GET_PROFILE_CONNECTED_DEVICES,
+ in_param1, in_param2, in_param3, in_param4, &out_param);
+
+ if (result == BLUETOOTH_ERROR_NONE) {
+ if (out_param == NULL) {
+ BT_ERR("out_param is NULL");
+ result = BLUETOOTH_ERROR_INTERNAL;
+ } else {
+ size = (out_param->len) / sizeof(bluetooth_device_address_t);
+
+ if (size == 0) {
+ BT_ERR("No connected device");
+ result = BLUETOOTH_ERROR_NOT_CONNECTED;
+ }
+
+ for (i = 0; i < size; i++) {
+ bluetooth_device_address_t *addr = NULL;
+ bluetooth_device_address_t *ptr = NULL;
+
+ ptr = &g_array_index(out_param,
+ bluetooth_device_address_t, i);
+
+ addr = g_memdup(ptr, sizeof(bluetooth_device_address_t));
+
+ if (addr)
+ g_ptr_array_add(*addr_list, (gpointer)addr);
+ }
+ }
+ }
+
+ BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+
+ return result;
+}
+
BT_EXPORT_API int bluetooth_set_manufacturer_data(const bluetooth_manufacturer_data_t *value)
{
int result;
return result;
}
+
+BT_EXPORT_API int bluetooth_set_passkey_notification(gboolean enable)
+{
+ int result;
+
+ BT_CHECK_ENABLED_ANY(return);
+
+ BT_INIT_PARAMS();
+ BT_ALLOC_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+
+ g_array_append_vals(in_param1, &enable, sizeof(gboolean));
+
+ result = _bt_send_request(BT_BLUEZ_SERVICE, BT_SET_PASSKEY_NOTIFICATION,
+ in_param1, in_param2, in_param3, in_param4, &out_param);
+
+ BT_FREE_PARAMS(in_param1, in_param2, in_param3, in_param4, out_param);
+
+ return result;
+}
+