mirror of
https://github.com/SELinuxProject/selinux
synced 2025-04-24 19:58:02 +00:00
semanage: py3 support for print function and map/filter
map and filter were turned into list comprehensions. This was done using python's 2to3 utility. Signed-off-by: Jason Zaman <jason@perfinion.com> Signed-off-by: James Carter <jwcart2@tycho.nsa.gov>
This commit is contained in:
parent
4209c00afe
commit
b51c39499b
policycoreutils/semanage
@ -336,7 +336,7 @@ class moduleRecords(semanageRecords):
|
|||||||
all = self.get_all()
|
all = self.get_all()
|
||||||
if len(all) == 0:
|
if len(all) == 0:
|
||||||
return
|
return
|
||||||
return map(lambda x: "-d %s" % x[0], filter(lambda t: t[1] == 0, all))
|
return ["-d %s" % x[0] for x in [t for t in all if t[1] == 0]]
|
||||||
|
|
||||||
def list(self, heading=1, locallist=0):
|
def list(self, heading=1, locallist=0):
|
||||||
all = self.get_all()
|
all = self.get_all()
|
||||||
@ -344,7 +344,7 @@ class moduleRecords(semanageRecords):
|
|||||||
return
|
return
|
||||||
|
|
||||||
if heading:
|
if heading:
|
||||||
print "\n%-25s %-9s %s\n" % (_("Module Name"), _("Priority"), _("Language"))
|
print("\n%-25s %-9s %s\n" % (_("Module Name"), _("Priority"), _("Language")))
|
||||||
for t in all:
|
for t in all:
|
||||||
if t[1] == 0:
|
if t[1] == 0:
|
||||||
disabled = _("Disabled")
|
disabled = _("Disabled")
|
||||||
@ -352,7 +352,7 @@ class moduleRecords(semanageRecords):
|
|||||||
if locallist:
|
if locallist:
|
||||||
continue
|
continue
|
||||||
disabled = ""
|
disabled = ""
|
||||||
print "%-25s %-9s %-5s %s" % (t[0], t[2], t[3], disabled)
|
print("%-25s %-9s %-5s %s" % (t[0], t[2], t[3], disabled))
|
||||||
|
|
||||||
def add(self, file, priority):
|
def add(self, file, priority):
|
||||||
if not os.path.exists(file):
|
if not os.path.exists(file):
|
||||||
@ -402,7 +402,7 @@ class moduleRecords(semanageRecords):
|
|||||||
self.commit()
|
self.commit()
|
||||||
|
|
||||||
def deleteall(self):
|
def deleteall(self):
|
||||||
l = map(lambda x: x[0], filter(lambda t: t[1] == 0, self.get_all()))
|
l = [x[0] for x in [t for t in self.get_all() if t[1] == 0]]
|
||||||
for m in l:
|
for m in l:
|
||||||
self.set_enabled(m, True)
|
self.set_enabled(m, True)
|
||||||
|
|
||||||
@ -439,24 +439,24 @@ class permissiveRecords(semanageRecords):
|
|||||||
return l
|
return l
|
||||||
|
|
||||||
def list(self, heading=1, locallist=0):
|
def list(self, heading=1, locallist=0):
|
||||||
all = map(lambda y: y["name"], filter(lambda x: x["permissive"], sepolicy.info(sepolicy.TYPE)))
|
all = [y["name"] for y in [x for x in sepolicy.info(sepolicy.TYPE) if x["permissive"]]]
|
||||||
if len(all) == 0:
|
if len(all) == 0:
|
||||||
return
|
return
|
||||||
|
|
||||||
if heading:
|
if heading:
|
||||||
print "\n%-25s\n" % (_("Builtin Permissive Types"))
|
print("\n%-25s\n" % (_("Builtin Permissive Types")))
|
||||||
customized = self.get_all()
|
customized = self.get_all()
|
||||||
for t in all:
|
for t in all:
|
||||||
if t not in customized:
|
if t not in customized:
|
||||||
print t
|
print(t)
|
||||||
|
|
||||||
if len(customized) == 0:
|
if len(customized) == 0:
|
||||||
return
|
return
|
||||||
|
|
||||||
if heading:
|
if heading:
|
||||||
print "\n%-25s\n" % (_("Customized Permissive Types"))
|
print("\n%-25s\n" % (_("Customized Permissive Types")))
|
||||||
for t in customized:
|
for t in customized:
|
||||||
print t
|
print(t)
|
||||||
|
|
||||||
def add(self, type):
|
def add(self, type):
|
||||||
import glob
|
import glob
|
||||||
@ -564,7 +564,7 @@ class loginRecords(semanageRecords):
|
|||||||
self.begin()
|
self.begin()
|
||||||
self.__add(name, sename, serange)
|
self.__add(name, sename, serange)
|
||||||
self.commit()
|
self.commit()
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -624,7 +624,7 @@ class loginRecords(semanageRecords):
|
|||||||
self.begin()
|
self.begin()
|
||||||
self.__modify(name, sename, serange)
|
self.__modify(name, sename, serange)
|
||||||
self.commit()
|
self.commit()
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -666,7 +666,7 @@ class loginRecords(semanageRecords):
|
|||||||
self.__delete(name)
|
self.__delete(name)
|
||||||
self.commit()
|
self.commit()
|
||||||
|
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -680,7 +680,7 @@ class loginRecords(semanageRecords):
|
|||||||
for u in ulist:
|
for u in ulist:
|
||||||
self.__delete(semanage_seuser_get_name(u))
|
self.__delete(semanage_seuser_get_name(u))
|
||||||
self.commit()
|
self.commit()
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -734,21 +734,21 @@ class loginRecords(semanageRecords):
|
|||||||
|
|
||||||
if is_mls_enabled == 1:
|
if is_mls_enabled == 1:
|
||||||
if heading:
|
if heading:
|
||||||
print "\n%-20s %-20s %-20s %s\n" % (_("Login Name"), _("SELinux User"), _("MLS/MCS Range"), _("Service"))
|
print("\n%-20s %-20s %-20s %s\n" % (_("Login Name"), _("SELinux User"), _("MLS/MCS Range"), _("Service")))
|
||||||
for k in keys:
|
for k in keys:
|
||||||
u = ddict[k]
|
u = ddict[k]
|
||||||
print "%-20s %-20s %-20s %s" % (k, u[0], translate(u[1]), u[2])
|
print("%-20s %-20s %-20s %s" % (k, u[0], translate(u[1]), u[2]))
|
||||||
if len(lkeys):
|
if len(lkeys):
|
||||||
print "\nLocal customization in %s" % self.logins_path
|
print("\nLocal customization in %s" % self.logins_path)
|
||||||
|
|
||||||
for k in lkeys:
|
for k in lkeys:
|
||||||
u = ldict[k]
|
u = ldict[k]
|
||||||
print "%-20s %-20s %-20s %s" % (k, u[0], translate(u[1]), u[2])
|
print("%-20s %-20s %-20s %s" % (k, u[0], translate(u[1]), u[2]))
|
||||||
else:
|
else:
|
||||||
if heading:
|
if heading:
|
||||||
print "\n%-25s %-25s\n" % (_("Login Name"), _("SELinux User"))
|
print("\n%-25s %-25s\n" % (_("Login Name"), _("SELinux User")))
|
||||||
for k in keys:
|
for k in keys:
|
||||||
print "%-25s %-25s" % (k, ddict[k][0])
|
print("%-25s %-25s" % (k, ddict[k][0]))
|
||||||
|
|
||||||
|
|
||||||
class seluserRecords(semanageRecords):
|
class seluserRecords(semanageRecords):
|
||||||
@ -839,7 +839,7 @@ class seluserRecords(semanageRecords):
|
|||||||
self.begin()
|
self.begin()
|
||||||
self.__add(name, roles, selevel, serange, prefix)
|
self.__add(name, roles, selevel, serange, prefix)
|
||||||
self.commit()
|
self.commit()
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -904,7 +904,7 @@ class seluserRecords(semanageRecords):
|
|||||||
self.begin()
|
self.begin()
|
||||||
self.__modify(name, roles, selevel, serange, prefix)
|
self.__modify(name, roles, selevel, serange, prefix)
|
||||||
self.commit()
|
self.commit()
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -947,7 +947,7 @@ class seluserRecords(semanageRecords):
|
|||||||
self.__delete(name)
|
self.__delete(name)
|
||||||
self.commit()
|
self.commit()
|
||||||
|
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -961,7 +961,7 @@ class seluserRecords(semanageRecords):
|
|||||||
for u in ulist:
|
for u in ulist:
|
||||||
self.__delete(semanage_user_get_name(u))
|
self.__delete(semanage_user_get_name(u))
|
||||||
self.commit()
|
self.commit()
|
||||||
except ValueError, error:
|
except ValueError as error:
|
||||||
self.mylog.commit(0)
|
self.mylog.commit(0)
|
||||||
raise error
|
raise error
|
||||||
|
|
||||||
@ -1003,15 +1003,15 @@ class seluserRecords(semanageRecords):
|
|||||||
|
|
||||||
if is_mls_enabled == 1:
|
if is_mls_enabled == 1:
|
||||||
if heading:
|
if heading:
|
||||||
print "\n%-15s %-10s %-10s %-30s" % ("", _("Labeling"), _("MLS/"), _("MLS/"))
|
print("\n%-15s %-10s %-10s %-30s" % ("", _("Labeling"), _("MLS/"), _("MLS/")))
|
||||||
print "%-15s %-10s %-10s %-30s %s\n" % (_("SELinux User"), _("Prefix"), _("MCS Level"), _("MCS Range"), _("SELinux Roles"))
|
print("%-15s %-10s %-10s %-30s %s\n" % (_("SELinux User"), _("Prefix"), _("MCS Level"), _("MCS Range"), _("SELinux Roles")))
|
||||||
for k in keys:
|
for k in keys:
|
||||||
print "%-15s %-10s %-10s %-30s %s" % (k, ddict[k][0], translate(ddict[k][1]), translate(ddict[k][2]), ddict[k][3])
|
print("%-15s %-10s %-10s %-30s %s" % (k, ddict[k][0], translate(ddict[k][1]), translate(ddict[k][2]), ddict[k][3]))
|
||||||
else:
|
else:
|
||||||
if heading:
|
if heading:
|
||||||
print "%-15s %s\n" % (_("SELinux User"), _("SELinux Roles"))
|
print("%-15s %s\n" % (_("SELinux User"), _("SELinux Roles")))
|
||||||
for k in keys:
|
for k in keys:
|
||||||
print "%-15s %s" % (k, ddict[k][3])
|
print("%-15s %s" % (k, ddict[k][3]))
|
||||||
|
|
||||||
|
|
||||||
class portRecords(semanageRecords):
|
class portRecords(semanageRecords):
|
||||||
@ -1268,13 +1268,13 @@ class portRecords(semanageRecords):
|
|||||||
keys.sort()
|
keys.sort()
|
||||||
|
|
||||||
if heading:
|
if heading:
|
||||||
print "%-30s %-8s %s\n" % (_("SELinux Port Type"), _("Proto"), _("Port Number"))
|
print("%-30s %-8s %s\n" % (_("SELinux Port Type"), _("Proto"), _("Port Number")))
|
||||||
for i in keys:
|
for i in keys:
|
||||||
rec = "%-30s %-8s " % i
|
rec = "%-30s %-8s " % i
|
||||||
rec += "%s" % ddict[i][0]
|
rec += "%s" % ddict[i][0]
|
||||||
for p in ddict[i][1:]:
|
for p in ddict[i][1:]:
|
||||||
rec += ", %s" % p
|
rec += ", %s" % p
|
||||||
print rec
|
print(rec)
|
||||||
|
|
||||||
|
|
||||||
class nodeRecords(semanageRecords):
|
class nodeRecords(semanageRecords):
|
||||||
@ -1502,16 +1502,16 @@ class nodeRecords(semanageRecords):
|
|||||||
keys.sort()
|
keys.sort()
|
||||||
|
|
||||||
if heading:
|
if heading:
|
||||||
print "%-18s %-18s %-5s %-5s\n" % ("IP Address", "Netmask", "Protocol", "Context")
|
print("%-18s %-18s %-5s %-5s\n" % ("IP Address", "Netmask", "Protocol", "Context"))
|
||||||
if is_mls_enabled:
|
if is_mls_enabled:
|
||||||
for k in keys:
|
for k in keys:
|
||||||
val = ''
|
val = ''
|
||||||
for fields in k:
|
for fields in k:
|
||||||
val = val + '\t' + str(fields)
|
val = val + '\t' + str(fields)
|
||||||
print "%-18s %-18s %-5s %s:%s:%s:%s " % (k[0], k[1], k[2], ddict[k][0], ddict[k][1], ddict[k][2], translate(ddict[k][3], False))
|
print("%-18s %-18s %-5s %s:%s:%s:%s " % (k[0], k[1], k[2], ddict[k][0], ddict[k][1], ddict[k][2], translate(ddict[k][3], False)))
|
||||||
else:
|
else:
|
||||||
for k in keys:
|
for k in keys:
|
||||||
print "%-18s %-18s %-5s %s:%s:%s " % (k[0], k[1], k[2], ddict[k][0], ddict[k][1], ddict[k][2])
|
print("%-18s %-18s %-5s %s:%s:%s " % (k[0], k[1], k[2], ddict[k][0], ddict[k][1], ddict[k][2]))
|
||||||
|
|
||||||
|
|
||||||
class interfaceRecords(semanageRecords):
|
class interfaceRecords(semanageRecords):
|
||||||
@ -1693,13 +1693,13 @@ class interfaceRecords(semanageRecords):
|
|||||||
keys.sort()
|
keys.sort()
|
||||||
|
|
||||||
if heading:
|
if heading:
|
||||||
print "%-30s %s\n" % (_("SELinux Interface"), _("Context"))
|
print("%-30s %s\n" % (_("SELinux Interface"), _("Context")))
|
||||||
if is_mls_enabled:
|
if is_mls_enabled:
|
||||||
for k in keys:
|
for k in keys:
|
||||||
print "%-30s %s:%s:%s:%s " % (k, ddict[k][0], ddict[k][1], ddict[k][2], translate(ddict[k][3], False))
|
print("%-30s %s:%s:%s:%s " % (k, ddict[k][0], ddict[k][1], ddict[k][2], translate(ddict[k][3], False)))
|
||||||
else:
|
else:
|
||||||
for k in keys:
|
for k in keys:
|
||||||
print "%-30s %s:%s:%s " % (k, ddict[k][0], ddict[k][1], ddict[k][2])
|
print("%-30s %s:%s:%s " % (k, ddict[k][0], ddict[k][1], ddict[k][2]))
|
||||||
|
|
||||||
|
|
||||||
class fcontextRecords(semanageRecords):
|
class fcontextRecords(semanageRecords):
|
||||||
@ -2048,28 +2048,28 @@ class fcontextRecords(semanageRecords):
|
|||||||
if len(keys) != 0:
|
if len(keys) != 0:
|
||||||
keys.sort()
|
keys.sort()
|
||||||
if heading:
|
if heading:
|
||||||
print "%-50s %-18s %s\n" % (_("SELinux fcontext"), _("type"), _("Context"))
|
print("%-50s %-18s %s\n" % (_("SELinux fcontext"), _("type"), _("Context")))
|
||||||
for k in keys:
|
for k in keys:
|
||||||
if fcon_dict[k]:
|
if fcon_dict[k]:
|
||||||
if is_mls_enabled:
|
if is_mls_enabled:
|
||||||
print "%-50s %-18s %s:%s:%s:%s " % (k[0], k[1], fcon_dict[k][0], fcon_dict[k][1], fcon_dict[k][2], translate(fcon_dict[k][3], False))
|
print("%-50s %-18s %s:%s:%s:%s " % (k[0], k[1], fcon_dict[k][0], fcon_dict[k][1], fcon_dict[k][2], translate(fcon_dict[k][3], False)))
|
||||||
else:
|
else:
|
||||||
print "%-50s %-18s %s:%s:%s " % (k[0], k[1], fcon_dict[k][0], fcon_dict[k][1], fcon_dict[k][2])
|
print("%-50s %-18s %s:%s:%s " % (k[0], k[1], fcon_dict[k][0], fcon_dict[k][1], fcon_dict[k][2]))
|
||||||
else:
|
else:
|
||||||
print "%-50s %-18s <<None>>" % (k[0], k[1])
|
print("%-50s %-18s <<None>>" % (k[0], k[1]))
|
||||||
|
|
||||||
if len(self.equiv_dist):
|
if len(self.equiv_dist):
|
||||||
if not locallist:
|
if not locallist:
|
||||||
if heading:
|
if heading:
|
||||||
print _("\nSELinux Distribution fcontext Equivalence \n")
|
print(_("\nSELinux Distribution fcontext Equivalence \n"))
|
||||||
for target in self.equiv_dist.keys():
|
for target in self.equiv_dist.keys():
|
||||||
print "%s = %s" % (target, self.equiv_dist[target])
|
print("%s = %s" % (target, self.equiv_dist[target]))
|
||||||
if len(self.equiv):
|
if len(self.equiv):
|
||||||
if heading:
|
if heading:
|
||||||
print _("\nSELinux Local fcontext Equivalence \n")
|
print(_("\nSELinux Local fcontext Equivalence \n"))
|
||||||
|
|
||||||
for target in self.equiv.keys():
|
for target in self.equiv.keys():
|
||||||
print "%s = %s" % (target, self.equiv[target])
|
print("%s = %s" % (target, self.equiv[target]))
|
||||||
|
|
||||||
|
|
||||||
class booleanRecords(semanageRecords):
|
class booleanRecords(semanageRecords):
|
||||||
@ -2237,7 +2237,7 @@ class booleanRecords(semanageRecords):
|
|||||||
keys = ddict.keys()
|
keys = ddict.keys()
|
||||||
for k in keys:
|
for k in keys:
|
||||||
if ddict[k]:
|
if ddict[k]:
|
||||||
print "%s=%s" % (k, ddict[k][2])
|
print("%s=%s" % (k, ddict[k][2]))
|
||||||
return
|
return
|
||||||
ddict = self.get_all(locallist)
|
ddict = self.get_all(locallist)
|
||||||
keys = ddict.keys()
|
keys = ddict.keys()
|
||||||
@ -2245,7 +2245,7 @@ class booleanRecords(semanageRecords):
|
|||||||
return
|
return
|
||||||
|
|
||||||
if heading:
|
if heading:
|
||||||
print "%-30s %s %s %s\n" % (_("SELinux boolean"), _("State"), _("Default"), _("Description"))
|
print("%-30s %s %s %s\n" % (_("SELinux boolean"), _("State"), _("Default"), _("Description")))
|
||||||
for k in keys:
|
for k in keys:
|
||||||
if ddict[k]:
|
if ddict[k]:
|
||||||
print "%-30s (%-5s,%5s) %s" % (k, on_off[selinux.security_get_boolean_active(k)], on_off[ddict[k][2]], self.get_desc(k))
|
print("%-30s (%-5s,%5s) %s" % (k, on_off[selinux.security_get_boolean_active(k)], on_off[ddict[k][2]], self.get_desc(k)))
|
||||||
|
@ -278,7 +278,7 @@ def gen_semanage_test_args(parser):
|
|||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
import selinux
|
import selinux
|
||||||
semanage_test_list = filter(lambda x: x.startswith("test_"), dir(SemanageTests))
|
semanage_test_list = [x for x in dir(SemanageTests) if x.startswith("test_")]
|
||||||
if selinux.security_getenforce() == 1:
|
if selinux.security_getenforce() == 1:
|
||||||
parser = argparse.ArgumentParser(description='Semanage unit test script')
|
parser = argparse.ArgumentParser(description='Semanage unit test script')
|
||||||
gen_semanage_test_args(parser)
|
gen_semanage_test_args(parser)
|
||||||
|
Loading…
Reference in New Issue
Block a user