# Authors: Karl MacMillan <kmacmillan@mentalrootkit.com> # # Copyright (C) 2006 Red Hat # see file 'COPYING' for use and warranty information # # This program is free software; you can redistribute it and/or # modify it under the terms of the GNU General Public License as # published by the Free Software Foundation; version 2 only # # This program 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 General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # """ This module provides knowledge object classes and permissions. It should be used to keep this knowledge from leaking into the more generic parts of the policy generation. """ # Objects that can be implicitly typed - these objects do # not _have_ to be implicitly typed (e.g., sockets can be # explicitly labeled), but they often are. # # File is in this list for /proc/self # # This list is useful when dealing with rules that have a # type (or param) used as both a subject and object. For # example: # # allow httpd_t httpd_t : socket read; # # This rule makes sense because the socket was (presumably) created # by a process with the type httpd_t. implicitly_typed_objects = ["socket", "fd", "process", "file", "lnk_file", "fifo_file", "dbus", "capability", "unix_stream_socket"] #:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: # #Information Flow # # All of the permissions in SELinux can be described in terms of # information flow. For example, a read of a file is a flow of # information from that file to the process reading. Viewing # permissions in these terms can be used to model a varity of # security properties. # # Here we have some infrastructure for understanding permissions # in terms of information flow # #:::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::::: # Information flow deals with information either flowing from a subject # to and object ("write") or to a subject from an object ("read"). Read # or write is described from the subject point-of-view. It is also possible # for a permission to represent both a read and write (though the flow is # typical asymettric in terms of bandwidth). It is also possible for # permission to not flow information (meaning that the result is pure # side-effect). # # The following constants are for representing the directionality # of information flow. FLOW_NONE = 0 FLOW_READ = 1 FLOW_WRITE = 2 FLOW_BOTH = FLOW_READ | FLOW_WRITE # These are used by the parser and for nice disply of the directions str_to_dir = { "n" : FLOW_NONE, "r" : FLOW_READ, "w" : FLOW_WRITE, "b" : FLOW_BOTH } dir_to_str = { FLOW_NONE : "n", FLOW_READ : "r", FLOW_WRITE : "w", FLOW_BOTH : "b" } class PermMap: """A mapping between a permission and its information flow properties. PermMap represents the information flow properties of a single permission including the direction (read, write, etc.) and an abstract representation of the bandwidth of the flow (weight). """ def __init__(self, perm, dir, weight): self.perm = perm self.dir = dir self.weight = weight def __repr__(self): return "<sepolgen.objectmodel.PermMap %s %s %d>" % (self.perm, dir_to_str[self.dir], self.weight) class PermMappings: """The information flow properties of a set of object classes and permissions. PermMappings maps one or more classes and permissions to their PermMap objects describing their information flow charecteristics. """ def __init__(self): self.classes = { } self.default_weight = 5 self.default_dir = FLOW_BOTH def from_file(self, fd): """Read the permission mappings from a file. This reads the format used by Apol in the setools suite. """ # This parsing is deliberitely picky and bails at the least error. It # is assumed that the permission map file will be shipped as part # of sepolgen and not user modified, so this is a reasonable design # choice. If user supplied permission mappings are needed the parser # should be made a little more robust and give better error messages. cur = None for line in fd: fields = line.split() if len(fields) == 0 or len(fields) == 1 or fields[0] == "#": continue if fields[0] == "class": c = fields[1] if c in self.classes: raise ValueError("duplicate class in perm map") self.classes[c] = { } cur = self.classes[c] else: if len(fields) != 3: raise ValueError("error in object classs permissions") if cur is None: raise ValueError("permission outside of class") pm = PermMap(fields[0], str_to_dir[fields[1]], int(fields[2])) cur[pm.perm] = pm def get(self, obj, perm): """Get the permission map for the object permission. Returns: PermMap representing the permission Raises: KeyError if the object or permission is not defined """ return self.classes[obj][perm] def getdefault(self, obj, perm): """Get the permission map for the object permission or a default. getdefault is the same as get except that a default PermMap is returned if the object class or permission is not defined. The default is FLOW_BOTH with a weight of 5. """ try: pm = self.classes[obj][perm] except KeyError: return PermMap(perm, self.default_dir, self.default_weight) return pm def getdefault_direction(self, obj, perms): dir = FLOW_NONE for perm in perms: pm = self.getdefault(obj, perm) dir = dir | pm.dir return dir def getdefault_distance(self, obj, perms): total = 0 for perm in perms: pm = self.getdefault(obj, perm) total += pm.weight return total
Name | Type | Size | Permission | Actions |
---|---|---|---|---|
.__init__.pyo.40009 | File | 142 B | 0644 |
|
.access.pyo.40009 | File | 13.18 KB | 0644 |
|
.audit.pyo.40009 | File | 22.33 KB | 0644 |
|
.classperms.pyo.40009 | File | 3.16 KB | 0644 |
|
.defaults.pyo.40009 | File | 2.87 KB | 0644 |
|
.interfaces.pyo.40009 | File | 15.86 KB | 0644 |
|
.lex.pyo.40009 | File | 19.24 KB | 0644 |
|
.matching.pyo.40009 | File | 7.4 KB | 0644 |
|
.module.pyo.40009 | File | 8.4 KB | 0644 |
|
.objectmodel.pyo.40009 | File | 4.64 KB | 0644 |
|
.output.pyo.40009 | File | 4.51 KB | 0644 |
|
.refparser.pyo.40009 | File | 36.27 KB | 0644 |
|
.refpolicy.pyo.40009 | File | 46.45 KB | 0644 |
|
.sepolgeni18n.pyo.40009 | File | 410 B | 0644 |
|
.util.pyo.40009 | File | 7.87 KB | 0644 |
|
.yacc.pyo.40009 | File | 41.4 KB | 0644 |
|
__init__.py | File | 0 B | 0644 |
|
__init__.pyc | File | 142 B | 0644 |
|
__init__.pyo | File | 142 B | 0644 |
|
access.py | File | 12.33 KB | 0644 |
|
access.pyc | File | 13.18 KB | 0644 |
|
access.pyo | File | 13.18 KB | 0644 |
|
audit.py | File | 23.64 KB | 0644 |
|
audit.pyc | File | 22.33 KB | 0644 |
|
audit.pyo | File | 22.33 KB | 0644 |
|
classperms.py | File | 2.75 KB | 0644 |
|
classperms.pyc | File | 3.16 KB | 0644 |
|
classperms.pyo | File | 3.16 KB | 0644 |
|
defaults.py | File | 2.69 KB | 0644 |
|
defaults.pyc | File | 2.87 KB | 0644 |
|
defaults.pyo | File | 2.87 KB | 0644 |
|
interfaces.py | File | 16.21 KB | 0644 |
|
interfaces.pyc | File | 15.86 KB | 0644 |
|
interfaces.pyo | File | 15.86 KB | 0644 |
|
lex.py | File | 32.86 KB | 0644 |
|
lex.pyc | File | 19.24 KB | 0644 |
|
lex.pyo | File | 19.24 KB | 0644 |
|
matching.py | File | 8.45 KB | 0644 |
|
matching.pyc | File | 7.4 KB | 0644 |
|
matching.pyo | File | 7.4 KB | 0644 |
|
module.py | File | 7.12 KB | 0644 |
|
module.pyc | File | 8.4 KB | 0644 |
|
module.pyo | File | 8.4 KB | 0644 |
|
objectmodel.py | File | 6.37 KB | 0644 |
|
objectmodel.pyc | File | 4.64 KB | 0644 |
|
objectmodel.pyo | File | 4.64 KB | 0644 |
|
output.py | File | 5.01 KB | 0644 |
|
output.pyc | File | 4.51 KB | 0644 |
|
output.pyo | File | 4.51 KB | 0644 |
|
policygen.py | File | 16.31 KB | 0644 |
|
policygen.pyc | File | 15.25 KB | 0644 |
|
policygen.pyo | File | 15.18 KB | 0644 |
|
refparser.py | File | 30.2 KB | 0644 |
|
refparser.pyc | File | 36.27 KB | 0644 |
|
refparser.pyo | File | 36.27 KB | 0644 |
|
refpolicy.py | File | 27.31 KB | 0644 |
|
refpolicy.pyc | File | 46.45 KB | 0644 |
|
refpolicy.pyo | File | 46.45 KB | 0644 |
|
sepolgeni18n.py | File | 912 B | 0644 |
|
sepolgeni18n.pyc | File | 410 B | 0644 |
|
sepolgeni18n.pyo | File | 410 B | 0644 |
|
util.py | File | 5.41 KB | 0644 |
|
util.pyc | File | 7.87 KB | 0644 |
|
util.pyo | File | 7.87 KB | 0644 |
|
yacc.py | File | 80.04 KB | 0644 |
|
yacc.pyc | File | 41.4 KB | 0644 |
|
yacc.pyo | File | 41.4 KB | 0644 |
|