AP: Allow both WPA passphrase and PSK to be configured
Instead of dropping the configured PSK and deriving it based on passphrase, use the provided PSK as-is and also maintain a copy of the passphrase since it can be of use later. This allows both values to be configured without havign to derive the PSK every time the network is initialized.
This commit is contained in:
parent
1078126f64
commit
0ae687bd10
1 changed files with 28 additions and 18 deletions
|
@ -448,16 +448,8 @@ static int hostapd_config_read_wpa_psk(const char *fname,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int hostapd_setup_wpa_psk(struct hostapd_bss_config *conf)
|
static int hostapd_derive_psk(struct hostapd_ssid *ssid)
|
||||||
{
|
{
|
||||||
struct hostapd_ssid *ssid = &conf->ssid;
|
|
||||||
|
|
||||||
if (ssid->wpa_passphrase != NULL) {
|
|
||||||
if (ssid->wpa_psk != NULL) {
|
|
||||||
wpa_printf(MSG_ERROR, "Warning: both WPA PSK and "
|
|
||||||
"passphrase set. Using passphrase.");
|
|
||||||
os_free(ssid->wpa_psk);
|
|
||||||
}
|
|
||||||
ssid->wpa_psk = os_zalloc(sizeof(struct hostapd_wpa_psk));
|
ssid->wpa_psk = os_zalloc(sizeof(struct hostapd_wpa_psk));
|
||||||
if (ssid->wpa_psk == NULL) {
|
if (ssid->wpa_psk == NULL) {
|
||||||
wpa_printf(MSG_ERROR, "Unable to alloc space for PSK");
|
wpa_printf(MSG_ERROR, "Unable to alloc space for PSK");
|
||||||
|
@ -465,14 +457,32 @@ int hostapd_setup_wpa_psk(struct hostapd_bss_config *conf)
|
||||||
}
|
}
|
||||||
wpa_hexdump_ascii(MSG_DEBUG, "SSID",
|
wpa_hexdump_ascii(MSG_DEBUG, "SSID",
|
||||||
(u8 *) ssid->ssid, ssid->ssid_len);
|
(u8 *) ssid->ssid, ssid->ssid_len);
|
||||||
wpa_hexdump_ascii(MSG_DEBUG, "PSK (ASCII passphrase)",
|
wpa_hexdump_ascii_key(MSG_DEBUG, "PSK (ASCII passphrase)",
|
||||||
(u8 *) ssid->wpa_passphrase,
|
(u8 *) ssid->wpa_passphrase,
|
||||||
os_strlen(ssid->wpa_passphrase));
|
os_strlen(ssid->wpa_passphrase));
|
||||||
pbkdf2_sha1(ssid->wpa_passphrase,
|
pbkdf2_sha1(ssid->wpa_passphrase,
|
||||||
ssid->ssid, ssid->ssid_len,
|
ssid->ssid, ssid->ssid_len,
|
||||||
4096, ssid->wpa_psk->psk, PMK_LEN);
|
4096, ssid->wpa_psk->psk, PMK_LEN);
|
||||||
wpa_hexdump(MSG_DEBUG, "PSK (from passphrase)",
|
wpa_hexdump_key(MSG_DEBUG, "PSK (from passphrase)",
|
||||||
ssid->wpa_psk->psk, PMK_LEN);
|
ssid->wpa_psk->psk, PMK_LEN);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int hostapd_setup_wpa_psk(struct hostapd_bss_config *conf)
|
||||||
|
{
|
||||||
|
struct hostapd_ssid *ssid = &conf->ssid;
|
||||||
|
|
||||||
|
if (ssid->wpa_passphrase != NULL) {
|
||||||
|
if (ssid->wpa_psk != NULL) {
|
||||||
|
wpa_printf(MSG_DEBUG, "Using pre-configured WPA PSK "
|
||||||
|
"instead of passphrase");
|
||||||
|
} else {
|
||||||
|
wpa_printf(MSG_DEBUG, "Deriving WPA PSK based on "
|
||||||
|
"passphrase");
|
||||||
|
if (hostapd_derive_psk(ssid) < 0)
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
ssid->wpa_psk->group = 1;
|
ssid->wpa_psk->group = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue