gnome-control-center/panels/network/panel-common.c

427 lines
17 KiB
C
Raw Normal View History

/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 8 -*-
*
* Copyright (C) 2010 Richard Hughes <richard@hughsie.com>
* Copyright (C) 2012 Thomas Bechtold <thomasbechtold@jpberlin.de>
*
* Licensed under the GNU General Public License Version 2
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
#include "config.h"
#include <glib.h>
#include <glib/gi18n.h>
#include <gtk/gtk.h>
#define HANDY_USE_UNSTABLE_API
#include <handy.h>
#include <NetworkManager.h>
#include "panel-common.h"
static const gchar *
device_state_to_localized_string (NMDeviceState state)
{
const gchar *value = NULL;
switch (state) {
case NM_DEVICE_STATE_UNKNOWN:
/* TRANSLATORS: device status */
value = _("Status unknown");
break;
case NM_DEVICE_STATE_UNMANAGED:
/* TRANSLATORS: device status */
value = _("Unmanaged");
break;
case NM_DEVICE_STATE_UNAVAILABLE:
/* TRANSLATORS: device status */
value = _("Unavailable");
break;
case NM_DEVICE_STATE_DISCONNECTED:
value = NULL;
break;
case NM_DEVICE_STATE_PREPARE:
case NM_DEVICE_STATE_CONFIG:
case NM_DEVICE_STATE_IP_CONFIG:
case NM_DEVICE_STATE_IP_CHECK:
/* TRANSLATORS: device status */
value = _("Connecting");
break;
case NM_DEVICE_STATE_NEED_AUTH:
/* TRANSLATORS: device status */
value = _("Authentication required");
break;
case NM_DEVICE_STATE_ACTIVATED:
/* TRANSLATORS: device status */
value = _("Connected");
break;
case NM_DEVICE_STATE_DEACTIVATING:
/* TRANSLATORS: device status */
value = _("Disconnecting");
break;
case NM_DEVICE_STATE_FAILED:
/* TRANSLATORS: device status */
value = _("Connection failed");
break;
default:
/* TRANSLATORS: device status */
value = _("Status unknown (missing)");
break;
}
return value;
}
static const gchar *
device_state_reason_to_localized_string (NMDevice *device)
{
const gchar *value = NULL;
NMDeviceStateReason state_reason;
/* This only covers NMDeviceStateReasons that explain why a connection
* failed / can't be attempted, and aren't redundant with the state
* (eg, NM_DEVICE_STATE_REASON_CARRIER).
*/
state_reason = nm_device_get_state_reason (device);
switch (state_reason) {
case NM_DEVICE_STATE_REASON_CONFIG_FAILED:
/* TRANSLATORS: device status reason */
value = _("Configuration failed");
break;
case NM_DEVICE_STATE_REASON_IP_CONFIG_UNAVAILABLE:
/* TRANSLATORS: device status reason */
value = _("IP configuration failed");
break;
case NM_DEVICE_STATE_REASON_IP_CONFIG_EXPIRED:
/* TRANSLATORS: device status reason */
value = _("IP configuration expired");
break;
case NM_DEVICE_STATE_REASON_NO_SECRETS:
/* TRANSLATORS: device status reason */
value = _("Secrets were required, but not provided");
break;
case NM_DEVICE_STATE_REASON_SUPPLICANT_DISCONNECT:
/* TRANSLATORS: device status reason */
value = _("802.1x supplicant disconnected");
break;
case NM_DEVICE_STATE_REASON_SUPPLICANT_CONFIG_FAILED:
/* TRANSLATORS: device status reason */
value = _("802.1x supplicant configuration failed");
break;
case NM_DEVICE_STATE_REASON_SUPPLICANT_FAILED:
/* TRANSLATORS: device status reason */
value = _("802.1x supplicant failed");
break;
case NM_DEVICE_STATE_REASON_SUPPLICANT_TIMEOUT:
/* TRANSLATORS: device status reason */
value = _("802.1x supplicant took too long to authenticate");
break;
case NM_DEVICE_STATE_REASON_PPP_START_FAILED:
/* TRANSLATORS: device status reason */
value = _("PPP service failed to start");
break;
case NM_DEVICE_STATE_REASON_PPP_DISCONNECT:
/* TRANSLATORS: device status reason */
value = _("PPP service disconnected");
break;
case NM_DEVICE_STATE_REASON_PPP_FAILED:
/* TRANSLATORS: device status reason */
value = _("PPP failed");
break;
case NM_DEVICE_STATE_REASON_DHCP_START_FAILED:
/* TRANSLATORS: device status reason */
value = _("DHCP client failed to start");
break;
case NM_DEVICE_STATE_REASON_DHCP_ERROR:
/* TRANSLATORS: device status reason */
value = _("DHCP client error");
break;
case NM_DEVICE_STATE_REASON_DHCP_FAILED:
/* TRANSLATORS: device status reason */
value = _("DHCP client failed");
break;
case NM_DEVICE_STATE_REASON_SHARED_START_FAILED:
/* TRANSLATORS: device status reason */
value = _("Shared connection service failed to start");
break;
case NM_DEVICE_STATE_REASON_SHARED_FAILED:
/* TRANSLATORS: device status reason */
value = _("Shared connection service failed");
break;
case NM_DEVICE_STATE_REASON_AUTOIP_START_FAILED:
/* TRANSLATORS: device status reason */
value = _("AutoIP service failed to start");
break;
case NM_DEVICE_STATE_REASON_AUTOIP_ERROR:
/* TRANSLATORS: device status reason */
value = _("AutoIP service error");
break;
case NM_DEVICE_STATE_REASON_AUTOIP_FAILED:
/* TRANSLATORS: device status reason */
value = _("AutoIP service failed");
break;
case NM_DEVICE_STATE_REASON_MODEM_BUSY:
/* TRANSLATORS: device status reason */
value = _("Line busy");
break;
case NM_DEVICE_STATE_REASON_MODEM_NO_DIAL_TONE:
/* TRANSLATORS: device status reason */
value = _("No dial tone");
break;
case NM_DEVICE_STATE_REASON_MODEM_NO_CARRIER:
/* TRANSLATORS: device status reason */
value = _("No carrier could be established");
break;
case NM_DEVICE_STATE_REASON_MODEM_DIAL_TIMEOUT:
/* TRANSLATORS: device status reason */
value = _("Dialing request timed out");
break;
case NM_DEVICE_STATE_REASON_MODEM_DIAL_FAILED:
/* TRANSLATORS: device status reason */
value = _("Dialing attempt failed");
break;
case NM_DEVICE_STATE_REASON_MODEM_INIT_FAILED:
/* TRANSLATORS: device status reason */
value = _("Modem initialization failed");
break;
case NM_DEVICE_STATE_REASON_GSM_APN_FAILED:
/* TRANSLATORS: device status reason */
value = _("Failed to select the specified APN");
break;
case NM_DEVICE_STATE_REASON_GSM_REGISTRATION_NOT_SEARCHING:
/* TRANSLATORS: device status reason */
value = _("Not searching for networks");
break;
case NM_DEVICE_STATE_REASON_GSM_REGISTRATION_DENIED:
/* TRANSLATORS: device status reason */
value = _("Network registration denied");
break;
case NM_DEVICE_STATE_REASON_GSM_REGISTRATION_TIMEOUT:
/* TRANSLATORS: device status reason */
value = _("Network registration timed out");
break;
case NM_DEVICE_STATE_REASON_GSM_REGISTRATION_FAILED:
/* TRANSLATORS: device status reason */
value = _("Failed to register with the requested network");
break;
case NM_DEVICE_STATE_REASON_GSM_PIN_CHECK_FAILED:
/* TRANSLATORS: device status reason */
value = _("PIN check failed");
break;
case NM_DEVICE_STATE_REASON_FIRMWARE_MISSING:
/* TRANSLATORS: device status reason */
value = _("Firmware for the device may be missing");
break;
case NM_DEVICE_STATE_REASON_CONNECTION_REMOVED:
/* TRANSLATORS: device status reason */
value = _("Connection disappeared");
break;
case NM_DEVICE_STATE_REASON_CONNECTION_ASSUMED:
/* TRANSLATORS: device status reason */
value = _("Existing connection was assumed");
break;
case NM_DEVICE_STATE_REASON_MODEM_NOT_FOUND:
/* TRANSLATORS: device status reason */
value = _("Modem not found");
break;
case NM_DEVICE_STATE_REASON_BT_FAILED:
/* TRANSLATORS: device status reason */
value = _("Bluetooth connection failed");
break;
case NM_DEVICE_STATE_REASON_GSM_SIM_NOT_INSERTED:
/* TRANSLATORS: device status reason */
value = _("SIM Card not inserted");
break;
case NM_DEVICE_STATE_REASON_GSM_SIM_PIN_REQUIRED:
/* TRANSLATORS: device status reason */
value = _("SIM Pin required");
break;
case NM_DEVICE_STATE_REASON_GSM_SIM_PUK_REQUIRED:
/* TRANSLATORS: device status reason */
value = _("SIM Puk required");
break;
case NM_DEVICE_STATE_REASON_GSM_SIM_WRONG:
/* TRANSLATORS: device status reason */
value = _("SIM wrong");
break;
case NM_DEVICE_STATE_REASON_DEPENDENCY_FAILED:
/* TRANSLATORS: device status reason */
value = _("Connection dependency failed");
break;
default:
/* no StateReason to show */
value = "";
break;
}
return value;
}
gchar *
panel_device_status_to_localized_string (NMDevice *nm_device,
const gchar *speed)
{
NMDeviceState state;
GString *string;
const gchar *state_str = NULL, *reason_str = NULL;
string = g_string_new (NULL);
state = nm_device_get_state (nm_device);
if (state == NM_DEVICE_STATE_UNAVAILABLE) {
if (nm_device_get_firmware_missing (nm_device)) {
/* TRANSLATORS: device status */
state_str = _("Firmware missing");
} else if (NM_IS_DEVICE_ETHERNET (nm_device) &&
!nm_device_ethernet_get_carrier (NM_DEVICE_ETHERNET (nm_device))) {
/* TRANSLATORS: device status */
state_str = _("Cable unplugged");
}
}
if (!state_str)
state_str = device_state_to_localized_string (state);
if (state_str)
g_string_append (string, state_str);
if (state > NM_DEVICE_STATE_UNAVAILABLE && speed) {
if (string->len)
g_string_append (string, " - ");
g_string_append (string, speed);
} else if (state == NM_DEVICE_STATE_UNAVAILABLE ||
state == NM_DEVICE_STATE_DISCONNECTED ||
state == NM_DEVICE_STATE_DEACTIVATING ||
state == NM_DEVICE_STATE_FAILED) {
reason_str = device_state_reason_to_localized_string (nm_device);
if (*reason_str) {
if (string->len)
g_string_append (string, " - ");
g_string_append (string, reason_str);
}
}
return g_string_free (string, FALSE);
}
gboolean
panel_set_device_widget_details (GtkLabel *heading,
GtkLabel *widget,
const gchar *value)
{
/* hide the row if there is no value */
if (value == NULL) {
gtk_widget_hide (GTK_WIDGET (heading));
gtk_widget_hide (GTK_WIDGET (widget));
} else {
/* there exists a value */
gtk_widget_show (GTK_WIDGET (heading));
gtk_widget_show (GTK_WIDGET (widget));
gtk_label_set_label (widget, value);
gtk_label_set_max_width_chars (widget, 50);
gtk_label_set_ellipsize (widget, PANGO_ELLIPSIZE_END);
}
return TRUE;
}
gchar *
panel_get_ip4_address_as_string (NMIPConfig *ip4_config, const char *what)
{
/* we only care about one address */
if (!strcmp (what, "address")) {
GPtrArray *array;
NMIPAddress *address;
array = nm_ip_config_get_addresses (ip4_config);
if (array->len < 1)
2019-10-01 14:52:13 +13:00
return NULL;
address = array->pdata[0];
2019-10-01 14:52:13 +13:00
return g_strdup (nm_ip_address_get_address (address));
} else if (!strcmp (what, "gateway")) {
2019-10-01 14:52:13 +13:00
return g_strdup (nm_ip_config_get_gateway (ip4_config));
}
2019-10-01 14:52:13 +13:00
return NULL;
}
gchar *
panel_get_ip4_dns_as_string (NMIPConfig *ip4_config)
{
return g_strjoinv (" ",
(char **) nm_ip_config_get_nameservers (ip4_config));
}
gchar *
panel_get_ip6_address_as_string (NMIPConfig *ip6_config)
{
GPtrArray *array;
NMIPAddress *address;
array = nm_ip_config_get_addresses (ip6_config);
if (array->len < 1)
return NULL;
address = array->pdata[0];
return g_strdup (nm_ip_address_get_address (address));
}
void
panel_set_device_widgets (GtkBuilder *builder, NMDevice *device)
{
GtkWidget *ipv4_heading, *ipv6_heading, *dns_heading, *route_heading;
GtkWidget *ipv4_widget, *ipv6_widget, *dns_widget, *route_widget;
2019-10-01 14:27:29 +13:00
g_autofree gchar *ipv4_text = NULL;
g_autofree gchar *ipv6_text = NULL;
g_autofree gchar *dns_text = NULL;
g_autofree gchar *route_text = NULL;
gboolean has_ip4, has_ip6;
ipv4_heading = GTK_WIDGET (gtk_builder_get_object (builder, "heading_ipv4"));
ipv4_widget = GTK_WIDGET (gtk_builder_get_object (builder, "label_ipv4"));
ipv6_heading = GTK_WIDGET (gtk_builder_get_object (builder, "heading_ipv6"));
ipv6_widget = GTK_WIDGET (gtk_builder_get_object (builder, "label_ipv6"));
dns_heading = GTK_WIDGET (gtk_builder_get_object (builder, "heading_dns"));
dns_widget = GTK_WIDGET (gtk_builder_get_object (builder, "label_dns"));
route_heading = GTK_WIDGET (gtk_builder_get_object (builder, "heading_route"));
route_widget = GTK_WIDGET (gtk_builder_get_object (builder, "label_route"));
2019-10-01 14:27:29 +13:00
if (device != NULL) {
NMIPConfig *ip4_config, *ip6_config;
ip4_config = nm_device_get_ip4_config (device);
if (ip4_config != NULL) {
ipv4_text = panel_get_ip4_address_as_string (ip4_config, "address");
dns_text = panel_get_ip4_dns_as_string (ip4_config);
route_text = panel_get_ip4_address_as_string (ip4_config, "gateway");
}
ip6_config = nm_device_get_ip6_config (device);
if (ip6_config != NULL)
ipv6_text = panel_get_ip6_address_as_string (ip6_config);
}
panel_set_device_widget_details (GTK_LABEL (ipv4_heading), GTK_LABEL (ipv4_widget), ipv4_text);
panel_set_device_widget_details (GTK_LABEL (ipv6_heading), GTK_LABEL (ipv6_widget), ipv6_text);
panel_set_device_widget_details (GTK_LABEL (dns_heading), GTK_LABEL (dns_widget), dns_text);
panel_set_device_widget_details (GTK_LABEL (route_heading), GTK_LABEL (route_widget), route_text);
2019-10-01 14:27:29 +13:00
has_ip4 = ipv4_text != NULL;
has_ip6 = ipv6_text != NULL;
if (has_ip4 && has_ip6) {
gtk_label_set_label (GTK_LABEL (ipv4_heading), _("IPv4 Address"));
gtk_label_set_label (GTK_LABEL (ipv6_heading), _("IPv6 Address"));
} else if (has_ip4) {
gtk_label_set_label (GTK_LABEL (ipv4_heading), _("IP Address"));
} else if (has_ip6) {
gtk_label_set_label (GTK_LABEL (ipv6_heading), _("IP Address"));
}
}