ManageIQ/manageiq

View on GitHub
tools/miq_config_sssd_ldap/configure_selinux.rb

Summary

Maintainability
A
0 mins
Test Coverage
A
100%
require 'awesome_spawn'

module MiqConfigSssdLdap
  class ConfigureSELinuxError < StandardError; end

  class ConfigureSELinux
    attr_reader :initial_settings

    def initialize(initial_settings)
      @initial_settings = initial_settings
    end

    def configure
      LOGGER.debug("Invoked #{self.class}##{__method__}")
      enable_non_standard_ldap_port(initial_settings[:ldapport])
      establish_permission("allow_httpd_mod_auth_pam")
      establish_permission("httpd_dbus_sssd")
    end

    private

    def enable_non_standard_ldap_port(port_number)
      LOGGER.debug("Invoked #{self.class}##{__method__}(#{port_number})")
      return if %w[389 636].include?(port_number)

      params = {
        nil => "port",
        :a  => nil,
        :t  => "ldap_port_t",
        :p  => ["tcp", port_number]
      }

      result = AwesomeSpawn.run("semanage", :params => params)
      LOGGER.debug("Ran command: #{result.command_line}")

      if result.failure?
        error_message = "semanage failed with: #{result.error}"
        return if error_message.include?("already defined")

        LOGGER.fatal(error_message)
        raise ConfigureSELinuxError, error_message
      end
    end

    def establish_permission(permission_name)
      LOGGER.debug("Invoked #{self.class}##{__method__}(#{permission_name})")
      params = {:P => [permission_name, "on"]}
      result = AwesomeSpawn.run("setsebool", :params => params)
      LOGGER.debug("Ran command: #{result.command_line}")

      if result.failure?
        error_message = "setsebool failed with: #{result.error}"
        LOGGER.fatal(error_message)
        raise ConfigureSELinuxError, error_message
      end
    end
  end
end