mirror of
https://git.kernel.org/pub/scm/network/wireless/iwd.git
synced 2025-01-05 12:42:43 +01:00
client: ap: show Name in 'ap <wlan> show'
This will show some basic AP information like Started and network Name. Some cleanup was done to make the AP interface and client table columns line up.
This commit is contained in:
parent
ec15ef1d34
commit
479506013c
45
client/ap.c
45
client/ap.c
@ -34,6 +34,7 @@
|
|||||||
|
|
||||||
struct ap {
|
struct ap {
|
||||||
bool started;
|
bool started;
|
||||||
|
char *name;
|
||||||
};
|
};
|
||||||
|
|
||||||
static void *ap_create(void)
|
static void *ap_create(void)
|
||||||
@ -45,6 +46,9 @@ static void ap_destroy(void *data)
|
|||||||
{
|
{
|
||||||
struct ap *ap = data;
|
struct ap *ap = data;
|
||||||
|
|
||||||
|
if (ap->name)
|
||||||
|
l_free(ap->name);
|
||||||
|
|
||||||
l_free(ap);
|
l_free(ap);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -74,8 +78,35 @@ static void update_started(void *data, struct l_dbus_message_iter *variant)
|
|||||||
ap->started = value;
|
ap->started = value;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char *get_name_tostr(const void *data)
|
||||||
|
{
|
||||||
|
const struct ap *ap = data;
|
||||||
|
|
||||||
|
if (!ap->name)
|
||||||
|
return "";
|
||||||
|
|
||||||
|
return ap->name;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void update_name(void *data, struct l_dbus_message_iter *variant)
|
||||||
|
{
|
||||||
|
struct ap *ap = data;
|
||||||
|
const char *name;
|
||||||
|
|
||||||
|
if (ap->name)
|
||||||
|
l_free(ap->name);
|
||||||
|
|
||||||
|
if (!l_dbus_message_iter_get_variant(variant, "s", &name)) {
|
||||||
|
ap->name = NULL;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
ap->name = l_strdup(name);
|
||||||
|
}
|
||||||
|
|
||||||
static const struct proxy_interface_property ap_properties[] = {
|
static const struct proxy_interface_property ap_properties[] = {
|
||||||
{ "Started", "b", update_started, get_started_tostr },
|
{ "Started", "b", update_started, get_started_tostr },
|
||||||
|
{ "Name", "s", update_name, get_name_tostr },
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -212,9 +243,9 @@ static void ap_get_diagnostics_callback(struct l_dbus_message *message,
|
|||||||
|
|
||||||
while (l_dbus_message_iter_next_entry(&array, &iter)) {
|
while (l_dbus_message_iter_next_entry(&array, &iter)) {
|
||||||
sprintf(client_num, "Client %u", idx++);
|
sprintf(client_num, "Client %u", idx++);
|
||||||
display_table_header(client_num, "%-*s%-*s",
|
display_table_header(client_num, " %-*s%-*s",
|
||||||
20, "Property", 20, "Value");
|
20, "Property", 20, "Value");
|
||||||
diagnostic_display(&iter, "", 20, 20);
|
diagnostic_display(&iter, " ", 20, 20);
|
||||||
display_table_footer();
|
display_table_footer();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -223,12 +254,20 @@ static enum cmd_status cmd_show(const char *device_name, char **argv, int argc)
|
|||||||
{
|
{
|
||||||
const struct proxy_interface *ap_diagnostic =
|
const struct proxy_interface *ap_diagnostic =
|
||||||
device_proxy_find(device_name, IWD_AP_DIAGNOSTIC_INTERFACE);
|
device_proxy_find(device_name, IWD_AP_DIAGNOSTIC_INTERFACE);
|
||||||
|
const struct proxy_interface *ap_i =
|
||||||
|
device_proxy_find(device_name, IWD_ACCESS_POINT_INTERFACE);
|
||||||
|
|
||||||
if (!ap_diagnostic) {
|
if (!ap_i) {
|
||||||
display("No ap on device: '%s'\n", device_name);
|
display("No ap on device: '%s'\n", device_name);
|
||||||
return CMD_STATUS_INVALID_VALUE;
|
return CMD_STATUS_INVALID_VALUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
proxy_properties_display(ap_i, "Access Point Interface", MARGIN, 20, 20);
|
||||||
|
display_table_footer();
|
||||||
|
|
||||||
|
if (!ap_diagnostic)
|
||||||
|
return CMD_STATUS_DONE;
|
||||||
|
|
||||||
proxy_interface_method_call(ap_diagnostic, "GetDiagnostics", "",
|
proxy_interface_method_call(ap_diagnostic, "GetDiagnostics", "",
|
||||||
ap_get_diagnostics_callback);
|
ap_get_diagnostics_callback);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user