Compare commits
No commits in common. "caff60b8b6c3044549ef0a653104a3cca23891f1" and "44e6b42342f2a44e6e627343bb2c95187a315423" have entirely different histories.
caff60b8b6
...
44e6b42342
72
mambatray.py
72
mambatray.py
@ -1,16 +1,19 @@
|
||||
#!/usr/bin/python3
|
||||
# mambatray 2
|
||||
# Copyright (C) 2011-2024 by Silvan Calarco
|
||||
# Copyright (C) 2011-2022 by Silvan Calarco
|
||||
# Copyright (C) 2011 by michiamophil
|
||||
# Distributed under the terms of the GPL version 3 FLOSS License
|
||||
#
|
||||
import sys
|
||||
import os
|
||||
import gettext
|
||||
import libproxy
|
||||
import distro
|
||||
from PyQt5.QtCore import Qt
|
||||
from PyQt5 import uic
|
||||
from PyQt5.QtCore import pyqtSignal, Qt
|
||||
from PyQt5.QtGui import QIcon, QCursor
|
||||
from PyQt5.QtWidgets import QSystemTrayIcon, QApplication, QMenu, QMessageBox
|
||||
from PyQt5.QtWidgets import QSystemTrayIcon, QApplication, QMenu, QMainWindow,\
|
||||
QMessageBox, QWidget
|
||||
from PyQt5.QtCore import QTimer, QProcess
|
||||
|
||||
DATADIR = os.path.dirname(os.path.realpath((__file__))) + "/"
|
||||
@ -20,8 +23,8 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
|
||||
menu = None
|
||||
|
||||
def __init__(self, icon):
|
||||
QSystemTrayIcon.__init__(self, icon)
|
||||
def __init__(self, icon, parent=None):
|
||||
QSystemTrayIcon.__init__(self, icon, parent)
|
||||
|
||||
global w, contatore, srpm, lista, NetsrpmsArg, nOre, desktop_session
|
||||
nOre = 2
|
||||
@ -32,7 +35,8 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
NetsrpmsArg = "-c"
|
||||
lista = []
|
||||
contatore = 0
|
||||
self.menu = QMenu()
|
||||
w = parent
|
||||
self.menu = QMenu(parent)
|
||||
|
||||
try:
|
||||
desktop_session = os.path.basename(os.getenv('DESKTOP_SESSION'))
|
||||
@ -64,7 +68,6 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
softwareBaseInstallsProcess = QProcess(self)
|
||||
|
||||
softwareMenu = self.menu.addMenu(QIcon.fromTheme("applications-system"),_("Software"))
|
||||
|
||||
softwareManageAction = softwareMenu.addAction(QIcon.fromTheme("applications-other"),_("Add/Remove software packages..."))
|
||||
softwareManageAction.triggered.connect(self.softwareManager)
|
||||
|
||||
@ -84,7 +87,6 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
|
||||
networkMenu = self.menu.addMenu(QIcon.fromTheme("preferences-system-network"),
|
||||
_("Network"))
|
||||
|
||||
networkFirewallMenu = networkMenu.addMenu(QIcon.fromTheme("security-medium"),_("Firewall"))
|
||||
networkFirewallDisableAction = networkFirewallMenu.addAction(QIcon.fromTheme("security-low"),_("Disable"))
|
||||
networkFirewallDisableAction.triggered.connect(self.networkFirewallDisable)
|
||||
@ -106,17 +108,29 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
self.setToolTip(_("{} control center").format(distro.name()))
|
||||
self.activated.connect(self.iconActivated)
|
||||
self.setContextMenu(self.menu)
|
||||
self.show()
|
||||
|
||||
# the first time refresh packages cache after 5 minutes
|
||||
refreshPackagesTimer.start( 5 * 60000 )
|
||||
# the first time check for SRPMS updates after 4 minutes
|
||||
checkSRPMSUpdatesTimer.start( 4 * 60000 )
|
||||
|
||||
|
||||
def setProxyForSmart(self):
|
||||
setProxyProcess = QProcess(self)
|
||||
pf = libproxy.ProxyFactory()
|
||||
for protocol in ["http","https","ftp"]:
|
||||
proxies = pf.getProxies("%s://openmamba.org" % protocol)
|
||||
for proxy in proxies:
|
||||
if proxy == "direct://":
|
||||
setProxyProcess.execute("smart",['config','--remove','%s_proxy' % protocol])
|
||||
break
|
||||
else:
|
||||
setProxyProcess.execute("smart",['config','--set','%s_proxy=%s' %(protocol,proxy)])
|
||||
break
|
||||
|
||||
def iconActivated(self, reason):
|
||||
if reason in (QSystemTrayIcon.Trigger, QSystemTrayIcon.DoubleClick, QSystemTrayIcon.Context):
|
||||
# FIXME: on plasma wayland and left click menu will popup in the center of the screen
|
||||
# disabling and only supporting right click.
|
||||
if desktop_session != 'plasmawayland':
|
||||
self.contextMenu().popup(QCursor.pos())
|
||||
|
||||
def about(self):
|
||||
@ -138,12 +152,15 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
return networkOnlineProcess.execute("/usr/bin/nm-online",['-q','-x'])
|
||||
|
||||
def softwareManager(self):
|
||||
#self.setProxyForSmart()
|
||||
softwareManagerProcess.execute("/usr/bin/plasma-discover")
|
||||
|
||||
def softwareCheckUpgrades(self):
|
||||
#self.setProxyForSmart()
|
||||
softwareCheckUpgradesProcess.start("/usr/bin/pkcon", ['refresh', 'force'])
|
||||
|
||||
def refreshPackagesCache(self):
|
||||
#self.setProxyForSmart()
|
||||
refreshPackagesTimer.stop()
|
||||
refreshPackagesCacheProcess.start("/usr/bin/pkcon", ['refresh', 'force'])
|
||||
|
||||
@ -173,18 +190,19 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
self.showMessage("Firewall", _("Could not enable firewall"))
|
||||
|
||||
def networkFirewallConfigure(self):
|
||||
if desktop_session == 'kde' or desktop_session.startswith('plasma'):
|
||||
if desktop_session == 'kde' or desktop_session == 'plasma':
|
||||
networkFirewallConfigureProcess.execute("/usr/bin/kcmshell5", list(set(['firewall'])))
|
||||
else:
|
||||
networkFirewallConfigureProcess.execute("/usr/bin/gufw")
|
||||
|
||||
def networkProxy(self):
|
||||
if desktop_session.startswith('plasma'):
|
||||
if desktop_session == 'plasma':
|
||||
networkProxyProcess.execute("/usr/bin/kcmshell5", list(set(['proxy'])))
|
||||
elif desktop_session == 'kde':
|
||||
networkProxyProcess.execute("/opt/kde/bin/kcmshell4", list(set(['proxy'])))
|
||||
elif desktop_session == 'gnome':
|
||||
networkProxyProcess.execute("/usr/bin/gnome-control-center", "network")
|
||||
#self.setProxyForSmart()
|
||||
|
||||
def SRPMSCheckUpgradeList(self):
|
||||
checkSRPMSUpdatesTimer.stop()
|
||||
@ -192,7 +210,7 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
if (self.networkOnline() == 0):
|
||||
try:
|
||||
SRPMUpdateProcess.start("/usr/bin/openmamba-netsrpms",[NetsrpmsArg,srpm[contatore]])
|
||||
except:
|
||||
except: #supera il limite dell'indice nella lista
|
||||
contatore = 0
|
||||
if NetsrpmsArg == '-c':
|
||||
self.SRPMSAskAndInstall()
|
||||
@ -201,7 +219,7 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
NetsrpmsArg = '-c'
|
||||
checkSRPMSUpdatesTimer.start((nOre * 60) * 60000)
|
||||
|
||||
# run for each netsrpm at the end of SRPMUpdateProcess
|
||||
#viene eseguita per ogni SRPM al termine del processo SRPMUpdateProcess
|
||||
def SRPMSCheckUpgrade(self, status):
|
||||
global contatore, lista
|
||||
if status == 1:
|
||||
@ -209,16 +227,13 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
contatore += 1
|
||||
self.SRPMSCheckUpgradeList()
|
||||
|
||||
# netsrpm updates ask and install
|
||||
#viene eseguita una volta terminata la fase di controllo degli aggiornamenti
|
||||
def SRPMSAskAndInstall(self):
|
||||
global NetsrpmsArg, lista
|
||||
if not lista == []:
|
||||
Lista = self.Lista()
|
||||
msg = QMessageBox.question(self.menu,
|
||||
(_("Not Open Source {} components").format(distro.name())),
|
||||
(_("The following components are available for update: ") +
|
||||
"\n\n" + Lista + "\n\n" + _("Ok to proceed?")),
|
||||
QMessageBox.Yes | QMessageBox.No, QMessageBox.Yes)
|
||||
msg = QMessageBox.question(self.menu,(_("Not Open Source {} components").format(distro.name())),
|
||||
(_("The following components are available for update: ") + "\n\n" + Lista + "\n\n" + _("Ok to proceed?")), QMessageBox.Yes | QMessageBox.No, QMessageBox.Yes)
|
||||
if msg == QMessageBox.Yes:
|
||||
NetsrpmsArg = '-u'
|
||||
self.SRPMSCheckUpgradeList()
|
||||
@ -228,8 +243,7 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
else:
|
||||
checkSRPMSUpdatesTimer.start((nOre * 60) * 60000)
|
||||
|
||||
# starting from the list "lista" returns the list in readable format
|
||||
# FIXME: make this code more clear and clean
|
||||
#partendo dalla lista lista (scusate il gioco di parole :) ) restituisce la lista in modo 'leggibile'
|
||||
def Lista(self):
|
||||
testo = ''
|
||||
for a in lista:
|
||||
@ -237,13 +251,17 @@ class SystemTrayIcon(QSystemTrayIcon):
|
||||
return testo[0:len(testo)-2]
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
def main():
|
||||
app = QApplication(sys.argv)
|
||||
if app.isSessionRestored():
|
||||
app.exit(1)
|
||||
else:
|
||||
app.setQuitOnLastWindowClosed(0)
|
||||
gettext.install('mambatray', '/usr/share/locale')
|
||||
trayIcon = SystemTrayIcon(QIcon.fromTheme("mambatray"))
|
||||
trayIcon.show()
|
||||
sys.exit(app.exec())
|
||||
trayIcon = SystemTrayIcon(QIcon.fromTheme("mambatray")
|
||||
)
|
||||
sys.exit(app.exec_())
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
main()
|
||||
|
Loading…
Reference in New Issue
Block a user