# Copyright 2016, Tresys Technology, LLC # # SPDX-License-Identifier: LGPL-2.1-only # # from PyQt6 import QtCore import setools from .. import details from . import modelroles from .table import SEToolsTableModel __all__ = ("NetifconTable",) class NetifconTable(SEToolsTableModel[setools.Netifcon]): """Table-based model for netifcons.""" headers = ["Device", "Device Context", "Packet Context"] 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.netif case 1: return str(rule.context) case 2: return str(rule.packet) case modelroles.ContextMenuRole: match col: case 1: return details.context_detail_action(rule.context) case 2: return details.context_detail_action(rule.packet) case QtCore.Qt.ItemDataRole.WhatsThisRole: match col: case 0: column_whatsthis = \ """
This is the name of the netifcon.
""" case 1: column_whatsthis = \ """This is the device context of the netifcon.
""" case 2: column_whatsthis = \ """This is the packet context of the netifcon.
""" case _: column_whatsthis = "" return \ f"""Table Representation of Network Interface Contexts (netifcon)
Each part of the rule is represented as a column in the table.
{column_whatsthis} """ return super().data(index, role)