diff options
author | Jeff Vander Stoep <jeffv@google.com> | 2015-06-18 07:52:02 -0700 |
---|---|---|
committer | Jeff Vander Stoep <jeffv@google.com> | 2015-06-18 07:52:02 -0700 |
commit | fe63c8d5e6e841f474eec96e2dd38d8fa97a17f8 (patch) | |
tree | 57b5a1be2dcd01bc500525ac831f3e3421f4dae5 /lib/python2.7/site-packages/setools/typeattrquery.py | |
parent | 5de4f653a1cff7d7acbbb933711537ef47e2723c (diff) | |
download | platform_prebuilts_python_linux-x86_2.7.5-fe63c8d5e6e841f474eec96e2dd38d8fa97a17f8.tar.gz platform_prebuilts_python_linux-x86_2.7.5-fe63c8d5e6e841f474eec96e2dd38d8fa97a17f8.tar.bz2 platform_prebuilts_python_linux-x86_2.7.5-fe63c8d5e6e841f474eec96e2dd38d8fa97a17f8.zip |
SELinux: python modules for selinux tools
<tool(s)>: <required python modules>
audit2allow audit2why: sepolgen selinux
sesearch: setools setoolsgui
Change-Id: Ifc19252d8d8e178b86c51fe1f54e162a61ffc0dd
Diffstat (limited to 'lib/python2.7/site-packages/setools/typeattrquery.py')
-rw-r--r-- | lib/python2.7/site-packages/setools/typeattrquery.py | 70 |
1 files changed, 70 insertions, 0 deletions
diff --git a/lib/python2.7/site-packages/setools/typeattrquery.py b/lib/python2.7/site-packages/setools/typeattrquery.py new file mode 100644 index 0000000..a91026c --- /dev/null +++ b/lib/python2.7/site-packages/setools/typeattrquery.py @@ -0,0 +1,70 @@ +# Copyright 2014-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/>. +# +import logging +import re + +from . import compquery +from .descriptors import CriteriaSetDescriptor + + +class TypeAttributeQuery(compquery.ComponentQuery): + + """ + Query SELinux policy type attributes. + + Parameter: + policy The policy to query. + + Keyword Parameters/Class attributes: + name The type name to match. + name_regex If true, regular expression matching + will be used on the type names. + types The type to match. + types_equal If true, only attributes 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 = False + types_regex = False + + def results(self): + """Generator which yields all matching types.""" + self.log.info("Generating results from {0.policy}".format(self)) + self.log.debug("Name: {0.name!r}, regex: {0.name_regex}".format(self)) + self.log.debug("Types: {0.types!r}, regex: {0.types_regex}, " + "eq: {0.types_equal}".format(self)) + + for attr in self.policy.typeattributes(): + if not self._match_name(attr): + continue + + if self.types and not self._match_regex_or_set( + set(attr.expand()), + self.types, + self.types_equal, + self.types_regex): + continue + + yield attr |