setools/setoolsgui/rulemodels.py

165 lines
5.3 KiB
Python
Raw Normal View History

2015-06-03 17:33:11 +00:00
# Copyright 2015, Tresys Technology, LLC
#
# This file is part of SETools.
#
# SETools is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as
# published by the Free Software Foundation, either version 2.1 of
# the License, or (at your option) any later version.
#
# SETools is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with SETools. If not, see
# <http://www.gnu.org/licenses/>.
#
from collections import defaultdict
2015-06-03 17:33:11 +00:00
from PyQt5.QtCore import Qt, QAbstractTableModel, QModelIndex
from setools.policyrep.exception import RuleNotConditional, RuleUseError
class RuleListModel(QAbstractTableModel):
2015-12-15 13:51:14 +00:00
"""Base class for rule list models."""
2015-12-15 13:51:14 +00:00
headers = None
2015-12-15 13:51:14 +00:00
def __init__(self, parent):
super(RuleListModel, self).__init__(parent)
2015-12-15 13:51:14 +00:00
self.resultlist = []
def headerData(self, section, orientation, role):
if role == Qt.DisplayRole and orientation == Qt.Horizontal:
return self.headers[section]
2015-12-15 13:51:14 +00:00
def columnCount(self, parent=QModelIndex()):
return 5
def rowCount(self, parent=QModelIndex()):
if self.resultlist:
return len(self.resultlist)
else:
return 0
def data(self, index, role):
raise NotImplementedError
class MLSRuleListModel(RuleListModel):
"""MLS rule model. Represents rules as a column."""
headers = defaultdict(str, {0: "Rule Type", 1: "Source", 2: "Target",
3: "Object Class", 4: "Default Range"})
2015-12-15 13:51:14 +00:00
def data(self, index, role):
if self.resultlist:
2015-12-15 13:51:14 +00:00
row = index.row()
col = index.column()
rule = self.resultlist[row]
2015-12-15 13:51:14 +00:00
if role == Qt.DisplayRole:
if col == 0:
return rule.ruletype
elif col == 1:
return str(rule.source)
elif col == 2:
return str(rule.target)
elif col == 3:
return str(rule.tclass)
elif col == 4:
return str(rule.default)
elif role == Qt.UserRole:
return rule
2015-12-15 13:51:14 +00:00
class RBACRuleListModel(RuleListModel):
"""RBAC rule model. Represents rules as a column."""
headers = defaultdict(str, {0: "Rule Type", 1: "Source", 2: "Target",
3: "Object Class", 4: "Default Role"})
2015-06-03 17:33:11 +00:00
def data(self, index, role):
if self.resultlist:
2015-06-03 17:33:11 +00:00
row = index.row()
col = index.column()
rule = self.resultlist[row]
if role == Qt.DisplayRole:
if col == 0:
return rule.ruletype
elif col == 1:
return str(rule.source)
elif col == 2:
return str(rule.target)
elif col == 3:
try:
return str(rule.tclass)
except RuleUseError:
# role allow
return None
elif col == 4:
# next most common: default
try:
return str(rule.default)
except RuleUseError:
return None
elif role == Qt.UserRole:
return rule
2015-06-03 17:33:11 +00:00
class TERuleListModel(RuleListModel):
2015-06-03 17:33:11 +00:00
"""Type Enforcement rule model. Represents rules as a column."""
headers = defaultdict(str, {0: "Rule Type", 1: "Source", 2: "Target",
3: "Object Class", 4: "Permissions/Default Type",
5: "Conditional Expression", 6: "Conditional Block"})
def columnCount(self, parent=QModelIndex()):
return 7
def data(self, index, role):
if self.resultlist:
row = index.row()
col = index.column()
rule = self.resultlist[row]
if role == Qt.DisplayRole:
if col == 0:
return rule.ruletype
elif col == 1:
return str(rule.source)
elif col == 2:
return str(rule.target)
elif col == 3:
return str(rule.tclass)
elif col == 4:
try:
if rule.extended:
return "{0.xperm_type}: {0.perms:,}".format(rule)
else:
return ", ".join(sorted(rule.perms))
except RuleUseError:
return str(rule.default)
elif col == 5:
try:
return str(rule.conditional)
except RuleNotConditional:
return None
elif col == 6:
try:
return str(rule.conditional_block)
except RuleNotConditional:
return None
elif role == Qt.UserRole:
return rule