53d87406a6
Update wpa 2.8 --> 2.9 hostapd: * SAE changes - disable use of groups using Brainpool curves - improved protection against side channel attacks [https://w1.fi/security/2019-6/] * EAP-pwd changes - disable use of groups using Brainpool curves - improved protection against side channel attacks [https://w1.fi/security/2019-6/] * fixed FT-EAP initial mobility domain association using PMKSA caching * added configuration of airtime policy * fixed FILS to and RSNE into (Re)Association Response frames * fixed DPP bootstrapping URI parser of channel list * added support for regulatory WMM limitation (for ETSI) * added support for MACsec Key Agreement using IEEE 802.1X/PSK * added experimental support for EAP-TEAP server (RFC 7170) * added experimental support for EAP-TLS server with TLS v1.3 * added support for two server certificates/keys (RSA/ECC) * added AKMSuiteSelector into "STA <addr>" control interface data to determine with AKM was used for an association * added eap_sim_id parameter to allow EAP-SIM/AKA server pseudonym and fast reauthentication use to be disabled * fixed an ECDH operation corner case with OpenSSL wpa_supplicant: * SAE changes - disable use of groups using Brainpool curves - improved protection against side channel attacks [https://w1.fi/security/2019-6/] * EAP-pwd changes - disable use of groups using Brainpool curves - allow the set of groups to be configured (eap_pwd_groups) - improved protection against side channel attacks [https://w1.fi/security/2019-6/] * fixed FT-EAP initial mobility domain association using PMKSA caching (disabled by default for backwards compatibility; can be enabled with ft_eap_pmksa_caching=1) * fixed a regression in OpenSSL 1.1+ engine loading * added validation of RSNE in (Re)Association Response frames * fixed DPP bootstrapping URI parser of channel list * extended EAP-SIM/AKA fast re-authentication to allow use with FILS * extended ca_cert_blob to support PEM format * improved robustness of P2P Action frame scheduling * added support for EAP-SIM/AKA using anonymous@realm identity * fixed Hotspot 2.0 credential selection based on roaming consortium to ignore credentials without a specific EAP method * added experimental support for EAP-TEAP peer (RFC 7170) * added experimental support for EAP-TLS peer with TLS v1.3 * fixed a regression in WMM parameter configuration for a TDLS peer * fixed a regression in operation with drivers that offload 802.1X 4-way handshake * fixed an ECDH operation corner case with OpenSSL MFC after: 1 week Security: https://w1.fi/security/2019-6/\ sae-eap-pwd-side-channel-attack-update.txt
161 lines
7.2 KiB
C
161 lines
7.2 KiB
C
/*
|
|
* wpa_supplicant - Event notifications
|
|
* Copyright (c) 2009-2010, Jouni Malinen <j@w1.fi>
|
|
*
|
|
* This software may be distributed under the terms of the BSD license.
|
|
* See README for more details.
|
|
*/
|
|
|
|
#ifndef NOTIFY_H
|
|
#define NOTIFY_H
|
|
|
|
#include "p2p/p2p.h"
|
|
|
|
struct wps_credential;
|
|
struct wps_event_m2d;
|
|
struct wps_event_fail;
|
|
struct tls_cert_data;
|
|
|
|
int wpas_notify_supplicant_initialized(struct wpa_global *global);
|
|
void wpas_notify_supplicant_deinitialized(struct wpa_global *global);
|
|
int wpas_notify_iface_added(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_iface_removed(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_state_changed(struct wpa_supplicant *wpa_s,
|
|
enum wpa_states new_state,
|
|
enum wpa_states old_state);
|
|
void wpas_notify_disconnect_reason(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_auth_status_code(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_assoc_status_code(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_roam_time(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_roam_complete(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_session_length(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_bss_tm_status(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_network_changed(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_ap_scan_changed(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_bssid_changed(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_auth_changed(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_network_enabled_changed(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_network_selected(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_network_request(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid,
|
|
enum wpa_ctrl_req_type rtype,
|
|
const char *default_txt);
|
|
void wpas_notify_scanning(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_scan_done(struct wpa_supplicant *wpa_s, int success);
|
|
void wpas_notify_scan_results(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_wps_credential(struct wpa_supplicant *wpa_s,
|
|
const struct wps_credential *cred);
|
|
void wpas_notify_wps_event_m2d(struct wpa_supplicant *wpa_s,
|
|
struct wps_event_m2d *m2d);
|
|
void wpas_notify_wps_event_fail(struct wpa_supplicant *wpa_s,
|
|
struct wps_event_fail *fail);
|
|
void wpas_notify_wps_event_success(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_wps_event_pbc_overlap(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_network_added(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_network_removed(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_bss_added(struct wpa_supplicant *wpa_s, u8 bssid[],
|
|
unsigned int id);
|
|
void wpas_notify_bss_removed(struct wpa_supplicant *wpa_s, u8 bssid[],
|
|
unsigned int id);
|
|
void wpas_notify_bss_freq_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_signal_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_privacy_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_mode_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_wpaie_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_rsnie_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_wps_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_ies_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_rates_changed(struct wpa_supplicant *wpa_s,
|
|
unsigned int id);
|
|
void wpas_notify_bss_seen(struct wpa_supplicant *wpa_s, unsigned int id);
|
|
void wpas_notify_blob_added(struct wpa_supplicant *wpa_s, const char *name);
|
|
void wpas_notify_blob_removed(struct wpa_supplicant *wpa_s, const char *name);
|
|
|
|
void wpas_notify_debug_level_changed(struct wpa_global *global);
|
|
void wpas_notify_debug_timestamp_changed(struct wpa_global *global);
|
|
void wpas_notify_debug_show_keys_changed(struct wpa_global *global);
|
|
void wpas_notify_suspend(struct wpa_global *global);
|
|
void wpas_notify_resume(struct wpa_global *global);
|
|
|
|
void wpas_notify_sta_authorized(struct wpa_supplicant *wpa_s,
|
|
const u8 *mac_addr, int authorized,
|
|
const u8 *p2p_dev_addr);
|
|
void wpas_notify_p2p_find_stopped(struct wpa_supplicant *wpa_s);
|
|
void wpas_notify_p2p_device_found(struct wpa_supplicant *wpa_s,
|
|
const u8 *dev_addr, int new_device);
|
|
void wpas_notify_p2p_device_lost(struct wpa_supplicant *wpa_s,
|
|
const u8 *dev_addr);
|
|
void wpas_notify_p2p_group_removed(struct wpa_supplicant *wpa_s,
|
|
const struct wpa_ssid *ssid,
|
|
const char *role);
|
|
void wpas_notify_p2p_go_neg_req(struct wpa_supplicant *wpa_s,
|
|
const u8 *src, u16 dev_passwd_id, u8 go_intent);
|
|
void wpas_notify_p2p_go_neg_completed(struct wpa_supplicant *wpa_s,
|
|
struct p2p_go_neg_results *res);
|
|
void wpas_notify_p2p_invitation_result(struct wpa_supplicant *wpa_s,
|
|
int status, const u8 *bssid);
|
|
void wpas_notify_p2p_sd_request(struct wpa_supplicant *wpa_s,
|
|
int freq, const u8 *sa, u8 dialog_token,
|
|
u16 update_indic, const u8 *tlvs,
|
|
size_t tlvs_len);
|
|
void wpas_notify_p2p_sd_response(struct wpa_supplicant *wpa_s,
|
|
const u8 *sa, u16 update_indic,
|
|
const u8 *tlvs, size_t tlvs_len);
|
|
void wpas_notify_p2p_provision_discovery(struct wpa_supplicant *wpa_s,
|
|
const u8 *dev_addr, int request,
|
|
enum p2p_prov_disc_status status,
|
|
u16 config_methods,
|
|
unsigned int generated_pin);
|
|
void wpas_notify_p2p_group_started(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid, int persistent,
|
|
int client, const u8 *ip);
|
|
void wpas_notify_p2p_group_formation_failure(struct wpa_supplicant *wpa_s,
|
|
const char *reason);
|
|
void wpas_notify_persistent_group_added(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_persistent_group_removed(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
|
|
void wpas_notify_p2p_wps_failed(struct wpa_supplicant *wpa_s,
|
|
struct wps_event_fail *fail);
|
|
|
|
void wpas_notify_certification(struct wpa_supplicant *wpa_s,
|
|
struct tls_cert_data *cert,
|
|
const char *cert_hash);
|
|
void wpas_notify_preq(struct wpa_supplicant *wpa_s,
|
|
const u8 *addr, const u8 *dst, const u8 *bssid,
|
|
const u8 *ie, size_t ie_len, u32 ssi_signal);
|
|
void wpas_notify_eap_status(struct wpa_supplicant *wpa_s, const char *status,
|
|
const char *parameter);
|
|
void wpas_notify_eap_error(struct wpa_supplicant *wpa_s, int error_code);
|
|
void wpas_notify_network_bssid_set_changed(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_network_type_changed(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_p2p_invitation_received(struct wpa_supplicant *wpa_s,
|
|
const u8 *sa, const u8 *go_dev_addr,
|
|
const u8 *bssid, int id, int op_freq);
|
|
void wpas_notify_mesh_group_started(struct wpa_supplicant *wpa_s,
|
|
struct wpa_ssid *ssid);
|
|
void wpas_notify_mesh_group_removed(struct wpa_supplicant *wpa_s,
|
|
const u8 *meshid, u8 meshid_len,
|
|
u16 reason_code);
|
|
void wpas_notify_mesh_peer_connected(struct wpa_supplicant *wpa_s,
|
|
const u8 *peer_addr);
|
|
void wpas_notify_mesh_peer_disconnected(struct wpa_supplicant *wpa_s,
|
|
const u8 *peer_addr, u16 reason_code);
|
|
|
|
#endif /* NOTIFY_H */
|