# SPDX-License-Identifier: LGPL-2.1-only from PyQt6 import QtCore, QtWidgets import setools from . import criteria, models, tab class RBACRuleQueryTab(tab.TableResultTabWidget): """An RBAC rule query.""" section = tab.AnalysisSection.Rules tab_title = "Role-based Access Control (RBAC) Rules" mlsonly = False def __init__(self, policy: setools.SELinuxPolicy, /, *, parent: QtWidgets.QWidget | None = None) -> None: super().__init__(setools.RBACRuleQuery(policy), enable_criteria=True, parent=parent) self.setWhatsThis("Search RBAC rules in a SELinux policy.") # # Set up criteria widgets # rt = criteria.RBACRuleType("Rule Type", self.query, parent=self.criteria_frame) rt.setToolTip("The rule types for rule matching.") rt.setWhatsThis( """
Select rule types for rule matching.
If a rule's has a one of the selected types, it will be returned.
""") src = criteria.RoleName("Source Role", self.query, "source", enable_regex=True, parent=self.criteria_frame) src.setToolTip("The source role for rule matching.") src.setWhatsThis( """Enter the source role for rule matching.
If regex is enabled, a regular expression is used for matching the role name instead of direct string comparison.
""") dst = criteria.TypeOrAttrName("Target Role/Type", self.query, "target", mode=criteria.TypeOrAttrName.Mode.type_or_attribute, enable_regex=True, enable_indirect=True, parent=self.criteria_frame) # add roles to completion completer = dst.criteria.completer() assert completer, "No completer set, this is an SETools bug" # type narrowing model = completer.model() assert isinstance(model, QtCore.QStringListModel) completion = model.stringList() completion.extend(r.name for r in policy.roles()) model.setStringList(completion) dst.setToolTip("The target role/type for rule matching.") dst.setWhatsThis( """Enter the target role/type for rule matching.
If regex is enabled, a regular expression is used for matching the role/type name instead of direct string comparison.
""") tclass = criteria.ObjClassList("Object Class", self.query, "tclass", parent=self.criteria_frame) tclass.setToolTip("The object class(es) for rule matching.") tclass.setWhatsThis( """Select object classes for rule matching.
A rule will be returned if its object class is one of the selected classes
""") dflt = criteria.RoleName("Default Role", self.query, "default", enable_regex=True, parent=self.criteria_frame) dflt.setToolTip("The default role for rule matching.") dflt.setWhatsThis( """Enter the default role for rule matching.
If a rule has this role as the default, it will be returned. Allow rules will not be returned.
""") # Add widgets to layout self.criteria_frame_layout.addWidget(rt, 0, 0, 1, 2) self.criteria_frame_layout.addWidget(src, 1, 0, 1, 1) self.criteria_frame_layout.addWidget(dst, 1, 1, 1, 1) self.criteria_frame_layout.addWidget(tclass, 2, 0, 1, 1) self.criteria_frame_layout.addWidget(dflt, 2, 1, 1, 1) self.criteria_frame_layout.addWidget(self.buttonBox, 3, 0, 1, 2) # Save widget references self.criteria = (rt, src, dst, tclass, dflt) # Set result table's model self.table_results_model = models.RBACRuleTable(self.table_results) if __name__ == '__main__': import sys import warnings import pprint import logging logging.basicConfig(level=logging.DEBUG, format='%(asctime)s|%(levelname)s|%(name)s|%(message)s') warnings.simplefilter("default") app = QtWidgets.QApplication(sys.argv) mw = QtWidgets.QMainWindow() widget = RBACRuleQueryTab(setools.SELinuxPolicy(), parent=mw) mw.setCentralWidget(widget) mw.resize(widget.size()) whatsthis = QtWidgets.QWhatsThis.createAction(mw) mw.menuBar().addAction(whatsthis) # type: ignore[union-attr] mw.setStatusBar(QtWidgets.QStatusBar(mw)) mw.show() rc = app.exec() pprint.pprint(widget.save()) sys.exit(rc)