appmenus fix
This commit is contained in:
parent
6462ae88b7
commit
eefa6c31c2
@ -20,113 +20,74 @@
|
||||
#
|
||||
#
|
||||
|
||||
import sys
|
||||
import os
|
||||
from PyQt4.QtCore import *
|
||||
from PyQt4.QtGui import *
|
||||
|
||||
import qubesmanager.resources_rc
|
||||
|
||||
from pyinotify import WatchManager, Notifier, ThreadedNotifier, EventsCodes, ProcessEvent
|
||||
|
||||
import subprocess
|
||||
import sys
|
||||
import time
|
||||
|
||||
from operator import itemgetter
|
||||
|
||||
from .thread_monitor import *
|
||||
from .multiselectwidget import *
|
||||
from PyQt4.QtCore import *
|
||||
from PyQt4.QtGui import *
|
||||
from pyinotify import WatchManager, Notifier, ThreadedNotifier, EventsCodes, ProcessEvent
|
||||
|
||||
whitelisted_filename = 'whitelisted-appmenus.list'
|
||||
import qubesmanager.resources_rc
|
||||
|
||||
# TODO description in tooltip
|
||||
# TODO icon
|
||||
class AppListWidgetItem(QListWidgetItem):
|
||||
def __init__(self, name, filename, command, parent = None):
|
||||
def __init__(self, name, ident, parent=None):
|
||||
super(AppListWidgetItem, self).__init__(name, parent)
|
||||
self.setToolTip(command)
|
||||
self.filename = filename
|
||||
# self.setToolTip(command)
|
||||
self.ident = ident
|
||||
|
||||
@classmethod
|
||||
def from_line(cls, line):
|
||||
ident, name = line.strip().split(maxsplit=2)
|
||||
return cls(name=name, ident=ident)
|
||||
|
||||
|
||||
class AppmenuSelectManager:
|
||||
def __init__(self, vm, apps_multiselect, parent=None):
|
||||
|
||||
self.app_list = apps_multiselect # this is a multiselect wiget
|
||||
|
||||
self.vm = vm
|
||||
if self.vm.template:
|
||||
self.source_vm = self.vm.template
|
||||
else:
|
||||
self.source_vm = self.vm
|
||||
|
||||
self.app_list = apps_multiselect # this is a multiselect wiget
|
||||
self.fill_apps_list()
|
||||
|
||||
def fill_apps_list(self):
|
||||
|
||||
template_dir = self.source_vm.appmenus_templates_dir
|
||||
|
||||
template_file_list = os.listdir(template_dir)
|
||||
|
||||
whitelisted = []
|
||||
if os.path.exists(self.vm.dir_path + '/' + whitelisted_filename):
|
||||
f = open(self.vm.dir_path + '/' + whitelisted_filename, 'r')
|
||||
whitelisted = [item.strip() for item in f]
|
||||
f.close()
|
||||
whitelisted = [line for line in subprocess.check_output(
|
||||
['qvm-appmenus', '--get-whitelist', self.vm.name]
|
||||
).decode().strip().split('\n') if line]
|
||||
|
||||
# Check if appmenu entry is really installed
|
||||
whitelisted = [a for a in whitelisted if os.path.exists('%s/apps/%s-%s' % (self.vm.dir_path, self.vm.name, a))]
|
||||
# whitelisted = [a for a in whitelisted if os.path.exists('%s/apps/%s-%s' % (self.vm.dir_path, self.vm.name, a))]
|
||||
|
||||
self.app_list.clear()
|
||||
|
||||
available_appmenus = []
|
||||
for template_file in template_file_list:
|
||||
desktop_template = open(template_dir + '/' + template_file, 'r')
|
||||
desktop_name = None
|
||||
desktop_command = None
|
||||
for line in desktop_template:
|
||||
if line.startswith("Name=%VMNAME%: "):
|
||||
desktop_name = line.partition('Name=%VMNAME%: ')[2].strip()
|
||||
if line.startswith("Exec=qvm-run"):
|
||||
desktop_command = line[line.find("'"):].strip("'\n")
|
||||
if not desktop_command:
|
||||
desktop_command = ""
|
||||
if desktop_name:
|
||||
available_appmenus.append( (template_file, desktop_name, desktop_command) )
|
||||
desktop_template.close()
|
||||
|
||||
self.whitelisted_appmenus = [a for a in available_appmenus if a[0] in whitelisted]
|
||||
available_appmenus = [a for a in available_appmenus if a[0] not in whitelisted]
|
||||
available_appmenus = [AppListWidgetItem.from_line(line)
|
||||
for line in subprocess.check_output(['qvm-appmenus',
|
||||
'--get-available', '--i-understand-format-is-unstable',
|
||||
self.vm.name]).decode().split()]
|
||||
|
||||
for a in available_appmenus:
|
||||
self.app_list.available_list.addItem( AppListWidgetItem(a[1], a[0], a[2]))
|
||||
|
||||
for a in self.whitelisted_appmenus:
|
||||
self.app_list.selected_list.addItem( AppListWidgetItem(a[1], a[0], a[2]))
|
||||
if a.ident in whitelisted:
|
||||
self.app_list.selected_list.addItem(a)
|
||||
else:
|
||||
self.app_list.available_list.addItem(a)
|
||||
|
||||
self.app_list.available_list.sortItems()
|
||||
self.app_list.selected_list.sortItems()
|
||||
|
||||
def save_list_of_selected(self):
|
||||
sth_changed = False
|
||||
added = []
|
||||
|
||||
for i in range(self.app_list.selected_list.count()):
|
||||
item = self.app_list.selected_list.item(i)
|
||||
if item.filename not in [ w[0] for w in self.whitelisted_appmenus]:
|
||||
added.append(item)
|
||||
new_whitelisted = [self.app_list.selected_list.item(i).ident
|
||||
for i in range(self.app_list.selected_list.count())]
|
||||
|
||||
if self.app_list.selected_list.count() - len(added) < len(self.whitelisted_appmenus): #sth removed
|
||||
sth_changed = True
|
||||
elif len(added) > 0:
|
||||
sth_changed = True
|
||||
subprocess.check_call(
|
||||
'qvm-appmenus', '--set-whitelist', '-', self.vm.name,
|
||||
input='\n'.join(new_whitelisted))
|
||||
|
||||
if sth_changed == True:
|
||||
whitelisted = open(self.vm.dir_path + '/' + whitelisted_filename, 'w')
|
||||
for i in range(self.app_list.selected_list.count()):
|
||||
item = self.app_list.selected_list.item(i)
|
||||
whitelisted.write(item.filename + '\n')
|
||||
whitelisted.close()
|
||||
return True
|
||||
else:
|
||||
return False
|
||||
|
||||
|
||||
def save_appmenu_select_changes(self):
|
||||
|
@ -33,10 +33,11 @@ import qubesadmin
|
||||
import qubesadmin.tools
|
||||
|
||||
from . import utils
|
||||
from . import multiselectwidget
|
||||
|
||||
from .ui_settingsdlg import *
|
||||
from .appmenu_select import *
|
||||
from .firewall import *
|
||||
from .appmenu_select import AppmenuSelectManager
|
||||
from .backup_utils import get_path_for_vm
|
||||
|
||||
class VMSettingsWindow(Ui_SettingsDialog, QDialog):
|
||||
@ -107,7 +108,7 @@ class VMSettingsWindow(Ui_SettingsDialog, QDialog):
|
||||
|
||||
####### apps tab
|
||||
if self.tabWidget.isTabEnabled(self.tabs_indices["applications"]):
|
||||
self.app_list = MultiSelectWidget(self)
|
||||
self.app_list = multiselectwidget.MultiSelectWidget(self)
|
||||
self.apps_layout.addWidget(self.app_list)
|
||||
self.AppListManager = AppmenuSelectManager(self.vm, self.app_list)
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user