Sha256: 50196c6d4737bcad1efb7ef8e36fd2fba21a6a1278531c24863563c5905de741

Contents?: true

Size: 1.94 KB

Versions: 25

Compression:

Stored size: 1.94 KB

Contents

# frozen_string_literal: true
#
# Author:: Davide Cavalca <dcavalca@fb.com>
# Copyright:: Copyright (c) 2020 Facebook
# License:: Apache License, Version 2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#

Ohai.plugin(:Selinux) do
  provides "selinux/status", "selinux/policy_booleans", "selinux/process_contexts", "selinux/file_contexts"
  optional true

  collect_data(:linux) do
    sestatus_path = which("sestatus")
    if sestatus_path
      sestatus = shell_out("#{sestatus_path} -v -b")

      selinux Mash.new unless selinux
      selinux[:status] ||= Mash.new
      selinux[:policy_booleans] ||= Mash.new
      selinux[:process_contexts] ||= Mash.new
      selinux[:file_contexts] ||= Mash.new
      section = nil

      sestatus.stdout.split("\n").each do |line|
        line.chomp!

        case line
        when "Policy booleans:"
          section = :policy_booleans
          next
        when "Process contexts:"
          section = :process_contexts
          next
        when "File contexts:"
          section = :file_contexts
          next
        else
          if section.nil?
            section = :status
          end
        end

        key, val = line.split(/:?\s\s+/, 2)
        next if key.nil?

        unless key.start_with?("/")
          key.downcase!
          key.tr!(" ", "_")
        end

        selinux[section][key] = val
      end
    else
      logger.debug("Plugin Selinux: Could not find sestatus. Skipping plugin.")
    end
  end
end

Version data entries

25 entries across 25 versions & 1 rubygems

Version Path
ohai-18.1.18 lib/ohai/plugins/linux/selinux.rb
ohai-17.9.4 lib/ohai/plugins/linux/selinux.rb
ohai-17.9.1 lib/ohai/plugins/linux/selinux.rb
ohai-18.1.3 lib/ohai/plugins/linux/selinux.rb
ohai-18.1.0 lib/ohai/plugins/linux/selinux.rb
ohai-16.17.2 lib/ohai/plugins/linux/selinux.rb
ohai-18.0.14 lib/ohai/plugins/linux/selinux.rb
ohai-17.9.0 lib/ohai/plugins/linux/selinux.rb
ohai-17.7.12 lib/ohai/plugins/linux/selinux.rb
ohai-16.17.0 lib/ohai/plugins/linux/selinux.rb
ohai-17.7.8 lib/ohai/plugins/linux/selinux.rb
ohai-17.7.5 lib/ohai/plugins/linux/selinux.rb
ohai-17.6.0 lib/ohai/plugins/linux/selinux.rb
ohai-17.5.2 lib/ohai/plugins/linux/selinux.rb
ohai-17.3.1 lib/ohai/plugins/linux/selinux.rb
ohai-17.1.0 lib/ohai/plugins/linux/selinux.rb
ohai-17.0.42 lib/ohai/plugins/linux/selinux.rb
ohai-16.13.0 lib/ohai/plugins/linux/selinux.rb
ohai-16.12.3 lib/ohai/plugins/linux/selinux.rb
ohai-16.10.7 lib/ohai/plugins/linux/selinux.rb