ManageIQ/manageiq

View on GitHub
app/models/mixins/verify_credentials_mixin.rb

Summary

Maintainability
A
0 mins
Test Coverage
F
43%
module VerifyCredentialsMixin
  extend ActiveSupport::Concern

  module ClassMethods
    def verify_credentials_task(userid, zone, options)
      task_opts = {
        :action => "Verify EMS Provider Credentials",
        :userid => userid
      }

      encrypt_verify_credential_params!(options)

      queue_opts = {
        :args        => [options],
        :class_name  => name,
        :method_name => "verify_credentials?",
        :queue_name  => "generic",
        :role        => "ems_operations",
        :zone        => zone
      }

      MiqTask.generic_action_with_callback(task_opts, queue_opts)
    end

    def verify_credentials?(args)
      # Prevent the connection details, including the password, from being leaked into the logs
      # and MiqQueue by only returning true/false
      !!verify_credentials(args)
    end

    private

    # Ensure that any passwords are encrypted before putting them onto the queue for any
    # DDF fields which are a password type
    def encrypt_verify_credential_params!(options)
      DDF.traverse(params_for_create) do |field|
        key_path = field[:name].try(:split, '.')
        if options.key_path?(key_path) && field[:type] == 'password'
          options.store_path(key_path, ManageIQ::Password.try_encrypt(options.fetch_path(key_path)))
        end
      end
    end
  end
end