Browse Source

dbus: Replace BSS 'Properties' property with separate properties

In addition, remove Quality and Noise properties since the BSS table
is not the correct place for fetching per-channel information (Noise)
and Quality is not well-defined (nor available from many drivers).
Witold Sowa 15 years ago
parent
commit
58605c6e61

+ 38 - 16
doc/dbus.doxygen

@@ -600,22 +600,44 @@ scan results.
 
     <ul>
       <li>
-	<h3>Properties - a{sv} - (read)</h3>
-	<p>Properties of scanned BSS. Dictionary contains following entries:</p>
-	<table>
-	  <tr><th>Key</th><th>Value type</th>
-	  <tr><td>BSSID</td><td>ay</td>
-	  <tr><td>SSID</td><td>ay</td>
-	  <tr><td>WPAIE</td><td>ay</td>
-	  <tr><td>RSNIE</td><td>ay</td>
-	  <tr><td>WPSIE</td><td>ay</td>
-	  <tr><td>Frequency</td><td>i</td>
-	  <tr><td>Capabilities</td><td>q</td>
-	  <tr><td>Quality</td><td>i</td>
-	  <tr><td>Noise</td><td>i</td>
-	  <tr><td>Level</td><td>i</td>
-	  <tr><td>MaxRate</td><td>i</td>
-	</table>
+	<h3>BSSID - ay - (read)</h3>
+	<p>BSSID of the BSS.</p>
+      </li>
+      <li>
+	<h3>SSID - ay - (read)</h3>
+	<p>SSID of the BSS.</p>
+      </li>
+      <li>
+	<h3>WPAIE - ay - (read)</h3>
+	<p>WPA information element of the BSS. The second byte contain number of bytes following it.</p>
+      </li>
+      <li>
+	<h3>RSNIE - ay - (read)</h3>
+	<p>RSN information element of the BSS. The second byte contain number of bytes following it.</p>
+      </li>
+      <li>
+	<h3>WPSIE - ay - (read)</h3>
+	<p>WPS information element of the BSS. The second byte contain number of bytes following it.</p>
+      </li>
+      <li>
+	<h3>Privacy - b - (read)</h3>
+	<p>Indicates if BSS supports privacy.</p>
+      </li>
+      <li>
+	<h3>Mode - s - (read)</h3>
+	<p>Describes mode of the BSS. Possible values are: "ad-hoc" and "infrastructure".</p>
+      </li>
+      <li>
+	<h3>Frequency - q - (read)</h3>
+	<p>Frequency of the BSS in MHz.</p>
+      </li>
+      <li>
+	<h3>MaxRate - q - (read)</h3>
+	<p>Maximal data rate of the BSS in bits per second.</p>
+      </li>
+      <li>
+	<h3>Signal - n - (read)</h3>
+	<p>Signal strength of the BSS.</p>
       </li>
     </ul>
 

+ 47 - 2
wpa_supplicant/dbus/dbus_new.c

@@ -1247,8 +1247,53 @@ static int wpas_dbus_unregister_network(struct wpa_supplicant *wpa_s, int nid)
 
 
 static const struct wpas_dbus_property wpas_dbus_bss_properties[] = {
-	{ "Properties", WPAS_DBUS_NEW_IFACE_BSSID, "a{sv}",
-	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_properties,
+	{ "SSID", WPAS_DBUS_NEW_IFACE_BSSID, "ay",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_ssid,
+	  NULL,
+	  R
+	},
+	{ "BSSID", WPAS_DBUS_NEW_IFACE_BSSID, "ay",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_bssid,
+	  NULL,
+	  R
+	},
+	{ "Privacy", WPAS_DBUS_NEW_IFACE_BSSID, "b",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_privacy,
+	  NULL,
+	  R
+	},
+	{ "Mode", WPAS_DBUS_NEW_IFACE_BSSID, "s",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_mode,
+	  NULL,
+	  R
+	},
+	{ "Signal", WPAS_DBUS_NEW_IFACE_BSSID, "n",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_signal,
+	  NULL,
+	  R
+	},
+	{ "Frequency", WPAS_DBUS_NEW_IFACE_BSSID, "q",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_frequency,
+	  NULL,
+	  R
+	},
+	{ "MaxRate", WPAS_DBUS_NEW_IFACE_BSSID, "q",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_max_rate,
+	  NULL,
+	  R
+	},
+	{ "WPAIE", WPAS_DBUS_NEW_IFACE_BSSID, "ay",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_wpaie,
+	  NULL,
+	  R
+	},
+	{ "RSNIE", WPAS_DBUS_NEW_IFACE_BSSID, "ay",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_rsnie,
+	  NULL,
+	  R
+	},
+	{ "WPSIE", WPAS_DBUS_NEW_IFACE_BSSID, "ay",
+	  (WPADBusPropertyAccessor) wpas_dbus_getter_bss_wpsie,
 	  NULL,
 	  R
 	},

+ 235 - 76
wpa_supplicant/dbus/dbus_new_handlers.c

@@ -2562,109 +2562,268 @@ out:
 
 
 /**
- * wpas_dbus_getter_bss_properties - Return the properties of a scanned bss
+ * wpas_dbus_getter_bss_bssid - Return the BSSID of a BSS
  * @message: Pointer to incoming dbus message
- * @bss: a pair of interface describing structure and bss' bssid
- * Returns: a dbus message containing the properties for the requested bss
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the bssid for the requested bss
  *
- * Getter for "Properties" property.
+ * Getter for "BSSID" property.
  */
-DBusMessage * wpas_dbus_getter_bss_properties(DBusMessage *message,
+DBusMessage * wpas_dbus_getter_bss_bssid(DBusMessage *message,
+					 struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_bssid[dbus]: no "
+			   "bss with id %d found", bss->id);
+		return NULL;
+	}
+
+	return wpas_dbus_simple_array_property_getter(message, DBUS_TYPE_BYTE,
+						      res->bssid, ETH_ALEN);
+}
+
+
+/**
+ * wpas_dbus_getter_bss_ssid - Return the SSID of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the ssid for the requested bss
+ *
+ * Getter for "SSID" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_ssid(DBusMessage *message,
 					      struct bss_handler_args *bss)
 {
-	DBusMessage *reply = NULL;
-	DBusMessageIter iter, iter_dict, variant_iter;
-	const u8 *ie;
 	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
 
-	if (res == NULL)
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_ssid[dbus]: no "
+			   "bss with id %d found", bss->id);
 		return NULL;
+	}
 
-	/* Dump the properties into a dbus message */
-	if (message == NULL)
-		reply = dbus_message_new(DBUS_MESSAGE_TYPE_SIGNAL);
-	else
-		reply = dbus_message_new_method_return(message);
+	return wpas_dbus_simple_array_property_getter(message, DBUS_TYPE_BYTE,
+						      res->ssid,
+						      res->ssid_len);
+}
 
-	if (!reply)
-		goto error;
 
-	dbus_message_iter_init_append(reply, &iter);
+/**
+ * wpas_dbus_getter_bss_privacy - Return the privacy flag of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the privacy flag value of requested bss
+ *
+ * Getter for "Privacy" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_privacy(DBusMessage *message,
+					   struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+	dbus_bool_t privacy;
 
-	if (!dbus_message_iter_open_container(&iter, DBUS_TYPE_VARIANT,
-					      "a{sv}", &variant_iter))
-		goto error;
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_privacy[dbus]: no "
+			   "bss with id %d found", bss->id);
+		return NULL;
+	}
 
-	if (!wpa_dbus_dict_open_write(&variant_iter, &iter_dict))
-		goto error;
+	privacy = res->caps && IEEE80211_CAP_PRIVACY ? TRUE : FALSE;
+	return wpas_dbus_simple_property_getter(message, DBUS_TYPE_BOOLEAN,
+						&privacy);
+}
 
-	if (!wpa_dbus_dict_append_byte_array(&iter_dict, "BSSID",
-					     (const char *) res->bssid,
-					     ETH_ALEN))
-		goto error;
 
-	ie = wpa_bss_get_ie(res, WLAN_EID_SSID);
-	if (ie) {
-		if (!wpa_dbus_dict_append_byte_array(&iter_dict, "SSID",
-						     (const char *) (ie + 2),
-						     ie[1]))
-		goto error;
+/**
+ * wpas_dbus_getter_bss_mode - Return the mode of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the mode of requested bss
+ *
+ * Getter for "Mode" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_mode(DBusMessage *message,
+					struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+	const char *mode;
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_mode[dbus]: no "
+			   "bss with id %d found", bss->id);
+		return NULL;
 	}
 
-	ie = wpa_bss_get_vendor_ie(res, WPA_IE_VENDOR_TYPE);
-	if (ie) {
-		if (!wpa_dbus_dict_append_byte_array(&iter_dict, "WPAIE",
-						     (const char *) ie,
-						     ie[1] + 2))
-			goto error;
+	if (res->caps & IEEE80211_CAP_IBSS)
+		mode = "ad-hoc";
+	else
+		mode = "infrastructure";
+
+	return wpas_dbus_simple_property_getter(message, DBUS_TYPE_STRING,
+						&mode);
+}
+
+
+/**
+ * wpas_dbus_getter_bss_level - Return the signal strength of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the signal strength of requested bss
+ *
+ * Getter for "Level" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_signal(DBusMessage *message,
+					  struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_signal[dbus]: no "
+			   "bss with id %d found", bss->id);
+		return NULL;
 	}
 
-	ie = wpa_bss_get_ie(res, WLAN_EID_RSN);
-	if (ie) {
-		if (!wpa_dbus_dict_append_byte_array(&iter_dict, "RSNIE",
-						     (const char *) ie,
-						     ie[1] + 2))
-			goto error;
+	return wpas_dbus_simple_property_getter(message, DBUS_TYPE_INT16,
+						&res->level);
+}
+
+
+/**
+ * wpas_dbus_getter_bss_frequency - Return the frequency of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the frequency of requested bss
+ *
+ * Getter for "Frequency" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_frequency(DBusMessage *message,
+					     struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_frequency[dbus]: "
+			   "no bss with id %d found", bss->id);
+		return NULL;
 	}
 
-	ie = wpa_bss_get_vendor_ie(res, WPS_IE_VENDOR_TYPE);
-	if (ie) {
-		if (!wpa_dbus_dict_append_byte_array(&iter_dict, "WPSIE",
-						     (const char *) ie,
-						     ie[1] + 2))
-			goto error;
+	return wpas_dbus_simple_property_getter(message, DBUS_TYPE_UINT16,
+						&res->freq);
+}
+
+
+/**
+ * wpas_dbus_getter_bss_max_rate - Return the maximal rate of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the maximal data rate of requested bss
+ *
+ * Getter for "MaxRate" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_max_rate(DBusMessage *message,
+					    struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+	int max_rate;
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_max_rate[dbus]: "
+			   "no bss with id %d found", bss->id);
+		return NULL;
 	}
 
-	if (res->freq) {
-		if (!wpa_dbus_dict_append_int32(&iter_dict, "Frequency",
-						res->freq))
-			goto error;
+	max_rate = wpa_bss_get_max_rate(res);
+	return wpas_dbus_simple_property_getter(message, DBUS_TYPE_UINT16,
+						&max_rate);
+}
+
+
+/**
+ * wpas_dbus_getter_bss_wpaie - Return the WPA IE of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the WPA information elements
+ * of requested bss
+ *
+ * Getter for "WPAIE" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_wpaie(DBusMessage *message,
+					 struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+	const u8 *ie;
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_wpaie[dbus]: no "
+			   "bss with id %d found", bss->id);
+		return NULL;
 	}
-	if (!wpa_dbus_dict_append_uint16(&iter_dict, "Capabilities",
-					 res->caps))
-		goto error;
-	if (!(res->flags & WPA_SCAN_QUAL_INVALID) &&
-	    !wpa_dbus_dict_append_int32(&iter_dict, "Quality", res->qual))
-		goto error;
-	if (!(res->flags & WPA_SCAN_NOISE_INVALID) &&
-	    !wpa_dbus_dict_append_int32(&iter_dict, "Noise", res->noise))
-		goto error;
-	if (!(res->flags & WPA_SCAN_LEVEL_INVALID) &&
-	    !wpa_dbus_dict_append_int32(&iter_dict, "Level", res->level))
-		goto error;
-	if (!wpa_dbus_dict_append_int32(&iter_dict, "MaxRate",
-					wpa_bss_get_max_rate(res) * 500000))
-		goto error;
 
-	if (!wpa_dbus_dict_close_write(&iter, &iter_dict))
-		goto error;
+	ie = wpa_bss_get_vendor_ie(res, WPA_IE_VENDOR_TYPE);
+	if (!ie)
+		return NULL;
+	return wpas_dbus_simple_array_property_getter(message, DBUS_TYPE_BYTE,
+						      ie, ie[1] + 2);
+}
 
-	return reply;
 
-error:
-	if (reply)
-		dbus_message_unref(reply);
-	return dbus_message_new_error(message, DBUS_ERROR_NO_MEMORY, NULL);
+/**
+ * wpas_dbus_getter_bss_rsnie - Return the RSN IE of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the RSN information elements
+ * of requested bss
+ *
+ * Getter for "RSNIE" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_rsnie(DBusMessage *message,
+					 struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+	const u8 *ie;
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_rsnie[dbus]: no "
+			   "bss with id %d found", bss->id);
+		return NULL;
+	}
+
+	ie = wpa_bss_get_ie(res, WLAN_EID_RSN);
+	if (!ie)
+		return NULL;
+	return wpas_dbus_simple_array_property_getter(message, DBUS_TYPE_BYTE,
+						      ie, ie[1] + 2);
+}
+
+
+/**
+ * wpas_dbus_getter_bss_wpsie - Return the WPS IE of a BSS
+ * @message: Pointer to incoming dbus message
+ * @bss: a pair of interface describing structure and bss's id
+ * Returns: a dbus message containing the WPS information elements
+ * of requested bss
+ *
+ * Getter for "WPSIE" property.
+ */
+DBusMessage * wpas_dbus_getter_bss_wpsie(DBusMessage *message,
+					 struct bss_handler_args *bss)
+{
+	struct wpa_bss *res = wpa_bss_get_id(bss->wpa_s, bss->id);
+	const u8 *ie;
+
+	if (!res) {
+		wpa_printf(MSG_ERROR, "wpas_dbus_getter_bss_wpsie[dbus]: no "
+			   "bss with id %d found", bss->id);
+		return NULL;
+	}
+
+	ie = wpa_bss_get_vendor_ie(res, WPS_IE_VENDOR_TYPE);
+	if (!ie)
+		return NULL;
+	return wpas_dbus_simple_array_property_getter(message, DBUS_TYPE_BYTE,
+						      ie, ie[1] + 2);
 }
 
 

+ 29 - 2
wpa_supplicant/dbus/dbus_new_handlers.h

@@ -121,8 +121,35 @@ DBusMessage * wpas_dbus_getter_networks(DBusMessage *message,
 DBusMessage * wpas_dbus_getter_blobs(DBusMessage *message,
 				     struct wpa_supplicant *bss);
 
-DBusMessage * wpas_dbus_getter_bss_properties(DBusMessage *message,
-					      struct bss_handler_args *bss);
+DBusMessage * wpas_dbus_getter_bss_bssid(DBusMessage *message,
+					 struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_ssid(DBusMessage *message,
+					struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_privacy(DBusMessage *message,
+					   struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_mode(DBusMessage *message,
+					struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_signal(DBusMessage *message,
+					  struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_frequency(DBusMessage *message,
+					     struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_max_rate(DBusMessage *message,
+					    struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_wpaie(DBusMessage *message,
+					 struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_rsnie(DBusMessage *message,
+					 struct bss_handler_args *bss);
+
+DBusMessage * wpas_dbus_getter_bss_wpsie(DBusMessage *message,
+					 struct bss_handler_args *bss);
 
 DBusMessage * wpas_dbus_getter_enabled(DBusMessage *message,
 				       struct network_handler_args *net);