]> git.ipfire.org Git - thirdparty/hostap.git/commitdiff
D-Bus: Add model number in WPS property
authorAvichal Agarwal <avichal.a@samsung.com>
Wed, 21 Dec 2016 12:24:23 +0000 (17:54 +0530)
committerJouni Malinen <j@w1.fi>
Fri, 23 Dec 2016 08:59:53 +0000 (10:59 +0200)
Signed-off-by: Avichal Agarwal <avichal.a@samsung.com>
Signed-off-by: Mayank Haarit <mayank.h@samsung.com>
wpa_supplicant/dbus/dbus_new.c
wpa_supplicant/dbus/dbus_new_handlers.h
wpa_supplicant/dbus/dbus_new_handlers_wps.c

index 562152cb24cb86de85643177f1824c84a8a9a176..08a3ee641fe564692d6aed7a93e1c8c6330786f2 100644 (file)
@@ -3252,6 +3252,12 @@ static const struct wpa_dbus_property_desc wpas_dbus_interface_properties[] = {
          wpas_dbus_setter_wps_device_model_name,
          NULL
        },
+       {
+         "ModelNumber", WPAS_DBUS_NEW_IFACE_WPS, "s",
+         wpas_dbus_getter_wps_device_model_number,
+         wpas_dbus_setter_wps_device_model_number,
+         NULL
+       },
 #endif /* CONFIG_WPS */
 #ifdef CONFIG_P2P
        { "P2PDeviceConfig", WPAS_DBUS_NEW_IFACE_P2PDEVICE, "a{sv}",
index a6863803bf1ad3949eb525204ff3894e47d864a2..f3b5af972a9726b0da68ec4370f61c67022c2124 100644 (file)
@@ -192,6 +192,8 @@ DECLARE_ACCESSOR(wpas_dbus_getter_wps_manufacturer);
 DECLARE_ACCESSOR(wpas_dbus_setter_wps_manufacturer);
 DECLARE_ACCESSOR(wpas_dbus_getter_wps_device_model_name);
 DECLARE_ACCESSOR(wpas_dbus_setter_wps_device_model_name);
+DECLARE_ACCESSOR(wpas_dbus_getter_wps_device_model_number);
+DECLARE_ACCESSOR(wpas_dbus_setter_wps_device_model_number);
 
 DBusMessage * wpas_dbus_handler_tdls_discover(DBusMessage *message,
                                              struct wpa_supplicant *wpa_s);
index cfa8eeefec48f5a2e8e6599a0f90a7c8de804b06..bd4a16b56fba399a3fc59f29072730c56b299015 100644 (file)
@@ -630,3 +630,62 @@ dbus_bool_t wpas_dbus_setter_wps_device_model_name(
 
        return TRUE;
 }
+
+
+/**
+ * wpas_dbus_getter_wps_device_model_number - Get current device model number
+ * @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 for "ModelNumber" property.
+ */
+dbus_bool_t wpas_dbus_getter_wps_device_model_number(
+       const struct wpa_dbus_property_desc *property_desc,
+       DBusMessageIter *iter, DBusError *error, void *user_data)
+{
+       struct wpa_supplicant *wpa_s = user_data;
+       char *model_number = wpa_s->conf->model_number;
+
+       if (!model_number)
+               model_number = "";
+       return wpas_dbus_simple_property_getter(iter, DBUS_TYPE_STRING,
+                                               &model_number, error);
+}
+
+
+/**
+ * wpas_dbus_setter_wps_device_model_number - Set current device model number
+ * @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 for "ModelNumber" property.
+ */
+dbus_bool_t wpas_dbus_setter_wps_device_model_number(
+       const struct wpa_dbus_property_desc *property_desc,
+       DBusMessageIter *iter, DBusError *error, void *user_data)
+{
+       struct wpa_supplicant *wpa_s = user_data;
+       char *methods, *model_number;
+
+       if (!wpas_dbus_simple_property_setter(iter, error, DBUS_TYPE_STRING,
+                                             &methods))
+               return FALSE;
+
+       if (os_strlen(methods) > WPS_MODEL_NUMBER_MAX_LEN)
+               return FALSE;
+
+       model_number = os_strdup(methods);
+       if (!model_number)
+               return FALSE;
+
+       os_free(wpa_s->conf->model_number);
+       wpa_s->conf->model_number = model_number;
+       wpa_s->conf->changed_parameters |= CFG_CHANGED_WPS_STRING;
+       wpa_supplicant_update_config(wpa_s);
+
+       return TRUE;
+}