Class: VagrantPlugins::SshConfigManager::Action::Up

Inherits:
Object
  • Object
show all
Defined in:
lib/vagrant_ssh_config_manager/action/up.rb

Instance Method Summary collapse

Constructor Details

#initialize(app, env) ⇒ Up

Returns a new instance of Up.



7
8
9
10
11
# File 'lib/vagrant_ssh_config_manager/action/up.rb', line 7

def initialize(app, env)
  @app = app
  @env = env
  @logger = Log4r::Logger.new('vagrant::plugins::ssh_config_manager::action::up')
end

Instance Method Details

#call(env) ⇒ Object



13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
# File 'lib/vagrant_ssh_config_manager/action/up.rb', line 13

def call(env)
  # Call the next middleware first
  @app.call(env)

  # Only proceed if the machine is running and SSH is ready
  machine = env[:machine]
  return unless machine
  return unless machine.state.id == :running

  # Check if plugin is enabled
  config = machine.config.sshconfigmanager
  return unless config&.enabled

  @logger.info("SSH Config Manager: Creating SSH config file for machine: #{machine.name}")

  # Handle SSH config file creation
  handle_ssh_config_creation(machine, config)
rescue StandardError => e
  @logger.error("SSH Config Manager: Error in Up action: #{e.message}")
  @logger.debug("Backtrace: #{e.backtrace.join("\n")}")
end