Interworking: Fix home SP check with real SIM card
The NAI building routine assumed that the credential included the IMSI, but that is not the case when using a real SIM card. Build the NAI based on the IMSI read for the card in such a case. Signed-hostap: Jouni Malinen <j@w1.fi>
This commit is contained in:
parent
8f23401281
commit
632c9458c4
1 changed files with 20 additions and 7 deletions
|
@ -563,7 +563,7 @@ static int plmn_id_match(struct wpabuf *anqp, const char *imsi, int mnc_len)
|
||||||
|
|
||||||
|
|
||||||
static int build_root_nai(char *nai, size_t nai_len, const char *imsi,
|
static int build_root_nai(char *nai, size_t nai_len, const char *imsi,
|
||||||
char prefix)
|
size_t mnc_len, char prefix)
|
||||||
{
|
{
|
||||||
const char *sep, *msin;
|
const char *sep, *msin;
|
||||||
char *end, *pos;
|
char *end, *pos;
|
||||||
|
@ -581,12 +581,16 @@ static int build_root_nai(char *nai, size_t nai_len, const char *imsi,
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
sep = os_strchr(imsi, '-');
|
sep = os_strchr(imsi, '-');
|
||||||
if (sep == NULL)
|
if (sep) {
|
||||||
return -1;
|
|
||||||
plmn_len = sep - imsi;
|
plmn_len = sep - imsi;
|
||||||
|
msin = sep + 1;
|
||||||
|
} else if (mnc_len && os_strlen(imsi) >= 3 + mnc_len) {
|
||||||
|
plmn_len = 3 + mnc_len;
|
||||||
|
msin = imsi + plmn_len;
|
||||||
|
} else
|
||||||
|
return -1;
|
||||||
if (plmn_len != 5 && plmn_len != 6)
|
if (plmn_len != 5 && plmn_len != 6)
|
||||||
return -1;
|
return -1;
|
||||||
msin = sep + 1;
|
|
||||||
msin_len = os_strlen(msin);
|
msin_len = os_strlen(msin);
|
||||||
|
|
||||||
pos = nai;
|
pos = nai;
|
||||||
|
@ -617,7 +621,7 @@ static int build_root_nai(char *nai, size_t nai_len, const char *imsi,
|
||||||
static int set_root_nai(struct wpa_ssid *ssid, const char *imsi, char prefix)
|
static int set_root_nai(struct wpa_ssid *ssid, const char *imsi, char prefix)
|
||||||
{
|
{
|
||||||
char nai[100];
|
char nai[100];
|
||||||
if (build_root_nai(nai, sizeof(nai), imsi, prefix) < 0)
|
if (build_root_nai(nai, sizeof(nai), imsi, 0, prefix) < 0)
|
||||||
return -1;
|
return -1;
|
||||||
return wpa_config_set_quoted(ssid, "identity", nai);
|
return wpa_config_set_quoted(ssid, "identity", nai);
|
||||||
}
|
}
|
||||||
|
@ -1311,8 +1315,17 @@ static int interworking_home_sp(struct wpa_supplicant *wpa_s,
|
||||||
|
|
||||||
for (cred = wpa_s->conf->cred; cred; cred = cred->next) {
|
for (cred = wpa_s->conf->cred; cred; cred = cred->next) {
|
||||||
#ifdef INTERWORKING_3GPP
|
#ifdef INTERWORKING_3GPP
|
||||||
if (cred->imsi &&
|
char *imsi = NULL;
|
||||||
build_root_nai(nai, sizeof(nai), cred->imsi, 0) == 0) {
|
int mnc_len = 0;
|
||||||
|
if (cred->imsi)
|
||||||
|
imsi = cred->imsi;
|
||||||
|
else if (cred->pcsc && wpa_s->conf->pcsc_reader &&
|
||||||
|
wpa_s->scard && wpa_s->imsi[0]) {
|
||||||
|
imsi = wpa_s->imsi;
|
||||||
|
mnc_len = wpa_s->mnc_len;
|
||||||
|
}
|
||||||
|
if (imsi && build_root_nai(nai, sizeof(nai), imsi, mnc_len, 0)
|
||||||
|
== 0) {
|
||||||
realm = os_strchr(nai, '@');
|
realm = os_strchr(nai, '@');
|
||||||
if (realm)
|
if (realm)
|
||||||
realm++;
|
realm++;
|
||||||
|
|
Loading…
Reference in a new issue