Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell
diff options
context:
space:
mode:
Diffstat (limited to 'shell')
-rw-r--r--shell/hardware/nmclient.py22
-rw-r--r--shell/model/devices/network/wireless.py1
-rw-r--r--shell/view/home/MeshBox.py12
3 files changed, 28 insertions, 7 deletions
diff --git a/shell/hardware/nmclient.py b/shell/hardware/nmclient.py
index b14277e..f61018c 100644
--- a/shell/hardware/nmclient.py
+++ b/shell/hardware/nmclient.py
@@ -92,14 +92,16 @@ class Network(gobject.GObject):
gobject.TYPE_NONE, ([]))
}
- def __init__(self, op):
+ def __init__(self, client, op):
gobject.GObject.__init__(self)
+ self._client = client
self._op = op
self._ssid = None
self._mode = None
self._strength = 0
self._caps = 0
self._valid = False
+ self._favorite = False
self._state = NETWORK_STATE_NOTCONNECTED
obj = sys_bus.get_object(NM_SERVICE, self._op)
@@ -130,6 +132,12 @@ class Network(gobject.GObject):
self.emit('initialized', self._valid)
return
+ fav_nets = []
+ if self._client.nminfo:
+ fav_nets = self._client.nminfo.get_networks()
+ if self._ssid in fav_nets:
+ self._favorite = True
+
self._valid = True
logging.debug("Net(%s): caps 0x%X" % (self._ssid, self._caps))
self.emit('initialized', self._valid)
@@ -184,6 +192,9 @@ class Network(gobject.GObject):
def is_valid(self):
return self._valid
+ def is_favorite(self):
+ return self._favorite
+
class Device(gobject.GObject):
__gsignals__ = {
'initialized': (gobject.SIGNAL_RUN_FIRST,
@@ -204,8 +215,9 @@ class Device(gobject.GObject):
([gobject.TYPE_PYOBJECT]))
}
- def __init__(self, op):
+ def __init__(self, client, op):
gobject.GObject.__init__(self)
+ self._client = client
self._op = op
self._iface = None
self._type = DEVICE_TYPE_UNKNOWN
@@ -273,7 +285,7 @@ class Device(gobject.GObject):
def _update_networks(self, net_ops, active_op):
for op in net_ops:
- net = Network(op)
+ net = Network(self._client, op)
self._networks[op] = net
net.connect('initialized', lambda *args: self._net_initialized_cb(active_op, *args))
@@ -348,7 +360,7 @@ class Device(gobject.GObject):
def network_appeared(self, network):
if self._networks.has_key(network):
return
- net = Network(network)
+ net = Network(self._client, network)
self._networks[network] = net
net.connect('initialized', lambda *args: self._net_initialized_cb(None, *args))
@@ -503,7 +515,7 @@ class NMClient(gobject.GObject):
def _add_device(self, dev_op):
if self._devices.has_key(dev_op):
return
- dev = Device(dev_op)
+ dev = Device(self, dev_op)
self._devices[dev_op] = dev
dev.connect('init-failed', self._dev_init_failed_cb)
dev.connect('initialized', self._dev_initialized_cb)
diff --git a/shell/model/devices/network/wireless.py b/shell/model/devices/network/wireless.py
index d61c343..345393d 100644
--- a/shell/model/devices/network/wireless.py
+++ b/shell/model/devices/network/wireless.py
@@ -63,7 +63,6 @@ class Device(device.Device):
nm_state = self._nm_device.get_state()
return device._nm_state_to_state[nm_state]
elif pspec.name == 'frequency':
- print "freq: %s" % self._nm_device.get_frequency()
return self._nm_device.get_frequency()
def get_type(self):
diff --git a/shell/view/home/MeshBox.py b/shell/view/home/MeshBox.py
index 6ccb5c7..0760c3c 100644
--- a/shell/view/home/MeshBox.py
+++ b/shell/view/home/MeshBox.py
@@ -36,6 +36,9 @@ from view.BuddyIcon import BuddyIcon
from view.pulsingicon import PulsingIcon
from view.home.snowflakelayout import SnowflakeLayout
+from hardware.nmclient import NM_802_11_CAP_PROTO_WEP, NM_802_11_CAP_PROTO_WPA, NM_802_11_CAP_PROTO_WPA2
+
+
_ICON_NAME = 'network-wireless'
class AccessPointView(PulsingIcon):
@@ -57,6 +60,13 @@ class AccessPointView(PulsingIcon):
self._update_name()
self._update_state()
+ # Update badge
+ caps = model.props.capabilities
+ if model.get_nm_network().is_favorite():
+ self.props.badge_name = "badge-star"
+ elif (caps & NM_802_11_CAP_PROTO_WEP) or (caps & NM_802_11_CAP_PROTO_WPA) or (caps & NM_802_11_CAP_PROTO_WPA2):
+ self.props.badge_name = "badge-locked"
+
def _strength_changed_cb(self, model, pspec):
self._update_icon()
@@ -82,7 +92,7 @@ class AccessPointView(PulsingIcon):
def _update_icon(self):
icon_name = get_icon_state(_ICON_NAME, self._model.props.strength)
if icon_name:
- self.props.icon_name = icon_name
+ self.props.icon_name = icon_name
def _update_state(self):
if self._model.props.state == accesspointmodel.STATE_CONNECTING: