ManageIQ/manageiq

View on GitHub
app/models/manageiq/providers/embedded_ansible/automation_manager/machine_credential.rb

Summary

Maintainability
A
25 mins
Test Coverage
A
93%
class ManageIQ::Providers::EmbeddedAnsible::AutomationManager::MachineCredential < ManageIQ::Providers::EmbeddedAnsible::AutomationManager::Credential
  COMMON_ATTRIBUTES = [
    {
      :component  => 'text-field',
      :label      => N_('Username'),
      :helperText => N_('Username for this credential'),
      :name       => 'userid',
      :id         => 'userid',
    },
    {
      :component  => 'password-field',
      :label      => N_('Password'),
      :helperText => N_('Password for this credential'),
      :name       => 'password',
      :id         => 'password',
      :type       => 'password',
    },
  ].freeze

  EXTRA_ATTRIBUTES = [
    {
      :component      => 'password-field',
      :label          => N_('Private key'),
      :helperText     => N_('RSA or DSA private key to be used instead of password'),
      :componentClass => 'textarea',
      :name           => 'ssh_key_data',
      :id             => 'ssh_key_data',
      :type           => 'password',
    },
    {
      :component  => 'password-field',
      :label      => N_('Private key passphrase'),
      :helperText => N_('Passphrase to unlock SSH private key if encrypted'),
      :name       => 'ssh_key_unlock',
      :id         => 'ssh_key_unlock',
      :maxLength  => 1024,
      :type       => 'password',
    },
    {
      :component    => 'select',
      :label        => N_('Privilege Escalation'),
      :helperText   => N_('Privilege escalation method'),
      :name         => 'become_method',
      :id           => 'become_method',
      :isClearable  => true,
      :clearedValue => nil,
      :placeholder  => N_('None'),
      :simpleValue  => true,
      :options      => %w[
        sudo
        su
        pbrum
        pfexec
        doas
        dzdo
        pmrun
        runas
        enable
        ksu
        sesu
        machinectl
      ].map { |item| {:label => item, :value => item} },
    },
    {
      :component  => 'text-field',
      :label      => N_('Privilege Escalation Username'),
      :helperText => N_('Privilege escalation username'),
      :name       => 'become_username',
      :id         => 'become_username',
      :maxLength  => 1024,
    },
    {
      :component  => 'password-field',
      :label      => N_('Privilege Escalation Password'),
      :helperText => N_('Password for privilege escalation method'),
      :name       => 'become_password',
      :id         => 'become_password',
      :maxLength  => 1024,
      :type       => 'password',
    },
  ].freeze

  API_ATTRIBUTES = (COMMON_ATTRIBUTES + EXTRA_ATTRIBUTES).freeze

  API_OPTIONS = {
    :label      => N_('Machine'),
    :type       => 'machine',
    :attributes => API_ATTRIBUTES
  }.freeze

  alias ssh_key_data   auth_key
  alias ssh_key_unlock auth_key_password

  before_validation :ensure_newline_for_ssh_key

  def self.display_name(number = 1)
    n_('Credential (Machine)', 'Credentials (Machine)', number)
  end

  def self.params_to_attributes(params)
    attrs = super.dup

    attrs[:auth_key]          = attrs.delete(:ssh_key_data)   if attrs.key?(:ssh_key_data)
    attrs[:auth_key_password] = attrs.delete(:ssh_key_unlock) if attrs.key?(:ssh_key_unlock)

    attrs
  end
end