PATH:
usr
/
lib64
/
python3.9
/
site-packages
/
setools
# Copyright 2014-2015, Tresys Technology, LLC # # SPDX-License-Identifier: LGPL-2.1-only # import logging import re from typing import Iterable from .descriptors import CriteriaSetDescriptor from .mixins import MatchName from .policyrep import Role from .query import PolicyQuery from .util import match_regex_or_set class RoleQuery(MatchName, PolicyQuery): """ Query SELinux policy roles. Parameter: policy The policy to query. Keyword Parameters/Class attributes: name The role name to match. name_regex If true, regular expression matching will be used on the role names. types The type to match. types_equal If true, only roles with type sets that are equal to the criteria will match. Otherwise, any intersection will match. types_regex If true, regular expression matching will be used on the type names instead of set logic. """ types = CriteriaSetDescriptor("types_regex", "lookup_type") types_equal: bool = False types_regex: bool = False def __init__(self, policy, **kwargs) -> None: super(RoleQuery, self).__init__(policy, **kwargs) self.log = logging.getLogger(__name__) def results(self) -> Iterable[Role]: """Generator which yields all matching roles.""" self.log.info("Generating role results from {0.policy}".format(self)) self._match_name_debug(self.log) self.log.debug("Types: {0.types!r}, regex: {0.types_regex}, " "eq: {0.types_equal}".format(self)) for r in self.policy.roles(): if not self._match_name(r): continue if self.types and not match_regex_or_set( set(r.types()), self.types, self.types_equal, self.types_regex): continue yield r
[-] netifconquery.py
[edit]
[-] constraintquery.py
[edit]
[-] terulequery.py
[edit]
[-] permmap.py
[edit]
[-] py.typed
[edit]
[-] nodeconquery.py
[edit]
[+]
checker
[-] util.py
[edit]
[-] perm_map
[edit]
[-] typequery.py
[edit]
[-] commonquery.py
[edit]
[-] defaultquery.py
[edit]
[-] pirqconquery.py
[edit]
[-] policyrep.pyi
[edit]
[-] ioportconquery.py
[edit]
[-] ibpkeyconquery.py
[edit]
[-] pcideviceconquery.py
[edit]
[-] ibendportconquery.py
[edit]
[-] __init__.py
[edit]
[+]
diff
[-] policyrep.cpython-39-x86_64-linux-gnu.so
[edit]
[-] categoryquery.py
[edit]
[-] genfsconquery.py
[edit]
[-] polcapquery.py
[edit]
[-] boundsquery.py
[edit]
[-] objclassquery.py
[edit]
[-] boolquery.py
[edit]
[-] userquery.py
[edit]
[-] rolequery.py
[edit]
[+]
..
[-] descriptors.py
[edit]
[-] iomemconquery.py
[edit]
[-] dta.py
[edit]
[-] sensitivityquery.py
[edit]
[-] fsusequery.py
[edit]
[-] portconquery.py
[edit]
[-] typeattrquery.py
[edit]
[-] rbacrulequery.py
[edit]
[-] mlsrulequery.py
[edit]
[+]
__pycache__
[-] exception.py
[edit]
[-] devicetreeconquery.py
[edit]
[-] initsidquery.py
[edit]
[-] mixins.py
[edit]
[-] infoflow.py
[edit]
[-] query.py
[edit]