mirror of
https://github.com/SELinuxProject/selinux
synced 2025-01-19 03:40:50 +00:00
sepolicy: make search() use setools4 api
Signed-off-by: Jason Zaman <jason@perfinion.com>
This commit is contained in:
parent
f10a096354
commit
97d5f6a24f
@ -249,23 +249,115 @@ def info(setype, name=None):
|
||||
raise ValueError("Invalid type")
|
||||
|
||||
|
||||
def search(types, info={}):
|
||||
seinfo = info
|
||||
valid_types = [ALLOW, AUDITALLOW, NEVERALLOW, DONTAUDIT, TRANSITION, ROLE_ALLOW]
|
||||
def _setools_rule_to_dict(rule):
|
||||
d = {
|
||||
'type': str(rule.ruletype),
|
||||
'source': str(rule.source),
|
||||
'target': str(rule.target),
|
||||
'class': str(rule.tclass),
|
||||
}
|
||||
|
||||
try:
|
||||
enabled = bool(rule.qpol_symbol.is_enabled(rule.policy))
|
||||
except AttributeError:
|
||||
enabled = True
|
||||
|
||||
if isinstance(rule, setools.policyrep.terule.AVRule):
|
||||
d['enabled'] = enabled
|
||||
|
||||
try:
|
||||
d['permlist'] = list(map(str, rule.perms))
|
||||
except setools.policyrep.exception.RuleUseError:
|
||||
pass
|
||||
|
||||
try:
|
||||
d['transtype'] = str(rule.default)
|
||||
except setools.policyrep.exception.RuleUseError:
|
||||
pass
|
||||
|
||||
try:
|
||||
d['boolean'] = [(str(rule.conditional), enabled)]
|
||||
except (AttributeError, setools.policyrep.exception.RuleNotConditional):
|
||||
pass
|
||||
|
||||
try:
|
||||
d['filename'] = rule.filename
|
||||
except (AttributeError,
|
||||
setools.policyrep.exception.RuleNotConditional,
|
||||
setools.policyrep.exception.TERuleNoFilename):
|
||||
pass
|
||||
|
||||
return d
|
||||
|
||||
|
||||
def search(types, seinfo=None):
|
||||
if not seinfo:
|
||||
seinfo = {}
|
||||
valid_types = set([ALLOW, AUDITALLOW, NEVERALLOW, DONTAUDIT, TRANSITION, ROLE_ALLOW])
|
||||
for setype in types:
|
||||
if setype not in valid_types:
|
||||
raise ValueError("Type has to be in %s" % valid_types)
|
||||
seinfo[setype] = True
|
||||
raise ValueError("Type has to be in %s" % " ".join(valid_types))
|
||||
|
||||
source = None
|
||||
if SOURCE in seinfo:
|
||||
source = str(seinfo[SOURCE])
|
||||
|
||||
target = None
|
||||
if TARGET in seinfo:
|
||||
target = str(seinfo[TARGET])
|
||||
|
||||
tclass = None
|
||||
if CLASS in seinfo:
|
||||
tclass = str(seinfo[CLASS]).split(',')
|
||||
|
||||
toret = []
|
||||
|
||||
tertypes = []
|
||||
if ALLOW in types:
|
||||
tertypes.append(ALLOW)
|
||||
if NEVERALLOW in types:
|
||||
tertypes.append(NEVERALLOW)
|
||||
if AUDITALLOW in types:
|
||||
tertypes.append(AUDITALLOW)
|
||||
|
||||
if len(tertypes) > 0:
|
||||
q = setools.TERuleQuery(_pol,
|
||||
ruletype=tertypes,
|
||||
source=source,
|
||||
target=target,
|
||||
tclass=tclass)
|
||||
|
||||
perms = []
|
||||
if PERMS in seinfo:
|
||||
perms = info[PERMS]
|
||||
seinfo[PERMS] = ",".join(seinfo[PERMS])
|
||||
q.perms = seinfo[PERMS]
|
||||
|
||||
dict_list = _policy.search(seinfo)
|
||||
if dict_list and len(perms) != 0:
|
||||
dict_list = filter(lambda x: _dict_has_perms(x, perms), dict_list)
|
||||
return dict_list
|
||||
toret += [_setools_rule_to_dict(x) for x in q.results()]
|
||||
|
||||
if TRANSITION in types:
|
||||
rtypes = ['type_transition', 'type_change', 'type_member']
|
||||
q = setools.TERuleQuery(_pol,
|
||||
ruletype=rtypes,
|
||||
source=source,
|
||||
target=target,
|
||||
tclass=tclass)
|
||||
|
||||
if PERMS in seinfo:
|
||||
q.perms = seinfo[PERMS]
|
||||
|
||||
toret += [_setools_rule_to_dict(x) for x in q.results()]
|
||||
|
||||
if ROLE_ALLOW in types:
|
||||
ratypes = ['allow']
|
||||
q = setools.RBACRuleQuery(_pol,
|
||||
ruletype=ratypes,
|
||||
source=source,
|
||||
target=target,
|
||||
tclass=tclass)
|
||||
|
||||
for r in q.results():
|
||||
toret.append({'source': str(r.source),
|
||||
'target': str(r.target)})
|
||||
|
||||
return toret
|
||||
|
||||
|
||||
def get_conditionals(src, dest, tclass, perm):
|
||||
|
Loading…
Reference in New Issue
Block a user