|
@@ -40,6 +40,7 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
size_t len;
|
|
|
int i;
|
|
|
struct wpabuf *b;
|
|
|
+ struct hostapd_radius_attr *attr;
|
|
|
|
|
|
msg = radius_msg_new(RADIUS_CODE_ACCOUNTING_REQUEST,
|
|
|
radius_client_get_id(hapd->radius));
|
|
@@ -68,7 +69,9 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
goto fail;
|
|
|
}
|
|
|
|
|
|
- if (!radius_msg_add_attr_int32(msg, RADIUS_ATTR_ACCT_AUTHENTIC,
|
|
|
+ if (!hostapd_config_get_radius_attr(hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_ACCT_AUTHENTIC) &&
|
|
|
+ !radius_msg_add_attr_int32(msg, RADIUS_ATTR_ACCT_AUTHENTIC,
|
|
|
hapd->conf->ieee802_1x ?
|
|
|
RADIUS_ACCT_AUTHENTIC_RADIUS :
|
|
|
RADIUS_ACCT_AUTHENTIC_LOCAL)) {
|
|
@@ -92,7 +95,9 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
- if (hapd->conf->own_ip_addr.af == AF_INET &&
|
|
|
+ if (!hostapd_config_get_radius_attr(hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_NAS_IP_ADDRESS) &&
|
|
|
+ hapd->conf->own_ip_addr.af == AF_INET &&
|
|
|
!radius_msg_add_attr(msg, RADIUS_ATTR_NAS_IP_ADDRESS,
|
|
|
(u8 *) &hapd->conf->own_ip_addr.u.v4, 4)) {
|
|
|
printf("Could not add NAS-IP-Address\n");
|
|
@@ -100,7 +105,9 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
}
|
|
|
|
|
|
#ifdef CONFIG_IPV6
|
|
|
- if (hapd->conf->own_ip_addr.af == AF_INET6 &&
|
|
|
+ if (!hostapd_config_get_radius_attr(hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_NAS_IPV6_ADDRESS) &&
|
|
|
+ hapd->conf->own_ip_addr.af == AF_INET6 &&
|
|
|
!radius_msg_add_attr(msg, RADIUS_ATTR_NAS_IPV6_ADDRESS,
|
|
|
(u8 *) &hapd->conf->own_ip_addr.u.v6, 16)) {
|
|
|
printf("Could not add NAS-IPv6-Address\n");
|
|
@@ -108,7 +115,9 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
}
|
|
|
#endif /* CONFIG_IPV6 */
|
|
|
|
|
|
- if (hapd->conf->nas_identifier &&
|
|
|
+ if (!hostapd_config_get_radius_attr(hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_NAS_IDENTIFIER) &&
|
|
|
+ hapd->conf->nas_identifier &&
|
|
|
!radius_msg_add_attr(msg, RADIUS_ATTR_NAS_IDENTIFIER,
|
|
|
(u8 *) hapd->conf->nas_identifier,
|
|
|
os_strlen(hapd->conf->nas_identifier))) {
|
|
@@ -116,7 +125,9 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
goto fail;
|
|
|
}
|
|
|
|
|
|
- if (sta &&
|
|
|
+ if (!hostapd_config_get_radius_attr(hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_NAS_PORT) &&
|
|
|
+ sta &&
|
|
|
!radius_msg_add_attr_int32(msg, RADIUS_ATTR_NAS_PORT, sta->aid)) {
|
|
|
printf("Could not add NAS-Port\n");
|
|
|
goto fail;
|
|
@@ -124,7 +135,9 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
|
|
|
os_snprintf(buf, sizeof(buf), RADIUS_802_1X_ADDR_FORMAT ":%s",
|
|
|
MAC2STR(hapd->own_addr), hapd->conf->ssid.ssid);
|
|
|
- if (!radius_msg_add_attr(msg, RADIUS_ATTR_CALLED_STATION_ID,
|
|
|
+ if (!hostapd_config_get_radius_attr(hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_CALLED_STATION_ID) &&
|
|
|
+ !radius_msg_add_attr(msg, RADIUS_ATTR_CALLED_STATION_ID,
|
|
|
(u8 *) buf, os_strlen(buf))) {
|
|
|
printf("Could not add Called-Station-Id\n");
|
|
|
goto fail;
|
|
@@ -139,7 +152,10 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
goto fail;
|
|
|
}
|
|
|
|
|
|
- if (!radius_msg_add_attr_int32(
|
|
|
+ if (!hostapd_config_get_radius_attr(
|
|
|
+ hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_NAS_PORT_TYPE) &&
|
|
|
+ !radius_msg_add_attr_int32(
|
|
|
msg, RADIUS_ATTR_NAS_PORT_TYPE,
|
|
|
RADIUS_NAS_PORT_TYPE_IEEE_802_11)) {
|
|
|
printf("Could not add NAS-Port-Type\n");
|
|
@@ -150,7 +166,10 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
radius_sta_rate(hapd, sta) / 2,
|
|
|
(radius_sta_rate(hapd, sta) & 1) ? ".5" : "",
|
|
|
radius_mode_txt(hapd));
|
|
|
- if (!radius_msg_add_attr(msg, RADIUS_ATTR_CONNECT_INFO,
|
|
|
+ if (!hostapd_config_get_radius_attr(
|
|
|
+ hapd->conf->radius_acct_req_attr,
|
|
|
+ RADIUS_ATTR_CONNECT_INFO) &&
|
|
|
+ !radius_msg_add_attr(msg, RADIUS_ATTR_CONNECT_INFO,
|
|
|
(u8 *) buf, os_strlen(buf))) {
|
|
|
printf("Could not add Connect-Info\n");
|
|
|
goto fail;
|
|
@@ -179,6 +198,17 @@ static struct radius_msg * accounting_msg(struct hostapd_data *hapd,
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ for (attr = hapd->conf->radius_acct_req_attr; attr; attr = attr->next)
|
|
|
+ {
|
|
|
+ if (!radius_msg_add_attr(msg, attr->type,
|
|
|
+ wpabuf_head(attr->val),
|
|
|
+ wpabuf_len(attr->val))) {
|
|
|
+ wpa_printf(MSG_ERROR, "Could not add RADIUS "
|
|
|
+ "attribute");
|
|
|
+ goto fail;
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
return msg;
|
|
|
|
|
|
fail:
|