Class: AuditViaSsh::LaunchAuditViaSsh

Inherits:
AuditViaSshState show all
Defined in:
lib/scripts/ec2/audit_via_ssh.rb

Overview

Launch the audit via SSH

Instance Attribute Summary

Attributes inherited from ScriptExecutionState

#context, #logger

Instance Method Summary collapse

Methods inherited from AuditViaSshState

load_state

Methods inherited from ScriptExecutionState

#done?, #end_state, #failed?, #initialize, #register_state_change_listener, #start_state_machine, #to_s

Methods included from StateTransitionHelper

#attach_volume, #connect, #copy_distribution, #create_fs, #create_labeled_fs, #create_snapshot, #create_volume, #create_volume_from_snapshot, #delete_snapshot, #delete_volume, #detach_volume, #determine_file, #disable_ssh_tty, #disconnect, #ec2_handler, #ec2_handler=, #enable_ssh_tty, #get_aws_kernel_image_aki, #get_aws_region_from_endpoint, #get_partition_fs_type, #get_partition_fs_type_and_label, #get_partition_label, #get_root_device_name, #get_root_partition_fs_type, #get_root_partition_fs_type_and_label, #get_root_partition_label, #get_root_volume_id, #launch_instance, #local_decompress_and_dump_file_to_device, #local_dump_and_compress_device_to_file, #mount_fs, #mount_fs_old, #register_snapshot, #remote_copy, #remote_copy_old, #remote_handler, #remote_handler=, #retrieve_instances, #retrieve_security_groups, #shut_down_instance, #snapshot_accessible, #start_instance, #stop_instance, #unmount_fs, #upload_file, #zip_volume

Methods included from VCloudTransitionHelper

#retrieve_ip_services

Constructor Details

This class inherits a constructor from ScriptExecutionState

Instance Method Details

#enterObject



106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
# File 'lib/scripts/ec2/audit_via_ssh.rb', line 106

def enter
  audit = @context[:audit]
  #audit = Audit.new(:benchmark => @context[:benchmark_file], :attachment_dir => @context[:tmp_dir],
  #                  :connection_type => :ssh, 
  #                  :connection_params => {:user => @context[:ssh_user],
  #                                         :keys => @context[:ssh_key_file],
  #                                         :host => @context[:public_dns_name],
  #                                         :paranoid => false}, 
                                           #:timeout => 120,
                                           #:verbose => :warn},
  #                                         :logger => nil)
  audit.start(false)
  @context[:result][:audit_test] = []
  audit.results.each() {|key, value|
    if key =~ /^SSH_.*$/ || key =~ /^APACHE2_.*$/
      puts "DEBUG: Key: #{key}, Result: #{value.result}, Desc: #{value.rule.description}"
      @context[:result][:audit_test] << {:name => key, :desc => value.rule.description, :status => value.result}
      post_message("== > Test #{key}: Status: #{value.result.eql?("pass") ? "OK" : "NOK"}\n  Desc: #{value.rule.description}")
    end
  }
  CleanUpAuditViaSsh.new(@context)
end