blob: ac7fe9c4622542a66f0cde70a719c2be4c0d933d (
plain)
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
|
# vim: set fileencoding=utf-8 :
#!/usr/bin/env python
import logging
logging.basicConfig()
logger = logging.getLogger(name=__name__)
logger.setLevel(logging.DEBUG)
from PyQt4 import QtCore
from PyQt4 import QtGui
from leap.baseapp.eip import EIPConductorApp
from leap.baseapp.log import LogPane
from leap.baseapp.systray import StatusAwareTrayIcon
from leap.baseapp.leap_app import MainWindow
class LeapWindow(QtGui.QMainWindow,
MainWindow, EIPConductorApp,
StatusAwareTrayIcon,
LogPane):
"""
main window for the leap app.
Initializes all of its base classes
We keep here some signal initialization
that gets tricky otherwise.
"""
newLogLine = QtCore.pyqtSignal([str])
statusChange = QtCore.pyqtSignal([object])
def __init__(self, opts):
logger.debug('init leap window')
self.debugmode = getattr(opts, 'debug', False)
super(LeapWindow, self).__init__()
if self.debugmode:
self.createLogBrowser()
EIPConductorApp.__init__(self, opts=opts)
StatusAwareTrayIcon.__init__(self)
MainWindow.__init__(self)
# bind signals
# XXX move to parent classes init??
self.trayIcon.activated.connect(self.iconActivated)
self.newLogLine.connect(
lambda line: self.onLoggerNewLine(line))
self.statusChange.connect(
lambda status: self.onStatusChange(status))
self.timer.timeout.connect(
lambda: self.onTimerTick())
# ... all ready. go!
# could send "ready" signal instead
# eipapp should catch that
if self.conductor.autostart:
self.start_or_stopVPN()
|