Module: Proxy::OpenSCAP

Extended by:
Log
Defined in:
lib/smart_proxy_openscap/version.rb,
lib/smart_proxy_openscap/arf_html.rb,
lib/smart_proxy_openscap/arf_parser.rb,
lib/smart_proxy_openscap/fetch_file.rb,
lib/smart_proxy_openscap/storage_fs.rb,
lib/smart_proxy_openscap/openscap_api.rb,
lib/smart_proxy_openscap/openscap_lib.rb,
lib/smart_proxy_openscap/policy_guide.rb,
lib/smart_proxy_openscap/policy_parser.rb,
lib/smart_proxy_openscap/shell_wrapper.rb,
lib/smart_proxy_openscap/content_parser.rb,
lib/smart_proxy_openscap/fetch_scap_file.rb,
lib/smart_proxy_openscap/openscap_plugin.rb,
lib/smart_proxy_openscap/profiles_parser.rb,
lib/smart_proxy_openscap/spool_forwarder.rb,
lib/smart_proxy_openscap/foreman_forwarder.rb,
lib/smart_proxy_openscap/storage_fs_common.rb,
lib/smart_proxy_openscap/openscap_exception.rb,
lib/smart_proxy_openscap/openscap_import_api.rb,
lib/smart_proxy_openscap/foreman_arf_forwarder.rb,
lib/smart_proxy_openscap/openscap_html_generator.rb,
lib/smart_proxy_openscap/storage.rb,
lib/smart_proxy_openscap.rb

Defined Under Namespace

Modules: StorageFsCommon Classes: Api, ArfHtml, ArfParser, ContentParser, FetchFile, FetchScapFile, FileNotFound, ForemanArfForwarder, ForemanForwarder, ImportApi, OpenSCAPException, OpenscapHtmlGenerator, Plugin, PolicyGuide, PolicyParser, ProfilesParser, ReportDecompressError, ReportUploadError, ShellWrapper, SpoolForwarder, Storage, StorageFs, StoreCorruptedError, StoreFailedError, StoreReportError, StoreSpoolError

Constant Summary collapse

VERSION =
'0.11.0'
HTTP_ERRORS =
[
  EOFError,
  Errno::ECONNRESET,
  Errno::EINVAL,
  Errno::ECONNREFUSED,
  Net::HTTPBadResponse,
  Net::HTTPHeaderSyntaxError,
  Net::ProtocolError,
  Timeout::Error
]

Class Method Summary collapse

Class Method Details

.common_name(request) ⇒ Object

Raises:

  • (Proxy::Error::Unauthorized)


41
42
43
44
45
46
47
48
49
50
51
52
53
54
# File 'lib/smart_proxy_openscap/openscap_lib.rb', line 41

def self.common_name(request)
  client_cert = request.env['SSL_CLIENT_CERT']
  raise Proxy::Error::Unauthorized, "Client certificate required!" if client_cert.to_s.empty?

  begin
    client_cert = OpenSSL::X509::Certificate.new(client_cert)
  rescue OpenSSL::OpenSSLError => e
    raise Proxy::Error::Unauthorized, e.message
  end
  cn = client_cert.subject.to_a.detect { |name, value| name == 'CN' }
  cn = cn[1] unless cn.nil?
  raise Proxy::Error::Unauthorized, "Common Name not found in the certificate" unless cn
  cn
end

.fullpath(path = Proxy::OpenSCAP::Plugin.settings.contentdir) ⇒ Object



62
63
64
65
# File 'lib/smart_proxy_openscap/openscap_lib.rb', line 62

def self.fullpath(path = Proxy::OpenSCAP::Plugin.settings.contentdir)
  pathname = Pathname.new(path)
  pathname.relative? ? pathname.expand_path(Sinatra::Base.root).to_s : path
end

.plugin_settingsObject



32
33
34
# File 'lib/smart_proxy_openscap/openscap_lib.rb', line 32

def self.plugin_settings
  @@settings ||= OpenStruct.new(read_settings)
end

.read_settingsObject



36
37
38
39
# File 'lib/smart_proxy_openscap/openscap_lib.rb', line 36

def self.read_settings
  ::Proxy::OpenSCAP::Plugin.default_settings.merge(
    YAML.load_file(File.join(::Proxy::SETTINGS.settings_directory, ::Proxy::OpenSCAP::Plugin.settings_file)))
end

.send_spool_to_foreman(loaded_settings) ⇒ Object



56
57
58
59
60
# File 'lib/smart_proxy_openscap/openscap_lib.rb', line 56

def self.send_spool_to_foreman(loaded_settings)
  arf_dir = File.join(loaded_settings.spooldir, "/arf")
  return unless File.exist? arf_dir
  SpoolForwarder.new(loaded_settings).post_arf_from_spool(arf_dir)
end