-
Notifications
You must be signed in to change notification settings - Fork 3
/
Copy pathdbusmanager.py
89 lines (72 loc) · 3.03 KB
/
dbusmanager.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import conic
import dbus
import dbus.glib
import gobject
from PyQt4.QtCore import QObject
""" DBus connection monitor. Monitors device internet connection and can requests one if needed.
most code taken from PyMaemo conic examples http://pymaemo.garage.maemo.org/conic.html """
class DBusMonitor(QObject):
def __init__(self, controller, logger):
QObject.__init__(self)
self.connection_manager = controller
self.logger = logger
self.device_has_networking = False
self.connection = None
self.bearer = None
# Note prints so I wont forget the hack on for releases
if self.device_has_networking:
print "\n" + 10 * " >> >> NOTE: Scratchbox networking enabled hack in use!\n"
self.gmainloop = gobject.MainLoop()
self.mainloop_context = self.gmainloop.get_context()
self.bus = dbus.SystemBus(private=True)
gobject.threads_init()
self.start_monitoring()
self.startTimer(250)
def timer_event(self, q_timer_event):
self.iteration()
def iteration(self):
self.mainloop_context.iteration(True)
def request_connection(self):
if not self.device_has_networking:
self.logger.network("Requesting for a network connection...")
self.connection.request_connection(conic.CONNECT_FLAG_NONE)
def start_monitoring(self):
if self.device_has_networking:
return
self.logger.network("Starting network connection monitoring...")
self.connection = conic.Connection()
self.connection.connect("connection-event", self.connection_callback, 0xAA55)
self.connection.set_property("automatic-connection-events", True)
return False
def stop_monitoring(self):
self.connection.set_property("automatic-connection-events", False)
def connection_callback(self, connection, event, magic):
message = None
status = event.get_status()
error = event.get_error()
iap_id = event.get_iap_id()
bearer = event.get_bearer_type()
if status == conic.STATUS_CONNECTED:
if self.device_has_networking:
return
if bearer != None:
message = "Device online: connected with " + bearer
else:
message = "Device online"
self.device_has_networking = True
elif status == conic.STATUS_DISCONNECTED:
if self.device_has_networking == False:
return
if bearer != None:
message = "Device offline: disconnected from " + bearer
else:
message = "Device offline"
self.device_has_networking = False
elif status == conic.STATUS_DISCONNECTING:
return
else:
return
if message != None:
self.logger.network(message)
self.bearer = bearer
self.connection_manager.set_connected(self.device_has_networking)