eapol_test: Allow generated RADIUS attributes to be replaced
Do not add the automatically generated RADIUS attributes NAS-IP-Address, Calling-Station-Id, Framed-MTU, NAS-Port-Type, and Connect-Info if -N option is used with the same attribute type. This allows these attributes to be replaced without causing duplicate entries.
This commit is contained in:
parent
8f33641c94
commit
676ea3413d
1 changed files with 23 additions and 5 deletions
|
@ -156,6 +156,18 @@ static int add_extra_attrs(struct radius_msg *msg,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static struct extra_radius_attr *
|
||||||
|
find_extra_attr(struct extra_radius_attr *attrs, u8 type)
|
||||||
|
{
|
||||||
|
struct extra_radius_attr *p;
|
||||||
|
for (p = attrs; p; p = p->next) {
|
||||||
|
if (p->type == type)
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
static void ieee802_1x_encapsulate_radius(struct eapol_test_data *e,
|
static void ieee802_1x_encapsulate_radius(struct eapol_test_data *e,
|
||||||
const u8 *eap, size_t len)
|
const u8 *eap, size_t len)
|
||||||
{
|
{
|
||||||
|
@ -200,7 +212,8 @@ static void ieee802_1x_encapsulate_radius(struct eapol_test_data *e,
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!radius_msg_add_attr(msg, RADIUS_ATTR_NAS_IP_ADDRESS,
|
if (!find_extra_attr(e->extra_attrs, RADIUS_ATTR_NAS_IP_ADDRESS) &&
|
||||||
|
!radius_msg_add_attr(msg, RADIUS_ATTR_NAS_IP_ADDRESS,
|
||||||
(u8 *) &e->own_ip_addr, 4)) {
|
(u8 *) &e->own_ip_addr, 4)) {
|
||||||
printf("Could not add NAS-IP-Address\n");
|
printf("Could not add NAS-IP-Address\n");
|
||||||
goto fail;
|
goto fail;
|
||||||
|
@ -208,7 +221,9 @@ static void ieee802_1x_encapsulate_radius(struct eapol_test_data *e,
|
||||||
|
|
||||||
os_snprintf(buf, sizeof(buf), RADIUS_802_1X_ADDR_FORMAT,
|
os_snprintf(buf, sizeof(buf), RADIUS_802_1X_ADDR_FORMAT,
|
||||||
MAC2STR(e->wpa_s->own_addr));
|
MAC2STR(e->wpa_s->own_addr));
|
||||||
if (!radius_msg_add_attr(msg, RADIUS_ATTR_CALLING_STATION_ID,
|
if (!find_extra_attr(e->extra_attrs, RADIUS_ATTR_CALLING_STATION_ID)
|
||||||
|
&&
|
||||||
|
!radius_msg_add_attr(msg, RADIUS_ATTR_CALLING_STATION_ID,
|
||||||
(u8 *) buf, os_strlen(buf))) {
|
(u8 *) buf, os_strlen(buf))) {
|
||||||
printf("Could not add Calling-Station-Id\n");
|
printf("Could not add Calling-Station-Id\n");
|
||||||
goto fail;
|
goto fail;
|
||||||
|
@ -217,19 +232,22 @@ static void ieee802_1x_encapsulate_radius(struct eapol_test_data *e,
|
||||||
/* TODO: should probably check MTU from driver config; 2304 is max for
|
/* TODO: should probably check MTU from driver config; 2304 is max for
|
||||||
* IEEE 802.11, but use 1400 to avoid problems with too large packets
|
* IEEE 802.11, but use 1400 to avoid problems with too large packets
|
||||||
*/
|
*/
|
||||||
if (!radius_msg_add_attr_int32(msg, RADIUS_ATTR_FRAMED_MTU, 1400)) {
|
if (!find_extra_attr(e->extra_attrs, RADIUS_ATTR_FRAMED_MTU) &&
|
||||||
|
!radius_msg_add_attr_int32(msg, RADIUS_ATTR_FRAMED_MTU, 1400)) {
|
||||||
printf("Could not add Framed-MTU\n");
|
printf("Could not add Framed-MTU\n");
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!radius_msg_add_attr_int32(msg, RADIUS_ATTR_NAS_PORT_TYPE,
|
if (!find_extra_attr(e->extra_attrs, RADIUS_ATTR_NAS_PORT_TYPE) &&
|
||||||
|
!radius_msg_add_attr_int32(msg, RADIUS_ATTR_NAS_PORT_TYPE,
|
||||||
RADIUS_NAS_PORT_TYPE_IEEE_802_11)) {
|
RADIUS_NAS_PORT_TYPE_IEEE_802_11)) {
|
||||||
printf("Could not add NAS-Port-Type\n");
|
printf("Could not add NAS-Port-Type\n");
|
||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
os_snprintf(buf, sizeof(buf), "%s", e->connect_info);
|
os_snprintf(buf, sizeof(buf), "%s", e->connect_info);
|
||||||
if (!radius_msg_add_attr(msg, RADIUS_ATTR_CONNECT_INFO,
|
if (!find_extra_attr(e->extra_attrs, RADIUS_ATTR_CONNECT_INFO) &&
|
||||||
|
!radius_msg_add_attr(msg, RADIUS_ATTR_CONNECT_INFO,
|
||||||
(u8 *) buf, os_strlen(buf))) {
|
(u8 *) buf, os_strlen(buf))) {
|
||||||
printf("Could not add Connect-Info\n");
|
printf("Could not add Connect-Info\n");
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
Loading…
Reference in a new issue