File: portconquery.py

package info (click to toggle)
setools 4.6.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,600 kB
  • sloc: python: 24,485; makefile: 14
file content (113 lines) | stat: -rw-r--r-- 4,403 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
# SPDX-License-Identifier: LGPL-2.1-only

from PyQt6 import QtWidgets
import setools

from . import criteria, models, tab

__all__ = ("PortconQueryTab",)


class PortconQueryTab(tab.TableResultTabWidget[setools.PortconQuery, setools.Portcon]):

    """A portcon query."""

    section = tab.AnalysisSection.Labeling
    tab_title = "Network Port Contexts"
    mlsonly = False

    def __init__(self, policy: setools.SELinuxPolicy, /, *,
                 parent: QtWidgets.QWidget | None = None) -> None:

        super().__init__(setools.PortconQuery(policy), enable_criteria=True, parent=parent)

        self.setWhatsThis("<b>Search portcon statements in a SELinux policy.</b>")

        #
        # Set up criteria widgets
        #
        ports = criteria.IP_PortName("Port/Port Range",
                                     self.query,
                                     "ports",
                                     convert_range=True,
                                     enable_range_opts=True,
                                     parent=self.criteria_frame)
        ports.setToolTip("The port number or port number range for portcon matching.")
        ports.setWhatsThis(
            """
            <p>This is the the port number or port number range used for portcon matching.</p>
            """)
        ports.criteria_opts[""].setWhatsThis(
            """
            <p>The port number/range must be equal to the portcon's port number/range for the
            portcon to match.</p>
            """)
        ports.criteria_opts["ports_overlap"].setWhatsThis(
            """
            <p>The port number/range must overlap the portcon's port number/range for the
            portcon to match.</p>
            """)
        ports.criteria_opts["ports_subset"].setWhatsThis(
            """
            <p>The port number/range must be a subset of the portcon's port number/range for the
            portcon to match.</p>
            """)
        ports.criteria_opts["ports_superset"].setWhatsThis(
            """
            <p>The port number/range must be a superset of the portcon's port number/range for the
            portcon to match.</p>
            """)

        proto = criteria.ComboEnumWidget[setools.PortconProtocol]("Protocol",
                                                                  self.query,
                                                                  "protocol",
                                                                  setools.PortconProtocol,
                                                                  parent=self.criteria_frame)
        proto.setToolTip("The protocol to use for portcon matching.")
        proto.setWhatsThis(
            """
            <p>This is the protocol used for portcon matching.  The blank option will match any
            protocol.</p>
            """)

        context = criteria.ContextMatch("Context Matching",
                                        self.query,
                                        parent=self.criteria_frame)
        context.setToolTip("The context to use for portcon matching.")
        context.setWhatsThis("""<p>This is the context used for portcon matching.""")

        # Add widgets to layout
        self.criteria_frame_layout.addWidget(ports, 0, 0, 1, 2)
        self.criteria_frame_layout.addWidget(proto, 0, 2, 1, 2)
        self.criteria_frame_layout.addWidget(context, 1, 0, 1, 4)
        self.criteria_frame_layout.addWidget(self.buttonBox, 2, 0, 1, 4)

        # Save widget references
        self.criteria = (ports, proto, context)

        # Set result table's model
        self.table_results_model = models.PortconTable(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 = PortconQueryTab(setools.SELinuxPolicy(), parent=mw)
    mw.setCentralWidget(widget)
    mw.resize(1280, 1024)
    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)