WPS: Split wps_build_oob_dev_password() into parts
This allows sharing of a function to build the attribute without changing the OOB parameters. Signed-hostap: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
8a13732f83
commit
78e625f79a
2 changed files with 26 additions and 12 deletions
|
@ -340,19 +340,34 @@ int wps_build_encr_settings(struct wps_data *wps, struct wpabuf *msg,
|
||||||
|
|
||||||
|
|
||||||
#ifdef CONFIG_WPS_OOB
|
#ifdef CONFIG_WPS_OOB
|
||||||
int wps_build_oob_dev_password(struct wpabuf *msg, struct wps_context *wps)
|
int wps_build_oob_dev_pw(struct wpabuf *msg, u16 dev_pw_id,
|
||||||
|
const struct wpabuf *pubkey, const u8 *dev_pw,
|
||||||
|
size_t dev_pw_len)
|
||||||
{
|
{
|
||||||
size_t hash_len;
|
size_t hash_len;
|
||||||
const u8 *addr[1];
|
const u8 *addr[1];
|
||||||
u8 pubkey_hash[WPS_HASH_LEN];
|
u8 pubkey_hash[WPS_HASH_LEN];
|
||||||
|
|
||||||
|
addr[0] = wpabuf_head(pubkey);
|
||||||
|
hash_len = wpabuf_len(pubkey);
|
||||||
|
sha256_vector(1, addr, &hash_len, pubkey_hash);
|
||||||
|
|
||||||
|
wpabuf_put_be16(msg, ATTR_OOB_DEVICE_PASSWORD);
|
||||||
|
wpabuf_put_be16(msg, WPS_OOB_PUBKEY_HASH_LEN + 2 + dev_pw_len);
|
||||||
|
wpabuf_put_data(msg, pubkey_hash, WPS_OOB_PUBKEY_HASH_LEN);
|
||||||
|
wpabuf_put_be16(msg, dev_pw_id);
|
||||||
|
wpabuf_put_data(msg, dev_pw, dev_pw_len);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int wps_build_oob_dev_password(struct wpabuf *msg, struct wps_context *wps)
|
||||||
|
{
|
||||||
u8 dev_password_bin[WPS_OOB_DEVICE_PASSWORD_LEN];
|
u8 dev_password_bin[WPS_OOB_DEVICE_PASSWORD_LEN];
|
||||||
|
|
||||||
wpa_printf(MSG_DEBUG, "WPS: * OOB Device Password");
|
wpa_printf(MSG_DEBUG, "WPS: * OOB Device Password");
|
||||||
|
|
||||||
addr[0] = wpabuf_head(wps->dh_pubkey);
|
|
||||||
hash_len = wpabuf_len(wps->dh_pubkey);
|
|
||||||
sha256_vector(1, addr, &hash_len, pubkey_hash);
|
|
||||||
|
|
||||||
if (os_get_random((u8 *) &wps->oob_dev_pw_id, sizeof(u16)) < 0) {
|
if (os_get_random((u8 *) &wps->oob_dev_pw_id, sizeof(u16)) < 0) {
|
||||||
wpa_printf(MSG_ERROR, "WPS: device password id "
|
wpa_printf(MSG_ERROR, "WPS: device password id "
|
||||||
"generation error");
|
"generation error");
|
||||||
|
@ -367,19 +382,15 @@ int wps_build_oob_dev_password(struct wpabuf *msg, struct wps_context *wps)
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
wpabuf_put_be16(msg, ATTR_OOB_DEVICE_PASSWORD);
|
|
||||||
wpabuf_put_be16(msg, WPS_OOB_DEVICE_PASSWORD_ATTR_LEN);
|
|
||||||
wpabuf_put_data(msg, pubkey_hash, WPS_OOB_PUBKEY_HASH_LEN);
|
|
||||||
wpabuf_put_be16(msg, wps->oob_dev_pw_id);
|
|
||||||
wpabuf_put_data(msg, dev_password_bin, WPS_OOB_DEVICE_PASSWORD_LEN);
|
|
||||||
|
|
||||||
wpa_snprintf_hex_uppercase(
|
wpa_snprintf_hex_uppercase(
|
||||||
wpabuf_put(wps->oob_conf.dev_password,
|
wpabuf_put(wps->oob_conf.dev_password,
|
||||||
wpabuf_size(wps->oob_conf.dev_password)),
|
wpabuf_size(wps->oob_conf.dev_password)),
|
||||||
wpabuf_size(wps->oob_conf.dev_password),
|
wpabuf_size(wps->oob_conf.dev_password),
|
||||||
dev_password_bin, WPS_OOB_DEVICE_PASSWORD_LEN);
|
dev_password_bin, WPS_OOB_DEVICE_PASSWORD_LEN);
|
||||||
|
|
||||||
return 0;
|
return wps_build_oob_dev_pw(msg, wps->oob_dev_pw_id, wps->dh_pubkey,
|
||||||
|
dev_password_bin,
|
||||||
|
WPS_OOB_DEVICE_PASSWORD_LEN);
|
||||||
}
|
}
|
||||||
#endif /* CONFIG_WPS_OOB */
|
#endif /* CONFIG_WPS_OOB */
|
||||||
|
|
||||||
|
|
|
@ -255,6 +255,9 @@ int wps_build_auth_type_flags(struct wps_data *wps, struct wpabuf *msg);
|
||||||
int wps_build_encr_type_flags(struct wps_data *wps, struct wpabuf *msg);
|
int wps_build_encr_type_flags(struct wps_data *wps, struct wpabuf *msg);
|
||||||
int wps_build_conn_type_flags(struct wps_data *wps, struct wpabuf *msg);
|
int wps_build_conn_type_flags(struct wps_data *wps, struct wpabuf *msg);
|
||||||
int wps_build_assoc_state(struct wps_data *wps, struct wpabuf *msg);
|
int wps_build_assoc_state(struct wps_data *wps, struct wpabuf *msg);
|
||||||
|
int wps_build_oob_dev_pw(struct wpabuf *msg, u16 dev_pw_id,
|
||||||
|
const struct wpabuf *pubkey, const u8 *dev_pw,
|
||||||
|
size_t dev_pw_len);
|
||||||
int wps_build_oob_dev_password(struct wpabuf *msg, struct wps_context *wps);
|
int wps_build_oob_dev_password(struct wpabuf *msg, struct wps_context *wps);
|
||||||
struct wpabuf * wps_ie_encapsulate(struct wpabuf *data);
|
struct wpabuf * wps_ie_encapsulate(struct wpabuf *data);
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue