mirror of
https://github.com/SELinuxProject/setools
synced 2025-04-30 07:14:05 +00:00
* Remove "Model" from names of model classes. * Remove remaining *_detail() functions. * Add typing. * Make models dir a package. * Update for superclass data() method as fallback. * Switch to match/case statements. Signed-off-by: Chris PeBenito <pebenito@ieee.org>
43 lines
1.3 KiB
Python
43 lines
1.3 KiB
Python
# Copyright 2016, Tresys Technology, LLC
|
|
#
|
|
# SPDX-License-Identifier: LGPL-2.1-only
|
|
#
|
|
#
|
|
from PyQt5 import QtCore
|
|
import setools
|
|
|
|
from .table import SEToolsTableModel
|
|
|
|
|
|
class ConstraintTable(SEToolsTableModel[setools.Constraint]):
|
|
|
|
"""A table-based model for constraints."""
|
|
|
|
headers = ["Rule Type", "Class", "Permissions", "Expression"]
|
|
|
|
def data(self, index: QtCore.QModelIndex, role: int = QtCore.Qt.ItemDataRole.DisplayRole):
|
|
if not self.item_list or not index.isValid():
|
|
return None
|
|
|
|
row = index.row()
|
|
col = index.column()
|
|
rule = self.item_list[row]
|
|
|
|
match role:
|
|
case QtCore.Qt.ItemDataRole.DisplayRole:
|
|
match col:
|
|
case 0:
|
|
return rule.ruletype.name
|
|
case 1:
|
|
return rule.tclass.name
|
|
case 2:
|
|
if rule.ruletype in (setools.ConstraintRuletype.constrain,
|
|
setools.ConstraintRuletype.mlsconstrain):
|
|
return ", ".join(sorted(rule.perms))
|
|
else:
|
|
return None
|
|
case 3:
|
|
return str(rule.expression)
|
|
|
|
return super().data(index, role)
|