]> git.ipfire.org Git - thirdparty/hostap.git/commitdiff
D-Bus: Implement Pmf property
authorStijn Tintel <stijn@linux-ipv6.be>
Thu, 12 Jan 2017 16:13:26 +0000 (17:13 +0100)
committerJouni Malinen <j@w1.fi>
Sat, 14 Jan 2017 15:28:00 +0000 (17:28 +0200)
The Pmf property is documented in doc/dbus.doxygen, but does not exist,
so implement it.

Signed-off-by: Stijn Tintel <stijn@linux-ipv6.be>
wpa_supplicant/dbus/dbus_new.c
wpa_supplicant/dbus/dbus_new.h
wpa_supplicant/dbus/dbus_new_handlers.c
wpa_supplicant/dbus/dbus_new_handlers.h

index a60118254e4b33911defca8b710544b99ce7c5dd..0c355f799dee823b242b1f91454bfd672d0567f8 100644 (file)
@@ -1987,6 +1987,11 @@ void wpas_dbus_signal_prop_changed(struct wpa_supplicant *wpa_s,
        case WPAS_DBUS_PROP_AP_SCAN:
                prop = "ApScan";
                break;
+#ifdef CONFIG_IEEE80211W
+       case WPAS_DBUS_PROP_PMF:
+               prop = "Pmf";
+               break;
+#endif /* CONFIG_IEEE80211W */
        case WPAS_DBUS_PROP_SCANNING:
                prop = "Scanning";
                break;
@@ -3138,6 +3143,13 @@ static const struct wpa_dbus_property_desc wpas_dbus_interface_properties[] = {
          wpas_dbus_setter_ap_scan,
          NULL
        },
+#ifdef CONFIG_IEEE80211W
+       { "Pmf", WPAS_DBUS_NEW_IFACE_INTERFACE, "u",
+         wpas_dbus_getter_pmf,
+         wpas_dbus_setter_pmf,
+         NULL
+       },
+#endif /* CONFIG_IEEE80211W */
        { "BSSExpireAge", WPAS_DBUS_NEW_IFACE_INTERFACE, "u",
          wpas_dbus_getter_bss_expire_age,
          wpas_dbus_setter_bss_expire_age,
index 2b0b775d33d5a77f672d494fddf2ae65cf4cbdd2..bd0e07433a3df3c5e88a0aa90329696bc7a47bd4 100644 (file)
@@ -22,6 +22,7 @@ struct wps_credential;
 
 enum wpas_dbus_prop {
        WPAS_DBUS_PROP_AP_SCAN,
+       WPAS_DBUS_PROP_PMF,
        WPAS_DBUS_PROP_SCANNING,
        WPAS_DBUS_PROP_STATE,
        WPAS_DBUS_PROP_CURRENT_BSS,
index e36226d86e616a027c5dc7c1d4f8940c3fd5796b..094301045ac8c1ee37b7e8bf0c9d9d7f31c3190b 100644 (file)
@@ -2787,6 +2787,61 @@ dbus_bool_t wpas_dbus_setter_ap_scan(
 }
 
 
+#ifdef CONFIG_IEEE80211W
+
+/**
+ * wpas_dbus_getter_pmf - Control PMF default
+ * @iter: Pointer to incoming dbus message iter
+ * @error: Location to store error on failure
+ * @user_data: Function specific data
+ * Returns: TRUE on success, FALSE on failure
+ *
+ * Getter function for "Pmf" property.
+ */
+dbus_bool_t wpas_dbus_getter_pmf(
+       const struct wpa_dbus_property_desc *property_desc,
+       DBusMessageIter *iter, DBusError *error, void *user_data)
+{
+       struct wpa_supplicant *wpa_s = user_data;
+       dbus_uint32_t pmf = wpa_s->conf->pmf;
+
+       return wpas_dbus_simple_property_getter(iter, DBUS_TYPE_UINT32,
+                                               &pmf, error);
+}
+
+
+/**
+ * wpas_dbus_setter_pmf - Control PMF default
+ * @iter: Pointer to incoming dbus message iter
+ * @error: Location to store error on failure
+ * @user_data: Function specific data
+ * Returns: TRUE on success, FALSE on failure
+ *
+ * Setter function for "Pmf" property.
+ */
+dbus_bool_t wpas_dbus_setter_pmf(
+       const struct wpa_dbus_property_desc *property_desc,
+       DBusMessageIter *iter, DBusError *error, void *user_data)
+{
+       struct wpa_supplicant *wpa_s = user_data;
+       dbus_uint32_t pmf;
+
+       if (!wpas_dbus_simple_property_setter(iter, error, DBUS_TYPE_UINT32,
+                                             &pmf))
+               return FALSE;
+
+       if (pmf > 2) {
+               dbus_set_error_const(error, DBUS_ERROR_FAILED,
+                                    "Pmf must be 0, 1, or 2");
+               return FALSE;
+       }
+       wpa_s->conf->pmf = pmf;
+       return TRUE;
+}
+
+#endif /* CONFIG_IEEE80211W */
+
+
 /**
  * wpas_dbus_getter_fast_reauth - Control fast
  * reauthentication (TLS session resumption)
index fe8767a1101adc1575a6428dfd9a3a278427dd68..3b8f0966f246a68568bae04b65528a57217a99fe 100644 (file)
@@ -138,6 +138,8 @@ DECLARE_ACCESSOR(wpas_dbus_getter_state);
 DECLARE_ACCESSOR(wpas_dbus_getter_scanning);
 DECLARE_ACCESSOR(wpas_dbus_getter_ap_scan);
 DECLARE_ACCESSOR(wpas_dbus_setter_ap_scan);
+DECLARE_ACCESSOR(wpas_dbus_getter_pmf);
+DECLARE_ACCESSOR(wpas_dbus_setter_pmf);
 DECLARE_ACCESSOR(wpas_dbus_getter_fast_reauth);
 DECLARE_ACCESSOR(wpas_dbus_setter_fast_reauth);
 DECLARE_ACCESSOR(wpas_dbus_getter_disconnect_reason);