summaryrefslogtreecommitdiff
path: root/examples
diff options
context:
space:
mode:
authorclarkbw <clarkbw@cvs.gnome.org>2004-09-22 13:19:45 +0000
committerBryan W. Clark <clarkbw@gnome.org>2004-09-22 13:19:45 +0000
commit8dfb7e0850c74a3a6f9ff47cc2f3299ac9df5b56 (patch)
treecb2007f6927ad50cf8811f6485440dc7c84abb71 /examples
parenta75df11a6f7bef3199732c3aef3ebb35798e935d (diff)
downloadNetworkManager-8dfb7e0850c74a3a6f9ff47cc2f3299ac9df5b56.tar.gz
2004-09-22 <clarkbw@cvs.gnome.org>
* examples/python/NetworkManager.py: s/Quality/Strength/ * examples/python/systray/network_tray.py: Lots of little changes and fixes. been rotting for a while so I figured I'd finally sync them all with CVS git-svn-id: http://svn-archive.gnome.org/svn/NetworkManager/trunk@166 4912f4e0-d625-0410-9fb7-b9a5a253dbdc
Diffstat (limited to 'examples')
-rwxr-xr-xexamples/python/NetworkManager.py31
-rwxr-xr-xexamples/python/systray/network_tray.py206
2 files changed, 149 insertions, 88 deletions
diff --git a/examples/python/NetworkManager.py b/examples/python/NetworkManager.py
index 36ed0c3ab1..d17832e30c 100755
--- a/examples/python/NetworkManager.py
+++ b/examples/python/NetworkManager.py
@@ -77,30 +77,33 @@ class NetworkManager:
"""
def get_device(self, device):
try:
- nm_device_object = self._nm_service.get_object(device,
- NM_INTERFACE_DEVICES)
+ nm_dev_obj = self._nm_service.get_object(device,
+ NM_INTERFACE_DEVICES)
d = {}
- d["nm.name"] = nm_device_object.getName(device)
- d["nm.type"] = nm_device_object.getType(device)
- d["nm.udi"] = nm_device_object.getHalUdi(device)
- d["nm.ip4"] = nm_device_object.getIP4Address(device)
- d["nm.quality"] = nm_device_object.getMaxQuality(device)
-
+ d["nm.device"] = device
+ d["nm.name"] = nm_dev_obj.getName(device)
+ d["nm.type"] = nm_dev_obj.getType(device)
+ d["nm.udi"] = nm_dev_obj.getHalUdi(device)
+ d["nm.ip4"] = nm_dev_obj.getIP4Address(device)
+ d["nm.link_active"] = nm_dev_obj.getLinkActive(device)
+
try:
- d["nm.active_network"] = nm_device_object.getActiveNetwork(device)
+ d["nm.active_network"] = nm_dev_obj.getActiveNetwork(device)
+ d["nm.strength"] = nm_dev_obj.getStrength(device)
except DBusException, e:
pass
try:
d["nm.networks"] = {}
- networks = nm_device_object.getNetworks(device)
+ networks = nm_dev_obj.getNetworks(device)
for network in networks:
nm_network_object = self._nm_service.get_object(network,
NM_INTERFACE_DEVICES)
n = {}
+ n["network"] = network
n["name"] = nm_network_object.getName()
n["address"] = nm_network_object.getAddress()
- n["quality"] = nm_network_object.getQuality()
+ n["strength"] = nm_network_object.getStrength()
n["frequency"] = nm_network_object.getFrequency()
n["rate"] = nm_network_object.getRate()
n["encrypted"] = nm_network_object.getEncrypted()
@@ -130,10 +133,10 @@ class NetworkManager:
return self.__devices[device]
- except Error, e:
+ except Exception, e:
print e
return None
-
+
"""
Returns list of dictionary objects of all active devices
Returns empty list if no active devices
@@ -172,7 +175,7 @@ class NetworkManager:
return self.number_device_types(self.WIRED_DEVICE)
def number_wireless_devices(self):
- return self.number_device_types(self.WIRELESS_DEVICE)
+ return self.number_device_types(self.WIRELESS_DEVICE)
def has_wired_device(self):
return self.has_type_device(self.WIRED_DEVICE)
diff --git a/examples/python/systray/network_tray.py b/examples/python/systray/network_tray.py
index 6da5321bb4..1b0dc36a79 100755
--- a/examples/python/systray/network_tray.py
+++ b/examples/python/systray/network_tray.py
@@ -6,7 +6,8 @@ import gtk.gdk
try:
import trayicon
from NetworkManager import NetworkManager
-except:
+except ImportError, e:
+ print e
print "type 'make' make the necessary modules to run this example"
import sys
sys.exit(1)
@@ -24,9 +25,27 @@ class network_tray:
self._network_event)
self._network_event(None, None, None,None,None)
+
+ def _wired_network_cb(self, menuitem, event, device_name):
+ return
+ print menuitem, event, device_name
+ try:
+ self._nm.nm_object.setActiveDevice(device_name)
+ except Exception, e:
+ print e
+
+ def _wireless_network_cb(self, menuitem, event, device_name, network_name):
+ return
+ print menuitem, event, device_name, network_name
+ try:
+ self._nm.nm_object.setActiveDevice(device_name, network_name)
+ except Exception, e:
+ print e
def _add_separator_item(self):
- self._menu.append(gtk.SeparatorMenuItem())
+ sep = gtk.SeparatorMenuItem()
+ sep.show()
+ self._menu.append(sep)
def _add_label_item(self, label):
menuitem = gtk.MenuItem()
@@ -55,13 +74,13 @@ class network_tray:
self._menu.append(menuitem)
menuitem.show_all()
- def _add_device_menu_item(self, device):
- if not self._is_wireless(device):
- menuitem = gtk.RadioMenuItem(group=self.__radio_group)
- if self._is_active(device):
- menuitem.set_active(1)
- else:
- menuitem = gtk.MenuItem()
+ def _add_wired_device_menu_item(self, device):
+ menuitem = gtk.RadioMenuItem(group=self.__radio_group)
+ if self._is_active(device):
+ menuitem.set_active(1)
+
+ menuitem.connect("button-press-event",self._wired_network_cb,
+ device["nm.device"])
hbox = gtk.HBox(homogeneous=gtk.FALSE, spacing=6)
hbox.pack_start(self._get_icon(device), expand=gtk.FALSE, fill=gtk.FALSE, padding=6)
@@ -72,7 +91,46 @@ class network_tray:
menuitem.add(hbox)
hbox.show()
self._menu.append(menuitem)
- tt = "IP: %d\nProduct Name: %s\nVendor: %s\nDevice Name: %s" % (device["nm.ip4"], device["pci.product"], device["info.vendor"], device["nm.name"] )
+ try:
+ tt = "IP: %d\nProduct Name: %s\nVendor: %s\nDevice Name: %s" % (device["nm.ip4"], device["pci.product"], device["info.vendor"], device["nm.name"] )
+ self._tooltips.set_tip(menuitem,tt)
+ except:
+ pass
+ menuitem.show_all()
+
+ def _add_wireless_device_menu_item(self, device, generic=gtk.FALSE):
+ menuitem = gtk.MenuItem()
+
+ hbox = gtk.HBox(homogeneous=gtk.FALSE, spacing=6)
+ hbox.pack_start(self._get_icon(device), expand=gtk.FALSE, fill=gtk.FALSE, padding=6)
+ label = gtk.Label()
+ label.set_justify(gtk.JUSTIFY_LEFT)
+ label.set_markup("<span foreground=\"#aaaaaa\">%s</span>" % self._get_device_name(device))
+ label.set_selectable(gtk.FALSE)
+ hbox.pack_start(label, expand=gtk.FALSE, fill=gtk.FALSE, padding=6)
+ menuitem.add(hbox)
+ hbox.show()
+ self._menu.append(menuitem)
+ try:
+ tt = "IP: %d\nProduct Name: %s\nVendor: %s\nDevice Name: %s" % (device["nm.ip4"], device["pci.product"], device["info.vendor"], device["nm.name"] )
+ self._tooltips.set_tip(menuitem,tt)
+ except:
+ pass
+ menuitem.show_all()
+
+ def _add_vpn_menu_item(self):
+ menuitem = gtk.CheckMenuItem()
+
+ hbox = gtk.HBox(homogeneous=gtk.FALSE, spacing=6)
+ hbox.pack_start(self._get_vpn_icon(), expand=gtk.FALSE, fill=gtk.FALSE, padding=6)
+ label = gtk.Label()
+ label.set_justify(gtk.JUSTIFY_LEFT)
+ label.set_text("Virtual Private Network")
+ hbox.pack_start(label, expand=gtk.FALSE, fill=gtk.FALSE, padding=6)
+ menuitem.add(hbox)
+ hbox.show()
+ self._menu.append(menuitem)
+ tt = "Use a Virtual Private Network to securely connect to your companies internal system"
self._tooltips.set_tip(menuitem,tt)
menuitem.show_all()
@@ -90,9 +148,9 @@ class network_tray:
hbox.pack_start(label,expand=gtk.TRUE, fill=gtk.TRUE)
progress = gtk.ProgressBar()
progress.set_orientation(gtk.PROGRESS_LEFT_TO_RIGHT)
- q = self._get_quality(device, network)
- progress.set_fraction(q)
-# progress.set_text("%s %%" % int(q*100))
+ strength = float(network["strength"] * .01)
+ progress.set_fraction(strength)
+# progress.set_text("%s%%" % int(strength*100))
progress.show()
hbox.pack_start(progress, expand=gtk.FALSE, fill=gtk.FALSE)
icon = self._get_encrypted_icon()
@@ -104,40 +162,29 @@ class network_tray:
hbox.show()
self._menu.append(menuitem)
- tt = "Name: %s\nEncrypted: %d\nRate: %d\nFrequency: %f\nAddress: %s\nQuality: %d" % (network['name'], network['encrypted'], network['rate'],network['frequency'], network['address'], network['quality'])
+ tt = "Name: %s\nEncrypted: %d\nRate: %d\nFrequency: %f\nAddress: %s\nStrength: %1.2f" % (network['name'], network['encrypted'], network['rate'],network['frequency'], network['address'], strength)
self._tooltips.set_tip(menuitem,tt)
+ menuitem.connect("button-press-event", self._wireless_network_cb,
+ device["nm.device"], network["network"])
menuitem.show()
- def _get_quality(self, device, network):
- if network["quality"] == 0:
- proc = "/proc/driver/aironet/%s/BSSList" % device["net.interface"]
- import fileinput
- for line in fileinput.input(proc):
- dev_info = line.split()
- if network["name"] in dev_info:
- fileinput.close()
- try:
- qual = float(dev_info[4])
- q = float(qual / 100)
- return q
- except ValueError:
- return 0.0
- fileinput.close()
- else:
- return float(network["quality"])
- return 0.0
-
def _get_device_name(self, device):
+
if self._is_wireless(device):
- if self._nm.number_wireless_devices() > 1:
- return device["info.product"]
- else:
- return "Wireless Network"
+ try:
+ if self._nm.number_wireless_devices() > 1:
+ return device["info.product"]
+ else:
+ return "Wireless Network"
+ except:
+ return "Wireless PCMCIA Card"
else:
- if self._nm.number_wired_devices() > 1:
- return device["info.product"]
- else:
- return "Wired Network"
+ try:
+ if self._nm.number_wired_devices() > 1:
+ return device["info.product"]
+ except:
+ pass
+ return "Wired Network"
def _is_wireless(self,dev):
if dev["nm.type"] == self._nm.WIRELESS_DEVICE:
@@ -145,14 +192,12 @@ class network_tray:
return gtk.FALSE
def _is_active(self, dev):
- return dev["nm.status"] != self._nm.DISCONNECTED
+ try:
+ if dev["nm.link_active"] == 1:
+ return gtk.TRUE
+ except:
+ return gtk.FALSE
- def _number_wired_devices(self, devices):
- return self._number_x_devices(devices, self._nm.WIRED_DEVICE)
-
- def _number_wireless_devices(self, devices):
- return self._number_x_devices(devices, self._nm.WIRELESS_DEVICE)
-
def _network_event(self, interface, signal_name,
service, path, message):
@@ -161,31 +206,35 @@ class network_tray:
devices = self._nm.get_devices()
active_device = self._nm.get_active_device()
- tt = ""
+
+ def sort_devs(x, y):
+ if x["nm.type"] > y["nm.type"]:
+ return 1
+ elif x["nm.type"] < y["nm.type"]:
+ return -1
+ elif x["nm.link_active"] > y["nm.link_active"]:
+ return 1
+ elif x["nm.link_active"] < y["nm.link_active"]:
+ return -1
+ return 0
def sort_networks(x, y):
- if x["name"] > y["name"]:
- print y["name"], x["name"]
+ if x.lower() < y.lower():
return 1
- print x["name"] ,y["name"]
return -1
-
- wireless = gtk.FALSE
- for device in devices:
-
- if self._is_wireless(device) and wireless == gtk.FALSE:
- wireless = gtk.TRUE
- self._add_separator_item()
- self._add_label_item("Wireless Networks")
- else:
- self._add_device_menu_item(device)
- tt = "%s%s [%s]\n"%(tt,device["info.product"],device["nm.status"])
-
- self._tooltips.set_tip(self._top_level_menu,tt)
+ type = 0
+ devices.sort(sort_devs)
+ for device in devices:
+
if self._is_wireless(device):
- device["nm.networks"].values().sort(sort_networks)
- print device["nm.networks"]
+ type = device["nm.type"]
+ if self._nm.number_wireless_devices() > 1:
+ self._add_wireless_device_menu_item(device)
+ else:
+ self._add_wireless_device_menu_item(device, gtk.FALSE)
+
+ device["nm.networks"].keys().sort(sort_networks)
for name, network in device["nm.networks"].iteritems():
try:
if device["nm.active_network"] == name:
@@ -195,10 +244,16 @@ class network_tray:
except:
active_network = gtk.FALSE
self._add_network_menu_item(device,network,active_network)
+
+ else:
+ if type == self._nm.WIRELESS_DEVICE:
+ self._add_separator_item()
+ self._add_wired_device_menu_item(device)
- if wireless == gtk.TRUE:
- self._add_other_wireless_item()
-
+
+ self._add_other_wireless_item()
+# self._add_vpn_menu_item()
+
self._current_icon = self._get_icon(active_device)
self._current_icon.show()
@@ -206,23 +261,26 @@ class network_tray:
def _get_encrypted_icon(self):
pb = gtk.gdk.pixbuf_new_from_file("../../../panel-applet/keyring.png")
- pb = pb.scale_simple(24,24,gtk.gdk.INTERP_NEAREST)
+ pb = pb.scale_simple(16,16,gtk.gdk.INTERP_NEAREST)
_keyring = gtk.Image()
_keyring.set_from_pixbuf(pb)
return _keyring
-
+
+ def _get_vpn_icon(self):
+ return self._get_encrypted_icon()
+
def _get_icon(self, active_device):
if active_device:
if active_device["nm.type"] == self._nm.WIRED_DEVICE:
pb = gtk.gdk.pixbuf_new_from_file("../../../panel-applet/wired.png")
- pb = pb.scale_simple(24,24,gtk.gdk.INTERP_NEAREST)
+ pb = pb.scale_simple(16,16,gtk.gdk.INTERP_NEAREST)
_wired_icon = gtk.Image()
_wired_icon.set_from_pixbuf(pb)
return _wired_icon
elif active_device["nm.type"] == self._nm.WIRELESS_DEVICE:
pb = gtk.gdk.pixbuf_new_from_file("../../../panel-applet/wireless-applet.png")
- pb = pb.scale_simple(24,24,gtk.gdk.INTERP_NEAREST)
+ pb = pb.scale_simple(16,16,gtk.gdk.INTERP_NEAREST)
_wireless_icon = gtk.Image()
_wireless_icon.set_from_pixbuf(pb)
return _wireless_icon