mirror of
https://github.com/openwrt/openwrt.git
synced 2025-01-18 10:46:41 +00:00
a463bd8c99
8e6485a1bcb0 PEAP client: Update Phase 2 authentication requirements de9a11f4dde9 TTLS client: Support phase2_auth=2 b2a1e7fe7ab9 tests: PEAP and TTLS phase2_auth behavior 518ae8c7cca8 P2P: Do not print control characters in debug a4c133ea73c7 WPS: Optimize attribute parsing workaround 7a37a94eaa0d Check whether element parsing has failed f80d83368818 ACS: Remove invalid debug print fb2b7858a728 FILS: Fix HE MCS field initialization 50ee26fc7044 P2P: Check p2p_channel_select() return value a50d1ea6a2b3 Add QCA vendor attributes for user defined power save parameters 4636476b7f22 Set RRM used config if the (Re)Association Request frame has RRM IE e53d44ac63e8 AP MLD: Use STA assoc link address in external auth status to the driver 99a96b2f9df7 AP MLD: OWE when SME is offloaded to the driver 96deacf5d710 nl80211: Skip STA MLO link channel switch handling in AP mode d320692d918a AP MLD: Handle new STA event when using SME offload to the driver faee8b99e928 tests: Fix eht_mld_sae_legacy_client to restore sae_pwe c3f465c56c94 wlantest: Handle variable length MIC field in EAPOL-Key with OWE 605034240e0c wlantest: Support multiple input files 053bd8af8ed2 Recognize FTE MLO subelements 43b5f11d969a Defragmentation of FTE 3973300b8ded FTE protected element check for MLO Reassociation Response frame 74e4a0a6f1e4 wlantest: Learn AP MLD MAC address from Beacon frames a5a0b2cf7b1b wlantest: Find non-AP MLD only from affiliated BSSs of the AP MLD 74472758584d wlantest: Recognize non-AP MLD based on any link address for decryption 1ffabd697c67 wlantest: Learn non-AP MLD MAC address from (Re)Association Request frames 4e8e515f92b9 wlantest: Use MLO search for the STA in reassociation 49bf9f2df95a wlantest: Use the MLD MAC address as well for matching STA entries 5434a42ec69c wlantest: Search for FT Target AP using MLD MAC address as well a19fcf685cae wlantest: Include the MLD MAC address of the AP MLD in new-STA prints 709d46da73da wlantest: Do not claim update to AP MD MAC address if no change 770760454f9e wlantest: Do not update BSS entries for other AP MLDs in PTK cloning 084745ffc508 Add QCA vendor attributes for NDP setup bf9cbb462fd9 Fix writing of BIGTK in FT protocol 011775af9443 tests: Check for beacon loss when using beacon protection 8f148d51322f Fix a compiler warning on prototype mismatch b7db495ad9c9 AP: Fix ieee802_1x_ml_set_sta_authorized() 232667eafe0d Fix CCMP test vector issues 30771e6e05ed Include PTID in PV1 nonce construction for CCMP test vector 34841cfd9aba Minor formatting changes to CCMP test vectors a685d84139e6 BSS coloring: Fix CCA with multiple BSS bc0636841a70 wpa_supplicant: Fix configuration parsing error for tx_queue_* 2763d1d97e66 hostapd: Fix AID assignment in multiple BSSID 763a19286e2f AP: Add configuration option to specify the desired MLD address bd209633eb10 AP: Use is_zero_ether_addr() to check if BSSID is NULL bc0268d053b4 wlantest: Guess SAE/OWE group from EAPOL-Key length mismatch a94ba5322803 EHT: Support puncturing for 320 MHz channel bandwidth 7e1f5c44c97e EHT: 320 MHz DFS support 6f293b32112a QCA vendor attributes for updating roaming AP BSSID info 5856373554eb Extend QCA vendor command to include more parameters for netdev events e080930aa0a5 Define QCA vendor roam control RSSI attributes fe72afe713ad Define QCA vendor attribute for high RSSI roam trigger threshold 47a65ccbfde2 P2P: Clean wpa_s->last_ssid when removing a temporary group network 884125ab7d21 tests: P2P autonomous GO and clearing of networking information 7637d0f25053 P2P: Do not filter pref_freq_list if the driver does not provide one dd1330b502ff Fix hostapd interface cleanup with multiple interfaces 0a6842d5030e nl80211: Fix beacon rate configuration for legacy rates 36, 48, 54 Mbps d606efe054d5 tests: Beacon rate configuration for 54 Mbps f91d10c0e6aa tests: Update RSA 3k certificates 07d3c1177bbb tests: Make sae_proto_hostapd_status_* more robust 1085e3bdc6f6 Update iface->current_mode when fetching new hw_features 338a78846b44 Add a QCA vendor sub command for transmit latency statistics 9318db7c38bc wlantest: Use local variables for AA/SPA in FT Request/Response processing 628b9f10223d wlantest: Derive PMK-R1 and PTK using AA/SPA for MLO FT over-the-DS 104aa291e5c8 wlantest: Fix FT over-the-DS decryption 37c87efecfe3 wlantest: Search SPA using MLO aware find for FT Request/Response frame 19f33d7929e8 wlantest: Learn the Link ID for AP MLD affiliated BSSs 6ae43bb10323 wlantest: Learn link address for assoc link from (Re)Association Request 4c079dcc64da Increment hmac_sha*_vector() maximum num_elem value to 25 e6f64a8e1daf FT: FTE MIC calculation for MLO Reassociation Request frame a83575df5994 wlantest: FTE MIC calculation for MLO Reassociation Request frames ff02f734baf8 wlantest: Allow specific link BSS to be found with bss_find_mld() 7381c60db8f0 FT: Make FTE MIC calculation more flexible ac9bf1cc2a4c Decrement hmac_sha*_vector() maximum num_elem value to 11 aa08d9d76803 Fix use of defragmented FTE information 78b153f90a74 Calculate defragmented FTE length during IE parsing 8cf919ffd5c4 wlantest: FTE MIC calculation for MLO Reassociation Response frame d12a3dce82a9 wlantest: Store and check SNonce/ANonce for FT Authentication 20febfd7838d wlantest: Dump MLO association information in debug 609864d6a8a1 Add QCA vendor attribute to configure MLD ID in ML probe request 12154861e24a Add support for conversion to little endian for 24 bits c437665041c0 Add Non EHT SCS Capability in (Re)Association Request frames 33da386553b7 SCS: Add support for QoS Characteristics in SCS request edfca280cbe8 SCS: Add support for optional QoS Charateristics parameters 32dcec9529ec Send actual MFP configuration when driver takes care of BSS selection 123d16d860fa Update hw_mode when CSA finishes b3d852560bda Change QCA vendor configure attribution name of peer MAC address 12fabc4765c2 Add QCA vendor attribute for configuring max A-MPDU aggregation count f6eaa7b729cb Add QCA vendor attribute for TTLM negotiation support type f6dcd326fea7 wlantest: Indicate ToDS/FromDS values for BSS DATA entries 6ce745bb87d4 wlantest: MLO support for decrypting 4-address frames 850dc1482953 wlantest: Remove duplicated A1/A2/A3 override detection for MLO 770e5a808fbb wlantest: Determine whether A1 points to STA once in rx_data_bss_prot() 377d617b574a Define new BSS command info mask for AP MLD address d3ab6e001f62 wlantest: Use non-AP MLD's MLD MAC address in FT over-the-air derivation a845601ffe32 wlantest: Derive PTK in MLO using MLD MAC addresses for FT over-the-air 0cd2bfc8a402 wlantest: Fix FTE MIC calculation for MLO Reassociation Response frames 528abdeb673b wlantest: Learn group keys from MLO FT Reassociation Response frames 990600753dd9 wlantest: Defragment Basic MLE before processing de043ec01ab5 wlantest: Defragment the Per-STA Profile subelement bae1ec693c44 wlantest: Minimal parsing of Basic MLE STA Profile ba1579f3bf7c Clear BIGTK values from wpa_supplicant state machine when not needed b46c4b9a916a tests: Beacon protection and reconnection 3e71516936b7 Document per-ESS MAC address (mac_addr=3 and mac_value) f85b2b2dee3b Extend wpa_parse_kde_ies() to include EHT capabilities e3a68081bc1e driver: Add option for link ID to be specified for send_tdls_mgmt() c7561502f2e8 nl80211: Use a QCA vendor command to set the link for TDLS Discovery Response a41c8dbdd84e TDLS: Copy peer's EHT capabilities 626501434be1 TDLS: Learn MLD link ID from TDLS Discovery Response 5f30f62eead7 TDLS: Reply to Discovery Request on the link with matching BSSID 940ef9a05c0f TDLS: Use link-specific BSSID instead of sm->bssid for MLO cases f429064189c3 TDLS: Set EHT/MLO information for TDLS STA into the driver dd25885a9daa Remove space-before-tab in QCA vendor related definitions af6e0306b2a9 Fix typos in QCA vendor related definitions 4c9af238c1e4 Fix inconsistent whitespace use in QCA vendor related definitions e5ccbfc69ecf Split long comment lines in QCA vendor related definitions Signed-off-by: Felix Fietkau <nbd@nbd.name>
155 lines
4.4 KiB
Diff
155 lines
4.4 KiB
Diff
--- a/hostapd/Makefile
|
|
+++ b/hostapd/Makefile
|
|
@@ -63,6 +63,10 @@ endif
|
|
OBJS += main.o
|
|
OBJS += config_file.o
|
|
|
|
+ifdef CONFIG_RADIUS_SERVER
|
|
+OBJS += radius.o
|
|
+endif
|
|
+
|
|
OBJS += ../src/ap/hostapd.o
|
|
OBJS += ../src/ap/wpa_auth_glue.o
|
|
OBJS += ../src/ap/drv_callbacks.o
|
|
--- a/hostapd/main.c
|
|
+++ b/hostapd/main.c
|
|
@@ -40,6 +40,7 @@ struct hapd_global {
|
|
|
|
static struct hapd_global global;
|
|
|
|
+extern int radius_main(int argc, char **argv);
|
|
|
|
#ifndef CONFIG_NO_HOSTAPD_LOGGER
|
|
static void hostapd_logger_cb(void *ctx, const u8 *addr, unsigned int module,
|
|
@@ -771,6 +772,11 @@ int main(int argc, char *argv[])
|
|
if (os_program_init())
|
|
return -1;
|
|
|
|
+#ifdef RADIUS_SERVER
|
|
+ if (strstr(argv[0], "radius"))
|
|
+ return radius_main(argc, argv);
|
|
+#endif
|
|
+
|
|
os_memset(&interfaces, 0, sizeof(interfaces));
|
|
interfaces.reload_config = hostapd_reload_config;
|
|
interfaces.config_read_cb = hostapd_config_read;
|
|
--- a/src/radius/radius_server.c
|
|
+++ b/src/radius/radius_server.c
|
|
@@ -63,6 +63,12 @@ struct radius_server_counters {
|
|
u32 unknown_acct_types;
|
|
};
|
|
|
|
+struct radius_accept_attr {
|
|
+ u8 type;
|
|
+ u16 len;
|
|
+ void *data;
|
|
+};
|
|
+
|
|
/**
|
|
* struct radius_session - Internal RADIUS server data for a session
|
|
*/
|
|
@@ -90,7 +96,7 @@ struct radius_session {
|
|
unsigned int macacl:1;
|
|
unsigned int t_c_filtering:1;
|
|
|
|
- struct hostapd_radius_attr *accept_attr;
|
|
+ struct radius_accept_attr *accept_attr;
|
|
|
|
u32 t_c_timestamp; /* Last read T&C timestamp from user DB */
|
|
};
|
|
@@ -394,6 +400,7 @@ static void radius_server_session_free(s
|
|
radius_msg_free(sess->last_reply);
|
|
os_free(sess->username);
|
|
os_free(sess->nas_ip);
|
|
+ os_free(sess->accept_attr);
|
|
os_free(sess);
|
|
data->num_sess--;
|
|
}
|
|
@@ -554,6 +561,36 @@ radius_server_erp_find_key(struct radius
|
|
}
|
|
#endif /* CONFIG_ERP */
|
|
|
|
+static struct radius_accept_attr *
|
|
+radius_server_copy_attr(const struct hostapd_radius_attr *data)
|
|
+{
|
|
+ const struct hostapd_radius_attr *attr;
|
|
+ struct radius_accept_attr *attr_new;
|
|
+ size_t data_size = 0;
|
|
+ void *data_buf;
|
|
+ int n_attr = 1;
|
|
+
|
|
+ for (attr = data; attr; attr = attr->next) {
|
|
+ n_attr++;
|
|
+ data_size += wpabuf_len(attr->val);
|
|
+ }
|
|
+
|
|
+ attr_new = os_zalloc(n_attr * sizeof(*attr) + data_size);
|
|
+ if (!attr_new)
|
|
+ return NULL;
|
|
+
|
|
+ data_buf = &attr_new[n_attr];
|
|
+ for (n_attr = 0, attr = data; attr; attr = attr->next) {
|
|
+ struct radius_accept_attr *cur = &attr_new[n_attr++];
|
|
+
|
|
+ cur->type = attr->type;
|
|
+ cur->len = wpabuf_len(attr->val);
|
|
+ cur->data = memcpy(data_buf, wpabuf_head(attr->val), cur->len);
|
|
+ data_buf += cur->len;
|
|
+ }
|
|
+
|
|
+ return attr_new;
|
|
+}
|
|
|
|
static struct radius_session *
|
|
radius_server_get_new_session(struct radius_server_data *data,
|
|
@@ -607,7 +644,7 @@ radius_server_get_new_session(struct rad
|
|
eap_user_free(tmp);
|
|
return NULL;
|
|
}
|
|
- sess->accept_attr = tmp->accept_attr;
|
|
+ sess->accept_attr = radius_server_copy_attr(tmp->accept_attr);
|
|
sess->macacl = tmp->macacl;
|
|
eap_user_free(tmp);
|
|
|
|
@@ -1118,11 +1155,10 @@ radius_server_encapsulate_eap(struct rad
|
|
}
|
|
|
|
if (code == RADIUS_CODE_ACCESS_ACCEPT) {
|
|
- struct hostapd_radius_attr *attr;
|
|
- for (attr = sess->accept_attr; attr; attr = attr->next) {
|
|
- if (!radius_msg_add_attr(msg, attr->type,
|
|
- wpabuf_head(attr->val),
|
|
- wpabuf_len(attr->val))) {
|
|
+ struct radius_accept_attr *attr;
|
|
+ for (attr = sess->accept_attr; attr->data; attr++) {
|
|
+ if (!radius_msg_add_attr(msg, attr->type, attr->data,
|
|
+ attr->len)) {
|
|
wpa_printf(MSG_ERROR, "Could not add RADIUS attribute");
|
|
radius_msg_free(msg);
|
|
return NULL;
|
|
@@ -1211,11 +1247,10 @@ radius_server_macacl(struct radius_serve
|
|
}
|
|
|
|
if (code == RADIUS_CODE_ACCESS_ACCEPT) {
|
|
- struct hostapd_radius_attr *attr;
|
|
- for (attr = sess->accept_attr; attr; attr = attr->next) {
|
|
- if (!radius_msg_add_attr(msg, attr->type,
|
|
- wpabuf_head(attr->val),
|
|
- wpabuf_len(attr->val))) {
|
|
+ struct radius_accept_attr *attr;
|
|
+ for (attr = sess->accept_attr; attr->data; attr++) {
|
|
+ if (!radius_msg_add_attr(msg, attr->type, attr->data,
|
|
+ attr->len)) {
|
|
wpa_printf(MSG_ERROR, "Could not add RADIUS attribute");
|
|
radius_msg_free(msg);
|
|
return NULL;
|
|
@@ -2512,7 +2547,7 @@ static int radius_server_get_eap_user(vo
|
|
ret = data->get_eap_user(data->conf_ctx, identity, identity_len,
|
|
phase2, user);
|
|
if (ret == 0 && user) {
|
|
- sess->accept_attr = user->accept_attr;
|
|
+ sess->accept_attr = radius_server_copy_attr(user->accept_attr);
|
|
sess->remediation = user->remediation;
|
|
sess->macacl = user->macacl;
|
|
sess->t_c_timestamp = user->t_c_timestamp;
|