diff options
author | Nicolas Iooss <nicolas.iooss@m4x.org> | 2017-10-01 18:15:15 +0200 |
---|---|---|
committer | Jason Zaman <jason@perfinion.com> | 2017-10-02 01:51:49 +0800 |
commit | 3b5e8fb8421b0f80a7be61d0e54d71ee694b2b33 (patch) | |
tree | 178d07ed4c2f4cf705fc9a4d502b5bb9b565ca3b /gui | |
parent | d689e3dc1647b78926126e8b0c3b22db98115dcd (diff) | |
download | android_external_selinux-3b5e8fb8421b0f80a7be61d0e54d71ee694b2b33.tar.gz android_external_selinux-3b5e8fb8421b0f80a7be61d0e54d71ee694b2b33.tar.bz2 android_external_selinux-3b5e8fb8421b0f80a7be61d0e54d71ee694b2b33.zip |
gui: fix parsing of "semodule -lfull" in tab Modules
The output of "semodule -lfull" changed from "module version" to
"priority module kind". Update system-config-selinux to use this new
format in its tab "Policy Module".
Signed-off-by: Nicolas Iooss <nicolas.iooss@m4x.org>
Diffstat (limited to 'gui')
-rw-r--r-- | gui/modulesPage.py | 19 |
1 files changed, 13 insertions, 6 deletions
diff --git a/gui/modulesPage.py b/gui/modulesPage.py index c7fde9ea..34c5d9e3 100644 --- a/gui/modulesPage.py +++ b/gui/modulesPage.py @@ -58,7 +58,8 @@ class modulesPage(semanagePage): self.module_filter.connect("activate", self.filter_changed) self.audit_enabled = False - self.store = Gtk.ListStore(GObject.TYPE_STRING, GObject.TYPE_STRING) + self.store = Gtk.ListStore(GObject.TYPE_STRING, GObject.TYPE_STRING, + GObject.TYPE_STRING) self.view.set_model(self.store) self.store.set_sort_column_id(0, Gtk.SortType.ASCENDING) col = Gtk.TreeViewColumn(_("Module Name"), Gtk.CellRendererText(), text=0) @@ -66,7 +67,7 @@ class modulesPage(semanagePage): col.set_resizable(True) self.view.append_column(col) self.store.set_sort_column_id(0, Gtk.SortType.ASCENDING) - col = Gtk.TreeViewColumn(_("Version"), Gtk.CellRendererText(), text=1) + col = Gtk.TreeViewColumn(_("Priority"), Gtk.CellRendererText(), text=1) self.enable_audit_button = xml.get_object("enableAuditButton") self.enable_audit_button.connect("clicked", self.enable_audit) self.new_button = xml.get_object("newModuleButton") @@ -74,6 +75,11 @@ class modulesPage(semanagePage): col.set_sort_column_id(1) col.set_resizable(True) self.view.append_column(col) + self.store.set_sort_column_id(2, Gtk.SortType.ASCENDING) + col = Gtk.TreeViewColumn(_("Kind"), Gtk.CellRendererText(), text=2) + col.set_sort_column_id(2) + col.set_resizable(True) + self.view.append_column(col) self.store.set_sort_func(1, self.sort_int, "") status, self.policy_type = selinux.selinux_getpolicytype() @@ -95,16 +101,17 @@ class modulesPage(semanagePage): self.filter = filter self.store.clear() try: - fd = Popen("semodule -l", shell=True, stdout=PIPE).stdout + fd = Popen("semodule -lfull", shell=True, stdout=PIPE).stdout l = fd.readlines() fd.close() for i in l: - module, ver, newline = i.split('\t') - if not (self.match(module, filter) or self.match(ver, filter)): + priority, module, kind = i.decode('utf-8').split() + if not (self.match(module, filter) or self.match(priority, filter)): continue iter = self.store.append() self.store.set_value(iter, 0, module.strip()) - self.store.set_value(iter, 1, ver.strip()) + self.store.set_value(iter, 1, priority.strip()) + self.store.set_value(iter, 2, kind.strip()) except: pass self.view.get_selection().select_path((0,)) |