mirror of
https://gitlab.freedesktop.org/NetworkManager/NetworkManager.git
synced 2026-05-15 05:28:05 +02:00
* Kill dhcpcd. We now use "dhcdbd", a dbus daemon that controls dhclient. This means that NetworkManager shouldn't have DHCP issues anymore. It also means you need dhcdbd, which you can get here (get the latest one): http://people.redhat.com/jvdias/dhcdbd/ Technically NetworkManager can use any DHCP daemon that uses the same DBUS interface as dhcdbd. * Rewrite device activation to facilitate the new DHCP infrastructure and future improvements. Its now "activation request" based, ie there is a single activation request composed of the device, access point, and other info which follows the entire activation process. There are 5 stages of the activation process which correspond to: 1) Device preparation 2) Device configuration (bring it up, set ESSID/Key/etc) 3) IP Config Start (fire off DHCP if we're using it) 4) IP Config Get (grab config from DHCP or static config files) 5) IP Config Commit (set device's IP address, DNS, etc) Note that there is no longer a "scanning" step, since the access point must be known _before_ activation starts. If the access point drops out or does not exist for some reason, the entire activation process fails and must be restarted for a different access point or device. Patch from Bill Moss: * gnome/applet/applet.c - Fix type of vpn_failure dialog -> vpn_banner dialog git-svn-id: http://svn-archive.gnome.org/svn/NetworkManager/trunk@597 4912f4e0-d625-0410-9fb7-b9a5a253dbdc
512 lines
11 KiB
C
512 lines
11 KiB
C
/* -*- Mode: C; tab-width: 5; indent-tabs-mode: t; c-basic-offset: 5 -*- */
|
|
/* NetworkManager Wireless Applet -- Display wireless access points and allow user control
|
|
*
|
|
* Dan Williams <dcbw@redhat.com>
|
|
*
|
|
* 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., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
*
|
|
* (C) Copyright 2004-2005 Red Hat, Inc.
|
|
*/
|
|
|
|
|
|
#include <glib.h>
|
|
#include <string.h>
|
|
#include "nm-device.h"
|
|
|
|
|
|
/*
|
|
* Representation of network device
|
|
*
|
|
*/
|
|
struct NetworkDevice
|
|
{
|
|
int refcount;
|
|
char * iface;
|
|
char * desc;
|
|
char * nm_path;
|
|
NMDeviceType type;
|
|
gboolean active;
|
|
gboolean link;
|
|
NMDriverSupportLevel driver_support_level;
|
|
char * addr;
|
|
char * udi;
|
|
gint strength;
|
|
GSList * networks;
|
|
};
|
|
|
|
|
|
/*
|
|
* network_device_new
|
|
*
|
|
* Create a new network device representation
|
|
*
|
|
*/
|
|
NetworkDevice *network_device_new (const char *iface, NMDeviceType type, const char *nm_path)
|
|
{
|
|
NetworkDevice *dev = NULL;
|
|
|
|
if ((dev = g_malloc0 (sizeof (NetworkDevice))))
|
|
{
|
|
dev->refcount = 1;
|
|
dev->iface = g_strdup (iface);
|
|
dev->type = type;
|
|
dev->nm_path = g_strdup (nm_path);
|
|
}
|
|
|
|
return (dev);
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_copy
|
|
*
|
|
* Create a new network device representation, filling its
|
|
* data in from an already existing one. Deep-copies the
|
|
* wireless networks too.
|
|
*
|
|
*/
|
|
NetworkDevice *network_device_copy (NetworkDevice *src)
|
|
{
|
|
NetworkDevice *dev = NULL;
|
|
|
|
g_return_val_if_fail (src != NULL, NULL);
|
|
|
|
if ((dev = g_malloc0 (sizeof (NetworkDevice))))
|
|
{
|
|
GSList *elt;
|
|
|
|
network_device_ref (dev);
|
|
dev->nm_path = g_strdup (src->nm_path);
|
|
dev->type = src->type;
|
|
dev->link = src->link;
|
|
dev->addr = g_strdup (src->addr);
|
|
dev->driver_support_level = src->driver_support_level;
|
|
dev->iface = g_strdup (src->iface);
|
|
dev->desc = g_strdup (src->desc);
|
|
dev->udi = g_strdup (src->udi);
|
|
dev->active = src->active;
|
|
dev->strength = src->strength;
|
|
|
|
for (elt = src->networks; elt; elt = g_slist_next (elt))
|
|
{
|
|
WirelessNetwork *net = (WirelessNetwork *)elt->data;
|
|
if (net)
|
|
{
|
|
WirelessNetwork *copy = wireless_network_copy (net);
|
|
dev->networks = g_slist_append (dev->networks, copy);
|
|
}
|
|
}
|
|
}
|
|
|
|
return (dev);
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_ref
|
|
*
|
|
* Increment the reference count of the network device
|
|
*
|
|
*/
|
|
void network_device_ref (NetworkDevice *dev)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
dev->refcount++;
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_unref
|
|
*
|
|
* Unrefs (and possibly frees) the representation of a network device
|
|
*
|
|
*/
|
|
void network_device_unref (NetworkDevice *dev)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
dev->refcount--;
|
|
if (dev->refcount < 1)
|
|
{
|
|
if (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET)
|
|
network_device_clear_wireless_networks (dev);
|
|
g_free (dev->nm_path);
|
|
g_free (dev->iface);
|
|
g_free (dev->udi);
|
|
g_free (dev->desc);
|
|
g_free (dev->addr);
|
|
g_free (dev);
|
|
memset (dev, 0, sizeof (NetworkDevice));
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_get_active_wireless_network
|
|
*
|
|
* Return the active wireless network.
|
|
*
|
|
*/
|
|
WirelessNetwork *network_device_get_active_wireless_network (NetworkDevice *dev)
|
|
{
|
|
GSList * list;
|
|
WirelessNetwork * active = NULL;
|
|
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
g_return_val_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET, NULL);
|
|
|
|
for (list = dev->networks; list; list = list->next)
|
|
{
|
|
WirelessNetwork *net = (WirelessNetwork *) list->data;
|
|
|
|
if (wireless_network_get_active (net))
|
|
{
|
|
active = net;
|
|
break;
|
|
}
|
|
}
|
|
|
|
return active;
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_get_wireless_network_by_essid
|
|
*
|
|
* Return the wireless network with the specified essid.
|
|
*
|
|
*/
|
|
WirelessNetwork *network_device_get_wireless_network_by_essid (NetworkDevice *dev, const char *essid)
|
|
{
|
|
GSList * list;
|
|
WirelessNetwork * return_net = NULL;
|
|
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
g_return_val_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET, NULL);
|
|
g_return_val_if_fail (essid != NULL, NULL);
|
|
|
|
for (list = dev->networks; list; list = list->next)
|
|
{
|
|
WirelessNetwork *net = (WirelessNetwork *) list->data;
|
|
|
|
if (!strcmp (wireless_network_get_essid (net), essid))
|
|
{
|
|
return_net = net;
|
|
break;
|
|
}
|
|
}
|
|
|
|
return return_net;
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_get_wireless_network_by_nm_path
|
|
*
|
|
* Return the wireless network with the specified NetworkManager object path.
|
|
*
|
|
*/
|
|
WirelessNetwork *network_device_get_wireless_network_by_nm_path (NetworkDevice *dev, const char *nm_path)
|
|
{
|
|
GSList * list;
|
|
WirelessNetwork * return_net = NULL;
|
|
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
g_return_val_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET, NULL);
|
|
g_return_val_if_fail (nm_path != NULL, NULL);
|
|
|
|
for (list = dev->networks; list; list = list->next)
|
|
{
|
|
WirelessNetwork *net = (WirelessNetwork *) list->data;
|
|
|
|
if (!strcmp (wireless_network_get_nm_path (net), nm_path))
|
|
{
|
|
return_net = net;
|
|
break;
|
|
}
|
|
}
|
|
|
|
return return_net;
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_get_wireless_network_by_nm_path
|
|
*
|
|
* Return the wireless network with the specified NetworkManager object path.
|
|
*
|
|
*/
|
|
void network_device_foreach_wireless_network (NetworkDevice *dev, WirelessNetworkForeach func, gpointer user_data)
|
|
{
|
|
GSList * list;
|
|
|
|
g_return_if_fail (dev != NULL);
|
|
g_return_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET);
|
|
g_return_if_fail (func != NULL);
|
|
|
|
for (list = dev->networks; list; list = list->next)
|
|
{
|
|
WirelessNetwork *net = (WirelessNetwork *) list->data;
|
|
|
|
if (net)
|
|
(*func)(dev, net, user_data);
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_add_wireless_network
|
|
*
|
|
* Adds a wireless network to the network device's network list
|
|
*
|
|
*/
|
|
void network_device_add_wireless_network (NetworkDevice *dev, WirelessNetwork *net)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
g_return_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET);
|
|
g_return_if_fail (net != NULL);
|
|
|
|
wireless_network_ref (net);
|
|
dev->networks = g_slist_append (dev->networks, net);
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_clear_wireless_networks
|
|
*
|
|
*/
|
|
void network_device_clear_wireless_networks (NetworkDevice *dev)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
g_return_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET);
|
|
|
|
g_slist_foreach (dev->networks, (GFunc) wireless_network_unref, NULL);
|
|
g_slist_free (dev->networks);
|
|
dev->networks = NULL;
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_remove_wireless_network
|
|
*
|
|
* Remove one wireless network from the wireless network list
|
|
*
|
|
*/
|
|
void network_device_remove_wireless_network (NetworkDevice *dev, WirelessNetwork *net)
|
|
{
|
|
GSList *elt;
|
|
|
|
g_return_if_fail (dev != NULL);
|
|
g_return_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET);
|
|
g_return_if_fail (net != NULL);
|
|
|
|
for (elt = dev->networks; elt; elt = g_slist_next (elt))
|
|
{
|
|
if (elt->data == net)
|
|
{
|
|
dev->networks = g_slist_remove_link (dev->networks, elt);
|
|
wireless_network_unref ((WirelessNetwork *)elt->data);
|
|
g_slist_free (elt);
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
|
|
/*
|
|
* network_device_get_num_wireless_networks
|
|
*
|
|
* Return the number of wireless networks this device knows about.
|
|
*
|
|
*/
|
|
guint network_device_get_num_wireless_networks (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, 0);
|
|
g_return_val_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET, 0);
|
|
|
|
return g_slist_length (dev->networks);
|
|
}
|
|
|
|
|
|
/*
|
|
* Accessors for hardware address
|
|
*/
|
|
const char *network_device_get_address (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
|
|
return (dev->addr);
|
|
}
|
|
|
|
void network_device_set_address (NetworkDevice *dev, const char *addr)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
if (dev->addr)
|
|
{
|
|
g_free (dev->addr);
|
|
dev->addr = NULL;
|
|
}
|
|
if (addr)
|
|
dev->addr = g_strdup (addr);
|
|
}
|
|
|
|
/*
|
|
* Accessors for driver support level
|
|
*/
|
|
NMDriverSupportLevel network_device_get_driver_support_level (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, NM_DRIVER_UNSUPPORTED);
|
|
|
|
return (dev->driver_support_level);
|
|
}
|
|
|
|
void network_device_set_driver_support_level (NetworkDevice *dev, NMDriverSupportLevel level)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
dev->driver_support_level = level;
|
|
}
|
|
|
|
/*
|
|
* Accessors for NM object path
|
|
*/
|
|
const char *network_device_get_nm_path (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
|
|
return (dev->nm_path);
|
|
}
|
|
|
|
/*
|
|
* Accessors for device type
|
|
*/
|
|
NMDeviceType network_device_get_type (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, DEVICE_TYPE_DONT_KNOW);
|
|
|
|
return (dev->type);
|
|
}
|
|
|
|
/*
|
|
* Accessors for strength
|
|
*/
|
|
gint network_device_get_strength (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, -1);
|
|
g_return_val_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET, -1);
|
|
|
|
return (dev->strength);
|
|
}
|
|
|
|
void network_device_set_strength (NetworkDevice *dev, gint strength)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
g_return_if_fail (dev->type == DEVICE_TYPE_WIRELESS_ETHERNET);
|
|
|
|
dev->strength = strength;
|
|
}
|
|
|
|
/*
|
|
* Accessors for device's interface name
|
|
*/
|
|
const char *network_device_get_iface (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
|
|
return (dev->iface);
|
|
}
|
|
|
|
/*
|
|
* Accessors for HAL udi
|
|
*/
|
|
const char *network_device_get_hal_udi (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
|
|
return (dev->udi);
|
|
}
|
|
|
|
void network_device_set_hal_udi (NetworkDevice *dev, const char *hal_udi)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
if (dev->udi)
|
|
{
|
|
g_free (dev->udi);
|
|
dev->udi = NULL;
|
|
}
|
|
if (hal_udi)
|
|
dev->udi = g_strdup (hal_udi);
|
|
}
|
|
|
|
/*
|
|
* Accessors for link
|
|
*/
|
|
gboolean network_device_get_link (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, FALSE);
|
|
|
|
return (dev->link);
|
|
}
|
|
|
|
void network_device_set_link (NetworkDevice *dev, gboolean link)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
dev->link = link;
|
|
}
|
|
|
|
/*
|
|
* Accessors for active
|
|
*/
|
|
gboolean network_device_get_active (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, FALSE);
|
|
|
|
return (dev->active);
|
|
}
|
|
|
|
void network_device_set_active (NetworkDevice *dev, gboolean active)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
dev->active = active;
|
|
}
|
|
|
|
/*
|
|
* Accessors for desc
|
|
*/
|
|
const char *network_device_get_desc (NetworkDevice *dev)
|
|
{
|
|
g_return_val_if_fail (dev != NULL, NULL);
|
|
|
|
return (dev->desc);
|
|
}
|
|
|
|
void network_device_set_desc (NetworkDevice *dev, const char *desc)
|
|
{
|
|
g_return_if_fail (dev != NULL);
|
|
|
|
if (dev->desc)
|
|
{
|
|
g_free (dev->desc);
|
|
dev->desc = NULL;
|
|
}
|
|
if (desc)
|
|
dev->desc = g_strdup (desc);
|
|
}
|
|
|