WPS 2.0: Modify empty-string workaround to meet 2.0 rules

Instead of using 0x00 as the extra character, use space (' ') to
avoid failing tests that verify that the variable length string
attributes are not null terminated. In addition, this workaround
can now be disabled by defining CONFIG_WPS_STRICT for the build.
This can be done by adding following line to .config:
CFLAGS += -DCONFIG_WPS_STRICT

However, it should be noted that such a build may not interoperate
with some deployed WPS 1.0 -based implementations and as such, is
mainly designed for testing.
This commit is contained in:
Jouni Malinen 2010-05-26 09:46:48 +03:00 committed by Jouni Malinen
parent 6a857074f4
commit 5314d652d4

View File

@ -25,18 +25,20 @@ int wps_build_manufacturer(struct wps_device_data *dev, struct wpabuf *msg)
wpa_printf(MSG_DEBUG, "WPS: * Manufacturer"); wpa_printf(MSG_DEBUG, "WPS: * Manufacturer");
wpabuf_put_be16(msg, ATTR_MANUFACTURER); wpabuf_put_be16(msg, ATTR_MANUFACTURER);
len = dev->manufacturer ? os_strlen(dev->manufacturer) : 0; len = dev->manufacturer ? os_strlen(dev->manufacturer) : 0;
#ifndef CONFIG_WPS_STRICT
if (len == 0) { if (len == 0) {
/* /*
* Some deployed WPS implementations fail to parse zero-length * Some deployed WPS implementations fail to parse zero-length
* attributes. As a workaround, send a null character if the * attributes. As a workaround, send a space character if the
* device attribute string is empty. * device attribute string is empty.
*/ */
wpabuf_put_be16(msg, 1); wpabuf_put_be16(msg, 1);
wpabuf_put_u8(msg, '\0'); wpabuf_put_u8(msg, ' ');
} else { return 0;
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->manufacturer, len);
} }
#endif /* CONFIG_WPS_STRICT */
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->manufacturer, len);
return 0; return 0;
} }
@ -47,18 +49,20 @@ int wps_build_model_name(struct wps_device_data *dev, struct wpabuf *msg)
wpa_printf(MSG_DEBUG, "WPS: * Model Name"); wpa_printf(MSG_DEBUG, "WPS: * Model Name");
wpabuf_put_be16(msg, ATTR_MODEL_NAME); wpabuf_put_be16(msg, ATTR_MODEL_NAME);
len = dev->model_name ? os_strlen(dev->model_name) : 0; len = dev->model_name ? os_strlen(dev->model_name) : 0;
#ifndef CONFIG_WPS_STRICT
if (len == 0) { if (len == 0) {
/* /*
* Some deployed WPS implementations fail to parse zero-length * Some deployed WPS implementations fail to parse zero-length
* attributes. As a workaround, send a null character if the * attributes. As a workaround, send a space character if the
* device attribute string is empty. * device attribute string is empty.
*/ */
wpabuf_put_be16(msg, 1); wpabuf_put_be16(msg, 1);
wpabuf_put_u8(msg, '\0'); wpabuf_put_u8(msg, ' ');
} else { return 0;
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->model_name, len);
} }
#endif /* CONFIG_WPS_STRICT */
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->model_name, len);
return 0; return 0;
} }
@ -69,18 +73,20 @@ int wps_build_model_number(struct wps_device_data *dev, struct wpabuf *msg)
wpa_printf(MSG_DEBUG, "WPS: * Model Number"); wpa_printf(MSG_DEBUG, "WPS: * Model Number");
wpabuf_put_be16(msg, ATTR_MODEL_NUMBER); wpabuf_put_be16(msg, ATTR_MODEL_NUMBER);
len = dev->model_number ? os_strlen(dev->model_number) : 0; len = dev->model_number ? os_strlen(dev->model_number) : 0;
#ifndef CONFIG_WPS_STRICT
if (len == 0) { if (len == 0) {
/* /*
* Some deployed WPS implementations fail to parse zero-length * Some deployed WPS implementations fail to parse zero-length
* attributes. As a workaround, send a null character if the * attributes. As a workaround, send a space character if the
* device attribute string is empty. * device attribute string is empty.
*/ */
wpabuf_put_be16(msg, 1); wpabuf_put_be16(msg, 1);
wpabuf_put_u8(msg, '\0'); wpabuf_put_u8(msg, ' ');
} else { return 0;
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->model_number, len);
} }
#endif /* CONFIG_WPS_STRICT */
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->model_number, len);
return 0; return 0;
} }
@ -92,18 +98,20 @@ static int wps_build_serial_number(struct wps_device_data *dev,
wpa_printf(MSG_DEBUG, "WPS: * Serial Number"); wpa_printf(MSG_DEBUG, "WPS: * Serial Number");
wpabuf_put_be16(msg, ATTR_SERIAL_NUMBER); wpabuf_put_be16(msg, ATTR_SERIAL_NUMBER);
len = dev->serial_number ? os_strlen(dev->serial_number) : 0; len = dev->serial_number ? os_strlen(dev->serial_number) : 0;
#ifndef CONFIG_WPS_STRICT
if (len == 0) { if (len == 0) {
/* /*
* Some deployed WPS implementations fail to parse zero-length * Some deployed WPS implementations fail to parse zero-length
* attributes. As a workaround, send a null character if the * attributes. As a workaround, send a space character if the
* device attribute string is empty. * device attribute string is empty.
*/ */
wpabuf_put_be16(msg, 1); wpabuf_put_be16(msg, 1);
wpabuf_put_u8(msg, '\0'); wpabuf_put_u8(msg, ' ');
} else { return 0;
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->serial_number, len);
} }
#endif /* CONFIG_WPS_STRICT */
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->serial_number, len);
return 0; return 0;
} }
@ -124,18 +132,20 @@ int wps_build_dev_name(struct wps_device_data *dev, struct wpabuf *msg)
wpa_printf(MSG_DEBUG, "WPS: * Device Name"); wpa_printf(MSG_DEBUG, "WPS: * Device Name");
wpabuf_put_be16(msg, ATTR_DEV_NAME); wpabuf_put_be16(msg, ATTR_DEV_NAME);
len = dev->device_name ? os_strlen(dev->device_name) : 0; len = dev->device_name ? os_strlen(dev->device_name) : 0;
#ifndef CONFIG_WPS_STRICT
if (len == 0) { if (len == 0) {
/* /*
* Some deployed WPS implementations fail to parse zero-length * Some deployed WPS implementations fail to parse zero-length
* attributes. As a workaround, send a null character if the * attributes. As a workaround, send a space character if the
* device attribute string is empty. * device attribute string is empty.
*/ */
wpabuf_put_be16(msg, 1); wpabuf_put_be16(msg, 1);
wpabuf_put_u8(msg, '\0'); wpabuf_put_u8(msg, ' ');
} else { return 0;
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->device_name, len);
} }
#endif /* CONFIG_WPS_STRICT */
wpabuf_put_be16(msg, len);
wpabuf_put_data(msg, dev->device_name, len);
return 0; return 0;
} }