diff options
author | James Turnbull <james@lovedthanlost.net> | 2009-05-10 19:33:01 +1000 |
---|---|---|
committer | James Turnbull <james@lovedthanlost.net> | 2009-05-10 21:51:40 +1000 |
commit | f94abfccfd6687a88f62703e4005c28ec04467a1 (patch) | |
tree | 0af4d8df67f207dd3752650b7b0bb6ef2d8604fe /lib/facter/selinux.rb | |
parent | 8768371511d081555db63a89be7c1a17a69f4e0c (diff) | |
download | facter-f94abfccfd6687a88f62703e4005c28ec04467a1.tar.gz facter-f94abfccfd6687a88f62703e4005c28ec04467a1.tar.xz facter-f94abfccfd6687a88f62703e4005c28ec04467a1.zip |
Fixed #1327 - Added SELinux facts
Diffstat (limited to 'lib/facter/selinux.rb')
-rw-r--r-- | lib/facter/selinux.rb | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/lib/facter/selinux.rb b/lib/facter/selinux.rb new file mode 100644 index 0000000..0e9637d --- /dev/null +++ b/lib/facter/selinux.rb @@ -0,0 +1,45 @@ +# Fact for SElinux +# Written by immerda admin team (admin(at)immerda.ch) + +Facter.add("selinux") do + confine :kernel => :linux + + setcode do + result = "false" + if FileTest.exists?("/selinux/enforce") + if FileTest.exists?("/proc/self/attr/current") + if (File.read("/proc/self/attr/current") != "kernel\0") + result = "true" + end + end + end + result + end +end + +Facter.add("selinux_enforced") do + confine :selinux => :true + + setcode do + result = "false" + if FileTest.exists?("/selinux/enforce") and File.read("/selinux/enforce") =~ /1/i + result = "true" + end + result + end +end + +Facter.add("selinux_policyversion") do + confine :selinux => :true + setcode do + File.read("/selinux/policyvers") + end +end + +Facter.add("selinux_mode") do + confine :selinux => :true + setcode do + %x{/usr/sbin/sestatus | /bin/grep "Policy from config file:" | awk '{print $5}'} + end +end + |