dbus: revert changes to some peer properties

Commit 3f6e50ac28 made it possible to access
P2P peer properties using the org.freedesktop.DBus.Properties interface.

While maintaining the original intent of that patch we make two changes
to it here:

First, 3f6e50ac28 changed the type used to
represent the WPS vendor extension data from bytes to a string. In
addition to the type change the way in which the vendor extension data
was provided to the function creating the string was incorrect and would
not present the correct vendor extension data even in string format.

Revert the type change made in 3f6e50ac28
and present the WPS vendor extension data as an array of an array of
bytes as it was before.

Second, 3f6e50ac28 changes the secondary
device types representation from an array of an array of bytes to an
array of bytes. Revert that change to make secondary device types
accessible via an array of an array of bytes again.

Signed-hostap: Reinette Chatre <reinette.chatre@intel.com>
intended-for: hostap-1
This commit is contained in:
Reinette Chatre 2012-02-25 10:50:13 +02:00 committed by Jouni Malinen
parent 96c4f3a707
commit ca29842700
2 changed files with 77 additions and 27 deletions

View file

@ -2921,11 +2921,11 @@ static const struct wpa_dbus_property_desc wpas_dbus_p2p_peer_properties[] = {
wpas_dbus_getter_p2p_peer_group_capability, wpas_dbus_getter_p2p_peer_group_capability,
NULL NULL
}, },
{ "SecondaryDeviceTypes", WPAS_DBUS_NEW_IFACE_P2P_PEER, "ay", { "SecondaryDeviceTypes", WPAS_DBUS_NEW_IFACE_P2P_PEER, "aay",
wpas_dbus_getter_p2p_peer_secondary_device_types, wpas_dbus_getter_p2p_peer_secondary_device_types,
NULL NULL
}, },
{ "VendorExtension", WPAS_DBUS_NEW_IFACE_P2P_PEER, "as", { "VendorExtension", WPAS_DBUS_NEW_IFACE_P2P_PEER, "aay",
wpas_dbus_getter_p2p_peer_vendor_extension, wpas_dbus_getter_p2p_peer_vendor_extension,
NULL NULL
}, },

View file

@ -1341,6 +1341,7 @@ dbus_bool_t wpas_dbus_getter_p2p_peer_secondary_device_types(
{ {
struct peer_handler_args *peer_args = user_data; struct peer_handler_args *peer_args = user_data;
const struct p2p_peer_info *info; const struct p2p_peer_info *info;
DBusMessageIter variant_iter, array_iter;
info = p2p_get_peer_found(peer_args->wpa_s->global->p2p, info = p2p_get_peer_found(peer_args->wpa_s->global->p2p,
peer_args->p2p_device_addr, 0); peer_args->p2p_device_addr, 0);
@ -1350,29 +1351,80 @@ dbus_bool_t wpas_dbus_getter_p2p_peer_secondary_device_types(
return FALSE; return FALSE;
} }
if (info->wps_sec_dev_type_list_len) { if (!dbus_message_iter_open_container(iter, DBUS_TYPE_VARIANT,
const u8 *sec_dev_type_list = info->wps_sec_dev_type_list; DBUS_TYPE_ARRAY_AS_STRING
int num_sec_dev_types = info->wps_sec_dev_type_list_len; DBUS_TYPE_ARRAY_AS_STRING
DBUS_TYPE_BYTE_AS_STRING,
if (!wpas_dbus_simple_array_property_getter(iter, &variant_iter)) {
DBUS_TYPE_BYTE, dbus_set_error(error, DBUS_ERROR_FAILED,
sec_dev_type_list, "%s: failed to construct message 1", __func__);
num_sec_dev_types, return FALSE;
error))
goto err_no_mem;
else
return TRUE;
} }
if (!wpas_dbus_simple_array_property_getter(iter, DBUS_TYPE_BYTE, NULL, if (!dbus_message_iter_open_container(&variant_iter, DBUS_TYPE_ARRAY,
0, error)) DBUS_TYPE_ARRAY_AS_STRING
goto err_no_mem; DBUS_TYPE_BYTE_AS_STRING,
&array_iter)) {
dbus_set_error(error, DBUS_ERROR_FAILED,
"%s: failed to construct message 2", __func__);
return FALSE;
}
if (info->wps_sec_dev_type_list_len) {
const u8 *sec_dev_type_list = info->wps_sec_dev_type_list;
int num_sec_device_types =
info->wps_sec_dev_type_list_len / WPS_DEV_TYPE_LEN;
int i;
DBusMessageIter inner_array_iter;
for (i = 0; i < num_sec_device_types; i++) {
if (!dbus_message_iter_open_container(
&array_iter, DBUS_TYPE_ARRAY,
DBUS_TYPE_BYTE_AS_STRING,
&inner_array_iter)) {
dbus_set_error(error, DBUS_ERROR_FAILED,
"%s: failed to construct "
"message 3 (%d)",
__func__, i);
return FALSE;
}
if (!dbus_message_iter_append_fixed_array(
&inner_array_iter, DBUS_TYPE_BYTE,
&sec_dev_type_list, WPS_DEV_TYPE_LEN)) {
dbus_set_error(error, DBUS_ERROR_FAILED,
"%s: failed to construct "
"message 4 (%d)",
__func__, i);
return FALSE;
}
if (!dbus_message_iter_close_container(
&array_iter, &inner_array_iter)) {
dbus_set_error(error, DBUS_ERROR_FAILED,
"%s: failed to construct "
"message 5 (%d)",
__func__, i);
return FALSE;
}
sec_dev_type_list += WPS_DEV_TYPE_LEN;
}
}
if (!dbus_message_iter_close_container(&variant_iter, &array_iter)) {
dbus_set_error(error, DBUS_ERROR_FAILED,
"%s: failed to construct message 6", __func__);
return FALSE;
}
if (!dbus_message_iter_close_container(iter, &variant_iter)) {
dbus_set_error(error, DBUS_ERROR_FAILED,
"%s: failed to construct message 7", __func__);
return FALSE;
}
return TRUE; return TRUE;
err_no_mem:
dbus_set_error_const(error, DBUS_ERROR_NO_MEMORY, "no memory");
return FALSE;
} }
@ -1380,7 +1432,7 @@ dbus_bool_t wpas_dbus_getter_p2p_peer_vendor_extension(DBusMessageIter *iter,
DBusError *error, DBusError *error,
void *user_data) void *user_data)
{ {
const struct wpabuf *vendor_extension[P2P_MAX_WPS_VENDOR_EXT]; struct wpabuf *vendor_extension[P2P_MAX_WPS_VENDOR_EXT];
int i, num; int i, num;
struct peer_handler_args *peer_args = user_data; struct peer_handler_args *peer_args = user_data;
const struct p2p_peer_info *info; const struct p2p_peer_info *info;
@ -1401,12 +1453,10 @@ dbus_bool_t wpas_dbus_getter_p2p_peer_vendor_extension(DBusMessageIter *iter,
num++; num++;
} }
if (!wpas_dbus_simple_array_property_getter(iter, DBUS_TYPE_STRING, if (!wpas_dbus_simple_array_array_property_getter(iter, DBUS_TYPE_BYTE,
vendor_extension, num, vendor_extension,
error)) { num, error))
dbus_set_error_const(error, DBUS_ERROR_NO_MEMORY, "no memory");
return FALSE; return FALSE;
}
return TRUE; return TRUE;
} }